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.

64 lines
2.2 KiB

###################################################################################
#
# Copyright (C) 2017 MuK IT GmbH
#
# 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 odoo import api, fields, models
from odoo import tools, _
from odoo.exceptions import ValidationError
_logger = logging.getLogger(__name__)
class AccessGroups(models.Model):
_inherit = "res.groups"
#----------------------------------------------------------
# Database
#----------------------------------------------------------
groups = fields.Many2many(
comodel_name='muk_security.groups',
relation='muk_groups_groups_rel',
column1='rid',
column2='gid',
string='Groups')
#----------------------------------------------------------
# Create, Update, Delete
#----------------------------------------------------------
@api.multi
def write(self, vals):
result = super(AccessGroups, self).write(vals)
if any(field in vals for field in ['users']):
for record in self:
for group in record.groups:
group.trigger_computation(['users'])
return result
@api.multi
def unlink(self):
groups = self.env['muk_security.groups']
for record in self:
groups |= record.groups
result = super(AccessGroups, self).unlink()
for group in groups:
group.trigger_computation(['users'])
return result