nsd: Initial version of role (WIP)
This commit is contained in:
parent
c1c74dc5c4
commit
69c17d7e12
3 changed files with 82 additions and 0 deletions
5
roles/nsd/handlers/main.yml
Normal file
5
roles/nsd/handlers/main.yml
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
- name: restart nsd
|
||||||
|
service:
|
||||||
|
name: nsd
|
||||||
|
state: restarted
|
49
roles/nsd/tasks/main.yml
Normal file
49
roles/nsd/tasks/main.yml
Normal file
|
@ -0,0 +1,49 @@
|
||||||
|
---
|
||||||
|
- name: copy server certificate
|
||||||
|
copy:
|
||||||
|
dest: "{{ tls_private }}/{{ nsd_server }}.key"
|
||||||
|
src: "{{ item }}"
|
||||||
|
mode: 0600
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_wheel }}"
|
||||||
|
with_first_found:
|
||||||
|
- "/srv/letsencrypt/live/{{ nsd_server }}/privkey.pem"
|
||||||
|
- "/srv/ca/private/{{ nsd_server }}.key"
|
||||||
|
- "/srv/ca/private/{{ inventory_hostname }}.key"
|
||||||
|
|
||||||
|
- name: copy server key
|
||||||
|
copy:
|
||||||
|
dest: "{{ tls_certs }}/{{ nsd_server }}.crt"
|
||||||
|
src: "{{ item }}"
|
||||||
|
mode: 0644
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_wheel }}"
|
||||||
|
with_first_found:
|
||||||
|
- "/srv/letsencrypt/live/{{ site }}/fullchain.pem"
|
||||||
|
- "/srv/ca/certs/{{ site }}.crt"
|
||||||
|
- "/srv/ca/certs/{{ inventory_hostname }}.crt"
|
||||||
|
|
||||||
|
- name: create nsd config
|
||||||
|
template:
|
||||||
|
src: nsd.conf.j2
|
||||||
|
dest: /var/nsd/etc/nsd.conf
|
||||||
|
mode: 0640
|
||||||
|
owner: root
|
||||||
|
group: _nsd
|
||||||
|
notify: restart nsd
|
||||||
|
|
||||||
|
- name: copy zone files
|
||||||
|
copy:
|
||||||
|
dest: "/var/nsd/zones/master/{{ item|replace('/', '-') }}"
|
||||||
|
src: "/srv/dns/{{ item|replace('/', '-') }}"
|
||||||
|
mode: 0640
|
||||||
|
owner: root
|
||||||
|
group: _nsd
|
||||||
|
notify: restart nsd
|
||||||
|
with_items: "{{ nsd_zones }}"
|
||||||
|
|
||||||
|
- name: enable nsd
|
||||||
|
service:
|
||||||
|
name: nsd
|
||||||
|
state: started
|
||||||
|
enabled: true
|
28
roles/nsd/templates/nsd.conf.j2
Normal file
28
roles/nsd/templates/nsd.conf.j2
Normal file
|
@ -0,0 +1,28 @@
|
||||||
|
|
||||||
|
server:
|
||||||
|
chroot: "/var/nsd"
|
||||||
|
database: ""
|
||||||
|
hide-version: yes
|
||||||
|
logfile: "/var/log/nsd.log"
|
||||||
|
server-count: {{ ansible_processor_count }}
|
||||||
|
verbosity: 2
|
||||||
|
|
||||||
|
interface: ::0@53
|
||||||
|
interface: 0.0.0.0@53
|
||||||
|
interface: ::0@853
|
||||||
|
interface: 0.0.0.0@853
|
||||||
|
|
||||||
|
tls-service-key: {{ tls_private }}/{{ nsd_server }}.key
|
||||||
|
tls-service-pem: {{ tls_certs }}/{{ nsd_server }}.crt
|
||||||
|
|
||||||
|
remote-control:
|
||||||
|
control-enable: yes
|
||||||
|
control-interface: "/var/nsd/run/control.sock"
|
||||||
|
{% for zone in nsd_zones %}
|
||||||
|
|
||||||
|
zone:
|
||||||
|
name: "{{ zone }}"
|
||||||
|
zonefile: "/zones/master/{{ zone|replace('/', '-') }}"
|
||||||
|
notify: 144.202.29.243 NOKEY
|
||||||
|
provide-xfr: 144.202.29.243 NOKEY
|
||||||
|
{% endfor %}
|
Loading…
Add table
Add a link
Reference in a new issue