--- - name: Generate keycloak auth token uri: url: "{{ keycloak_url }}/auth/realms/master/protocol/openid-connect/token" method: POST body: "client_id={{ keycloak_auth_client }}&username={{ keycloak_admin_user }}&password={{ keycloak_admin_password }}&grant_type=password" validate_certs: no register: keycloak_auth_response until: keycloak_auth_response.status == 200 retries: 5 delay: 2 - name: "Determine if realm exists" uri: url: "{{ keycloak_url }}/auth/admin/realms/{{ keycloak_realm }}" method: GET status_code: - 200 - 404 headers: Accept: "application/json" Authorization: "Bearer {{ keycloak_auth_response.json.access_token }}" register: keycloak_realm_exists - name: Create Realm uri: url: "{{ keycloak_url }}/auth/admin/realms" method: POST body: "{{ lookup('template','realm.json.j2') }}" validate_certs: no body_format: json headers: Authorization: "Bearer {{ keycloak_auth_response.json.access_token }}" status_code: 201 when: keycloak_realm_exists.status == 404 - name: Create user federation community.general.keycloak_user_federation: auth_keycloak_url: "{{ keycloak_url }}/auth" auth_realm: "{{ keycloak_auth_realm }}" auth_username: "{{ keycloak_admin_user }}" auth_password: "{{ keycloak_admin_password }}" realm: "{{ item.realm }}" name: "{{ item.name }}" state: present provider_id: "{{ item.provider_id }}" provider_type: "{{ item.provider_type | default(org.keycloak.storage.UserStorageProvider) }}" config: "{{ item.config }}" mappers: "{{ item.mappers | default(omit) }}" register: create_user_federation_result loop: "{{ keycloak_user_federation | flatten }}" when: keycloak_user_federation is defined - name: Create Client community.general.keycloak_client: auth_client_id: "{{ keycloak_auth_client }}" auth_keycloak_url: "{{ keycloak_url }}/auth" auth_realm: "{{ keycloak_auth_realm }}" auth_username: "{{ keycloak_admin_user }}" auth_password: "{{ keycloak_admin_password }}" client_id: "{{ item.name }}" realm: "{{ item.realm }}" default_roles: "{{ item.roles | default(omit) }}" root_url: "{{ item.root_url | default('') }}" redirect_uris: "{{ demo_app_redirect_uris | default([]) }}" public_client: "{{ item.public_client | default(False) }}" web_origins: "{{ item.web_origins | default('+') }}" state: present register: create_client_result loop: "{{ keycloak_clients | flatten }}" when: item.name|length > 0 - name: Create client roles include_tasks: manage_client_roles.yml when: keycloak_rhsso_enable loop: "{{ keycloak_clients | flatten }}" loop_control: loop_var: client - name: Create client users include_tasks: manage_client_users.yml loop: "{{ keycloak_clients | flatten }}" loop_control: loop_var: client