mirror of
https://github.com/bringout/oca-ocb-core.git
synced 2026-04-20 11:52:04 +02:00
vanilla 19.0
This commit is contained in:
parent
991d2234ca
commit
d1963a3c3a
3066 changed files with 1651266 additions and 922560 deletions
36
odoo-bringout-oca-ocb-web/web/models/res_users.py
Normal file
36
odoo-bringout-oca-ocb-web/web/models/res_users.py
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
from odoo import api, models
|
||||
from odoo.fields import Domain
|
||||
from odoo.http import request
|
||||
|
||||
SKIP_CAPTCHA_LOGIN = object()
|
||||
|
||||
|
||||
class ResUsers(models.Model):
|
||||
_inherit = "res.users"
|
||||
|
||||
@api.model
|
||||
def name_search(self, name='', domain=None, operator='ilike', limit=100):
|
||||
# if we have a search with a limit, move current user as the first result
|
||||
domain = Domain(domain or Domain.TRUE)
|
||||
user_list = super().name_search(name, domain, operator, limit)
|
||||
uid = self.env.uid
|
||||
# index 0 is correct not Falsy in this case, use None to avoid ignoring it
|
||||
if (index := next((i for i, (user_id, _name) in enumerate(user_list) if user_id == uid), None)) is not None:
|
||||
# move found user first
|
||||
user_tuple = user_list.pop(index)
|
||||
user_list.insert(0, user_tuple)
|
||||
elif limit is not None and len(user_list) == limit:
|
||||
# user not found and limit reached, try to find the user again
|
||||
if user_tuple := super().name_search(name, domain & Domain('id', '=', uid), operator, limit=1):
|
||||
user_list = [user_tuple[0], *user_list[:-1]]
|
||||
return user_list
|
||||
|
||||
def _on_webclient_bootstrap(self):
|
||||
self.ensure_one()
|
||||
|
||||
def _should_captcha_login(self, credential):
|
||||
if request and request.env.context.get('skip_captcha_login') is SKIP_CAPTCHA_LOGIN:
|
||||
return False
|
||||
return credential['type'] == 'password'
|
||||
Loading…
Add table
Add a link
Reference in a new issue