當前位置: 首頁>>代碼示例>>Python>>正文


Python exceptions.ValidationError方法代碼示例

本文整理匯總了Python中openerp.exceptions.ValidationError方法的典型用法代碼示例。如果您正苦於以下問題:Python exceptions.ValidationError方法的具體用法?Python exceptions.ValidationError怎麽用?Python exceptions.ValidationError使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在openerp.exceptions的用法示例。


在下文中一共展示了exceptions.ValidationError方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: create

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def create(self, vals):
        product_tmpl = self.env['product.template'].browse(
            vals.get('product_tmpl_id')).exists()
        if product_tmpl:
            default_val_ids = product_tmpl.attribute_line_ids.filtered(
                lambda l: l.default_val).mapped('default_val').ids
            value_ids = vals.get('value_ids')
            if value_ids:
                default_val_ids += value_ids[0][2]
            valid_conf = product_tmpl.validate_configuration(
                default_val_ids, final=False)
            # TODO: Remove if cond when PR with raise error on github is merged
            if not valid_conf:
                raise ValidationError(
                    _('Default values provided generate an invalid '
                      'configuration')
                )
            vals.update({'value_ids': [(6, 0, default_val_ids)]})
        return super(ProductConfigSession, self).create(vals) 
開發者ID:pledra,項目名稱:odoo-product-configurator,代碼行數:21,代碼來源:product_config.py

示例2: unique_attribute

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def unique_attribute(self):
        if len(self.cfg_session_id.custom_value_ids.filtered(
                lambda x: x.attribute_id == self.attribute_id)) > 1:
            raise ValidationError(
                _("Configuration cannot have the same value inserted twice")
            )

    # @api.constrains('cfg_session_id.value_ids')
    # def custom_only(self):
    #     """Verify that the attribute_id is not present in vals as well"""
    #     import ipdb;ipdb.set_trace()
    #     if self.cfg_session_id.value_ids.filtered(
    #             lambda x: x.attribute_id == self.attribute_id):
    #         raise ValidationError(
    #             _("Configuration cannot have a selected option and a custom "
    #               "value with the same attribute")
    #         ) 
開發者ID:pledra,項目名稱:odoo-product-configurator,代碼行數:19,代碼來源:product_config.py

示例3: validate_custom_val

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def validate_custom_val(self, val):
        """ Pass in a desired custom value and ensure it is valid.
        Probaly should check type, etc, but let's assume fine for the moment.
        """
        self.ensure_one()
        if self.custom_type in ('int', 'float'):
            minv = self.min_val
            maxv = self.max_val
            val = literal_eval(val)
            if minv and maxv and (val < minv or val > maxv):
                raise ValidationError(
                    _("Selected custom value '%s' must be between %s and %s"
                        % (self.name, self.min_val, self.max_val))
                )
            elif minv and val < minv:
                raise ValidationError(
                    _("Selected custom value '%s' must be at least %s" %
                        (self.name, self.min_val))
                )
            elif maxv and val > maxv:
                raise ValidationError(
                    _("Selected custom value '%s' must be lower than %s" %
                        (self.name, self.max_val + 1))
                ) 
開發者ID:pledra,項目名稱:odoo-product-configurator,代碼行數:26,代碼來源:product_attribute.py

示例4: _check_ident_num

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def _check_ident_num(self):
        """
        This function checks the content of the identification fields: Type of
        document and number cannot be empty.
        There are two document types that permit letters in the identification
        field: 21 and 41. The rest does not permit any letters
        @return: void
        """
        for item in self:
            if item.doctype is not 1:
                if item.xidentification is not False and \
                                item.doctype != 21 and \
                                item.doctype != 41:
                    if re.match("^[0-9]+$", item.xidentification) is None:
                        msg = _('Error! Identification number can only '
                                'have numbers')
                        raise exceptions.ValidationError(msg) 
開發者ID:dkrimmer84,項目名稱:l10n_co_res_partner,代碼行數:19,代碼來源:l10n_co_res_partner.py

