# 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: Include provision_idrac vars
  include_vars: "{{ playbook_dir }}/../roles/provision_idrac/vars/main.yml"
  run_once: true

- name: Check tower_cli.cfg is encrypted
  command: cat "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vars_filename }}"
  changed_when: false
  register: awx_content
  run_once: true

- name: Decrpyt tower_cli.cfg
  command: >-
    ansible-vault decrypt "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vars_filename }}"
    --vault-password-file "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vaultname }}"
  changed_when: false
  run_once: true
  when: "'$ANSIBLE_VAULT;' in awx_content.stdout"

- name: Fetch awx host
  command: grep "host:" "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vars_filename }}"
  register: fetch_awx_host
  changed_when: false
  run_once: true

- name: Fetch awx username
  command: grep "username:" "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vars_filename }}"
  register: fetch_awx_username
  changed_when: false
  run_once: true
  no_log: true

- name: Fetch awx password
  command: grep "password:" "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vars_filename }}"
  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 "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vars_filename }}"
    --vault-password-file "{{ playbook_dir }}/../roles/webui_awx/files/{{ awx_vaultname }}"
  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 provisioned_idrac inventory
      command: >-
        awx --conf.host {{ awx_host }} --conf.username {{ awx_username }} --conf.password {{ awx_password }}
        hosts list --inventory "{{ provisioned_idrac_inventory_name }}" -f human --filter "name"
      register: fetch_inventory
      run_once: true
      changed_when: false
      no_log: true
    
    - name: Launch ethernet_template
      command: >-
        awx --conf.host {{ awx_host }} --conf.username {{ awx_username }} --conf.password {{ awx_password }}
        job_templates launch {{ ethernet_template_name }} --wait
      run_once: true
      changed_when: true
      no_log: true

    - name: Wait for 10 mins for DHCP to assign IP to devices
      wait_for:
        timeout: "{{ dhcp_wait_time }}"

    - name: Launch idrac_template
      command: >-
        awx --conf.host {{ awx_host }} --conf.username {{ awx_username }} --conf.password {{ awx_password }}
        job_templates launch {{ idrac_template_name }} --wait
      run_once: true
      changed_when: false
      no_log: true
      when: inventory_hostname not in fetch_inventory.stdout
  when: provisioned_idrac_inventory_name in inventory_list.stdout