summaryrefslogtreecommitdiff
path: root/include/erebos/sync.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/erebos/sync.h')
-rw-r--r--include/erebos/sync.h32
1 files changed, 32 insertions, 0 deletions
diff --git a/include/erebos/sync.h b/include/erebos/sync.h
new file mode 100644
index 0000000..662a558
--- /dev/null
+++ b/include/erebos/sync.h
@@ -0,0 +1,32 @@
+#pragma once
+
+#include <erebos/service.h>
+#include <erebos/state.h>
+#include <erebos/storage.h>
+
+#include <optional>
+#include <mutex>
+#include <vector>
+
+namespace erebos {
+
+using std::vector;
+
+class SyncService : public Service
+{
+public:
+ SyncService(Config &&, const Server &);
+ virtual ~SyncService();
+
+ UUID uuid() const override;
+ void handle(Context &) override;
+
+private:
+ void peerWatcher(size_t, const class Peer *);
+ void localStateWatcher(const vector<Ref> &);
+
+ const Server & server;
+ Watched<vector<Ref>> watchedLocal;
+};
+
+}