X-Git-Url: https://git.distorted.org.uk/~mdw/zoneconf/blobdiff_plain/5860c677e943ea2cdc935d725c90e5a3b0a63c8c..e4ce9d1ee876952c2c339a84ad658caff954a95e:/zoneconf.in diff --git a/zoneconf.in b/zoneconf.in index 7af2845..4a6713f 100755 --- a/zoneconf.in +++ b/zoneconf.in @@ -1022,6 +1022,12 @@ define-configuration-space zone ZONECFG { } define primary {map} { + ## There's a grim hack here: a primary-address entry may have the form + ## REAL!FAKE. If the REAL address is not a local address then this + ## is used as the master address; otherwise the FAKE address is used. + ## This is useful for inter-view updates of dynamic zones on the same + ## host. I suggest abusing 127.0.0.0/8 addresses for this kind of + ## chicanery. if {[llength $map] % 2} { error "master map must have an even number of items" } @@ -1141,13 +1147,24 @@ proc compute-zone-properties {view config} { if {[info exists zone(mapped-view)]} { foreach {outview hosts} $zone(master-map) { if {[string match $outview $zone(mapped-view)]} { - set zone(masters) $hosts + set masters {} set zone(config-type) slave foreach host $hosts { - if {[local-address-p $host]} { + set bang [string first "!" $host] + if {$bang >= 0} { + set before [string range $host 0 [expr {$bang - 1}]] + set after [string range $host [expr {$bang + 1}] end] + if {[local-address-p $before]} { + set host $after + } else { + set host $before + } + } elseif {[local-address-p $host]} { set zone(config-type) master } + lappend masters $host } + set zone(masters) $masters break } }