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