chiark / gitweb /
distorted.lisp: Include nameservers in dhcp subzone.
[zones] / Makefile
CommitLineData
5c420db9
MW
1### -*-makefile-*-
2###
3### Makefile for the DNS zones I maintain.
4###
5### (c) 2011 Mark Wooding
6
7###--------------------------------------------------------------------------
8### Silent-rules machinery.
9
10V = 0
11v_tag = $(call v_tag_$V,$1)
12v_tag_0 = @printf " %-6s %s\n" "$1" "$@";
13
14V_AT = $(V_AT_$V)
15V_AT_0 = @
16
17###--------------------------------------------------------------------------
18### Programs and options.
19
d7af5ae7 20## Zone checking.
5c420db9
MW
21CHECKZONE = named-checkzone -i full \
22 -k fail -M fail -n fail -S fail -W fail
23
d7af5ae7
MW
24## Zone installation.
25MASTER = localhost
38c2de7c
MW
26inside_MASTER = precision
27
d7af5ae7
MW
28ifeq ($(MASTER),localhost)
29ZONEINST = userv zoneconf install
30else
31ZONEINST = ssh zoneconf@$(MASTER)
32endif
33
5c420db9
MW
34###--------------------------------------------------------------------------
35### Utility functions.
36
37dir-nosl = $(patsubst %/,%,$(dir $1))
38
39###--------------------------------------------------------------------------
40### Keeping all of the files straight.
41
42## Establish a default target. We'll sort out what it does later.
43all:
44.PHONY: all
45
46## Things to clean.
47CLEANFILES =
48CLEANDIRS =
49REALCLEANFILES = $(CLEANFILES)
50REALCLEANDIRS = $(CLEANDIRS)
51
52## We work in terms of `zonesets'. Each one corresponds to a Lisp source
53## file to be passed to `zone'. A zoneset has a number of different nets
54## associated with it, in the variable zoneset_NETS, and we must run it
55## through `zone' once for each net. The zoneset will make a number of
56## zones, listed in zoneset_ZONES.
57ZONESETS =
58
59###--------------------------------------------------------------------------
60### The distorted.org.uk zones.
61
62ZONESETS += distorted
63
4a487d58 64distorted_VIEWS = inside outside
38c2de7c 65distorted_outside_NETS = dmz jump
2d396faa 66distorted_inside_NETS = any unsafe colo vpn
5c420db9 67
b420e5ee 68distorted_all_ZONES += distorted.org.uk
652c34be 69
b29264c5
MW
70distorted_all_ZONES += 144-159.204.49.62.in-addr.arpa
71distorted_all_ZONES += 64-79.198.13.212.in-addr.arpa
72
74180153 73distorted_all_ZONES += 199.29.172.in-addr.arpa
5c420db9 74
652c34be
MW
75distorted_all_ZONES += 8.9.b.1.9.0.f.1.0.7.4.0.1.0.0.2.ip6.arpa
76distorted_all_ZONES += 0.4.7.9.0.7.4.0.1.0.0.2.ip6.arpa
77
78distorted_all_ZONES += 9.d.1.0.0.0.0.0.8.a.b.0.1.0.0.2.ip6.arpa
79distorted_all_ZONES += 9.d.1.0.8.a.b.0.1.0.0.2.ip6.arpa
80
f54dd5ce
MW
81distorted_outside_NSDIFF = -sradius.dmz.distorted.org.uk
82
5c420db9 83###--------------------------------------------------------------------------
61097cd6 84### Other zones.
5c420db9 85
8dcb3700
MW
86## binswood.org.uk
87ZONESETS += binswood
88binswood_VIEWS = outside
89binswood_all_ZONES += binswood.org.uk
90binswood_all_ZONES += 27.165.10.in-addr.arpa
91
3a772cfb
MW
92## escorted.org.uk
93ZONESETS += escorted
94escorted_VIEWS = outside
95escorted_all_ZONES += escorted.org.uk
96
0885bc47
MW
97## odin.gg
98ZONESETS += odin
99odin_VIEWS = outside
100odin_all_ZONES = odin.gg
101
6fc6709b
MW
102## goodhstg.com
103ZONESETS += goodhstg
104goodhstg_VIEWS = outside
105goodhstg_all_ZONES = goodhstg.com
106
39c01832 107###--------------------------------------------------------------------------
5c420db9
MW
108### Zone construction machinery.
109
110ZONE = zone
111V_ZONE = $(call v_tag,ZONE)$(ZONE)
112
113.SECONDEXPANSION: #sorry
114
115## For each net/zoneset pair, we make a stamp file net/zoneset.stamp to
116## remember that we've made the corresponding zones.
117ALL_ZONESTAMPS = $(foreach s,$(ZONESETS), \
118 $(patsubst %,%/$s.zonestamp,$($s_VIEWS)))
119$(ALL_ZONESTAMPS) : %.zonestamp : $$(notdir $$*).lisp hosts.lisp
120 $(V_AT)mkdir -p $(dir $*)
121 $(V_ZONE) -d$(dir $*) -fview/$(call dir-nosl,$*)$(hack \
d7af5ae7
MW
122 hack) $(addprefix -s, \
123 $($(notdir $*)_$(call dir-nosl,$*)_NETS)) $<
5c420db9
MW
124 $(V_AT)touch $@
125all: $(ALL_ZONESTAMPS)
126CLEANFILES += $(sort $(foreach s,$(ZONESETS), \
127 $(foreach v,$($s_VIEWS), \
128 $v/*.zonestamp $v/*.zone)))
129REALCLEANFILES += $(sort $(foreach s,$(ZONESETS), \
130 $(foreach v,$($s_VIEWS), \
131 $v/*.serial)))
132REALCLEANDIRS += $(sort $(foreach s,$(ZONESETS),$($s_VIEWS)))
133
134## Now explain that each generated zone file depends on the corresponding
135## zonestamp. This is where things start getting a little hairy.
136$(foreach s,$(ZONESETS), \
137 $(foreach v,$($s_VIEWS), \
138 $(foreach z,$($s_all_ZONES) $($s_$v_ZONES), \
139 $(eval $v/$z.zone: $v/$s.zonestamp))))
140
f54dd5ce
MW
141## Prepare a mapping from zone names back to their owning zonesets.
142$(foreach s,$(ZONESETS), \
143 $(foreach z,$(sort $(foreach v,$($s_VIEWS), \
144 $($s_all_ZONES) $($s_$v_ZONES))), \
145 $(eval $z_ZONESET = $s)))
146
5c420db9
MW
147## Now we have to check the individual zone files.
148ALL_ZONECHECKS = $(foreach s,$(ZONESETS), \
149 $(foreach v,$($s_VIEWS), \
150 $(foreach z,$($s_all_ZONES) $($s_$v_ZONES), \
151 $v/$z.check)))
152$(ALL_ZONECHECKS) : %.check : %.zone
153 $(call v_tag,CHECK)\
154 { $(CHECKZONE) $(notdir $*) $^ || kill $$$$; } | \
155 { grep -Ev 'loaded serial|OK' || :; }
156check: $(ALL_ZONECHECKS)
157.PHONY: check $(ALL_ZONECHECKS)
158
f54dd5ce
MW
159## If nsdiff(1) is available then we can show what changes we will make if
160## we install the new zone files.
161ALL_ZONEDIFFS = $(foreach s,$(ZONESETS), \
162 $(foreach v,$($s_VIEWS), \
163 $(foreach z,$($s_all_ZONES) $($s_$v_ZONES), \
164 $v/$z.zonediff)))
3f954bac 165run-nsdiff = nsdiff -v "" $2 \
f54dd5ce
MW
166 $($($(call notdir,$1)_ZONESET)_$(call dir-nosl,$1)_NSDIFF) \
167 $(call notdir,$1) $1.zone
168$(ALL_ZONEDIFFS) : %.zonediff : %.zone
169 $(call v_tag,NSDIFF)$(call run-nsdiff,$*,-q); \
170 rc=$$?; case $$rc in 1) $(call run-nsdiff,$*); rc=$$? ;; esac; \
23ca64ab 171 case $$rc in 0 | 1) : ;; *) exit $$rc ;; esac
f54dd5ce
MW
172diff: $(ALL_ZONEDIFFS)
173
d7af5ae7
MW
174## Finally we have to install the zone files.
175ALL_INSTALLS = $(foreach s,$(ZONESETS), \
176 $(foreach v,$($s_VIEWS), \
177 $(foreach z,$($s_all_ZONES) $($s_$v_ZONES), \
178 $v/$z.inst)))
179$(ALL_INSTALLS) : %.inst : %.check
180 $(call v_tag,INST)$(ZONEINST) \
181 $(call dir-nosl,$*) $(notdir $*) <$*.zone
182install: $(ALL_INSTALLS)
183.PHONY: install $(ALL_INSTALLS)
184
5c420db9
MW
185## Files to clean.
186clean:
187 rm -f $(CLEANFILES)
188 [ "$(CLEANDIRS)x" = x ] || rmdir $(CLEANDIRS) || :
189realclean:
190 rm -f $(REALCLEANFILES)
191 [ "$(REALCLEANDIRS)x" = x ] || rmdir $(REALCLEANDIRS) || :
192.PHONY: clean realclean
193
194###----- That's all, folks --------------------------------------------------