blob: f67009d7bdb2f02ff935fc44b069f0c41263a6d7 [file] [log] [blame]
Rolf Badorekef2bf512019-08-20 11:17:15 +03001/*
2 Copyright (c) 2018-2019 Nokia.
3
4 Licensed under the Apache License, Version 2.0 (the "License");
5 you may not use this file except in compliance with the License.
6 You may obtain a copy of the License at
7
8 http://www.apache.org/licenses/LICENSE-2.0
9
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an "AS IS" BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
15*/
16
Timo Tietavainena0745d22019-11-28 09:55:22 +020017/*
18 * This source code is part of the near-RT RIC (RAN Intelligent Controller)
19 * platform project (RICP).
20*/
21
Rolf Badorekef2bf512019-08-20 11:17:15 +030022#ifndef SHAREDDATALAYER_SYNCSTORAGEIMPL_HPP_
23#define SHAREDDATALAYER_SYNCSTORAGEIMPL_HPP_
24
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030025#include <sdl/asyncstorage.hpp>
Rolf Badorekef2bf512019-08-20 11:17:15 +030026#include <sdl/syncstorage.hpp>
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030027#include <sys/poll.h>
Rolf Badorekef2bf512019-08-20 11:17:15 +030028#include <system_error>
29
30namespace shareddatalayer
31{
Rolf Badorekef2bf512019-08-20 11:17:15 +030032 class System;
33
34 class SyncStorageImpl: public SyncStorage
35 {
36 public:
37 explicit SyncStorageImpl(std::unique_ptr<AsyncStorage> asyncStorage);
38
39 SyncStorageImpl(std::unique_ptr<AsyncStorage> asyncStorage,
40 System& system);
41
Timo Tietavainend565df62021-08-11 07:33:30 +030042 virtual void waitReady(const Namespace& ns, const std::chrono::steady_clock::duration& timeout) override;
43
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030044 virtual void set(const Namespace& ns, const DataMap& dataMap) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030045
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030046 virtual bool setIf(const Namespace& ns, const Key& key, const Data& oldData, const Data& newData) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030047
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030048 virtual bool setIfNotExists(const Namespace& ns, const Key& key, const Data& data) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030049
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030050 virtual DataMap get(const Namespace& ns, const Keys& keys) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030051
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030052 virtual void remove(const Namespace& ns, const Keys& keys) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030053
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030054 virtual bool removeIf(const Namespace& ns, const Key& key, const Data& data) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030055
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030056 virtual Keys findKeys(const Namespace& ns, const std::string& keyPrefix) override;
Rolf Badorekef2bf512019-08-20 11:17:15 +030057
Petri Ovaska63869e12021-09-17 11:54:21 +030058 virtual Keys listKeys(const Namespace& ns, const std::string& pattern) override;
59
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030060 virtual void removeAll(const Namespace& ns) override;
61
62 virtual void setOperationTimeout(const std::chrono::steady_clock::duration& timeout) override;
63
64 static constexpr int NO_TIMEOUT = -1;
Rolf Badorekef2bf512019-08-20 11:17:15 +030065
66 private:
67 std::unique_ptr<AsyncStorage> asyncStorage;
68 System& system;
Rolf Badorekef2bf512019-08-20 11:17:15 +030069 DataMap localMap;
70 Keys localKeys;
71 bool localStatus;
72 std::error_code localError;
73 bool synced;
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030074 bool isReady;
75 struct pollfd events;
76 std::chrono::steady_clock::duration operationTimeout;
Rolf Badorekef2bf512019-08-20 11:17:15 +030077
78 void verifyBackendResponse();
79
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030080 void pollAndHandleEvents(int timeout_ms);
81
Timo Tietavainend565df62021-08-11 07:33:30 +030082 void waitForReadinessCheckCallback(const std::chrono::steady_clock::duration& timeout);
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030083
84 void waitForOperationCallback();
Rolf Badorekef2bf512019-08-20 11:17:15 +030085
86 void waitSdlToBeReady(const Namespace& ns);
87
Timo Tietavainend565df62021-08-11 07:33:30 +030088 void waitSdlToBeReady(const Namespace& ns, const std::chrono::steady_clock::duration& timeout);
89
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030090 void waitReadyAck(const std::error_code& error);
91
Rolf Badorekef2bf512019-08-20 11:17:15 +030092 void modifyAck(const std::error_code& error);
93
94 void modifyIfAck(const std::error_code& error, bool status);
95
96 void getAck(const std::error_code& error, const DataMap& dataMap);
97
98 void findKeysAck(const std::error_code& error, const Keys& keys);
Timo Tietavainenfaf9fc72021-08-05 11:46:07 +030099
100 void handlePendingEvents();
Rolf Badorekef2bf512019-08-20 11:17:15 +0300101 };
102}
103
104#endif