X-Git-Url: https://git.adam-barratt.org.uk/?a=blobdiff_plain;f=manifests%2Fsite.pp;h=7f9e3119dc6c8d020c1f0cff6b6e8287683bf7e4;hb=ac7831af052e807cae7aa0913005d5bb13ecb0af;hp=fce042a4b3f3b3cdd8db0082ca9c1b0ea05fed2b;hpb=57a65d1ad2fb3fa112637e643fa3e2f68a10bf14;p=mirror%2Fdsa-puppet.git diff --git a/manifests/site.pp b/manifests/site.pp index fce042a4b..a5d96b4de 100644 --- a/manifests/site.pp +++ b/manifests/site.pp @@ -9,59 +9,159 @@ 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 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 $hostname { - morales: {} - default: { include samhain } + 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,rore,tartini: { include apache2 } - default: {} - } } - default: {} + "true": { + case extractnodeinfo($nodeinfo, 'apache2_security_mirror') { + true: { include apache2::security_mirror } + default: { include apache2 } + } + } + } + + case extractnodeinfo($nodeinfo, 'buildd') { + 'true': { + include buildd + case $kernel { + Linux: { + include ferm + } + } + } } case $hostname { - ancina,brahms,goedel,goetz,lafayette,malo,praetorius,puccini: - { include buildd } - default: {} + klecker,ravel,senfl,orff: { include named::secondary } + geo1,geo2,geo3: { include named::geodns } + bartok,schein,steffani: { include named::recursor } } + case $hostname { - geo1,geo2,geo3: - { include geodns } - default: {} + logtest01,geo1,geo2,geo3,bartok,senfl,beethoven,piatti,saens,villa,lobos,raff,gluck,schein,wieck,steffani,ball,handel,tchaikovsky: { include ferm } } -} + case $hostname { + zandonai,zelenka: { + @ferm::rule { "dsa-zivit-rrdcollect": + description => "port 6666 for rrdcollect for zivit", + rule => "&SERVICE_RANGE(tcp, 6666, ( 10.130.18.71 ))" + } + @ferm::rule { "dsa-zivit-zabbix": + description => "port 10050 for zabbix for zivit", + rule => "&SERVICE_RANGE(tcp, 10050, ( 10.130.18.76 ))" + } + } + 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)" + } + } + handel: { + @ferm::rule { "dsa-puppet": + description => "Allow puppet access", + rule => "&SERVICE_RANGE(tcp, 8140, \$HOST_DEBIAN_V4)" + } + @ferm::rule { "dsa-puppet-v6": + domain => 'ip6', + description => "Allow puppet access", + rule => "&SERVICE_RANGE(tcp, 8140, \$HOST_DEBIAN_V6)" + } + } + beethoven: { + @ferm::rule { "dsa-merikanto-beethoven": + description => "Allow merikanto", # for nfs, and that uses all kind of ports by default. + rule => "source 172.22.127.147 interface bond0 jump ACCEPT", + } + } -node penalosa inherits default { - include hosts - include motd + } + case $brokenhosts { + "true": { include hosts } + } + case $hoster { + "ubcece", "darmstadt", "ftcollins", "grnet": { include resolv } + } + case $portforwarder_user_exists { + "true": { include portforwarder } + } + include samhain }