this is probably more like it
authorStephen Gran <steve@lobefin.net>
Sun, 22 Apr 2012 19:48:10 +0000 (20:48 +0100)
committerStephen Gran <steve@lobefin.net>
Sun, 22 Apr 2012 19:48:10 +0000 (20:48 +0100)
Signed-off-by: Stephen Gran <steve@lobefin.net>
manifests/site.pp
modules/roles/files/security_mirror/vsftpd.conf [new file with mode: 0644]
modules/roles/manifests/security_mirror.pp
modules/vsftpd/manifests/site.pp [new file with mode: 0644]

index 54ed652..77007e1 100644 (file)
@@ -148,7 +148,7 @@ node default {
                munin::check { 'spamassassin': }
        }
 
-       if $::hostname in [chopin,franck,gluck,kassia,klecker,lobos,morricone,ravel,saens,schein,santoro,steffani,villa,wieck,bizet] {
+       if $::hostname in [chopin,franck,kassia,klecker,morricone,ravel,bizet] {
                include vsftpd
        }
 }
diff --git a/modules/roles/files/security_mirror/vsftpd.conf b/modules/roles/files/security_mirror/vsftpd.conf
new file mode 100644 (file)
index 0000000..2cbe373
--- /dev/null
@@ -0,0 +1,14 @@
+anonymous_enable=YES\r
+connect_from_port_20=NO\r
+connect_from_port_20=YES\r
+dirmessage_enable=NO\r
+dirmessage_enable=YES\r
+ftpd_banner=security.debian.org FTP server (vsftpd)\r
+listen=YES\r
+ls_recurse_enable=YES\r
+pam_service_name=vsftpd\r
+rsa_cert_file=/etc/ssl/certs/vsftpd.pem\r
+secure_chroot_dir=/var/run/vsftpd\r
+setproctitle_enable=YES\r
+xferlog_enable=YES\r
+xferlog_file=/var/log/vsftpd.log\r
index 46f9b5f..9b9ec2d 100644 (file)
@@ -5,4 +5,7 @@ class roles::security_mirror {
                config => 'puppet:///modules/roles/security_mirror/security.debian.org'
        }
 
+       class { 'vsftpd::site':
+               source => 'puppet:///modules/roles/security_mirror/vsftpd.conf'
+       }
 }
diff --git a/modules/vsftpd/manifests/site.pp b/modules/vsftpd/manifests/site.pp
new file mode 100644 (file)
index 0000000..bc66c95
--- /dev/null
@@ -0,0 +1,34 @@
+class vsftpd::site (
+       $source='',
+       $content='',
+       $ensure=present,
+){
+
+       include vsftpd
+
+       if ($source and $content) {
+               fail ( "Can't have both source and content for $name" )
+       }
+
+       case $ensure {
+               present,absent: {}
+               default: { fail ( "Invald ensure `$ensure' for $name" ) }
+       }
+
+       if $source {
+               file { '/etc/vsftpd.conf':
+                       ensure => $ensure,
+                       source => $source,
+                       notify => Service['vsftpd']
+               }
+       } elsif $content {
+               file { '/etc/vsftpd.conf':
+                       ensure  => $ensure,
+                       content => $content,
+                       notify  => Service['vsftpd']
+               }
+       } else {
+               fail ( "Need one of source or content for $name" )
+       }
+
+}