diff --git a/base_user_effective_permissions/= b/base_user_effective_permissions/= new file mode 100644 index 000000000..bbe49c094 --- /dev/null +++ b/base_user_effective_permissions/= @@ -0,0 +1,22 @@ +# Copyright 2023 Hunki Enterprises BV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl-3.0) + +{ + "name": "Effective permissions", + "summary": "Inspect effective permissions applying to a user", + "version": "16.0.1.0.0", + "development_status": "Alpha", + "category": "Technical", + "website": "https://github.com/OCA/server-backend", + "author": "Hunki Enterprises BV, Odoo Community Association (OCA)", + "maintainers": ["hbrunn"], + "license": "AGPL-3", + "depends": [ + "base", + ], + "data": [ + "security/ir.model.access.csv", + "views/res_users_effective_permission.xml", + "views/res_users.xml", + ], +} diff --git a/base_user_effective_permissions/README.rst b/base_user_effective_permissions/README.rst new file mode 100644 index 000000000..3a7748e55 --- /dev/null +++ b/base_user_effective_permissions/README.rst @@ -0,0 +1,103 @@ +===================== +Effective permissions +===================== + +.. + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! This file is generated by oca-gen-addon-readme !! + !! changes will be overwritten. !! + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + !! source digest: sha256:5108ef47acdaa695d28924080b90d6d1c72304a18c7cd09f4314fa0ecdeab7b0 + !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! + +.. |badge1| image:: https://img.shields.io/badge/maturity-Alpha-red.png + :target: https://odoo-community.org/page/development-status + :alt: Alpha +.. |badge2| image:: https://img.shields.io/badge/licence-AGPL--3-blue.png + :target: http://www.gnu.org/licenses/agpl-3.0-standalone.html + :alt: License: AGPL-3 +.. |badge3| image:: https://img.shields.io/badge/github-OCA%2Fserver--backend-lightgray.png?logo=github + :target: https://github.com/OCA/server-backend/tree/18.0/base_user_effective_permissions + :alt: OCA/server-backend +.. |badge4| image:: https://img.shields.io/badge/weblate-Translate%20me-F47D42.png + :target: https://translation.odoo-community.org/projects/server-backend-18-0/server-backend-18-0-base_user_effective_permissions + :alt: Translate me on Weblate +.. |badge5| image:: https://img.shields.io/badge/runboat-Try%20me-875A7B.png + :target: https://runboat.odoo-community.org/builds?repo=OCA/server-backend&target_branch=18.0 + :alt: Try me on Runboat + +|badge1| |badge2| |badge3| |badge4| |badge5| + +This module shows administrators a combined view of access rights and +record rules per model with expressions expanded. This is convenient for +reviewing permissions. + +.. IMPORTANT:: + This is an alpha version, the data model and design can change at any time without warning. + Only for development or testing purpose, do not use in production. + `More details on development status `_ + +**Table of contents** + +.. contents:: + :local: + +Usage +===== + +To use this module, you need to be in developer mode and: + +1. Go to Settings/Users & Companies +2. Open a user +3. Click the Effective permissions button +4. Note you can switch between the rule domains in text form or as + domain widget + +Bug Tracker +=========== + +Bugs are tracked on `GitHub Issues `_. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +`feedback `_. + +Do not contact contributors directly about support or help with technical issues. + +Credits +======= + +Authors +------- + +* Hunki Enterprises BV + +Contributors +------------ + +- Holger Brunn + (https://hunki-enterprises.com) + +Maintainers +----------- + +This module is maintained by the OCA. + +.. image:: https://odoo-community.org/logo.png + :alt: Odoo Community Association + :target: https://odoo-community.org + +OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use. + +.. |maintainer-hbrunn| image:: https://github.com/hbrunn.png?size=40px + :target: https://github.com/hbrunn + :alt: hbrunn + +Current `maintainer `__: + +|maintainer-hbrunn| + +This module is part of the `OCA/server-backend `_ project on GitHub. + +You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute. diff --git a/base_user_effective_permissions/__init__.py b/base_user_effective_permissions/__init__.py new file mode 100644 index 000000000..0650744f6 --- /dev/null +++ b/base_user_effective_permissions/__init__.py @@ -0,0 +1 @@ +from . import models diff --git a/base_user_effective_permissions/__manifest__.py b/base_user_effective_permissions/__manifest__.py new file mode 100644 index 000000000..2957d441c --- /dev/null +++ b/base_user_effective_permissions/__manifest__.py @@ -0,0 +1,22 @@ +# Copyright 2023 Hunki Enterprises BV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl-3.0) + +{ + "name": "Effective permissions", + "summary": "Inspect effective permissions applying to a user", + "version": "18.0.1.0.0", + "development_status": "Alpha", + "category": "Technical", + "website": "https://github.com/OCA/server-backend", + "author": "Hunki Enterprises BV, Odoo Community Association (OCA)", + "maintainers": ["hbrunn"], + "license": "AGPL-3", + "depends": [ + "base", + ], + "data": [ + "security/ir.model.access.csv", + "views/res_users_effective_permission.xml", + "views/res_users.xml", + ], +} diff --git a/base_user_effective_permissions/i18n/base_user_effective_permissions.pot b/base_user_effective_permissions/i18n/base_user_effective_permissions.pot new file mode 100644 index 000000000..309cdca5b --- /dev/null +++ b/base_user_effective_permissions/i18n/base_user_effective_permissions.pot @@ -0,0 +1,146 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_user_effective_permissions +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"Last-Translator: \n" +"Language-Team: \n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: \n" + +#. module: base_user_effective_permissions +#: model_terms:ir.ui.view,arch_db:base_user_effective_permissions.view_users_form +msgid "Effective permissions" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_permission +msgid "Create" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_domain_widget +msgid "Create domain" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_domain +msgid "Create restrictions" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_uid +msgid "Created by" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_date +msgid "Created on" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__unlink_permission +msgid "Delete" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__unlink_domain_widget +msgid "Delete domain" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__unlink_domain +msgid "Delete restrictions" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__display_name +msgid "Display Name" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model,name:base_user_effective_permissions.model_res_users_effective_permission +msgid "Effective permissions" +msgstr "" + +#. module: base_user_effective_permissions +#. odoo-python +#: code:addons/base_user_effective_permissions/models/res_users.py:0 +#, python-format +msgid "Effective permissions for %s" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__model_human_name +msgid "Human readable model name" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__id +msgid "ID" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission____last_update +msgid "Last Modified on" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_uid +msgid "Last Updated by" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_date +msgid "Last Updated on" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__model_id +msgid "Model" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__model_name +msgid "Model name" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__read_permission +msgid "Read" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__read_domain_widget +msgid "Read domain" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__read_domain +msgid "Read restrictions" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model,name:base_user_effective_permissions.model_res_users +msgid "User" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_permission +msgid "Write" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_domain_widget +msgid "Write domain" +msgstr "" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_domain +msgid "Write restrictions" +msgstr "" diff --git a/base_user_effective_permissions/i18n/it.po b/base_user_effective_permissions/i18n/it.po new file mode 100644 index 000000000..1cb6ca906 --- /dev/null +++ b/base_user_effective_permissions/i18n/it.po @@ -0,0 +1,149 @@ +# Translation of Odoo Server. +# This file contains the translation of the following modules: +# * base_user_effective_permissions +# +msgid "" +msgstr "" +"Project-Id-Version: Odoo Server 16.0\n" +"Report-Msgid-Bugs-To: \n" +"PO-Revision-Date: 2024-11-25 18:06+0000\n" +"Last-Translator: mymage \n" +"Language-Team: none\n" +"Language: it\n" +"MIME-Version: 1.0\n" +"Content-Type: text/plain; charset=UTF-8\n" +"Content-Transfer-Encoding: \n" +"Plural-Forms: nplurals=2; plural=n != 1;\n" +"X-Generator: Weblate 5.6.2\n" + +#. module: base_user_effective_permissions +#: model_terms:ir.ui.view,arch_db:base_user_effective_permissions.view_users_form +msgid "Effective permissions" +msgstr "Permessi effettivi" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_permission +msgid "Create" +msgstr "Crea" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_domain_widget +msgid "Create domain" +msgstr "Crea dominio" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_domain +msgid "Create restrictions" +msgstr "Crea restrizioni" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_uid +msgid "Created by" +msgstr "Creato da" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__create_date +msgid "Created on" +msgstr "Creato il" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__unlink_permission +msgid "Delete" +msgstr "Cancella" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__unlink_domain_widget +msgid "Delete domain" +msgstr "Cancella dominio" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__unlink_domain +msgid "Delete restrictions" +msgstr "Cancella restrizioni" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__display_name +msgid "Display Name" +msgstr "Nome visualizzato" + +#. module: base_user_effective_permissions +#: model:ir.model,name:base_user_effective_permissions.model_res_users_effective_permission +msgid "Effective permissions" +msgstr "Permessi effettivi" + +#. module: base_user_effective_permissions +#. odoo-python +#: code:addons/base_user_effective_permissions/models/res_users.py:0 +#, python-format +msgid "Effective permissions for %s" +msgstr "Permessi effettivi per %s" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__model_human_name +msgid "Human readable model name" +msgstr "Nome modello leggibile" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__id +msgid "ID" +msgstr "ID" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission____last_update +msgid "Last Modified on" +msgstr "Ultima modifica il" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_uid +msgid "Last Updated by" +msgstr "Ultimo aggiornamento di" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_date +msgid "Last Updated on" +msgstr "Ultimo aggiornamento il" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__model_id +msgid "Model" +msgstr "Modello" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__model_name +msgid "Model name" +msgstr "Nome modello" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__read_permission +msgid "Read" +msgstr "Leggi" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__read_domain_widget +msgid "Read domain" +msgstr "Leggi dominio" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__read_domain +msgid "Read restrictions" +msgstr "Leggi restrizioni" + +#. module: base_user_effective_permissions +#: model:ir.model,name:base_user_effective_permissions.model_res_users +msgid "User" +msgstr "Utente" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_permission +msgid "Write" +msgstr "Scrivi" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_domain_widget +msgid "Write domain" +msgstr "Scrivi dominio" + +#. module: base_user_effective_permissions +#: model:ir.model.fields,field_description:base_user_effective_permissions.field_res_users_effective_permission__write_domain +msgid "Write restrictions" +msgstr "Scrivi restrizioni" diff --git a/base_user_effective_permissions/models/__init__.py b/base_user_effective_permissions/models/__init__.py new file mode 100644 index 000000000..17d12ce8a --- /dev/null +++ b/base_user_effective_permissions/models/__init__.py @@ -0,0 +1,2 @@ +from . import res_users +from . import res_users_effective_permission diff --git a/base_user_effective_permissions/models/res_users.py b/base_user_effective_permissions/models/res_users.py new file mode 100644 index 000000000..a82229843 --- /dev/null +++ b/base_user_effective_permissions/models/res_users.py @@ -0,0 +1,23 @@ +# Copyright 2023 Hunki Enterprises BV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl-3.0) + + +from odoo import _, models + + +class ResUsers(models.Model): + _inherit = "res.users" + + def action_show_effective_permissions(self): + self.ensure_one() + permissions = self.env["res.users.effective.permission"]._generate_permissions( + self + ) + return { + "type": "ir.actions.act_window", + "name": _("Effective permissions for %s") % self.name, + "res_model": "res.users.effective.permission", + "view_mode": "list", + "views": [[False, "list"]], + "domain": [("id", "in", permissions.ids)], + } diff --git a/base_user_effective_permissions/models/res_users_effective_permission.py b/base_user_effective_permissions/models/res_users_effective_permission.py new file mode 100644 index 000000000..584635137 --- /dev/null +++ b/base_user_effective_permissions/models/res_users_effective_permission.py @@ -0,0 +1,66 @@ +# Copyright 2023 Hunki Enterprises BV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl-3.0) + + +from odoo import fields, models +from odoo.exceptions import AccessError + + +class ResUsersEffectivePermission(models.TransientModel): + _name = "res.users.effective.permission" + _order = "model_human_name" + _description = "Effective permissions" + + model_id = fields.Many2one("ir.model", string="Model") + model_name = fields.Char(related="model_id.model", string="Model name") + model_human_name = fields.Char( + related="model_id.name", string="Human readable model name" + ) + create_permission = fields.Boolean("Create") + create_domain = fields.Char("Create restrictions") + create_domain_widget = fields.Char(related="create_domain", string="Create domain") + read_permission = fields.Boolean("Read") + read_domain = fields.Char("Read restrictions") + read_domain_widget = fields.Char(related="read_domain", string="Read domain") + write_permission = fields.Boolean("Write") + write_domain = fields.Char("Write restrictions") + write_domain_widget = fields.Char(related="write_domain", string="Write domain") + unlink_permission = fields.Boolean("Delete") + unlink_domain = fields.Char("Delete restrictions") + unlink_domain_widget = fields.Char(related="unlink_domain", string="Delete domain") + + def _generate_permissions(self, user): + permissions = self.browse([]) + operations = ("create", "unlink", "read", "write") + IrRule = ( + self.env["ir.rule"] + .with_user(user) + .with_company(user.company_id) + .with_context( + allowed_company_ids=user.company_id.ids, + ) + ) + for model_record in self.env["ir.model"].search([]): + if model_record.model not in self.env: + continue + model = ( + self.env[model_record.model] + .with_user(user) + .with_company(user.company_id) + .with_context(allowed_company_ids=user.company_id.ids) + ) + vals = {"model_id": model_record.id} + ir_model_access = self.env["ir.model.access"].with_user(user) + for operation in operations: + vals[f"{operation}_permission"] = ir_model_access.check( + model._name, operation, raise_exception=False + ) + for operation in operations: + try: + vals[f"{operation}_domain"] = IrRule._compute_domain( + model._name, operation + ) + except AccessError: + vals[f"{operation}_domain"] = "[]" + permissions += self.create(vals) + return permissions diff --git a/base_user_effective_permissions/pyproject.toml b/base_user_effective_permissions/pyproject.toml new file mode 100644 index 000000000..4231d0ccc --- /dev/null +++ b/base_user_effective_permissions/pyproject.toml @@ -0,0 +1,3 @@ +[build-system] +requires = ["whool"] +build-backend = "whool.buildapi" diff --git a/base_user_effective_permissions/readme/CONTRIBUTORS.md b/base_user_effective_permissions/readme/CONTRIBUTORS.md new file mode 100644 index 000000000..19459e90a --- /dev/null +++ b/base_user_effective_permissions/readme/CONTRIBUTORS.md @@ -0,0 +1,2 @@ +- Holger Brunn \ + () diff --git a/base_user_effective_permissions/readme/DESCRIPTION.md b/base_user_effective_permissions/readme/DESCRIPTION.md new file mode 100644 index 000000000..41761c822 --- /dev/null +++ b/base_user_effective_permissions/readme/DESCRIPTION.md @@ -0,0 +1,3 @@ +This module shows administrators a combined view of access rights and +record rules per model with expressions expanded. This is convenient for +reviewing permissions. diff --git a/base_user_effective_permissions/readme/USAGE.md b/base_user_effective_permissions/readme/USAGE.md new file mode 100644 index 000000000..14657e78f --- /dev/null +++ b/base_user_effective_permissions/readme/USAGE.md @@ -0,0 +1,7 @@ +To use this module, you need to be in developer mode and: + +1. Go to Settings/Users & Companies +2. Open a user +3. Click the Effective permissions button +4. Note you can switch between the rule domains in text form or as + domain widget diff --git a/base_user_effective_permissions/security/ir.model.access.csv b/base_user_effective_permissions/security/ir.model.access.csv new file mode 100644 index 000000000..80d829858 --- /dev/null +++ b/base_user_effective_permissions/security/ir.model.access.csv @@ -0,0 +1,2 @@ +id,name,model_id:id,group_id:id,perm_read,perm_write,perm_create,perm_unlink +access_res_users_effective_permission,access_res_users_effective_permission,base_user_effective_permissions.model_res_users_effective_permission,base.group_user,1,0,1,0 diff --git a/base_user_effective_permissions/static/description/icon.png b/base_user_effective_permissions/static/description/icon.png new file mode 100644 index 000000000..3a0328b51 Binary files /dev/null and b/base_user_effective_permissions/static/description/icon.png differ diff --git a/base_user_effective_permissions/static/description/index.html b/base_user_effective_permissions/static/description/index.html new file mode 100644 index 000000000..5bbbdc065 --- /dev/null +++ b/base_user_effective_permissions/static/description/index.html @@ -0,0 +1,446 @@ + + + + + +Effective permissions + + + +
+

