mirror of https://github.com/jumpserver/jumpserver
				
				
				
			
		
			
				
	
	
		
			58 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			58 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
| from django.contrib.auth.backends import ModelBackend
 | |
| from django.contrib.auth import get_user_model
 | |
| 
 | |
| from users.models import User
 | |
| from common.utils import get_logger
 | |
| 
 | |
| 
 | |
| UserModel = get_user_model()
 | |
| logger = get_logger(__file__)
 | |
| 
 | |
| 
 | |
| class JMSBaseAuthBackend:
 | |
| 
 | |
|     @staticmethod
 | |
|     def is_enabled():
 | |
|         return True
 | |
| 
 | |
|     def has_perm(self, user_obj, perm, obj=None):
 | |
|         return False
 | |
| 
 | |
|     def user_can_authenticate(self, user):
 | |
|         """
 | |
|         Reject users with is_valid=False. Custom user models that don't have
 | |
|         that attribute are allowed.
 | |
|         """
 | |
|         # 在 check_user_auth 中进行了校验,可以返回对应的错误信息
 | |
|         # is_valid = getattr(user, 'is_valid', None)
 | |
|         # return is_valid or is_valid is None
 | |
|         return True
 | |
| 
 | |
|     # allow user to authenticate
 | |
|     def username_allow_authenticate(self, username):
 | |
|         return self.allow_authenticate(username=username)
 | |
| 
 | |
|     def user_allow_authenticate(self, user):
 | |
|         return self.allow_authenticate(user=user)
 | |
| 
 | |
|     def allow_authenticate(self, user=None, username=None):
 | |
|         if user:
 | |
|             allowed_backend_paths = user.get_allowed_auth_backend_paths()
 | |
|         else:
 | |
|             allowed_backend_paths = User.get_user_allowed_auth_backend_paths(username)
 | |
|         if allowed_backend_paths is None:
 | |
|             # 特殊值 None 表示没有限制
 | |
|             return True
 | |
|         backend_name = self.__class__.__name__
 | |
|         allowed_backend_names = [path.split('.')[-1] for path in allowed_backend_paths]
 | |
|         allow = backend_name in allowed_backend_names
 | |
|         if not allow:
 | |
|             info = 'User {} skip authentication backend {}, because it not in {}'
 | |
|             info = info.format(username, backend_name, ','.join(allowed_backend_names))
 | |
|             logger.info(info)
 | |
|         return allow
 | |
| 
 | |
| 
 | |
| class JMSModelBackend(JMSBaseAuthBackend, ModelBackend):
 | |
|     pass
 |