]> granicus.if.org Git - icinga2/commitdiff
Implemented the external commands "ENABLE_HOST_SVC_CHECKS" and "DISABLE_HOST_SVC_CHECKS".
authorGunnar Beutner <gunnar.beutner@netways.de>
Wed, 23 Jan 2013 09:51:54 +0000 (10:51 +0100)
committerGunnar Beutner <gunnar.beutner@netways.de>
Wed, 23 Jan 2013 09:51:54 +0000 (10:51 +0100)
lib/icinga/externalcommand.cpp
lib/icinga/externalcommand.h

index aee5c9ca4a4b9a01f7ee1fe49d55872e1f0c2d6c..8c4764d34f243f8e2773c597f2c0e80639648212 100644 (file)
@@ -36,6 +36,8 @@ void ExternalCommand::Execute(double time, const String& command, const vector<S
                RegisterCommand("SHUTDOWN_PROCESS", &ExternalCommand::ShutdownProcess);
                RegisterCommand("SCHEDULE_FORCED_HOST_SVC_CHECKS", &ExternalCommand::ScheduleForcedHostSvcChecks);
                RegisterCommand("SCHEDULE_HOST_SVC_CHECKS", &ExternalCommand::ScheduleHostSvcChecks);
+               RegisterCommand("ENABLE_HOST_SVC_CHECKS", &ExternalCommand::EnableHostSvcChecks);
+               RegisterCommand("DISABLE_HOST_SVC_CHECKS", &ExternalCommand::DisableHostSvcChecks);
 
                m_Initialized = true;
        }
@@ -209,3 +211,47 @@ void ExternalCommand::ScheduleHostSvcChecks(double time, const vector<String>& a
        }
 }
 
+void ExternalCommand::EnableHostSvcChecks(double time, const vector<String>& arguments)
+{
+       if (arguments.size() < 1)
+               throw_exception(invalid_argument("Expected 1 argument."));
+
+       if (!Host::Exists(arguments[0]))
+               throw_exception(invalid_argument("The host '" + arguments[0] + "' does not exist."));
+
+       Host::Ptr host = Host::GetByName(arguments[0]);
+
+       DynamicObject::Ptr object;
+       BOOST_FOREACH(tie(tuples::ignore, object), DynamicType::GetByName("Service")->GetObjects()) {
+               Service::Ptr service = static_pointer_cast<Service>(object);
+
+               if (service->GetHost() != host)
+                       continue;
+
+               Logger::Write(LogInformation, "icinga", "Enabling checks for service '" + service->GetName() + "'");
+               service->SetEnableChecks(true);
+       }
+}
+
+void ExternalCommand::DisableHostSvcChecks(double time, const vector<String>& arguments)
+{
+       if (arguments.size() < 1)
+               throw_exception(invalid_argument("Expected 1 arguments."));
+
+       if (!Host::Exists(arguments[0]))
+               throw_exception(invalid_argument("The host '" + arguments[0] + "' does not exist."));
+
+       Host::Ptr host = Host::GetByName(arguments[0]);
+
+       DynamicObject::Ptr object;
+       BOOST_FOREACH(tie(tuples::ignore, object), DynamicType::GetByName("Service")->GetObjects()) {
+               Service::Ptr service = static_pointer_cast<Service>(object);
+
+               if (service->GetHost() != host)
+                       continue;
+
+               Logger::Write(LogInformation, "icinga", "Disabling checks for service '" + service->GetName() + "'");
+               service->SetEnableChecks(false);
+       }
+}
+
index bbeb598ddd0e23c960d73a88de73af274efb67fc..adb7eb5557b1b0d00046b0f3c59c03c09dad181f 100644 (file)
@@ -37,6 +37,8 @@ public:
        static void ShutdownProcess(double time, const vector<String>& arguments);
        static void ScheduleForcedHostSvcChecks(double time, const vector<String>& arguments);
        static void ScheduleHostSvcChecks(double time, const vector<String>& arguments);
+       static void EnableHostSvcChecks(double time, const vector<String>& arguments);
+       static void DisableHostSvcChecks(double time, const vector<String>& arguments);
 
 private:
        typedef function<void (double time, const vector<String>& arguments)> Callback;