37 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
from django.contrib.auth.backends import ModelBackend
 | 
						|
from django.db.models import Q
 | 
						|
from django.contrib.auth import get_user_model
 | 
						|
from django.core.cache import cache
 | 
						|
from django.core.exceptions import ValidationError
 | 
						|
 | 
						|
UserModel = get_user_model()
 | 
						|
 | 
						|
def get_user_by_username_or(username: str):
 | 
						|
    try:
 | 
						|
        user = UserModel._default_manager.get(
 | 
						|
            Q(username=username) | Q(phone=username) | Q(employee__id_number=username))
 | 
						|
        return user, ""
 | 
						|
    except UserModel.DoesNotExist:
 | 
						|
        return None, 'not_exist'
 | 
						|
    except Exception as e:
 | 
						|
        return None, str(e)
 | 
						|
 | 
						|
class CustomBackend(ModelBackend):
 | 
						|
    def authenticate(self, request, username=None, password=None, **kwargs):
 | 
						|
        if username is None:
 | 
						|
            username = kwargs.get(UserModel.USERNAME_FIELD)
 | 
						|
        if username is None or password is None:
 | 
						|
            return
 | 
						|
        user, msg = get_user_by_username_or(username)
 | 
						|
        if msg == 'not_exist':
 | 
						|
            UserModel().set_password(password)
 | 
						|
        if user:
 | 
						|
            key_login_attempt = f"login_attempt_{user.id}"
 | 
						|
            if user.check_password(password) and self.user_can_authenticate(user):
 | 
						|
                cache.delete(key_login_attempt)
 | 
						|
                return user
 | 
						|
            else:
 | 
						|
                login_attempt = cache.get(key_login_attempt, 0)
 | 
						|
                cache.set(key_login_attempt, login_attempt + 1, 60)
 | 
						|
 |