/** Redis node-type * * @file * @author Steffen Vogel * @copyright 2014-2022, Institute for Automation of Complex Power Systems, EONERC * @license Apache 2.0 *********************************************************************************/ #pragma once #include #include #include #include #include #include #include #include #include #include #include namespace villas { namespace node { enum class RedisMode { KEY, HASH, CHANNEL }; class RedisConnection { public: sw::redis::Redis context; protected: enum State { INITIALIZED, RUNNING, STOPPING }; std::thread thread; std::atomic state; void onMessage(const std::string &channel, const std::string &msg); void loop(); std::unordered_multimap subscriberMap; sw::redis::Subscriber subscriber; villas::Logger logger; public: RedisConnection(const sw::redis::ConnectionOptions &opts); static RedisConnection * get(const sw::redis::ConnectionOptions &opts); void start(); void stop(); void subscribe(NodeCompat *n, const std::string &channel); void unsubscribe(NodeCompat *n, const std::string &channel); }; struct redis { sw::redis::ConnectionOptions options; RedisConnection *conn; enum RedisMode mode; std::string key; bool notify; /**< Use Redis Keyspace notifications to listen for updates. */ struct Task task; /**< Timer for periodic events. */ double rate; /**< Rate for polling key updates if keyspace notifications are disabled. */ Format *formatter; struct Pool pool; struct CQueueSignalled queue; }; int redis_init(NodeCompat *n); int redis_destroy(NodeCompat *n); int redis_parse(NodeCompat *n, json_t *json); char * redis_print(NodeCompat *n); int redis_check(NodeCompat *n); int redis_prepare(NodeCompat *n); int redis_start(NodeCompat *n); int redis_stop(NodeCompat *n); int redis_pause(NodeCompat *n); int redis_resume(NodeCompat *n); int redis_write(NodeCompat *n, struct Sample * const smps[], unsigned cnt); int redis_read(NodeCompat *n, struct Sample * const smps[], unsigned cnt); int redis_reverse(NodeCompat *n); int redis_poll_fds(NodeCompat *n, int fds[]); int redis_netem_fds(NodeCompat *n, int fds[]); } // namespace node } // namespace villas