keycloak-scim/server_development/topics/themes.adoc

454 lines
15 KiB
Text
Raw Normal View History

[[_themes]]
== Themes
2016-04-18 21:02:18 +00:00
2017-08-28 12:50:14 +00:00
{project_name} provides theme support for web pages and emails. This allows customizing the look and feel of end-user facing pages so they can be
integrated with your applications.
2017-08-28 12:50:14 +00:00
image::images/login-sunrise.png[caption="",title="Login page with sunrise example theme"]
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
=== Theme types
2016-04-18 21:02:18 +00:00
2017-08-28 12:50:14 +00:00
A theme can provide one or more types to customize different aspects of {project_name}. The types available are:
2016-04-18 21:02:18 +00:00
* Account - Account management
2021-06-23 18:10:41 +00:00
* Admin - Admin Console
2016-04-18 21:02:18 +00:00
* Email - Emails
* Login - Login forms
* Welcome - Welcome page
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
=== Configuring a theme
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
All theme types, except welcome, are configured through the Admin Console.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
.Procedure
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Log into the Admin Console.
. Select your realm from the drop-down box in the top left corner.
. Click *Realm Settings* from the menu.
. Click the *Themes* tab.
+
NOTE: To set the theme for the `master` Admin Console you need to set the Admin Console theme for the `master` realm.
+
. To see the changes to the Admin Console refresh the page.
2016-04-18 21:02:18 +00:00
ifeval::["{kc_dist}" == "quarkus"]
. Change the welcome theme by using the `spi-theme-welcome-theme` option.
. For example:
+
[source,bash]
----
bin/kc.[sh|bat] start --spi-theme-welcome-theme=custom-theme
----
endif::[]
ifeval::["{kc_dist}" == "wildfly"]
2021-06-23 18:10:41 +00:00
. Change the welcome theme by editing `standalone.xml`, `standalone-ha.xml`, or `domain.xml`.
2021-06-23 18:10:41 +00:00
. Add `welcomeTheme` to the theme element, for example:
+
[source,xml]
2016-04-18 21:02:18 +00:00
----
<theme>
2016-04-18 21:02:18 +00:00
...
<welcomeTheme>custom-theme</welcomeTheme>
...
</theme>
----
2021-06-23 18:10:41 +00:00
. Restart the server for the changes to the welcome theme to take effect.
endif::[]
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
=== Default themes
2016-04-18 21:02:18 +00:00
2017-08-28 12:50:14 +00:00
{project_name} comes bundled with default themes in the server's root `themes` directory. To simplify upgrading you should not edit the bundled themes
2019-01-15 13:24:22 +00:00
directly. Instead create your own theme that extends one of the bundled themes.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
=== Creating a theme
2016-04-18 21:02:18 +00:00
2016-12-02 19:52:58 +00:00
A theme consists of:
2016-04-18 21:02:18 +00:00
2017-11-13 08:56:19 +00:00
* HTML templates (https://freemarker.apache.org/[Freemarker Templates])
2016-04-18 21:02:18 +00:00
* Images
* Message bundles
* Stylesheets
* Scripts
* Theme properties
2016-04-18 21:02:18 +00:00
2017-08-28 12:50:14 +00:00
Unless you plan to replace every single page you should extend another theme. Most likely you will want to extend the {project_name} theme, but you could also
consider extending the base theme if you are significantly changing the look and feel of the pages. The base theme primarily consists of HTML templates and
2017-08-28 12:50:14 +00:00
message bundles, while the {project_name} theme primarily contains images and stylesheets.
2016-04-18 21:02:18 +00:00
When extending a theme you can override individual resources (templates, stylesheets, etc.). If you decide to override HTML templates bear in mind that you may
need to update your custom template when upgrading to a new release.
2016-04-18 21:02:18 +00:00
While creating a theme it's a good idea to disable caching as this makes it possible to edit theme resources directly from the `themes` directory without
2021-06-23 18:10:41 +00:00
restarting {project_name}.
.Procedure
ifeval::["{kc_dist}" == "quarkus"]
. Run Keycloak with the following options:
+
[source,bash]
----
bin/kc.[sh|bat] start --spi-theme-static-max-age=-1 --spi-theme-cache-themes=false --spi-theme-cache-templates=false
----
endif::[]
ifeval::["{kc_dist}" == "wildfly"]
2021-06-23 18:10:41 +00:00
. Edit `standalone.xml`.
2021-06-23 18:10:41 +00:00
. For `theme` set `staticMaxAge` to `-1` and both
`cacheTemplates` and `cacheThemes` to `false`:
+
[source,xml]
2016-04-18 21:02:18 +00:00
----
<theme>
<staticMaxAge>-1</staticMaxAge>
<cacheThemes>false</cacheThemes>
<cacheTemplates>false</cacheTemplates>
...
</theme>
----
endif::[]
2021-06-23 18:10:41 +00:00
. Create a directory in the `themes` directory.
+
The name of the directory becomes the name of the theme. For example to
create a theme called `mytheme` create the directory `themes/mytheme`.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Inside the theme directory, create a directory for each of the types your theme is going to provide.
+
For example, to add the login type to the `mytheme` theme, create the directory `themes/mytheme/login`.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. For each type create a file `theme.properties` which allows setting some configuration for the theme.
+
For example, to configure the theme `themes/mytheme/login` to extend the base theme and import some common resources, create the file `themes/mytheme/login/theme.properties` with following contents:
+
2016-04-18 21:02:18 +00:00
[source]
----
parent=base
import=common/keycloak
----
2021-06-23 18:10:41 +00:00
+
You have now created a theme with support for the login type.
2021-06-23 18:10:41 +00:00
. Log into the Admin Console to checkout your new theme
. Select your realm
. Click *Realm Settings* from the menu.
. Click on the *Themes* tab.
. For *Login Theme* select *mytheme* and click *Save*.
. Open the login page for the realm.
+
You can do this either by logging in through your application or by opening the Account Management console (`/realms/{realm name}/account`).
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. To see the effect of changing the parent theme, set `parent=keycloak` in `theme.properties` and refresh the login page.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
[NOTE]
====
Be sure to re-enable caching in production as it will significantly impact performance.
====
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
==== Theme properties
2016-04-18 21:02:18 +00:00
Theme properties are set in the file `<THEME TYPE>/theme.properties` in the theme directory.
2016-04-18 21:02:18 +00:00
* parent - Parent theme to extend
* import - Import resources from another theme
* styles - Space-separated list of styles to include
* locales - Comma-separated list of supported locales
2016-04-18 21:02:18 +00:00
There are a list of properties that can be used to change the css class used for certain element types. For a list of these properties look at the theme.properties
file in the corresponding type of the keycloak theme (`themes/keycloak/<THEME TYPE>/theme.properties`).
2016-04-18 21:02:18 +00:00
You can also add your own custom properties and use them from custom templates.
When doing so, you can substitute system properties or environment variables by using these formats:
* `${some.system.property}` - for system properties
* `${env.ENV_VAR}` - for environment variables.
A default value can also be provided in case the system property or the environment variable is not found with `${foo:defaultValue}`.
NOTE: If no default value is provided and there's no corresponding system property or environment variable, then nothing is replaced and you end up with the format in your template.
Here's an example of what is possible:
[source,properties]
----
javaVersion=${java.version}
unixHome=${env.HOME:Unix home not found}
windowsHome=${env.HOMEPATH:Windows home not found}
----
2021-06-23 18:10:41 +00:00
==== Add a stylesheet to a theme
You can add one or more stylesheets to a theme.
2021-06-23 18:10:41 +00:00
.Procedure
2021-06-23 18:10:41 +00:00
. Create a file in the `<THEME TYPE>/resources/css` directory of your theme.
2021-06-23 18:10:41 +00:00
. Add this file to the `styles` property in `theme.properties`.
+
For example, to add `styles.css` to the `mytheme`, create `themes/mytheme/login/resources/css/styles.css` with the following content:
+
[source,css]
2016-04-18 21:02:18 +00:00
----
.login-pf body {
background: DimGrey none;
}
2016-04-18 21:02:18 +00:00
----
2021-06-23 18:10:41 +00:00
. Edit `themes/mytheme/login/theme.properties` and add:
+
2016-04-18 21:02:18 +00:00
[source]
----
styles=css/styles.css
2016-04-18 21:02:18 +00:00
----
2021-06-23 18:10:41 +00:00
. To see the changes, open the login page for your realm.
+
You will notice that the only styles being applied are those from your custom stylesheet.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. To include the styles from the parent theme, load the styles from that theme. Edit `themes/mytheme/login/theme.properties` and change `styles` to:
+
2016-04-18 21:02:18 +00:00
[source]
----
styles=web_modules/@fontawesome/fontawesome-free/css/icons/all.css web_modules/@patternfly/react-core/dist/styles/base.css web_modules/@patternfly/react-core/dist/styles/app.css node_modules/patternfly/dist/css/patternfly.min.css node_modules/patternfly/dist/css/patternfly-additions.min.css css/login.css css/styles.css
2016-04-18 21:02:18 +00:00
----
2021-06-23 18:10:41 +00:00
+
NOTE: To override styles from the parent stylesheets, ensure that your stylesheet is listed last.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
==== Adding a script to a theme
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
You can add one or more scripts to a theme.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
.Procedure
2021-06-23 18:10:41 +00:00
. Create a file in the `<THEME TYPE>/resources/js` directory of your theme.
2021-06-23 18:10:41 +00:00
. Add the file to the `scripts` property in `theme.properties`.
+
For example, to add `script.js` to the `mytheme`, create `themes/mytheme/login/resources/js/script.js` with the following content:
+
[source,javascript]
2016-04-18 21:02:18 +00:00
----
alert('Hello');
2016-04-18 21:02:18 +00:00
----
2021-06-23 18:10:41 +00:00
+
Then edit `themes/mytheme/login/theme.properties` and add:
+
2016-04-18 21:02:18 +00:00
[source]
----
scripts=js/script.js
2016-04-18 21:02:18 +00:00
----
2021-06-23 18:10:41 +00:00
==== Adding an image to a theme
2016-04-18 21:02:18 +00:00
To make images available to the theme add them to the `<THEME TYPE>/resources/img` directory of your theme. These can be used from within stylesheets or
directly in HTML templates.
2016-04-18 21:02:18 +00:00
For example to add an image to the `mytheme` copy an image to `themes/mytheme/login/resources/img/image.jpg`.
You can then use this image from within a custom stylesheet with:
[source,css]
2016-04-18 21:02:18 +00:00
----
body {
background-image: url('../img/image.jpg');
background-size: cover;
2016-04-18 21:02:18 +00:00
}
----
Or to use directly in HTML templates add the following to a custom HTML template:
2016-04-18 21:02:18 +00:00
[source,html]
2016-04-18 21:02:18 +00:00
----
<img src="${url.resourcesPath}/img/image.jpg">
----
==== Messages
2019-01-15 13:24:22 +00:00
Text in the templates is loaded from message bundles. A theme that extends another theme will inherit all messages from the parent's message bundle and you can
override individual messages by adding `<THEME TYPE>/messages/messages_en.properties` to your theme.
2016-04-18 21:02:18 +00:00
For example to replace `Username` on the login form with `Your Username` for the `mytheme` create the file
`themes/mytheme/login/messages/messages_en.properties` with the following content:
2016-04-18 21:02:18 +00:00
[source]
----
usernameOrEmail=Your Username
2016-04-18 21:02:18 +00:00
----
2016-12-02 19:52:58 +00:00
Within a message values like `{0}` and `{1}` are replaced with arguments when the message is used. For example {0} in `Log in to {0}` is replaced with the name
of the realm.
Texts of these message bundles can be overwritten by realm-specific values. The realm-specific values are manageable via UI and API.
2021-06-23 18:10:41 +00:00
==== Adding a language to a realm
.Prerequisites
2016-04-18 21:02:18 +00:00
* To enable internationalization for a realm, see the {adminguide_link}[{adminguide_name}].
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
.Procedure
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Create the file `<THEME TYPE>/messages/messages_<LOCALE>.properties` in the directory of your theme.
. Add this file to the `locales` property in `<THEME TYPE>/theme.properties`.
For a language to be available to users the realms `login`, `account` and `email`, the theme has to support the language, so you need to add your language for those theme types.
+
2016-12-08 20:41:51 +00:00
For example, to add Norwegian translations to the `mytheme` theme create the file `themes/mytheme/login/messages/messages_no.properties` with the
following content:
2021-06-23 18:10:41 +00:00
+
[source]
----
usernameOrEmail=Brukernavn
password=Passord
----
2021-06-23 18:10:41 +00:00
+
If you omit a translation for messages, they will use English.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Edit `themes/mytheme/login/theme.properties` and add:
+
2016-04-18 21:02:18 +00:00
[source]
----
locales=en,no
----
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Add the same for the `account` and `email` theme types. To do this create `themes/mytheme/account/messages/messages_no.properties` and
`themes/mytheme/email/messages/messages_no.properties`. Leaving these files empty will result in the English messages being used.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Copy `themes/mytheme/login/theme.properties` to `themes/mytheme/account/theme.properties` and `themes/mytheme/email/theme.properties`.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
. Add a translation for the language selector. This is done by adding a message to the English translation. To do this add the following to
`themes/mytheme/account/messages/messages_en.properties` and `themes/mytheme/login/messages/messages_en.properties`:
+
2016-04-18 21:02:18 +00:00
[source]
----
locale_no=Norsk
----
2021-06-23 18:10:41 +00:00
+
2016-07-12 08:34:21 +00:00
By default message properties files should be encoded using ISO-8859-1. It's also possible to specify the encoding using a special header. For example to use UTF-8 encoding:
2021-06-23 18:10:41 +00:00
+
2016-07-12 08:34:21 +00:00
[source]
----
2016-08-19 06:50:01 +00:00
# encoding: UTF-8
2016-07-12 08:34:21 +00:00
usernameOrEmail=....
----
2021-06-23 18:10:41 +00:00
[role="_additional-resources"]
.Additional resources
* See <<_locale_selector,Locale Selector>> for details on how the current locale is selected.
2021-06-23 18:10:41 +00:00
[[custom-identity-providers-icons]]
==== Adding custom Identity Providers icons
{project_name} supports adding icons for custom Identity providers, which are displayed on the login screen.
2021-06-23 18:10:41 +00:00
.Procedure
. Define icon classes in your login `theme.properties` file (for example, `themes/mytheme/login/theme.properties`) with key pattern `kcLogoIdP-<alias>`.
. For an Identity Provider with an alias `myProvider`, you may add a line to `theme.properties` file of your custom theme. For example:
+
[source]
----
kcLogoIdP-myProvider = fa fa-lock
----
All icons are available on the official website of PatternFly4.
Icons for social providers are already defined in base login theme properties (`themes/keycloak/login/theme.properties`), where you can inspire yourself.
2021-06-23 18:10:41 +00:00
==== Creating a custom HTML template
{project_name} uses https://freemarker.apache.org/[Apache Freemarker] templates to generate HTML. You can override individual templates in your own theme by
creating `<THEME TYPE>/<TEMPLATE>.ftl`. For a list of templates used see `themes/base/<THEME TYPE>`.
2021-06-23 18:10:41 +00:00
.Procedure
2021-06-23 18:10:41 +00:00
. Copy the template from the base theme to your own theme.
2021-06-23 18:10:41 +00:00
. Apply the modifications you need.
+
For example, to create a custom login form for the `mytheme` theme, copy `themes/base/login/login.ftl` to `themes/mytheme/login` and open it in an editor.
+
After the first line (<#import ...>), add `<h1>HELLO WORLD!</h1>` as shown here:
2021-06-23 18:10:41 +00:00
+
[source,html]
2016-04-18 21:02:18 +00:00
----
<#import "template.ftl" as layout>
<h1>HELLO WORLD!</h1>
...
2016-04-18 21:02:18 +00:00
----
2021-06-23 18:10:41 +00:00
. Back up the modified template. When upgrading to a new version of {project_name} you may need to update your custom templates to apply changes to the original template if applicable.
[role="_additional-resources"]
.Additional resources
* See the https://freemarker.apache.org/docs/index.html[FreeMarker Manual] for details on how to edit templates.
==== Emails
2019-01-15 13:24:22 +00:00
To edit the subject and contents for emails, for example password recovery email, add a message bundle to the `email` type of your theme. There are three messages for each email. One for the subject, one for the plain text body and one for the html body.
To see all emails available take a look at `themes/base/email/messages/messages_en.properties`.
For example to change the password recovery email for the `mytheme` theme create `themes/mytheme/email/messages/messages_en.properties` with the following
content:
2016-04-18 21:02:18 +00:00
[source]
----
passwordResetSubject=My password recovery
passwordResetBody=Reset password link: {0}
passwordResetBodyHtml=<a href="{0}">Reset password</a>
----
2016-04-18 21:02:18 +00:00
=== Deploying themes
2016-04-18 21:02:18 +00:00
2019-01-15 13:24:22 +00:00
Themes can be deployed to {project_name} by copying the theme directory to `themes` or it can be deployed as an archive. During development you can copy the
theme to the `themes` directory, but in production you may want to consider using an `archive`. An `archive` makes it simpler to have a versioned copy of
2017-08-28 12:50:14 +00:00
the theme, especially when you have multiple instances of {project_name} for example with clustering.
2016-04-18 21:02:18 +00:00
2021-06-23 18:10:41 +00:00
.Procedure
2016-04-18 21:02:18 +00:00
. To deploy a theme as an archive, create a JAR archive with the theme resources.
2021-06-23 18:10:41 +00:00
. Add a file `META-INF/keycloak-themes.json` to the
archive that lists the available themes in the archive as well as what types each theme provides.
+
For example for the `mytheme` theme create `mytheme.jar` with the contents:
2021-06-23 18:10:41 +00:00
+
* META-INF/keycloak-themes.json
2022-01-31 08:34:29 +00:00
* theme/mytheme/login/theme.properties
* theme/mytheme/login/login.ftl
* theme/mytheme/login/resources/css/styles.css
* theme/mytheme/login/resources/img/image.png
* theme/mytheme/login/messages/messages_en.properties
* theme/mytheme/email/messages/messages_en.properties
+
The contents of `META-INF/keycloak-themes.json` in this case would be:
2021-06-23 18:10:41 +00:00
+
2018-02-08 21:09:26 +00:00
[source,json]
2016-04-18 21:02:18 +00:00
----
{
"themes": [{
"name" : "mytheme",
"types": [ "login", "email" ]
}]
2016-04-18 21:02:18 +00:00
}
----
2021-06-23 18:10:41 +00:00
+
A single archive can contain multiple themes and each theme can support one or more types.
2016-04-18 21:02:18 +00:00
ifeval::["{kc_dist}" == "quarkus"]
To deploy the archive to {project_name}, add it to the `providers/` directory of
{project_name} and restart the server if it is already running.
endif::[]
ifeval::["{kc_dist}" == "wildfly"]
To deploy the archive to {project_name}, add it to the `standalone/deployments/` directory of
{project_name} and it will be automatically loaded.
endif::[]