mirror of
https://github.com/Unleash/unleash.git
synced 2025-02-19 00:15:43 +01:00
109 lines
4.7 KiB
Markdown
109 lines
4.7 KiB
Markdown
|
---
|
||
|
title: 'How to set up Keycloak and Unleash to sync user groups'
|
||
|
---
|
||
|
|
||
|
:::info availability
|
||
|
|
||
|
User group syncing is an upcoming Unleash feature that will be available for enterprise customers.
|
||
|
|
||
|
:::
|
||
|
|
||
|
In this guide, we will setup OIDC Single Sign-On (SSO) in Keycloak and configure Unleash to automatically sync user group membership from Keycloak.
|
||
|
|
||
|
## Prerequisites
|
||
|
The steps in this guide assume you have admin access to a running Unleash instance and to a running Keycloak instance.
|
||
|
|
||
|
## Keycloak Configuration
|
||
|
|
||
|
### Step 1: Navigate to Create Client {#keycloak-step-1}
|
||
|
|
||
|
Open the Keycloak admin dashboard, navigate to clients and select "Create Client".
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/31c07/31c07a399a7e203aeb7bb0adc1db840351e0a89f" alt="The Keycloak Admin UI with the steps highlighted to navigate to client configuration."
|
||
|
|
||
|
|
||
|
### Step 2: Create an Unleash Client {#keycloak-step-2}
|
||
|
|
||
|
Select "OpenID Connect" as the client type and give your client a name, then save your configuration.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/cd7de/cd7de508b75c2ff5fbb9e465b615d2ce3ca33280" alt="The Keycloak Admin UI with the client configuration open."
|
||
|
|
||
|
### Step 3: Set a redirect URI {#keycloak-step-3}
|
||
|
|
||
|
Set the redirect URI to:
|
||
|
|
||
|
`<base-url>/auth/oidc/callback`
|
||
|
|
||
|
For a hosted Unleash instance this becomes:
|
||
|
|
||
|
`https://<region>.app.unleash-hosted.com/<instance-name>/auth/oidc/callback`
|
||
|
|
||
|
Save your configuration.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/d9a10/d9a1059ebe6c03583d4c73d5da4e4c1d626cc159" alt="The Keycloak client configuration with redirect URIs highlighted."
|
||
|
|
||
|
### Step 4: Copy your client secret {#keycloak-step-4}
|
||
|
|
||
|
Navigate to "Credentials" and copy your client secret. You'll need to add this to the Unleash configuration later, so put it somewhere you'll be able to find it.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/48585/485853d6295b02eed4a3a5a57368221085d01b78" alt="The Keycloak credentials configuration with copy client secret highlighted."
|
||
|
|
||
|
### Step 5: Copy your OpenID endpoint configuration {#keycloak-step-5}
|
||
|
|
||
|
Navigate to your realm settings and copy the link to OpenID endpoint configuration. You'll need to add this to the Unleash configuration later.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/017b8/017b8bc24695a7852cae5993f7a61b3a089f9a5c" alt="The Keycloak realm settings the OpenID endpoint configuration link highlighted."
|
||
|
|
||
|
### Step 6: Create a new Client Scope and Map Groups {#keycloak-step-6}
|
||
|
|
||
|
Navigate to the "Client Scopes" page and select "Create Client Scope".
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/90d8a/90d8a92f183907a24430d17d00fafcc59366fa46" alt="The Keycloak Client Scopes page with the Create Client Scope button highlighted."
|
||
|
|
||
|
Give your new scope a name. Set the type to "Optional". Make sure the protocol is set to "OpenID Connect" and the "Include in Token Response" option is enabled. Save your new scope.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/a4a5e/a4a5e80e16e0731117445baa3cab5d2441798d6a" alt="The Keycloak Add Client Scope page with the Name, Type, Protocol and Include in Token Response fields highlighted."
|
||
|
|
||
|
Navigate the the Mappers tab and select "Configure new Mapper".
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/de599/de599c52b37bf902f4a80df5d64edf031a7f4af8" alt="The Keycloak Client Scope details page with the Mappers tab and Configure new Mapper element highlighted."
|
||
|
|
||
|
Select the Group Membership mapper.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/6622d/6622dcf095c14e2b7d0297a816c1e7eac9763892" alt="The Keycloak mapper popup with the Group Membership mapper highlighted."
|
||
|
|
||
|
Give your mapper a claim name, this must match the "Group Field JSON Path" in Unleash, and turn off the "Full group path" option.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/8b1a7/8b1a70b6e6b754187f36e3f4e03b1b69e1b688ab" alt="The Keycloak mapper options screen with the Token Claim Name and Full Group Path elements highlighted."
|
||
|
|
||
|
|
||
|
## Unleash Configuration
|
||
|
|
||
|
### Step 1: Navigate to the Unleash SSO Configuration {#unleash-step-1}
|
||
|
|
||
|
Log in to Unleash as an admin user and navigate to the SSO configuration. Input your Client Secret (copied in step 3 of the Keycloak configuration), your Discover URL (copied in step 4 of the Keycloak configuration), and the Client ID (from step 2 of the Keycloak configuration).
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/b8f05/b8f055f0f48427765b33b8d5cddac0beaf3e7b13" alt="The Unleash SSO configuration screen with Client ID, Client Secret and Discover URL highlighted."
|
||
|
|
||
|
### Step 2: Enable Group Syncing {#unleash-step-2}
|
||
|
|
||
|
Turn on Group Syncing and set a value for "Group Field JSON Path". This must match the value in claim name in Keycloak exactly. Save your configuration.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/f26dc/f26dcf97adf1460b5f1d2d2329b9d1c783e57c52" alt="The Unleash SSO configuration screen with the Enable Group Syncing and Group Field JSON Path highlighted."
|
||
|
|
||
|
### Step 3: Enable Group Syncing for your Group {#unleash-step-3}
|
||
|
|
||
|
Navigate to Groups and select the group that you want to sync.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/cf92c/cf92c3d2fd5ed7c45d046885d76d127c011328aa" alt="The Groups page with a group element highlighted."
|
||
|
|
||
|
Edit the group.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/552ee/552ee39cf406ed94c0b90903824c23b491f10db9" alt="The Group page with the Edit group element highlighted."
|
||
|
|
||
|
Add as many SSO groups as you like. These need to match the Keycloak groups exactly.
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/720de/720def50cb08d148d03cb1bc762d7545040a33e7" alt="The edit group page with the add SSO group element highlighted."
|
||
|
|
||
|
Save your configuration. Once a user belonging to one of these Keycloak groups logs in through SSO, they'll be automatically added to this Unleash group.
|