summaryrefslogtreecommitdiff
path: root/manifests/zone.pp
blob: eb07746d29a625e5ebf5b86f0279c71885284234 (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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
# = Definition: bind::zone
#
# Creates a valid Bind9 zone.
#
# Arguments:
#  *$is_slave*: Boolean. Is your zone a slave or a master? Default false
#  *$zone_ttl*: Time period. Time to live for your zonefile (master only)
#  *$zone_contact*: Valid contact record (master only)
#  *$zone_serial*: Integer. Zone serial (master only)
#  *$zone_refresh*: Time period. Time between each slave refresh (master only)
#  *$zone_retry*: Time period. Time between each slave retry (master only)
#  *$zone_expiracy*: Time period. Slave expiracy time (master only)
#  *$zone_ns*: Valid NS for this zone (master only)
#  *$zone_xfers*: IPs. Valid xfers for zone (master only)
#  *$zone_masters*: IPs. Valid master for this zone (slave only)
#  *$zone_origin*: The origin of the zone
#
define bind::zone (
  $ensure        = present,
  $is_slave      = false,
  $zone_ttl      = false,
  $zone_contact  = false,
  $zone_serial   = false,
  $zone_refresh  = '3h',
  $zone_retry    = '1h',
  $zone_expiracy = '1w',
  $zone_ns       = false,
  $zone_xfers    = false,
  $zone_masters  = false,
  $zone_origin   = false
) {

  concat {"/etc/bind/pri/${name}.conf":
    owner => root,
    group => root,
    mode  => '0644',
  }

  concat {"/etc/bind/zones/${name}.conf":
    owner => root,
    group => root,
    mode  => '0644',
  }

  concat::fragment {"bind.zones.${name}":
    ensure  => $ensure,
    target  => "/etc/bind/zones/${name}.conf",
    notify  => Service['bind9'],
    require => Package['bind9'],
  }

  concat::fragment {"named.local.zone.${name}":
    ensure  => $ensure,
    target  => '/etc/bind/named.conf.local',
    content => "include \"/etc/bind/zones/${name}.conf\";\n",
    notify  => Service['bind9'],
    require => Package['bind9'],
  }

  if $is_slave {
    if !$zone_masters {
      fail "No master defined for ${name}!"
    }
    Concat::Fragment["bind.zones.${name}"] {
      content => template('bind/zone-slave.erb'),
    }
## END of slave
  } else {
    if !$zone_contact {
      fail "No contact defined for ${name}!"
    }
    if !$zone_ns {
      fail "No ns defined for ${name}!"
    }
    if !$zone_serial {
      fail "No serial defined for ${name}!"
    }
    if !$zone_ttl {
      fail "No ttl defined for ${name}!"
    }

    Concat::Fragment["bind.zones.${name}"] {
      content => template('bind/zone-master.erb'),
    }

    concat::fragment {"00.bind.${name}":
      ensure  => $ensure,
      target  => "/etc/bind/pri/${name}.conf",
      content => template('bind/zone-header.erb'),
      require => Package['bind9'],
    }

    file {"/etc/bind/pri/${name}.conf.d":
      ensure  => absent,
      mode    => '0700',
      purge   => true,
      recurse => true,
      backup  => false,
      force   => true,
    }
  }

}