diff options
Diffstat (limited to 'manifests')
24 files changed, 112 insertions, 68 deletions
diff --git a/manifests/base.pp b/manifests/base.pp index 0a6e2f9..69a7568 100644 --- a/manifests/base.pp +++ b/manifests/base.pp @@ -1,8 +1,23 @@ class puppet::base { + if !$puppet_config { $puppet_config = '/etc/puppet/puppet.conf' } $puppet_majorversion = regsubst($puppetversion,'^(\d+\.\d+).*$','\1') + case $puppet_cleanup_clientbucket { + # if not set, don't do anything + '': {} + default: { + tidy { "/var/lib/puppet/clientbucket": + backup => false, + recurse => true, + rmdirs => true, + type => mtime, + age => "$puppet_cleanup_clientbucket"; + } + } + } + file { 'puppet_config': path => "$puppet_config", source => [ "puppet:///modules/site-puppet/client/${fqdn}/puppet.conf", @@ -13,11 +28,12 @@ class puppet::base { "puppet:///modules/puppet/client/puppet.conf.$operatingsystem", "puppet:///modules/puppet/client/puppet.conf" ], notify => Service[puppet], - # if puppetmasterd is deployed by apache2/passenger it needs to read puppet.conf - # therefore it must be readable by puppet + # if puppetmasterd is deployed by apache2/passenger it needs to read puppet.conf + # therefore it must be readable by puppet owner => puppet, group => 0, mode => 600; } - service{'puppet': + + service { 'puppet': ensure => running, enable => true, hasstatus => true, diff --git a/manifests/centos.pp b/manifests/centos.pp index 6fdde9e..61aa065 100644 --- a/manifests/centos.pp +++ b/manifests/centos.pp @@ -1,5 +1,6 @@ class puppet::centos inherits puppet::linux { - file{'/etc/sysconfig/puppet': + + file { '/etc/sysconfig/puppet': source => [ "puppet:///modules/site-puppet/sysconfig/${fqdn}/puppet", "puppet:///modules/site-puppet/sysconfig/${domain}/puppet", "puppet:///modules/site-puppet/sysconfig/puppet", diff --git a/manifests/cron/base.pp b/manifests/cron/base.pp index acef55e..74e0225 100644 --- a/manifests/cron/base.pp +++ b/manifests/cron/base.pp @@ -1,12 +1,12 @@ # manifests/cron/base.pp - class puppet::cron::base inherits puppet::base { + Service['puppet']{ enable => false, } case $operatingsystem { - debian,openbsd,ubuntu: { + openbsd: { #it's already disabled } default: { @@ -21,7 +21,7 @@ class puppet::cron::base inherits puppet::base { pattern => 'puppetd', } # this works only on < 2.6 - exec{'stop_puppet': + exec { 'stop_puppet': command => 'kill `cat /var/run/puppet/puppetd.pid`', onlyif => 'test -f /var/run/puppet/puppetd.pid', require => Service['puppet'], diff --git a/manifests/cron/linux.pp b/manifests/cron/linux.pp index a5008bf..b3a10aa 100644 --- a/manifests/cron/linux.pp +++ b/manifests/cron/linux.pp @@ -1,5 +1,6 @@ # manifests/cron/linux.pp class puppet::cron::linux inherits puppet::linux { + include puppet::cron::base if !$puppet_config { $puppet_config = '/etc/puppet/puppet.conf' } if $puppet_http_compression { $puppet_http_compression_str = '--http_compression' } diff --git a/manifests/cron/openbsd.pp b/manifests/cron/openbsd.pp index 4ee293f..084b022 100644 --- a/manifests/cron/openbsd.pp +++ b/manifests/cron/openbsd.pp @@ -1,4 +1,5 @@ class puppet::cron::openbsd inherits puppet::openbsd { + include puppet::cron::base if !$puppet_config { $puppet_config = '/etc/puppet/puppet.conf' } if $puppet_http_compression { $puppet_http_compression_str = '--http_compression' } diff --git a/manifests/debian.pp b/manifests/debian.pp index fba7beb..9f33c64 100644 --- a/manifests/debian.pp +++ b/manifests/debian.pp @@ -1,17 +1,14 @@ class puppet::debian inherits puppet::linux { - file{'/etc/default/puppet': + + file { '/etc/default/puppet': source => [ "puppet:///modules/site-puppet/client/debian/${fqdn}/puppet", "puppet:///modules/site-puppet/client/debian/${domain}/puppet", "puppet:///modules/site-puppet/client/debian/puppet", "puppet:///modules/puppet/client/debian/puppet" ], notify => Service[puppet], owner => root, group => 0, mode => 0644; - } - - # there is really no status cmd for it - Service[puppet]{ - hasstatus => false, } + File['/etc/cron.d/puppetd.cron']{ path => '/etc/cron.d/puppetd', } diff --git a/manifests/gentoo.pp b/manifests/gentoo.pp index 1fed53d..da78226 100644 --- a/manifests/gentoo.pp +++ b/manifests/gentoo.pp @@ -1,4 +1,5 @@ class puppet::gentoo inherits puppet::linux { + Package[puppet]{ category => 'app-admin', } diff --git a/manifests/linux.pp b/manifests/linux.pp index a217f66..cf79e00 100644 --- a/manifests/linux.pp +++ b/manifests/linux.pp @@ -10,14 +10,20 @@ class puppet::linux inherits puppet::base { ensure => $facter_ensure_version, } - # package bc needed for cron job - include bc + if !defined(Package["bc"]) { + if $bc_ensure_version == '' { $bc_ensure_version = 'installed' } + package { 'bc': + ensure => $bc_ensure_version, + } + } + Service['puppet']{ require => Package[puppet], } - file{'/etc/cron.d/puppetd.cron': - source => [ "puppet:///modules/puppet/cron.d/puppetd.${operatingsystem}", + file { '/etc/cron.d/puppetd.cron': + source => [ "puppet:///modules/site-puppet/cron.d/puppetd", + "puppet:///modules/puppet/cron.d/puppetd.${operatingsystem}", "puppet:///modules/puppet/cron.d/puppetd" ], owner => root, group => 0, mode => 0644, } diff --git a/manifests/openbsd.pp b/manifests/openbsd.pp index 1eeaba5..cff727e 100644 --- a/manifests/openbsd.pp +++ b/manifests/openbsd.pp @@ -1,7 +1,9 @@ class puppet::openbsd inherits puppet::base { + File['puppet_config']{ owner => '_puppet' } + Service['puppet']{ restart => '/bin/kill -HUP `/bin/cat /var/run/puppet/agent.pid`', stop => '/bin/kill `/bin/cat /var/run/puppet/agent.pid`', @@ -10,18 +12,21 @@ class puppet::openbsd inherits puppet::base { hasrestart => false, pattern => 'puppet agent', } - openbsd::rc_local{'puppetd': + + openbsd::rc_local { 'puppetd': binary => '/usr/local/bin/puppet agent', } - cron { 'puppetd_check': - command => '/bin/ps ax | /usr/bin/grep -v grep | /usr/bin/grep -q "puppet agent" || (sleep `echo $RANDOM/2000*60 | bc` && /usr/local/bin/puppet agent)', - user => root, - minute => 0, - } - cron { 'puppetd_restart': - command => 'sleep `echo $RANDOM/2000*60 | bc` && /bin/kill `/bin/cat /var/run/puppet/agent.pid`; /usr/local/bin/puppet agent', - minute => 0, - hour => 22, - monthday => '*/2', + + cron { + 'puppetd_check': + command => '/bin/ps ax | /usr/bin/grep -v grep | /usr/bin/grep -q "puppet agent" || (sleep `echo $RANDOM/2000*60 | bc` && /usr/local/bin/puppet agent)', + user => root, + minute => 0; + + 'puppetd_restart': + command => 'sleep `echo $RANDOM/2000*60 | bc` && /bin/kill `/bin/cat /var/run/puppet/agent.pid`; /usr/local/bin/puppet agent', + minute => 0, + hour => 22, + monthday => '*/2', } } diff --git a/manifests/puppetmaster/base.pp b/manifests/puppetmaster/base.pp index 6f9bdc7..6ac1e0c 100644 --- a/manifests/puppetmaster/base.pp +++ b/manifests/puppetmaster/base.pp @@ -1,4 +1,5 @@ class puppet::puppetmaster::base inherits puppet::base { + File[puppet_config]{ source => [ "puppet:///modules/site-puppet/master/puppet.conf", "puppet:///modules/puppet/master/puppet.conf" ], diff --git a/manifests/puppetmaster/centos.pp b/manifests/puppetmaster/centos.pp index 0daa69b..2673a4d 100644 --- a/manifests/puppetmaster/centos.pp +++ b/manifests/puppetmaster/centos.pp @@ -1,7 +1,7 @@ # manifests/puppetmaster/centos.pp - class puppet::puppetmaster::centos inherits puppet::puppetmaster::package { - file{'/etc/sysconfig/puppetmaster': + + file { '/etc/sysconfig/puppetmaster': source => [ "puppet:///modules/site-puppet/sysconfig/${fqdn}/puppetmaster", "puppet:///modules/site-puppet/sysconfig/${domain}/puppetmaster", "puppet:///modules/site-puppet/sysconfig/puppetmaster", diff --git a/manifests/puppetmaster/checklastrun.pp b/manifests/puppetmaster/checklastrun.pp index 72a97ce..17f4553 100644 --- a/manifests/puppetmaster/checklastrun.pp +++ b/manifests/puppetmaster/checklastrun.pp @@ -1,4 +1,5 @@ class puppet::puppetmaster::checklastrun { + $puppet_lastruncheck_ignorehosts_str = $puppet_lastruncheck_ignorehosts ? { '' => '', undef => '', @@ -11,13 +12,14 @@ class puppet::puppetmaster::checklastrun { default => "--timeout ${puppet_lastruncheck_timeout}" } - file{"/usr/local/sbin/puppetlast": - source => [ "puppet:///modules/puppet/master/lastruncheck" ], - owner => root, group => 0, mode => 0700; - } - file{'/etc/cron.d/puppetlast.cron': - content => "${puppetmaster_lastruncheck_cron} root /usr/local/sbin/puppetlast ${puppet_lastruncheck_timeout_str} ${puppet_lastruncheck_ignorehosts_str} ${$puppet_lastruncheck_additionaloptions}\n", - require => File["/usr/local/bin/puppetlast"], - owner => root, group => 0, mode => 0644, + file{ + '/usr/local/sbin/puppetlast': + source => [ "puppet:///modules/puppet/master/lastruncheck" ], + owner => root, group => 0, mode => 0700; + + '/etc/cron.d/puppetlast.cron': + content => "${puppetmaster_lastruncheck_cron} root /usr/local/sbin/puppetlast ${puppet_lastruncheck_timeout_str} ${puppet_lastruncheck_ignorehosts_str} ${$puppet_lastruncheck_additionaloptions}\n", + require => File["/usr/local/bin/puppetlast"], + owner => root, group => 0, mode => 0644, } } diff --git a/manifests/puppetmaster/checklastrun/disable.pp b/manifests/puppetmaster/checklastrun/disable.pp index 3fc91d0..8fff212 100644 --- a/manifests/puppetmaster/checklastrun/disable.pp +++ b/manifests/puppetmaster/checklastrun/disable.pp @@ -1,8 +1,10 @@ class puppet::puppetmaster::checklastrun::disable inherits puppet::puppetmaster::checklastrun { + File['/usr/local/sbin/puppetlast']{ source => undef, ensure => absent, } + File['/etc/cron.d/puppetlast.cron']{ ensure => absent, } diff --git a/manifests/puppetmaster/cleanup_reports.pp b/manifests/puppetmaster/cleanup_reports.pp index 4d76ceb..58fb9e2 100644 --- a/manifests/puppetmaster/cleanup_reports.pp +++ b/manifests/puppetmaster/cleanup_reports.pp @@ -1,6 +1,7 @@ class puppet::puppetmaster::cleanup_reports { + # clean up reports older than $puppetmaster_cleanup_reports days - file{'/etc/cron.daily/puppet_reports_cleanup.sh': + file { '/etc/cron.daily/puppet_reports_cleanup.sh': content => "#!/bin/bash\nfind /var/log/puppet/reports/ -maxdepth 2 -type f -ctime +${puppetmaster_cleanup_reports} -exec rm {} \\;\n", owner => root, group => 0, mode => 0700; } diff --git a/manifests/puppetmaster/cleanup_reports/disable.pp b/manifests/puppetmaster/cleanup_reports/disable.pp index f195a3e..8636223 100644 --- a/manifests/puppetmaster/cleanup_reports/disable.pp +++ b/manifests/puppetmaster/cleanup_reports/disable.pp @@ -1,4 +1,5 @@ class puppet::puppetmaster::cleanup_reports::disable inherits puppet::puppetmaster::cleanup_reports { + File['/etc/cron.daily/puppet_reports_cleanup.sh']{ ensure => absent, } diff --git a/manifests/puppetmaster/cluster.pp b/manifests/puppetmaster/cluster.pp index 41298b3..8d635ab 100644 --- a/manifests/puppetmaster/cluster.pp +++ b/manifests/puppetmaster/cluster.pp @@ -1,3 +1,5 @@ class puppet::puppetmaster::cluster inherits puppet::puppetmaster { + include puppet::puppetmaster::cluster::base + } diff --git a/manifests/puppetmaster/cluster/base.pp b/manifests/puppetmaster/cluster/base.pp index 1aa1f8b..8c90153 100644 --- a/manifests/puppetmaster/cluster/base.pp +++ b/manifests/puppetmaster/cluster/base.pp @@ -1,6 +1,7 @@ class puppet::puppetmaster::cluster::base inherits puppet::puppetmaster::base { - include mongrel, nginx + include mongrel, nginx + File[puppet_config] { require +> [ Package[mongrel], Package[nginx], File[nginx_config] ], } diff --git a/manifests/puppetmaster/debian.pp b/manifests/puppetmaster/debian.pp index 14ea3cc..76cd4f5 100644 --- a/manifests/puppetmaster/debian.pp +++ b/manifests/puppetmaster/debian.pp @@ -1 +1,6 @@ -class puppet::puppetmaster::debian inherits puppet::puppetmaster::package { } +class puppet::puppetmaster::debian inherits puppet::puppetmaster::package { + + if $puppetmaster_mode != 'passenger' { + Service['puppetmaster'] { hasstatus => true, hasrestart => true } + } +} diff --git a/manifests/puppetmaster/hasdb.pp b/manifests/puppetmaster/hasdb.pp index 1ba1331..2aca0e6 100644 --- a/manifests/puppetmaster/hasdb.pp +++ b/manifests/puppetmaster/hasdb.pp @@ -1,4 +1,4 @@ -define puppet::puppetmaster::hasdb( +define puppet::puppetmaster::hasdb ( $dbtype = 'mysql', $dbname = 'puppet', $dbhost = 'localhost', @@ -6,8 +6,8 @@ define puppet::puppetmaster::hasdb( $dbhostfqdn = "${fqdn}", $dbuser = 'puppet', $dbpwd = $puppet_storeconfig_password, - $dbconnectinghost = 'locahost' -){ + $dbconnectinghost = 'locahost' ) +{ if !$puppet_storeconfig_password { fail("No \$puppet_storeconfig_password is set, please set it in your manifests or site.pp to add a password") } diff --git a/manifests/puppetmaster/hasdb/mysql.pp b/manifests/puppetmaster/hasdb/mysql.pp index 22e6434..322bf69 100644 --- a/manifests/puppetmaster/hasdb/mysql.pp +++ b/manifests/puppetmaster/hasdb/mysql.pp @@ -1,30 +1,29 @@ # don't use this define use the general interface -define puppet::puppetmaster::hasdb::mysql( +define puppet::puppetmaster::hasdb::mysql ( $dbname = 'puppet', $dbhost = 'localhost', $dbhostfqdn = "${fqdn}", $dbuser = 'puppet', $dbpwd, - $dbconnectinghost = 'localhost' -){ - @@mysql_database{$dbname: + $dbconnectinghost = 'localhost' ) +{ + @@mysql_database { $dbname: tag => "mysql_${dbhostfqdn}", } - @@mysql_user{"${dbuser}@${dbconnectinghost}": + @@mysql_user { "${dbuser}@${dbconnectinghost}": password_hash => mysql_password("$dbpwd"), require => Mysql_database[$dbname], tag => "mysql_${dbhostfqdn}", } - - @@mysql_grant{"${dbuser}@${dbconnectinghost}/${dbname}": + @@mysql_grant { "${dbuser}@${dbconnectinghost}/${dbname}": privileges => all, require => Mysql_user["${dbuser}@${dbconnectinghost}"], tag => "mysql_${dbhostfqdn}", } - munin::plugin::deploy{'puppetresources': + munin::plugin::deploy { 'puppetresources': source => "puppet/munin/puppetresources.mysql", config => "env.mysqlopts --user=$dbuser --password=$dbpwd -h $dbhost\nenv.puppetdb $dbname", } diff --git a/manifests/puppetmaster/linux.pp b/manifests/puppetmaster/linux.pp index 3d36f75..2670203 100644 --- a/manifests/puppetmaster/linux.pp +++ b/manifests/puppetmaster/linux.pp @@ -1,16 +1,16 @@ class puppet::puppetmaster::linux inherits puppet::linux { if $puppetmaster_mode == 'passenger' { - exec{'notify_passenger_puppetmaster': + exec { 'notify_passenger_puppetmaster': refreshonly => true, command => 'touch /etc/puppet/rack/tmp/restart.txt && sleep 1 && rm /etc/puppet/rack/tmp/restart.txt', - } + } } else { - service{'puppetmaster': - ensure => running, - enable => true, - require => [ Package[puppet] ], - } + service { 'puppetmaster': + ensure => running, + enable => true, + require => [ Package[puppet] ], + } } Service[puppet]{ require +> Service[puppetmaster], diff --git a/manifests/puppetmaster/package/base.pp b/manifests/puppetmaster/package/base.pp index 94f2c79..363f827 100644 --- a/manifests/puppetmaster/package/base.pp +++ b/manifests/puppetmaster/package/base.pp @@ -1,5 +1,6 @@ class puppet::puppetmaster::package::base inherits puppet::puppetmaster::package { - package{'puppetmaster': + + package { 'puppetmaster': ensure => present, } diff --git a/manifests/puppetmaster/package/centos.pp b/manifests/puppetmaster/package/centos.pp index e3bb145..43361fd 100644 --- a/manifests/puppetmaster/package/centos.pp +++ b/manifests/puppetmaster/package/centos.pp @@ -1,4 +1,5 @@ class puppet::puppetmaster::package::centos inherits puppet::puppetmaster::package::base { + Package['puppetmaster']{ name => 'puppet-server', alias => 'puppetmaster', diff --git a/manifests/puppetmaster/passenger.pp b/manifests/puppetmaster/passenger.pp index f7fa3ab..c4bc062 100644 --- a/manifests/puppetmaster/passenger.pp +++ b/manifests/puppetmaster/passenger.pp @@ -7,14 +7,14 @@ class puppet::puppetmaster::passenger inherits puppet::puppetmaster::base { # A reference configuration is available at : # http://github.com/reductivelabs/puppet/tree/master/ext/rack - file { ['/etc/puppet/rack', '/etc/puppet/rack/public', '/etc/puppet/rack/tmp']: - ensure => directory, - owner => root, group => 0, mode => 0755; - } + file { + ['/etc/puppet/rack', '/etc/puppet/rack/public', '/etc/puppet/rack/tmp']: + ensure => directory, + owner => root, group => 0, mode => 0755; - file {'/etc/puppet/rack/config.ru': - source => [ "puppet:///modules/site-puppet/master/config.ru", - "puppet:///modules/puppet/master/config.ru" ], - owner => puppet, group => 0, mode => 0644; + '/etc/puppet/rack/config.ru': + source => [ "puppet:///modules/site-puppet/master/config.ru", + "puppet:///modules/puppet/master/config.ru" ], + owner => puppet, group => 0, mode => 0644; } } |