You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

60 lines
2.4 KiB

  1. # -*- coding: utf-8 -*-
  2. ##############################################################################
  3. #
  4. # OpenERP, Open Source Management Solution
  5. # This module copyright (C) 2013 Therp BV (<http://therp.nl>).
  6. #
  7. # This program is free software: you can redistribute it and/or modify
  8. # it under the terms of the GNU Affero General Public License as
  9. # published by the Free Software Foundation, either version 3 of the
  10. # License, or (at your option) any later version.
  11. #
  12. # This program is distributed in the hope that it will be useful,
  13. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. # GNU Affero General Public License for more details.
  16. #
  17. # You should have received a copy of the GNU Affero General Public License
  18. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  19. #
  20. ##############################################################################
  21. from openerp.models import Model
  22. from openerp import SUPERUSER_ID
  23. class ResUsers(Model):
  24. _inherit = 'res.users'
  25. def _login(self, db, login, password):
  26. uid = super(ResUsers, self)._login(db, login, password)
  27. if uid and uid != SUPERUSER_ID:
  28. self.update_dynamic_groups(uid, db)
  29. return uid
  30. def update_dynamic_groups(self, uid, db):
  31. cr = self.pool._db.cursor(serialized=False)
  32. groups_obj = self.pool.get('res.groups')
  33. try:
  34. dynamic_groups = groups_obj.browse(
  35. cr, SUPERUSER_ID, groups_obj.search(
  36. cr, SUPERUSER_ID, [('is_dynamic', '=', True)]))
  37. if dynamic_groups:
  38. cr.execute(
  39. 'delete from res_groups_users_rel '
  40. 'where uid=%s and gid in %s',
  41. (uid, tuple(dynamic_groups.ids))
  42. )
  43. for dynamic_group in dynamic_groups:
  44. if dynamic_group.eval_dynamic_group_condition(uid=uid):
  45. cr.execute(
  46. 'insert into res_groups_users_rel (uid, gid) values '
  47. '(%s, %s)',
  48. (uid, dynamic_group.id))
  49. self.invalidate_cache(cr, uid, ['groups_id'], [uid])
  50. # we really need a new transaction
  51. # pylint: disable=invalid-commit
  52. cr.commit()
  53. finally:
  54. cr.close()