diff --git a/manifests/icinga2/agent.pp b/manifests/icinga2/agent.pp index fba1020..c54f3b8 100644 --- a/manifests/icinga2/agent.pp +++ b/manifests/icinga2/agent.pp @@ -1,49 +1,54 @@ # Icinga2 agent configuration class profile::icinga2::agent { $features = hiera('icinga2::features') $icinga2_network = hiera('icinga2::network') + $icinga2_host_vars = hiera_hash('icinga2::host::vars') + $parent_zone = hiera('icinga2::parent_zone') $parent_endpoints = hiera('icinga2::parent_endpoints') include profile::icinga2::apt_config class {'::icinga2': confd => false, features => $features, } class { '::icinga2::feature::api': accept_config => true, accept_commands => true, zones => { 'ZoneName' => { endpoints => ['NodeName'], parent => $parent_zone, }, }, } create_resources('::icinga2::object::endpoint', $parent_endpoints) ::icinga2::object::zone {$parent_zone: endpoints => keys($parent_endpoints), } @@::icinga2::object::endpoint {$::fqdn: target => "/etc/icinga2/zones.d/${parent_zone}/${::fqdn}.conf", } @@::icinga2::object::zone {$::fqdn: endpoints => [$::fqdn], parent => $parent_zone, target => "/etc/icinga2/zones.d/${parent_zone}/${::fqdn}.conf", } @@::icinga2::object::host {$::fqdn: - address => ip_for_network($icinga2_network), - target => "/etc/icinga2/zones.d/${parent_zone}/${::fqdn}.conf", + address => ip_for_network($icinga2_network), + display_name => $::fqdn, + check_command => 'hostalive', + vars => $icinga2_host_vars, + target => "/etc/icinga2/zones.d/${parent_zone}/${::fqdn}.conf", } icinga2::object::zone { 'global-templates': global => true, } } diff --git a/manifests/icinga2/master.pp b/manifests/icinga2/master.pp index e4cb910..b2cdd37 100644 --- a/manifests/icinga2/master.pp +++ b/manifests/icinga2/master.pp @@ -1,77 +1,84 @@ # An icinga master host class profile::icinga2::master { $zonename = hiera('icinga2::master::zonename') $features = hiera('icinga2::features') $icinga2_network = hiera('icinga2::network') + $icinga2_host_vars = hiera_hash('icinga2::host::vars') + $icinga2_db_username = hiera('icinga2::master::db::username') $icinga2_db_password = hiera('icinga2::master::db::password') $icinga2_db_database = hiera('icinga2::master::db::database') include profile::icinga2::apt_config include profile::icinga2::objects include ::postgresql::server ::postgresql::server::db {$icinga2_db_database: user => $icinga2_db_username, password => postgresql_password($icinga2_db_username, $icinga2_db_password) } class {'::icinga2': confd => false, features => $features, constants => { 'ZoneName' => $zonename, }, } class { '::icinga2::feature::api': accept_commands => true, zones => {}, endpoints => {}, } class { '::icinga2::feature::idopgsql': user => $icinga2_db_username, password => $icinga2_db_password, database => $icinga2_db_database, import_schema => true, require => Postgresql::Server::Db[$icinga2_db_database], } @@::icinga2::object::endpoint {$::fqdn: target => "/etc/icinga2/zones.d/${zonename}/${::fqdn}.conf", } @@::icinga2::object::zone {$zonename: endpoints => [$::fqdn], target => "/etc/icinga2/zones.d/${zonename}/${::fqdn}.conf", } + $icinga2_host_vars = hiera('icinga2::host::vars') + @@::icinga2::object::host {$::fqdn: - address => ip_for_network($icinga2_network), - target => "/etc/icinga2/zones.d/${zonename}/${::fqdn}.conf", + address => ip_for_network($icinga2_network), + display_name => $::fqdn, + check_command => 'hostalive', + vars => $icinga2_host_vars, + target => "/etc/icinga2/zones.d/${zonename}/${::fqdn}.conf", } ::Icinga2::Object::Host <<| |>> ::Icinga2::Object::Endpoint <<| |>> ::Icinga2::Object::Zone <<| |>> ::icinga2::object::zone { 'global-templates': global => true, } file {[ '/etc/icinga2/zones.d/global-templates', "/etc/icinga2/zones.d/${zonename}", ]: ensure => directory, owner => 'nagios', group => 'nagios', mode => '0750', tag => 'icinga2::config::file', } }