added support for deleting nagios downtime (#2497)

This commit is contained in:
jonathanbouvier 2016-07-06 12:41:52 -04:00 committed by René Moser
parent 346ec3ce3c
commit 0f01acd6c4

View file

@ -31,8 +31,9 @@ options:
description: description:
- Action to take. - Action to take.
- servicegroup options were added in 2.0. - servicegroup options were added in 2.0.
- delete_downtime options were added in 2.2.
required: true 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", "silence_nagios", "unsilence_nagios", "command", "servicegroup_service_downtime",
"servicegroup_host_downtime" ] "servicegroup_host_downtime" ]
host: host:
@ -109,6 +110,12 @@ EXAMPLES = '''
# set 30 minutes downtime for all host in servicegroup foo # set 30 minutes downtime for all host in servicegroup foo
- nagios: action=servicegroup_host_downtime minutes=30 servicegroup=foo host={{ inventory_hostname }} - 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 # enable SMART disk alerts
- nagios: action=enable_alerts service=smart host={{ inventory_hostname }} - nagios: action=enable_alerts service=smart host={{ inventory_hostname }}
@ -181,6 +188,7 @@ def which_cmdfile():
def main(): def main():
ACTION_CHOICES = [ ACTION_CHOICES = [
'downtime', 'downtime',
'delete_downtime',
'silence', 'silence',
'unsilence', 'unsilence',
'enable_alerts', 'enable_alerts',
@ -242,6 +250,12 @@ def main():
except Exception: except Exception:
module.fail_json(msg='invalid entry for minutes') 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']: if action in ['servicegroup_service_downtime', 'servicegroup_host_downtime']:
@ -383,6 +397,47 @@ class Nagios(object):
return dt_str 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): def _fmt_notif_str(self, cmd, host=None, svc=None):
""" """
Format an external-command notification string. Format an external-command notification string.
@ -462,6 +517,26 @@ class Nagios(object):
dt_cmd_str = self._fmt_dt_str(cmd, host, minutes) dt_cmd_str = self._fmt_dt_str(cmd, host, minutes)
self._write_command(dt_cmd_str) 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): def schedule_hostgroup_host_downtime(self, hostgroup, minutes=30):
""" """
This command is used to schedule downtime for all hosts in a 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, self.schedule_svc_downtime(self.host,
services=self.services, services=self.services,
minutes=self.minutes) 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": elif self.action == "servicegroup_host_downtime":
if self.servicegroup: if self.servicegroup:
self.schedule_servicegroup_host_downtime(servicegroup = self.servicegroup, minutes = self.minutes) self.schedule_servicegroup_host_downtime(servicegroup = self.servicegroup, minutes = self.minutes)