Odoo14 rpc
odoo14中rpc调用分为两种。
一种是外部调用rpc来访问odoo数据,这个时候你需要登录授权。
另一种是我们自己编写的widget小部件或者自定义视图时候通过js通过rpc去获取数据。
这里说的是第二种rpc的使用。
上代码:
//调用res.users中的自定义的get_userform_action方法
this._rpc({
model: 'res.users',
method: 'get_userform_action',
args: [[data.val]]//这里就是python函数声明里的*args,当你的方法不是model方法也不是model_create方法的时候,这里一个参数传的是当前model(res.users)的记录id,它会查询id结果作为self去调用get_userform_action
}).then(function (result){
self.do_action(result);
}); //查询数据的方法
this._rpc({
model: this.model,
method: 'read_group',
domain: [],
fields: ['color'],
groupBy: ['color'],
}).then(function (result) {
_.each(result, function (r) {
self.colorGroupData[r.color] = r.color_count;
});
});
//自定义的方法
class Users(models.AbstractModel):
_inherit = 'res.users' def get_userform_action(self):
action = self.env.ref('ship_manage.res_company_user_form_action').read()[0]
action['res_id'] = self.id
return action
1 //Python rpc参数传递源码
2 def _call_kw_model(method, self, args, kwargs):
3 context, args, kwargs = split_context(method, args, kwargs)
4 recs = self.with_context(context or {})
5 _logger.debug("call %s.%s(%s)", recs, method.__name__, Params(args, kwargs))
6 result = method(recs, *args, **kwargs)
7 return downgrade(method, result, recs, args, kwargs)
8
9
10 def _call_kw_model_create(method, self, args, kwargs):
11 # special case for method 'create'
12 context, args, kwargs = split_context(method, args, kwargs)
13 recs = self.with_context(context or {})
14 _logger.debug("call %s.%s(%s)", recs, method.__name__, Params(args, kwargs))
15 result = method(recs, *args, **kwargs)
16 return result.id if isinstance(args[0], Mapping) else result.ids
17
18
19 def _call_kw_multi(method, self, args, kwargs):
20 ids, args = args[0], args[1:]
21 context, args, kwargs = split_context(method, args, kwargs)
22 recs = self.with_context(context or {}).browse(ids)
23 _logger.debug("call %s.%s(%s)", recs, method.__name__, Params(args, kwargs))
24 result = method(recs, *args, **kwargs)
25 return downgrade(method, result, recs, args, kwargs)
26
27
28 def call_kw(model, name, args, kwargs):
29 """ Invoke the given method ``name`` on the recordset ``model``. """
30 method = getattr(type(model), name)
31 api = getattr(method, '_api', None)
32 if api == 'model'://这里将模型分成了三种走向,三种走向对参数的处理不一样
33 result = _call_kw_model(method, model, args, kwargs)
34 elif api == 'model_create':
35 result = _call_kw_model_create(method, model, args, kwargs)
36 else:
37 result = _call_kw_multi(method, model, args, kwargs)
38 model.flush()
39 return result
Odoo14 rpc的更多相关文章
- 【odoo14】第十五章、网站客户端开发
odoo的web客户端.后台是员工经常使用的地方.在第九章中,我们了解了如何使用后台提供的各种可能性.本章,我们将了解如何扩展这种可能性.其中web模块包含了我们在使用odoo中的各种交互行为. 本章 ...
- 【odoo14】第十六章、odoo web库(OWL)
odoo14引入了名为OWL(Odoo Web Library)的JavaScript框架.OWL是以组件为基础的UI框架,通过QWeb模板作为架构.OWL与传统的组件系统相比更快,并引入了一些新的特 ...
- 【odoo14】odoo 14 Development Cookbook【目录篇】
网上已经有大佬翻译过odoo12并且在翻译odoo14了.各位着急的可以自行搜索下... 这本书是为了让自己从odoo12转odoo14学习.也是为了锻炼下自己... odoo 14 Developm ...
- Odoo14 OWL 如何访问model方法和res_id
首先OWL是Odoo14版本新加的功能. 因为是新加的所以并没有太多的说明文档,包括英文板文档也没有:所以你要用它再没有更详细的文档之前你得自己去看源码. 注意owl是没有do_action函数给你跳 ...
- 从RPC开始(一)
这是一篇关于纯C++RPC框架的文章.所以,我们先看看,我们有什么? 1.一个什么都能干的C++.(前提是,你什么都干了) 2.原始的Socket接口,还是C API.还得自己去二次封装... 3.C ...
- RPC 使用中的一些注意点
最近线上碰到一点小问题,分析其原因发现是出在对 RPC 使用上的一些细节掌握不够清晰导致.很多时候我们做业务开发会把 RPC 当作黑盒机制来使用,但若不对黑盒的工作原理有个基本掌握,也容易犯一些误用的 ...
- 谈谈如何使用Netty开发实现高性能的RPC服务器
RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协议.说的再直白一点,就是客户端在不必知道 ...
- 游戏编程系列[1]--游戏编程中RPC协议的使用[3]--体验
运行环境,客户端一般编译为.Net 3.5 Unity兼容,服务端因为用了一些库,所以一般为4.0 或往上.同一份代码,建立拥有2个项目.客户端引用: WindNet.Client服务端引用: OpL ...
- python通过protobuf实现rpc
由于项目组现在用的rpc是基于google protobuf rpc协议实现的,所以花了点时间了解下protobuf rpc.rpc对于做分布式系统的人来说肯定不陌生,对于rpc不了解的童鞋可以自行g ...
随机推荐
- 【Java8新特性】Optional 类
概述 Optional 类是一个可以为null的容器对象.如果值存在则isPresent()方法会返回true,调用get()方法会返回该对象. Optional 是个容器:它可以保存类型T的值,或者 ...
- TypeScript 学习的随笔
TypeScript 是 JavaScript 的一个超集,支持 ECMAScript 6 标准 安装TypeScript npm install -g typescript 编译 tsc app.t ...
- fpn(feature-Pyramid-network)学习笔记
FPN(特征金字塔网络)学习笔记 论文 在物体检测里面,有限计算量情况下,网络的深度(对应到感受野)与 stride 通常是一对矛盾的东西,常用的网络结构对应的 stride 一般会比较大(如 32) ...
- Kubernetes Job Controller 原理和源码分析(三)
概述Job controller 的启动processNextWorkItem()核心调谐逻辑入口 - syncJob()Pod 数量管理 - manageJob()小结 概述 源码版本:kubern ...
- linux-基于tensorflow2.x的手写数字识别-基于MNIST数据集
数据集 数据集下载MNIST 首先读取数据集, 并打印相关信息 包括 图像的数量, 形状 像素的最大, 最小值 以及看一下第一张图片 path = 'MNIST/mnist.npz' with np. ...
- npm发布包以及更新包还有需要注意的几点问题(这里以发布vue插件为例)
前言 在此之前,你需要去npm官网注册一个属于自己的账号,记住自己的账户名以及密码.邮箱,后面会用的到.第一步,安装webpack简易框架 vue init webpack-simple marque ...
- node zlib压缩模块了解一下
压缩: 从index.html压缩成index.html.gz const zlib = require('zlib'); const gzip = zlib.createGzip();const f ...
- SAP 定义客户端
SCC4 定义客户端 点击新建条目按钮 Client(客户端) R 200 Client Name(客户端名称) O City(城市) R Logical system(逻辑系统) R ...
- 4种Kafka网络中断和网络分区场景分析
摘要:本文主要带来4种Kafka网络中断和网络分区场景分析. 本文分享自华为云社区<Kafka网络中断和网络分区场景分析>,作者: 中间件小哥. 以Kafka 2.7.1版本为例,依赖zk ...
- 从傅里叶级数(Fourier series)到离散傅里叶变换(Discrete Fourier transform)
从傅里叶级数(Fourier series)到离散傅里叶变换(Discrete Fourier transform) 一. 傅里叶级数(FS) 首先从最直观的开始,我们有一个信号\(x(t)\)(满足 ...