Se rendre au contenu
Menu
Cette question a été signalée
2 Réponses
10188 Vues

i had created a user and mapped to two different groups with two different access rights.

For one group pnly read access and another group  both read and write access 

It is talking the highest access rights (read and write) but i want to know how it is taking the highest access rights (and i want to the architecture behind that)

 

 

Avatar
Ignorer
Meilleure réponse

Hi,

Group security rights "Add" permissions. 

Edit: When for a certain model, groupA adds read access and groupB adds write access, a user in both groupA and groupB will have both read and write access.  If in doubt, check: https://github.com/odoo/odoo/blob/master/openerp/addons/base/ir/ir_model.py#L704

If you want a security rule to remove a certain permissions, look at the record rules:

Global rules (non group-specific) are restrictions, and cannot be bypassed. Group-local rules grant additional permissions, but are constrained within the bounds of global ones. The first group rules restrict further than global rules, but any additional group rule will add more permissions

Detailed algorithm:

1. Global rules are combined together with a logical AND operator, and with the result of the following steps

2. Group-specific rules are combined together with a logical OR operator

3. If user belongs to several groups, the results from step 2 are combined with logical OR operator

Example: GLOBAL_RULE_1 AND GLOBAL_RULE_2 AND ( (GROUP_A_RULE_1 OR GROUP_A_RULE_2) OR (GROUP_B_RULE_1 OR GROUP_B_RULE_2) )     

 

 

Regards,

Jos

Avatar
Ignorer
Meilleure réponse

By default the groups determine the access rights to the different resources. A user may belong to several groups. If he belongs to several groups, we always use the group with the highest rights for a selected resource.

You can get more details on the following link1, link2.

Avatar
Ignorer
Publications associées Réponses Vues Activité
2
août 24
2683
1
févr. 24
2804
0
nov. 15
5380
1
nov. 15
5459
0
mai 15
5184