]> git.openstreetmap.org Git - dns.git/blob - src/openstreetmap.js
Add fastly DNS ACME challenge CNAME
[dns.git] / src / openstreetmap.js
1 D(DOMAIN, REGISTRAR, DnsProvider(PROVIDER),
2
3   // Publish CAA records indicating that only letsencrypt and globalsign (Fastly) should issue certificates
4
5   CAA_BUILDER({
6     label: "@",
7     ttl: "1h",
8     iodef: "mailto:hostmaster@openstreetmap.org",
9     issue: [
10       "letsencrypt.org",
11       "globalsign.com",   // Used by Fastly for CDN certificates
12     ],
13     issuewild: [
14       "letsencrypt.org",
15       "globalsign.com",   // Used by Fastly for CDN certificates
16     ],
17   }),
18
19   // Use shenron as the MX host
20
21   MX("@", 10, QUALIFY("a.mx")),
22   MX("messages", 10, QUALIFY("a.mx")),
23   MX("noreply", 10, QUALIFY("a.mx")),
24   MX("otrs", 10, QUALIFY("a.mx")),
25   A("a.mx", SHENRON_IPV4),
26   AAAA("a.mx", SHENRON_IPV6),
27
28   // Publish SPF records indicating that only shenron sends mail
29
30   SPF_BUILDER({
31     label: "@",
32     ttl: "1h",
33     parts: [
34       "v=spf1",
35       "ip4:212.110.172.32",       // shenron ipv4
36       "ip6:2001:41c9:1:400::32",  // shenron ipv6
37       "mx",                       // safety net if we change mx
38       "-all"
39     ]
40   }),
41
42   SPF_BUILDER({
43     label: "messages",
44     ttl: "1h",
45     parts: [
46       "v=spf1",
47       "ip4:212.110.172.32",       // shenron ipv4
48       "ip6:2001:41c9:1:400::32",  // shenron ipv6
49       "mx",                       // safety net if we change mx
50       "-all"
51     ]
52   }),
53
54   SPF_BUILDER({
55     label: "noreply",
56     ttl: "1h",
57     parts: [
58       "v=spf1",
59       "ip4:212.110.172.32",       // shenron ipv4
60       "ip6:2001:41c9:1:400::32",  // shenron ipv6
61       "mx",                       // safety net if we change mx
62       "-all"
63     ]
64   }),
65
66   SPF_BUILDER({
67     label: "otrs",
68     ttl: "1h",
69     parts: [
70       "v=spf1",
71       "ip4:212.110.172.32",       // shenron ipv4
72       "ip6:2001:41c9:1:400::32",  // shenron ipv6
73       "mx",                       // safety net if we change mx
74       "-all"
75     ]
76   }),
77
78   // Publish DKIM public key
79
80   TXT("20200301._domainkey", "v=DKIM1; k=rsa; p=MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAzvoNZVOGfw1V4A171hxHMhzVTAnIUQVJ8iX3wbqCld8A5iIaXeTGYvBmewymax/cYJS4QqzbpUzkgrrTA9avuZhd+QGJDgjADgx4VyMOaOS6FwAxS0uXtLrt+lsixRDx/feKyZHaxjzJAQy46ok77xXL4UXIaaovw6G6eZpIScMzZQ2zkKNJxTICzzSOduIilHhMWte4XP+/2PdRmD7Ge9jb0U4bZjswX0AqKSGzDKYw+yxVna9l53adeCnklqg2ofoXu+ResiH+kt05aCUOMo8en3em6yBnRCMalgi1E3Tt7I5BWcYFRkT/8agUGW4gGC6XMV9IskOsYL0emG0kGwIDAQAB", AUTOSPLIT),
81
82   // Publish DMARC report-only policy
83
84   DMARC_BUILDER({
85     policy: "none",
86     rua: [
87       "mailto:openstreetmap-d@dmarc.report-uri.com"
88     ],
89     failureOptions: 1
90   }),
91
92   // Announce MTA-STS policy and TLSRPT policy for error reports
93
94   TXT("_mta-sts", "v=STSv1; id=202001291805Z"),
95   TXT("_smtp._tls", "v=TLSRPTv1; rua=mailto:openstreetmap-d@tlsrpt.report-uri.com"),
96
97   // Fastly cert domain ownership confirmation
98
99   TXT("@", "_globalsign-domain-verification=ps00GlW1BzY9c2_cwH_pFqRkvzZyaCVZ-3RLssRG6S"),
100   TXT("@", "_globalsign-domain-verification=W0buKB5ZmL-VwwHw2oQyQImk3I1q3hSemf2qmB1hjP"),
101
102   // Delegate MTA-STS policy for subdomains
103
104   CNAME("_mta-sts.messages", QUALIFY("_mta-sts")),
105   CNAME("_mta-sts.noreply", QUALIFY("_mta-sts")),
106   CNAME("_mta-sts.otrs", QUALIFY("_mta-sts")),
107
108   // Google postmaster tools verification
109
110   CNAME("af323lytato5", "gv-o4v3qh5pfayqex.dv.googlehosted.com."),
111   CNAME("irzdddnmh465", "gv-cwr6bvt7xsgact.dv.googlehosted.com."),
112
113   // Delegate geo.openstreetmap.org to PowerDNS
114
115   NS("geo", QUALIFY("balerion")),
116   NS("geo", QUALIFY("saphira")),
117   NS("geo", QUALIFY("stormfly-04")),
118   NS("geo", QUALIFY("ridgeback")),
119
120   // Main web servers and their aliases
121
122   A("spike-01", SPIKE01_IPV4),
123   AAAA("spike-01", SPIKE01_IPV6),
124   // A("@", SPIKE01_IPV4, TTL("10m")),
125   // AAAA("@", SPIKE01_IPV6, TTL("10m")),
126   // A("www", SPIKE01_IPV4, TTL("10m")),
127   // AAAA("www", SPIKE01_IPV6, TTL("10m")),
128   // A("api", SPIKE01_IPV4, TTL("10m")),
129   // AAAA("api", SPIKE01_IPV6, TTL("10m")),
130   // A("maps", SPIKE01_IPV4, TTL("10m")),
131   // AAAA("maps", SPIKE01_IPV6, TTL("10m")),
132   // A("mapz", SPIKE01_IPV4, TTL("10m")),
133   // AAAA("mapz", SPIKE01_IPV6, TTL("10m")),
134   A("spike-01.dub", SPIKE01_INTERNAL),
135   A("spike-01.oob", SPIKE01_OOB),
136
137   A("spike-02", SPIKE02_IPV4),
138   AAAA("spike-02", SPIKE02_IPV6),
139   // A("@", SPIKE02_IPV4, TTL("10m")),
140   // AAAA("@", SPIKE02_IPV6, TTL("10m")),
141   // A("www", SPIKE02_IPV4, TTL("10m")),
142   // AAAA("www", SPIKE02_IPV6, TTL("10m")),
143   // A("api", SPIKE02_IPV4, TTL("10m")),
144   // AAAA("api", SPIKE02_IPV6, TTL("10m")),
145   // A("maps", SPIKE02_IPV4, TTL("10m")),
146   // AAAA("maps", SPIKE02_IPV6, TTL("10m")),
147   // A("mapz", SPIKE02_IPV4, TTL("10m")),
148   // AAAA("mapz", SPIKE02_IPV6, TTL("10m")),
149   A("spike-02.dub", SPIKE02_INTERNAL),
150   A("spike-02.oob", SPIKE02_OOB),
151
152   A("spike-03", SPIKE03_IPV4),
153   AAAA("spike-03", SPIKE03_IPV6),
154   // A("@", SPIKE03_IPV4, TTL("10m")),
155   // AAAA("@", SPIKE03_IPV6, TTL("10m")),
156   // A("www", SPIKE03_IPV4, TTL("10m")),
157   // AAAA("www", SPIKE03_IPV6, TTL("10m")),
158   // A("api", SPIKE03_IPV4, TTL("10m")),
159   // AAAA("api", SPIKE03_IPV6, TTL("10m")),
160   // A("maps", SPIKE03_IPV4, TTL("10m")),
161   // AAAA("maps", SPIKE03_IPV6, TTL("10m")),
162   // A("mapz", SPIKE03_IPV4, TTL("10m")),
163   // AAAA("mapz", SPIKE03_IPV6, TTL("10m")),
164   A("spike-03.dub", SPIKE03_INTERNAL),
165   A("spike-03.oob", SPIKE03_OOB),
166
167   A("spike-04", SPIKE04_IPV4),
168   AAAA("spike-04", SPIKE04_IPV6),
169   // A("@", SPIKE04_IPV4, TTL("10m")),
170   // AAAA("@", SPIKE04_IPV6, TTL("10m")),
171   // A("www", SPIKE04_IPV4, TTL("10m")),
172   // AAAA("www", SPIKE04_IPV6, TTL("10m")),
173   // A("api", SPIKE04_IPV4, TTL("10m")),
174   // AAAA("api", SPIKE04_IPV6, TTL("10m")),
175   // A("maps", SPIKE04_IPV4, TTL("10m")),
176   // AAAA("maps", SPIKE04_IPV6, TTL("10m")),
177   // A("mapz", SPIKE04_IPV4, TTL("10m")),
178   // AAAA("mapz", SPIKE04_IPV6, TTL("10m")),
179   A("spike-04.bm", SPIKE04_INTERNAL),
180   A("spike-04.oob", SPIKE04_OOB),
181
182   A("spike-05", SPIKE05_IPV4),
183   AAAA("spike-05", SPIKE05_IPV6),
184   // A("@", SPIKE05_IPV4, TTL("10m")),
185   // AAAA("@", SPIKE05_IPV6, TTL("10m")),
186   // A("www", SPIKE05_IPV4, TTL("10m")),
187   // AAAA("www", SPIKE05_IPV6, TTL("10m")),
188   // A("api", SPIKE05_IPV4, TTL("10m")),
189   // AAAA("api", SPIKE05_IPV6, TTL("10m")),
190   // A("maps", SPIKE05_IPV4, TTL("10m")),
191   // AAAA("maps", SPIKE05_IPV6, TTL("10m")),
192   // A("mapz", SPIKE05_IPV4, TTL("10m")),
193   // AAAA("mapz", SPIKE05_IPV6, TTL("10m")),
194   A("spike-05.bm", SPIKE05_INTERNAL),
195   A("spike-05.oob", SPIKE05_OOB),
196
197   A("spike-06", SPIKE06_IPV4),
198   AAAA("spike-06", SPIKE06_IPV6),
199   A("@", SPIKE06_IPV4, TTL("10m")),
200   AAAA("@", SPIKE06_IPV6, TTL("10m")),
201   A("www", SPIKE06_IPV4, TTL("10m")),
202   AAAA("www", SPIKE06_IPV6, TTL("10m")),
203   A("api", SPIKE06_IPV4, TTL("10m")),
204   AAAA("api", SPIKE06_IPV6, TTL("10m")),
205   A("maps", SPIKE06_IPV4, TTL("10m")),
206   AAAA("maps", SPIKE06_IPV6, TTL("10m")),
207   A("mapz", SPIKE06_IPV4, TTL("10m")),
208   AAAA("mapz", SPIKE06_IPV6, TTL("10m")),
209   A("spike-06.ams", SPIKE06_INTERNAL),
210   A("spike-06.oob", SPIKE06_OOB),
211
212   A("spike-07", SPIKE07_IPV4),
213   AAAA("spike-07", SPIKE07_IPV6),
214   A("@", SPIKE07_IPV4, TTL("10m")),
215   AAAA("@", SPIKE07_IPV6, TTL("10m")),
216   A("www", SPIKE07_IPV4, TTL("10m")),
217   AAAA("www", SPIKE07_IPV6, TTL("10m")),
218   A("api", SPIKE07_IPV4, TTL("10m")),
219   AAAA("api", SPIKE07_IPV6, TTL("10m")),
220   A("maps", SPIKE07_IPV4, TTL("10m")),
221   AAAA("maps", SPIKE07_IPV6, TTL("10m")),
222   A("mapz", SPIKE07_IPV4, TTL("10m")),
223   AAAA("mapz", SPIKE07_IPV6, TTL("10m")),
224   A("spike-07.ams", SPIKE07_INTERNAL),
225   A("spike-07.oob", SPIKE07_OOB),
226
227   A("spike-08", SPIKE08_IPV4),
228   AAAA("spike-08", SPIKE08_IPV6),
229   A("@", SPIKE08_IPV4, TTL("10m")),
230   AAAA("@", SPIKE08_IPV6, TTL("10m")),
231   A("www", SPIKE08_IPV4, TTL("10m")),
232   AAAA("www", SPIKE08_IPV6, TTL("10m")),
233   A("api", SPIKE08_IPV4, TTL("10m")),
234   AAAA("api", SPIKE08_IPV6, TTL("10m")),
235   A("maps", SPIKE08_IPV4, TTL("10m")),
236   AAAA("maps", SPIKE08_IPV6, TTL("10m")),
237   A("mapz", SPIKE08_IPV4, TTL("10m")),
238   AAAA("mapz", SPIKE08_IPV6, TTL("10m")),
239   A("spike-08.ams", SPIKE08_INTERNAL),
240   A("spike-08.oob", SPIKE08_OOB),
241
242   // Rails application servers
243
244   A("thorn-02.ams", THORN02_INTERNAL),
245   A("rails2.ams", THORN02_INTERNAL),
246   A("thorn-02.oob", THORN02_OOB),
247
248   A("thorn-03.ams", THORN03_INTERNAL),
249   A("rails3.ams", THORN03_INTERNAL),
250   A("thorn-03.oob", THORN03_OOB),
251
252   A("thorn-04.bm", THORN04_INTERNAL),
253   A("rails4.bm", THORN04_INTERNAL),
254   A("thorn-04.oob", THORN04_OOB),
255
256   A("thorn-05.bm", THORN05_INTERNAL),
257   A("rails5.bm", THORN05_INTERNAL),
258   A("thorn-05.oob", THORN05_OOB),
259
260   // Nominatim servers
261
262   A("pummelzacken", PUMMELZACKEN_IPV4),
263   A("pummelzacken.ucl", PUMMELZACKEN_INTERNAL),
264   A("pummelzacken.oob", PUMMELZACKEN_OOB),
265
266   A("dulcy", DULCY_IPV4),
267   AAAA("dulcy", DULCY_IPV6),
268   A("dulcy.ams", DULCY_INTERNAL),
269   A("dulcy.oob", DULCY_OOB),
270
271   A("stormfly-04", STORMFLY04_IPV4),
272   AAAA("stormfly-04", STORMFLY04_IPV6),
273   A("stormfly-04.oob", STORMFLY04_OOB),
274
275   CNAME("nominatim", "nominatim.geo.openstreetmap.org."),
276   CNAME("qgis.nominatim", "nominatim.geo.openstreetmap.org."),
277
278   // Taginfo server
279
280   A("grindtooth", GRINDTOOTH_IPV4),
281   A("taginfo", GRINDTOOTH_IPV4, TTL("10m")),
282   A("grindtooth.ucl", GRINDTOOTH_INTERNAL),
283   A("grindtooth.oob", GRINDTOOTH_OOB),
284
285   // Tile servers
286
287   A("orm", ORM_IPV4),
288   AAAA("orm", ORM_IPV6),
289   A("orm.ams", ORM_INTERNAL),
290   A("orm.oob", ORM_OOB),
291
292   A("odin", ODIN_IPV4),
293   AAAA("odin", ODIN_IPV6),
294   A("odin.ams", ODIN_INTERNAL),
295   A("odin.oob", ODIN_OOB),
296
297   A("ysera", YSERA_IPV4),
298   A("ysera.ucl", YSERA_INTERNAL),
299   A("ysera.oob", YSERA_OOB),
300
301   A("culebre", CULEBRE_IPV4),
302   AAAA("culebre", CULEBRE_IPV6),
303   A("culebre.dub", CULEBRE_INTERNAL),
304   A("culebre.oob", CULEBRE_OOB),
305
306   A("nidhogg", NIDHOGG_IPV4),
307   AAAA("nidhogg", NIDHOGG_IPV6),
308   A("nidhogg.oob", NIDHOGG_OOB),
309
310   A("scorch", SCORCH_IPV4),
311   AAAA("scorch", SCORCH_IPV6),
312
313   A("rhaegal", RHAEGAL_IPV4),
314
315   A("pyrene", PYRENE_IPV4),
316   AAAA("pyrene", PYRENE_IPV6),
317   A("pyrene.oob", TIAMAT00_INTERNAL),
318
319   A("bowser", BOWSER_IPV4),
320
321   A("balerion", BALERION_IPV4),
322
323   A("albi", ALBI_IPV4),
324   AAAA("albi", ALBI_IPV6),
325
326   A("necrosan", NECROSAN_IPV4),
327   AAAA("necrosan", NECROSAN_IPV6),
328
329   CNAME("tile", "dualstack.k.sni.global.fastly.net.", TTL("10m")),
330   CNAME("a.tile", "dualstack.k.sni.global.fastly.net.", TTL("10m")),
331   CNAME("b.tile", "dualstack.k.sni.global.fastly.net.", TTL("10m")),
332   CNAME("c.tile", "dualstack.k.sni.global.fastly.net.", TTL("10m")),
333   // Fastly DNS based ACME Challenge requirement
334   CNAME("_acme-challenge.tile", "bxve5ryiwwv7woiraq.fastly-validations.com.", TTL("10m")),
335
336   // Services machine
337
338   A("ironbelly", IRONBELLY_IPV4),
339   AAAA("ironbelly", IRONBELLY_IPV6),
340   A("backup", IRONBELLY_IPV4, TTL("10m")),
341   AAAA("backup", IRONBELLY_IPV6, TTL("10m")),
342   A("planet", IRONBELLY_IPV4, TTL("10m")),
343   AAAA("planet", IRONBELLY_IPV6, TTL("10m")),
344   A("logstash", IRONBELLY_IPV4),
345   AAAA("logstash", IRONBELLY_IPV6),
346   A("ironbelly.ams", IRONBELLY_INTERNAL),
347   A("ironbelly.oob", IRONBELLY_OOB),
348
349   A("norbert", NORBERT_IPV4),
350   AAAA("norbert", NORBERT_IPV6),
351   // A("backup", NORBERT_IPV4, TTL("10m")),
352   // AAAA("backup", NORBERT_IPV6, TTL("10m")),
353   // A("planet", NORBERT_IPV4, TTL("10m")),
354   // AAAA("planet", NORBERT_IPV6, TTL("10m")),
355   A("norbert.ams", NORBERT_INTERNAL),
356   A("norbert.oob", NORBERT_OOB),
357
358   A("fafnir", FAFNIR_IPV4),
359   AAAA("fafnir", FAFNIR_IPV6),
360   // A("backup", FAFNIR_IPV4, TTL("10m")),
361   // AAAA("backup", FAFNIR_IPV6, TTL("10m")),
362   // A("planet", FAFNIR_IPV4, TTL("10m")),
363   // AAAA("planet", FAFNIR_IPV6, TTL("10m")),
364   A("fafnir.dub", FAFNIR_INTERNAL),
365   A("fafnir.oob", FAFNIR_OOB),
366
367   A("horntail", HORNTAIL_IPV4),
368   AAAA("horntail", HORNTAIL_IPV6),
369   // A("backup", HORNTAIL_IPV4, TTL("10m")),
370   // AAAA("backup", HORNTAIL_IPV6, TTL("10m")),
371   // A("planet", HORNTAIL_IPV4, TTL("10m")),
372   // AAAA("planet", HORNTAIL_IPV6, TTL("10m")),
373   A("horntail.dub", HORNTAIL_INTERNAL),
374   A("horntail.oob", HORNTAIL_OOB),
375
376   A("grisu", GRISU_IPV4),
377   AAAA("grisu", GRISU_IPV6),
378   // A("backup", GRISU_IPV4, TTL("10m")),
379   // AAAA("backup", GRISU_IPV6, TTL("10m")),
380   // A("planet", GRISU_IPV4, TTL("10m")),
381   // AAAA("planet", GRISU_IPV6, TTL("10m")),
382   A("grisu.bm", GRISU_INTERNAL),
383   A("grisu.oob", GRISU_OOB),
384
385   // Database servers
386
387   A("snap-01.ams", SNAP01_INTERNAL),
388   A("snap-01.oob", SNAP01_OOB),
389
390   A("snap-02.ucl", SNAP02_INTERNAL),
391   A("snap-02.oob", SNAP02_OOB),
392
393   A("snap-03.dub", SNAP03_INTERNAL),
394   A("snap-03.oob", SNAP03_OOB),
395
396   A("karm.ams", KARM_INTERNAL),
397   A("karm.oob", KARM_OOB),
398
399   A("eddie.ucl", EDDIE_INTERNAL),
400   A("eddie.oob", EDDIE_OOB),
401
402   A("katla.bm", KATLA_INTERNAL),
403   A("katla.oob", KATLA_OOB),
404
405   A("ramoth.ams", RAMOTH_INTERNAL),
406   A("ramoth.oob", RAMOTH_OOB),
407
408   // Development server with wildcard alias for user sites
409
410   A("errol", ERROL_IPV4),
411   A("dev", ERROL_IPV4),
412   A("*.dev", ERROL_IPV4),
413   A("ooc", ERROL_IPV4),
414   A("a.ooc", ERROL_IPV4),
415   A("b.ooc", ERROL_IPV4),
416   A("c.ooc", ERROL_IPV4),
417   A("npe", ERROL_IPV4),
418   A("errol.ucl", ERROL_INTERNAL),
419   A("errol.oob", ERROL_OOB),
420
421   // Foundation server
422
423   A("ridley", RIDLEY_IPV4),
424   A("otrs", RIDLEY_IPV4),
425   A("blog", RIDLEY_IPV4),
426   A("foundation", RIDLEY_IPV4),
427   A("hot", RIDLEY_IPV4),
428   A("dmca", RIDLEY_IPV4),
429   A("ridley.ucl", RIDLEY_INTERNAL),
430   A("ridley.oob", RIDLEY_OOB),
431
432   // Piwik server
433
434   A("eustace", EUSTACE_IPV4),
435   A("piwik", EUSTACE_IPV4),
436   A("eustace.ucl", EUSTACE_INTERNAL),
437   A("eustace.oob", EUSTACE_OOB),
438
439   // Imagery servers
440
441   A("draco", DRACO_IPV4),
442   A("draco.ucl", DRACO_INTERNAL),
443   A("draco.oob", DRACO_OOB),
444
445   A("kessie", KESSIE_IPV4),
446   AAAA("kessie", KESSIE_IPV6),
447   A("agri", KESSIE_IPV4, TTL("1h")),
448   AAAA("agri", KESSIE_IPV6, TTL("1h")),
449   A("a.agri", KESSIE_IPV4, TTL("1h")),
450   AAAA("a.agri", KESSIE_IPV6, TTL("1h")),
451   A("b.agri", KESSIE_IPV4, TTL("1h")),
452   AAAA("b.agri", KESSIE_IPV6, TTL("1h")),
453   A("c.agri", KESSIE_IPV4, TTL("1h")),
454   AAAA("c.agri", KESSIE_IPV6, TTL("1h")),
455   A("os", KESSIE_IPV4, TTL("1h")),
456   AAAA("os", KESSIE_IPV6, TTL("1h")),
457   A("a.os", KESSIE_IPV4, TTL("1h")),
458   AAAA("a.os", KESSIE_IPV6, TTL("1h")),
459   A("b.os", KESSIE_IPV4, TTL("1h")),
460   AAAA("b.os", KESSIE_IPV6, TTL("1h")),
461   A("c.os", KESSIE_IPV4, TTL("1h")),
462   AAAA("c.os", KESSIE_IPV6, TTL("1h")),
463   A("kessie.oob", KESSIE_OOB),
464
465   // Munin server
466
467   A("urmel", URMEL_IPV4),
468   A("munin", URMEL_IPV4),
469   A("urmel.ucl", URMEL_INTERNAL),
470   A("urmel.oob", URMEL_OOB),
471
472   // Prometheus server
473
474   A("stormfly-03", STORMFLY03_IPV4),
475   AAAA("stormfly-03", STORMFLY03_IPV6),
476   A("prometheus", STORMFLY03_IPV4, TTL("10m")),
477   AAAA("prometheus", STORMFLY03_IPV6, TTL("10m")),
478   A("stormfly-03.oob", STORMFLY03_OOB),
479
480   // Chef server
481
482   A("sarel", SAREL_IPV4),
483   A("chef", SAREL_IPV4),
484   A("hardware", SAREL_IPV4),
485   A("acme", SAREL_IPV4),
486   A("git", SAREL_IPV4, TTL("10m")),
487   A("dns", SAREL_IPV4, TTL("10m")),
488   A("sarel.ucl", SAREL_INTERNAL),
489   A("sarel.oob", SAREL_OOB),
490
491   // Forum server
492
493   A("clifford", CLIFFORD_IPV4),
494   A("forum", CLIFFORD_IPV4, TTL("10m")),
495   A("clifford.ucl", CLIFFORD_INTERNAL),
496   A("clifford.oob", CLIFFORD_OOB),
497
498   // Discourse server ("community")
499
500   A("lockheed", LOCKHEED_IPV4),
501   AAAA("lockheed", LOCKHEED_IPV6),
502   A("community", LOCKHEED_IPV4),
503   AAAA("community", LOCKHEED_IPV6),
504   A("lockheed.ams", LOCKHEED_INTERNAL),
505   A("lockheed.oob", LOCKHEED_OOB),
506
507   // KVMs
508
509   A("kvm1.ucl", KVM1_INTERNAL),
510
511   // Managed network switches
512
513   A("switch1.ams", SWITCH1AMS_IPV4),
514   AAAA("switch1.ams", SWITCH1AMS_IPV6),
515
516   A("switch1.dub", SWITCH1DUB_IPV4),
517   AAAA("switch1.dub", SWITCH1DUB_IPV6),
518
519   // Managed power strips
520
521   A("pdu1.ams", PDU1AMS_INTERNAL),
522   A("pdu2.ams", PDU2AMS_INTERNAL),
523
524   A("pdu1.dub", PDU1DUB_INTERNAL),
525   A("pdu2.dub", PDU2DUB_INTERNAL),
526
527   // Out of band access servers
528
529   A("oob1.dub", OOB1DUB_INTERNAL),
530
531   // Bytemark machine, and the services which operate from it
532
533   A("shenron", SHENRON_IPV4),
534   AAAA("shenron", SHENRON_IPV6),
535   A("mail", SHENRON_IPV4),
536   AAAA("mail", SHENRON_IPV6),
537   A("mta-sts", SHENRON_IPV4),
538   AAAA("mta-sts", SHENRON_IPV6),
539   A("lists", SHENRON_IPV4),
540   AAAA("lists", SHENRON_IPV6),
541   A("svn", SHENRON_IPV4),
542   AAAA("svn", SHENRON_IPV6),
543   A("trac", SHENRON_IPV4),
544   AAAA("trac", SHENRON_IPV6),
545   A("irc", SHENRON_IPV4),
546   AAAA("irc", SHENRON_IPV6),
547   A("help", SHENRON_IPV4),
548   AAAA("help", SHENRON_IPV6),
549   A("blogs", SHENRON_IPV4, TTL("10m")),
550   AAAA("blogs", SHENRON_IPV6, TTL("10m")),
551   A("shenron.bm", SHENRON_INTERNAL),
552
553   // Wiki servers
554
555   A("tabaluga", TABALUGA_IPV4),
556   AAAA("tabaluga", TABALUGA_IPV6),
557   A("wiki", TABALUGA_IPV4, TTL("10m")),
558   AAAA("wiki", TABALUGA_IPV6, TTL("10m")),
559   A("tabaluga.ams", TABALUGA_INTERNAL),
560   A("tabaluga.oob", TABALUGA_OOB),
561
562   // Overpass server
563
564   A("gorwen", GORWEN_IPV4),
565   AAAA("gorwen", GORWEN_IPV6),
566   A("query", GORWEN_IPV4, TTL("10m")),
567   AAAA("query", GORWEN_IPV6, TTL("10m")),
568   A("gorwen.dub", GORWEN_INTERNAL),
569   A("gorwen.oob", GORWEN_OOB),
570
571   // GPS tile server
572
573   A("noquiklos", NOQUIKLOS_IPV4),
574   A("gps-tile", NOQUIKLOS_IPV4),
575   A("a.gps-tile", NOQUIKLOS_IPV4),
576   A("b.gps-tile", NOQUIKLOS_IPV4),
577   A("c.gps-tile", NOQUIKLOS_IPV4),
578   A("gps.tile", NOQUIKLOS_IPV4),
579   A("gps-a.tile", NOQUIKLOS_IPV4),
580   A("gps-b.tile", NOQUIKLOS_IPV4),
581   A("gps-c.tile", NOQUIKLOS_IPV4),
582   A("noquiklos.ucl", NOQUIKLOS_INTERNAL),
583   A("noquiklos.oob", NOQUIKLOS_OOB),
584
585   // Tile cache servers
586
587   A("gorynych", GORYNYCH_IPV4),
588   AAAA("gorynych", GORYNYCH_IPV6),
589   A("trogdor", TROGDOR_IPV4),
590   A("trogdor.oob", TROGDOR_OOB),
591   A("ridgeback", RIDGEBACK_IPV4),
592   A("ridgeback.oob", RIDGEBACK_OOB),
593   A("nepomuk", NEPOMUK_IPV4),
594   AAAA("nepomuk", NEPOMUK_IPV6),
595   A("viserion", VISERION_IPV4),
596   AAAA("viserion", VISERION_IPV6),
597   A("drogon", DROGON_IPV4),
598   AAAA("drogon", DROGON_IPV6),
599   A("saphira", SAPHIRA_IPV4),
600   AAAA("saphira", SAPHIRA_IPV6),
601   A("toothless", TOOTHLESS_IPV4),
602   AAAA("toothless", TOOTHLESS_IPV6),
603   A("angor", ANGOR_IPV4),
604   // AAAA("angor", ANGOR_IPV6),
605   A("ladon", LADON_IPV4),
606   AAAA("ladon", LADON_IPV6),
607   A("ascalon", ASCALON_IPV4),
608   A("takhisis", TAKHISIS_IPV4),
609   AAAA("takhisis", TAKHISIS_IPV6),
610   A("neak", NEAK_IPV4),
611   A("meraxes", MERAXES_IPV4),
612   AAAA("meraxes", MERAXES_IPV6),
613   A("firnen", FIRNEN_IPV4),
614
615   // Blades
616
617   A("tiamat-00", TIAMAT00_IPV4),
618   A("tiamat-00.ucl", TIAMAT00_INTERNAL),
619   A("tiamat-00.oob", TIAMAT00_OOB),
620   A("tiamat-01", TIAMAT01_IPV4),
621   A("tiamat-01.ucl", TIAMAT01_INTERNAL),
622   A("tiamat-01.oob", TIAMAT01_OOB),
623   A("tiamat-02", TIAMAT02_IPV4),
624   A("tiamat-02.ucl", TIAMAT02_INTERNAL),
625   A("tiamat-02.oob", TIAMAT02_OOB),
626   A("tiamat-03", TIAMAT03_IPV4),
627   A("tiamat-03.ucl", TIAMAT03_INTERNAL),
628   A("tiamat-03.oob", TIAMAT03_OOB),
629   A("tiamat-10", TIAMAT10_IPV4),
630   A("tiamat-10.ucl", TIAMAT10_INTERNAL),
631   A("tiamat-10.oob", TIAMAT10_OOB),
632   A("tiamat-11", TIAMAT11_IPV4),
633   A("tiamat-11.ucl", TIAMAT11_INTERNAL),
634   A("tiamat-11.oob", TIAMAT11_OOB),
635   A("tiamat-12", TIAMAT12_IPV4),
636   A("tiamat-12.ucl", TIAMAT12_INTERNAL),
637   A("tiamat-12.oob", TIAMAT12_OOB),
638   A("tiamat-13", TIAMAT13_IPV4),
639   A("tiamat-13.ucl", TIAMAT13_INTERNAL),
640   A("tiamat-13.oob", TIAMAT13_OOB),
641   A("tiamat-20", TIAMAT20_IPV4),
642   A("tiamat-20.ucl", TIAMAT20_INTERNAL),
643   A("tiamat-20.oob", TIAMAT20_OOB),
644   A("tiamat-21", TIAMAT21_IPV4),
645   A("tiamat-21.ucl", TIAMAT21_INTERNAL),
646   A("tiamat-21.oob", TIAMAT21_OOB),
647   A("tiamat-22", TIAMAT22_IPV4),
648   A("tiamat-22.ucl", TIAMAT22_INTERNAL),
649   A("tiamat-22.oob", TIAMAT22_OOB),
650   A("tiamat-23", TIAMAT23_IPV4),
651   A("tiamat-23.ucl", TIAMAT23_INTERNAL),
652   A("tiamat-23.oob", TIAMAT23_OOB),
653
654   // Spare
655
656   A("idris", IDRIS_IPV4),
657   AAAA("idris", IDRIS_IPV6),
658   A("idris.dub", IDRIS_INTERNAL),
659   A("idris.oob", IDRIS_OOB),
660   A("konqi", KONQI_IPV4),
661   AAAA("konqi", KONQI_IPV6),
662   A("konqi.dub", KONQI_INTERNAL),
663   A("konqi.oob", KONQI_OOB),
664   A("naga", NAGA_IPV4),
665   AAAA("naga", NAGA_IPV6),
666   A("naga.dub", NAGA_INTERNAL),
667   A("naga.oob", NAGA_OOB),
668   A("jakelong", JAKELONG_IPV4),
669   AAAA("jakelong", JAKELONG_IPV6),
670   A("jakelong.dub", JAKELONG_INTERNAL),
671   A("jakelong.oob", JAKELONG_OOB),
672
673   // Donation site
674
675   A("donate", RIDLEY_IPV4),
676
677   // Uptime site at StatusCake
678
679   CNAME("uptime", "uptimessl-new.statuscake.com."),
680
681   // Custom Domain for https://github.com/osmfoundation/welcome-mat/
682
683   CNAME("welcome", "osmfoundation.github.io."),
684
685   // Dynamic DNS records
686
687   DYNAMIC_RECORDS
688
689 );