Generate Odoo Security Rules and Access Control
Helps you write correct Odoo ir.model.access.csv entries and ir.rule XML record rules for model-level and record-level security, including debugging access
Why it matters
Automate the creation and debugging of Odoo's model-level and record-level security rules. Ensure correct access control for users and modules, preventing unauthorized data access.
Outcomes
What it gets done
Generate correct `ir.model.access.csv` entries.
Create `ir.rule` domain-based record rules.
Debug 'Access Denied' errors with proposed fixes.
Implement multi-company record visibility.
Install
Add it to your toolbox
Run in your project directory:
curl -fsSL https://spark.entire.vc/get/ag-odoo-security-rules | bash Capabilities
What this skill does
Reviews permissions and logs to flag unauthorized activity.
Traces errors to their root cause and suggests fixes.
Writes source code or scripts from a description.
Writes and executes SQL or NoSQL queries on databases.
Overview
Odoo Security Rules
What it does
This skill helps you write correct `ir.model.access.csv` entries and `ir.rule` domain-based record rules for Odoo security. It covers model-level access (who can read/write which models) and record-level rules (which records a user can see).
How it connects
Use this skill when setting up access rights for custom modules, restricting records so users only see their own data or their company's data, debugging access denied errors, or implementing multi-company record visibility rules.
Source README
Odoo Security Rules
Overview
Security in Odoo is managed at two levels: model-level access (who can read/write which models) and record-level rules (which records a user can see). This skill helps you write correct ir.model.access.csv entries and ir.rule domain-based record rules.
When to Use This Skill
- Setting up access rights for a new custom module.
- Restricting records so users only see their own data or their company's data.
- Debugging "Access Denied" or "You are not allowed to access" errors.
- Implementing multi-company record visibility rules.
How It Works
- Activate: Mention
@odoo-security-rulesand describe the access scenario. - Generate: Get correct CSV access lines and XML record rules.
- Debug: Paste an access error and get a diagnosis with the fix.
Examples
Example 1: ir.model.access.csv
id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink
access_hospital_patient_user,hospital.patient.user,model_hospital_patient,base.group_user,1,0,0,0
access_hospital_patient_manager,hospital.patient.manager,model_hospital_patient,base.group_erp_manager,1,1,1,1
Note: Use
base.group_erp_managerfor ERP managers, notbase.group_system- that group is reserved for Odoo's technical superusers. Always create a custom group for module-specific manager roles:<record id="group_hospital_manager" model="res.groups"> <field name="name">Hospital Manager</field> <field name="category_id" ref="base.module_category_hidden"/> </record>
Example 2: Record Rule - Users See Only Their Own Records
<record id="rule_hospital_patient_own" model="ir.rule">
<field name="name">Hospital Patient: Own Records Only</field>
<field name="model_id" ref="model_hospital_patient"/>
<field name="domain_force">[('create_uid', '=', user.id)]</field>
<field name="groups" eval="[(4, ref('base.group_user'))]"/>
<field name="perm_read" eval="True"/>
<field name="perm_write" eval="True"/>
<field name="perm_create" eval="True"/>
<field name="perm_unlink" eval="False"/>
</record>
Important: If you omit
<field name="groups">, the rule becomes global and applies to ALL users, including admins. Always assign a group unless you explicitly intend a global restriction.
Example 3: Multi-Company Record Rule
<record id="rule_hospital_patient_company" model="ir.rule">
<field name="name">Hospital Patient: Multi-Company</field>
<field name="model_id" ref="model_hospital_patient"/>
<field name="domain_force">
['|', ('company_id', '=', False),
('company_id', 'in', company_ids)]
</field>
<field name="groups" eval="[(4, ref('base.group_user'))]"/>
</record>
Best Practices
- ✅ Do: Start with the most restrictive access and open up as needed.
- ✅ Do: Use
company_ids(plural) in multi-company rules - it includes all companies the user belongs to. - ✅ Do: Test rules using a non-admin user in debug mode -
sudo()bypasses all record rules entirely. - ✅ Do: Create dedicated security groups per module rather than reusing core Odoo groups.
- ❌ Don't: Give
perm_unlink = 1to regular users unless deletion is explicitly required by the business process. - ❌ Don't: Leave
group_idblank inir.model.access.csvunless you intend to grant public (unauthenticated) access. - ❌ Don't: Use
base.group_systemfor module managers - that grants full technical access including server configurations.
Limitations
- Does not cover field-level access control (
ir.model.fieldsread/write restrictions) - those require custom OWL or Python overrides. - Portal and public user access rules have additional nuances not fully covered here; test carefully with
base.group_portal. - Record rules are bypassed by
sudo()- any code running in superuser context ignores allir.ruleentries. - Does not cover row-level security via PostgreSQL (RLS) - Odoo manages all security at the ORM layer.
Discussion
Questions & comments · 0
Sign In Sign in to leave a comment.