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