Browse Source
Merge pull request #112 from hbrunn/6.1-auth_dynamic_groups
Merge pull request #112 from hbrunn/6.1-auth_dynamic_groups
[ADD] auth_dynamic_groups6.1
Alexandre Fayolle
8 years ago
committed by
GitHub
6 changed files with 271 additions and 0 deletions
-
21auth_dynamic_groups/__init__.py
-
67auth_dynamic_groups/__openerp__.py
-
22auth_dynamic_groups/model/__init__.py
-
77auth_dynamic_groups/model/res_groups.py
-
54auth_dynamic_groups/model/res_users.py
-
30auth_dynamic_groups/view/res_groups.xml
@ -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,67 @@ |
|||||
|
# -*- 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/>. |
||||
|
# |
||||
|
############################################################################## |
||||
|
{ |
||||
|
"name": "Dynamic groups", |
||||
|
"version": "1.0", |
||||
|
"author": "Therp BV,Odoo Community Association (OCA)", |
||||
|
"complexity": "normal", |
||||
|
"description": """ |
||||
|
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. |
||||
|
""", |
||||
|
"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,77 @@ |
|||||
|
# -*- 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/>. |
||||
|
# |
||||
|
############################################################################## |
||||
|
import logging |
||||
|
from openerp.osv.orm import Model |
||||
|
from openerp.osv import fields |
||||
|
from openerp.tools.safe_eval import safe_eval |
||||
|
from openerp import SUPERUSER_ID |
||||
|
|
||||
|
|
||||
|
class res_groups(Model): |
||||
|
_inherit = 'res.groups' |
||||
|
|
||||
|
_columns = { |
||||
|
'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') |
||||
|
} |
||||
|
|
||||
|
def eval_dynamic_group_condition(self, cr, uid, ids, context=None): |
||||
|
result = True |
||||
|
user = self.pool.get('res.users').browse(cr, SUPERUSER_ID, uid, |
||||
|
context=context) |
||||
|
for this in self.browse(cr, uid, ids, context=context): |
||||
|
result &= bool( |
||||
|
safe_eval( |
||||
|
this.dynamic_group_condition, |
||||
|
{ |
||||
|
'user': user, |
||||
|
'any': any, |
||||
|
'all': all, |
||||
|
'filter': filter, |
||||
|
})) |
||||
|
return result |
||||
|
|
||||
|
def _check_dynamic_group_condition(self, cr, uid, ids, context=None): |
||||
|
try: |
||||
|
for this in self.browse(cr, uid, ids, context=context): |
||||
|
if this.is_dynamic: |
||||
|
this.eval_dynamic_group_condition() |
||||
|
except (NameError, SyntaxError, TypeError) as e: |
||||
|
logging.info(e) |
||||
|
return False |
||||
|
return True |
||||
|
|
||||
|
_constraints = [ |
||||
|
(_check_dynamic_group_condition, |
||||
|
'The condition doesn\'t evaluate correctly!', |
||||
|
['dynamic_group_condition']), |
||||
|
] |
||||
|
|
||||
|
def action_evaluate(self, cr, uid, ids, context=None): |
||||
|
user_obj = self.pool.get('res.users') |
||||
|
for user in user_obj.browse( |
||||
|
cr, uid, |
||||
|
user_obj.search(cr, uid, [], context=context), |
||||
|
context=context): |
||||
|
user_obj.update_dynamic_groups(user.id, cr.dbname) |
@ -0,0 +1,54 @@ |
|||||
|
# -*- 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.osv.orm import Model |
||||
|
from openerp import pooler, 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): |
||||
|
cr = pooler.get_db(db).cursor() |
||||
|
pool = pooler.get_pool(db) |
||||
|
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, uid, |
||||
|
groups_obj.search(cr, uid, |
||||
|
[('is_dynamic', '=', True)])) |
||||
|
], |
||||
|
}) |
||||
|
cr.commit() |
||||
|
cr.close() |
@ -0,0 +1,30 @@ |
|||||
|
<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"> |
||||
|
<field |
||||
|
name="dynamic_group_condition" |
||||
|
colspan="4" nolabel="1" |
||||
|
attrs="{'invisible': [('is_dynamic', '=', False)]}" /> |
||||
|
<button |
||||
|
type="object" |
||||
|
name="action_evaluate" |
||||
|
string="Evaluate" |
||||
|
attrs="{'invisible': [('is_dynamic', '=', False)]}" /> |
||||
|
</field> |
||||
|
</data> |
||||
|
</field> |
||||
|
</record> |
||||
|
</data> |
||||
|
</openerp> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue