odoo权限管理
Odoo的权限的核心是权限组(res_groups)。对每个权限组,可以设置权限组的菜单表示,对象表示,记录规则表示,字段表示。
1.菜单/对象级别
设置哪些人可以访问哪些菜单/对象,对象的访问权限包括创建、读、写、删除。
2.记录级别
设置哪些人可以访问哪些记录,也就是设置表的查询条件。
3.字段级别
设置表中的字段的访问权限。
4.工作流级别
在工作流的每一步迁移中,设置哪些角色允许触发本迁移
菜单/对象级别:
1
2
3
4
5
|
模块下 security 目录有两个文件:xxx_security.xml、ir.model.access.csv。 其中: xxx_security.xml文件定义组和组对菜单的访问权限, ir.model.access.csv定义组对对象的权限矩阵。<br><br> |
1
|
<span style = " padding: 0px !important; border-radius: 0px !important; background: none !important; border: 0px !important; bottom: auto !important; float: none !important; height: auto !important; left: auto !important; line-height: 1.8em !important; outline: 0px !important; overflow: visible !important; position: static !important; right: auto !important; top: auto !important; vertical-align: baseline !important; width: auto !important; box-sizing: content-box !important; font-family: Consolas, "Bitstream Vera Sans Mono", "Courier New", Courier, monospace !important; min-height: auto !important;">>x_security.xml文件:< / span> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
<data noupdate = "0" > <record model = "ir.module.category" id = "module_category_test" > <field name = "name" >测试< / field> < / record> <record model = "res.groups" id = "group_test_user" > <field name = "name" >测试用户< / field> <field name = "category_id" ref = "module_category_test" / > < / record> <record model = "res.groups" id = "group_test_manager" > <field name = "name" >测试管理< / field> <field name = "implied_ids" eval = "[(4, ref('group_test_user'))]" / > <field name = "category_id" ref = "module_category_test" / > < / record> < / data> |
Noupdate 表示,当模块升级时是否更新本条数据。
对于demo 数据,通常设置成noupdate=”1”,即不更新,不指定noupdate 的话,默认值是noupdate=”0”。
category_id表示:
group_test_user和group_test_manager属于module_category_test分组,并且只能选择其中一个。
ir.model.access.csv 文件:
示例:
id name model_id:id group_id:id perm_read perm_write perm_create perm_unlink
access_xxx xxxxx model_website_menu base.group_website_designer 1 1 1 1
model_id:id 对应的对象模型,
写法示例:website.model_website_config_settings
如果内容本身在website模块中则可以省略website.
后面则为模型的name将”.”替换成”-“的结果,在前面加model_
group_id:id 哪个组
perm_read、perm_write、perm_create、perm_unlink 增删改查权限。1 有权限 0 无权限
记录规则表示:
记录规则是一个记录模型”ir.rule”,关联到一个模型。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<record id = "stock_picking_multi_company_rule" model = "ir.rule" > <field name = "name" >stock.picking multi - company< / field> <field name = "model_id" ref = "stock.model_stock_picking" / > <field name = "global" eval = "True" / > <field name = "active" eval = "False" / > <field name = "domain_force" >[ '|' , '|' , ( 'company_id' , '=' , False ), ( 'company_id' , 'child_of' ,[user.company_id. id ]),( 'company_id' , 'in' ,[c. id for c in user.company_ids])]< / field> < / record> <record id = "product_template_public" model = "ir.rule" > <field name = "name" >Public product template< / field> <field name = "model_id" ref = "product.model_product_template" / > <field name = "domain_force" >[( 'website_published' , '=' , True ), ( "sale_ok" , "=" , True )]< / field> <field name = "groups" eval = "[(4, ref('base.group_public')), (4, ref('base.group_portal'))]" / > <field name = "perm_read" eval = "True" / > <field name = "perm_write" eval = "False" / > <field name = "perm_create" eval = "False" / > <field name = "perm_unlink" eval = "False" / > < / record> Domain_force表示自定义Domain 表达式,用于过滤条件,含义是只能访问符合本过滤条件的记录。这里过滤条件是操作人必须是当前用户。 |
字段表示 :
字段表示权限可以指定权限组能访问记录里的哪个字段,可以在视图和对象上指定字段访问权限。
在视图上指定字段访问权限:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<field name = "arch" type = "xml" > <form string = "Scheduled Products" > <group col = "4" > <field name = "name" / > <field name = "product_id" / > <field name = "product_qty" / > <field name = "product_uom" groups = "product.group_uom" / > <field name = "product_uos_qty" groups = "product.group_uos" / > <field name = "product_uos" groups = "product.group_uos" / > < / group> < / form> < / field> 在字段对象定义时指定字段访问权限: _columns = { "gengo_private_key" : fields.text( "Gengo Private Key" , copy = False , groups = "base.group_system" ), "gengo_public_key" : fields.text( "Gengo Public Key" , copy = False , groups = "base.group_user" ), "gengo_comment" : fields.text( "Comments" , help = "This comment will be automatically be enclosed in each an every request sent to Gengo" , groups = "base.group_user" ), "gengo_auto_approve" : fields.boolean( "Auto Approve Translation ?" , help = "Jobs are Automatically Approved by Gengo." , groups = "base.group_user" ), "gengo_sandbox" : fields.boolean( "Sandbox Mode" , help = "Check this box if you're using the sandbox mode of Gengo, mainly used for testing purpose." ), } |
1
|
<span style = " padding: 0px !important; border-radius: 0px !important; background: none !important; border: 0px !important; bottom: auto !important; float: none !important; height: auto !important; left: auto !important; line-height: 1.8em !important; outline: 0px !important; overflow: visible !important; position: static !important; right: auto !important; top: auto !important; vertical-align: baseline !important; width: auto !important; box-sizing: content-box !important; font-family: Consolas, "Bitstream Vera Sans Mono", "Courier New", Courier, monospace !important; min-height: auto !important;">>隐藏的常用技巧:< / span> |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
* 直接隐藏 <group name = "owner" position = "attributes" > <attribute name = "invisible" > True < / attribute> < / group> * 满足某些条件的隐藏 <xpath expr = "//field[@name='parent_id']" position = 'attributes' > <attribute name = "attrs" >{ 'invisible' : [( 'passenger' , '=' , True )]}< / attribute> < / xpath> <group col = "4" string = '旅客信息' attrs = "{'invisible': [('supplier','=', True)]}" >< / group> * 通过组来隐藏 <xpath expr = "//field[@name='type']" position = "attributes" > <attribute name = "groups" >base.group_no_one< / attribute> < / xpath> * 菜单的隐藏 <record model = "ir.ui.menu" id = "crm.menu_crm_opportunities" > <field eval = "[(6,0, [ref('base.group_no_one'),])]" name = "groups_id" / > < / record> |
odoo权限管理的更多相关文章
- ODOO权限管理,在两个方面设置权限
转载参考https://zhuanlan.zhihu.com/p/29130388 在odoo中新建两个用户user1,user2 新建用户 建完了用户,记得编辑用户,设置密码. 然后以user1用户 ...
- odoo权限管理(二.记录管理)
规则保存在ir.rule模型表里,需要设置关联某个模型,关联很多组,访问权限控制和domian. 通过domain_force过滤出的一些记录来执行约束. 例子:经理只能删除状态为'cancel'的客 ...
- odoo开发笔记 -- odoo权限管理
odoo框架 整体权限可以分为4个级别: (1) 菜单级别: 不属于指定菜单所包含组的用,看不到相应菜单.不安全,只是隐藏菜单,若用户知道菜单ID,仍然可以通过指定URL访问(2) 对象级别: 对某个 ...
- odoo权限机制
转两篇关于权限的2篇文章,加深这方面的认识.注:后面附有原作者地址,希望不构成侵权. 第一篇:http://www.cnblogs.com/dancesir/p/6994030.html Odoo的权 ...
- Odoo权限控制
转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9278734.html 一:Odoo中的权限设置主要有以下5种 1)菜单.报表的访问权限 Odoo可以设置菜单项 ...
- Odoo权限控制详解
转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/10826105.html 一:Odoo中的权限设置主要有以下5种 1)菜单.报表的访问权限 Odoo可以设置菜 ...
- Android权限管理之RxPermission解决Android 6.0 适配问题
前言: 上篇重点学习了Android 6.0的运行时权限,今天还是围绕着Android 6.0权限适配来总结学习,这里主要介绍一下我们公司解决Android 6.0权限适配的方案:RxJava+RxP ...
- Android权限管理之Android 6.0运行时权限及解决办法
前言: 今天还是围绕着最近面试的一个热门话题Android 6.0权限适配来总结学习,其实Android 6.0权限适配我们公司是在今年5月份才开始做,算是比较晚的吧,不过现在Android 6.0以 ...
- Android权限管理之Permission权限机制及使用
前言: 最近突然喜欢上一句诗:"宠辱不惊,看庭前花开花落:去留无意,望天空云卷云舒." 哈哈~,这个和今天的主题无关,最近只要不学习总觉得生活中少了点什么,所以想着围绕着最近面试过 ...
随机推荐
- RxSwift之路 2#如何开始
RxSwift之路 2#如何开始 第一步当然是把项目clone到本地,github地址:https://github.com/ReactiveX/RxSwift. 官方文档 学习的第一手资源当然是项目 ...
- cocos2d-x 重力感应
本文没你想象的那么,,复杂.事实上就是通过重力感应控制个小球移动而已. 先看头文件: #ifndef __HELLOWORLD_SCENE_H__ #define __HELLOWORLD_SCENE ...
- 前端异常监控 - BadJS
前端异常监控 - BadJS 简介:BadJS 是 web 前端异常监控解决方案,提供一种 web 页面的脚本错误监控.上报.统计.查看等系统化的跟踪解决方案.目前BadJS覆盖了腾讯课堂.公众号.邮 ...
- 【网络编程】——ne-snmp开发实例1
net-snmp扩展有多种方式,在此只介绍两种——动态库扩展,静态库扩展. 在做net-snmp开发之前,首先确定net-snmp相关的软件是否安装. rpm -qa | grep snmp net- ...
- 卷积、矩阵乘积、高斯模糊滤波(降噪)、空域计算(2D卷积计算)、频域计算(FFT)的理解
矩阵乘积:对应行列对应元素相乘的和组成新的矩阵 两个矩阵的乘法仅当第一个矩阵A的列数和另一个矩阵B的行数相等时才能定义.如A是m×n矩阵和B是n×p矩阵,它们的乘积C是一个m×p矩阵 并将此乘积记为: ...
- CentOS 配置集群机器之间SSH免密码登录
SSH 为 Secure Shell 的缩写,由 IETF 的网络小组(Network Working Group)所制定:SSH 为建立在应用层和传输层基础上的安全协议.SSH 是目前较可靠,专为远 ...
- linux选择sdb sdb4 fat32 还是sda分区
fat32是怎么混到它们中的sda,sdb,sdc是你的第一块,第二块,第三块硬盘sda1,sda2,sda5是你第一块硬盘中的第一块分区,2块,5块分区fat32,ext2,ext3,ext4是你的 ...
- Cisco VTP中继协议配置
VTP协议: VLAN中继协议,VTP,VLAN TRUNKING PROTOCOL,是CISCO专用协议,大多数交换机都支持该协议.VTP负责在VTP域内同步VLAN信息, 这样就不必在每个交换上配 ...
- jq ajax post body raw传json
$.ajax( { url: '', 'data': JSON.stringify({ }), 'type': 'POST', 'processData': false, 'contentType': ...
- file_name[:-4]
file_name: chair_0001.off file_name[:-4] : chair_0001