/** Redis node-type * * @file * @author Steffen Vogel * @copyright 2014-2022, Institute for Automation of Complex Power Systems, EONERC * @license GNU General Public License (version 3) * * VILLASnode * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . *********************************************************************************/ #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 */