|
1 | 1 | --- |
2 | 2 | # @todo bug: parameter user, password and sysdba needs a refactoring |
3 | | -- name: Gather Facts from Database |
4 | | - opitzconsulting.ansible_oracle.oracle_facts: |
5 | | - hostname: "{{ oracle_hostname }}" |
6 | | - port: "{{ _listener_port_cdb }}" |
7 | | - service_name: "{{ _db_service_name }}" |
8 | | - user: "{{ db_user }}" |
9 | | - password: "{{ _db_password_cdb }}" |
10 | | - mode: sysdba |
11 | | - environment: "{{ _oracle_env }}" |
12 | | - register: dbfactsreg |
13 | | - vars: |
14 | | - # set db_user for _db_password_cdb |
15 | | - db_user: "{{ oradb_facts_db_user }}" |
| 3 | +- name: Gather Facts |
| 4 | + block: |
| 5 | + - name: Gather Facts from Database (rescue failures in later task) |
| 6 | + opitzconsulting.ansible_oracle.oracle_facts: |
| 7 | + hostname: "{{ oracle_hostname }}" |
| 8 | + port: "{{ _listener_port_cdb }}" |
| 9 | + service_name: "{{ _db_service_name }}" |
| 10 | + user: "{{ db_user }}" |
| 11 | + password: "{{ _db_password_cdb }}" |
| 12 | + mode: sysdba |
| 13 | + environment: "{{ _oracle_env }}" |
| 14 | + register: dbfactsreg |
| 15 | + vars: |
| 16 | + # set db_user for _db_password_cdb |
| 17 | + db_user: "{{ oradb_facts_db_user }}" |
16 | 18 |
|
| 19 | + # 2nd execution of oracle_facts will overwrite data of last execution. |
| 20 | + # => Store facts from oracle_facts in structure |
| 21 | + - name: Write facts to oracledb.db_unique_name |
| 22 | + ansible.builtin.set_fact: |
| 23 | + cacheable: true |
| 24 | + oracledb_facts: "{{ oracledb_facts | default({}) | combine(_db_facts | items2dict) }}" |
| 25 | + when: |
| 26 | + - dbfactsreg.ansible_facts['version'] is defined |
| 27 | + vars: |
| 28 | + _db_facts: |
| 29 | + - key: "{{ odb['oracle_db_unique_name'] | default(odb['oracle_db_name']) }}" |
| 30 | + value: |
| 31 | + state: present |
| 32 | + version: "{{ ansible_facts['version'] }}" |
| 33 | + database: "{{ ansible_facts['database'] }}" |
| 34 | + instance: "{{ ansible_facts['instance'] }}" |
| 35 | + pdb: "{{ ansible_facts['pdb'] }}" |
| 36 | + parameter: "{{ ansible_facts['parameter'] }}" |
| 37 | + rac: "{{ ansible_facts['rac'] }}" |
| 38 | + redolog: "{{ ansible_facts['redolog'] }}" |
| 39 | + tablespace: "{{ ansible_facts['tablespace'] }}" |
| 40 | + temp_tablespace: "{{ ansible_facts['temp_tablespace'] }}" |
| 41 | + userenv: "{{ ansible_facts['userenv'] }}" |
| 42 | + option: "{{ ansible_facts['option'] }}" |
17 | 43 |
|
18 | | -# 2nd execution of oracle_factswill overwrite data of last execution. |
19 | | -# => Store facts from oracle_facts in structure |
20 | | -- name: Write facts to oracledb.db_unique_name |
21 | | - ansible.builtin.set_fact: |
22 | | - cacheable: true |
23 | | - oracledb_facts: "{{ oracledb_facts | default({}) | combine(_db_facts | items2dict) }}" |
24 | | - when: |
25 | | - - dbfactsreg.ansible_facts['version'] is defined |
26 | | - vars: |
27 | | - _db_facts: |
28 | | - - key: "{{ odb['oracle_db_unique_name'] | default(odb['oracle_db_name']) }}" |
29 | | - value: |
30 | | - version: "{{ dbfactsreg.ansible_facts['version'] }}" |
31 | | - database: "{{ dbfactsreg.ansible_facts['database'] }}" |
32 | | - instance: "{{ dbfactsreg.ansible_facts['instance'] }}" |
33 | | - pdb: "{{ dbfactsreg.ansible_facts['pdb'] }}" |
34 | | - parameter: "{{ dbfactsreg.ansible_facts['parameter'] }}" |
35 | | - rac: "{{ dbfactsreg.ansible_facts['rac'] }}" |
36 | | - redolog: "{{ dbfactsreg.ansible_facts['redolog'] }}" |
37 | | - tablespace: "{{ dbfactsreg.ansible_facts['tablespace'] }}" |
38 | | - temp_tablespace: "{{ dbfactsreg.ansible_facts['temp_tablespace'] }}" |
39 | | - userenv: "{{ dbfactsreg.ansible_facts['userenv'] }}" |
40 | | - option: "{{ dbfactsreg.ansible_facts['option'] }}" |
| 44 | + rescue: |
| 45 | + # default is |
| 46 | + # => Fail execution of Playbook |
| 47 | + - name: Fail execution of oradb_facts |
| 48 | + ansible.builtin.fail: |
| 49 | + msg: >- |
| 50 | + Set oradb_facts_ignore_unreachable=false in oracle_databases |
| 51 | + to disable this fail task. |
| 52 | + when: |
| 53 | + - not _odb_loop_helper.oradb_facts_ignore_unreachable | default(false) |
| 54 | + |
| 55 | + - name: Write empty facts to oracledb.db_unique_name (rescue from failure above) |
| 56 | + ansible.builtin.set_fact: |
| 57 | + cacheable: true |
| 58 | + oracledb_facts: "{{ oracledb_facts | default({}) | combine(_db_facts | items2dict) }}" |
| 59 | + vars: |
| 60 | + _db_facts: |
| 61 | + - key: "{{ odb['oracle_db_unique_name'] | default(odb['oracle_db_name']) }}" |
| 62 | + value: |
| 63 | + state: unreachable |
0 commit comments