X-Git-Url: https://git.distorted.org.uk/~mdw/zones/blobdiff_plain/8dcb37002e1a38b33e38c71001ef74e0163852f9..f54dd5ce2ae0a3a39ab6520ea898a6a62a280ad8:/Makefile diff --git a/Makefile b/Makefile index eda4119..69191ed 100644 --- a/Makefile +++ b/Makefile @@ -25,7 +25,6 @@ CHECKZONE = named-checkzone -i full \ MASTER = localhost inside_MASTER = precision - ifeq ($(MASTER),localhost) ZONEINST = userv zoneconf install else @@ -67,20 +66,22 @@ distorted_outside_NETS = dmz jump distorted_inside_NETS = any unsafe colo vpn distorted_all_ZONES += distorted.org.uk + +distorted_all_ZONES += 144-159.204.49.62.in-addr.arpa +distorted_all_ZONES += 64-79.198.13.212.in-addr.arpa + distorted_all_ZONES += 199.29.172.in-addr.arpa -###-------------------------------------------------------------------------- -### Other zones. +distorted_all_ZONES += 8.9.b.1.9.0.f.1.0.7.4.0.1.0.0.2.ip6.arpa +distorted_all_ZONES += 0.4.7.9.0.7.4.0.1.0.0.2.ip6.arpa + +distorted_all_ZONES += 9.d.1.0.0.0.0.0.8.a.b.0.1.0.0.2.ip6.arpa +distorted_all_ZONES += 9.d.1.0.8.a.b.0.1.0.0.2.ip6.arpa -## harlequin.org.uk -ZONESETS += harlequin -harlequin_VIEWS = outside -harlequin_all_ZONES = harlequin.org.uk +distorted_outside_NSDIFF = -sradius.dmz.distorted.org.uk -## felixpearce.com -ZONESETS += felixpearce -felixpearce_VIEWS = outside -felixpearce_all_ZONES = felixpearce.com +###-------------------------------------------------------------------------- +### Other zones. ## binswood.org.uk ZONESETS += binswood @@ -88,6 +89,21 @@ binswood_VIEWS = outside binswood_all_ZONES += binswood.org.uk binswood_all_ZONES += 27.165.10.in-addr.arpa +## escorted.org.uk +ZONESETS += escorted +escorted_VIEWS = outside +escorted_all_ZONES += escorted.org.uk + +## odin.gg +ZONESETS += odin +odin_VIEWS = outside +odin_all_ZONES = odin.gg + +## goodhstg.com +ZONESETS += goodhstg +goodhstg_VIEWS = outside +goodhstg_all_ZONES = goodhstg.com + ###-------------------------------------------------------------------------- ### Zone construction machinery. @@ -122,6 +138,12 @@ $(foreach s,$(ZONESETS), \ $(foreach z,$($s_all_ZONES) $($s_$v_ZONES), \ $(eval $v/$z.zone: $v/$s.zonestamp)))) +## Prepare a mapping from zone names back to their owning zonesets. +$(foreach s,$(ZONESETS), \ + $(foreach z,$(sort $(foreach v,$($s_VIEWS), \ + $($s_all_ZONES) $($s_$v_ZONES))), \ + $(eval $z_ZONESET = $s))) + ## Now we have to check the individual zone files. ALL_ZONECHECKS = $(foreach s,$(ZONESETS), \ $(foreach v,$($s_VIEWS), \ @@ -134,6 +156,21 @@ $(ALL_ZONECHECKS) : %.check : %.zone check: $(ALL_ZONECHECKS) .PHONY: check $(ALL_ZONECHECKS) +## If nsdiff(1) is available then we can show what changes we will make if +## we install the new zone files. +ALL_ZONEDIFFS = $(foreach s,$(ZONESETS), \ + $(foreach v,$($s_VIEWS), \ + $(foreach z,$($s_all_ZONES) $($s_$v_ZONES), \ + $v/$z.zonediff))) +run-nsdiff = nsdiff -d -v "" $2 \ + $($($(call notdir,$1)_ZONESET)_$(call dir-nosl,$1)_NSDIFF) \ + $(call notdir,$1) $1.zone +$(ALL_ZONEDIFFS) : %.zonediff : %.zone + $(call v_tag,NSDIFF)$(call run-nsdiff,$*,-q); \ + rc=$$?; case $$rc in 1) $(call run-nsdiff,$*); rc=$$? ;; esac; \ + case $$rc in 0 | 1) : ;; *) exit $$? ;; esac +diff: $(ALL_ZONEDIFFS) + ## Finally we have to install the zone files. ALL_INSTALLS = $(foreach s,$(ZONESETS), \ $(foreach v,$($s_VIEWS), \