--- /dev/null
+/*
+ Copyright (c) 2018-2019 Nokia.
+
+ Licensed under the Apache License, Version 2.0 (the "License");
+ you may not use this file except in compliance with the License.
+ You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+ Unless required by applicable law or agreed to in writing, software
+ distributed under the License is distributed on an "AS IS" BASIS,
+ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ See the License for the specific language governing permissions and
+ limitations under the License.
+*/
+
+#ifndef SHAREDDATALAYER_REDIS_HIREDISCLUSTEREPOLLADAPTER_HPP_
+#define SHAREDDATALAYER_REDIS_HIREDISCLUSTEREPOLLADAPTER_HPP_
+
+#include <map>
+#include <memory>
+
+extern "C"
+{
+ struct redisClusterAsyncContext;
+ struct redisAsyncContext;
+}
+
+namespace shareddatalayer
+{
+ class Engine;
+
+ namespace redis
+ {
+ class HiredisClusterSystem;
+
+ class HiredisClusterEpollAdapter
+ {
+ public:
+ class Node;
+
+ explicit HiredisClusterEpollAdapter(Engine& engine);
+
+ HiredisClusterEpollAdapter(Engine& engine, HiredisClusterSystem& hiredisClusterSystem);
+
+ virtual ~HiredisClusterEpollAdapter() = default;
+
+ virtual void setup(redisClusterAsyncContext* acc);
+
+ virtual void attach(redisAsyncContext* ac);
+
+ virtual void detach(const redisAsyncContext* ac);
+
+ HiredisClusterEpollAdapter(const HiredisClusterEpollAdapter&) = delete;
+ HiredisClusterEpollAdapter(HiredisClusterEpollAdapter&&) = delete;
+ HiredisClusterEpollAdapter& operator = (const HiredisClusterEpollAdapter&) = delete;
+ HiredisClusterEpollAdapter& operator = (HiredisClusterEpollAdapter&&) = delete;
+
+ private:
+ Engine& engine;
+ HiredisClusterSystem& hiredisClusterSystem;
+ std::map<int, std::unique_ptr<Node>> nodes;
+ };
+
+ class HiredisClusterEpollAdapter::Node
+ {
+ public:
+ Node(Engine& engine,
+ redisAsyncContext* ac,
+ HiredisClusterSystem& hiredisClusterSystem);
+
+ ~Node();
+
+ void addRead();
+
+ void addWrite();
+
+ void delRead();
+
+ void delWrite();
+
+ void cleanup();
+
+ Node(const Node&) = delete;
+ Node(Node&&) = delete;
+ Node& operator = (const Node&) = delete;
+ Node& operator = (Node&&) = delete;
+
+ private:
+ Engine& engine;
+ HiredisClusterSystem& hiredisClusterSystem;
+ redisAsyncContext* ac;
+ unsigned int eventState;
+ bool reading;
+ bool writing;
+ bool isMonitoring;
+
+ void eventHandler(unsigned int events);
+ };
+ }
+}
+
+#endif