192 lines
8.9 KiB
XML
Executable File
192 lines
8.9 KiB
XML
Executable File
<?xml version="1.0" encoding="UTF-8" ?>
|
|
<!--
|
|
|
|
Copyright 2017-2019 MuK IT GmbH
|
|
Copyright 2020 Creu Blanca
|
|
Copyright 2021 Tecnativa - Víctor Martínez
|
|
Copyright 2024 Subteno - Timothée Vannier (https://www.subteno.com).
|
|
License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl).
|
|
|
|
-->
|
|
<odoo>
|
|
<record id="category_dms_security" model="ir.module.category">
|
|
<field name="name">Documents</field>
|
|
</record>
|
|
<record id="group_dms_user" model="res.groups">
|
|
<field name="name">User</field>
|
|
<field name="category_id" ref="category_dms_security" />
|
|
<field name="implied_ids" eval="[(4, ref('base.group_user'))]" />
|
|
</record>
|
|
<record id="group_dms_manager" model="res.groups">
|
|
<field name="name">Manager</field>
|
|
<field name="implied_ids" eval="[(4, ref('group_dms_user'))]" />
|
|
<field name="category_id" ref="category_dms_security" />
|
|
<field
|
|
name="users"
|
|
eval="[(4, ref('base.user_root')), (4, ref('base.user_admin'))]"
|
|
/>
|
|
</record>
|
|
<record id="rule_multi_company_storage" model="ir.rule">
|
|
<field name="name">DMS Storage multi-company</field>
|
|
<field name="model_id" ref="model_dms_storage" />
|
|
<field name="global" eval="True" />
|
|
<field
|
|
name="domain_force"
|
|
>['|',('company_id','=',False),('company_id','in',company_ids)]</field>
|
|
</record>
|
|
<record id="rule_multi_company_directory" model="ir.rule">
|
|
<field name="name">DMS Directory multi-company</field>
|
|
<field name="model_id" ref="model_dms_directory" />
|
|
<field name="global" eval="True" />
|
|
<field
|
|
name="domain_force"
|
|
>['|',('company_id','=',False),('company_id','in',company_ids)]</field>
|
|
</record>
|
|
<record id="rule_multi_company_file" model="ir.rule">
|
|
<field name="name">File multi-company</field>
|
|
<field name="model_id" ref="model_dms_file" />
|
|
<field name="global" eval="True" />
|
|
<field
|
|
name="domain_force"
|
|
>['|',('company_id','=',False),('company_id','in',company_ids)]</field>
|
|
</record>
|
|
<record id="rule_file_locked" model="ir.rule">
|
|
<field name="name">Locked files are only modified by locker user.</field>
|
|
<field name="model_id" ref="model_dms_file" />
|
|
<field name="groups" eval="[(4, ref('base.group_user'))]" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="1" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field
|
|
name="domain_force"
|
|
>['|', ('locked_by', '=', False), ('locked_by', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_security_groups_user" model="ir.rule">
|
|
<field name="name">DMS users can only edit and delete their own groups.</field>
|
|
<field name="model_id" ref="model_dms_access_group" />
|
|
<field name="groups" eval="[(4, ref('group_dms_user'))]" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field name="domain_force">[('create_uid','=',user.id)]</field>
|
|
</record>
|
|
<record id="rule_security_groups_manager" model="ir.rule">
|
|
<field name="name">DMS Managers can edit and delete all groups.</field>
|
|
<field name="model_id" ref="model_dms_access_group" />
|
|
<field name="groups" eval="[(4, ref('group_dms_manager'))]" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field name="domain_force">[(1 ,'=', 1)]</field>
|
|
</record>
|
|
<!-- Forbid lower groups access to hidden storage -->
|
|
<record id="rule_forbid_hidden_storage" model="ir.rule">
|
|
<field name="name">Basic users cannot access hidden storage</field>
|
|
<field name="model_id" ref="model_dms_storage" />
|
|
<field
|
|
name="groups"
|
|
eval="[(4, ref('base.group_portal')), (4, ref('group_dms_user'))]"
|
|
/>
|
|
<field name="perm_read" eval="1" />
|
|
<field name="perm_create" eval="1" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field name="domain_force">[('is_hidden', '=', False)]</field>
|
|
</record>
|
|
<record id="rule_allow_hidden_storage" model="ir.rule">
|
|
<field name="name">Managers can access hidden storage</field>
|
|
<field name="model_id" ref="model_dms_storage" />
|
|
<field name="groups" eval="[(4, ref('group_dms_manager'))]" />
|
|
<field name="perm_read" eval="1" />
|
|
<field name="perm_create" eval="1" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field name="domain_force">[('is_hidden', '=', True)]</field>
|
|
</record>
|
|
<!-- These rules leverage computed permission management -->
|
|
<record id="rule_directory_computed_create" model="ir.rule">
|
|
<field name="name">Apply computed create permissions.</field>
|
|
<field name="model_id" ref="model_dms_directory" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="1" />
|
|
<field name="perm_write" eval="0" />
|
|
<field name="perm_unlink" eval="0" />
|
|
<field name="domain_force">[('permission_create', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_directory_computed_read" model="ir.rule">
|
|
<field name="name">Apply computed read permissions.</field>
|
|
<field name="model_id" ref="model_dms_directory" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="1" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="0" />
|
|
<field name="perm_unlink" eval="0" />
|
|
<field name="domain_force">[('permission_read', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_directory_computed_unlink" model="ir.rule">
|
|
<field name="name">Apply computed unlink permissions.</field>
|
|
<field name="model_id" ref="model_dms_directory" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="0" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field name="domain_force">[('permission_unlink', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_directory_computed_write" model="ir.rule">
|
|
<field name="name">Apply computed write permissions.</field>
|
|
<field name="model_id" ref="model_dms_directory" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="0" />
|
|
<field name="domain_force">[('permission_write', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_file_computed_create" model="ir.rule">
|
|
<field name="name">Apply computed create permissions.</field>
|
|
<field name="model_id" ref="model_dms_file" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="1" />
|
|
<field name="perm_write" eval="0" />
|
|
<field name="perm_unlink" eval="0" />
|
|
<field name="domain_force">[('permission_create', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_file_computed_read" model="ir.rule">
|
|
<field name="name">Apply computed read permissions.</field>
|
|
<field name="model_id" ref="model_dms_file" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="1" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="0" />
|
|
<field name="perm_unlink" eval="0" />
|
|
<field name="domain_force">[('permission_read', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_file_computed_unlink" model="ir.rule">
|
|
<field name="name">Apply computed unlink permissions.</field>
|
|
<field name="model_id" ref="model_dms_file" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="0" />
|
|
<field name="perm_unlink" eval="1" />
|
|
<field name="domain_force">[('permission_unlink', '=', user.id)]</field>
|
|
</record>
|
|
<record id="rule_file_computed_write" model="ir.rule">
|
|
<field name="name">Apply computed write permissions.</field>
|
|
<field name="model_id" ref="model_dms_file" />
|
|
<field name="global" eval="True" />
|
|
<field name="perm_read" eval="0" />
|
|
<field name="perm_create" eval="0" />
|
|
<field name="perm_write" eval="1" />
|
|
<field name="perm_unlink" eval="0" />
|
|
<field name="domain_force">[('permission_write', '=', user.id)]</field>
|
|
</record>
|
|
</odoo>
|