Pull listen addresses for apache mirrors from hiera
authorTollef Fog Heen <tfheen@err.no>
Thu, 1 Feb 2018 18:27:21 +0000 (19:27 +0100)
committerTollef Fog Heen <tfheen@err.no>
Thu, 1 Feb 2018 18:28:29 +0000 (19:28 +0100)
This is slightly crazy with a bit of transitional logic.

hieradata/common.yaml
modules/roles/manifests/debian_mirror.pp

index abb603f..6b13e5e 100644 (file)
@@ -243,6 +243,9 @@ roles:
     - klecker.debian.org
     - mirror-bytemark.debian.org:
         service-hostname: bytemark.debian.backend.mirrors.debian.org
+        listen-addresses:
+          - '5.153.231.45:80'
+          - '[2001:41c8:1000:21::21:45]:80'
         fastly-backend: true
     - mirror-accumu.debian.org:
         service-hostname: accumu.debian.backend.mirrors.debian.org
index e790c88..549e982 100644 (file)
@@ -7,10 +7,12 @@ class roles::debian_mirror {
        $vhost_listen = join([
                $::hostname ? {
                        klecker    => '130.89.148.12:80 127.0.0.1:80 [2001:610:1908:b000::148:12]:80 [2001:67c:2564:a119::148:12]:80 [::1]:80',
-                       mirror-bytemark => '5.153.231.45:80 127.0.0.1:80 [2001:41c8:1000:21::21:45]:80 [::1]:80',
                        mirror-isc => '149.20.4.15:80 127.0.0.1:80 [2001:4f8:1:c::15]:80 [::1]:80',
                        mirror-conova => '217.196.149.232:80 127.0.0.1:80 [2a02:16a8:dc41:100::232]:80 [::1]:80',
-                       default => '*:80',
+                       default => hiera("roles.debian_mirror.${::hostname}.listen-addresses", 'missing') ? {
+                               'missing' => '*:80',
+                               default => join([hiera("roles.debian_mirror.${::hostname}.listen-addresses"), '127.0.0.1:80', '[::1]:80'])
+                       }
                },
                has_role('bgp') ? {
                        true => '193.31.7.2:80 [2a02:158:ffff:deb::2]:80',