summaryrefslogtreecommitdiff
path: root/manifests/zone.pp
blob: 68295695d6a530fd75e13b2da4f0fb8b25ba35f0 (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
/*

= 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,
    }
  }
}