Secure an app with Keycloak
Before you start
If you already have an up and running otoroshi instance, you can skip the following instructions
Let’s start by downloading the latest Otoroshi.
curl -L -o otoroshi.jar 'https://github.com/MAIF/otoroshi/releases/download/v16.22.0/otoroshi.jar'
then you can run start Otoroshi :
java -Dotoroshi.adminPassword=password -jar otoroshi.jar
Now you can log into Otoroshi at http://otoroshi.oto.tools:8080 with admin@otoroshi.io/password
Create a new route, exposed on http://myservice.oto.tools:8080
, which will forward all requests to the mirror https://request.otoroshi.io
. Each call to this service will returned the body and the headers received by the mirror.
curl -X POST 'http://otoroshi-api.oto.tools:8080/api/routes' \
-H "Content-type: application/json" \
-u admin-api-apikey-id:admin-api-apikey-secret \
-d @- <<'EOF'
{
"name": "my-service",
"frontend": {
"domains": ["myservice.oto.tools"]
},
"backend": {
"targets": [
{
"hostname": "request.otoroshi.io",
"port": 443,
"tls": true
}
]
}
}
EOF
Running a keycloak instance with docker
docker run \
-p 8080:8080 \
-e KEYCLOAK_USER=admin \
-e KEYCLOAK_PASSWORD=admin \
--name keycloak-server \
--detach jboss/keycloak:15.0.1
This should download the image of keycloak (if you haven’t already it) and display the digest of the created container. This command mapped TCP port 8080 in the container to port 8080 of your laptop and created a server with admin/admin
as admin credentials.
Once started, you can open a browser on http://localhost:8080 and click on Administration Console
. Log to your instance with admin/admin
as credentials.
The first step is to create a Keycloak client, an entity that can request Keycloak to authenticate a user. Click on the clients button on the sidebar, and then on Create button at the top right of the view.
Fill the client form with the following values.
Client ID
:keycloak-otoroshi-backoffice
Client Protocol
:openid-connect
Root URL
:http://otoroshi.oto.tools:8080/
Validate the creation of the client by clicking on the Save button.
The next step is to change the Access Type
used by default. Jump to the Access Type
field and select confidential
. The confidential configuration force the client application to send at Keycloak a client ID and a client Secret. Scroll to the bottom of the page and save the configuration.
Now scroll to the top of your page. Just at the right of the Settings
tab, a new tab appeared : the Credentials
page. Click on this tab, and make sure that Client Id and Secret
is selected as Client Authenticator
and copy the generated Secret
to the next part.
Create a Keycloak provider module
- Go ahead, and navigate to http://otoroshi.oto.tools:8080
- Click on the cog icon on the top right
- Then
Authentication configs
button - And add a new configuration when clicking on the
Add item
button - Select the
OAuth2 / OIDC provider
in the type selector field - Set a basic name and description
A simple way to import a Keycloak client is to give the URL of the OpenID Connect
Otoroshi. By default, keycloak used the next URL : http://localhost:8080/auth/realms/master/.well-known/openid-configuration
.
Click on the Get from OIDC config
button and paste the previous link. Once it’s done, scroll to the URLs
section. All URLs has been fill with the values picked from the JSON object returns by the previous URL.
The only fields to change are :
Client ID
:keycloak-otoroshi-backoffice
Client Secret
: Paste the secret from the Credentials Keycloak page. In my case, it’s something like90c9bf0b-2c0c-4eb0-aa02-72195beb9da7
Callback URL
:http://otoroshi.oto.tools:8080/backoffice/auth0/callback
At the bottom of the page, disable the secure
button (because we’re using http and this configuration avoid to include cookie in an HTTP Request without secure channel, typically HTTPs). Nothing else to change, just save the configuration.
Connect to Otoroshi with Keycloak authentication
To secure Otoroshi with your Keycloak configuration, we have to register an Authentication configuration as a BackOffice Auth. configuration.
- Navigate to the danger zone (when clicking on the cog on the top right and selecting Danger zone)
- Scroll to the BackOffice auth. settings
- Select your last Authentication configuration (created in the previous section)
- Save the global configuration with the button on the top right
Testing your configuration
- Disconnect from your instance
- Then click on the Login using third-party button (or navigate to http://otoroshi.oto.tools:8080)
- Click on Login using Third-party button
- If all is configured, Otoroshi will redirect you to the keycloak login page
- Set
admin/admin
as user and trust the user by clicking onyes
button. - Good work! You’re connected to Otoroshi with an Keycloak module.
A fallback solution is always available in the event of a bad authentication configuration. By going to http://otoroshi.oto.tools:8080/bo/simple/login, the administrators will be able to redefine the configuration.
Visualize an admin user session or a private user session
Each user, wheter connected user to the Otoroshi UI or at a private Otoroshi app, has an own session. As an administrator of Otoroshi, you can visualize via Otoroshi the list of the connected users and their profile.
Let’s start by navigating to the Admin users sessions
page (just here or when clicking on the cog, and on the Admins sessions
button at the bottom of the list).
This page gives a complete view of the connected admins. For each admin, you have his connection date and his expiration date. You can also check the Profile
and the Rights
of the connected users.
If we check the profile and the rights of the previously logged user (from Keycloak in the previous part) we can retrieve the following information :
{
"sub": "4c8cd101-ca28-4611-80b9-efa504ac51fd",
"upn": "admin",
"email_verified": false,
"address": {},
"groups": [
"create-realm",
"default-roles-master",
"offline_access",
"admin",
"uma_authorization"
],
"preferred_username": "admin"
}
and his default rights
[
{
"tenant": "default:rw",
"teams": [
"default:rw"
]
}
]
We haven’t create any specific groups in Keycloak or specify rights in Otoroshi for him. In this case, the use received the default Otoroshi rights at his connection. The user can navigate on the default Organization and Teams (which are two resources created by Otoroshi at the boot) and have the full access on its (r
: Read, w
: Write, *
: read/write).
In the same way, you’ll find all users connected to a private Otoroshi app when navigate on the Private App View
or using the cog at the top of the page.
Configure the Keycloak module to force logged in users to be an Otoroshi admin with full access
Go back to the Keycloak module in Authentication configs
view. Turn on the Supers admin only
button and save your configuration. Try again the connection to Otoroshi using Keycloak third-party server.
Once connected, click on the cog button, and check that you have access to the full features of Otoroshi (like Admin user sessions). Now, your rights should be :
[
{
"tenant": "*:rw",
"teams": [
"*:rw"
]
}
]
Merge Id token content on user profile
Go back to the Keycloak module in Authentication configs
view. Turn on the Read profile
from token button and save your configuration. Try again the connection to Otoroshi using Keycloak third-party server.
Once connected, your profile should be contains all Keycloak id token :
{
"exp": 1634286674,
"iat": 1634286614,
"auth_time": 1634286614,
"jti": "eb368578-e886-4caa-a51b-c1d04973c80e",
"iss": "http://localhost:8080/auth/realms/master",
"aud": [
"master-realm",
"account"
],
"sub": "4c8cd101-ca28-4611-80b9-efa504ac51fd",
"typ": "Bearer",
"azp": "keycloak-otoroshi-backoffice",
"session_state": "e44fe471-aa3b-477d-b792-4f7b4caea220",
"acr": "1",
"allowed-origins": [
"http://otoroshi.oto.tools:8080"
],
"realm_access": {
"roles": [
"create-realm",
"default-roles-master",
"offline_access",
"admin",
"uma_authorization"
]
},
"resource_access": {
"master-realm": {
"roles": [
"view-identity-providers",
"view-realm",
"manage-identity-providers",
"impersonation",
"create-client",
"manage-users",
"query-realms",
"view-authorization",
"query-clients",
"query-users",
"manage-events",
"manage-realm",
"view-events",
"view-users",
"view-clients",
"manage-authorization",
"manage-clients",
"query-groups"
]
},
"account": {
"roles": [
"manage-account",
"manage-account-links",
"view-profile"
]
}
}
...
}
Manage the Otoroshi user rights from keycloak
One powerful feature supports by Otoroshi, is to use the Keycloak groups attributes to set a list of rights for a Otoroshi user.
In the Keycloak module, you have a field, named Otoroshi rights field name
with otoroshi_rights
as default value. This field is used by Otoroshi to retrieve information from the Id token groups.
Let’s create a group in Keycloak, and set our default Admin user inside. In Keycloak admin console :
- Navigate to the groups view, using the keycloak sidebar
- Create a new group with
my-group
asName
-
Then, on the
Attributes
tab, create an attribute withotoroshi_rights
asKey
and the following json array asValue
[ { "tenant": "*:rw", "teams": [ "*:rw", "my-future-team:rw" ] } ]
With this configuration, the user have a full access on all Otoroshi resources (my-future-team is not created in Otoroshi but it’s not a problem, Otoroshi can handle it and use this rights only when the team will be present)
Click on the Add button and save the group. The last step is to assign our user to this group. Jump to Users
view using the sidebar, click on View all users, edit the user and his group membership using the Groups
tab (use join button the assign user in my-group
).
The next step is to add a mapper in the Keycloak client. By default, Keycloak doesn’t expose any users information (like group membership or users attribute). We need to ask to Keycloak to expose the user attribute otoroshi_rights
set previously on group.
Navigate to the Keycloak-otoroshi-backoffice
client, and jump to Mappers
tab. Create a new mapper with the following values:
- Name:
otoroshi_rights
- Mapper Type:
User Attribute
- User Attribute:
otoroshi_rights
- Token Claim Name:
otoroshi_rights
- Claim JSON Type:
JSON
- Multivalued:
√
- Aggregate attribute values:
√
Go back to the Authentication Keycloak module inside Otoroshi UI, and turn off Super admins only. Save the configuration.
Once done, try again the connection to Otoroshi using Keycloak third-party server. Now, your rights should be :
[
{
"tenant": "*:rw",
"teams": [
"*:rw",
"my-future-team:rw"
]
}
]
Secure an app with Keycloak authentication
The only change to apply on the previous authentication module is on the callback URL. When you want secure a Otoroshi service, and transform it on Private App
, you need to set the Callback URL
at http://privateapps.oto.tools:8080/privateapps/generic/callback
. This configuration will redirect users to the backend service after they have successfully logged in.
- Go back to the authentication module
- Jump to the
Callback URL
field - Paste this value
http://privateapps.oto.tools:8080/privateapps/generic/callback
- Save your configuration
- Navigate to
http://myservice.oto.tools:8080
. - You should redirect to the keycloak login page.
- Once logged in, you can check the content of the private app session created.
The rights should be :
[
{
"tenant": "*:rw",
"teams": [
"*:rw",
"my-future-team:rw"
]
}
]