1 /******************************************************************************
3 * Copyright (C) 2012 Icinga Development Team (http://www.icinga.org/) *
5 * This program is free software; you can redistribute it and/or *
6 * modify it under the terms of the GNU General Public License *
7 * as published by the Free Software Foundation; either version 2 *
8 * of the License, or (at your option) any later version. *
10 * This program is distributed in the hope that it will be useful, *
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13 * GNU General Public License for more details. *
15 * You should have received a copy of the GNU General Public License *
16 * along with this program; if not, write to the Free Software Foundation *
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
18 ******************************************************************************/
20 #include "icinga/externalcommandprocessor.h"
21 #include "icinga/host.h"
22 #include "icinga/service.h"
23 #include "icinga/user.h"
24 #include "icinga/hostgroup.h"
25 #include "icinga/servicegroup.h"
26 #include "icinga/pluginchecktask.h"
27 #include "base/convert.h"
28 #include "base/logger_fwd.h"
29 #include "base/objectlock.h"
30 #include "base/application.h"
31 #include "base/utility.h"
33 #include <boost/algorithm/string/classification.hpp>
34 #include <boost/foreach.hpp>
35 #include <boost/exception/diagnostic_information.hpp>
36 #include <boost/algorithm/string/split.hpp>
38 using namespace icinga;
40 boost::once_flag ExternalCommandProcessor::m_InitializeOnce = BOOST_ONCE_INIT;
41 boost::mutex ExternalCommandProcessor::m_Mutex;
42 std::map<String, ExternalCommandProcessor::Callback> ExternalCommandProcessor::m_Commands;
44 void ExternalCommandProcessor::Execute(const String& line)
50 BOOST_THROW_EXCEPTION(std::invalid_argument("Missing timestamp in command: " + line));
52 size_t pos = line.FindFirstOf("]");
54 if (pos == String::NPos)
55 BOOST_THROW_EXCEPTION(std::invalid_argument("Missing timestamp in command: " + line));
57 String timestamp = line.SubStr(1, pos - 1);
58 String args = line.SubStr(pos + 2, String::NPos);
60 double ts = Convert::ToDouble(timestamp);
63 BOOST_THROW_EXCEPTION(std::invalid_argument("Invalid timestamp in command: " + line));
65 std::vector<String> argv;
66 boost::algorithm::split(argv, args, boost::is_any_of(";"));
69 BOOST_THROW_EXCEPTION(std::invalid_argument("Missing arguments in command: " + line));
71 std::vector<String> argvExtra(argv.begin() + 1, argv.end());
72 Execute(ts, argv[0], argvExtra);
75 void ExternalCommandProcessor::Execute(double time, const String& command, const std::vector<String>& arguments)
77 boost::call_once(m_InitializeOnce, &ExternalCommandProcessor::Initialize);
82 boost::mutex::scoped_lock lock(m_Mutex);
84 std::map<String, ExternalCommandProcessor::Callback>::iterator it;
85 it = m_Commands.find(command);
87 if (it == m_Commands.end())
88 BOOST_THROW_EXCEPTION(std::invalid_argument("The external command '" + command + "' does not exist."));
90 callback = it->second;
93 callback(time, arguments);
96 void ExternalCommandProcessor::Initialize(void)
98 RegisterCommand("PROCESS_HOST_CHECK_RESULT", &ExternalCommandProcessor::ProcessHostCheckResult);
99 RegisterCommand("PROCESS_SERVICE_CHECK_RESULT", &ExternalCommandProcessor::ProcessServiceCheckResult);
100 RegisterCommand("SCHEDULE_HOST_CHECK", &ExternalCommandProcessor::ScheduleHostCheck);
101 RegisterCommand("SCHEDULE_FORCED_HOST_CHECK", &ExternalCommandProcessor::ScheduleForcedHostCheck);
102 RegisterCommand("SCHEDULE_SVC_CHECK", &ExternalCommandProcessor::ScheduleSvcCheck);
103 RegisterCommand("SCHEDULE_FORCED_SVC_CHECK", &ExternalCommandProcessor::ScheduleForcedSvcCheck);
104 RegisterCommand("ENABLE_HOST_CHECK", &ExternalCommandProcessor::EnableHostCheck);
105 RegisterCommand("DISABLE_HOST_CHECK", &ExternalCommandProcessor::DisableHostCheck);
106 RegisterCommand("ENABLE_SVC_CHECK", &ExternalCommandProcessor::EnableSvcCheck);
107 RegisterCommand("DISABLE_SVC_CHECK", &ExternalCommandProcessor::DisableSvcCheck);
108 RegisterCommand("SHUTDOWN_PROCESS", &ExternalCommandProcessor::ShutdownProcess);
109 RegisterCommand("SCHEDULE_FORCED_HOST_SVC_CHECKS", &ExternalCommandProcessor::ScheduleForcedHostSvcChecks);
110 RegisterCommand("SCHEDULE_HOST_SVC_CHECKS", &ExternalCommandProcessor::ScheduleHostSvcChecks);
111 RegisterCommand("ENABLE_HOST_SVC_CHECKS", &ExternalCommandProcessor::EnableHostSvcChecks);
112 RegisterCommand("DISABLE_HOST_SVC_CHECKS", &ExternalCommandProcessor::DisableHostSvcChecks);
113 RegisterCommand("ACKNOWLEDGE_SVC_PROBLEM", &ExternalCommandProcessor::AcknowledgeSvcProblem);
114 RegisterCommand("ACKNOWLEDGE_SVC_PROBLEM_EXPIRE", &ExternalCommandProcessor::AcknowledgeSvcProblemExpire);
115 RegisterCommand("REMOVE_SVC_ACKNOWLEDGEMENT", &ExternalCommandProcessor::RemoveSvcAcknowledgement);
116 RegisterCommand("ACKNOWLEDGE_HOST_PROBLEM", &ExternalCommandProcessor::AcknowledgeHostProblem);
117 RegisterCommand("ACKNOWLEDGE_HOST_PROBLEM_EXPIRE", &ExternalCommandProcessor::AcknowledgeHostProblemExpire);
118 RegisterCommand("REMOVE_HOST_ACKNOWLEDGEMENT", &ExternalCommandProcessor::RemoveHostAcknowledgement);
119 RegisterCommand("DISABLE_HOST_FLAP_DETECTION", &ExternalCommandProcessor::DisableHostFlapping);
120 RegisterCommand("ENABLE_HOST_FLAP_DETECTION", &ExternalCommandProcessor::EnableHostFlapping);
121 RegisterCommand("DISABLE_SVC_FLAP_DETECTION", &ExternalCommandProcessor::DisableSvcFlapping);
122 RegisterCommand("ENABLE_SVC_FLAP_DETECTION", &ExternalCommandProcessor::EnableSvcFlapping);
123 RegisterCommand("ENABLE_HOSTGROUP_SVC_CHECKS", &ExternalCommandProcessor::EnableHostgroupSvcChecks);
124 RegisterCommand("DISABLE_HOSTGROUP_SVC_CHECKS", &ExternalCommandProcessor::DisableHostgroupSvcChecks);
125 RegisterCommand("ENABLE_SERVICEGROUP_SVC_CHECKS", &ExternalCommandProcessor::EnableServicegroupSvcChecks);
126 RegisterCommand("DISABLE_SERVICEGROUP_SVC_CHECKS", &ExternalCommandProcessor::DisableServicegroupSvcChecks);
127 RegisterCommand("ENABLE_PASSIVE_HOST_CHECKS", &ExternalCommandProcessor::EnablePassiveHostChecks);
128 RegisterCommand("DISABLE_PASSIVE_HOST_CHECKS", &ExternalCommandProcessor::DisablePassiveHostChecks);
129 RegisterCommand("ENABLE_PASSIVE_SVC_CHECKS", &ExternalCommandProcessor::EnablePassiveSvcChecks);
130 RegisterCommand("DISABLE_PASSIVE_SVC_CHECKS", &ExternalCommandProcessor::DisablePassiveSvcChecks);
131 RegisterCommand("ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS", &ExternalCommandProcessor::EnableServicegroupPassiveSvcChecks);
132 RegisterCommand("DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS", &ExternalCommandProcessor::DisableServicegroupPassiveSvcChecks);
133 RegisterCommand("ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS", &ExternalCommandProcessor::EnableHostgroupPassiveSvcChecks);
134 RegisterCommand("DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS", &ExternalCommandProcessor::DisableHostgroupPassiveSvcChecks);
135 RegisterCommand("PROCESS_FILE", &ExternalCommandProcessor::ProcessFile);
136 RegisterCommand("SCHEDULE_SVC_DOWNTIME", &ExternalCommandProcessor::ScheduleSvcDowntime);
137 RegisterCommand("DEL_SVC_DOWNTIME", &ExternalCommandProcessor::DelSvcDowntime);
138 RegisterCommand("SCHEDULE_HOST_DOWNTIME", &ExternalCommandProcessor::ScheduleHostDowntime);
139 RegisterCommand("DEL_HOST_DOWNTIME", &ExternalCommandProcessor::DelHostDowntime);
140 RegisterCommand("SCHEDULE_HOST_SVC_DOWNTIME", &ExternalCommandProcessor::ScheduleHostSvcDowntime);
141 RegisterCommand("SCHEDULE_HOSTGROUP_HOST_DOWNTIME", &ExternalCommandProcessor::ScheduleHostgroupHostDowntime);
142 RegisterCommand("SCHEDULE_HOSTGROUP_SVC_DOWNTIME", &ExternalCommandProcessor::ScheduleHostgroupSvcDowntime);
143 RegisterCommand("SCHEDULE_SERVICEGROUP_HOST_DOWNTIME", &ExternalCommandProcessor::ScheduleServicegroupHostDowntime);
144 RegisterCommand("SCHEDULE_SERVICEGROUP_SVC_DOWNTIME", &ExternalCommandProcessor::ScheduleServicegroupSvcDowntime);
145 RegisterCommand("ADD_HOST_COMMENT", &ExternalCommandProcessor::AddHostComment);
146 RegisterCommand("DEL_HOST_COMMENT", &ExternalCommandProcessor::DelHostComment);
147 RegisterCommand("ADD_SVC_COMMENT", &ExternalCommandProcessor::AddSvcComment);
148 RegisterCommand("DEL_SVC_COMMENT", &ExternalCommandProcessor::DelSvcComment);
149 RegisterCommand("DEL_ALL_HOST_COMMENTS", &ExternalCommandProcessor::DelAllHostComments);
150 RegisterCommand("DEL_ALL_SVC_COMMENTS", &ExternalCommandProcessor::DelAllSvcComments);
151 RegisterCommand("SEND_CUSTOM_HOST_NOTIFICATION", &ExternalCommandProcessor::SendCustomHostNotification);
152 RegisterCommand("SEND_CUSTOM_SVC_NOTIFICATION", &ExternalCommandProcessor::SendCustomSvcNotification);
153 RegisterCommand("DELAY_HOST_NOTIFICATION", &ExternalCommandProcessor::DelayHostNotification);
154 RegisterCommand("DELAY_SVC_NOTIFICATION", &ExternalCommandProcessor::DelaySvcNotification);
155 RegisterCommand("ENABLE_HOST_NOTIFICATIONS", &ExternalCommandProcessor::EnableHostNotifications);
156 RegisterCommand("DISABLE_HOST_NOTIFICATIONS", &ExternalCommandProcessor::DisableHostNotifications);
157 RegisterCommand("ENABLE_SVC_NOTIFICATIONS", &ExternalCommandProcessor::EnableSvcNotifications);
158 RegisterCommand("DISABLE_SVC_NOTIFICATIONS", &ExternalCommandProcessor::DisableSvcNotifications);
159 RegisterCommand("DISABLE_HOSTGROUP_HOST_CHECKS", &ExternalCommandProcessor::DisableHostgroupHostChecks);
160 RegisterCommand("DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS", &ExternalCommandProcessor::DisableHostgroupPassiveHostChecks);
161 RegisterCommand("DISABLE_SERVICEGROUP_HOST_CHECKS", &ExternalCommandProcessor::DisableServicegroupHostChecks);
162 RegisterCommand("DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS", &ExternalCommandProcessor::DisableServicegroupPassiveHostChecks);
163 RegisterCommand("ENABLE_HOSTGROUP_HOST_CHECKS", &ExternalCommandProcessor::EnableHostgroupHostChecks);
164 RegisterCommand("ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS", &ExternalCommandProcessor::EnableHostgroupPassiveHostChecks);
165 RegisterCommand("ENABLE_SERVICEGROUP_HOST_CHECKS", &ExternalCommandProcessor::EnableServicegroupHostChecks);
166 RegisterCommand("ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS", &ExternalCommandProcessor::EnableServicegroupPassiveHostChecks);
169 void ExternalCommandProcessor::RegisterCommand(const String& command, const ExternalCommandProcessor::Callback& callback)
171 boost::mutex::scoped_lock lock(m_Mutex);
172 m_Commands[command] = callback;
175 void ExternalCommandProcessor::ProcessHostCheckResult(double time, const std::vector<String>& arguments)
177 if (arguments.size() < 3)
178 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 3 arguments."));
180 Host::Ptr host = Host::GetByName(arguments[0]);
182 Service::Ptr hc = host->GetHostCheckService();
184 if (!hc->GetEnablePassiveChecks())
185 BOOST_THROW_EXCEPTION(std::invalid_argument("Got passive check result for host '" + arguments[0] + "' which has passive checks disabled."));
187 int exitStatus = Convert::ToDouble(arguments[1]);
188 Dictionary::Ptr result = PluginCheckTask::ParseCheckOutput(arguments[2]);
189 result->Set("state", PluginCheckTask::ExitStatusToState(exitStatus));
191 result->Set("schedule_start", time);
192 result->Set("schedule_end", time);
193 result->Set("execution_start", time);
194 result->Set("execution_end", time);
195 result->Set("active", 0);
197 Log(LogInformation, "icinga", "Processing passive check result for host '" + arguments[0] + "'");
198 hc->ProcessCheckResult(result);
201 ObjectLock olock(hc);
203 /* Reschedule the next check. The side effect of this is that for as long
204 * as we receive passive results for a service we won't execute any
206 hc->SetNextCheck(Utility::GetTime() + hc->GetCheckInterval());
210 void ExternalCommandProcessor::ProcessServiceCheckResult(double time, const std::vector<String>& arguments)
212 if (arguments.size() < 4)
213 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 4 arguments."));
215 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
217 if (!service->GetEnablePassiveChecks())
218 BOOST_THROW_EXCEPTION(std::invalid_argument("Got passive check result for service '" + arguments[1] + "' which has passive checks disabled."));
220 int exitStatus = Convert::ToDouble(arguments[2]);
221 Dictionary::Ptr result = PluginCheckTask::ParseCheckOutput(arguments[3]);
222 result->Set("state", PluginCheckTask::ExitStatusToState(exitStatus));
224 result->Set("schedule_start", time);
225 result->Set("schedule_end", time);
226 result->Set("execution_start", time);
227 result->Set("execution_end", time);
228 result->Set("active", 0);
230 Log(LogInformation, "icinga", "Processing passive check result for service '" + arguments[1] + "'");
231 service->ProcessCheckResult(result);
234 ObjectLock olock(service);
236 /* Reschedule the next check. The side effect of this is that for as long
237 * as we receive passive results for a service we won't execute any
239 service->SetNextCheck(Utility::GetTime() + service->GetCheckInterval());
243 void ExternalCommandProcessor::ScheduleHostCheck(double, const std::vector<String>& arguments)
245 if (arguments.size() < 2)
246 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
248 Host::Ptr host = Host::GetByName(arguments[0]);
250 Service::Ptr hc = host->GetHostCheckService();
253 Log(LogInformation, "icinga", "Ignoring request request for host '" +
254 arguments[0] + "' (does not have a host check)");
258 double planned_check = Convert::ToDouble(arguments[1]);
260 if (planned_check > hc->GetNextCheck()) {
261 Log(LogInformation, "icinga", "Ignoring reschedule request for host '" +
262 arguments[0] + "' (next check is already sooner than requested check time)");
266 Log(LogInformation, "icinga", "Rescheduling next check for host '" + arguments[0] + "'");
269 ObjectLock olock(hc);
271 hc->SetNextCheck(planned_check);
275 void ExternalCommandProcessor::ScheduleForcedHostCheck(double, const std::vector<String>& arguments)
277 if (arguments.size() < 2)
278 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
280 Host::Ptr host = Host::GetByName(arguments[0]);
282 Service::Ptr hc = host->GetHostCheckService();
285 Log(LogInformation, "icinga", "Ignoring request request for host '" +
286 arguments[0] + "' (does not have a host check)");
290 Log(LogInformation, "icinga", "Rescheduling next check for host '" + arguments[0] + "'");
293 ObjectLock olock(hc);
295 hc->SetForceNextCheck(true);
296 hc->SetNextCheck(Convert::ToDouble(arguments[1]));
300 void ExternalCommandProcessor::ScheduleSvcCheck(double, const std::vector<String>& arguments)
302 if (arguments.size() < 3)
303 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 3 arguments."));
305 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
307 double planned_check = Convert::ToDouble(arguments[2]);
309 if (planned_check > service->GetNextCheck()) {
310 Log(LogInformation, "icinga", "Ignoring reschedule request for service '" +
311 arguments[1] + "' (next check is already sooner than requested check time)");
315 Log(LogInformation, "icinga", "Rescheduling next check for service '" + arguments[1] + "'");
318 ObjectLock olock(service);
320 service->SetNextCheck(planned_check);
324 void ExternalCommandProcessor::ScheduleForcedSvcCheck(double, const std::vector<String>& arguments)
326 if (arguments.size() < 3)
327 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 3 arguments."));
329 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
331 Log(LogInformation, "icinga", "Rescheduling next check for service '" + arguments[1] + "'");
334 ObjectLock olock(service);
336 service->SetForceNextCheck(true);
337 service->SetNextCheck(Convert::ToDouble(arguments[2]));
341 void ExternalCommandProcessor::EnableHostCheck(double, const std::vector<String>& arguments)
343 if (arguments.size() < 1)
344 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
346 Host::Ptr host = Host::GetByName(arguments[0]);
348 Log(LogInformation, "icinga", "Enabling active checks for host '" + arguments[0] + "'");
349 Service::Ptr hc = host->GetHostCheckService();
355 ObjectLock olock(hc);
357 hc->SetEnableActiveChecks(true);
361 void ExternalCommandProcessor::DisableHostCheck(double, const std::vector<String>& arguments)
363 if (arguments.size() < 1)
364 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
366 Host::Ptr host = Host::GetByName(arguments[0]);
368 Log(LogInformation, "icinga", "Disabling active checks for host '" + arguments[0] + "'");
369 Service::Ptr hc = host->GetHostCheckService();
375 ObjectLock olock(hc);
377 hc->SetEnableActiveChecks(false);
381 void ExternalCommandProcessor::EnableSvcCheck(double, const std::vector<String>& arguments)
383 if (arguments.size() < 2)
384 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
386 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
388 Log(LogInformation, "icinga", "Enabling active checks for service '" + arguments[1] + "'");
391 ObjectLock olock(service);
393 service->SetEnableActiveChecks(true);
397 void ExternalCommandProcessor::DisableSvcCheck(double, const std::vector<String>& arguments)
399 if (arguments.size() < 2)
400 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
402 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
404 Log(LogInformation, "icinga", "Disabling active checks for service '" + arguments[1] + "'");
407 ObjectLock olock(service);
409 service->SetEnableActiveChecks(false);
413 void ExternalCommandProcessor::ShutdownProcess(double, const std::vector<String>&)
415 Log(LogInformation, "icinga", "Shutting down Icinga via external command.");
416 Application::RequestShutdown();
419 void ExternalCommandProcessor::ScheduleForcedHostSvcChecks(double, const std::vector<String>& arguments)
421 if (arguments.size() < 2)
422 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
424 double planned_check = Convert::ToDouble(arguments[1]);
426 Host::Ptr host = Host::GetByName(arguments[0]);
428 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
429 Log(LogInformation, "icinga", "Rescheduling next check for service '" + service->GetName() + "'");
432 ObjectLock olock(service);
434 service->SetNextCheck(planned_check);
435 service->SetForceNextCheck(true);
440 void ExternalCommandProcessor::ScheduleHostSvcChecks(double, const std::vector<String>& arguments)
442 if (arguments.size() < 2)
443 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
445 double planned_check = Convert::ToDouble(arguments[1]);
447 Host::Ptr host = Host::GetByName(arguments[0]);
449 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
450 if (planned_check > service->GetNextCheck()) {
451 Log(LogInformation, "icinga", "Ignoring reschedule request for service '" +
452 service->GetName() + "' (next check is already sooner than requested check time)");
456 Log(LogInformation, "icinga", "Rescheduling next check for service '" + service->GetName() + "'");
459 ObjectLock olock(service);
461 service->SetNextCheck(planned_check);
466 void ExternalCommandProcessor::EnableHostSvcChecks(double, const std::vector<String>& arguments)
468 if (arguments.size() < 1)
469 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
471 Host::Ptr host = Host::GetByName(arguments[0]);
473 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
474 Log(LogInformation, "icinga", "Enabling active checks for service '" + service->GetName() + "'");
475 service->SetEnableActiveChecks(true);
479 void ExternalCommandProcessor::DisableHostSvcChecks(double, const std::vector<String>& arguments)
481 if (arguments.size() < 1)
482 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
484 Host::Ptr host = Host::GetByName(arguments[0]);
486 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
487 Log(LogInformation, "icinga", "Disabling active checks for service '" + service->GetName() + "'");
490 ObjectLock olock(service);
492 service->SetEnableActiveChecks(false);
497 void ExternalCommandProcessor::AcknowledgeSvcProblem(double, const std::vector<String>& arguments)
499 if (arguments.size() < 7)
500 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 7 arguments."));
502 bool sticky = Convert::ToBool(arguments[2]);
504 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
506 if (service->GetState() == StateOK)
507 BOOST_THROW_EXCEPTION(std::invalid_argument("The service '" + arguments[1] + "' is OK."));
509 Log(LogInformation, "icinga", "Setting acknowledgement for service '" + service->GetName() + "'");
511 service->AddComment(CommentAcknowledgement, arguments[5], arguments[6], 0);
512 service->AcknowledgeProblem(arguments[5], arguments[6], sticky ? AcknowledgementSticky : AcknowledgementNormal);
515 void ExternalCommandProcessor::AcknowledgeSvcProblemExpire(double, const std::vector<String>& arguments)
517 if (arguments.size() < 8)
518 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 arguments."));
520 bool sticky = Convert::ToBool(arguments[2]);
521 double timestamp = Convert::ToDouble(arguments[5]);
523 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
525 if (service->GetState() == StateOK)
526 BOOST_THROW_EXCEPTION(std::invalid_argument("The service '" + arguments[1] + "' is OK."));
528 Log(LogInformation, "icinga", "Setting timed acknowledgement for service '" + service->GetName() + "'");
530 service->AddComment(CommentAcknowledgement, arguments[6], arguments[7], 0);
531 service->AcknowledgeProblem(arguments[6], arguments[7], sticky ? AcknowledgementSticky : AcknowledgementNormal, timestamp);
534 void ExternalCommandProcessor::RemoveSvcAcknowledgement(double, const std::vector<String>& arguments)
536 if (arguments.size() < 2)
537 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
539 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
541 Log(LogInformation, "icinga", "Removing acknowledgement for service '" + service->GetName() + "'");
543 service->ClearAcknowledgement();
546 void ExternalCommandProcessor::AcknowledgeHostProblem(double, const std::vector<String>& arguments)
548 if (arguments.size() < 6)
549 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 6 arguments."));
551 bool sticky = Convert::ToBool(arguments[1]);
553 Host::Ptr host = Host::GetByName(arguments[0]);
555 Log(LogInformation, "icinga", "Setting acknowledgement for host '" + host->GetName() + "'");
556 Service::Ptr service = host->GetHostCheckService();
558 if (service->GetState() == StateOK)
559 BOOST_THROW_EXCEPTION(std::invalid_argument("The host '" + arguments[0] + "' is OK."));
561 service->AddComment(CommentAcknowledgement, arguments[4], arguments[5], 0);
562 service->AcknowledgeProblem(arguments[4], arguments[5], sticky ? AcknowledgementSticky : AcknowledgementNormal);
566 void ExternalCommandProcessor::AcknowledgeHostProblemExpire(double, const std::vector<String>& arguments)
568 if (arguments.size() < 7)
569 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 7 arguments."));
571 bool sticky = Convert::ToBool(arguments[1]);
572 double timestamp = Convert::ToDouble(arguments[4]);
574 Host::Ptr host = Host::GetByName(arguments[0]);
576 Log(LogInformation, "icinga", "Setting timed acknowledgement for host '" + host->GetName() + "'");
577 Service::Ptr service = host->GetHostCheckService();
579 if (service->GetState() == StateOK)
580 BOOST_THROW_EXCEPTION(std::invalid_argument("The host '" + arguments[0] + "' is OK."));
582 service->AddComment(CommentAcknowledgement, arguments[5], arguments[6], 0);
583 service->AcknowledgeProblem(arguments[5], arguments[6], sticky ? AcknowledgementSticky : AcknowledgementNormal, timestamp);
587 void ExternalCommandProcessor::RemoveHostAcknowledgement(double, const std::vector<String>& arguments)
589 if (arguments.size() < 1)
590 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
592 Host::Ptr host = Host::GetByName(arguments[0]);
594 Log(LogInformation, "icinga", "Removing acknowledgement for host '" + host->GetName() + "'");
595 Service::Ptr service = host->GetHostCheckService();
597 service->ClearAcknowledgement();
600 void ExternalCommandProcessor::EnableHostgroupSvcChecks(double, const std::vector<String>& arguments)
602 if (arguments.size() < 1)
603 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
605 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
607 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
608 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
609 Log(LogInformation, "icinga", "Enabling active checks for service '" + service->GetName() + "'");
612 ObjectLock olock(service);
614 service->SetEnableActiveChecks(true);
620 void ExternalCommandProcessor::DisableHostgroupSvcChecks(double, const std::vector<String>& arguments)
622 if (arguments.size() < 1)
623 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
625 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
627 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
628 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
629 Log(LogInformation, "icinga", "Disabling active checks for service '" + service->GetName() + "'");
632 ObjectLock olock(service);
634 service->SetEnableActiveChecks(false);
640 void ExternalCommandProcessor::EnableServicegroupSvcChecks(double, const std::vector<String>& arguments)
642 if (arguments.size() < 1)
643 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
645 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
647 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
648 Log(LogInformation, "icinga", "Enabling active checks for service '" + service->GetName() + "'");
651 ObjectLock olock(service);
653 service->SetEnableActiveChecks(true);
658 void ExternalCommandProcessor::DisableServicegroupSvcChecks(double, const std::vector<String>& arguments)
660 if (arguments.size() < 1)
661 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
663 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
665 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
666 Log(LogInformation, "icinga", "Disabling active checks for service '" + service->GetName() + "'");
669 ObjectLock olock(service);
671 service->SetEnableActiveChecks(false);
676 void ExternalCommandProcessor::EnablePassiveHostChecks(double, const std::vector<String>& arguments)
678 if (arguments.size() < 1)
679 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
681 Host::Ptr host = Host::GetByName(arguments[0]);
683 Log(LogInformation, "icinga", "Enabling passive checks for host '" + arguments[0] + "'");
684 Service::Ptr hc = host->GetHostCheckService();
690 ObjectLock olock(hc);
692 hc->SetEnablePassiveChecks(true);
696 void ExternalCommandProcessor::DisablePassiveHostChecks(double, const std::vector<String>& arguments)
698 if (arguments.size() < 1)
699 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
701 Host::Ptr host = Host::GetByName(arguments[0]);
703 Log(LogInformation, "icinga", "Disabling passive checks for host '" + arguments[0] + "'");
704 Service::Ptr hc = host->GetHostCheckService();
710 ObjectLock olock(hc);
712 hc->SetEnablePassiveChecks(false);
716 void ExternalCommandProcessor::EnablePassiveSvcChecks(double, const std::vector<String>& arguments)
718 if (arguments.size() < 2)
719 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
721 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
723 Log(LogInformation, "icinga", "Enabling passive checks for service '" + arguments[1] + "'");
726 ObjectLock olock(service);
728 service->SetEnablePassiveChecks(true);
732 void ExternalCommandProcessor::DisablePassiveSvcChecks(double, const std::vector<String>& arguments)
734 if (arguments.size() < 2)
735 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
737 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
739 Log(LogInformation, "icinga", "Disabling passive checks for service '" + arguments[1] + "'");
742 ObjectLock olock(service);
744 service->SetEnablePassiveChecks(false);
748 void ExternalCommandProcessor::EnableServicegroupPassiveSvcChecks(double, const std::vector<String>& arguments)
750 if (arguments.size() < 1)
751 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
753 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
755 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
756 Log(LogInformation, "icinga", "Enabling passive checks for service '" + service->GetName() + "'");
759 ObjectLock olock(service);
761 service->SetEnablePassiveChecks(true);
766 void ExternalCommandProcessor::DisableServicegroupPassiveSvcChecks(double, const std::vector<String>& arguments)
768 if (arguments.size() < 1)
769 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
771 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
773 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
774 Log(LogInformation, "icinga", "Disabling passive checks for service '" + service->GetName() + "'");
777 ObjectLock olock(service);
779 service->SetEnablePassiveChecks(true);
784 void ExternalCommandProcessor::EnableHostgroupPassiveSvcChecks(double, const std::vector<String>& arguments)
786 if (arguments.size() < 1)
787 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
789 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
791 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
792 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
793 Log(LogInformation, "icinga", "Enabling passive checks for service '" + service->GetName() + "'");
796 ObjectLock olock(service);
798 service->SetEnablePassiveChecks(true);
804 void ExternalCommandProcessor::DisableHostgroupPassiveSvcChecks(double, const std::vector<String>& arguments)
806 if (arguments.size() < 1)
807 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
809 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
811 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
812 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
813 Log(LogInformation, "icinga", "Disabling passive checks for service '" + service->GetName() + "'");
816 ObjectLock olock(service);
818 service->SetEnablePassiveChecks(false);
824 void ExternalCommandProcessor::ProcessFile(double, const std::vector<String>& arguments)
826 if (arguments.size() < 2)
827 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
829 String file = arguments[0];
830 bool del = Convert::ToBool(arguments[1]);
833 ifp.exceptions(std::ifstream::badbit);
835 ifp.open(file.CStr(), std::ifstream::in);
839 std::getline(ifp, line);
842 Log(LogInformation, "compat", "Executing external command: " + line);
845 } catch (const std::exception& ex) {
846 std::ostringstream msgbuf;
847 msgbuf << "External command failed: " << boost::diagnostic_information(ex);
848 Log(LogWarning, "icinga", msgbuf.str());
855 (void) unlink(file.CStr());
858 void ExternalCommandProcessor::ScheduleSvcDowntime(double, const std::vector<String>& arguments)
860 if (arguments.size() < 9)
861 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 9 arguments."));
863 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
866 int triggeredByLegacy = Convert::ToLong(arguments[5]);
867 if (triggeredByLegacy != 0)
868 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
870 Log(LogInformation, "icinga", "Creating downtime for service " + service->GetName());
871 String comment_id = service->AddComment(CommentDowntime, arguments[7], arguments[8], Convert::ToDouble(arguments[3]));
872 (void) service->AddDowntime(comment_id,
873 Convert::ToDouble(arguments[2]), Convert::ToDouble(arguments[3]),
874 Convert::ToBool(arguments[4]), triggeredBy, Convert::ToDouble(arguments[6]));
877 void ExternalCommandProcessor::DelSvcDowntime(double, const std::vector<String>& arguments)
879 if (arguments.size() < 1)
880 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
882 int id = Convert::ToLong(arguments[0]);
883 Log(LogInformation, "icinga", "Removing downtime ID " + arguments[0]);
884 String rid = Service::GetDowntimeIDFromLegacyID(id);
885 Service::RemoveDowntime(rid);
888 void ExternalCommandProcessor::ScheduleHostDowntime(double, const std::vector<String>& arguments)
890 if (arguments.size() < 8)
891 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 arguments."));
893 Host::Ptr host = Host::GetByName(arguments[0]);
896 int triggeredByLegacy = Convert::ToLong(arguments[4]);
897 if (triggeredByLegacy != 0)
898 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
900 Log(LogInformation, "icinga", "Creating downtime for host " + host->GetName());
901 Service::Ptr service = host->GetHostCheckService();
903 String comment_id = service->AddComment(CommentDowntime, arguments[6], arguments[7], Convert::ToDouble(arguments[2]));
904 (void) service->AddDowntime(comment_id,
905 Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]),
906 Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5]));
910 void ExternalCommandProcessor::DelHostDowntime(double, const std::vector<String>& arguments)
912 if (arguments.size() < 1)
913 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
915 int id = Convert::ToLong(arguments[0]);
916 Log(LogInformation, "icinga", "Removing downtime ID " + arguments[0]);
917 String rid = Service::GetDowntimeIDFromLegacyID(id);
918 Service::RemoveDowntime(rid);
921 void ExternalCommandProcessor::ScheduleHostSvcDowntime(double, const std::vector<String>& arguments)
923 if (arguments.size() < 8)
924 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 argument."));
926 Host::Ptr host = Host::GetByName(arguments[0]);
929 int triggeredByLegacy = Convert::ToLong(arguments[4]);
930 if (triggeredByLegacy != 0)
931 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
933 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
934 Log(LogInformation, "icinga", "Creating downtime for service " + service->GetName());
935 String comment_id = service->AddComment(CommentDowntime, arguments[6], arguments[7], Convert::ToDouble(arguments[2]));
936 (void) service->AddDowntime(comment_id,
937 Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]),
938 Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5]));
942 void ExternalCommandProcessor::ScheduleHostgroupHostDowntime(double, const std::vector<String>& arguments)
944 if (arguments.size() < 8)
945 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 arguments."));
947 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
950 int triggeredByLegacy = Convert::ToLong(arguments[4]);
951 if (triggeredByLegacy != 0)
952 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
954 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
955 Log(LogInformation, "icinga", "Creating downtime for host " + host->GetName());
956 Service::Ptr service = host->GetHostCheckService();
958 String comment_id = service->AddComment(CommentDowntime, arguments[6], arguments[7], Convert::ToDouble(arguments[2]));
959 (void) service->AddDowntime(comment_id,
960 Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]),
961 Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5]));
966 void ExternalCommandProcessor::ScheduleHostgroupSvcDowntime(double, const std::vector<String>& arguments)
968 if (arguments.size() < 8)
969 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 arguments."));
971 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
974 int triggeredByLegacy = Convert::ToLong(arguments[4]);
975 if (triggeredByLegacy != 0)
976 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
978 /* Note: we can't just directly create downtimes for all the services by iterating
979 * over all hosts in the host group - otherwise we might end up creating multiple
980 * downtimes for some services. */
982 std::set<Service::Ptr> services;
984 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
985 BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) {
986 services.insert(service);
990 BOOST_FOREACH(const Service::Ptr& service, services) {
991 Log(LogInformation, "icinga", "Creating downtime for service " + service->GetName());
992 String comment_id = service->AddComment(CommentDowntime, arguments[6], arguments[7], Convert::ToDouble(arguments[2]));
993 (void) service->AddDowntime(comment_id,
994 Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]),
995 Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5]));
999 void ExternalCommandProcessor::ScheduleServicegroupHostDowntime(double, const std::vector<String>& arguments)
1001 if (arguments.size() < 8)
1002 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 arguments."));
1004 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
1007 int triggeredByLegacy = Convert::ToLong(arguments[4]);
1008 if (triggeredByLegacy != 0)
1009 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
1011 /* Note: we can't just directly create downtimes for all the hosts by iterating
1012 * over all services in the service group - otherwise we might end up creating multiple
1013 * downtimes for some hosts. */
1015 std::set<Service::Ptr> services;
1017 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
1018 Host::Ptr host = service->GetHost();
1019 Service::Ptr hcService = host->GetHostCheckService();
1021 services.insert(hcService);
1024 BOOST_FOREACH(const Service::Ptr& service, services) {
1025 Log(LogInformation, "icinga", "Creating downtime for service " + service->GetName());
1026 String comment_id = service->AddComment(CommentDowntime, arguments[6], arguments[7], Convert::ToDouble(arguments[2]));
1027 (void) service->AddDowntime(comment_id,
1028 Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]),
1029 Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5]));
1033 void ExternalCommandProcessor::ScheduleServicegroupSvcDowntime(double, const std::vector<String>& arguments)
1035 if (arguments.size() < 8)
1036 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 8 arguments."));
1038 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
1041 int triggeredByLegacy = Convert::ToLong(arguments[4]);
1042 if (triggeredByLegacy != 0)
1043 triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy);
1045 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
1046 Log(LogInformation, "icinga", "Creating downtime for service " + service->GetName());
1047 String comment_id = service->AddComment(CommentDowntime, arguments[6], arguments[7], Convert::ToDouble(arguments[2]));
1048 (void) service->AddDowntime(comment_id,
1049 Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]),
1050 Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5]));
1054 void ExternalCommandProcessor::AddHostComment(double, const std::vector<String>& arguments)
1056 if (arguments.size() < 4)
1057 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 4 arguments."));
1059 Host::Ptr host = Host::GetByName(arguments[0]);
1061 Log(LogInformation, "icinga", "Creating comment for host " + host->GetName());
1062 Service::Ptr service = host->GetHostCheckService();
1064 (void) service->AddComment(CommentUser, arguments[2], arguments[3], 0);
1067 void ExternalCommandProcessor::DelHostComment(double, const std::vector<String>& arguments)
1069 if (arguments.size() < 1)
1070 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1072 int id = Convert::ToLong(arguments[0]);
1073 Log(LogInformation, "icinga", "Removing comment ID " + arguments[0]);
1074 String rid = Service::GetCommentIDFromLegacyID(id);
1075 Service::RemoveComment(rid);
1078 void ExternalCommandProcessor::AddSvcComment(double, const std::vector<String>& arguments)
1080 if (arguments.size() < 5)
1081 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 5 arguments."));
1083 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1085 Log(LogInformation, "icinga", "Creating comment for service " + service->GetName());
1086 (void) service->AddComment(CommentUser, arguments[3], arguments[4], 0);
1089 void ExternalCommandProcessor::DelSvcComment(double, const std::vector<String>& arguments)
1091 if (arguments.size() < 1)
1092 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1094 int id = Convert::ToLong(arguments[0]);
1095 Log(LogInformation, "icinga", "Removing comment ID " + arguments[0]);
1097 String rid = Service::GetCommentIDFromLegacyID(id);
1098 Service::RemoveComment(rid);
1101 void ExternalCommandProcessor::DelAllHostComments(double, const std::vector<String>& arguments)
1103 if (arguments.size() < 1)
1104 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1106 Host::Ptr host = Host::GetByName(arguments[0]);
1108 Log(LogInformation, "icinga", "Removing all comments for host " + host->GetName());
1109 Service::Ptr service = host->GetHostCheckService();
1111 service->RemoveAllComments();
1114 void ExternalCommandProcessor::DelAllSvcComments(double, const std::vector<String>& arguments)
1116 if (arguments.size() < 2)
1117 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
1119 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1121 Log(LogInformation, "icinga", "Removing all comments for service " + service->GetName());
1122 service->RemoveAllComments();
1125 void ExternalCommandProcessor::SendCustomHostNotification(double, const std::vector<String>& arguments)
1127 if (arguments.size() < 4)
1128 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 4 arguments."));
1130 Host::Ptr host = Host::GetByName(arguments[0]);
1131 int options = Convert::ToLong(arguments[1]);
1133 Log(LogInformation, "icinga", "Sending custom notification for host " + host->GetName());
1134 Service::Ptr service = host->GetHostCheckService();
1137 ObjectLock olock(service);
1138 service->SetForceNextNotification(true);
1141 Service::OnNotificationsRequested(service, NotificationCustom, service->GetLastCheckResult(), arguments[2], arguments[3]);
1145 void ExternalCommandProcessor::SendCustomSvcNotification(double, const std::vector<String>& arguments)
1147 if (arguments.size() < 5)
1148 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 5 arguments."));
1150 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1151 int options = Convert::ToLong(arguments[2]);
1153 Log(LogInformation, "icinga", "Sending custom notification for service " + service->GetName());
1156 ObjectLock olock(service);
1157 service->SetForceNextNotification(true);
1160 Service::OnNotificationsRequested(service, NotificationCustom, service->GetLastCheckResult(), arguments[3], arguments[4]);
1163 void ExternalCommandProcessor::DelayHostNotification(double, const std::vector<String>& arguments)
1165 if (arguments.size() < 2)
1166 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
1168 Host::Ptr host = Host::GetByName(arguments[0]);
1170 Log(LogInformation, "icinga", "Delaying notifications for host " + host->GetName());
1171 Service::Ptr hc = host->GetHostCheckService();
1175 BOOST_FOREACH(const Notification::Ptr& notification, hc->GetNotifications()) {
1176 ObjectLock olock(notification);
1178 notification->SetNextNotification(Convert::ToDouble(arguments[1]));
1182 void ExternalCommandProcessor::DelaySvcNotification(double, const std::vector<String>& arguments)
1184 if (arguments.size() < 3)
1185 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 3 arguments."));
1187 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1189 Log(LogInformation, "icinga", "Delaying notifications for service " + service->GetName());
1191 BOOST_FOREACH(const Notification::Ptr& notification, service->GetNotifications()) {
1192 ObjectLock olock(notification);
1194 notification->SetNextNotification(Convert::ToDouble(arguments[2]));
1198 void ExternalCommandProcessor::EnableHostNotifications(double, const std::vector<String>& arguments)
1200 if (arguments.size() < 1)
1201 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1203 Host::Ptr host = Host::GetByName(arguments[0]);
1205 Log(LogInformation, "icinga", "Enabling notifications for host '" + arguments[0] + "'");
1206 Service::Ptr hc = host->GetHostCheckService();
1212 ObjectLock olock(hc);
1214 hc->SetEnableNotifications(true);
1218 void ExternalCommandProcessor::DisableHostNotifications(double, const std::vector<String>& arguments)
1220 if (arguments.size() < 1)
1221 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1223 Host::Ptr host = Host::GetByName(arguments[0]);
1225 Log(LogInformation, "icinga", "Disabling notifications for host '" + arguments[0] + "'");
1226 Service::Ptr hc = host->GetHostCheckService();
1232 ObjectLock olock(hc);
1234 hc->SetEnableNotifications(false);
1238 void ExternalCommandProcessor::EnableSvcNotifications(double, const std::vector<String>& arguments)
1240 if (arguments.size() < 2)
1241 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
1243 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1245 Log(LogInformation, "icinga", "Enabling notifications for service '" + arguments[1] + "'");
1248 ObjectLock olock(service);
1250 service->SetEnableNotifications(true);
1254 void ExternalCommandProcessor::DisableSvcNotifications(double, const std::vector<String>& arguments)
1256 if (arguments.size() < 2)
1257 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
1259 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1261 Log(LogInformation, "icinga", "Disabling notifications for service '" + arguments[1] + "'");
1264 ObjectLock olock(service);
1266 service->SetEnableNotifications(false);
1270 void ExternalCommandProcessor::DisableHostgroupHostChecks(double, const std::vector<String>& arguments)
1272 if (arguments.size() < 1)
1273 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1275 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
1277 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
1278 Service::Ptr hc = host->GetHostCheckService();
1283 Log(LogInformation, "icinga", "Disabling active checks for host '" + host->GetName() + "'");
1286 ObjectLock olock(hc);
1288 hc->SetEnableActiveChecks(false);
1293 void ExternalCommandProcessor::DisableHostgroupPassiveHostChecks(double, const std::vector<String>& arguments)
1295 if (arguments.size() < 1)
1296 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1298 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
1300 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
1301 Service::Ptr hc = host->GetHostCheckService();
1306 Log(LogInformation, "icinga", "Disabling active checks for host '" + host->GetName() + "'");
1309 ObjectLock olock(hc);
1311 hc->SetEnablePassiveChecks(false);
1316 void ExternalCommandProcessor::DisableServicegroupHostChecks(double, const std::vector<String>& arguments)
1318 if (arguments.size() < 1)
1319 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1321 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
1323 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
1324 Host::Ptr host = service->GetHost();
1329 Service::Ptr hc = host->GetHostCheckService();
1334 Log(LogInformation, "icinga", "Disabling active checks for host '" + host->GetName() + "'");
1337 ObjectLock olock(hc);
1339 hc->SetEnableActiveChecks(false);
1344 void ExternalCommandProcessor::DisableServicegroupPassiveHostChecks(double, const std::vector<String>& arguments)
1346 if (arguments.size() < 1)
1347 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1349 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
1351 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
1352 Host::Ptr host = service->GetHost();
1357 Service::Ptr hc = host->GetHostCheckService();
1362 Log(LogInformation, "icinga", "Disabling active checks for host '" + host->GetName() + "'");
1365 ObjectLock olock(hc);
1367 hc->SetEnablePassiveChecks(false);
1372 void ExternalCommandProcessor::EnableHostgroupHostChecks(double, const std::vector<String>& arguments)
1374 if (arguments.size() < 1)
1375 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1377 HostGroup::Ptr hg = HostGroup::GetByName(arguments[0]);
1379 BOOST_FOREACH(const Host::Ptr& host, hg->GetMembers()) {
1380 Service::Ptr hc = host->GetHostCheckService();
1385 Log(LogInformation, "icinga", "Enabling active checks for host '" + host->GetName() + "'");
1388 ObjectLock olock(hc);
1390 hc->SetEnableActiveChecks(true);
1395 void ExternalCommandProcessor::EnableHostgroupPassiveHostChecks(double, const std::vector<String>& arguments)
1397 if (arguments.size() < 1)
1398 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1402 void ExternalCommandProcessor::EnableServicegroupHostChecks(double, const std::vector<String>& arguments)
1404 if (arguments.size() < 1)
1405 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1407 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
1409 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
1410 Host::Ptr host = service->GetHost();
1415 Service::Ptr hc = host->GetHostCheckService();
1420 Log(LogInformation, "icinga", "Enabling active checks for host '" + host->GetName() + "'");
1423 ObjectLock olock(hc);
1425 hc->SetEnableActiveChecks(true);
1430 void ExternalCommandProcessor::EnableServicegroupPassiveHostChecks(double, const std::vector<String>& arguments)
1432 if (arguments.size() < 1)
1433 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 arguments."));
1435 ServiceGroup::Ptr sg = ServiceGroup::GetByName(arguments[0]);
1437 BOOST_FOREACH(const Service::Ptr& service, sg->GetMembers()) {
1438 Host::Ptr host = service->GetHost();
1443 Service::Ptr hc = host->GetHostCheckService();
1448 Log(LogInformation, "icinga", "Enabling active checks for host '" + host->GetName() + "'");
1451 ObjectLock olock(hc);
1453 hc->SetEnablePassiveChecks(false);
1458 void ExternalCommandProcessor::EnableHostFlapping(double, const std::vector<String>& arguments)
1460 if (arguments.size() < 1)
1461 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1463 Host::Ptr host = Host::GetByName(arguments[0]);
1465 Log(LogInformation, "icinga", "Enabling flapping detection for host '" + arguments[0] + "'");
1466 Service::Ptr hc = host->GetHostCheckService();
1472 ObjectLock olock(hc);
1474 hc->SetEnableFlapping(true);
1478 void ExternalCommandProcessor::DisableHostFlapping(double, const std::vector<String>& arguments)
1480 if (arguments.size() < 1)
1481 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 1 argument."));
1483 Host::Ptr host = Host::GetByName(arguments[0]);
1485 Log(LogInformation, "icinga", "Disabling flapping detection for host '" + arguments[0] + "'");
1486 Service::Ptr hc = host->GetHostCheckService();
1492 ObjectLock olock(hc);
1494 hc->SetEnableFlapping(false);
1498 void ExternalCommandProcessor::EnableSvcFlapping(double, const std::vector<String>& arguments)
1500 if (arguments.size() < 2)
1501 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
1503 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1505 Log(LogInformation, "icinga", "Enabling flapping detection for service '" + arguments[1] + "'");
1508 ObjectLock olock(service);
1510 service->SetEnableFlapping(true);
1514 void ExternalCommandProcessor::DisableSvcFlapping(double, const std::vector<String>& arguments)
1516 if (arguments.size() < 2)
1517 BOOST_THROW_EXCEPTION(std::invalid_argument("Expected 2 arguments."));
1519 Service::Ptr service = Service::GetByNamePair(arguments[0], arguments[1]);
1521 Log(LogInformation, "icinga", "Disabling flapping detection for service '" + arguments[1] + "'");
1524 ObjectLock olock(service);
1526 service->SetEnableFlapping(false);