This is the vanilla theme for rciam installations.
🔴 IMPORTANT: Please note that this theme needs a custom modification on core keycloak code in order to work. The theme releases are compatible with these keycloak releases, as presented in the compatibility matrix at the end of this page
The theme also requires one of the following env variables: { JBOSS_HOME | QUARKUS_HOME | HOME } to store its configuration files - even in development mode. This is the folder that theme files are stored. Folder can be empty for default configuration.
Contact the development team for instructions.
Create the following folders: $KEYCLOAK_BASE/modules/system/layers/keycloak/org/keycloak/keycloak-theme-vanilla $KEYCLOAK_BASE/modules/system/layers/keycloak/org/keycloak/keycloak-theme-vanilla/main
and add into the folder "main"
- the built jar keycloak-theme-vanilla/target/keycloak-theme-vanilla.jar
- the keycloak-theme-vanilla/module.xml from the source (this one) base folder
so you should end up with the following structure in $KEYCLOAK_BASE/modules/system/layers/keycloak/org/keycloak/keycloak-theme-vanilla
keycloak-theme-vanilla
└── main
├── keycloak-theme-vanilla.jar
└── module.xml
Following the above, we should also let wildfly server and keycloak to load this module as well. So, open file $KEYCLOAK_BASE/standalone/configuration/standalone.xml
Find the <subsystem xmlns="urn:jboss:domain:keycloak-server:1.1">
node.
- Add the
<provider>module:org.keycloak.keycloak-theme-vanilla</provider>
into the<providers>
list - Add the
into the
<modules> <module>org.keycloak.keycloak-theme-vanilla</module> </modules>
<theme>
block
Download the keycloak-theme-vanilla.jar from the releases page.
Just drop the jar file into the $KEYCLOAK_BASE/standalone/deployments/ folder. Wait for wildfly to auto-deploy the jar file.
For Keycloak X (after version 18.0.0), just drop the jar file into the $KEYCLOAK_BASE/providers/ folder.
Since v.2.0.0, the theme has two different ways to edit its configuration per realm.
An admin could edit the generated files under the $KEYCLOAK_BASE/standalone/theme-config folder.
For each realm it maintains two files:
- a terms-of-use/<REALM_NAME>.html file which contains the html file with the realm-specific terms of use
- a configurations/<REALM_NAME>.json file which contains the json file with the realm-specific theme configuration
Alternatively, an admin could use the following endpoints:
- https://<HOST_NAME>/auth/realms/<REALM_NAME>/theme-info/terms-of-use (HTTP-GET or HTTP-POST to fetch or set/update the theme's terms of use for the realm)
- https://<HOST_NAME>/auth/realms/<REALM_NAME>/theme-info/theme-config (HTTP-GET or HTTP-POST to fetch or set/update the theme's config for the realm)
Both endpoints require for the HTTP-POST a valid admin token (Authorization: "Bearer <VALID_ADMIN_TOKEN>"), or the call will be rejected with a http 401 code.
The expected body payload for the POST requests should be similar to the termsofuse.html file (that's the theme's default terms of use file) and the configuration.json file (that's the default template configuration).
Since v.4.0.0, the theme has the ability to serve static files (any filetype), just like a fileserver.
The theme also uses a cache to speed up file serving for the most commonly requested files, with size smaller than 1ΜΒ. Larger than 1MB files are always fetched from the filesystem.
There are 2 ways to define the files to serve (a) by uploading them as a multipart/form-data on each keycloak node, or (b) by adding them into a folder under the $KEYCLOAK_BASE/standalone/theme-config/resources/<REALM_NAME>/
To set/register a file into the embedded file repo, you need to send a POST request at the endpoint
https://<HOST_NAME>/auth/realms/<REALM_NAME>/theme-info/resource/<FILE_NAME>
with a single form key (with any key name, since key name is ignored) containing the file.
NOTE: This must be issued on each node of keycloak. So, this will not work if you are sending this at a reverse proxy / load balancer serving more than 1 nodes.
To get the registered file, you can achive that by sending a HTTP GET request at the same endpoint
https://<HOST_NAME>/auth/realms/<REALM_NAME>/theme-info/resource/<FILE_NAME>
If you have access to the running keycloak node instance, you can add a file at runtime under the folder
$KEYCLOAK_BASE/standalone/theme-config/resources/<REALM_NAME>/
and the keycloak theme will pick up any file instantly (it utilizes file listerners).
This theme is compatible with the custom releases of keycloak which can be found here
Theme version | Keycloak version |
---|---|
v1.0.0 | 15.0.2-r1.0.(1-4) |
v1.1.0 | 15.0.2-r1.0.(1-4) |
v1.2.0 | 15.0.2-r1.0.5 + |
v2.0.0 | 15.0.2-r1.0.6 + |
v2.1.0 | 15.0.2-r1.0.6 + |
v2.2.0 | 15.0.2-r1.0.6 + |
v2.3.0 | 16.1.0-rc1.0.1 + |
v3.0.0 | 16.1.0-rc1.0.1 + |
v3.0.1 | 16.1.0-rc1.0.1 + |
v4.0.0 | 16.1.0-1.0.1 + |
v4.0.3 | 16.1.0-1.0.1 + |
v4.1.0 | 18.0.0-1.0.1 + |
v4.1.1 | 18.0.0-1.0.1 + |
v4.1.2 | 18.0.1-2.1 + |
v5.0.0 | 22.0.5-1.0 + |
v5.3.0 | 22.0.5-1.11 + |
v5.5.0 | 22.0.5-1.12 + |
If you are using keycloak 16.1.0-X.X.X versions, you should definitely use the theme version 4.0.3 which includes a critical fix. Version 5.0.0 and upper is based in Keycloak version 22.0.5 . This means use JDK 17 and Jakarta version.
- Apache License, Version 2.0 - see LICENCE file