--- title: Generic Setup --- ### Create User/Group 1. Create a new user account to bind with under _Directory_ -> _Users_ -> _Create_, in this example called `ldapservice`. Note the DN of this user will be `cn=ldapservice,ou=users,dc=ldap,dc=goauthentik,dc=io` 2. Create a new group for LDAP searches. In this example `ldapsearch`. Add the `ldapservice` user to this new group. :::info Note: The `default-authentication-flow` validates MFA by default, and currently everything but SMS-based devices are supported by LDAP. If you plan to use only dedicated service accounts to bind to LDAP, or don't use SMS-based authenticators, then you can use the default flow and skip the extra steps below and continue at [Create LDAP Provider](#create-ldap-provider) ::: ### LDAP Flow #### Create Custom Stages 1. Create a new identification stage. _Flows & Stage_ -> _Stages_ -> _Create_ data:image/s3,"s3://crabby-images/fa368/fa368af47d493445b68fdf23cb2a4373e64ecefe" alt="" 2. Name it something meaningful like `ldap-identification-stage`. Select User fields Username and Email (and UPN if it is relevant to your setup). data:image/s3,"s3://crabby-images/f5728/f5728ec7b4214003314515349e556e4b774a2159" alt="" 3. Create a new password stage. _Flows & Stage_ -> _Stages_ -> _Create_ data:image/s3,"s3://crabby-images/ef9d5/ef9d5a416a0100fba3706aa45be628fd7a7e27b4" alt="" 4. Name it something meaningful like `ldap-authentication-password`. Leave the defaults for Backends. data:image/s3,"s3://crabby-images/10e9f/10e9f2ae5bf0c8614623d4c99f6a63a145b48b11" alt="" 5. Create a new user login stage. _Flows & Stage_ -> _Stages_ -> _Create_ data:image/s3,"s3://crabby-images/21af5/21af56adc64a79b889ce6fa023e189aed5df73aa" alt="" 6. Name it something meaningful like `ldap-authentication-login`. data:image/s3,"s3://crabby-images/0d567/0d567beb9708e1950bae4810a8cc99c254187038" alt="" #### Create Custom Flow 1. Create a new authentication flow under _Flows & Stage_ -> _Flows_ -> _Create_, and name it something meaningful like `ldap-authentication-flow` data:image/s3,"s3://crabby-images/7372c/7372c822073655eec911267355a9999204db938c" alt="" 2. Click the newly created flow and choose _Stage Bindings_. data:image/s3,"s3://crabby-images/c4e63/c4e634e699d208b5c2ff54e5c711a196254e12e0" alt="" 3. Click `Bind Stage` choose `ldap-identification-stage` and set the order to `10`. data:image/s3,"s3://crabby-images/ba632/ba6323e1cc45c01637aca7ef93b38f5a65d1bd0c" alt="" 4. Click `Bind Stage` choose `ldap-authentication-login` and set the order to `30`. data:image/s3,"s3://crabby-images/46ead/46ead1b7278545f88c939cff146ebde492a9048d" alt="" 5. Edit the `ldap-identification-stage`. data:image/s3,"s3://crabby-images/ff56e/ff56e65f43c2dc28e73e083c178021ac3bd7edbd" alt="" 6. Change the Password stage to `ldap-authentication-password`. data:image/s3,"s3://crabby-images/705c5/705c51372c79a3a95ed0ad85bfcdf53aef0f83e8" alt="" ### Create LDAP Provider 1. Create the LDAP Provider under _Applications_ -> _Providers_ -> _Create_. data:image/s3,"s3://crabby-images/a5963/a5963ef25193938b39f51576f21ef3225c1cdba7" alt="" 2. Name is something meaningful like `LDAP`, bind the custom flow created previously (or the default flow, depending on setup) and specify the search group created earlier. data:image/s3,"s3://crabby-images/461ed/461ed19ba47220c8aeaabc8b030819597207a32c" alt="" ### Create LDAP Application 1. Create the LDAP Application under _Applications_ -> _Applications_ -> _Create_ and name it something meaningful like `LDAP`. Choose the provider created in the previous step. data:image/s3,"s3://crabby-images/d075a/d075aed8fe1ba2b539a9866b34d570d676ba91e0" alt="" ### Create LDAP Outpost 1. Create (or update) the LDAP Outpost under _Applications_ -> _Outposts_ -> _Create_. Set the Type to `LDAP` and choose the `LDAP` application created in the previous step. data:image/s3,"s3://crabby-images/66f48/66f488ca13df8519aa6d88248c4305c0b62ca136" alt="" :::info The LDAP Outpost selects different providers based on their Base DN. Adding multiple providers with the same Base DN will result in inconsistent access ::: ### ldapsearch Test Test connectivity by using ldapsearch. :::info ldapsearch can be installed on Linux system with these commands ``` sudo apt-get install ldap-utils -y # Debian-based systems sudo yum install openldap-clients -y # CentOS-based systems ``` ::: ``` ldapsearch \ -x \ -h <LDAP Outpost IP address> \ -p 389 \ # Production should use SSL 636 -D 'cn=ldapservice,ou=users,DC=ldap,DC=goauthentik,DC=io' \ -w '<ldapuserpassword>' \ -b 'DC=ldap,DC=goauthentik,DC=io' \ '(objectClass=user)' ``` :::info This query will log the first successful attempt in an event in the _Events_ -> _Logs_ area, further successful logins from the same user are not logged as they are cached in the outpost. :::