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