|
|
|
@ -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:
|
|
|
|
@ -108,6 +109,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 }}
|
|
|
|
|
|
|
|
|
@ -180,6 +187,7 @@ def which_cmdfile():
|
|
|
|
|
def main():
|
|
|
|
|
ACTION_CHOICES = [
|
|
|
|
|
'downtime',
|
|
|
|
|
'delete_downtime',
|
|
|
|
|
'silence',
|
|
|
|
|
'unsilence',
|
|
|
|
|
'enable_alerts',
|
|
|
|
@ -241,6 +249,12 @@ def main():
|
|
|
|
|
except Exception:
|
|
|
|
|
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']:
|
|
|
|
@ -382,6 +396,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.
|
|
|
|
@ -461,6 +516,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
|
|
|
|
@ -890,6 +965,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)
|
|
|
|
|