Skip to main content

Create Realm and Client

Keycloak version

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>, where oauth2ProviderName 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>
URIs and origins

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