Effective permissions

+ + +

Alpha License: AGPL-3 OCA/server-backend Translate me on Weblate Try me on Runboat

+

This module shows administrators a combined view of access rights and +record rules per model with expressions expanded. This is convenient for +reviewing permissions.

+
+

Important

+

This is an alpha version, the data model and design can change at any time without warning. +Only for development or testing purpose, do not use in production. +More details on development status

+
+

Table of contents

+ +
+

Usage

+

To use this module, you need to be in developer mode and:

+
    +
  1. Go to Settings/Users & Companies
  2. +
  3. Open a user
  4. +
  5. Click the Effective permissions button
  6. +
  7. Note you can switch between the rule domains in text form or as +domain widget
  8. +
+
+
+

Bug Tracker

+

Bugs are tracked on GitHub Issues. +In case of trouble, please check there if your issue has already been reported. +If you spotted it first, help us to smash it by providing a detailed and welcomed +feedback.

+

Do not contact contributors directly about support or help with technical issues.

+
+
+

Credits

+
+

Authors

+
    +
  • Hunki Enterprises BV
  • +
+
+ +
+

Maintainers

+

This module is maintained by the OCA.

+ +Odoo Community Association + +

OCA, or the Odoo Community Association, is a nonprofit organization whose +mission is to support the collaborative development of Odoo features and +promote its widespread use.

