13#ifndef RTCTK_COMPONENTFRAMEWORK_OPTIMISABLE_HPP
14#define RTCTK_COMPONENTFRAMEWORK_OPTIMISABLE_HPP
44 : m_logger(GetLogger(
"rtctk")), m_request(
request), m_arg() {
45 m_arg = JsonPayload::parse(m_request.GetRequestPayload());
64 }
catch (
const std::exception& exception) {
66 m_logger,
"OptimiseContext::SendReply: Failed to send reply: " << exception.what());
70 "OptimiseContext::SendReply: Failed to send reply with unknown exception.");
87 log4cplus::Logger& m_logger;
90 rad::cii::Request<std::string, std::string> m_request;
127template <
typename Super>
129 static_assert(std::is_base_of_v<RtcComponent, Super>,
"'Optimisable' requires 'RtcComponent'");
168 using Super::InputStage::InputStage;
171 Super::InputStage::Start();
188 this->m_engine.PostEvent(std::make_unique<events::OptimiseDone>());
192 this->m_engine.PostEvent(std::make_unique<events::OptimiseError>(std::move(
eptr)));
197 this->m_no_disable_in_states.push_back(
"On::Operational:Optimise:Busy");
201 this->m_no_update_in_states.push_back(
"On::Operational:Optimise:Busy");
210 "GuardOptimisingAllowed", [
this](
const events::Optimise&
ev) ->
bool {
219 auto act_state = this->m_engine.GetState();
227 .GuardOptimisingAllowed(
ctx.GetArg())) {
241 "ActivityOptimising",
251 engine.RegisterActionStatic<events::OptimiseDone>(
"ActionOptimisingDone",
252 [
this](
const events::OptimiseDone&) {
258 engine.RegisterActionStatic<events::OptimiseError>(
259 "ActionOptimisingFailed", [
this](
const events::OptimiseError&
ev) {
279 this->mm.ModStateType(
"On::Operational",
Parallel);
281 this->mm.AddState(
Composite,
"On::Operational:Optimise:",
"On::Operational");
282 this->mm.AddState(
Initial,
"On::Operational:Optimise:Initial",
"On::Operational:Optimise:");
283 this->mm.AddState(
Simple,
"On::Operational:Optimise:Idle",
"On::Operational:Optimise:");
284 this->mm.AddState(
Simple,
"On::Operational:Optimise:Busy",
"On::Operational:Optimise:",
"ActivityOptimising");
286 this->mm.AddTrans(
"On::Operational:Optimise:Initial" ,
"On::Operational:Optimise:Idle" );
287 this->mm.AddTrans(
"On::Operational:Optimise:Idle" ,
"On::Operational:Optimise:Busy", events::Optimise::ID,
"GuardOptimisingAllowed");
288 this->mm.AddTrans(
"On::Operational:Optimise:Busy" ,
"On::Operational:Optimise:Idle", events::OptimiseDone::ID,
"",
"ActionOptimisingDone");
289 this->mm.AddTrans(
"On::Operational:Optimise:Busy" ,
"On::Operational:Optimise:Idle", events::OptimiseError::ID,
"",
"ActionOptimisingFailed");
Adapter object intended to be used in contexts without direct access to the output-stream object.
Definition exceptions.hpp:159
static void Register(CommandReplier &replier, StateMachineEngine &engine)
Definition optCmdsImpl.hpp:37
Business logic interface for Optimisable mixin.
Definition optimisable.hpp:135
virtual bool GuardOptimisingAllowed(const JsonPayload &arg)
Determines if optimising is possible at this time with the provided argument.
Definition optimisable.hpp:158
virtual void ActivityOptimising(StopToken st, const JsonPayload &arg)
Activity executed in its own thread that performs the requested optimization.
Definition optimisable.hpp:147
Definition optimisable.hpp:275
ModelBuilder(StateMachineEngine &engine)
Definition optimisable.hpp:277
Definition optimisable.hpp:180
std::optional< detail::OptimiseContext > m_optimise_ctx
Definition optimisable.hpp:266
OutputStage(StateMachineEngine &engine, BizLogicIf &bl)
Definition optimisable.hpp:182
std::function< void()> m_optimise_success_handler
Definition optimisable.hpp:267
std::function< void(std::exception_ptr)> m_optimise_error_handler
Definition optimisable.hpp:268
std::list< std::string > m_no_optimise_in_states
Definition optimisable.hpp:269
Thrown if the command was accepted but the task to run failed.
Definition rtcComponent.hpp:53
Thrown if a command is not allowed in current state or guard.
Definition rtcComponent.hpp:40
Definition stateMachineEngine.hpp:35
void RegisterGuardStatic(const std::string &id, std::function< bool(const Event &)> guard)
Register guard for statically known event type.
Definition stateMachineEngine.hpp:126
Holds context necessary for processing a optimise request to completion.
Definition optimisable.hpp:35
const JsonPayload & GetArg() const noexcept
Definition optimisable.hpp:52
void SendErrorReply(std::exception_ptr eptr) noexcept
Send exceptional reply.
Definition optimisable.hpp:79
OptimiseContext(OptimiseContext &&) noexcept=default
void SendReply() noexcept
Sends hardcoded string reply.
Definition optimisable.hpp:61
OptimiseContext(const rad::cii::Request< std::string, std::string > &request)
Construct context with provided request.
Definition optimisable.hpp:43
Provides macros and utilities for exception handling.
Defines the JSON payload type JsonPayload.
Logging Support Library based on log4cplus.
Definition commandReplier.cpp:22
@ Simple
Definition model.hpp:23
@ Composite
Definition model.hpp:23
@ Parallel
Definition model.hpp:23
@ Initial
Definition model.hpp:23
rad::StopToken StopToken
Definition stopToken.hpp:20
const std::string STD_OK_REPLY
Definition stdComponent.hpp:86
nlohmann::json JsonPayload
Type requirements:
Definition jsonPayload.hpp:25
elt::mal::future< std::string > InjectReqRepEvent(StateMachineEngine &engine)
Definition malEventInjector.hpp:23
Implementation of MAL commands for layer 'Optimisable'.
Lifecycle of a basic 'RtcComponent'.
Life cycle extension to make RtcComponent Optimisable.
Definition optimisable.hpp:128