salsa
0.4.0
|
#include <Consumer.hh>
Public Member Functions | |
Consumer (std::string uuid, std::shared_ptr< Socket > pPipe, NodeManager *pNM) | |
virtual | ~Consumer () |
virtual void | onEnter (Message *pInMsg, std::vector< std::string > &out, std::string type) |
TODO Consumer action on ENTER event. More... | |
virtual void | onExit (Message *pInMsg, std::vector< std::string > &out) |
TODO Consumer action on EXIT event. More... | |
virtual void | onWhisper (Message *pInMsg, std::vector< std::string > &out) |
TODO Consumer action on WHISPER event. More... | |
std::string | uuid () const |
Returns distributor's UUID. More... | |
std::shared_ptr< Socket > | pipe () const |
TODO Returns distributor's pipe? More... | |
void | print () const |
TODO Prints distributor's state. More... | |
void | addClient (std::string uuid, std::string type) |
void | removeClient (std::string uuid) |
void | addOther (std::string uuid, std::string type) |
void | removeOther (std::string uuid) |
NodeInfo * | nodeInfo () const |
Static Public Member Functions | |
static std::shared_ptr< spdlog::logger > | getConsoleOutput () |
Get console output. | |
static void | setConsoleLevel (spdlog::level::level_enum level) |
Sets console log level. | |
Protected Attributes | |
std::string | mUUID {} |
Self UUID. | |
std::shared_ptr< Socket > | mpPipe = nullptr |
Pipe for messages (net connector) | |
std::map< std::string, std::string > | mClients {} |
List of clients. | |
std::map< std::string, std::string > | mOthers {} |
List of others. | |
NodeManager * | mpNodeManager = nullptr |
Node Manager. | |
NodeInfo * | mpNodeInfo {new NodeInfo()} |
Node Info. | |
TaskInfo | mTaskInfoCache {} |
Task Info cache. | |
Base Consumer class.
Definition at line 16 of file Consumer.hh.
Salsa::Consumer::Consumer | ( | std::string | uuid, |
std::shared_ptr< Socket > | pPipe, | ||
NodeManager * | pNM | ||
) |
Constructor
Definition at line 4 of file Consumer.cc.
|
virtual |
Destructor
Definition at line 10 of file Consumer.cc.
|
inherited |
Adds client
Definition at line 18 of file Distributor.cc.
References Salsa::Distributor::mClients, and Salsa::Distributor::uuid().
|
inherited |
Adds other
Definition at line 34 of file Distributor.cc.
References Salsa::Distributor::mOthers, and Salsa::Distributor::uuid().
|
inherited |
Returns node info
Definition at line 92 of file Distributor.cc.
References Salsa::Distributor::mpNodeInfo.
Referenced by Salsa::Feeder::onWhisper().
|
virtual |
TODO Consumer action on ENTER event.
onEnter
Reimplemented from Salsa::Distributor.
Definition at line 17 of file Consumer.cc.
References Salsa::Message::content().
|
virtual |
TODO Consumer action on EXIT event.
onExit
Reimplemented from Salsa::Distributor.
Definition at line 32 of file Consumer.cc.
References Salsa::Message::content(), Salsa::NodeManager::jobs(), Salsa::Distributor::mpNodeManager, Salsa::NodeManager::terminateJob(), and Salsa::Message::uuid().
|
virtual |
TODO Consumer action on WHISPER event.
onWhisper
Reimplemented from Salsa::Distributor.
Definition at line 49 of file Consumer.cc.
References Salsa::NodeManager::addTask(), Salsa::Message::content(), Salsa::Distributor::mpNodeManager, Salsa::Distributor::mUUID, Salsa::NodeManager::noMoreTasks(), Salsa::NodeManager::nSlots(), and Salsa::Message::uuid().
|
inherited |
TODO Returns distributor's pipe?
Returns pipe socket
Definition at line 77 of file Distributor.cc.
References Salsa::Distributor::mpPipe.
Referenced by Salsa::Feeder::subscribe(), and Salsa::Feeder::terminateJob().
|
inherited |
TODO Prints distributor's state.
Prints info
Definition at line 50 of file Distributor.cc.
References Salsa::Distributor::mClients, Salsa::Distributor::mOthers, and Salsa::Distributor::mpPipe.
|
inherited |
Remove client
Definition at line 26 of file Distributor.cc.
References Salsa::Distributor::mClients, and Salsa::Distributor::uuid().
|
inherited |
Remove other
Definition at line 42 of file Distributor.cc.
References Salsa::Distributor::mOthers, and Salsa::Distributor::uuid().
|
inherited |
Returns distributor's UUID.
Returns uuid
Definition at line 84 of file Distributor.cc.
References Salsa::Distributor::mUUID.
Referenced by Salsa::Distributor::addClient(), Salsa::Distributor::addOther(), Salsa::Distributor::removeClient(), Salsa::Distributor::removeOther(), Salsa::Feeder::removeWorkerTask(), Salsa::Feeder::subscribe(), and Salsa::Feeder::terminateJob().