This add-on (plugin) provides SCIM server functionality with multiple IDP IdP support that allows securely automate the exchange of user identity data between your IDPs and Atlassian Jira according to the SCIM specification v.2 or v.1.1. Thus, this gives you the ability to easily synchronize your user and group accounts from different IDPs such as OneLogin, OKTA, Azure, etc.
...
1.
Anchor | ||||
---|---|---|---|---|
|
...
2.
Anchor | ||||
---|---|---|---|---|
|
2.1. Quick setup
As an overview, we will show how you can quickly create a new SCIM configuration and get the parameters to configure your IDP connection.
Open the plugin Configuration page, navigate to the New Configuration tab and specify the values as shown below, then click Generate token.
...
Navigate to the General tab. Existing Configurations. Here in the table Existing Configurations we can see a new entry with the configuration parameters we specified.
...
Your IDP will need SCIM v2 URL (or possible v1) and Bearer Token to set up a connection. You can also test the SСIM API as described in p. 4.
Note that the SСIM v1/v2 URL values here are relative to the server with the Jira instance, as if the SCIM client (IDP) is on the same server. So, the actual URL that you need to specify in the IDP will differ and depends on your network configuration and settings.
2.2. Advanced Setup
Let's look at the configuration options in more detail. Please navigate to the New Configuration tab again. Here we specify the parameters for creating a new configuration, which determine whether a new Jira internal directory will be created, the authentication method, the method for deactivating users and the ability to assign users to groups by default when a new user is registered.
User Directory - by default you can select any Jira internal 'User Directory' or create a new one for user provisioning (Create new user directory option).
Directory Name - specify the name of the directory to be created.
Username that will be used for BASIC Auth - optional parameter. The name of an existing Jira user if you select the HTTP Basic authentication access control method. By default, if no username is specified, the OAuth2 Bearer Token (which acts as the authentication of the API request) method will be used.
Delete users - If you select 'Yes' users will be completely deleted from Jira on delete operation. If you select 'No' users will be only disabled.
Default Group(s) - a comma-separated list of groups that users will be added to when they are created through the provisioning process.
Application Group(s) - there are three Jira applications: Jira Core, Jira Software and Jira Service Desk. Each of these applications allows users to create and use specific project types. Determine which applications the user will be associated with by default.
The created configurations are displayed on the General tab:
...
To set up a connection on the SСIM client/IDP side, you will need to specify the OAuth2 Bearer Token or Basic Auth (username and password) and the real URL corresponding to the value of the SCIM v2/v1 field.
3.
Anchor | ||||
---|---|---|---|---|
|
3.1. Utils for Existing Users/Directories
The plugin's internal logic of working with data is based on the automatic building of mapping for existing app users, groups and memberships with bindings to the corresponding directories. Mappings are stored in so-called SСIM tables. During the plugin regular operation, synchronization of SСIM tables is performed automatically. But, sometimes, you need manually sync data. For example, when you just installed a plugin, and you need perform an initial synchronization with users, groups, memberships and directories of the application. This operation does not affect the application data but only supplements the information in the SСIM tables with missing data.
Navigate to Utils for Existing Users/Directories tab.
Build mapping for existing users, groups and memberships section.
Sync Users & Groups button (optional) - synchronize local users and groups for SCIM API. Initiates asynchronous execution of a background synchronization task on the server. As a result, SCIM tables data about users and groups will match application data.
Show statistics… - expand the block of information with the statistics of the last synchronization. During the execution of the background synchronization task, the information updates dynamically.
...
Remove/Reset Users Data section.
User Directory drop-down menu - select a directory for further actions.
Remove Directory button - all users and groups of the selected directory in the application and SСIM tables will be deleted. Be careful, this operation is irreversible.
Clear All datа from SCIM Tables button - all users and groups of the selected directory in the SСIM tables will be deleted. However, if you then perform Sync Users & Groups, the data will be restored using information from the app. Note that the users and groups IDs will be changed (regenerated) in SCIM tables.
3.2. SCIM Customization
Navigate to SCIM Customization tab, Users last login info section.
Here you can enable the mode of displaying information about the user’s last login in responses to Get /Users requests. Information will be represented in the meta.lastLogin attribute and also according to User Enterprise Schema Extension (One Identity version).
...
Sync Users last login info button - is intended for initial synchronization the users last login info between the application data and the SCIM table. Further synchronization is performed automatically.
...
4.
Anchor | ||||
---|---|---|---|---|
|
...
Code Block | ||
---|---|---|
| ||
curl -X GET https://jiratest.luxplugins.com:2990/jira/rest/user-provisioning/1.0/scim/v2/Users -H "Accept: application/json" -H "Authorization: Bearer xxxxxxxxxxxxxxxxxxxx" |
where xxxxxxxxxxxxxxxxxxxx
is your bearer token.
4.3. PostMan
Postman is an API platform for building, using and testing APIs. With a rich GUI, Postman simplifies your work. Let's see how we can create our request.
...
Check the setting. Click Ctrl+F and enter luxplugins, then click Enter. Check the logging level of found record:
...
Note that any changes you make here are not persisted across server restarts. You will need to edit 'WEB-INF/classes/log4j.properties' to change levels permanently.
5.2
...
. SCIM Audit Log
You can easily check API requests history from the Jira admin page (Audit Log menu item in the SCIM section of the left-hand menu). By default, recording the history of incoming requests to the log is disabled. You can turn it on with the trigger button:
...
Log filtering feature makes it easy to search for events based on various search criteria. For example, you need to find the request that initiated the creation of a user with the family name fn_lk10fjjz
:
...
Search result:
...
The Audit Log can be uploaded to a CSV file (Export to CSV button), which can then be processed in the way you need. The uploaded file will contain no more than 10,000 recent records that match the conditions of the last filtering performed.
The Сlear History button will delete all existing log entries. The Reset Filter button will clear the filtering conditions, as a result, the initial unfiltered set of records will be displayed.
5.3. Our support
If you have any questions please ask our support team.
https://luxplugins.atlassian.net/servicedesk/customer/portal/1
Sometimes, If you contact our support with an issue, our team may also ask you to send a .csv file of the SCIM Audit Log to help us understand the problem faster. The same may apply to the system log file described in p. 5.1. regarding the operation of the plugin.
6.
Anchor | ||||
---|---|---|---|---|
|
SCIM Integration with OKTA (new)
SCIM Integration with OKTA, on-premises provisioning architecture (new)
SCIM Integration with Azure Active Directory (new)
SCIM Integration with Google Workspace (new)