Gitlab Omniauth with openid_connect with azure_ad as backend does not respect gitlab_username_claim
Summary
When using openid_connect with AzureAd, the gitlab_username_claim argument is not working.
Steps to reproduce
Configure omniauth oidc with AzureAd.
Config:
{
name: "openid_connect",
label: "Login with SSO",
icon: "",
args: {
name: "openid_connect",
scope: ["openid", "profile", "email"],
response_type: "code",
issuer: "https://login.microsoftonline.com/fill-in/v2.0",
client_auth_method: "query",
discovery: true,
gitlab_username_claim: "mycustomusernamefield",
client_options: {
identifier: "some-uid",
secret: "some-secret",
redirect_uri: "https://my.git.hostname/users/auth/openid_connect/callback"
}
}
}
Example Project
don't have one
What is the current bug behavior?
My username created via omniauth is the first part of the email until the @
What is the expected correct behavior?
The content of mycustomusernamefield should be used. It's included in the id_token, but not in the acces_token or the userinfo endpoint
Relevant logs and/or screenshots
sorry - didn't found anything in the logs
Output of checks
sorry - not run
Results of GitLab environment info
System information
System:
Current User: git
Using RVM: no
Ruby Version: 2.7.7p221
Gem Version: 3.2.33
Bundler Version:2.3.15
Rake Version: 13.0.6
Redis Version: 6.0.16
Sidekiq Version:6.5.7
Go Version: unknown
GitLab information
Version: 15.7.5
Revision: 358d690d91c
Directory: /srv/gitlab
DB Adapter: PostgreSQL
DB Version: 12.12
URL: https://gitlab.re.dac.ted
HTTP Clone URL: https://gitlab.re.dac.ted/some-group/some-project.git
SSH Clone URL: git@ssh.re.dac.ted:some-group/some-project.git
Using LDAP: yes
Using Omniauth: yes
Omniauth Providers: openid_connect, azure_activedirectory_v2
GitLab Shell
Version: 14.14.0
Repository storages:
- default: tcp://gitlab-praefect.gitlab-dev-default.svc:8075
GitLab Shell path: /home/git/gitlab-shell
Results of GitLab application Check
I swear, sidekiqk is running fine - I think, the checks are not correct when using the helm chart?
Checking GitLab subtasks ...
Checking GitLab Shell ...
GitLab Shell: ... GitLab Shell version >= 14.14.0 ? ... OK (14.14.0)
Running /home/git/gitlab-shell/bin/check
gitlab-shell self-check failed
Try fixing it:
Make sure GitLab is running;
Check the gitlab-shell configuration file:
sudo -u git -H editor /home/git/gitlab-shell/config.yml
Please fix the error above and rerun the checks.
Checking GitLab Shell ... Finished
Checking Gitaly ...
Gitaly: ... default ... OK
Checking Gitaly ... Finished
Checking Sidekiq ...
Sidekiq: ... Running? ... no
Try fixing it:
sudo -u git -H RAILS_ENV=production bin/background_jobs start
For more information see:
doc/install/installation.md in section "Install Init Script"
see log/sidekiq.log for possible errors
Please fix the error above and rerun the checks.
Checking Sidekiq ... Finished
Checking Incoming Email ...
Incoming Email: ... Reply by email is disabled in config/gitlab.yml
Checking Incoming Email ... Finished
Checking LDAP ...
LDAP: ... Server: ldapmain
Exception: SSL_connect returned=1 errno=0 state=error: certificate verify failed (unable to get local issuer certificate)
Checking LDAP ... Finished
Checking GitLab App ...
Database config exists? ... yes
All migrations up? ... yes
Database contains orphaned GroupMembers? ... no
GitLab config exists? ... yes
GitLab config up to date? ... yes
Cable config exists? ... yes
Resque config exists? ... yes
Log directory writable? ... yes
Tmp directory writable? ... yes
Uploads directory exists? ... yes
Uploads directory has correct permissions? ... yes
Uploads directory tmp has correct permissions? ... skipped (no tmp uploads folder yet)
Systemd unit files or init script exist? ... no
Try fixing it:
Install the Service
For more information see:
doc/install/installation.md in section "Install the Service"
Please fix the error above and rerun the checks.
Systemd unit files or init script up-to-date? ... can't check because of previous errors
Projects have namespace: ...
2/1 ... yes
1/6 ... yes
1/7 ... yes
1/9 ... yes
Redis version >= 6.0.0? ... yes
Ruby version >= 2.7.2 ? ... yes (2.7.7)
Git user has default SSH configuration? ... yes
Active users: ... 5
Is authorized keys file accessible? ... skipped (authorized keys not enabled)
GitLab configured to store new projects in hashed storage? ... yes
All projects are in hashed storage? ... yes
Checking GitLab App ... Finished
Checking GitLab subtasks ... Finished
Possible fixes
didn't found any
Edited by Markus Siebert