mirror of https://github.com/Icinga/icinga2.git
Send event::ExecutedCommand where necessary
This commit is contained in:
parent
2e8b492f29
commit
05b1beb2ff
|
@ -231,11 +231,42 @@ void ClusterEvents::ExecuteCheckFromQueue(const MessageOrigin::Ptr& origin, cons
|
||||||
|
|
||||||
if (command_type == "check_command") {
|
if (command_type == "check_command") {
|
||||||
if (!CheckCommand::GetByName(command)) {
|
if (!CheckCommand::GetByName(command)) {
|
||||||
|
ServiceState state = ServiceUnknown;
|
||||||
|
String output = "Check command '" + command + "' does not exist.";
|
||||||
|
double now = Utility::GetTime();
|
||||||
|
|
||||||
|
if (params->Contains("source")) {
|
||||||
|
Dictionary::Ptr executedParams = new Dictionary();
|
||||||
|
executedParams->Set("execution", params->Get("source"));
|
||||||
|
executedParams->Set("host", params->Get("host"));
|
||||||
|
if (params->Contains("service"))
|
||||||
|
executedParams->Set("service", params->Get("service"));
|
||||||
|
executedParams->Set("exit", state);
|
||||||
|
executedParams->Set("output", output);
|
||||||
|
executedParams->Set("start", now);
|
||||||
|
executedParams->Set("end", now);
|
||||||
|
|
||||||
|
if (origin->IsLocal()) {
|
||||||
|
ClusterEvents::ExecutedCommandAPIHandler(origin, executedParams);
|
||||||
|
} else {
|
||||||
|
Dictionary::Ptr executedMessage = new Dictionary();
|
||||||
|
executedMessage->Set("jsonrpc", "2.0");
|
||||||
|
executedMessage->Set("method", "event::ExecutedCommand");
|
||||||
|
executedMessage->Set("params", executedParams);
|
||||||
|
|
||||||
|
listener->SyncSendMessage(sourceEndpoint, executedMessage);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
CheckResult::Ptr cr = new CheckResult();
|
CheckResult::Ptr cr = new CheckResult();
|
||||||
cr->SetState(ServiceUnknown);
|
cr->SetState(state);
|
||||||
cr->SetOutput("Check command '" + command + "' does not exist.");
|
cr->SetOutput(output);
|
||||||
|
cr->SetScheduleStart(now);
|
||||||
|
cr->SetScheduleEnd(now);
|
||||||
|
cr->SetExecutionStart(now);
|
||||||
|
cr->SetExecutionEnd(now);
|
||||||
Dictionary::Ptr message = MakeCheckResultMessage(host, cr);
|
Dictionary::Ptr message = MakeCheckResultMessage(host, cr);
|
||||||
listener->SyncSendMessage(sourceEndpoint, message);
|
listener->SyncSendMessage(sourceEndpoint, message);
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else if (command_type == "event_command") {
|
} else if (command_type == "event_command") {
|
||||||
|
@ -265,13 +296,35 @@ void ClusterEvents::ExecuteCheckFromQueue(const MessageOrigin::Ptr& origin, cons
|
||||||
try {
|
try {
|
||||||
host->ExecuteRemoteCheck(macros);
|
host->ExecuteRemoteCheck(macros);
|
||||||
} catch (const std::exception& ex) {
|
} catch (const std::exception& ex) {
|
||||||
CheckResult::Ptr cr = new CheckResult();
|
|
||||||
cr->SetState(ServiceUnknown);
|
|
||||||
|
|
||||||
String output = "Exception occurred while checking '" + host->GetName() + "': " + DiagnosticInformation(ex);
|
String output = "Exception occurred while checking '" + host->GetName() + "': " + DiagnosticInformation(ex);
|
||||||
cr->SetOutput(output);
|
ServiceState state = ServiceUnknown;
|
||||||
|
|
||||||
double now = Utility::GetTime();
|
double now = Utility::GetTime();
|
||||||
|
|
||||||
|
if (params->Contains("source")) {
|
||||||
|
Dictionary::Ptr executedParams = new Dictionary();
|
||||||
|
executedParams->Set("execution", params->Get("source"));
|
||||||
|
executedParams->Set("host", params->Get("host"));
|
||||||
|
if (params->Contains("service"))
|
||||||
|
executedParams->Set("service", params->Get("service"));
|
||||||
|
executedParams->Set("exit", state);
|
||||||
|
executedParams->Set("output", output);
|
||||||
|
executedParams->Set("start", now);
|
||||||
|
executedParams->Set("end", now);
|
||||||
|
|
||||||
|
if (origin->IsLocal()) {
|
||||||
|
ClusterEvents::ExecutedCommandAPIHandler(origin, executedParams);
|
||||||
|
} else {
|
||||||
|
Dictionary::Ptr executedMessage = new Dictionary();
|
||||||
|
executedMessage->Set("jsonrpc", "2.0");
|
||||||
|
executedMessage->Set("method", "event::ExecutedCommand");
|
||||||
|
executedMessage->Set("params", executedParams);
|
||||||
|
|
||||||
|
listener->SyncSendMessage(sourceEndpoint, executedMessage);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
CheckResult::Ptr cr = new CheckResult();
|
||||||
|
cr->SetState(state);
|
||||||
|
cr->SetOutput(output);
|
||||||
cr->SetScheduleStart(now);
|
cr->SetScheduleStart(now);
|
||||||
cr->SetScheduleEnd(now);
|
cr->SetScheduleEnd(now);
|
||||||
cr->SetExecutionStart(now);
|
cr->SetExecutionStart(now);
|
||||||
|
@ -279,6 +332,7 @@ void ClusterEvents::ExecuteCheckFromQueue(const MessageOrigin::Ptr& origin, cons
|
||||||
|
|
||||||
Dictionary::Ptr message = MakeCheckResultMessage(host, cr);
|
Dictionary::Ptr message = MakeCheckResultMessage(host, cr);
|
||||||
listener->SyncSendMessage(sourceEndpoint, message);
|
listener->SyncSendMessage(sourceEndpoint, message);
|
||||||
|
}
|
||||||
|
|
||||||
Log(LogCritical, "checker", output);
|
Log(LogCritical, "checker", output);
|
||||||
}
|
}
|
||||||
|
@ -315,9 +369,32 @@ void ClusterEvents::ExecuteCheckFromQueue(const MessageOrigin::Ptr& origin, cons
|
||||||
+ "' and user '" + user->GetName() + "' using command '" + command + "': "
|
+ "' and user '" + user->GetName() + "' using command '" + command + "': "
|
||||||
+ DiagnosticInformation(ex, false);
|
+ DiagnosticInformation(ex, false);
|
||||||
double now = Utility::GetTime();
|
double now = Utility::GetTime();
|
||||||
|
ServiceState state = ServiceUnknown;
|
||||||
|
|
||||||
|
if (params->Contains("source")) {
|
||||||
|
Dictionary::Ptr executedParams = new Dictionary();
|
||||||
|
executedParams->Set("execution", params->Get("source"));
|
||||||
|
executedParams->Set("host", params->Get("host"));
|
||||||
|
if (params->Contains("service"))
|
||||||
|
executedParams->Set("service", params->Get("service"));
|
||||||
|
executedParams->Set("exit", state);
|
||||||
|
executedParams->Set("output", output);
|
||||||
|
executedParams->Set("start", now);
|
||||||
|
executedParams->Set("end", now);
|
||||||
|
|
||||||
|
if (origin->IsLocal()) {
|
||||||
|
ClusterEvents::ExecutedCommandAPIHandler(origin, executedParams);
|
||||||
|
} else {
|
||||||
|
Dictionary::Ptr executedMessage = new Dictionary();
|
||||||
|
executedMessage->Set("jsonrpc", "2.0");
|
||||||
|
executedMessage->Set("method", "event::ExecutedCommand");
|
||||||
|
executedMessage->Set("params", executedParams);
|
||||||
|
|
||||||
|
listener->SyncSendMessage(sourceEndpoint, executedMessage);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
CheckResult::Ptr cr = new CheckResult();
|
CheckResult::Ptr cr = new CheckResult();
|
||||||
cr->SetState(ServiceUnknown);
|
cr->SetState(state);
|
||||||
cr->SetOutput(output);
|
cr->SetOutput(output);
|
||||||
cr->SetScheduleStart(now);
|
cr->SetScheduleStart(now);
|
||||||
cr->SetScheduleEnd(now);
|
cr->SetScheduleEnd(now);
|
||||||
|
@ -326,6 +403,7 @@ void ClusterEvents::ExecuteCheckFromQueue(const MessageOrigin::Ptr& origin, cons
|
||||||
|
|
||||||
Dictionary::Ptr message = MakeCheckResultMessage(host, cr);
|
Dictionary::Ptr message = MakeCheckResultMessage(host, cr);
|
||||||
listener->SyncSendMessage(sourceEndpoint, message);
|
listener->SyncSendMessage(sourceEndpoint, message);
|
||||||
|
}
|
||||||
|
|
||||||
Log(LogCritical, "checker", output);
|
Log(LogCritical, "checker", output);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue