dataset/seed/ldap-client/funcs/openldap_client.py

53 lines
1.5 KiB
Python
Raw Normal View History

2022-03-08 19:42:28 +01:00
def valid_base_dn(base_dn: str) -> None:
for att in ['o', 'dc', 'ou']:
if base_dn.startswith(att + '='):
break
else:
raise ValueError('La racine doit débuter par une organisation (o=), une composante du domaine (dc=) ou une unité organisationnelle (ou=)')
2022-05-04 10:29:03 +02:00
def calc_ldapclient_base_dn(ldap_base_dn: str,
2022-06-24 19:00:16 +02:00
family_name: str=None,
base: bool=False,
group: bool=False,
2022-05-04 10:29:03 +02:00
) -> str:
2022-08-18 10:19:43 +02:00
if ldap_base_dn is None:
return
2022-06-24 19:00:16 +02:00
if family_name == 'all':
family_name = None
base = True
if group:
return f'ou=groups,{ldap_base_dn}'
if not ldap_base_dn.startswith('ou=accounts,'):
base_name = f'ou=accounts,{ldap_base_dn}'
else:
base_name = ldap_base_dn
if base:
return base_name
2022-05-04 10:29:03 +02:00
if not family_name:
2022-06-24 19:00:16 +02:00
return f'ou=users,{base_name}'
base_name = f'ou=families,{base_name}'
2022-05-07 08:11:18 +02:00
if family_name != '-':
2022-06-24 19:00:16 +02:00
base_name = f'ou={family_name},{base_name}'
return base_name
2022-08-18 10:19:43 +02:00
class _Undefined:
pass
_undefined = _Undefined()
def get_default_base_dn(server_name: str) -> str:
if not server_name or '.' not in server_name:
return None
values = server_name.split('.')
# cannot calculated base dn should be server.domain.tld
# remove 'server' in dn
if len(values) < 3:
return None
domain = ['ou=' + domain for domain in values[1:-2]]
domain.append(f'o={values[-2]},o={values[-1]}')
return ','.join(domain)