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

第三方库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版本间进行数据迁移. 笔者提供不同版本间的基础数据的迁移服务, 有需要的同学可以联系笔者洽谈.

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]}

results matching ""

    No results matching ""