Odoo安装教程13-创建新的插件模块之业务逻辑层
业务逻辑层
业务逻辑层编写应用的业务规则,如验证和自动计算。现在我们来为按钮添加逻辑,通过在模型
Python 类中编写方法来实现。
添加业务逻辑
上文中我们在 Book 表单中添加了一个按钮,用于检查 ISBN 是否有效。现代 ISBN 包含 13位数字,最后一位是由前 12 位计算所得的检查位。我们无需深入到算法的细节,这里是一个实现验证的 Python 方法。应当在 class Book(…)中进行添加:
@api.multi
def _check_isbn(self):
self.ensure_one()
isbn = self.isbn.replace('-', '') # 为保持兼容性自行添加
digits = [int(x) for x in isbn if x.isdigit()]
if len(digits) == 13:
ponderations = [1, 3] * 6
terms = [a * b for a,b in zip(digits[:12], ponderations)]
remain = sum(terms) % 10
check = 10 - remain if remain !=0 else 0
return digits[-1] == check
图书模型的 button_check_isbn()方法应使用该函数来验证 ISBN 字段中的数字,如果验证失
败,应向用户显示警告信息。
首先要导入 Odoo API 库,添加对应的 import 及 Odoo Warning 异常。这需要编辑library_book.py 文件修改前两行为:
from odoo import api, fields, models
from odoo.exceptions import Warning
然后还是在 models/library_book.py 文件 Book 类中加入:
@api.multi
def button_check_isbn(self):
for book in self:
if not book.isbn:
raise Warning('Please provide an ISBN for %s' % book.name)
if book.isbn and not book._check_isbn():
raise Warning('%s is an invalid ISBN' % book.isbn)
return True
对于记录的逻辑,我们使用@api.multi 装饰器。此处 self 表示一个记录集,然后我们遍历每一条记录。其实@api.multi 装饰器可以不写,因为这是模型方法的默认值。这里保留以示清晰。代码遍历所有已选图书,对于每本书,如果 ISBN 有值,则检查有效性,若无值,则向用户抛出一条警告消息。
模型方法无需返回值,但此处需至少返回 True 值。因为不是所有 XML-RPC 客户端实现都支持None/Null 空值,这种情况若返回空值则会导致抛出错误。此时可更新模块并再次运行测试,添加–test-enable 参数来确定测试是否通过。也可以在线测试,进入 Book 表单使用正确和错误的ISBN 点击按钮进行测试。