Configure SCIM for GitLab Self-Managed
- Introduced in GitLab 15.8.
You can use the open standard System for Cross-domain Identity Management (SCIM) to automatically:
- Create users.
- Block users.
- Re-add users (reactivate SCIM identity).
The internal GitLab SCIM API implements part of the RFC7644 protocol.
If you are a GitLab.com user, see configuring SCIM for GitLab.com groups.
Configure GitLab
Prerequisites:
- Configure SAML single sign-on.
To configure GitLab SCIM:
- On the left sidebar, at the bottom, select Admin.
- Select Settings > General.
- Expand the SCIM Token section and select Generate a SCIM token.
- For configuration of your identity provider, save the:
- Token from the Your SCIM token field.
- URL from the SCIM API endpoint URL field.
Configure an identity provider
You can configure the following as an identity provider:
Configure Okta
The SAML application created during single sign-on set up for Okta must be set up for SCIM.
Prerequisites:
- You must use the Okta Lifecycle Management product. This product tier is required to use SCIM on Okta.
- GitLab is configured for SCIM.
- The SAML application for Okta set up as described in the Okta setup notes.
- Your Okta SAML setup matches the configuration steps, especially the NameID configuration.
To configure Okta for SCIM:
- Sign in to Okta.
- In the upper-right corner, select Admin. The button is not visible from the Admin area.
- In the Application tab, select Browse App Catalog.
- Find and select the GitLab application.
- On the GitLab application overview page, select Add Integration.
- Under Application Visibility, select both checkboxes. The GitLab application does not support SAML authentication so the icon should not be shown to users.
- Select Done to finish adding the application.
- In the Provisioning tab, select Configure API integration.
- Select Enable API integration.
- For Base URL, paste the URL you copied from SCIM API endpoint URL on the GitLab SCIM configuration page.
- For API Token, paste the SCIM token you copied from Your SCIM token on the GitLab SCIM configuration page.
- To verify the configuration, select Test API Credentials.
- Select Save.
- After saving the API integration details, new settings tabs appear on the left. Select To App.
- Select Edit.
- Select the Enable checkbox for both Create Users and Deactivate Users.
- Select Save.
- Assign users in the Assignments tab. Assigned users are created and managed in your GitLab group.
Configure Microsoft Entra ID (formerly Azure Active Directory)
- Changed to Microsoft Entra ID terminology in GitLab 16.10.
Prerequisites:
The SAML application created during single sign-on set up for Azure Active Directory must be set up for SCIM. For an example, see example configuration.
To configure Microsoft Entra ID, you configure:
- Microsoft Entra ID for SCIM.
- Settings.
- Mappings, including attribute mappings.
Configure Microsoft Entra ID for SCIM
- In your app, go to the Provisioning tab and select Get started.
- Set the Provisioning Mode to Automatic.
- Complete the Admin Credentials using the value of:
- SCIM API endpoint URL in GitLab for the Tenant URL field.
- Your SCIM token in GitLab for the Secret Token field.
-
Select Test Connection.
If the test is successful, save your configuration.
If the test is unsuccessful, see troubleshooting to try to resolve this.
- Select Save.
After saving, the Mappings and Settings sections appear.
Configure mappings
Under the Mappings section, first provision the groups:
- Select Provision Microsoft Entra ID Groups.
-
On the Attribute Mapping page, turn off the Enabled toggle.
SCIM group provisioning is not supported in GitLab. Leaving group provisioning enabled does not break the SCIM user provisioning, but it causes errors in the Entra ID SCIM provisioning log that might be confusing and misleading.
Even when Provision Microsoft Entra ID Groups is disabled, the mappings section may display “Enabled: Yes”. This behavior is a display bug that you can safely ignore. - Select Save.
Next, provision the users:
- Select Provision Microsoft Entra ID Users.
- Ensure that the Enabled toggle is set to Yes.
- Ensure that all Target Object Actions are enabled.
- Under Attribute Mappings, configure mappings to match
the configured attribute mappings:
- Optional. In the customappsso Attribute column, find
externalId
and delete it. - Edit the first attribute to have a:
-
source attribute of
objectId
. -
target attribute of
externalId
. -
matching precedence of
1
.
-
source attribute of
- Update the existing customappsso attributes to match the configured attribute mappings.
- Delete any additional attributes that are not present in the attribute mappings table. They do not cause problems if they are not deleted, but GitLab does not consume the attributes.
- Optional. In the customappsso Attribute column, find
- Under the mapping list, select the Show advanced options checkbox.
- Select the Edit attribute list for customappsso link.
- Ensure the
id
is the primary and required field, andexternalId
is also required. - Select Save, which returns you to the Attribute Mapping configuration page.
- Close the Attribute Mapping configuration page by clicking the
X
in the top right corner.
Configure attribute mappings
While configuring Entra ID for SCIM, you configure attribute mappings. For an example, see example configuration.
The following table provides attribute mappings that are required for GitLab.
Source attribute | Target attribute | Matching precedence |
---|---|---|
objectId
| externalId
| 1 |
userPrincipalName OR mail 1
| emails[type eq "work"].value
| |
mailNickname
| userName
| |
displayName OR Join(" ", [givenName], [surname]) 2
| name.formatted
| |
Switch([IsSoftDeleted], , "False", "True", "True", "False") 3
| active
|
Footnotes:
- Use
mail
as a source attribute when theuserPrincipalName
is not an email address or is not deliverable. - Use the
Join
expression if yourdisplayName
does not match the format ofFirstname Lastname
. - This is an expression mapping type, not a direct mapping. Select Expression in the Mapping type dropdown list.
Each attribute mapping has:
- A customappsso Attribute, which corresponds to target attribute.
- A Microsoft Entra ID Attribute, which corresponds to source attribute.
- A matching precedence.
For each attribute:
- Edit the existing attribute or add a new attribute.
- Select the required source and target attribute mappings from the dropdown lists.
- Select Ok.
- Select Save.
If your SAML configuration differs from the recommended SAML settings, select the mapping
attributes and modify them accordingly. The source attribute that you map to the externalId
target attribute must match the attribute used for the SAML NameID
.
If a mapping is not listed in the table, use the Microsoft Entra ID defaults. For a list of required attributes, refer to the internal instance SCIM API documentation.
Configure settings
Under the Settings section:
- Optional. If desired, select the Send an email notification when a failure occurs checkbox.
- Optional. If desired, select the Prevent accidental deletion checkbox.
- If necessary, select Save to ensure all changes have been saved.
After you have configured the mappings and the settings, return to the app overview page and select Start provisioning to start automatic SCIM provisioning of users in GitLab.
id
and externalId
might cause errors. These include
provisioning errors, duplicate users, and might prevent existing users from accessing the GitLab group.Remove access
Removing or deactivating a user on the identity provider blocks the user on the GitLab instance, while the SCIM identity remains linked to the GitLab user.
To update the user SCIM identity, use the internal GitLab SCIM API.
Reactivate access
-
Introduced in GitLab 16.0 with a flag named
skip_saml_identity_destroy_during_scim_deprovision
. Disabled by default. -
Generally available in GitLab 16.4. Feature flag
skip_saml_identity_destroy_during_scim_deprovision
removed.
After a user is removed or deactivated through SCIM, you can reactivate that user by adding them to the SCIM identity provider.
After the identity provider performs a sync based on its configured schedule, the user’s SCIM identity is reactivated and their GitLab instance access is restored.
Troubleshooting
See our troubleshooting SCIM guide.