ifw-fcf
2.0.0
|
Lamp Local Control System (LCS) Interface (IF) class. More...
#include <lampLcsIf.hpp>
Public Member Functions | |
LampLcsIf (std::shared_ptr< devmgr::common::IDeviceConfig > config, devmgr::common::DataContext &data_ctx, bool initialise=true) | |
LampLcsIf constructor. More... | |
virtual | ~LampLcsIf () |
Default destructor. More... | |
virtual bool | IsReady () |
Check if controller is in Standby/Ready state. More... | |
virtual bool | IsOperational () |
Check if controller is in Operational. More... | |
void | SwitchOn (double intensity, unsigned int time) |
Executes the SwitchOn RPC. More... | |
void | SwitchOff () |
Executes the SwitchOff RPC. More... | |
bool | IsTurningOn () |
Check if controller is switching the lamp on. More... | |
bool | IsTurningOff () |
Check if controller is switching the lamp off. More... | |
bool | IsOn () |
Check if lamp is on. More... | |
bool | IsOff () |
Check if lamp is off. More... | |
virtual void | ReadStatus (LampControllerData &status) |
Read status from the controller. More... | |
void | Listener (fcf::common::VectorVariant ¶ms) |
Callback to manageUpdateStatus(); changes on the monitored items. More... | |
virtual std::string | GetRpcError (const short error_code) const |
Public Member Functions inherited from fcf::devmgr::common::DeviceLcsIf | |
DeviceLcsIf (std::shared_ptr< IDeviceConfig > config, DataContext &data_ctx) | |
DeviceLcsIf constructor. More... | |
virtual void | RegisterComm (std::shared_ptr< fcf::common::IComm > comm_if, fcf::common::Dispatcher<> &failure, fcf::common::Dispatcher<> &normal) |
Register a communication interface. More... | |
virtual void | Connect () |
Connect to the controller or simulator. More... | |
virtual void | Disconnect () |
Disconnect from the controller of simulator. More... | |
virtual void | ReadConfig (const std::vector< std::string > &stat_map_vector, const std::vector< std::string > &rpc_map_vector) |
Read the configuration. More... | |
virtual bool | IsNotReady () |
Check if controller is in Standby/NotReady state. More... | |
virtual bool | IsDisabling () |
Check if controller is in Disabling state. More... | |
virtual bool | IsHwFailure () |
Check if controller is in Hardware Failure. More... | |
virtual void | Init () |
Executes the Init RPC. More... | |
virtual void | Enable () |
Executes the Enable RPC. More... | |
virtual void | Disable () |
Executes the Disable RPC. More... | |
virtual void | Stop () |
Executes the Stop RPC. More... | |
virtual void | Reset () |
Executes the Reset RPC. More... | |
virtual void | StartMonitoring () |
Start monitoring of controller attributes. More... | |
virtual void | StopMonitoring () |
Stop monitoring of controller attributes. More... | |
virtual std::string | GetHwError (int &error_code, const bool update=false) |
Get error message. More... | |
std::string | GetMapValue (std::string category, std::string key) |
Get mapping valLampConfigue. More... | |
fcf::common::Dispatcher < fcf::common::VectorVariant & > & | GetDispatcher () |
bool | IsConfigLoaded () const |
Check if configuration was loaded. More... | |
bool | IsConnected () const |
Check is the communication was established. More... | |
virtual std::shared_ptr < IDeviceConfig > | GetDeviceConfig () |
Get a pointer of device configuration. More... | |
Protected Attributes | |
std::unique_ptr < rad::cii::Publisher < TOPIC_TYPE > > | m_publisher |
Protected Attributes inherited from fcf::devmgr::common::DeviceLcsIf | |
YAML::Node | m_config_node |
YAML node for the device mapping file. More... | |
std::shared_ptr < fcf::common::IComm > | m_comm |
Shared pointer to the communication object. More... | |
std::shared_ptr< IDeviceConfig > | m_config |
Shared pointer to the device config object. More... | |
fcf::common::Dispatcher < fcf::common::VectorVariant & > | m_dispatcher |
Dispatcher for managing subscription events. More... | |
fcf::common::Dispatcher | m_failure |
Dispatcher for managing failures in the communication. More... | |
fcf::common::Dispatcher | m_normal |
Dispatcher for managing recovery of communication failures. More... | |
short | m_state |
Actual controller state. More... | |
short | m_substate |
Actual controller substate. More... | |
bool | m_config_loaded |
Flag indicating whether the configuration was successfully loaded. More... | |
bool | m_connected |
Flag indicating whether the LCS is connected. More... | |
devmgr::common::DataContext & | m_data_ctx |
std::string | m_lcs_prefix |
Store the prefix for storing keys in the database. More... | |
elt::mal::Mal::Properties | m_mal_properties |
std::string | m_pub_endpoint |
std::unordered_map < std::string, short > | m_ua_status_map |
std::vector< std::string > | m_ua_monitor_vector |
std::unordered_map< short, std::string > | m_hw_errors |
Additional Inherited Members | |
Public Types inherited from fcf::devmgr::common::DeviceLcsIf | |
enum | { STAT_LOCAL = 1, STAT_ERROR = 2, STAT_HW_STATUS = 3, STAT_STATE = 4, STAT_SUBSTATE = 5 } |
Protected Member Functions inherited from fcf::devmgr::common::DeviceLcsIf | |
void | LoadConfig () |
Load the YAML configuration. More... | |
void | ExecuteRpc (const std::string &obj, const std::string &proc, fcf::common::VectorVariant &attr_list) |
int | ReadErrorCode () |
void | GetStates (int &state, int &substate) |
Get states (state and substate) of the controller. More... | |
void | StoreUaNames (const std::vector< std::pair< std::string, unsigned int >> &ualist) |
StoreUaNames. More... | |
void | StoreAttribute (const std::string key, const fcf::common::Variant &value, int attribute) |
Store the updated into the DB. More... | |
Lamp Local Control System (LCS) Interface (IF) class.
This class manages the lamp connection to the LCS encapsulating all basic communication with the controller or the simulator.
Each RPC call is synchronous but it only starts the action in the controller. The controller will return successfully if the action can be started, not that the action was completed.
The completion of the action must be monitored by reading the status of the controller but this is out of the scope of this class.
fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::LampLcsIf | ( | std::shared_ptr< devmgr::common::IDeviceConfig > | config, |
devmgr::common::DataContext & | data_ctx, | ||
bool | initialise = true |
||
) |
LampLcsIf constructor.
[in,out] | config | Shared pointer to the device configuration. |
[in,out] | data_ctx | Reference to the data context object. |
[in] | initialise | Flag to control the initialization. This flag is used when using child classes. |
|
inlinevirtual |
Default destructor.
|
virtual |
error_code | Error code |
Implements fcf::devmgr::common::DeviceLcsIf.
bool fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::IsOff | ( | ) |
Check if lamp is off.
bool fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::IsOn | ( | ) |
Check if lamp is on.
|
virtual |
Check if controller is in Operational.
Reimplemented from fcf::devmgr::common::DeviceLcsIf.
|
virtual |
Check if controller is in Standby/Ready state.
Reimplemented from fcf::devmgr::common::DeviceLcsIf.
bool fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::IsTurningOff | ( | ) |
Check if controller is switching the lamp off.
bool fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::IsTurningOn | ( | ) |
Check if controller is switching the lamp on.
|
virtual |
Callback to manageUpdateStatus(); changes on the monitored items.
[in] | params | Vector containing the list of atributes that have changed |
This method implement the actions associated to the events originated from the monitoring of attributes.
This method is storing in the database the values that have changed. It also publish the events for the clients via zeroMQ.
Implements fcf::devmgr::common::DeviceLcsIf.
|
virtual |
Read status from the controller.
status | structure containing the status of the controller. |
void fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::SwitchOff | ( | ) |
Executes the SwitchOff RPC.
an | exception if an error ocurrs. |
This RPC call shall bring the controller to Operational/Off state.
void fcf::devmgr::lamp::LampLcsIf< TOPIC_TYPE >::SwitchOn | ( | double | intensity, |
unsigned int | time | ||
) |
Executes the SwitchOn RPC.
an | exception if an error ocurrs. |
This RPC call shall bring the controller to Operational/On state.
|
protected |