ZeroTierOne/controller/RedisStatusWriter.hpp
Grant Limberg 85f23356a3
Some checks failed
/ build_macos (push) Has been cancelled
/ build_windows (push) Has been cancelled
/ build_ubuntu (push) Has been cancelled
add a StatusWriter class hierarchy for writing member status updates
* Postgres Direct
* Redis
* BigTable
2025-08-28 17:03:59 -07:00

46 lines
No EOL
1.2 KiB
C++

#ifndef REDIS_STATUS_WRITER_HPP
#define REDIS_STATUS_WRITER_HPP
#include "Redis.hpp"
#include "StatusWriter.hpp"
#include <memory>
#include <mutex>
#include <sw/redis++/redis++.h>
namespace ZeroTier {
class RedisStatusWriter : public StatusWriter {
public:
RedisStatusWriter(std::shared_ptr<sw::redis::Redis> redis, std::string controller_id);
RedisStatusWriter(std::shared_ptr<sw::redis::RedisCluster> cluster, std::string controller_id);
virtual ~RedisStatusWriter();
virtual void updateNodeStatus(
const std::string& network_id,
const std::string& node_id,
const std::string& os,
const std::string& arch,
const std::string& version,
const InetAddress& address,
int64_t last_seen) override;
virtual size_t queueLength() const override;
virtual void writePending() override;
private:
void _doWritePending(sw::redis::Transaction& tx);
std::string _controller_id;
enum RedisMode { REDIS_MODE_STANDALONE, REDIS_MODE_CLUSTER };
std::shared_ptr<sw::redis::Redis> _redis;
std::shared_ptr<sw::redis::RedisCluster> _cluster;
RedisMode _mode = REDIS_MODE_STANDALONE;
mutable std::mutex _lock;
std::vector<PendingStatusEntry> _pending;
};
} // namespace ZeroTier
#endif // REDIS_STATUS_WRITER_HPP