Skip to content
Snippets Groups Projects
main.yml 1.75 KiB
Newer Older
  • Learn to ignore specific revisions
  • - name: Install powerdns
    
      pacman: name=powerdns state=present
    
    
    - name: Install PowerDNS configuration
    
      template: src={{ item.src }} dest=/etc/powerdns/{{ item.dest }} owner=root group=root mode=0644
      loop:
        - {src: pdns.conf.j2, dest: pdns.conf}
        - {src: dnsupdate-policy.lua.j2, dest: dnsupdate-policy.lua}
    
      notify: Restart powerdns
    
    - name: Create directory for sqlite3 dbs
    
      file: path=/var/lib/powerdns state=directory owner=powerdns group=powerdns mode=0755
    
    
    - name: Initialize sqlite3 database for _acme-challenge zones
    
      command: sqlite3 -init /usr/share/doc/powerdns/schema.sqlite3.sql /var/lib/powerdns/pdns.sqlite3 ""
      become: true
      become_user: powerdns
      args:
        creates: /var/lib/powerdns/pdns.sqlite3
    
    
    - name: Create _acme-challenge zones
    
      shell: |
        pdnsutil create-zone _acme-challenge.{{ item }} {{ inventory_hostname }}
        pdnsutil replace-rrset _acme-challenge.{{ item }} @ SOA "{{ inventory_hostname }}. root.archlinux.org. 0 10800 3600 604800 3600"
      loop: "{{ geo_domains }}"
      become: true
      become_user: powerdns
      changed_when: false
    
    
    - name: Import TSIG key (for certbot)
    
      command: pdnsutil import-tsig-key {{ certbot_rfc2136_key }} {{ certbot_rfc2136_algorithm }} {{ certbot_rfc2136_secret }}
      changed_when: false
    
    
    - name: Open powerdns ipv4 port for monitoring.archlinux.org
    
      ansible.posix.firewalld: zone=wireguard state=enabled permanent=true immediate=yes
        rich_rule="rule family=ipv4 source address={{ hostvars['monitoring.archlinux.org']['wireguard_address'] }} port protocol=tcp port=8081 accept"
      tags:
        - firewall
    
    
    - name: Open firewall hole
    
      ansible.posix.firewalld: service=dns permanent=true state=enabled immediate=yes
    
    
    - name: Start and enable powerdns
    
      systemd: name=pdns.service enabled=yes daemon_reload=yes state=started