Take a stab at using the class hierarchy that puppet provides
authorStephen Gran <steve@lobefin.net>
Sat, 25 Apr 2009 16:39:30 +0000 (17:39 +0100)
committerStephen Gran <steve@lobefin.net>
Sat, 25 Apr 2009 16:39:30 +0000 (17:39 +0100)
Signed-off-by: Stephen Gran <steve@lobefin.net>
manifests/site.pp
modules/nagios/manifests/client.pp [new file with mode: 0644]
modules/nagios/manifests/init.pp
modules/nagios/manifests/server.pp [new file with mode: 0644]

index c658619..094c418 100644 (file)
@@ -31,8 +31,6 @@ node default {
         default:   {}
     }
 
-    import "nagios"
-    include nagios-client
 
     case $hostname {
         spohr: {
diff --git a/modules/nagios/manifests/client.pp b/modules/nagios/manifests/client.pp
new file mode 100644 (file)
index 0000000..d323451
--- /dev/null
@@ -0,0 +1,44 @@
+class nagios::client inherits nagios {
+       package {
+               dsa-nagios-nrpe-config: ensure => purged;
+               dsa-nagios-checks: ensure => installed;
+       }
+
+       file {
+               "/etc/default/nagios-nrpe-server":
+                       source  => [ "puppet:///nagios/per-host/$fqdn/default",
+                                    "puppet:///nagios/common/default" ],
+                       require => Package["nagios-nrpe-server"],
+                       notify  => Exec["nagios-nrpe-server restart"];
+               "/etc/default/nagios-nrpe":
+                       ensure  => absent,
+                       notify  => Exec["nagios-nrpe-server restart"];
+               "/etc/nagios/nrpe.cfg":
+                       source  => [ "puppet:///nagios/per-host/$fqdn/nrpe.cfg",
+                                    "puppet:///nagios/common/nrpe.cfg" ],
+                       require => Package["nagios-nrpe-server"],
+                       notify  => Exec["nagios-nrpe-server restart"];
+               "/etc/nagios/nrpe.d":
+                       mode    => 755,
+                       ensure  => directory;
+               "/etc/nagios/nrpe.d/debianorg.cfg":
+                       source  => [ "puppet:///nagios/per-host/$fqdn/inc-debian.org",
+                                    "puppet:///nagios/common/inc-debian.org" ],
+                       require => Package["nagios-nrpe-server"],
+                       notify  => Exec["nagios-nrpe-server restart"];
+               "/etc/nagios/nrpe.d/nrpe_dsa.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/nrpe_dsa.cfg" ],
+                       require => Package["dsa-nagios-checks"],
+                       notify  => Exec["nagios-nrpe-server restart"];
+
+               "/etc/nagios/obsolete-packages-ignore":
+                       source  => [ "puppet:///nagios/per-host/$fqdn/obsolete-packages-ignore",
+                                    "puppet:///nagios/common/obsolete-packages-ignore" ],
+                       require => Package["dsa-nagios-checks"];
+       }
+
+       exec { "nagios-nrpe-server restart":
+               path        => "/etc/init.d:/usr/bin:/usr/sbin:/bin:/sbin",
+               refreshonly => true,
+       }
+}
index 64502aa..13c0dc9 100644 (file)
@@ -1,127 +1,5 @@
-class nagios-client {
+class nagios {
        package {
                nagios-nrpe-server: ensure => installed;
-               dsa-nagios-nrpe-config: ensure => purged;
-               dsa-nagios-checks: ensure => installed;
-       }
-
-       file {
-               "/etc/default/nagios-nrpe-server":
-                       source  => [ "puppet:///nagios/per-host/$fqdn/default",
-                                    "puppet:///nagios/common/default" ],
-                       require => Package["nagios-nrpe-server"],
-                       notify  => Exec["nagios-nrpe-server restart"];
-               "/etc/default/nagios-nrpe":
-                       ensure  => absent,
-                       notify  => Exec["nagios-nrpe-server restart"];
-               "/etc/nagios/nrpe.cfg":
-                       source  => [ "puppet:///nagios/per-host/$fqdn/nrpe.cfg",
-                                    "puppet:///nagios/common/nrpe.cfg" ],
-                       require => Package["nagios-nrpe-server"],
-                       notify  => Exec["nagios-nrpe-server restart"];
-               "/etc/nagios/nrpe.d":
-                       mode    => 755,
-                       ensure  => directory;
-               "/etc/nagios/nrpe.d/debianorg.cfg":
-                       source  => [ "puppet:///nagios/per-host/$fqdn/inc-debian.org",
-                                    "puppet:///nagios/common/inc-debian.org" ],
-                       require => Package["nagios-nrpe-server"],
-                       notify  => Exec["nagios-nrpe-server restart"];
-               "/etc/nagios/nrpe.d/nrpe_dsa.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/nrpe_dsa.cfg" ],
-                       require => Package["dsa-nagios-checks"],
-                       notify  => Exec["nagios-nrpe-server restart"];
-
-               "/etc/nagios/obsolete-packages-ignore":
-                       source  => [ "puppet:///nagios/per-host/$fqdn/obsolete-packages-ignore",
-                                    "puppet:///nagios/common/obsolete-packages-ignore" ],
-                       require => Package["dsa-nagios-checks"];
-       }
-
-       exec { "nagios-nrpe-server restart":
-               path        => "/etc/init.d:/usr/bin:/usr/sbin:/bin:/sbin",
-               refreshonly => true,
-       }
-}
-
-class nagios-server {
-       package {
-               nagios3: ensure => installed;
-               nagios-nrpe-plugin: ensure => installed;
-               nagios-plugins: ensure => installed;
-               nagios-images: ensure => installed;
-       }
-
-       file {
-               "/etc/nagios-plugins/config/local-dsa-checkcommands.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/checkcommands.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-
-               "/etc/nagios3/cgi.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/cgi.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/nagios.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/nagios.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-
-               "/etc/nagios3/puppetconf.d":
-                       mode    => 755,
-                       ensure  => directory;
-
-               "/etc/nagios3/puppetconf.d/contacts.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/contacts.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/generic-host.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/generic-host.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/generic-service.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/generic-service.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/timeperiods.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/timeperiods.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-
-               "/etc/nagios3/puppetconf.d/auto-dependencies.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-dependencies.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/auto-hostextinfo.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-hostextinfo.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/auto-hostgroups.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-hostgroups.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/auto-hosts.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-hosts.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/auto-serviceextinfo.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-serviceextinfo.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/auto-servicegroups.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-servicegroups.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-               "/etc/nagios3/puppetconf.d/auto-services.cfg":
-                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-services.cfg" ],
-                       require => Package["nagios3"],
-                       notify  => Exec["nagios3 reload"];
-
-       }
-
-       exec { "nagios3 reload":
-               path        => "/etc/init.d:/usr/bin:/usr/sbin:/bin:/sbin",
-               refreshonly => true,
        }
 }
-
diff --git a/modules/nagios/manifests/server.pp b/modules/nagios/manifests/server.pp
new file mode 100644 (file)
index 0000000..39a48ff
--- /dev/null
@@ -0,0 +1,80 @@
+class nagios::server inherits nagios::client {
+       package {
+               nagios3: ensure => installed;
+               nagios-nrpe-plugin: ensure => installed;
+               nagios-plugins: ensure => installed;
+               nagios-images: ensure => installed;
+       }
+
+       file {
+               "/etc/nagios-plugins/config/local-dsa-checkcommands.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/checkcommands.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+
+               "/etc/nagios3/cgi.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/cgi.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/nagios.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/nagios.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+
+               "/etc/nagios3/puppetconf.d":
+                       mode    => 755,
+                       ensure  => directory;
+
+               "/etc/nagios3/puppetconf.d/contacts.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/contacts.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/generic-host.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/generic-host.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/generic-service.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/generic-service.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/timeperiods.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/static/conf.d/timeperiods.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+
+               "/etc/nagios3/puppetconf.d/auto-dependencies.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-dependencies.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/auto-hostextinfo.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-hostextinfo.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/auto-hostgroups.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-hostgroups.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/auto-hosts.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-hosts.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/auto-serviceextinfo.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-serviceextinfo.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/auto-servicegroups.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-servicegroups.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+               "/etc/nagios3/puppetconf.d/auto-services.cfg":
+                       source  => [ "puppet:///nagios/dsa-nagios/generated/auto-services.cfg" ],
+                       require => Package["nagios3"],
+                       notify  => Exec["nagios3 reload"];
+
+       }
+
+       exec { "nagios3 reload":
+               path        => "/etc/init.d:/usr/bin:/usr/sbin:/bin:/sbin",
+               refreshonly => true,
+       }
+}