人类逻辑与OpenERP逻辑,困难时期。
非常简单的想法:项目用户应该能够查看/阅读所有任务,但只能编辑/编写他分配的任务。
简单,在project.task上记录规则:
不,第二条规则会覆盖第一条规则。
做真正简单的事情,是我还是真的很复杂? 我错过了什么吗?
由于
编辑:为了澄清我的观点,这里是我的规则1& 2:
<record model="ir.rule" id="project_task_user_rule">
<field name="name">Project/task: user: read others tasks</field>
<field name="model_id" ref="project.model_project_task"/>
<field name="domain_force">[('user_id','not in',[user.id])]</field>
<field name="groups" eval="[(4,ref('project.group_project_user'))]"/>
<field eval="1" name="perm_read"/>
<field eval="0" name="perm_write"/>
<field eval="0" name="perm_create"/>
<field eval="0" name="perm_unlink"/>
</record>
<record model="ir.rule" id="project_task_user_rule">
<field name="name">Project/task: user: RW rights on his tasks</field>
<field name="model_id" ref="project.model_project_task"/>
<field name="domain_force">[('user_id','=',user.id)]</field>
<field name="groups" eval="[(4,ref('project.group_project_user'))]"/>
<field eval="1" name="perm_read"/>
<field eval="1" name="perm_write"/>
<field eval="0" name="perm_create"/>
<field eval="0" name="perm_unlink"/>
</record>
在这种情况下,用户只能看到他的任务并可以修改它们。 如果我将第二条规则放在第一条规则上,则用户可以查看所有任务,但无法编辑任何任务,也不能编辑自己的任务。
答案 0 :(得分:0)
不,他们不会互相覆盖,他们是累积的:
访问规则引擎会在任何可用规则中查找要执行的操作(read
,create
,write
,unlink
)的肯定权限。
在OCA模块project_baseuser
中使用相同的方法来限制帮助台最终用户仅对草稿/新任务具有写访问权限。一旦任务移动到开始阶段,只有项目用户可以编辑它们。请参阅:https://github.com/OCA/project/blob/29caef1cd8029e755c2c27d54541202d52b9c744/project_baseuser/security/project_security.xml#L79
答案 1 :(得分:0)
好的,在编辑我的帖子时,我发现我犯了一个巨大的初学者错误......
如果你查看我给我的记录的id,它们是相同的,因此第二次在读取时覆盖第一个。 有两个不同的ID,当然现在有效!
谢谢@Daniel Reis,不知何故让我意识到了这一点。
干杯!