keycloak_realm
Create realms and clients in keycloak or Red Hat Single Sign-On services.
Role Defaults
Variable |
Description |
Default |
---|---|---|
|
Administration console user account |
|
|
hostname |
|
|
Context path for rest calls |
|
|
HTTP port |
|
|
TLS HTTP port |
|
|
Name of the main authentication realm |
|
|
Management port |
|
|
Authentication client for configuration REST calls |
|
|
Configure a public realm client |
|
|
Web origins for realm client |
|
|
URL for configuration rest calls |
|
|
URL for management console rest calls |
|
Role Variables
The following are a set of required variables for the role:
Variable |
Description |
---|---|
|
Name of the realm to be created |
|
Password for the administration console user account |
The following variables are available for creating clients:
Variable |
Description |
Default |
---|---|---|
|
List of client declarations for the realm |
|
|
List of default role name for clients |
|
|
List of user/role mappings for a client |
|
The following variable are available for creating user federation:
Variable |
Description |
Default |
---|---|---|
|
List of keycloak_user_federation for the realm |
|
Variable formats
keycloak_user_federation
, a list of:
- realm: <name of the realm in which user federation should be configured, required>
name: <name of the user federation provider, required>
provider_id: <type of the user federation provider, required>
provider_type: <Provider Type, default is set to org.keycloak.storage.UserStorageProvider>
config: <dictionary of supported configuration values, required>
mappers: <list of supported configuration values, required>
Refer to docs for information on supported variables.
keycloak_clients
, a list of:
- name: <name of the client>
id: <id of the client>
client_id: <id of the client>
roles: <keycloak_client_default_roles>
realm: <name of the realm that contains the client>
public_client: <true for public, false for confidential>
web_origins: <list of allowed we origins for the client>
users: <keycloak_client_users>
name
and either id
or client_id
are required.
keycloak_client_users
, a list of:
- username: <username, required>
password: <password, required>
firstName: <firstName, optional>
lastName: <lastName, optional>
email: <email, optional>
client_roles: <list of client user/role mappings>
Client user/role mappings, a list of:
- client: <name of the client>
role: <name of the role>
realm: <name of the realm>
For a comprehensive example, refer to the playbook.
Example Playbook
The following is an example playbook that makes use of the role to create a realm in keycloak.
---
- hosts: ...
collections:
- middleware_automation.keycloak
tasks:
- name: Include keycloak role
include_role:
name: keycloak_realm
vars:
keycloak_admin_password: "changeme"
keycloak_realm: TestRealm
keycloak_clients: [...]
License
Apache License 2.0