2020-10-20 04:44:58 +02:00
|
|
|
class zulip_ops::profile::nagios {
|
|
|
|
include zulip_ops::profile::base
|
2016-10-17 04:05:49 +02:00
|
|
|
include zulip_ops::apache
|
2013-02-07 22:20:10 +01:00
|
|
|
|
2013-11-08 21:17:14 +01:00
|
|
|
$nagios_packages = [# Packages needed for Nagios
|
2022-01-11 00:55:20 +01:00
|
|
|
'nagios4',
|
2016-07-23 01:55:50 +02:00
|
|
|
# For sending outgoing email
|
2018-08-13 21:29:40 +02:00
|
|
|
'msmtp',
|
2013-11-08 21:17:14 +01:00
|
|
|
]
|
2022-03-16 01:23:53 +01:00
|
|
|
package { $nagios_packages: ensure => installed }
|
2018-08-13 21:29:40 +02:00
|
|
|
$nagios_alert_email = zulipconf('nagios', 'alert_email', undef)
|
|
|
|
$nagios_test_email = zulipconf('nagios', 'test_email', undef)
|
|
|
|
$nagios_pager_email = zulipconf('nagios', 'pager_email', undef)
|
2013-02-07 22:20:10 +01:00
|
|
|
|
2018-08-13 21:29:40 +02:00
|
|
|
$nagios_mail_domain = zulipconf('nagios', 'mail_domain', undef)
|
|
|
|
$nagios_mail_host = zulipconf('nagios', 'mail_host', undef)
|
|
|
|
$nagios_mail_password = zulipsecret('secrets', 'nagios_mail_password', '')
|
2021-06-25 02:15:26 +02:00
|
|
|
if zulipconf('nagios', 'camo_check_url', undef) =~ /^https:\/\/([^\/]*)(\/.*)$/ {
|
|
|
|
$nagios_camo_check_host = $1
|
|
|
|
$nagios_camo_check_path = $2
|
|
|
|
}
|
2016-07-23 01:55:50 +02:00
|
|
|
|
2020-07-10 04:15:30 +02:00
|
|
|
$default_host_domain = zulipconf('nagios', 'default_host_domain', undef)
|
2018-08-13 21:29:40 +02:00
|
|
|
$hosts_zmirror = split(zulipconf('nagios', 'hosts_zmirror', undef), ',')
|
|
|
|
$hosts_zmirrorp = split(zulipconf('nagios', 'hosts_zmirrorp', undef), ',')
|
|
|
|
$hosts_app_prod = split(zulipconf('nagios', 'hosts_app_prod', undef), ',')
|
|
|
|
$hosts_app_staging = split(zulipconf('nagios', 'hosts_app_staging', undef), ',')
|
2020-10-26 21:56:58 +01:00
|
|
|
$hosts_postgresql_primary = split(zulipconf('nagios', 'hosts_postgresql_primary', undef), ',')
|
|
|
|
$hosts_postgresql_replica = split(zulipconf('nagios', 'hosts_postgresql_replica', undef), ',')
|
2018-08-13 21:29:40 +02:00
|
|
|
$hosts_redis = split(zulipconf('nagios', 'hosts_redis', undef), ',')
|
|
|
|
$hosts_fullstack = split(zulipconf('nagios', 'hosts_fullstack', undef), ',')
|
2021-03-18 04:04:15 +01:00
|
|
|
$hosts_smokescreen = split(zulipconf('nagios', 'hosts_smokescreen', undef), ',')
|
2022-06-14 02:12:01 +02:00
|
|
|
$hosts_other = split(zulipconf('nagios', 'hosts_other', undef), ',')
|
2017-10-06 04:44:52 +02:00
|
|
|
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/':
|
2013-05-31 21:50:57 +02:00
|
|
|
recurse => true,
|
2018-08-13 21:20:34 +02:00
|
|
|
purge => false,
|
2022-01-11 00:55:20 +01:00
|
|
|
require => Package[nagios4],
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2018-08-13 21:20:34 +02:00
|
|
|
mode => '0644',
|
2022-01-11 00:55:20 +01:00
|
|
|
source => 'puppet:///modules/zulip_ops/nagios4/',
|
|
|
|
notify => Service['nagios4'],
|
2013-06-14 20:15:12 +02:00
|
|
|
}
|
|
|
|
|
2020-07-09 00:24:41 +02:00
|
|
|
file { '/etc/apache2/sites-available/nagios.conf':
|
|
|
|
purge => false,
|
|
|
|
require => Package[apache2],
|
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
|
|
|
mode => '0640',
|
|
|
|
content => template('zulip_ops/nagios_apache_site.conf.template.erb'),
|
|
|
|
}
|
|
|
|
apache2site { 'nagios':
|
|
|
|
ensure => present,
|
|
|
|
require => [
|
|
|
|
File['/etc/apache2/sites-available/nagios.conf'],
|
|
|
|
Apache2mod['headers'], Apache2mod['ssl'],
|
|
|
|
],
|
|
|
|
notify => Service['apache2'],
|
|
|
|
}
|
2021-06-08 23:41:02 +02:00
|
|
|
zulip_ops::teleport::application{ 'nagios':
|
|
|
|
description => 'Monitoring: nagios and munin',
|
|
|
|
port => '3000',
|
|
|
|
}
|
2020-07-09 00:24:41 +02:00
|
|
|
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/conf.d/contacts.cfg':
|
|
|
|
require => Package[nagios4],
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2018-08-13 21:20:34 +02:00
|
|
|
mode => '0644',
|
2022-01-11 00:55:20 +01:00
|
|
|
content => template('zulip_ops/nagios4/contacts.cfg.template.erb'),
|
|
|
|
notify => Service['nagios4'],
|
2017-10-06 04:08:50 +02:00
|
|
|
}
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/conf.d/hosts.cfg':
|
|
|
|
require => Package[nagios4],
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2018-08-13 21:20:34 +02:00
|
|
|
mode => '0644',
|
2022-01-11 00:55:20 +01:00
|
|
|
content => template('zulip_ops/nagios4/hosts.cfg.template.erb'),
|
|
|
|
notify => Service['nagios4'],
|
2017-10-06 04:06:28 +02:00
|
|
|
}
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/conf.d/localhost.cfg':
|
|
|
|
require => Package[nagios4],
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2018-08-13 21:20:34 +02:00
|
|
|
mode => '0644',
|
2022-01-11 00:55:20 +01:00
|
|
|
content => template('zulip_ops/nagios4/localhost.cfg.template.erb'),
|
|
|
|
notify => Service['nagios4'],
|
2016-07-21 07:59:17 +02:00
|
|
|
}
|
2017-10-06 04:06:28 +02:00
|
|
|
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/cgi.cfg':
|
|
|
|
require => Package[nagios4],
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2018-08-13 21:20:34 +02:00
|
|
|
mode => '0644',
|
2022-01-11 00:55:20 +01:00
|
|
|
content => template('zulip_ops/nagios4/cgi.cfg.template.erb'),
|
|
|
|
notify => Service['nagios4'],
|
2016-07-21 07:56:00 +02:00
|
|
|
}
|
|
|
|
|
2022-01-11 00:55:20 +01:00
|
|
|
service { 'nagios4':
|
2013-06-14 20:15:12 +02:00
|
|
|
ensure => running,
|
|
|
|
}
|
|
|
|
|
2021-06-02 04:03:53 +02:00
|
|
|
file { [
|
2022-01-11 00:55:20 +01:00
|
|
|
'/etc/nagios4/conf.d/extinfo_nagios2.cfg',
|
|
|
|
'/etc/nagios4/conf.d/services_nagios2.cfg',
|
|
|
|
'/etc/nagios4/conf.d/contacts_nagios2.cfg',
|
|
|
|
'/etc/nagios4/conf.d/hostgroups_nagios2.cfg',
|
|
|
|
'/etc/nagios4/conf.d/localhost_nagios2.cfg',
|
2018-08-13 21:27:41 +02:00
|
|
|
]:
|
2016-07-21 07:54:35 +02:00
|
|
|
ensure => absent,
|
|
|
|
}
|
|
|
|
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/conf.d/zulip_nagios.cfg':
|
2018-08-13 21:20:34 +02:00
|
|
|
ensure => file,
|
|
|
|
mode => '0644',
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2017-10-06 03:42:13 +02:00
|
|
|
source => '/usr/local/share/zulip/integrations/nagios/zulip_nagios.cfg',
|
2022-01-11 00:55:20 +01:00
|
|
|
notify => Service['nagios4'],
|
2013-08-07 18:22:36 +02:00
|
|
|
}
|
2016-08-03 21:53:03 +02:00
|
|
|
|
2020-07-10 04:24:51 +02:00
|
|
|
$hosts = zulipconf_nagios_hosts()
|
2022-01-11 00:55:20 +01:00
|
|
|
file { '/etc/nagios4/conf.d/zulip_autossh.cfg':
|
2018-08-13 21:20:34 +02:00
|
|
|
ensure => file,
|
|
|
|
mode => '0644',
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'root',
|
|
|
|
group => 'root',
|
2016-08-03 21:53:03 +02:00
|
|
|
content => template('zulip_ops/nagios_autossh.template.erb'),
|
2022-01-11 00:55:20 +01:00
|
|
|
notify => Service['nagios4'],
|
2016-08-03 21:53:03 +02:00
|
|
|
}
|
2013-08-07 18:22:36 +02:00
|
|
|
|
2016-07-23 01:55:50 +02:00
|
|
|
file { '/var/lib/nagios/msmtprc':
|
2018-08-13 21:20:34 +02:00
|
|
|
ensure => file,
|
|
|
|
mode => '0600',
|
2018-08-13 21:29:40 +02:00
|
|
|
owner => 'nagios',
|
|
|
|
group => 'nagios',
|
|
|
|
content => template('zulip_ops/msmtprc_nagios.template.erb'),
|
2018-08-13 21:20:34 +02:00
|
|
|
require => File['/var/lib/nagios'],
|
2016-07-23 01:55:50 +02:00
|
|
|
}
|
|
|
|
|
2022-11-01 20:04:16 +01:00
|
|
|
file { '/var/lib/nagios/.ssh/config':
|
|
|
|
ensure => file,
|
|
|
|
mode => '0644',
|
|
|
|
owner => 'nagios',
|
|
|
|
group => 'nagios',
|
|
|
|
source => 'puppet:///modules/zulip_ops/nagios_ssh_config',
|
|
|
|
}
|
|
|
|
|
2022-01-11 01:54:05 +01:00
|
|
|
# Disable apparmor for msmtp so it can read the above config file
|
|
|
|
file { '/etc/apparmor.d/disable/usr.bin.msmtp':
|
|
|
|
ensure => link,
|
|
|
|
target => '/etc/apparmor.d/usr.bin.msmtp',
|
|
|
|
notify => Exec['reload apparmor'],
|
|
|
|
}
|
|
|
|
exec {'reload apparmor':
|
|
|
|
command => '/sbin/apparmor_parser -R /etc/apparmor.d/usr.bin.msmtp',
|
|
|
|
refreshonly => true,
|
|
|
|
}
|
|
|
|
|
2018-08-13 21:29:40 +02:00
|
|
|
exec { 'fix_nagios_permissions':
|
2022-01-11 00:55:20 +01:00
|
|
|
command => 'dpkg-statoverride --update --add nagios www-data 2710 /var/lib/nagios4/rw',
|
|
|
|
unless => 'bash -c "ls -ld /var/lib/nagios4/rw | grep ^drwx--s--- -q"',
|
|
|
|
notify => Service['nagios4'],
|
2013-06-14 20:15:12 +02:00
|
|
|
}
|
2018-08-13 21:29:40 +02:00
|
|
|
exec { 'fix_nagios_permissions2':
|
2022-01-11 00:55:20 +01:00
|
|
|
command => 'dpkg-statoverride --update --add nagios nagios 751 /var/lib/nagios4',
|
|
|
|
unless => 'bash -c "ls -ld /var/lib/nagios4 | grep ^drwxr-x--x -q"',
|
|
|
|
notify => Service['nagios4'],
|
2013-05-31 21:50:57 +02:00
|
|
|
}
|
|
|
|
|
2013-02-13 22:19:08 +01:00
|
|
|
# TODO: Install our API
|
2013-02-07 22:20:10 +01:00
|
|
|
}
|