Configurable variables

This commit is contained in:
135
2023-10-13 12:38:40 +03:00
parent 69be69ebb0
commit 1d34e1324c
5 changed files with 37 additions and 12 deletions

View File

@@ -1,8 +1,12 @@
--- ---
# defaults file for roles/powerdns-recursor # defaults file for roles/powerdns-recursor
powerdns_version: 49 powerdns_version: "{{ powerdns_recursor.version | default(49) }}"
deb_powerdns_version: =4.9.* deb_powerdns_version: "{{ powerdns_recursor.deb_version | default('=4.9.*') }}"
repo_uri: http://repo.powerdns.com/debian repo_uri: "{{ powerdns_recursor.repo_uri | default('http://repo.powerdns.com/debian') }}"
repo_components: "{{ ansible_distribution_release }}-rec-{{ powerdns_version }} main" repo_components: "{{ ansible_distribution_release }}-rec-{{ powerdns_version }} main"
repo_signed_key: "rec-{{ powerdns_version }}-pub.asc" repo_signed_key: "rec-{{ powerdns_version }}-pub.asc"
repo_state: "{{ powerdns_recursor__state }}" repo_state: "{{ powerdns_recursor__state }}"
forward_lst: "{{ powerdns_recursor.forward_lst | default ([]) }}"
# domain: auth_server_ip
nta_lst: "{{ powerdns_recursor.nta_lst | default([]) }}"
root_cached: "{{ powerdns_recursor.root_cached | default('file') }}"

View File

@@ -3,11 +3,18 @@
- name: "add powerdns-recursor repository" - name: "add powerdns-recursor repository"
become: true become: true
block: block:
- name: "powerdns repo apt key" - name: Check if powerdns repo apt key exists
stat:
path: "/etc/apt/trusted.gpg.d/{{ repo_signed_key }}"
register: key_stat
ignore_errors: yes
- name: Download powerdns repo apt key if needed
become: true become: true
get_url: get_url:
url: https://repo.powerdns.com/FD380FBB-pub.asc url: https://repo.powerdns.com/FD380FBB-pub.asc
dest: "/etc/apt/trusted.gpg.d/{{ repo_signed_key }}" dest: "/etc/apt/trusted.gpg.d/{{ repo_signed_key }}"
when: key_stat.stat.exists == False or key_stat.stat.checksum != 'sha256:checksum_of_the_source_key'
- name: "powerdns-recursor {{ powerdns_version }} repo" - name: "powerdns-recursor {{ powerdns_version }} repo"
become: true become: true
@@ -31,12 +38,13 @@
get_url: get_url:
url: https://www.internic.net/domain/root.zone url: https://www.internic.net/domain/root.zone
dest: /etc/powerdns/root.zone dest: /etc/powerdns/root.zone
when: root_cached == 'file'
- name: "template powerdns-recursor configs" - name: "template powerdns-recursor configs"
become: true become: true
template: template:
src: "templates{{ item }}.j2" src: "templates{{ file }}.j2"
dest: "{{ item }}" dest: "{{ file }}"
owner: root owner: root
group: root group: root
mode: 0644 mode: 0644
@@ -46,5 +54,7 @@
- /etc/powerdns/recursor.d/allow.lst - /etc/powerdns/recursor.d/allow.lst
- /etc/powerdns/recursor.d/forward.lst - /etc/powerdns/recursor.d/forward.lst
- /etc/powerdns/recursor.d/dns-script.lua - /etc/powerdns/recursor.d/dns-script.lua
loop_control:
loop_var: file
notify: notify:
- Restart powerdns-recursor - Restart powerdns-recursor

View File

@@ -2,7 +2,9 @@
-- WARNING: auto-generated by Ansible powerdns-recursor role. -- WARNING: auto-generated by Ansible powerdns-recursor role.
-- --
self = newDS() self = newDS()
self:add{'{{ ansible_hostname }}', '{{ ansible_hostname }}.mm', '{{ ansible_fqdn }}'} self:add{'{{ ansible_hostname }}', '{{ ansible_fqdn }}'{%- for fqdn in powerdns_recursor__self_add | default([]) %}
{% if loop.first %}, {% endif %}'{{ fqdn }}'{% if not loop.last %}, {% endif %}
{%- endfor %}}
function string.starts(String,Start) function string.starts(String,Start)
return string.sub(String,1,string.len(Start))==Start return string.sub(String,1,string.len(Start))==Start

View File

@@ -1,5 +1,8 @@
# #
# WARNING: auto-generated by Ansible powerdns-recursor role. # WARNING: auto-generated by Ansible powerdns-recursor role.
# #
mm=172.31.122.10 {% if forward_lst is defined and forward_lst | length > 0 %}
miranda-media.net=172.31.122.10 {% for zone, auth_server in forward_lst.items() %}
{{ zone }}={{ auth_server }}
{% endfor %}
{% endif %}

View File

@@ -6,7 +6,13 @@
-- Note: If you provide your own Lua configuration file, consider -- Note: If you provide your own Lua configuration file, consider
-- running rootkeys.lua too. -- running rootkeys.lua too.
dofile("/usr/share/pdns-recursor/lua-config/rootkeys.lua") dofile("/usr/share/pdns-recursor/lua-config/rootkeys.lua")
-- zoneToCache(".", "url", "https://www.internic.net/domain/root.zone", { refreshPeriod = 0 }) {% if root_cached == 'file' %}
zoneToCache(".", "file", "/etc/powerdns/root.zone", { refreshPeriod = 0 }) zoneToCache(".", "file", "/etc/powerdns/root.zone", { refreshPeriod = 0 })
addNTA('mm', "private MM domain") {% else %}
addNTA('miranda-media.net', "fix DNSSEC issue for MM domain") zoneToCache(".", "url", "https://www.internic.net/domain/root.zone", { refreshPeriod = 0 })
{% endif %}
{% if nta_lst is defined and nta_lst | length > 0 %}
{% for zone, description in nta_lst.items() %}
addNTA("{{ zone }}", "{{ description }}")
{% endfor %}
{% endif %}