I'm trying to add the LDAP feature for our GitLab. We have a running ActiveDirectoy server running on windows. Gitlab itself is hosted on an ubuntu server machine. For the authentication we created a serverice-user on the ad server. here is my gitlab.rb file (showing only the ldap config.)
gitlab_rails['ldap_servers'] = YAML.load <<-'EOS'
main:
label: 'LDAP'
host: '1.2.3.4'
port: 389
uid: 'serviceAcc'
bind_dn: 'CN=serviceACC,OU=Org 1,DC=organisation,DC=com'
password: 'supersecurePass'
encryption: 'plain'
active_directory: true
EOS
The options which are not listed, are commented-out (so the default values will be used). Next I execute the both commands:
sudo gitlab-ctl reconfigure
sudo gitlab-rake gitlab:ldap:check
This is the result of the last command:
Checking LDAP ...
LDAP: ... Server: ldapmain
LDAP authentication... Success
LDAP users with access to your GitLab server (only showing the first 100 results)
Checking LDAP ... Finished
Why is my list empty? Shouldn't there be listed all users of the ad? I also tried applying the base_dn option, where the users are stored.
If I do an lsdapsearch i get the results:
ldapsearch -H ldap://1.2.3.4 -x -W -D "[email protected]" -b "dc=organisation,dc=com" "(objectClass=user)" mail
.
.
.
# serviceACC, Org 1, organisation.com
dn: CN=serviceACC,OU=Org 1,DC=organisation,DC=com
.
.
.
So the AD server is reachable and response to my ldapsearch query. Am I missing something in the gitlab.rb config?
I'm using the gitlab EE with the version 12.5.3
UPDATE Here are the requested details for @EricLavault:
- username:user.1 ; dn:CN=User 1,OU=Company Workers,DC=company,DC=com
- The user submits it's AD credentials: Username:user.1 PW:#his AD-PW#
- For the error logs i can proivde you the production.log. If you need some more logs, let me know:
Started POST "/users/auth/ldapmain/callback" for 1.2.3.8 at 2019-12-11-07:48:59 +0000 Processing by OmniauthCallbacksController#failure as HTML Parameters: {"utf8"=>"✓", "authenticity_token"=>"[FILTERED]", "username"=>"user.1", "password"=>"[FILTERED]"} Redirected to https://git.company.com/users/sign_in
For security reasons I have to change the real values with dummy values. But please, trust me that the provided user details are similars to the real values. (usernames with ".", Service User is in another OU than the users which will login to the gitlab)
The user will be displayed following error message:
Could not authenticate you from Ldapmain because "Invalid credentials for user.1".
The credentials are right.
First, you need to fix the uid setting. It should hold the username attribute, not the value that maps to a username. Since you are targeting AD, this should be either
sAMAccountName
oruserPrincipalName
(eg. matching respectivelyusername
or[email protected]
).If using
sAMAccountName
as uid and in case users submit[email protected]
format on login (instead of justusername
) you need to setallow_username_or_email_login: true
(default is false).Otheriwse if using
userPrincipalName
as uid, you must set it tofalse
.Then, you can set the
base
to narrow the search to users only, if you are not sure where users are located in the directory, just set the domain components as you did with ldapsearch:base: 'dc=organisation,dc=com'
.You can also set a filter as you did with ldapsearch :
user_filter: '(objectClass=user)'
.Recap :