From 7af41e93c0d180b3637a7cdabf5ae2ab41bae858 Mon Sep 17 00:00:00 2001 From: Michael Friedrich Date: Sat, 25 Apr 2015 15:06:29 +0200 Subject: [PATCH] Fix that downtimes are always "fixed" even if scheduled as "flexible" fixes #9142 --- lib/db_ido/dbevents.cpp | 2 +- lib/icinga/externalcommandprocessor.cpp | 27 ++++++++++++++++--------- 2 files changed, 18 insertions(+), 11 deletions(-) diff --git a/lib/db_ido/dbevents.cpp b/lib/db_ido/dbevents.cpp index f11bda29e..61f667a1b 100644 --- a/lib/db_ido/dbevents.cpp +++ b/lib/db_ido/dbevents.cpp @@ -524,7 +524,7 @@ void DbEvents::AddDowntimeByType(const Checkable::Ptr& checkable, const Downtime fields1->Set("author_name", downtime->GetAuthor()); fields1->Set("comment_data", downtime->GetComment()); fields1->Set("triggered_by_id", Service::GetDowntimeByID(downtime->GetTriggeredBy())); - fields1->Set("is_fixed", downtime->GetFixed()); + fields1->Set("is_fixed", downtime->GetFixed() ? 1 : 0); fields1->Set("duration", downtime->GetDuration()); fields1->Set("scheduled_start_time", DbValue::FromTimestamp(downtime->GetStartTime())); fields1->Set("scheduled_end_time", DbValue::FromTimestamp(downtime->GetEndTime())); diff --git a/lib/icinga/externalcommandprocessor.cpp b/lib/icinga/externalcommandprocessor.cpp index 53a35f81a..ee6b6799e 100644 --- a/lib/icinga/externalcommandprocessor.cpp +++ b/lib/icinga/externalcommandprocessor.cpp @@ -988,7 +988,7 @@ void ExternalCommandProcessor::DisableHostgroupPassiveSvcChecks(double, const st void ExternalCommandProcessor::ProcessFile(double, const std::vector& arguments) { String file = arguments[0]; - bool del = Convert::ToBool(arguments[1]); + int del = Convert::ToLong(arguments[1]); std::ifstream ifp; ifp.exceptions(std::ifstream::badbit); @@ -1012,7 +1012,7 @@ void ExternalCommandProcessor::ProcessFile(double, const std::vector& ar ifp.close(); - if (del) + if (del > 0) (void) unlink(file.CStr()); } @@ -1025,6 +1025,7 @@ void ExternalCommandProcessor::ScheduleSvcDowntime(double, const std::vectorGetName(); (void) service->AddDowntime(arguments[7], arguments[8], Convert::ToDouble(arguments[2]), Convert::ToDouble(arguments[3]), - Convert::ToBool(arguments[4]), triggeredBy, Convert::ToDouble(arguments[6])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[6])); } void ExternalCommandProcessor::DelSvcDowntime(double, const std::vector& arguments) @@ -1053,6 +1054,7 @@ void ExternalCommandProcessor::ScheduleHostDowntime(double, const std::vectorAddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); } void ExternalCommandProcessor::DelHostDowntime(double, const std::vector& arguments) @@ -1082,6 +1084,7 @@ void ExternalCommandProcessor::ScheduleHostSvcDowntime(double, const std::vector String triggeredBy; int triggeredByLegacy = Convert::ToLong(arguments[4]); + int is_fixed = Convert::ToLong(arguments[3]); if (triggeredByLegacy != 0) triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy); @@ -1090,14 +1093,14 @@ void ExternalCommandProcessor::ScheduleHostSvcDowntime(double, const std::vector (void) host->AddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); BOOST_FOREACH(const Service::Ptr& service, host->GetServices()) { Log(LogNotice, "ExternalCommandProcessor") << "Creating downtime for service " << service->GetName(); (void) service->AddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); } } @@ -1110,6 +1113,7 @@ void ExternalCommandProcessor::ScheduleHostgroupHostDowntime(double, const std:: String triggeredBy; int triggeredByLegacy = Convert::ToLong(arguments[4]); + int is_fixed = Convert::ToLong(arguments[3]); if (triggeredByLegacy != 0) triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy); @@ -1119,7 +1123,7 @@ void ExternalCommandProcessor::ScheduleHostgroupHostDowntime(double, const std:: (void) host->AddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); } } @@ -1132,6 +1136,7 @@ void ExternalCommandProcessor::ScheduleHostgroupSvcDowntime(double, const std::v String triggeredBy; int triggeredByLegacy = Convert::ToLong(arguments[4]); + int is_fixed = Convert::ToLong(arguments[3]); if (triggeredByLegacy != 0) triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy); @@ -1152,7 +1157,7 @@ void ExternalCommandProcessor::ScheduleHostgroupSvcDowntime(double, const std::v << "Creating downtime for service " << service->GetName(); (void) service->AddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); } } @@ -1165,6 +1170,7 @@ void ExternalCommandProcessor::ScheduleServicegroupHostDowntime(double, const st String triggeredBy; int triggeredByLegacy = Convert::ToLong(arguments[4]); + int is_fixed = Convert::ToLong(arguments[3]); if (triggeredByLegacy != 0) triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy); @@ -1184,7 +1190,7 @@ void ExternalCommandProcessor::ScheduleServicegroupHostDowntime(double, const st << "Creating downtime for host " << host->GetName(); (void) host->AddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); } } @@ -1197,6 +1203,7 @@ void ExternalCommandProcessor::ScheduleServicegroupSvcDowntime(double, const std String triggeredBy; int triggeredByLegacy = Convert::ToLong(arguments[4]); + int is_fixed = Convert::ToLong(arguments[3]); if (triggeredByLegacy != 0) triggeredBy = Service::GetDowntimeIDFromLegacyID(triggeredByLegacy); @@ -1205,7 +1212,7 @@ void ExternalCommandProcessor::ScheduleServicegroupSvcDowntime(double, const std << "Creating downtime for service " << service->GetName(); (void) service->AddDowntime(arguments[6], arguments[7], Convert::ToDouble(arguments[1]), Convert::ToDouble(arguments[2]), - Convert::ToBool(arguments[3]), triggeredBy, Convert::ToDouble(arguments[5])); + Convert::ToBool(is_fixed), triggeredBy, Convert::ToDouble(arguments[5])); } } -- 2.40.0