forked from OCA/server-tools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
res_users.py
121 lines (108 loc) · 4.28 KB
/
res_users.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
# -*- coding: utf-8 -*-
# Copyright 2017 LasLabs Inc.
# License LGPL-3.0 or later (http://www.gnu.org/licenses/lgpl.html).
import os
from csv import reader
from lxml import etree
from odoo import api, fields, models, _
from odoo.exceptions import AccessError, ValidationError
from .ir_config_parameter import THRESHOLD_HIDE, MAX_DB_USER_PARAM
from .res_groups import THRESHOLD_MANAGER
class ResUsers(models.Model):
_inherit = 'res.users'
threshold_exempt = fields.Boolean(
'Exempt User From User Count Thresholds',
)
@api.model_cr
def _register_hook(self):
"""
Override to check if env var to hide threshold configuration and
reset the database state is set. If it is, run those actions
"""
if THRESHOLD_HIDE:
exempt_users_var = os.environ.get('USER_THRESHOLD_USER', '')
exempt_users = reader([exempt_users_var])
users = self.env['res.users'].search([
('share', '=', False),
('threshold_exempt', '=', True),
])
non_ex = users.filtered(lambda r: r.login not in exempt_users)
for user in non_ex:
user.threshold_exempt = False
def _check_thresholds(self):
"""
Check to see if any user thresholds are met
Returns:
False when the thresholds aren't met and True when they are
"""
domain = [
('threshold_exempt', '=', False),
('share', '=', False),
]
users = self.env['res.users'].search(domain)
max_db_users = int(self.env['ir.config_parameter'].get_param(
MAX_DB_USER_PARAM
))
if max_db_users > 0 and len(users) >= max_db_users:
return True
company = self.env.user.company_id
company_users = users.filtered(lambda r: r.company_id.id == company.id)
if company.max_users > 0 and len(company_users) >= company.max_users:
return True
return False
@api.multi
def copy(self, default=None):
"""
Override method to make sure the Thresholds aren't met before
creating a new user
"""
if self._check_thresholds():
raise ValidationError(_(
'Cannot add user - Maximum number of allowed users reached'
))
return super(ResUsers, self).copy(default=default)
@api.multi
def create(self, vals):
"""
Override method to make sure the Thresholds aren't met before
creating a new user
"""
if self._check_thresholds():
raise ValidationError(_(
'Cannot add user - Maximum number of allowed users reached'
))
return super(ResUsers, self).create(vals)
@api.model
def fields_view_get(self, view_id=None, view_type='form', toolbar=False,
submenu=False):
""" Hide Max User Field when the env var to hide the field is set """
res = super(ResUsers, self).fields_view_get(
view_id, view_type, toolbar, submenu
)
if THRESHOLD_HIDE:
doc = etree.XML(res['arch'])
for node in doc.xpath("//group[@name='user_threshold']"):
node.getparent().remove(node)
res['arch'] = etree.tostring(doc, pretty_print=True)
return res
@api.multi
def write(self, vals):
"""
Override write to verify that membership of the Threshold Manager
group is not able to be set by users outside that group
"""
thold_group = self.env.ref(THRESHOLD_MANAGER, raise_if_not_found=False)
if thold_group:
user_is_manager = self.env.user.has_group(THRESHOLD_MANAGER)
if vals.get('threshold_exempt') and not user_is_manager:
raise AccessError(_(
'You must be a member of the `User Threshold Manager`'
' group to grant threshold exemptions.'
))
is_add_group = vals.get('in_group_%s' % thold_group.id)
if is_add_group and not user_is_manager:
raise AccessError(_(
'You must be a member of the `User Threshold Manager`'
' group to grant access to it.'
))
return super(ResUsers, self).write(vals)