Odoo中的RPC调用
odoo原生支持外部系统调用,通过XMLRPC服务对外提供接口,本章将介绍如何在外部系统中使用RPC接口对odoo进行调用。
XML-RPC
XML-RPC是什么
xmlrpc是一种远程过程调用方法,使用http协议传递xml格式的数据,客户端可以在远程服务器上调用带参数的方法获取结构化的数据。
XML-RPC和Webservice是什么关系?
Webservice是一种抽象的概念描述,具体的实现方式可以有多种,例如REST\SOAP\XML-RPC。SOAP是在XML-RPC的基础上加入了新的功能发展而来的。
Odoo中的XML-RPC
odoo中内置了XML-RPC接口,可以在原生系统中直接调用。
XML-RPC中切换公司
默认情况下,XML-RPC只能工作在默认的公司下,当操作其他公司的对象时就会出现权限问题。此时我们希望使用with_company解决这个问题,但是XML-RPC中的使用方式与Python后端的代码中有所不同。
import xmlrpc.client
url = "http://odoomommy.com"
common = xmlrpc.client.ServerProxy('{}/xmlrpc/2/common'.format(url))
common.version()
uid = common.authenticate("odoo", "admin", "admin_1234", {})
models = xmlrpc.client.ServerProxy('{}/xmlrpc/2/object'.format(url))
models.execute_kw("odoo", uid, "admin_1234", 'product.template', 'write', [[15327], {
'standard_price': "678"
}])
models.execute_kw("odoo", uid, "admin_1234", 'product.template', 'write', [[15327], {
'standard_price': "789"
}], {'context': {'with_company': 2}})
我们要切换公司的时候需要把参数传入到context参数中。
同样地,如果我们希望查询到某条被归档的数据,那么我们可以使用下面的方式进行查询:
product_templates = models.execute_kw(db,user_id,password,'product.template','search',[[('default_code','=','NZMKCGKG23')]],{
'context':{
'active_test': False
}
})
JsonRPC
不止于XML-RPC, odoo原生还支持了JSONRPC的方式进行远程调用。下面我们看一下如何使用Json-RPC进行远程调用。
登录
data='{
"jsonrpc": "2.0",
"method": "call",
"params": {
"service": "common",
"method": "authenticate",
"args": [
"erp",
"admin",
"HkGTVrq4pQzKhRN",
{}
]
}
}'
curl https://erp.hhglobal.co.nz/jsonrpc -H "Content-Type:application/json" -d $data
---------------
{"jsonrpc": "2.0", "id": null, "result": 2}
搜索
data='{
"jsonrpc": "2.0",
"method": "call",
"params": {
"service": "object",
"method": "execute",
"args": [
"erp",
2,
"password",
"product.category",
"search",
[]
]
}
}'
curl https://erp.hhglobal.co.nz/jsonrpc -H "Content-Type:application/json" -d $data
-------------
{"jsonrpc": "2.0", "id": null, "result": [1, 29, 30, 35, 43, 36, 10, 38, 15, 56, 17, 61, 16, 9, 39, 70, 3, 34, 45, 14, 42, 76, 27, 64, 62, 13, 11, 18, 21, 22, 24, 23, 19, 66, 41, 2, 57, 65, 31, 67, 33, 32, 72]}
OdooRPC
第三方库OdooRPC是一个利用jsonrpc实现的远程调用库.
安装方法:
pip install odoorpc
使用方法:
# 使用账号密码登录
odoo = odoorpc.ODOO(host=HOST,port=PORT)
odoo.login(DB,USER,PASSWORD)
#初始化对象
sale_obj = odoo.env['sale.order']
order_ids = sale_obj.search([])
order = sale_obj.browse(order_ids)
orders.write({"price":213.0})
需要注意的是, 这里的search方法返回的结果是记录的ids而不是记录集。
odoorpc给我们提供一种外部脚本化的操作方式, 其中一个有效的场景就是在不同的odoo版本间进行数据迁移. 笔者提供不同版本间的基础数据的迁移服务, 有需要的同学可以联系笔者洽谈.