+

Current maintainer:

+

hbrunn

+

This module is part of the OCA/server-backend project on GitHub.

+

You are welcome to contribute. To learn how please visit https://odoo-community.org/page/Contribute.

+
+
+
+ + diff --git a/base_user_effective_permissions/tests/__init__.py b/base_user_effective_permissions/tests/__init__.py new file mode 100644 index 000000000..a9d6740bb --- /dev/null +++ b/base_user_effective_permissions/tests/__init__.py @@ -0,0 +1 @@ +from . import test_base_user_effective_permissions diff --git a/base_user_effective_permissions/tests/test_base_user_effective_permissions.py b/base_user_effective_permissions/tests/test_base_user_effective_permissions.py new file mode 100644 index 000000000..34c21b9ed --- /dev/null +++ b/base_user_effective_permissions/tests/test_base_user_effective_permissions.py @@ -0,0 +1,19 @@ +# Copyright 2023 Hunki Enterprises BV +# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl-3.0) + + +from odoo.tests.common import TransactionCase + + +class EffectivePermissionsCase(TransactionCase): + def test_effective_permissions(self): + """Test effective permissions of base.user_demo""" + action = self.env.ref("base.user_demo").action_show_effective_permissions() + permissions = self.env["res.users.effective.permission"].search( + action["domain"] + ) + self.assertTrue( + permissions.filtered( + lambda x: x.model_name == "res.company" + ).read_permission + ) diff --git a/base_user_effective_permissions/views/res_users.xml b/base_user_effective_permissions/views/res_users.xml new file mode 100644 index 000000000..6415aade0 --- /dev/null +++ b/base_user_effective_permissions/views/res_users.xml @@ -0,0 +1,21 @@ + + + + + res.users + + + + + + + + diff --git a/base_user_effective_permissions/views/res_users_effective_permission.xml b/base_user_effective_permissions/views/res_users_effective_permission.xml new file mode 100644 index 000000000..e3f9b40a5 --- /dev/null +++ b/base_user_effective_permissions/views/res_users_effective_permission.xml @@ -0,0 +1,54 @@ + + + + + res.users.effective.permission + + + + + + + + + + + + + + + + + + + + + res.users.effective.permission + + + + + + +