X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=manifests%2Fsite.pp;h=7a8565dbde89fa7a956cee860d1b85c78e35bb3c;hb=d18bb90cf17cc35126f7bb4d60fa54f360024bc9;hp=cf42ca499b4e3434e9395b50f1f20393caad5478;hpb=b9902f1fda20f972542e19724d8364720f96f4b1;p=mirror%2Fdsa-puppet.git diff --git a/manifests/site.pp b/manifests/site.pp index cf42ca499..7a8565dbd 100644 --- a/manifests/site.pp +++ b/manifests/site.pp @@ -9,54 +9,132 @@ File { ensure => file, } +Exec { + path => "/usr/bin:/usr/sbin:/bin:/sbin" +} + node default { + $localinfo = yamlinfo('*', "/etc/puppet/modules/debian-org/misc/local.yaml") + $nodeinfo = nodeinfo($fqdn, "/etc/puppet/modules/debian-org/misc/local.yaml") + $hoster = whohosts($nodeinfo, "/etc/puppet/modules/debian-org/misc/hoster.yaml") + $keyinfo = allnodeinfo("sshRSAHostKey", "ipHostNumber") + notice("hoster for ${fqdn} is ${hoster}") + + $mxinfo = allnodeinfo("mXRecord") + include munin-node - include samhain include sudo + include ssh include debian-org + include monit + include apt-keys + include ntp + + include motd + + case $hostname { + finzi,fano,fasch,field: { include kfreebsd } + } case $smartarraycontroller { "true": { include debian-proliant } - default: {} + } + case $kvmdomain { + "true": { package { acpid: ensure => installed } } + } + case $mptraid { + "true": { include "raidmpt" } } case $mta { - "exim4": { include exim } - default: {} + "exim4": { + case extractnodeinfo($nodeinfo, 'heavy_exim') { + true: { include exim::mx } + default: { include exim } + } + } } - import "nagios" - include nagios-client + case extractnodeinfo($nodeinfo, 'muninmaster') { + true: { include munin-node::master } + } - case $hostname { - spohr: { - import "nagios" - include nagios-server - } - default: {} + case extractnodeinfo($nodeinfo, 'nagiosmaster') { + true: { include nagios::server } + default: { include nagios::client } } case $apache2 { - "true": { case $hostname { - "carver": { include apache2 } - default: {} - } } - default: {} + "true": { + case extractnodeinfo($nodeinfo, 'apache2_security_mirror') { + true: { include apache2::security_mirror } + default: { include apache2 } + } + } } - case $hostname { - brahms,goedel,goetz,lafayette,malo,praetorius,puccini: - { include buildd } - default: {} + case extractnodeinfo($nodeinfo, 'buildd') { + 'true': { + include buildd + case $kernel { + Linux: { + include ferm + } + } + } } + case $hostname { - geo1,geo2,geo3: - { include geodns } - default: {} + klecker,ravel,senfl,orff: { include named::secondary } + geo1,geo2,geo3: { include named::geodns } + bartok,schein,steffani: { include named::recursor } } -} + case $hostname { + logtest01,geo1,geo2,geo3,bartok,senfl,beethoven,piatti,saens,villa,lobos,raff,gluck,schein,wieck,steffani,ball: { include ferm } + } + case $hostname { + piatti: { + @ferm::rule { "dsa-udd-stunnel": + description => "port 8080 for udd stunnel", + rule => "&SERVICE_RANGE(tcp, http-alt, ( 192.25.206.16 70.103.162.29 217.196.43.134 ))" + } + } + senfl: { + @ferm::rule { "dsa-rsync": + domain => "(ip ip6)", + description => "Allow rsync access", + rule => "&SERVICE(tcp, 873)" + } + } + saens,villa,lobos,raff,gluck,schein,wieck,steffani: { + @ferm::rule { "dsa-ftp": + domain => "(ip ip6)", + description => "Allow ftp access", + rule => "&SERVICE(tcp, 21)" + } + @ferm::rule { "dsa-rsync": + domain => "(ip ip6)", + description => "Allow rsync access", + rule => "&SERVICE(tcp, 873)" + } + } + ancina,zelenka: { + @ferm::rule { "dsa-time": + description => "Allow time access", + rule => "&SERVICE_RANGE(tcp, time, \$HOST_NAGIOS_V4)" + } + } -node penalosa inherits default { - include hosts + } + case $brokenhosts { + "true": { include hosts } + } + case $hoster { + "ubcece", "darmstadt", "ftcollins", "grnet": { include resolv } + } + case $portforwarder_user_exists { + "true": { include portforwarder } + } + include samhain }