Installation
docker :
docker run -p 8080:8080 -e KEYCLOAK_ADMIN=admin -e KEYCLOAK_ADMIN_PASSWORD=admin quay.io/keycloak/keycloak:24.0.1 start-dev --features=preview
or
Download the Keycloak server from the official website and start it with the following command:
bin/kc.sh start-dev --features=preview
In either case it is important that the flag: --features=preview is passed along in order to enable the "token-exchange" option (see below).
Keycloak Realm Configuration
- Create a new realm named "waltid-keycloak-ktor" in the Keycloak admin console.
data:image/s3,"s3://crabby-images/2918d/2918d72a8155ea3c95c255a09b229e90d565485a" alt="image realm creation"
Client Setup
- Setup a client with the following configurations:
data:image/s3,"s3://crabby-images/3d305/3d305c6f5366c64bc305dc0a24a1e908a7da1e56" alt="image of client configuration"
- Client Capability Configuration
Configure client capabilities:
data:image/s3,"s3://crabby-images/43631/436311c338d4872e5094a113044bba3caca5a292" alt="image of client capabilities"
- Login Settings in Client Config :
data:image/s3,"s3://crabby-images/5bb9e/5bb9ee90643d7d8dce7cf7b44179cf2eb278d2ab" alt="image of client login settings"
1.Root URL : Public root URL of the wallet.
2. Home URL : Default URL for redirects or links.
3. Valid URI pattern for successful login redirects (wildcard: *).
4. Web origins : Allowed CORS origins.
Service Account Configuration
To use the Keycloak user API, you need to add a service account role in Keycloak. This role is used to authenticate a user using the username and password.
- Go to the Keycloak admin console and select the realm you want to use.
- Go to the client waltid_backend and select the
Service Account Roles
tab. - Add the
manage-users
role to the service account.
data:image/s3,"s3://crabby-images/7a18c/7a18ca900ee1b37833c2ff37a9b80ec1b9980831" alt="image of service account roles"
Token exchange for user impersonation Configuration
User impersonation in Keycloak allows one user to obtain a token that represents another user, enabling them to perform actions on behalf of that user. This process involves exchanging a token granted to the acting user with another token representing the target user.
To granting permission for the exchange of tokens , you need to define a token-exchange fine grain permission in the target client you want permission to exchange to.
- Go to the Keycloak admin console and select the realm waltid-keycloak-ktor.
- Go to the client waltid_backend and select the
Permissions
tab. - Toggle Permissions Enabled to On.
data:image/s3,"s3://crabby-images/1d61e/1d61e8d3c466f7820dab3261bd9e0cd17aecd730" alt="image of token exchange permission"
- Click on the token-exchange link and add the
token-exchange
permission to the client.
data:image/s3,"s3://crabby-images/4e5fc/4e5fc609d3a326723a1ac89878f915ed08c084e5" alt="image of token exchange permission"
- Click Client details in the breadcrumbs at the top of the screen.
Define a policy for this permission
- Click Authorization in the breadcrumbs at the top of the screen.
- Click Policies in the breadcrumbs at the top of the screen.
- Click Create Policy.
data:image/s3,"s3://crabby-images/5ae35/5ae358713979cc944d53c5bba61184a0c7f3e5c8" alt="image of token exchange policy"
- After you create this policy, go back to the target client’s token-exchange permission and add the client policy you just defined.
Apply Client Policy
data:image/s3,"s3://crabby-images/ae7ed/ae7edb39e3af385cfb5e84346dc64f1eb2b72f19" alt="image of token exchange policy"
Impersonation Configuration
- Go to the Keycloak admin console and select the realm you want to use.
- Go to the Users tab in the left-hand menu.
- Go to permissions .
data:image/s3,"s3://crabby-images/ccad8/ccad8bb896e68fff622dbdd6ae2f320510dd7f6e" alt="image of user permission"
- Click on the impersonate link and click the
impersonate
link.
data:image/s3,"s3://crabby-images/48ca7/48ca731e3a7445354f63cf2c38b5708d87fcb644" alt="image of user permission details"
- Click Client details in the breadcrumbs at the top of the screen.
Define a policy for this permission
data:image/s3,"s3://crabby-images/33752/337523a969107c5d55c005c851d91fa08a02b553" alt="image of user permission policy"
- After you create this policy, go back to users' impersonation permission and add the client policy you just defined.
Apply Client Policy
data:image/s3,"s3://crabby-images/eaa68/eaa685ee3091b147fd929f0c5edbebff57387e91" alt="image of user permission policy apply"
Keycloak integration in wallet-api
Read here how to configure wallet-api to support Keycloak login.
Keycloak provider configuration
Update OIDC config file in config/oidc.conf
:
enableOidcLogin = true
providerName = keycloak
oidcRealm = "https://keycloak.walt-test.cloud/realms/waltid-keycloak-ktor"
oidcJwks = "${oidcRealm}/protocol/openid-connect/certs"
authorizeUrl = "${oidcRealm}/protocol/openid-connect/auth"
accessTokenUrl = "${oidcRealm}/protocol/openid-connect/token"
logoutUrl = "${oidcRealm}/protocol/openid-connect/logout"
clientId = "waltid_backend"
keycloakUserApi = "https://keycloak.walt-test.cloud/admin/realms/waltid-keycloak-ktor/users"
clientSecret = "..."
jwksCache = {
cacheSize = 10
cacheExpirationHours = 24
rateLimit: {
bucketSize: 10
refillRateMinutes: 1
}
}
oidcRealm
: The realm base URL:<keycloak-URL>/realms/<realm-name>
clientId
: Specify the client ID created in Keycloak.clientSecret
: The client secret is generated by Keycloak (found inclients -> <client_name> -> credentials
):
data:image/s3,"s3://crabby-images/98b7d/98b7d19d73e1a0d33c4397f88fd7bbd0c7ccf12c" alt="image of client secret"