1 /* Icinga 2 | (c) 2012 Icinga GmbH | GPLv2+ */
6 #include "methods/dummychecktask.hpp"
7 #include "icinga/icingaapplication.hpp"
8 #include "icinga/pluginutility.hpp"
9 #include "base/utility.hpp"
10 #include "base/perfdatavalue.hpp"
11 #include "base/convert.hpp"
12 #include "base/function.hpp"
13 #include "base/logger.hpp"
15 using namespace icinga;
17 REGISTER_FUNCTION_NONCONST(Internal, DummyCheck, &DummyCheckTask::ScriptFunc, "checkable:cr:resolvedMacros:useResolvedMacros");
19 void DummyCheckTask::ScriptFunc(const Checkable::Ptr& checkable, const CheckResult::Ptr& cr,
20 const Dictionary::Ptr& resolvedMacros, bool useResolvedMacros)
22 REQUIRE_NOT_NULL(checkable);
25 CheckCommand::Ptr command = checkable->GetCheckCommand();
29 tie(host, service) = GetHostService(checkable);
31 MacroProcessor::ResolverList resolvers;
33 resolvers.emplace_back("service", service);
34 resolvers.emplace_back("host", host);
35 resolvers.emplace_back("command", command);
36 resolvers.emplace_back("icinga", IcingaApplication::GetInstance());
38 int dummyState = MacroProcessor::ResolveMacros("$dummy_state$", resolvers, checkable->GetLastCheckResult(),
39 nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
41 String dummyText = MacroProcessor::ResolveMacros("$dummy_text$", resolvers, checkable->GetLastCheckResult(),
42 nullptr, MacroProcessor::EscapeCallback(), resolvedMacros, useResolvedMacros);
44 if (resolvedMacros && !useResolvedMacros)
47 /* Parse output and performance data. */
48 std::pair<String, String> co = PluginUtility::ParseCheckOutput(dummyText);
50 double now = Utility::GetTime();
52 cr->SetOutput(co.first);
53 cr->SetPerformanceData(PluginUtility::SplitPerfdata(co.second));
54 cr->SetState(PluginUtility::ExitStatusToState(dummyState));
55 cr->SetExitStatus(dummyState);
56 cr->SetExecutionStart(now);
57 cr->SetExecutionEnd(now);
58 cr->SetCommand(command->GetName());
60 checkable->ProcessCheckResult(cr);