Skip to content
Snippets Groups Projects
Select Git revision
  • a3089484b15bf8c18401ac3982b73250f5b73677
  • master default protected
  • v1.14.7
  • v1.14.6
  • v1.14.5
  • v1.14.4
  • v1.14.3
  • v1.14.2
  • v1.14.1
  • v1.14.0
  • v1.13.2
  • v1.13.1
  • v1.13.0
  • v1.12.1
  • v1.12.0
  • v1.11.1
  • v1.11.0
  • v1.10.0
  • v1.9.2
  • v1.9.1
  • v1.9.0
  • v1.8.4
22 results

README-servicedelegationrule.md

Blame
  • README-dnsrecord.md 12.68 KiB

    DNSRecord module

    Description

    The dnsrecord module allows management of DNS records and is as compatible as possible with the Ansible upstream ipa_dnsrecord module, but provide some other features like multiple record management in one execution and support for more DNS record types.

    Features

    • DNS record management.

    Supported FreeIPA Versions

    FreeIPA versions 4.4.0 and up are supported by the ipadnsrecord module.

    Requirements

    Controller

    • Ansible version: 2.8+

    Node

    • Supported FreeIPA version (see above)

    Usage

    Example inventory file

    [ipaserver]
    ipaserver.example.com

    Example playbook to ensure an AAAA record is present:

    ---
    - ipadnsrecord:
        ipaadmin_password: SomeADMINpassword
        name: host01
        zone_name: example.com
        record_type: 'AAAA'
        record_value: '::1'

    Example playbook to ensure an AAAA record is present, with a TTL of 300:

    ---
    - ipadnsrecord:
        ipaadmin_password: SomeADMINpassword
        name: host01
        zone_name: example.com
        record_type: 'AAAA'
        record_value: '::1'
        record_ttl: 300

    Example playbook to ensure an AAAA record is present, with a reverse PTR record:

    ---
    - ipadnsrecord:
        ipaadmin_password: SomeADMINpassword
        name: host02
        zone_name: example.com
        record_type: 'AAAA'
        record_value: 'fd00::0002'
        create_reverse: yes

    Example playbook to ensure a LOC record is present, given its individual attributes:

    ---
    - ipadnsrecord:
        ipaadmin_password: SomeADMINpassword
        zone_name: example.com
        name: host03
        loc_lat_deg: 52
        loc_lat_min: 22
        loc_lat_sec: 23.000
        loc_lat_dir: N
        loc_lon_deg: 4
        loc_lon_min: 53
        loc_lon_sec: 32.00
        loc_lon_dir: E
        loc_altitude: -2.00
        loc_size: 1.00
        loc_h_precision: 10000
        loc_v_precision: 10

    Example playbook to ensure multiple DNS records are present:

    ---
    ipadnsrecord:
      ipaadmin_password: SomeADMINpassword
      records:
        - name: host02
          zone_name: example.com
          record_type: A
          record_value:
            - "{{ ipv4_prefix }}.112"
            - "{{ ipv4_prefix }}.122"
        - name: host02
          zone_name: example.com
          record_type: AAAA
          record_value: ::1

    Example playbook to ensure multiple CNAME records are present:

    ---
    - name: Ensure that 'host03' and 'host04' have CNAME records.
      ipadnsrecord:
        ipaadmin_password: SomeADMINpassword
        zone_name: example.com
        records:
        - name: host03
          cname_hostname: host03.example.com
        - name: host04
          cname_hostname: host04.example.com

    Example playbook to ensure NS record is absent:

    ---
    - ipadnsrecord:
        ipaadmin_password: SomeADMINpassword
        zone_name: example.com
        name: host04
        ns_hostname: host04
        state: absent

    Example playbook to ensure LOC record is present, with fields: