atoti.LdapConfig#
- final class atoti.LdapConfig#
The config to delegate authentication to an LDAP provider.
The user’s roles can be defined using
atoti.security.Security.ldap
andindividual_roles
.Example
>>> config = tt.LdapConfig( ... url="ldap://example.com:389", ... base_dn="dc=example,dc=com", ... user_search_base="ou=people", ... group_search_base="ou=roles", ... username_case_conversion="lower", ... )
- group_search_filter: str = '(uniqueMember={0})'#
The filter to search for groups.
The substituted parameter is the DN of the user.
- manager_dn: str | None = None#
The Distinguished Name (DN) used to log into the Directory Service and to search for user accounts.
If
None
, the connection to the service will be done anonymously.
- manager_password: str | None = None#
The password for the manager account specified in the manager_dn attribute.
- user_search_filter: str = '(uid={0})'#
The filter to search for users.
The substituted parameter is the user’s login name.
- username_case_conversion: 'upper' | 'lower' | None = None#
The case conversion to apply to the username.
This authentication provider is generally case insensitive: the same user Jane could log in with the usernames
"jane"
,"Jane"
,"JANE"
, etc. This attribute allows reducing all the possible cases to a single one to be compatible withindividual_roles
and other case sensitive mappings.For instance, if
session.security.individual_roles == {"jane": {"ROLE_USER"}}
,username_case_conversion
should be set to"lower"
.Leaving this attribute to
None
is deprecated since it is a source of confusion or bugs.