1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
# File 'modules/profile/manifests/openstack/eqiad1/pdns/recursor/service.pp', line 1
class profile::openstack::eqiad1::pdns::recursor::service(
Array[Stdlib::Fqdn] $designate_hosts = lookup('profile::openstack::eqiad1::designate_hosts'),
Array[Stdlib::Fqdn] $pdns_hosts = lookup('profile::openstack::eqiad1::pdns::hosts'),
Stdlib::Fqdn $recursor_service_name = lookup('profile::openstack::eqiad1::pdns::recursor_service_name'),
Stdlib::Fqdn $keystone_api_fqdn = lookup('profile::openstack::eqiad1::keystone_api_fqdn'),
$observer_password = lookup('profile::openstack::eqiad1::observer_password'),
$tld = lookup('profile::openstack::eqiad1::pdns::tld'),
$legacy_tld = lookup('profile::openstack::eqiad1::pdns::legacy_tld'),
$private_reverse_zones = lookup('profile::openstack::eqiad1::pdns::private_reverse_zones'),
$aliaser_extra_records = lookup('profile::openstack::eqiad1::pdns::recursor_aliaser_extra_records'),
Array[Stdlib::IP::Address] $extra_allow_from = lookup('profile::openstack::eqiad1::pdns::extra_allow_from', {default_value => []}),
Array[Stdlib::Fqdn] $controllers = lookup('profile::openstack::eqiad1::openstack_controllers', {default_value => []}),
Array[Stdlib::Fqdn] $prometheus_nodes = lookup('prometheus_nodes'),
) {
# This iterates on $hosts and returns the entry in $hosts with the same
# ipv4 as $::fqdn
$service_pdns_host = $pdns_hosts.reduce(false) |$memo, $service_host_fqdn| {
if (ipresolve($::fqdn,4) == ipresolve($service_host_fqdn,4)) {
$service_host_fqdn
} else {
$memo
}
}
# for now only prometheus metrics are needed.. maybe something else in the future?
$api_allow_hosts = $prometheus_nodes
class {'::profile::openstack::base::pdns::recursor::service':
keystone_api_fqdn => $keystone_api_fqdn,
observer_password => $observer_password,
pdns_host => $service_pdns_host,
pdns_recursor => $recursor_service_name,
tld => $tld,
legacy_tld => $legacy_tld,
private_reverse_zones => $private_reverse_zones,
aliaser_extra_records => $aliaser_extra_records,
extra_allow_from => $extra_allow_from,
controllers => $controllers,
pdns_api_allow_from => flatten([
'127.0.0.1',
$api_allow_hosts.map |Stdlib::Fqdn $host| { ipresolve($host, 4) },
$api_allow_hosts.map |Stdlib::Fqdn $host| { ipresolve($host, 6) }
]),
}
class{'::profile::openstack::base::pdns::recursor::monitor::rec_control':}
}
|