]> git.donarmstrong.com Git - dsa-puppet.git/blob - modules/vsftpd/manifests/site.pp
e1cfbe8fe7b84046c90eb028c010f289c601f2cd
[dsa-puppet.git] / modules / vsftpd / manifests / site.pp
1 define vsftpd::site (
2         $source='',
3         $content='',
4         $bind='',
5         $ensure=present
6 ){
7
8         include vsftpd::nolisten
9
10         if ($source and $content) {
11                 fail ( "Can't have both source and content for $name" )
12         }
13
14         case $ensure {
15                 present,absent: {}
16                 default: { fail ( "Invald ensure `$ensure' for $name" ) }
17         }
18
19         $fname = "/etc/vsftpd-${name}.conf"
20
21         $noop = $::hostname ? {
22                 villa    => false,
23                 lobos    => false,
24                 steffani => false,
25                 default  => true
26         }
27
28         if $source {
29                 file { $fname:
30                         ensure => $ensure,
31                         noop   => $noop,
32                         source => $source,
33                 }
34         } elsif $content {
35                 file { $fname:
36                         ensure  => $ensure,
37                         noop    => $noop,
38                         content => $content,
39                 }
40         } else {
41                 fail ( "Need one of source or content for $name" )
42         }
43
44         # We don't need a firewall rule because it's added in vsftp.pp
45         xinetd::service { "vsftpd-${name}":
46                 bind        => $bind,
47                 id          => "${name}-ftp",
48                 server      => '/usr/sbin/vsftpd',
49                 port        => 'ftp',
50                 server_args => $fname,
51                 ferm        => false,
52                 require     => File[$fname]
53         }
54
55 }