Create Realm and Client
Based on your Keycloak version, steps to create realm and OIDC client may differ. Refer to the Keycloak documentation specific for your Keycloak version.
Keycloak realm provides a management space where you can create users and give them permissions to use CZERTAINLY. CZERTAINLY realm can be considered as a kind of isolation you want to have for your users and applications using the platform.
You can create multiple realms in Keycloak for more granular isolation of use-cases related to the platform. For the purpose of this guide, we will create one new realm for CZERTAINLY.
To protect using OpenID connect protocol, we will need to create an OIDC client in the respective realm.
Create Realm
To create a new realm, follow steps in Creating a realm with the following attributes:
- Realm name: CZERTAINLY
Create OIDC Client
To create new OIDC client, follow steps described in Creating an OpenID Connect client with the following attributes:
- Client type: OpenID Connect
- Client ID: CZERTAINLY
- Name: CZERTAINLY
- Client authentication: On
- Root URL: https://<CZERTAINLY_DOMAIN>, where
<CZERTAINLY_DOMAIN>
is the domain of your CZERTAINLY instance. This serves as an access point to your deployment - Valid redirect URIs: URI pointing to redirect in Core after login via Keycloak, must contain
https://<CZERTAINLY_DOMAIN>/api/login/oauth2/code/<oauth2ProviderName>
, whereoauth2ProviderName
is a name of OAuth2 Provider configured in settings - Valid post logout redirect URIs: list of valid post logout redirect URIs, for example
https://<CZERTAINLY_DOMAIN>/administrator/
- Web origins: list of valid web origins, for example
https://<CZERTAINLY_DOMAIN>
Valid URIs and web origins should be properly configured to avoid any security related issues, for example Cross-origin resource sharing (CORS) issues.
Configure CZERTAINLY dedicated scope
The user in the platform is identified using JWT Access Token as described in the Identification part of the access control.
Based on the attributes coming from the configuration of the identity provider, proper mappers for the dedicated scope should be created. For more information, see OIDC token and SAML assertion mappings in the Keycloak documentation.
As an example, if you want to create mapper that will map groups
attributes (that are sent from Active Directory) to array of roles
in the JWT Claims Set, you can use the following configuration:
- Mapper type: User Attribute
- Name: Groups
- User Attribute: groups
- Token Claim Name: roles
- Claim JSON Type: String
- Add to ID token: On
- Add to access token: On
- Add to userinfo: On
- Multivalued: On
- Aggregate attribute values: Off