summaryrefslogtreecommitdiff
path: root/monitoring
diff options
context:
space:
mode:
authorjonathanbouvier <jonathan.bouvier@gmail.com>2016-07-06 12:41:52 -0400
committerRené Moser <mail@renemoser.net>2016-07-06 18:41:52 +0200
commit0f01acd6c4ddadb912016b1cc4a1d53d5aa66885 (patch)
treef044ed45ed1a896639ecd33c9188e41ebd6a6206 /monitoring
parent346ec3ce3c0488142845ad052409ca57d632bc54 (diff)
downloadansible-modules-extras-0f01acd6c4ddadb912016b1cc4a1d53d5aa66885.tar.gz
added support for deleting nagios downtime (#2497)
Diffstat (limited to 'monitoring')
-rw-r--r--monitoring/nagios.py86
1 files changed, 85 insertions, 1 deletions
diff --git a/monitoring/nagios.py b/monitoring/nagios.py
index 5b6e9796..689e9f09 100644
--- a/monitoring/nagios.py
+++ b/monitoring/nagios.py
@@ -31,8 +31,9 @@ options:
description:
- Action to take.
- servicegroup options were added in 2.0.
+ - delete_downtime options were added in 2.2.
required: true
- choices: [ "downtime", "enable_alerts", "disable_alerts", "silence", "unsilence",
+ choices: [ "downtime", "delete_downtime", "enable_alerts", "disable_alerts", "silence", "unsilence",
"silence_nagios", "unsilence_nagios", "command", "servicegroup_service_downtime",
"servicegroup_host_downtime" ]
host:
@@ -109,6 +110,12 @@ EXAMPLES = '''
# set 30 minutes downtime for all host in servicegroup foo
- nagios: action=servicegroup_host_downtime minutes=30 servicegroup=foo host={{ inventory_hostname }}
+# delete all downtime for a given host
+- nagios: action=delete_downtime host={{ inventory_hostname }} service=all
+
+# delete all downtime for HOST with a particular comment
+- nagios: action=delete_downtime host={{ inventory_hostname }} service=host comment="Planned maintenance"
+
# enable SMART disk alerts
- nagios: action=enable_alerts service=smart host={{ inventory_hostname }}
@@ -181,6 +188,7 @@ def which_cmdfile():
def main():
ACTION_CHOICES = [
'downtime',
+ 'delete_downtime',
'silence',
'unsilence',
'enable_alerts',
@@ -243,6 +251,12 @@ def main():
module.fail_json(msg='invalid entry for minutes')
######################################################################
+ if action == 'delete_downtime':
+ # Make sure there's an actual service selected
+ if not services:
+ module.fail_json(msg='no service selected to set downtime for')
+
+ ######################################################################
if action in ['servicegroup_service_downtime', 'servicegroup_host_downtime']:
# Make sure there's an actual servicegroup selected
@@ -383,6 +397,47 @@ class Nagios(object):
return dt_str
+ def _fmt_dt_del_str(self, cmd, host, svc=None, start=None, comment=None):
+ """
+ Format an external-command downtime deletion string.
+
+ cmd - Nagios command ID
+ host - Host to remove scheduled downtime from
+ comment - Reason downtime was added (upgrade, reboot, etc)
+ start - Start of downtime in seconds since 12:00AM Jan 1 1970
+ svc - Service to remove downtime for, omit to remove all downtime for the host
+
+ Syntax: [submitted] COMMAND;<host_name>;
+ [<service_desription>];[<start_time>];[<comment>]
+ """
+
+ entry_time = self._now()
+ hdr = "[%s] %s;%s;" % (entry_time, cmd, host)
+
+ if comment is None:
+ comment = self.comment
+
+ dt_del_args = []
+ if svc is not None:
+ dt_del_args.append(svc)
+ else:
+ dt_del_args.append('')
+
+ if start is not None:
+ dt_del_args.append(str(start))
+ else:
+ dt_del_args.append('')
+
+ if comment is not None:
+ dt_del_args.append(comment)
+ else:
+ dt_del_args.append('')
+
+ dt_del_arg_str = ";".join(dt_del_args)
+ dt_del_str = hdr + dt_del_arg_str + "\n"
+
+ return dt_del_str
+
def _fmt_notif_str(self, cmd, host=None, svc=None):
"""
Format an external-command notification string.
@@ -462,6 +517,26 @@ class Nagios(object):
dt_cmd_str = self._fmt_dt_str(cmd, host, minutes)
self._write_command(dt_cmd_str)
+ def delete_host_downtime(self, host, services=None, comment=None):
+ """
+ This command is used to remove scheduled downtime for a particular
+ host.
+
+ Syntax: DEL_DOWNTIME_BY_HOST_NAME;<host_name>;
+ [<service_desription>];[<start_time>];[<comment>]
+ """
+
+ cmd = "DEL_DOWNTIME_BY_HOST_NAME"
+
+ if services is None:
+ dt_del_cmd_str = self._fmt_dt_del_str(cmd, host, comment=comment)
+ self._write_command(dt_del_cmd_str)
+ else:
+ for service in services:
+ dt_del_cmd_str = self._fmt_dt_del_str(cmd, host, svc=service, comment=comment)
+ self._write_command(dt_del_cmd_str)
+
+
def schedule_hostgroup_host_downtime(self, hostgroup, minutes=30):
"""
This command is used to schedule downtime for all hosts in a
@@ -891,6 +966,15 @@ class Nagios(object):
self.schedule_svc_downtime(self.host,
services=self.services,
minutes=self.minutes)
+
+ elif self.action == 'delete_downtime':
+ if self.services=='host':
+ self.delete_host_downtime(self.host)
+ elif self.services=='all':
+ self.delete_host_downtime(self.host, comment='')
+ else:
+ self.delete_host_downtime(self.host, services=self.services)
+
elif self.action == "servicegroup_host_downtime":
if self.servicegroup:
self.schedule_servicegroup_host_downtime(servicegroup = self.servicegroup, minutes = self.minutes)