--- - name: Validate admin console password ansible.builtin.assert: that: - keycloak_quarkus_admin_pass | length > 12 quiet: true fail_msg: "The console administrator password is empty or invalid. Please set the keycloak_quarkus_admin_pass variable to a 12+ char long string" success_msg: "{{ 'Console administrator password OK' }}" - name: Validate relative path ansible.builtin.assert: that: - keycloak_quarkus_http_relative_path is regex('^/.*') quiet: true fail_msg: "the relative path must begin with /" success_msg: "{{ 'relative path OK' }}" - name: Validate configuration ansible.builtin.assert: that: - (keycloak_quarkus_ha_enabled and keycloak_quarkus_db_enabled) or (not keycloak_quarkus_ha_enabled and keycloak_quarkus_db_enabled) or (not keycloak_quarkus_ha_enabled and not keycloak_quarkus_db_enabled) quiet: true fail_msg: "Cannot install HA setup without a backend database service. Check keycloak_quarkus_ha_enabled and keycloak_quarkus_db_enabled" success_msg: "{{ 'Configuring HA' if keycloak_quarkus_ha_enabled else 'Configuring standalone' }}" - name: Validate OS family ansible.builtin.assert: that: - ansible_os_family in ["RedHat", "Debian"] quiet: true fail_msg: "Can only install on RedHat or Debian OS families; found {{ ansible_os_family }}" success_msg: "Installing on {{ ansible_os_family }}" - name: Load OS specific variables ansible.builtin.include_vars: "vars/{{ ansible_os_family | lower }}.yml" tags: - always - name: Ensure required packages are installed ansible.builtin.include_tasks: fastpackages.yml vars: packages_list: "{{ keycloak_quarkus_prereq_package_list }}"