diff options
Diffstat (limited to 'addons/auth_password_policy/models/res_users.py')
| -rw-r--r-- | addons/auth_password_policy/models/res_users.py | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/addons/auth_password_policy/models/res_users.py b/addons/auth_password_policy/models/res_users.py new file mode 100644 index 00000000..b938acd5 --- /dev/null +++ b/addons/auth_password_policy/models/res_users.py @@ -0,0 +1,33 @@ +# -*- coding: utf-8 -*- +from odoo import api, models, _ +from odoo.exceptions import UserError + + +class ResUsers(models.Model): + _inherit = 'res.users' + + @api.model + def get_password_policy(self): + params = self.env['ir.config_parameter'].sudo() + return { + 'minlength': int(params.get_param('auth_password_policy.minlength', default=0)), + } + + def _set_password(self): + self._check_password_policy(self.mapped('password')) + + super(ResUsers, self)._set_password() + + def _check_password_policy(self, passwords): + failures = [] + params = self.env['ir.config_parameter'].sudo() + + minlength = int(params.get_param('auth_password_policy.minlength', default=0)) + for password in passwords: + if not password: + continue + if len(password) < minlength: + failures.append(_(u"Passwords must have at least %d characters, got %d.") % (minlength, len(password))) + + if failures: + raise UserError(u'\n\n '.join(failures)) |
