Similar in features to Gluu Server, Keycloak is an open-source identity and access management software. It supports user federation, OAuth, SAML, and OpenID Connect protocols. Along with role-based authorization, you can also connect to existing LDAP user directories. Rocket.Chat supports Keycloak configuration for you to securely manage your users and resources.
To create a client in Keycloak,
- Provide a Client ID:
rocket-chat-client
- Select the Client Protocol as
openid-connect.
- Select the Client access type as confidential.
- Standard flow implemented: ON
- Valid Redirect URL:
http:{Rocket.Chat_server_address}/*
{% hint style="info" %} Ensure the redirect URI is the IP and PORT of your Rocket.chat instance. {% endhint %}
After saving the changes, a new credentials tab will be created for the client. This credentials tab will provide the client secrets to be used when configuring Keycloak in your Rocket.Chat workspace.
- Login to Rocket.Chat with an administrator account and navigate to the OAuth page in the Settings tab.
- Click the Add custom OAuth button and provide the following details:
- URL:
http://{keycloak_ip_address}:{port}
- Token Path:
/realms/{realm_name}/protocol/openid-connect/token
- Token sent via: Header
- Identity Token Sent Via: Same As "Token Sent Via"
- Identity Path:
/realms/{realm_name}/protocol/openid-connect/userinfo
- Authorize Path:
/realms/{realm_name}/protocol/openid-connect/auth
- Scope:
openid
- Param Name for access token:
access_token
- Id: This is the id of the Rocket.Chat client created in the keycloak
rocket-chat-client
- Secret: Secret key provided in the credentials tab when creating the Rocket.Chat client.
- Button Text:
Login with Keycloak
- URL:
{% hint style="info" %}
You can also access the URL paths provided in the configurations by navigating to the Realm setting > General and clicking the endpoints link. While configuring the settings, replace the realm_name
with the appropriate realm name. The default realm provided by Keycloak is master
.
{% endhint %}
- Leave the rest of the configurations as default. Click Save Changes.
- Enable the new Keycloak provider. Click Refresh OAuth Services.
- If you are in a test environment with no SMTP server set, disable two-factor authentication in Administration > Settings > General.
A Login with KeyCloak button appears on your workspace's login page. Users can now log in with Keycloak!
Client-specific roles of a Keycloak-managed user can be mapped to Rocket.Chat roles. This does not work for federated users (LDAP-managed users). For this example, to map the admin
and livechat-manager
role, add the required roles to the client.
To create a role in Keycloak,
- Navigate to Roles and click Add Role.
- Fill in the name and description of the role, and then click Save.
- Add a mapper entry that maps our client roles to OpenID, passing the value to Rocket.Chat.
To view all the client roles you have created, navigate to Roles and click View all roles.
A composite role is a role that can be associated with other roles. To define composite roles, navigate to Roles > Composite Roles.
To grant the Rocket.Chat role to a user, we have to modify the user's Role Mappings.
Create Protocol Mapper
Mappers