25 lines
		
	
	
		
			802 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			25 lines
		
	
	
		
			802 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| """passbook LDAP Authentication Backend"""
 | |
| from django.contrib.auth.backends import ModelBackend
 | |
| from django.http import HttpRequest
 | |
| from structlog import get_logger
 | |
| 
 | |
| from passbook.sources.ldap.connector import Connector
 | |
| from passbook.sources.ldap.models import LDAPSource
 | |
| 
 | |
| LOGGER = get_logger()
 | |
| 
 | |
| 
 | |
| class LDAPBackend(ModelBackend):
 | |
|     """Authenticate users against LDAP Server"""
 | |
| 
 | |
|     def authenticate(self, request: HttpRequest, **kwargs):
 | |
|         """Try to authenticate a user via ldap"""
 | |
|         if "password" not in kwargs:
 | |
|             return None
 | |
|         for source in LDAPSource.objects.filter(enabled=True):
 | |
|             LOGGER.debug("LDAP Auth attempt", source=source)
 | |
|             user = Connector(source).auth_user(**kwargs)
 | |
|             if user:
 | |
|                 return user
 | |
|         return None
 | 
