Browse Source
Merge pull request #113 from hbrunn/8.0-auth_dynamic_groups
Merge pull request #113 from hbrunn/8.0-auth_dynamic_groups
[ADD] auth_dynamic_groupspull/141/head
Stefan Rijnhart (Therp)
10 years ago
7 changed files with 261 additions and 0 deletions
-
30auth_dynamic_groups/README.rst
-
21auth_dynamic_groups/__init__.py
-
39auth_dynamic_groups/__openerp__.py
-
22auth_dynamic_groups/model/__init__.py
-
62auth_dynamic_groups/model/res_groups.py
-
55auth_dynamic_groups/model/res_users.py
-
32auth_dynamic_groups/view/res_groups.xml
@ -0,0 +1,30 @@ |
|||
Description |
|||
----------- |
|||
This module allows defining groups whose membership is a condition expressed as |
|||
python code. For every user, it is evaluated during login if she belongs to |
|||
the group or not. |
|||
|
|||
Usage |
|||
----- |
|||
Check `Dynamic` on a group you want to be dynamic. Now fill in the condition, |
|||
using `user` which is a browse record of the user in question that evaluates |
|||
truthy if the user is supposed to be a member of the group and falsy if not. |
|||
|
|||
There is a constraint on the field to check for validity if this expression. |
|||
When you're satisfied, click the button `Evaluate` to prefill the group's |
|||
members. The condition will be checked now for every user who logs in. |
|||
|
|||
Example |
|||
------- |
|||
We have a group called `Amsterdam` and want it to contain all users from |
|||
city of Amsterdam. So we use the membership condition |
|||
|
|||
``` |
|||
user.partner_id.city == 'Amsterdam' |
|||
``` |
|||
|
|||
Now we can be sure every user living in this city is in the right group, and we |
|||
can start assigning local menus to it, adjust permissions, etc. Keep in mind |
|||
that view overrides can also be restricted by a group id, this gives a lot of |
|||
possibilities to dynamically adapt views based on arbitrary properties |
|||
reachable via the user record. |
@ -0,0 +1,21 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
from . import model |
@ -0,0 +1,39 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013-2015 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
{ |
|||
"name": "Dynamic groups", |
|||
"version": "1.0", |
|||
"author": "Therp BV", |
|||
"complexity": "normal", |
|||
'summary': 'Have membership conditions for certain groups', |
|||
"category": "Tools", |
|||
"depends": [ |
|||
'base', |
|||
], |
|||
"data": [ |
|||
'view/res_groups.xml', |
|||
], |
|||
"auto_install": False, |
|||
"installable": True, |
|||
"external_dependencies": { |
|||
'python': [], |
|||
}, |
|||
} |
@ -0,0 +1,22 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
from . import res_users |
|||
from . import res_groups |
@ -0,0 +1,62 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
from openerp import models, fields, api, exceptions |
|||
from openerp.tools.safe_eval import safe_eval |
|||
from openerp import _ |
|||
|
|||
|
|||
class res_groups(models.Model): |
|||
_inherit = 'res.groups' |
|||
|
|||
is_dynamic = fields.Boolean('Dynamic') |
|||
dynamic_group_condition = fields.Text( |
|||
'Condition', help='The condition to be met for a user to be a ' |
|||
'member of this group. It is evaluated as python code at login ' |
|||
'time, you get `user` passed as a browse record') |
|||
|
|||
@api.multi |
|||
def eval_dynamic_group_condition(self): |
|||
result = all( |
|||
self.mapped( |
|||
lambda this: safe_eval( |
|||
this.dynamic_group_condition, |
|||
{ |
|||
'user': self.env.user, |
|||
'any': any, |
|||
'all': all, |
|||
'filter': filter, |
|||
}))) |
|||
return result |
|||
|
|||
@api.multi |
|||
@api.constrains('dynamic_group_condition') |
|||
def _check_dynamic_group_condition(self): |
|||
try: |
|||
self.filtered('is_dynamic').eval_dynamic_group_condition() |
|||
except (NameError, SyntaxError, TypeError): |
|||
raise exceptions.ValidationError( |
|||
_('The condition doesn\'t evaluate correctly!')) |
|||
|
|||
@api.multi |
|||
def action_evaluate(self): |
|||
res_users = self.env['res.users'] |
|||
for user in res_users.search([]): |
|||
res_users.update_dynamic_groups(user.id, self.env.cr.dbname) |
@ -0,0 +1,55 @@ |
|||
# -*- coding: utf-8 -*- |
|||
############################################################################## |
|||
# |
|||
# OpenERP, Open Source Management Solution |
|||
# This module copyright (C) 2013 Therp BV (<http://therp.nl>). |
|||
# |
|||
# This program is free software: you can redistribute it and/or modify |
|||
# it under the terms of the GNU Affero General Public License as |
|||
# published by the Free Software Foundation, either version 3 of the |
|||
# License, or (at your option) any later version. |
|||
# |
|||
# This program is distributed in the hope that it will be useful, |
|||
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|||
# GNU Affero General Public License for more details. |
|||
# |
|||
# You should have received a copy of the GNU Affero General Public License |
|||
# along with this program. If not, see <http://www.gnu.org/licenses/>. |
|||
# |
|||
############################################################################## |
|||
from openerp.models import Model |
|||
from openerp.modules.registry import RegistryManager |
|||
from openerp import SUPERUSER_ID |
|||
|
|||
|
|||
class res_users(Model): |
|||
_inherit = 'res.users' |
|||
|
|||
def _login(self, db, login, password): |
|||
uid = super(res_users, self)._login(db, login, password) |
|||
|
|||
if uid: |
|||
self.update_dynamic_groups(uid, db) |
|||
|
|||
return uid |
|||
|
|||
def update_dynamic_groups(self, uid, db): |
|||
pool = RegistryManager.get(db) |
|||
cr = pool._db.cursor() |
|||
user = pool.get('res.users').browse(cr, SUPERUSER_ID, uid) |
|||
groups_obj = pool.get('res.groups') |
|||
user.write( |
|||
{ |
|||
'groups_id': [ |
|||
(4, dynamic_group.id) |
|||
if dynamic_group.eval_dynamic_group_condition() |
|||
else (3, dynamic_group.id) |
|||
for dynamic_group in groups_obj.browse( |
|||
cr, SUPERUSER_ID, |
|||
groups_obj.search(cr, SUPERUSER_ID, |
|||
[('is_dynamic', '=', True)])) |
|||
], |
|||
}) |
|||
cr.commit() |
|||
cr.close() |
@ -0,0 +1,32 @@ |
|||
<openerp> |
|||
<data> |
|||
<record model="ir.ui.view" id="view_groups_form"> |
|||
<field name="inherit_id" ref="base.view_groups_form" /> |
|||
<field name="view_type">form</field> |
|||
<field name="model">res.groups</field> |
|||
<field name="arch" type="xml"> |
|||
<data> |
|||
<field name="name" position="after"> |
|||
<field name="is_dynamic" /> |
|||
</field> |
|||
<field name="users" position="attributes"> |
|||
<attribute name="attrs">{'readonly': [('is_dynamic', '=', True)]}</attribute> |
|||
</field> |
|||
<field name="users" position="before"> |
|||
<group name="auth_dynamic_groups" attrs="{'invisible': [('is_dynamic', '=', False)]}"> |
|||
<field |
|||
name="dynamic_group_condition" |
|||
placeholder="Fill in your condition..." |
|||
attrs="{'required': [('is_dynamic', '=', True)]}" |
|||
colspan="4" nolabel="1" /> |
|||
<button |
|||
type="object" |
|||
name="action_evaluate" |
|||
string="Evaluate" /> |
|||
</group> |
|||
</field> |
|||
</data> |
|||
</field> |
|||
</record> |
|||
</data> |
|||
</openerp> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue