You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
hetzner-ansible/roles/_digitalocean/tasks/domain.yml

60 lines
1.9 KiB
YAML

---
- name: Read DNS entry for {{ record_name }}.{{ domain }} from digitalocean
uri:
url: "https://api.digitalocean.com/v2/domains/{{ domain }}/records?name={{ record_name }}.{{ domain }}"
headers:
accept: application/json
authorization: Bearer {{ digitalocean_authentication_token }}
return_content: yes
register: domain_records_response
delegate_to: 127.0.0.1
- name: Save DNS entry as variable (fact)
set_fact:
domain_records_response_json: "{{ domain_records_response.json }}"
- name: Parse DNS entry for {{ record_name }}.{{ domain }}
set_fact:
domain_record: "{{ domain_records_response_json.domain_records | json_query(jmesquery) | first | default({'name': '-', 'ip': '-'}) }}"
vars:
jmesquery: '[*].{id: id, name: name, ip: data}'
- name: Print DNS entry for {{ record_name }}.{{ domain }}
debug:
msg: "{{ domain_record }}"
- name: Delete DNS entry for <{{ record_name }}> if necessary
uri:
method: DELETE
url: "https://api.digitalocean.com/v2/domains/{{ domain }}/records/{{ domain_record.id }}"
headers:
authorization: Bearer {{ digitalocean_authentication_token }}
return_content: yes
status_code: 204
when:
domain_record.ip != '-'
and record_data != domain_record.ip
delegate_to: 127.0.0.1
- name: Create DNS entry for <{{ record_name }}> if necessary
uri:
method: POST
url: "https://api.digitalocean.com/v2/domains/{{ domain }}/records"
headers:
authorization: Bearer {{ digitalocean_authentication_token }}
body: '{{ create_record | to_json }}'
body_format: json
return_content: yes
status_code: 201
vars:
create_record:
type: 'A'
ttl: 1800
data: "{{ record_data }}"
name: "{{ record_name }}"
when:
domain_record.ip == '-'
or record_data != domain_record.ip
or record_name != domain_record.name
delegate_to: 127.0.0.1