From 3751379f1e9a4c215fb6eb898b4ccc67659b9ace Mon Sep 17 00:00:00 2001 From: stephanchrst Date: Tue, 10 May 2022 21:51:50 +0700 Subject: initial commit 2 --- addons/base_setup/models/res_users.py | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 addons/base_setup/models/res_users.py (limited to 'addons/base_setup/models/res_users.py') diff --git a/addons/base_setup/models/res_users.py b/addons/base_setup/models/res_users.py new file mode 100644 index 00000000..112c55c1 --- /dev/null +++ b/addons/base_setup/models/res_users.py @@ -0,0 +1,25 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +from odoo import models, api + + +class ResUsers(models.Model): + _inherit = 'res.users' + + @api.model + def web_create_users(self, emails): + + # Reactivate already existing users if needed + deactivated_users = self.with_context(active_test=False).search([('active', '=', False), '|', ('login', 'in', emails), ('email', 'in', emails)]) + for user in deactivated_users: + user.active = True + + new_emails = set(emails) - set(deactivated_users.mapped('email')) + + # Process new email addresses : create new users + for email in new_emails: + default_values = {'login': email, 'name': email.split('@')[0], 'email': email, 'active': True} + user = self.with_context(signup_valid=True).create(default_values) + + return True -- cgit v1.2.3