1 /*
2 * Copyright (c) 2021 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include "sqlite_single_ver_continue_token.h"
17 #include "sqlite_single_ver_storage_executor_sql.h"
18 #include "sqlite_utils.h"
19
20 namespace DistributedDB {
SQLiteSingleVerContinueToken(Timestamp begin,Timestamp end)21 SQLiteSingleVerContinueToken::SQLiteSingleVerContinueToken(Timestamp begin, Timestamp end)
22 : timeRanges_(MulDevTimeRanges{{"", {begin, end}}})
23 {}
24
SQLiteSingleVerContinueToken(const SyncTimeRange & timeRange,const QueryObject & queryObject)25 SQLiteSingleVerContinueToken::SQLiteSingleVerContinueToken(
26 const SyncTimeRange &timeRange, const QueryObject &queryObject)
27 : queryObject_(std::map<DeviceID, QueryObject>{{"", queryObject}}),
28 timeRanges_(MulDevTimeRanges{{"", {timeRange.beginTime, timeRange.endTime}}}),
29 deleteTimeRanges_(MulDevTimeRanges{{"", {timeRange.deleteBeginTime, timeRange.deleteEndTime}}})
30 {}
31
SQLiteSingleVerContinueToken(MulDevTimeRanges timeRanges)32 SQLiteSingleVerContinueToken::SQLiteSingleVerContinueToken(MulDevTimeRanges timeRanges)
33 : timeRanges_(timeRanges)
34 {}
35
~SQLiteSingleVerContinueToken()36 SQLiteSingleVerContinueToken::~SQLiteSingleVerContinueToken()
37 {}
38
CheckValid() const39 bool SQLiteSingleVerContinueToken::CheckValid() const
40 {
41 return ((magicBegin_ == MAGIC_BEGIN) && (magicEnd_ == MAGIC_END));
42 }
43
GetQueryBeginTime() const44 Timestamp SQLiteSingleVerContinueToken::GetQueryBeginTime() const
45 {
46 return GetBeginTimestamp(timeRanges_);
47 }
48
GetQueryEndTime() const49 Timestamp SQLiteSingleVerContinueToken::GetQueryEndTime() const
50 {
51 return GetEndTimestamp(timeRanges_);
52 }
53
GetDeletedBeginTime() const54 Timestamp SQLiteSingleVerContinueToken::GetDeletedBeginTime() const
55 {
56 return GetBeginTimestamp(deleteTimeRanges_);
57 }
58
GetDeletedEndTime() const59 Timestamp SQLiteSingleVerContinueToken::GetDeletedEndTime() const
60 {
61 return GetEndTimestamp(deleteTimeRanges_);
62 }
63
SetNextBeginTime(const DeviceID & deviceID,Timestamp nextBeginTime)64 void SQLiteSingleVerContinueToken::SetNextBeginTime(const DeviceID &deviceID, Timestamp nextBeginTime)
65 {
66 RemovePrevDevAndSetBeginTime(deviceID, nextBeginTime, timeRanges_);
67 }
68
GetTimeRanges()69 const MulDevTimeRanges& SQLiteSingleVerContinueToken::GetTimeRanges()
70 {
71 return timeRanges_;
72 }
73
SetDeletedNextBeginTime(const DeviceID & deviceID,Timestamp nextBeginTime)74 void SQLiteSingleVerContinueToken::SetDeletedNextBeginTime(const DeviceID &deviceID, Timestamp nextBeginTime)
75 {
76 RemovePrevDevAndSetBeginTime(deviceID, nextBeginTime, deleteTimeRanges_);
77 }
78
GetDeletedTimeRanges() const79 const MulDevTimeRanges& SQLiteSingleVerContinueToken::GetDeletedTimeRanges() const
80 {
81 return deleteTimeRanges_;
82 }
83
FinishGetQueryData()84 void SQLiteSingleVerContinueToken::FinishGetQueryData()
85 {
86 timeRanges_.clear();
87 }
88
FinishGetDeletedData()89 void SQLiteSingleVerContinueToken::FinishGetDeletedData()
90 {
91 deleteTimeRanges_.clear();
92 }
93
IsGetQueryDataFinished() const94 bool SQLiteSingleVerContinueToken::IsGetQueryDataFinished() const
95 {
96 return timeRanges_.empty();
97 }
98
IsGetDeletedDataFinished() const99 bool SQLiteSingleVerContinueToken::IsGetDeletedDataFinished() const
100 {
101 return deleteTimeRanges_.empty();
102 }
103
IsQuerySync() const104 bool SQLiteSingleVerContinueToken::IsQuerySync() const
105 {
106 return !queryObject_.empty();
107 }
108
GetQuery() const109 QueryObject SQLiteSingleVerContinueToken::GetQuery() const
110 {
111 if (!queryObject_.empty()) {
112 return queryObject_.begin()->second;
113 }
114 return QueryObject{};
115 }
116
RemovePrevDevAndSetBeginTime(const DeviceID & deviceID,Timestamp nextBeginTime,MulDevTimeRanges & timeRanges)117 void SQLiteSingleVerContinueToken::RemovePrevDevAndSetBeginTime(const DeviceID &deviceID, Timestamp nextBeginTime,
118 MulDevTimeRanges &timeRanges)
119 {
120 auto iter = timeRanges.find(deviceID);
121 if (iter == timeRanges.end()) {
122 return;
123 }
124 iter = timeRanges.erase(timeRanges.begin(), iter);
125 iter->second.first = nextBeginTime;
126 }
127
GetBeginTimestamp(const MulDevTimeRanges & timeRanges) const128 Timestamp SQLiteSingleVerContinueToken::GetBeginTimestamp(const MulDevTimeRanges &timeRanges) const
129 {
130 if (timeRanges.empty()) {
131 return 0;
132 }
133 return timeRanges.begin()->second.first;
134 }
135
GetEndTimestamp(const MulDevTimeRanges & timeRanges) const136 Timestamp SQLiteSingleVerContinueToken::GetEndTimestamp(const MulDevTimeRanges &timeRanges) const
137 {
138 if (timeRanges.empty()) {
139 return static_cast<Timestamp>(INT64_MAX);
140 }
141 return timeRanges.begin()->second.second;
142 }
143
GetCloudQueryStmt(sqlite3 * db,bool forcePush,bool & stepNext,const CloudWaterType mode)144 std::pair<int, sqlite3_stmt *> SQLiteSingleVerContinueToken::GetCloudQueryStmt(sqlite3 *db, bool forcePush,
145 bool &stepNext, const CloudWaterType mode)
146 {
147 if (queryDataStmt_ != nullptr) {
148 return {E_OK, queryDataStmt_};
149 }
150 std::pair<int, sqlite3_stmt *> res;
151 int &errCode = res.first;
152 sqlite3_stmt *&stmt = res.second;
153 SqliteQueryHelper helper = GetQuery().GetQueryHelper(errCode);
154 if (errCode != E_OK) {
155 return res;
156 }
157 std::tie(errCode, stmt) = helper.GetKvCloudQueryStmt(db, forcePush, mode, timeRanges_[""].first, user_);
158 if (errCode != E_OK) {
159 return res;
160 }
161 queryDataStmt_ = stmt;
162 stepNext = true;
163 return res;
164 }
165
ReleaseCloudQueryStmt()166 void SQLiteSingleVerContinueToken::ReleaseCloudQueryStmt()
167 {
168 if (queryDataStmt_ == nullptr) {
169 return;
170 }
171 int errCode = E_OK;
172 SQLiteUtils::ResetStatement(queryDataStmt_, true, errCode);
173 queryDataStmt_ = nullptr;
174 if (errCode != E_OK) {
175 LOGW("[SQLiteSingleVerContinueToken] release cloud query stmt failed %d", errCode);
176 }
177 }
178
SetUser(const std::string & user)179 void SQLiteSingleVerContinueToken::SetUser(const std::string &user)
180 {
181 user_ = user;
182 }
183 } // namespace DistributedDB
184