summaryrefslogtreecommitdiff
path: root/manifests/dns_zones.pp
blob: af11729c54603c4f545654eab04a5f5699bdf8d5 (plain)
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
49
50
51
52
53
54
55
56
57
# Sets up our dns-server, assumes that all zone information comes from
# hiera.
class profiles::dns_zones (
  Hash $zones,
  Hash $default = {},
  Optional[Hash] $views = undef,
  Hash $view_defaults = {},
  String $default_view = '_GLOBAL_',
) {

  if $views != undef {
    class { 'dns':
      enable_views => true,
    }
    create_resources(dns::view, $views, $view_defaults)
  }

  create_resources(dns::zone, $zones, $default)

  [$_, $rev_zone] = dns_record::rev_record(
    $facts['networking']['ip6'],
    $facts['networking']['netmask6'])

  dns::zone { $rev_zone:
    reverse      => true,
    target_views => [
      $default_view,
    ],
  }

  dns_zone { $rev_zone:
  }

  Dns_record <<| zone == 'adrift.space' |>>
  Dns_record <<| zone == $rev_zone |>>

  $zone_hash = Hash(lookup('dns_zones."adrift.space"').map |$d| {
    ["adrift.space ${d['type']} ${d['key']} ${d['value']}", $d]
  })

  create_resources(dns_record, $zone_hash, {
    # 'ensure' => 'present',
    'zone'     => 'adrift.space',
    # 'notify'   => Dns_zone['adrift.space'],
    })

  dns_zone { 'adrift.space':
    # default_ttl  => '300',
    primary      => 'ns1.adrift.space.',
    # email        => 'domainmaster.adrift.space.',
    # serial       => $facts['zones']['adrift.space']['serial'] + 1,
    soa_refresh      => '2w',
    # retry        => '1d',
    # expire       => '1000h',
    # negative_ttl => '300',
  }
}