示例5: _check_names

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def _check_names(self):
        """
        Double check: Although validation is checked within the frontend (xml)
        we check it again to get sure
        """
        if self.is_company is True:
            if self.personType is 1:
                if self.x_name1 is False or self.x_name1 == '':
                    msg = _('Error! Please enter the persons name')
                    raise exceptions.ValidationError(msg)
            elif self.personType is 2:
                if self.companyName is False:
                    msg = _('Error! Please enter the companys name')
                    raise exceptions.ValidationError(msg)
        elif self.type == 'delivery':
            if self.pos_name is False or self.pos_name == '':
                msg = _('Error! Please enter the persons name')
                raise exceptions.ValidationError(msg)
        else:
            if self.x_name1 is False or self.x_name1 == '':
                msg = _('Error! Please enter the name of the person')
                raise exceptions.ValidationError(msg) 
開發者ID:dkrimmer84,項目名稱:l10n_co_res_partner,代碼行數:24,代碼來源:l10n_co_res_partner.py

示例6: _check_librarian_not_in_asstlibrarian

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def _check_librarian_not_in_asstlibrarian(self):
	for r in self:
		if r.librarian_id in r.asstlibrarian_id:
			raise exceptions.ValidationError("An assistant librarian can't be a librarian") 
開發者ID:mpasha96,項目名稱:Odoo-9-Library-Management-Module,代碼行數:6,代碼來源:models.py

示例7: create

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def create(self, values):
        _logger.info('wx.corpuser create >>> %s'%str(values))
        if not (values.get('weixinid', '') or  values.get('mobile', '') or values.get('email', '') ):
            raise ValidationError('??????????????????')
        from_subscribe = False
        if '_from_subscribe' in values:
            from_subscribe = True
            values.pop('_from_subscribe')
        obj = super(wx_corpuser, self).create(values)
        if not from_subscribe:
            arg = {}
            for k,v in values.items():
                if v!=False and k in ['mobile', 'email', 'weixinid', 'gender']:
                    arg[k] = v
            arg['department'] = 1
            if 'weixinid' in arg:
                arg['weixin_id'] = arg.pop('weixinid')
            corp_client.client.user.create(values['userid'], values['name'], **arg)
        return obj 
開發者ID:JoneXiong,項目名稱:oejia_wx,代碼行數:21,代碼來源:user_models.py

示例8: send_signal_to_pabiweb

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def send_signal_to_pabiweb(self, signal, comment=''):
        alfresco = self._get_alfresco_connect()
        if alfresco is False:
            return False
        arg = {
            'action': signal,
            'by': self.env.user.login,
            'comment': comment,
        }
        result = False
        if self.is_employee_advance:
            arg.update({'avNo': self.number})
            result = alfresco.brw.action(arg)
        else:
            arg.update({'exNo': self.number})
            result = alfresco.use.action(arg)
        if not result['success']:
            raise ValidationError(
                _("Can't send data to PabiWeb : %s" % (result['message'],))
            )
        return result 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:23,代碼來源:expense_web_interface.py

示例9: send_comment_to_pabiweb

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def send_comment_to_pabiweb(self, status, status_th, comment):
        alfresco = self._get_alfresco_connect()
        if alfresco is False:
            return False
        arg = {
            'by': self.env.user.login,
            'task': 'Finance',
            'task_th': u'???????',
            'status': status,
            'status_th': status_th,
            'comment': comment,
        }
        result = False
        if self.is_employee_advance:
            arg.update({'avNo': self.number})
            result = alfresco.brw.history(arg)
        else:
            arg.update({'exNo': self.number})
            result = alfresco.use.history(arg)
        if not result['success']:
            raise ValidationError(
                _("Can't send data to PabiWeb : %s" % (result['message'],))
            )
        return result 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:26,代碼來源:expense_web_interface.py

示例10: _send_comment_onchange_date_value

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def _send_comment_onchange_date_value(self):
        try:
            for voucher in self:
                if not voucher.date_value:
                    continue
                status = u'Payment Approved'
                status_th = u'???????????'
                comment = u'??????????/??? %s' % (voucher.date_value,)
                for voucher in self:
                    for line in voucher.line_ids:
                        exp = line.move_line_id.invoice.expense_id
                        if not exp:
                            continue
                        exp.send_comment_to_pabiweb(status,
                                                    status_th,
                                                    comment)
        except Exception, e:
            self._cr.rollback()
            raise ValidationError(str(e))
        return 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:22,代碼來源:account_voucher.py

