--- - name: Check for specified PostgreSQL configuration k8s_info: kind: Secret namespace: '{{ meta.namespace }}' name: '{{ postgres_configuration_secret }}' register: _custom_pg_config_resources when: postgres_configuration_secret | length - name: Check for default PostgreSQL configuration k8s_info: kind: Secret namespace: '{{ meta.namespace }}' name: '{{ meta.name }}-postgres-configuration' register: _default_pg_config_resources - name: Check for specified old PostgreSQL configuration secret k8s_info: kind: Secret namespace: '{{ meta.namespace }}' name: '{{ old_postgres_configuration_secret }}' register: _custom_old_pg_config_resources when: old_postgres_configuration_secret | length - name: Check for default old PostgreSQL configuration k8s_info: kind: Secret namespace: '{{ meta.namespace }}' name: '{{ meta.name }}-old-postgres-configuration' register: _default_old_pg_config_resources - name: Set old PostgreSQL configuration set_fact: # yamllint disable-line rule:line-length old_pg_config: '{{ _custom_old_pg_config_resources["resources"] | default([]) | length | ternary(_custom_old_pg_config_resources, _default_old_pg_config_resources) }}' # noqa 204 - name: Set proper database name when migrating from old deployment set_fact: database_name: "{{ old_pg_config['resources'][0]['data']['database'] | b64decode }}" database_username: "{{ old_pg_config['resources'][0]['data']['username'] | b64decode }}" when: - old_pg_config['resources'] is defined - old_pg_config['resources'] | length - name: Set PostgreSQL configuration set_fact: _pg_config: '{{ _custom_pg_config_resources["resources"] | default([]) | length | ternary(_custom_pg_config_resources, _default_pg_config_resources) }}' - block: - name: Create Database configuration k8s: apply: true definition: "{{ lookup('template', 'postgres_secret.yaml.j2') }}" - name: Read Database Configuration k8s_info: kind: Secret namespace: '{{ meta.namespace }}' name: '{{ meta.name }}-postgres-configuration' register: _generated_pg_config_resources when: not _pg_config['resources'] | default([]) | length - name: Set PostgreSQL Configuration set_fact: pg_config: '{{ _generated_pg_config_resources["resources"] | default([]) | length | ternary(_generated_pg_config_resources, _pg_config) }}' - name: Set actual postgres configuration secret used set_fact: __postgres_configuration_secret: "{{ pg_config['resources'][0]['metadata']['name'] }}" - block: - name: Create Database if no database is specified k8s: apply: true definition: "{{ lookup('template', 'postgres.yaml.j2') }}" register: create_statefulset_result rescue: - name: Scale down Deployment for migration include_tasks: scale_down_deployment.yml - name: Scale down PostgreSQL statefulset for migration community.kubernetes.k8s_scale: api_version: apps/v1 kind: StatefulSet name: "{{ meta.name }}-postgres" namespace: "{{ meta.namespace }}" replicas: 0 wait: yes - name: Remove PostgreSQL statefulset for upgrade k8s: state: absent api_version: apps/v1 kind: StatefulSet name: "{{ meta.name }}-postgres" namespace: "{{ meta.namespace }}" wait: yes when: create_statefulset_result.error == 422 - name: Recreate PostgreSQL statefulset with updated values k8s: apply: true definition: "{{ lookup('template', 'postgres.yaml.j2') }}" when: pg_config['resources'][0]['data']['type'] | default('') | b64decode == 'managed' - name: Store Database Configuration set_fact: awx_postgres_user: "{{ pg_config['resources'][0]['data']['username'] | b64decode }}" awx_postgres_pass: "{{ pg_config['resources'][0]['data']['password'] | b64decode }}" awx_postgres_database: "{{ pg_config['resources'][0]['data']['database'] | b64decode }}" awx_postgres_port: "{{ pg_config['resources'][0]['data']['port'] | b64decode }}" awx_postgres_host: "{{ pg_config['resources'][0]['data']['host'] | b64decode }}" awx_postgres_sslmode: "{{ pg_config['resources'][0]['data']['sslmode'] | default('prefer'|b64encode) | b64decode }}" - name: Look up details for this deployment k8s_info: api_version: "{{ api_version }}" kind: "{{ kind }}" name: "{{ meta.name }}" namespace: "{{ meta.namespace }}" register: this_awx - name: Migrate data from old Openshift instance import_tasks: migrate_data.yml when: - old_pg_config['resources'] is defined - old_pg_config['resources'] | length - this_awx['resources'][0]['status']['migratedFromSecret'] is not defined