update login

This commit is contained in:
Ivan Office
2024-12-07 03:19:11 +08:00
parent e8715c2b5b
commit b153d88813
2 changed files with 28 additions and 29 deletions

View File

@@ -9,7 +9,6 @@
<field name="scope">odoo,profile</field>
<field name="validation_endpoint">https://www.odooapp.cn/oauth/profile</field>
<field name="data_endpoint"></field>
<field name="user_template_id" ref=""/>
<field name="css_class">fa fa-2x fa-fw fa-sign-in text-primary</field>
<field name="enabled" eval="True"/>
</record>

View File

@@ -15,7 +15,6 @@ from odoo import api, fields, models, _
from odoo.exceptions import AccessDenied, UserError
from odoo.addons.auth_signup.models.res_users import SignupError
from odoo.http import request, Response
from odoo.tools.misc import ustr
from ast import literal_eval
import json
@@ -66,7 +65,7 @@ class ResUsers(models.Model):
# 额外code 处理
kw = params
if oauth_provider.code_endpoint and code and not access_token:
ret = self.get_token_from_code(provider, params)
ret = self.sudo().get_token_from_code(provider, params)
kw.update(ret)
kw.pop('code', False)
@@ -97,33 +96,34 @@ class ResUsers(models.Model):
return res
def _create_user_from_template(self, values):
# 处理odooapp.cn 为 server 时 默认为内部用户
oauth_provider_id = values.get('oauth_provider_id')
if oauth_provider_id:
provider = request.env['auth.oauth.provider'].sudo().browse(int(oauth_provider_id))
if provider:
template_user = provider.user_template_id
if not template_user and provider.scope.find('odoo') >= 0:
template_user = self.sudo().env.ref('base.default_user', False)
if not template_user:
template_user_id = literal_eval(self.env['ir.config_parameter'].sudo().get_param('base.template_portal_user_id', 'False'))
template_user = self.sudo().browse(template_user_id)
if not values.get('login'):
raise ValueError(_('Signup: no login given for new user'))
if not values.get('partner_id') and not values.get('name'):
raise ValueError(_('Signup: no name or partner given for new user'))
# create a copy of the template user (attached to a specific partner_id if given)
values['active'] = True
try:
with self.env.cr.savepoint():
return template_user.sudo().with_context(no_reset_password=True).copy(values)
except Exception as e:
# copy may failed if asked login is not available.
raise SignupError(ustr(e))
# todo: 注意,选模板用户的功能暂时不可开放,因为会与 social_login 不兼容
# 注意,没有装 app_partner_user时删除 user 时不会删除 partner故容易出错测试时要手工再把partner删除
# self = self.sudo()
# oauth_provider_id = values.get('oauth_provider_id')
# if oauth_provider_id:
# provider = request.env['auth.oauth.provider'].sudo().browse(int(oauth_provider_id))
# if provider:
# template_user = provider.user_template_id
# if not template_user and provider.scope.find('odoo') >= 0:
# template_user = self.env.ref('base.default_user', False)
# if not template_user:
# template_user_id = literal_eval(self.env['ir.config_parameter'].sudo().get_param('base.template_portal_user_id', 'False'))
# template_user = self.browse(template_user_id)
#
# if not values.get('login'):
# raise ValueError(_('Signup: no login given for new user'))
# if not values.get('partner_id') and not values.get('name'):
# raise ValueError(_('Signup: no name or partner given for new user'))
#
# # create a copy of the template user (attached to a specific partner_id if given)
# values['active'] = True
# try:
# with self.env.cr.savepoint():
# return template_user.sudo().with_context(no_reset_password=True).copy(values)
# except Exception as e:
# # copy may failed if asked login is not available.
# raise SignupError(str(e))
res = super(ResUsers, self)._create_user_from_template(values)
self._cr.commit()
return res
@api.model