示例11: action_done

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def action_done(self):
        for rec in self:
            assets = rec.request_asset_ids.mapped('asset_id')
            assets.validate_asset_to_request()
            if self.env.user != rec.approve_user_id:
                raise ValidationError(
                    _('Only %s can approve this document!') %
                    (rec.approve_user_id.name,))
            for line in rec.request_asset_ids:
                line.asset_id.write({
                    'doc_request_id': rec.id,
                    'date_request': rec.date_request,
                    'responsible_user_id': rec.responsible_user_id.id,
                    'location_id': line.location_id.id,
                    'room': line.room,
                })
        self.write({'state': 'done'}) 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:19,代碼來源:asset_request.py

示例12: write

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def write(self, vals):
        Status = self.env['account.asset.status']
        # Status follow state
        if 'state' in vals and vals.get('state', False):
            if vals.get('state') == 'close':
                vals['status'] = Status.search([('code', '=', 'expire')]).id
            if vals.get('state') == 'open':
                vals['status'] = Status.search([('code', '=', 'normal')]).id
            if vals.get('state') == 'draft':
                vals['status'] = Status.search([('code', '=', 'cancel')]).id
            # For removed, the state will be set in remove wizard
        # Validate status change must be within status map
        elif 'status' in vals and vals.get('status', False):
            status = Status.browse(vals.get('status'))
            for asset in self:
                if status.map_state != asset.state:
                    raise ValidationError(_('Invalid change of asset status'))
        return super(AccountAsset, self).write(vals) 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:20,代碼來源:asset.py

示例13: create

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def create(self, vals):
        # Case Parent Assets, AIT, AUC, ATM
        type = vals.get('type', False)
        ptype = vals.get('parent_type', False)
        if ptype and type == 'view':
            sequence_code = 'parent.asset.%s' % (ptype)
            vals['name'] = self.env['ir.sequence'].next_by_code(sequence_code)
        if vals.get('code', '/') == '/':
            # Normal Case
            product_id = vals.get('product_id', False)
            if product_id:
                product = self.env['product.product'].browse(product_id)
                sequence = product.sequence_id
                if not sequence:
                    raise ValidationError(
                        _('No asset sequence setup for selected product!'))
                vals['code'] = self.env['ir.sequence'].next_by_id(sequence.id)
        asset = super(AccountAsset, self).create(vals)
        asset.update_related_dimension(vals)
        # Init Salvage Value from Category
        if self._context.get('create_asset_from_move_line', False):
            if not asset.profile_id.no_depreciation:
                asset.salvage_value = asset.profile_id.salvage_value
        return asset 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:26,代碼來源:asset.py

示例14: _move_budget_check

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def _move_budget_check(self):
        Budget = self.env['account.budget']
        AnalyticLine = self.env['account.analytic.line']
        for move in self:
            if move.state == 'posted':
                analytic_lines = AnalyticLine.search([
                    ('move_id', 'in', move.line_id._ids)
                ])
                if not analytic_lines:
                    continue
                doc_date = move.date
                doc_lines = Budget.convert_lines_to_doc_lines(analytic_lines)
                res = Budget.post_commit_budget_check(doc_date, doc_lines)
                if not res['budget_ok']:
                    raise ValidationError(res['message'])
        return True 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:18,代碼來源:account.py

示例15: _validate_account_user_type_vs_org

# 需要導入模塊: from openerp import exceptions [as 別名]
# 或者: from openerp.exceptions import ValidationError [as 別名]
def _validate_account_user_type_vs_org(self):
        """
        * Profit & Loss must have org_id
        * Balance Sheet must not have org_id
        """
        error1 = _('%s is Balance Sheet\nOrg is NOT required!')
        error2 = _('%s is Profit & Loss\nOrg is required!')
        for move_line in self:
            err_msg = False
            report_type = move_line.account_id.user_type.report_type
            # 1) Balance Sheet but have Org
            if report_type in ('asset', 'liability') and move_line.org_id:
                err_msg = error1 % (move_line.account_id.name_get()[0][1],)
            # 2) Profit & Loss but no Org
            if report_type not in ('asset', 'liability') and \
                    not move_line.org_id:
                err_msg = error2 % (move_line.account_id.name_get()[0][1],)
            if err_msg:
                raise ValidationError(err_msg) 
開發者ID:pabi2,項目名稱:NOTUSE_pb2_pabi,代碼行數:21,代碼來源:account.py


注:本文中的openerp.exceptions.ValidationError方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。