odoo原生权限编写方式:
根据用户组分配权限
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_sale_order,sale.order,model_sale_order,sales_team.group_sale_salesman,1,1,
1,0
access_sale_order_manager,sale.order.manager,model_sale_order,sales_team.group_sa
le_manager,1,1,1,1
<record id="group_sale_salesman" model="res.groups">
<field name="name">User: Own Documents Only</field><field name="category_id" ref="base.module_category_sales_sales"/><field name="implied_ids" eval="[(4, ref('base.group_user'))]"/><field name="comment">the user will have access to his own data in the sales
application.</field>
</record>
<record id="group_sale_salesman_all_leads" model="res.groups"><field name="name">User: All Documents</field><field name="category_id" ref="base.module_category_sales_sales"/><field name="implied_ids" eval="[(4, ref('group_sale_salesman'))]"/><field name="comment">the user will have access to all records of everyone in
the sales application.</field>
</record>
<record id="group_sale_manager" model="res.groups"><field name="name">Administrator</field><field name="comment">the user will have an access to the sales configuration
as well as statistic reports.</field><field name="category_id" ref="base.module_category_sales_sales"/><field name="implied_ids" eval="[(4,
ref('group_sale_salesman_all_leads'))]"/><field name="users" eval="[(4, ref('base.user_root')),
(4,ref('base.user_admin'))]"/>
</record>
在menu、button等的groups中设置权限
<menuitem id="menu_sale_quotations" action="action_quotations_with_onboarding"groups="sales_team.group_sale_salesman" sequence="10"/>
细分权限编写方式:
官方的权限分得不是很细,按照业务的需求,我们可以把权限细分。
比如按照增删改查去划分权限,甚至是页面上的按钮、page页:
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_121,mes.production.line.change,model_mes_production_line_change,mes_produc
tion_line_change_read,1,0,0,0
access_122,mes.production.line.change,model_mes_production_line_change,mes_produc
tion_line_change_write,0,1,0,0
access_123,mes.production.line.change,model_mes_production_line_change,mes_produc
tion_line_change_create,0,0,1,0
access_124,mes.production.line.change,model_mes_production_line_change,mes_produc
tion_line_change_unlink,0,0,0,1
<!--增删改查-->
<record model="res.groups" id="mes_production_line_change_read"><field name="name">Production Line Change Read</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
<record model="res.groups" id="mes_production_line_change_write"><field name="name">Production Line Change Write</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
<record model="res.groups" id="mes_production_line_change_create"><field name="name">Production Line Change Create</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
<record model="res.groups" id="mes_production_line_change_unlink"><field name="name">Production Line Change Unlink</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
<!--按钮-->
<record model="res.groups" id="mes_production_line_btn_action_submit"><field name="name">Production Line Change btn Submit</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
这样,我们就可以单独分配增删改查等权限
</record>
...
<record model="res.groups" id="mes_production_line_btn_action_cancel"><field name="name">Production Line Change btn Cancel</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
<button name="action_submit" string="Submit Application" states="draft"class="oe_highlight" confirm="Are you sure you want to submit?"
type="object"groups="mes_base.mes_production_line_btn_action_submit" />
<!--page-->
<record model="res.groups" id="mes_production_ready_page_order_dispatch"><field name="name">Production Ready Page Work Order Dispatch</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
...
<record model="res.groups" id="mes_production_ready_page_worksite_record"><field name="name">Production Ready Page Worksite Record</field><field name="category_id" ref="mes_base.module_category_HHY_MES"/><field name="users" eval="[(4, ref('base.user_root')), (4,
ref('base.user_admin'))]"/>
</record>
<page name="order_dispatch_ids" string="Work Order Dispatch"groups="mes_base.mes_production_ready_page_order_dispatch">
</page>
这样,我们就可以单独分配增删改查等权限