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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
define samba::server::share($ensure = present,
$browsable = '',
$comment = '',
$copy = '',
$create_mask = '',
$directory_mask = '',
$force_create_mask = '',
$force_directory_mask = '',
$force_group = '',
$force_user = '',
$guest_account = '',
$guest_ok = '',
$guest_only = '',
$path = '',
$read_only = '',
$public = '',
$writable = '',
$printable = '') {
$incl = $samba::server::incl
$context = $samba::server::context
$target = "target[. = '${name}']"
augeas { "${name}-section":
incl => $incl,
lens => 'Samba.lns',
context => $context,
changes => $ensure ? {
present => "set ${target} '${name}'",
default => "rm ${target} '${name}'",
},
require => Class['samba::server::config'],
notify => Class['samba::server::service']
}
if $ensure == 'present' {
$changes = [
$browsable ? {
true => "set \"${target}/browsable\" yes",
false => "set \"${target}/browsable\" no",
default => "rm \"${target}/browsable\"",
},
$comment ? {
default => "set \"${target}/comment\" '${comment}'",
'' => "rm \"${target}/comment\"",
},
$copy ? {
default => "set \"${target}/copy\" '${copy}'",
'' => "rm \"${target}/copy\"",
},
$create_mask ? {
default => "set \"${target}/create mask\" '${create_mask}'",
'' => "rm \"${target}/create mask\"",
},
$directory_mask ? {
default => "set \"${target}/directory mask\" '${directory_mask}'",
'' => "rm \"${target}/directory mask\"",
},
$force_create_mask ? {
default => "set \"${target}/force create mask\" '${force_create_mask}'",
'' => "rm \"${target}/force create mask\"",
},
$force_directory_mask ? {
default => "set \"${target}/force directory mask\" '${force_directory_mask}'",
'' => "rm \"${target}/force directory mask\"",
},
$force_group ? {
default => "set \"${target}/force group\" '${force_group}'",
'' => "rm \"${target}/force group\"",
},
$force_user ? {
default => "set \"${target}/force user\" '${force_user}'",
'' => "rm \"${target}/force user\"",
},
$guest_account ? {
default => "set \"${target}/guest account\" '${guest_account}'",
'' => "rm \"${target}/guest account\"",
},
$guest_ok ? {
true => "set \"${target}/guest ok\" yes",
false => "set \"${target}/guest ok\" no",
default => "rm \"${target}/guest ok\"",
},
$guest_only ? {
true => "set \"${target}/guest only\" yes",
false => "set \"${target}/guest only\" no",
default => "rm \"${target}/guest only\"",
},
$path ? {
default => "set ${target}/path '${path}'",
'' => "rm ${target}/path",
},
$read_only ? {
true => "set \"${target}/read only\" yes",
false => "set \"${target}/read only\" no",
default => "rm \"${target}/read_only\"",
},
$public ? {
true => "set \"${target}/public\" yes",
false => "set \"${target}/public\" no",
default => "rm \"${target}/public\"",
},
$writable ? {
true => "set \"${target}/writable\" yes",
false => "set \"${target}/writable\" no",
default => "rm \"${target}/writable\"",
},
$printable ? {
true => "set \"${target}/printable\" yes",
false => "set \"${target}/printable\" no",
default => "rm \"${target}/printable\"",
},
]
augeas { "${name}-changes":
incl => $incl,
lens => 'Samba.lns',
context => $context,
changes => $changes,
require => Augeas["${name}-section"],
notify => Class['samba::server::service']
}
}
}
|