Skip to main content

Django LDAP authentication backend

Project description

This is a Django authentication backend that authenticates against an LDAP service. Configuration can be as simple as a single distinguished name template, but there are many rich configuration options for working with users, groups, and permissions.

This version is supported on Python 2.6, 2.7, 3.3, 3.4, 3.5, and 3.6; and Django >= 1.3. Under Python 2, it requires python-ldap >= 2.0; under Python 3, it uses pyldap.

Full documentation can be found at http://pythonhosted.org/django-auth-ldap/; following is an example configuration, just to whet your appetite:

import ldap
from django_auth_ldap.config import LDAPSearch, GroupOfNamesType


# Baseline configuration.
AUTH_LDAP_SERVER_URI = "ldap://ldap.example.com"

AUTH_LDAP_BIND_DN = "cn=django-agent,dc=example,dc=com"
AUTH_LDAP_BIND_PASSWORD = "phlebotinum"
AUTH_LDAP_USER_SEARCH = LDAPSearch("ou=users,dc=example,dc=com",
    ldap.SCOPE_SUBTREE, "(uid=%(user)s)")
# or perhaps:
# AUTH_LDAP_USER_DN_TEMPLATE = "uid=%(user)s,ou=users,dc=example,dc=com"

# Set up the basic group parameters.
AUTH_LDAP_GROUP_SEARCH = LDAPSearch("ou=django,ou=groups,dc=example,dc=com",
    ldap.SCOPE_SUBTREE, "(objectClass=groupOfNames)"
)
AUTH_LDAP_GROUP_TYPE = GroupOfNamesType()

# Simple group restrictions
AUTH_LDAP_REQUIRE_GROUP = "cn=enabled,ou=django,ou=groups,dc=example,dc=com"
AUTH_LDAP_DENY_GROUP = "cn=disabled,ou=django,ou=groups,dc=example,dc=com"

# Populate the Django user from the LDAP directory.
AUTH_LDAP_USER_ATTR_MAP = {
    "first_name": "givenName",
    "last_name": "sn",
    "email": "mail"
}

AUTH_LDAP_USER_FLAGS_BY_GROUP = {
    "is_active": "cn=active,ou=django,ou=groups,dc=example,dc=com",
    "is_staff": "cn=staff,ou=django,ou=groups,dc=example,dc=com",
    "is_superuser": "cn=superuser,ou=django,ou=groups,dc=example,dc=com"
}

# Use LDAP group membership to calculate group permissions.
AUTH_LDAP_FIND_GROUP_PERMS = True

# Cache group memberships for an hour to minimize LDAP traffic
AUTH_LDAP_CACHE_GROUPS = True
AUTH_LDAP_GROUP_CACHE_TIMEOUT = 3600


# Keep ModelBackend around for per-user permissions and maybe a local
# superuser.
AUTHENTICATION_BACKENDS = (
    'django_auth_ldap.backend.LDAPBackend',
    'django.contrib.auth.backends.ModelBackend',
)

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-auth-ldap-1.2.13.tar.gz (143.9 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

django_auth_ldap-1.2.13-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

django_auth_ldap-1.2.13-py2-none-any.whl (29.9 kB view details)

Uploaded Python 2

File details

Details for the file django-auth-ldap-1.2.13.tar.gz.

File metadata

File hashes

Hashes for django-auth-ldap-1.2.13.tar.gz
Algorithm Hash digest
SHA256 7bced0fa7c5b1e0860a5ab3ccb01d3fcf9f7de30ea887d3c6fd8af4066ae9050
MD5 d0326fb462b014f2fe9045ef7a49c45c
BLAKE2b-256 690a2a1863ff8db44efa5d3bfd68f48fea27fde36edf76ff673897d5efda0145

See more details on using hashes here.

File details

Details for the file django_auth_ldap-1.2.13-py3-none-any.whl.

File metadata

File hashes

Hashes for django_auth_ldap-1.2.13-py3-none-any.whl
Algorithm Hash digest
SHA256 5e8cc42305cf9017709b45da0a1b54b61698ab38f629f1d49f0334b96626f1d8
MD5 0ad74319991f86afff943b4a09ec4dbb
BLAKE2b-256 3d9925622494f5ad757243745a0a16837e94781b98a458469cd569dc0cc144a7

See more details on using hashes here.

File details

Details for the file django_auth_ldap-1.2.13-py2-none-any.whl.

File metadata

File hashes

Hashes for django_auth_ldap-1.2.13-py2-none-any.whl
Algorithm Hash digest
SHA256 512a33f6090af35c42e5f4c3e0fc56cf318843291ddd5a2124135d27ca7370f6
MD5 f9b40c1a0e046eb7b0170b6fe2601222
BLAKE2b-256 f06c0338074bab82212de1b29c9beb1fc3660d6af7ba51c4d03b6f70ac55c298

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page