即使一个人,也要活得像军队一样!

正常的列表视图做为菜单动作直接打开的话,直接点击是跳转当前动作下的表单视图;还有一种是做为表单视图One2many、Many2many类型的嵌入式列表视图,直接点击打开Dialog窗口展示表单视图,一些特殊的需求场景下往往希望只将信息展示到列表即止,不用更多的详细互动。
两种方式:

阅读全文 »

如题,Odoo开发过程中,有时遇到一些需求需要在页面中快速配置一些信息数据,此时就需要用到配置面板, 如下图所示:
配置面板

**主要分三步:
一是定义配置面板的模板
二是定义路由渲染模板
三是给指定模型视图绑定模板路由

阅读全文 »

场景: odoo原生模块翻译不正确,我们想在新模块通过po文件进行翻译且不动原生模块。

方式一:xml视图继承。
这也是最常规的,通过xpath定位找到相关翻译,进行添加属性,或者替换等操作,此时我们的模块可以导出po文件。
此操作不仅适用于字段,还适用于div等标签属性的翻译。

方式二:python后台字段继承。
此方式适用于硬编码,不需要po文件。直接重写字段的定义。

阅读全文 »

Docker容器基本使用

容器基本命令

启动容器: docker run Image [command] [arg...]

启动交互式容器: docker run -i -t Image /bin/bash

自定义容器名: docker run --name=自定义名 -i -t Image /bin/bash

阅读全文 »

Odoo权限机制

除手动通过自定义模式管理权限外,Odoo还提供了两种数据驱动的机制来管理或限制对数据的访问。

这两种机制都通过组来与具体用户相关联:一个用户可属于多个组,安全机制与组进行关联,进而应用对用户应用安全机制。

1
2
3
用户---拥有----> 1个或多个组 ----拥有---->多个权限

通过组,用户既可以拥有权限
阅读全文 »

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
 
[options]

addons_path = opt\odoo\addons ;addons模块的查找路径

admin_passwd = admin ;管理员主控密码(用于创建、还原和备份数据库等操作)

auto_reload = None ;自动重载?

csv_internal_sep = , ;用于导入导出的csv文件的默认分隔符

data_dir = data ; data目录, 用于存放session信息、附件

db_host = 127.0.0.1 ; 数据库主机名

db_maxconn = 64 ; 数据库的最大连接数

db_name = odoo ; 指定要使用的数据库名

db_password = odoo ; 数据库用户密码

db_port = 5432 ; 数据库端口号

db_template = template1 ; 创建新数据库时使用的数据库模板

db_user = odoo ; 数据库用户名

dbfilter = .* ; 过滤要显示的数据库名称

debug_mode = False ; 是否为调试模式

demo = {} ; 哪些模块加载demo数据?

email_from = False ; 用于发送邮件的邮箱地址

import_partial = ; 在导入大量数据时使用这个选项, 如果在导入期间程序宕机, 你可以在当前状态下继续。指定一个存储中间导入状态的文件名。

limit_memory_hard = None ; 一个处理器允许使用的最大物理内存

limit_memory_soft = None ; 一个处理器允许使用的最大虚拟内存

limit_request = None ; 一个处理器接受的最大请求数

limit_time_cpu = None ; 一个请求最多占用多少处理器时间

limit_time_real = None ; 一个请求允许的最长实时时间

list_db = True ; 是否允许显示数据库列表

log_db = False ; 是否将log写入db的ir_logging表

log_handler = :INFO ; 可以是一组module:log_level对, 默认值是:INFO(表示所有模块的默认日志级别为INFO级别)

log_level = info ; 日志的级别, 可选值包括debug_rpc_answer, debug_rpc, debug, debug_sql, info, warn, error, critical

logfile = openerp-server.log ; 指定用来存储日志的文件

logrotate = False ; 是否按天存放日志

longpolling_port = 8072 ; 长连接池使用的端口号?

max_cron_threads = 2 ; 处理当前计划任务的最大线程数

osv_memory_age_limit = 1.0 ; 强制保存在virtual osv_memory表中的记录的最长时间,以小时为单位

osv_memory_count_limit = False ; 强制一个virtual osv_memory表的最大记录数

pg_path = runtime/pgsql/bin ; 数据库可执行文件的路径

pidfile = None ; 存储服务器pid的文件名

proxy_mode = False ; 是否使用反向代理模式

reportgz = False ; 是否压缩报表

secure_cert_file = server.cert ; 指定用于SSL连接的证书文件

secure_pkey_file = server.pkey ; 指定用于SSL连接的主密钥文件

server_wide_modules = None ; server范围的模块,以逗号分隔

smtp_password = False ; 发送邮件的SMTP用户密码

smtp_port = 25 ; SMTP端口号

smtp_server = localhost ; SMTP服务器名

smtp_ssl = False ; SMTP服务器是否支持SSL协议

smtp_user = False ; 发送邮件的SMTP用户名

syslog = False ; 是否把日志发送给系统日志服务器

test_commit = False ; 是否提交YAML或XML测试造成的数据库更改

test_enable = False ; 是否允许YAML和单元测试

test_file = False ; YML测试文件

test_report_directory = False ; 报表的范例的存放位置

timezone = False ; 为系统提供一个参照的时区

translate_modules = ['all'] ; 哪些模块可翻译, 默认为all

unaccent = False ; 是否使用数据库的unaccent功能

without_demo = False ; 在安装时哪些模块不加载演示数据

workers = None ; 要使用的处理器数量

xmlrpc = True ; 是否禁止使用XML-RPC协议

xmlrpc_interface = ; 指定使用XML-RPC协议的IP地址,为空时表示绑定到现有IP

xmlrpc_port = 8069 ; XML-RPC协议使用的TCP端口

xmlrpcs = True ; 是否禁止使用XML-RPC安全协议