system-configuration/modules/config/dns.scm

dns.scm

1
;;; Tyreunom's system administration and configuration tools.
2
;;;
3
;;; Copyright © 2019 Julien Lepiller <julien@lepiller.eu>
4
;;;
5
;;; This program is free software: you can redistribute it and/or modify
6
;;; it under the terms of the GNU General Public License as published by
7
;;; the Free Software Foundation, either version 3 of the License, or
8
;;; (at your option) any later version.
9
;;;
10
;;; This program is distributed in the hope that it will be useful,
11
;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
12
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
;;; GNU General Public License for more details.
14
;;;
15
;;; You should have received a copy of the GNU General Public License
16
;;; along with this program.  If not, see <http://www.gnu.org/licenses/>.
17
18
;;
19
;; DNS services
20
;;
21
22
(define-module (config dns)
23
  #:use-module (data dns)
24
  #:use-module (gnu services)
25
  #:use-module (gnu services dns)
26
  #:use-module (srfi srfi-1)
27
  #:use-module (ice-9 textual-ports)
28
  #:export (ipv4-reverse-master-zone
29
            ipv6-reverse-master-zone
30
            lepiller-master-zone
31
            lepiller-slave-zone
32
            master-acl
33
            slave-acl
34
            hermes
35
            ene))
36
37
(define public-dkim
38
  (apply
39
    string-append
40
    (string-split
41
      (call-with-input-file "/etc/mail/dkim/public.key" get-string-all)
42
      #\newline)))
43
44
(define-zone-entries lepiller.eu.zone
45
;; Name         TTL Class Type Data
46
  ("amadeus"    ""  "IN"  "A"     amadeus-ip4)
47
  ("ene"        ""  "IN"  "A"     ene-ip4)
48
  ("hermes"     ""  "IN"  "A"     hermes-ip4)
49
  ("hermes"     ""  "IN"  "AAAA"  hermes-ip6)
50
  ("xana"       ""  "IN"  "A"     xana-ip4)
51
  ("@"          ""  "IN"  "A"     hermes-ip4)
52
  ("@"          ""  "IN"  "AAAA"  hermes-ip6)
53
  ("www"        ""  "IN"  "CNAME" "lepiller.eu.")
54
55
  ("avatar"     ""  "IN"  "CNAME" "ene")
56
  ("ct-buildings" "" "IN" "CNAME" "xana")
57
  ("guix"       ""  "IN"  "CNAME" "amadeus")
58
  ("i18n"       ""  "IN"  "CNAME" "xana")
59
  ("nani"       ""  "IN"  "CNAME" "xana")
60
  ("offlate"    ""  "IN"  "CNAME" "xana")
61
  ("rennes"     ""  "IN"  "CNAME" "ene")
62
  ("social"     ""  "IN"  "CNAME" "hermes")
63
64
  ("@"          ""  "IN"  "NS"    "ns")
65
  ("@"          ""  "IN"  "NS"    "ns2")
66
  ("ns"         ""  "IN"  "A"     hermes-ip4)
67
  ("ns"         ""  "IN"  "AAAA"  hermes-ip6)
68
  ("ns2"        ""  "IN"  "A"     ene-ip4)
69
70
  ("@"          ""  "IN"  "MX"    "10 courriel")
71
  ("@"          ""  "IN"  "MX"    "50 b.courriel")
72
  ("b.courriel" ""  "IN"  "A"     hermes-ip4)
73
  ("b.courriel" ""  "IN"  "AAAA"  hermes-ip6)
74
  ("courriel"   ""  "IN"  "A"     ene-ip4)
75
  ("imap"       ""  "IN"  "CNAME" "courriel")
76
  ("smtp"       ""  "IN"  "CNAME" "b.courriel")
77
  ("@"          ""  "IN"  "TXT"   "v=spf1 mx a ~all")
78
  ("@"          ""  "IN"  "SPF"   "v=spf1 mx a ~all")
79
  
80
  ("dkim._domainkey" "" "IN" "TXT" (string-append "v=DKIM1\\; p=" public-dkim "\\; s=email\\; t=s"))
81
  ("_dmarc"     ""  "IN"  "TXT"   "v=DMARC1\\; p=none\\; sp=reject\\; rua=mailto:rua@lepiller.eu!10m\\; ruf=mailto:ruf@lepiller.eu!10m\\; rf=afrf\\; pct=100\\; ri=86400"))
82
83
(define-zone-entries ipv4-reverse.zone
84
  ("@" "" "IN" "PTR" "lepiller.eu.")
85
  ("@"          ""  "IN"  "NS"    "ns.lepiller.eu.")
86
  ("@"          ""  "IN"  "NS"    "ns2.lepiller.eu."))
87
88
(define-zone-entries ipv6-reverse.zone
89
  ("1.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0.0" "" "IN" "PTR" "lepiller.eu.")
90
  ("@"          ""  "IN"  "NS"    "ns.lepiller.eu.")
91
  ("@"          ""  "IN"  "NS"    "ns2.lepiller.eu."))
92
93
(define ene
94
  (knot-remote-configuration
95
    (id "ene")
96
    (address (list ene-ip4))
97
    (key "lepiller-key")))
98
99
(define hermes
100
  (knot-remote-configuration
101
    (id "hermes")
102
    (address (list hermes-ip4 hermes-ip6))
103
    (key "lepiller-key")))
104
105
(define master-acl
106
  (knot-acl-configuration
107
    (id "master-acl")
108
    (address (list hermes-ip4))
109
    (key '("lepiller-key"))
110
    (action '(transfer))))
111
112
(define slave-acl
113
  (knot-acl-configuration
114
    (id "slave-acl")
115
    (address (list ene-ip4))
116
    (key '("lepiller-key"))
117
    (action '(notify))))
118
119
(define lepiller-master-zone
120
  (knot-zone-configuration
121
    (domain "lepiller.eu")
122
    (notify '("hermes"))
123
    (dnssec-policy "default")
124
    (acl '("master-acl"))
125
    (zonefile-load 'difference)
126
    (zone (zone-file
127
            (origin "lepiller.eu")
128
            (entries lepiller.eu.zone)
129
            (serial 2020060901)))))
130
131
(define lepiller-slave-zone
132
  (knot-zone-configuration
133
    (domain "lepiller.eu")
134
    (acl '("slave-acl"))
135
    (master '("ene"))))
136
137
(define ipv6-reverse-master-zone
138
  (let* ((ip6 (string->list (substring (string-delete #\: hermes-ip6) 0 12)))
139
         (rev-ip6-lst (fold (lambda (elem acc)
140
                          (cons* #\. elem acc))
141
                        '()
142
                        ip6))
143
         (rev-ip6 (list->string (cdr rev-ip6-lst)))
144
         (domain (string-append rev-ip6 ".ip6.arpa")))
145
    (knot-zone-configuration
146
      (domain domain)
147
      (zone (zone-file
148
              (origin domain)
149
              (entries ipv6-reverse.zone)
150
              (ns "ns.lepiller.eu.")
151
              (mail "hostmaster.lepiller.eu.")
152
              (serial 1))))))
153
154
(define ipv4-reverse-master-zone
155
  (let ((domain (string-append
156
                  (string-join (reverse (string-split hermes-ip4 #\.)) ".")
157
                  ".in-addr.arpa")))
158
    (knot-zone-configuration
159
      (domain domain)
160
      (zone (zone-file
161
              (origin domain)
162
              (entries ipv4-reverse.zone)
163
              (ns "ns.lepiller.eu.")
164
              (mail "hostmaster.lepiller.eu.")
165
              (serial 1))))))
166