control: Store/use trigger enable functions on events
Create and store trigger enablement functions on the events based on the
trigger's configuration so that they can be enabled separately from when
the event is created. This will allow actions that load events to be
able to be parsed and then enabled when the action determines that the
events should be enabled. It also supports the use of SIGHUP to reload
the event configuration since the events JSON configuration must
successfully be loaded before the newly created events can be enabled in
place of the currently enabled events.
Change-Id: I31871ee1691d5e6b26fe16cde2a829c426ad6504
Signed-off-by: Matthew Barth <msbarth@us.ibm.com>
diff --git a/control/json/triggers/timer.cpp b/control/json/triggers/timer.cpp
index 641e33b..fcb5e95 100644
--- a/control/json/triggers/timer.cpp
+++ b/control/json/triggers/timer.cpp
@@ -16,6 +16,7 @@
#include "timer.hpp"
#include "../manager.hpp"
+#include "trigger_aliases.hpp"
#include <fmt/format.h>
@@ -69,17 +70,20 @@
jsonObj["interval"].get<uint64_t>());
}
-void triggerTimer(const json& jsonObj, const std::string& eventName,
- Manager* mgr,
- std::vector<std::unique_ptr<ActionBase>>& actions)
+enableTrigger triggerTimer(const json& jsonObj, const std::string& eventName,
+ Manager* mgr,
+ std::vector<std::unique_ptr<ActionBase>>& actions)
{
// Get the type and interval of this timer from the JSON
auto type = getType(jsonObj);
auto interval = getInterval(jsonObj);
- // Create/add event timer
- auto tpPtr = std::make_unique<TimerPkg>(eventName, std::ref(actions));
- mgr->addTimer(type, interval, std::move(tpPtr));
+ return [type = std::move(type), interval = std::move(interval)](
+ const std::string& eventName, Manager* mgr,
+ std::vector<std::unique_ptr<ActionBase>>& actions) {
+ auto tpPtr = std::make_unique<TimerPkg>(eventName, std::ref(actions));
+ mgr->addTimer(type, interval, std::move(tpPtr));
+ };
}
} // namespace phosphor::fan::control::json::trigger::timer