summaryrefslogtreecommitdiff
path: root/session_ldap.py
blob: b478ef512d207da9cde659b7f2be4ff915713de8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# python3 library
# Startdate: 2021-06-21
# Dependencies:
#    req-devuan: python3-ldap3

# reference: https://github.com/ArtemAngelchev/flask-basicauth-ldap/blob/master/flask_basicauth_ldap.py

import ldap3
from ldap3.core.exceptions import LDAPBindError, LDAPPasswordIsMandatoryError

def authenticated_user(server_uri, user_format, username, password):
   user = user_format.replace("%s",username)
   print(f"server_uri: {server_uri}")
   print(f"username: {username}")
   print(f"user_format: {user_format}")
   print(f"user: {user}")
   try:
      server = ldap3.Server(server_uri)
      conn = ldap3.Connection(server, auto_bind=True, user=user, password=password)
      return conn
   except LDAPBindError as e:
      if 'invalidCredentials' in str(e):
         print("Invalid credentials.")
         return False
      else:
         raise e
   #except (LDAPPasswordIsMandatoryError, LDAPBindError):
   #   print("Either an ldap password is required, or we had another bind error.")
   #   return False
   return False
bgstack15