Blob Blame History Raw
---
- name: Test host
  hosts: ipaserver
  become: true

  tasks:
  - name: Get Domain from server name
    set_fact:
      ipaserver_domain: "{{ ansible_fqdn.split('.')[1:] | join ('.') }}"
    when: ipaserver_domain is not defined

  - name: Set host1_fqdn
    set_fact:
      host1_fqdn: "{{ 'host1.' + ipaserver_domain }}"

  - name: Host absent
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name:
      - "{{ host1_fqdn }}"
      update_dns: yes
      state: absent

  - name: Get IPv4 address prefix from server node
    set_fact:
      ipv4_prefix: "{{ ansible_default_ipv4.address.split('.')[:-1] |
                       join('.') }}"

  - name: Set zone prefixes.
    set_fact:
      zone_ipv6_reverse: "ip6.arpa."
      zone_ipv6_reverse_workaround: "d.f.ip6.arpa."
      zone_prefix_reverse: "in-addr.arpa"
      zone_prefix_reverse_8: "{{ ipv4_prefix.split('.')[2::-1] | join ('.') }}.in-addr.arpa"
      zone_prefix_reverse_16: "{{ ipv4_prefix.split('.')[1::-1] | join ('.') }}.in-addr.arpa"
      zone_prefix_reverse_24: "{{ ipv4_prefix.split('.')[::-1] | join ('.') }}.in-addr.arpa"

  - name: Set zone for reverse address.
    ipadnszone:
      ipaadmin_password: SomeADMINpassword
      name: "{{ item }}"
      skip_nameserver_check: yes
      skip_overlap_check: yes
    with_items:
      - "{{ zone_ipv6_reverse }}"
      - "{{ zone_ipv6_reverse_workaround }}"
      - "{{ zone_prefix_reverse }}"
      - "{{ zone_prefix_reverse_8 }}"
      - "{{ zone_prefix_reverse_16 }}"
      - "{{ zone_prefix_reverse_24 }}"

  - name: Host "{{ host1_fqdn }}" present
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name: "{{ host1_fqdn }}"
      ip_address: "{{ ipv4_prefix + '.201' }}"
      update_dns: yes
      reverse: yes
    register: result
    failed_when: not result.changed

  - name: Host "{{ host1_fqdn }}" present, again.
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name: "{{ host1_fqdn }}"
      ip_address: "{{ ipv4_prefix + '.201' }}"
      update_dns: yes
      reverse: yes
    register: result
    failed_when: result.changed

  - name: Hosts host1 absent
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name:
      - "{{ host1_fqdn }}"
      update_dns: yes
      state: absent
    register: result
    failed_when: not result.changed

  - name: Host "{{ host1_fqdn }}" present with IPv6
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name: "{{ host1_fqdn }}"
      ip_address: "fd00::0001"
      update_dns: yes
      reverse: yes
    register: result
    failed_when: not result.changed

  - name: Host "{{ host1_fqdn }}" present with IPv6, again.
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name: "{{ host1_fqdn }}"
      ip_address: "fd00::0001"
      update_dns: yes
      reverse: yes
    register: result
    failed_when: result.changed

  - name: Hosts host1 absent
    ipahost:
      ipaadmin_password: SomeADMINpassword
      name:
      - "{{ host1_fqdn }}"
      update_dns: yes
      state: absent
    register: result
    failed_when: not result.changed

  - name: Delete zone for reverse address.
    ipadnszone:
      ipaadmin_password: SomeADMINpassword
      name: "{{ item }}"
      state: absent
    with_items:
      - "{{ zone_ipv6_reverse }}"
      - "{{ zone_ipv6_reverse_workaround }}"
      - "{{ zone_prefix_reverse }}"
      - "{{ zone_prefix_reverse_8 }}"
      - "{{ zone_prefix_reverse_16 }}"
      - "{{ zone_prefix_reverse_24 }}"