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

= 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)

*/
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) {

  common::concatfilepart {"bind.zones.${name}":
    ensure  => $ensure,
    notify  => Service["bind9"],
    file    => "/etc/bind/zones/${name}.conf",
    require => Package["bind9"],
  }

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

  if $is_slave {
    if !$zone_masters {
      fail "No master defined for ${name}!"
    }
    Common::Concatfilepart["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}!"
    }

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

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

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