aboutsummaryrefslogtreecommitdiff
path: root/manifests/server/share.pp
blob: d9eb331e2ebde67744edbc202840ce7893e5e7ce (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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
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 = '',
                            $valid_users = '',
                            ) {
                              
  $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']
    }

    augeas { "${name}-valid_users":
      context => $context,
      changes => $printable ? {
        default => "set ${target}/valid users '${valid_users}'",
        ''      => "rm ${target}/valid users",
      },
      require => Augeas["${name}-section"],
      notify  => Class['samba::server::service']
    }
  }
}