12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- # Copyright 2021 Dell Inc. or its subsidiaries. All Rights Reserved.
- #
- # Licensed under the Apache License, Version 2.0 (the "License");
- # you may not use this file except in compliance with the License.
- # You may obtain a copy of the License at
- #
- # http://www.apache.org/licenses/LICENSE-2.0
- #
- # Unless required by applicable law or agreed to in writing, software
- # distributed under the License is distributed on an "AS IS" BASIS,
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- # See the License for the specific language governing permissions and
- # limitations under the License.
- ---
- - name: Check tower_cli.cfg is encrypted
- command: cat "{{ tower_config_path }}"
- changed_when: false
- register: awx_content
- run_once: true
- no_log: true
- - name: Decrpyt tower_cli.cfg
- command: ansible-vault decrypt "{{ tower_config_path }}" --vault-password-file "{{ tower_vault_path }}"
- changed_when: false
- run_once: true
- when: "'$ANSIBLE_VAULT;' in awx_content.stdout"
- - name: Fetch awx host
- command: grep "host:" "{{ tower_config_path }}"
- register: fetch_awx_host
- changed_when: false
- run_once: true
- - name: Fetch awx username
- command: grep "username:" "{{ tower_config_path }}"
- register: fetch_awx_username
- changed_when: false
- run_once: true
- no_log: true
- - name: Fetch awx password
- command: grep "password:" "{{ tower_config_path }}"
- register: fetch_awx_password
- changed_when: false
- run_once: true
- no_log: true
- - name: Set awx variables
- set_fact:
- awx_host: "{{ fetch_awx_host.stdout | regex_replace('host: ','') }}"
- awx_username: "{{ fetch_awx_username.stdout | regex_replace('username: ','') }}"
- awx_password: "{{ fetch_awx_password.stdout | regex_replace('password: ','') }}"
- no_log: true
- - name: Encrypt tower_cli.cfg
- command: ansible-vault encrypt "{{ tower_config_path }}" --vault-password-file "{{ tower_vault_path }}"
- changed_when: false
- run_once: true
- when: "'$ANSIBLE_VAULT;' in awx_content.stdout"
- - name: Get inventory list
- command: >-
- awx --conf.host "{{ awx_host }}" --conf.username "{{ awx_username }}" --conf.password "{{ awx_password }}"
- inventory list -f human --filter "name"
- register: inventory_list
- run_once: true
- changed_when: false
- no_log: true
- - block:
- - name: Fetch powervault_me4_inventory
- command: >-
- awx --conf.host {{ awx_host }} --conf.username {{ awx_username }} --conf.password {{ awx_password }}
- hosts list --inventory "{{ powervault_inventory_name }}" -f human --filter "name"
- register: fetch_inventory
- run_once: true
- changed_when: false
- no_log: true
- - name: Set powervault_status
- set_fact:
- powervault_status: true
- when: fetch_inventory.stdout_lines[2:] | length > 0
- - name: Create powervault_me4 group
- add_host:
- name: "{{ item | regex_replace(' ','') }}"
- groups: "{{ powervault_group }}"
- when: powervault_status
- with_items: "{{ fetch_inventory.stdout_lines[2:] }}"
|