hr_attendance/security/hr_attendance_security.xml

132 lines
6.5 KiB
XML
Raw Permalink Normal View History

<?xml version="1.0" encoding="utf-8"?>
<odoo>
<record model="ir.module.category" id="base.module_category_human_resources_attendances">
<field name="sequence">14</field>
</record>
<record id="group_hr_attendance_own_reader" model="res.groups">
<field name="name">User: Read his own attendances</field>
<field name="category_id" ref="base.module_category_hidden"/>
<field name="comment">The user will have access to his own attendances on his user / employee profile</field>
</record>
<record id="base.group_user" model="res.groups">
<field name="implied_ids" eval="[(4, ref('hr_attendance.group_hr_attendance_own_reader'))]"/>
</record>
<record id="group_hr_attendance_officer" model="res.groups">
<field name="name">Officer: Manage attendances</field>
<field name="category_id" ref="base.module_category_hidden"/>
<field name="comment">The user will have access to the attendance records and reporting of employees where he's set as an attendance manager</field>
</record>
<record id="group_hr_attendance_manager" model="res.groups">
<field name="name">Administrator</field>
<field name="category_id" ref="base.module_category_human_resources_attendances"/>
<field name="users" eval="[(4, ref('base.user_root')), (4, ref('base.user_admin'))]"/>
<field name="implied_ids" eval="[(4, ref('hr_attendance.group_hr_attendance_officer'))]"/>
</record>
<record id="base.default_user" model="res.users">
<field name="groups_id" eval="[(4, ref('hr_attendance.group_hr_attendance_manager'))]"/>
</record>
<data noupdate="1">
<!-- Attendances -->
<record id="hr_attendance_rule_employee_company" model="ir.rule">
<field name="name">Employee multi company rule</field>
<field name="model_id" ref="model_hr_attendance"/>
<field name="global" eval="True"/>
<field name="domain_force">['|',('employee_id.company_id','=',False),('employee_id.company_id', 'in', company_ids)]</field>
</record>
<record id="hr_attendance_rule_attendance_admin" model="ir.rule">
<field name="name">Attendance Administrator: Full access</field>
<field name="model_id" ref="model_hr_attendance"/>
<field name="domain_force">[(1,'=',1)]</field>
<field name="groups" eval="[(4, ref('hr_attendance.group_hr_attendance_manager'))]"/>
</record>
<record id="hr_attendance_rule_attendance_manager_restrict" model="ir.rule">
<field name="name">Attendance Officer: Restrict Attendances to managed employees</field>
<field name="model_id" ref="model_hr_attendance"/>
<field name="domain_force">
[
'|',
'&amp;',
('employee_id.attendance_manager_id', '=', user.id),
('employee_id.user_id', '=', user.id),
'&amp;',
('employee_id.user_id', '!=', user.id),
('employee_id.attendance_manager_id', '=', user.id)
]
</field>
<field name="groups" eval="[(4, ref('hr_attendance.group_hr_attendance_officer'))]"/>
<field name="perm_create" eval="1"/>
<field name="perm_write" eval="1"/>
<field name="perm_unlink" eval="1"/>
<field name="perm_read" eval="1"/>
</record>
<record id="hr_attendance_rule_attendance_simple_user" model="ir.rule">
<field name="name">Attendance base user: Read his own attendances in other apps</field>
<field name="model_id" ref="model_hr_attendance"/>
<field name="domain_force">[('employee_id.user_id', '=', user.id)]</field>
<field name="groups" eval="[(4, ref('hr_attendance.group_hr_attendance_own_reader'))]"/>
<field name="perm_create" eval="0"/>
<field name="perm_write" eval="0"/>
<field name="perm_unlink" eval="0"/>
<field name="perm_read" eval="1"/>
</record>
<!-- Overtime -->
<record id="hr_attendance_overtime_rule_employee_company" model="ir.rule">
<field name="name">Employee multi company rule</field>
<field name="model_id" ref="model_hr_attendance_overtime"/>
<field name="global" eval="True"/>
<field name="domain_force">['|',('employee_id.company_id','=',False),('employee_id.company_id', 'in', company_ids)]</field>
</record>
<record id="hr_attendance_rule_attendance_officer_overtime_restrict" model="ir.rule">
<field name="name">Attendance Officer: Restrict Overtime to managed employees</field>
<field name="model_id" ref="model_hr_attendance_overtime"/>
<field name="domain_force">
[
'|',
'&amp;',
('employee_id.attendance_manager_id', '=', user.id),
('employee_id.user_id', '=', user.id),
'&amp;',
('employee_id.user_id', '!=', user.id),
('employee_id.attendance_manager_id', '=', user.id)
]
</field>
<field name="groups" eval="[(4, ref('hr_attendance.group_hr_attendance_officer'))]"/>
<field name="perm_create" eval="1"/>
<field name="perm_write" eval="1"/>
<field name="perm_unlink" eval="1"/>
<field name="perm_read" eval="1"/>
</record>
<record id="hr_attendance_rule_attendance_overtime_admin" model="ir.rule">
<field name="name">Attendance Admin: full access</field>
<field name="model_id" ref="model_hr_attendance_overtime"/>
<field name="domain_force">[(1,'=',1)]</field>
<field name="groups" eval="[(4, ref('hr_attendance.group_hr_attendance_manager'))]"/>
</record>
<record id="hr_attendance_rule_attendance_overtime_simple_user" model="ir.rule">
<field name="name">Attendance base user: Read his own overtime</field>
<field name="model_id" ref="model_hr_attendance_overtime"/>
<field name="domain_force">[('employee_id.user_id', '=', user.id)]</field>
<field name="groups" eval="[(4, ref('hr_attendance.group_hr_attendance_own_reader'))]"/>
<field name="perm_create" eval="0"/>
<field name="perm_write" eval="0"/>
<field name="perm_unlink" eval="0"/>
<field name="perm_read" eval="1"/>
</record>
</data>
</odoo>