External user databases that already exist can be federated with Authority Service. By default, the Authority Service supports LDAP and Active Directory. When a user logs in, Authority Service looks up the person in its internal user database. If it is unable to identify it there, it will search across all User Storage providers configured for the realm until it finds one that matches. The Authority Service retrieves data from the external store and converts it to a internal common user model. It is possible to federate multiple different LDAP servers in the same Authority Service realm. You can map LDAP user attributes into the Authority Service common user model. By default, it maps username, email, first name, and last name, but you are free to configure additional mappings.
Authority Service imports users from LDAP into the local user database. Synchronization occurs on-demand or via a scheduled background job. There is an exception for password synchronization. Authority Service makes no attempt to import passwords. Password validation is performed on the LDAP server at all times.
Setting up Active Directory user federation
Given that:
Locator is avaible under
https://locator.internal
host nameAD domain name is
COMPANY.INTERNAL
Domain controller is at
ldap://DC.company.internal
AD Users distinguished name is
OU=Users, DC=company, DC=internal
you should perform following steps to setup user federation.
Prerequisites
Create the domain user
In Active directory create user named
svcKeycloak
. The user should only need to be a Domain User.Once the user is made, run a
dsquery
command to get the Bind DN string (ie.CN=svcKeycloak,OU=ServiceAccounts,OU=Users,DC=company,DC=internal
)
Configuring Active Directory integration
User Federation settings are dependent on particular Active Directory setup. You should adjusts following example to your current configuration. To learn more about federation settings, hover your mouse pointer over the tooltips in the Authority Service Admin Console.
Go to User Storage Federation menu option
On the right side, there is a list box labeled Add Provider. Select the LDAP provider type and you will be sent to the provider's settings page.
Adjusts settings according to screen below:
Enter the display name for the provider
Choose Active Directory in Vendor field
Set Import users to On. Authority Service will import users into local database.
Set Edit Mode to Read Only. You will be unable to modify the username, email address, first and last names, or any other mapped attributes. Updates to passwords are not supported.
Set Sync registrations to Off. Users created in Authority Service will not be synced back to LDAP.
Set Username LDAP attribute to “sAMAccountName”. This will set username of imported user to it’s Active Directory user name.
Set Custom User LDAP Filter to (&(objectCategory=Person)(sAMAccountName=*)) to import users with sAMAccountName attribute set only.
If you want to filter users to be imported by AD Group, extend filter with memberOf clause. For example, given that you want to import users in SagaUsers group only and distinguished name of that group is CN=SagaUsers,OU=Groups,DC=company,DC=internal, use following filter (&(objectCategory=Person)(sAMAccountName=*)(memberOf=CN=SagaUsers,OU=Groups,DC=company,DC=internal)) .
Set Search Scope to Subtree.
Set Bind DN and Bind Credential with the domain user created in prerequisites.
Go to Mappers tab and edit "username" mapper. Change LDAP Attribute to sAMAccountName
Configuring Single Sign On
This configuration is optional. Perform following steps only if you want to enable Kerberos Signle Sign On.
Run the following command on domain controller to assign a SPN to the user and generate a keytab file:
ktpass -out keycloak.keytab -princ HTTP/locator.internal@COMPANY.INTERNAL -mapUser Keycloak@COMPANY.INTERNAL -pass password! -kvno 0 -ptype KRB5_NT_PRINCIPAL -crypto RC4-HMAC-NT
Copy keycloak.ktab file to
<Saga Directory>\volumes\authority\docker-entrypoint.d
In LDAP provider configuration, turn on Kerberos integration and fill in details according to screen below
Set Allow Kerberos authentication to ON
Set your Kerberos Realm (ie.
COMPANY.INTERNAL
)Set your Server principal according to spn set on domain user (ie.
HTTP/locator.internal@COMPANY.INTERNAL
)Point to keytabfile ie.
c:\docker-entrypoint.d\keycloak.ktab
if you have copied ktab to<Saga Directory>\volumes\authority\docker-entrypoint.d
If you want to debug your configuration, set Debug to On.
Set Use Kerberos For Password Authentication to On.
Limitations
Active Directory user federation through LDAPS requires that the domain controller has a valid SSL certificate issued by a well-known authority.