@powersync/service-module-mongodb-storage 0.0.0-dev-20260203155513 → 0.0.0-dev-20260223080959
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +56 -10
- package/dist/migrations/db/migrations/1770213298299-storage-version.js +29 -0
- package/dist/migrations/db/migrations/1770213298299-storage-version.js.map +1 -0
- package/dist/storage/MongoBucketStorage.d.ts +7 -15
- package/dist/storage/MongoBucketStorage.js +12 -51
- package/dist/storage/MongoBucketStorage.js.map +1 -1
- package/dist/storage/MongoReportStorage.d.ts +1 -11
- package/dist/storage/MongoReportStorage.js +1 -321
- package/dist/storage/MongoReportStorage.js.map +1 -1
- package/dist/storage/implementation/MongoChecksums.d.ts +5 -2
- package/dist/storage/implementation/MongoChecksums.js +7 -4
- package/dist/storage/implementation/MongoChecksums.js.map +1 -1
- package/dist/storage/implementation/MongoCompactor.d.ts +16 -1
- package/dist/storage/implementation/MongoCompactor.js +80 -23
- package/dist/storage/implementation/MongoCompactor.js.map +1 -1
- package/dist/storage/implementation/MongoPersistedSyncRulesContent.d.ts +2 -12
- package/dist/storage/implementation/MongoPersistedSyncRulesContent.js +23 -24
- package/dist/storage/implementation/MongoPersistedSyncRulesContent.js.map +1 -1
- package/dist/storage/implementation/MongoSyncBucketStorage.d.ts +5 -2
- package/dist/storage/implementation/MongoSyncBucketStorage.js +42 -40
- package/dist/storage/implementation/MongoSyncBucketStorage.js.map +1 -1
- package/dist/storage/implementation/db.d.ts +0 -10
- package/dist/storage/implementation/db.js +0 -30
- package/dist/storage/implementation/db.js.map +1 -1
- package/dist/storage/implementation/models.d.ts +11 -0
- package/dist/storage/implementation/models.js +9 -1
- package/dist/storage/implementation/models.js.map +1 -1
- package/dist/storage/storage-index.d.ts +0 -1
- package/dist/storage/storage-index.js +0 -1
- package/dist/storage/storage-index.js.map +1 -1
- package/dist/utils/test-utils.d.ts +3 -4
- package/dist/utils/test-utils.js +2 -2
- package/dist/utils/test-utils.js.map +1 -1
- package/dist/utils/util.d.ts +0 -7
- package/dist/utils/util.js +3 -27
- package/dist/utils/util.js.map +1 -1
- package/package.json +7 -7
- package/src/migrations/db/migrations/1770213298299-storage-version.ts +44 -0
- package/src/storage/MongoBucketStorage.ts +20 -59
- package/src/storage/MongoReportStorage.ts +4 -369
- package/src/storage/implementation/MongoChecksums.ts +14 -6
- package/src/storage/implementation/MongoCompactor.ts +94 -25
- package/src/storage/implementation/MongoPersistedSyncRulesContent.ts +25 -32
- package/src/storage/implementation/MongoSyncBucketStorage.ts +60 -44
- package/src/storage/implementation/db.ts +0 -32
- package/src/storage/implementation/models.ts +23 -0
- package/src/storage/storage-index.ts +0 -1
- package/src/utils/test-utils.ts +3 -4
- package/src/utils/util.ts +3 -36
- package/test/src/__snapshots__/storage_sync.test.ts.snap +1116 -21
- package/test/src/compression.test.ts +17 -0
- package/test/src/connection-report-storage.test.ts +6 -2
- package/test/src/storage_compacting.test.ts +29 -22
- package/test/src/storage_sync.test.ts +27 -14
- package/test/src/util.ts +3 -0
- package/test/tsconfig.json +3 -7
- package/tsconfig.tsbuildinfo +1 -1
- package/dist/migrations/db/migrations/1770037239303-sync-reporting.js +0 -44
- package/dist/migrations/db/migrations/1770037239303-sync-reporting.js.map +0 -1
- package/dist/storage/implementation/MongoPersistedSyncRules.d.ts +0 -10
- package/dist/storage/implementation/MongoPersistedSyncRules.js +0 -17
- package/dist/storage/implementation/MongoPersistedSyncRules.js.map +0 -1
- package/src/migrations/db/migrations/1770037239303-sync-reporting.ts +0 -74
- package/src/storage/implementation/MongoPersistedSyncRules.ts +0 -20
- package/test/src/__snapshots__/storage.test.ts.snap +0 -25
- /package/dist/migrations/db/migrations/{1770037239303-sync-reporting.d.ts → 1770213298299-storage-version.d.ts} +0 -0
|
@@ -1,329 +1,9 @@
|
|
|
1
|
-
import { event_types } from '@powersync/service-types';
|
|
2
1
|
import { logger } from '@powersync/lib-services-framework';
|
|
3
|
-
import { createPaginatedConnectionQuery
|
|
4
|
-
import * as bson from 'bson';
|
|
2
|
+
import { createPaginatedConnectionQuery } from '../utils/util.js';
|
|
5
3
|
export class MongoReportStorage {
|
|
6
4
|
db;
|
|
7
|
-
client;
|
|
8
|
-
session;
|
|
9
5
|
constructor(db) {
|
|
10
6
|
this.db = db;
|
|
11
|
-
this.client = db.client;
|
|
12
|
-
this.session = this.client.startSession();
|
|
13
|
-
}
|
|
14
|
-
async reportSyncCheckpoint(data) {
|
|
15
|
-
const { user_id, client_id, data: checkData, request_streams } = data;
|
|
16
|
-
const { id, type, last_op_id, buckets, date, streams } = checkData;
|
|
17
|
-
await this.session.withTransaction(async () => {
|
|
18
|
-
await this.db.sync_report_events.insertOne({
|
|
19
|
-
_id: id,
|
|
20
|
-
user_id,
|
|
21
|
-
client_id,
|
|
22
|
-
type,
|
|
23
|
-
last_op_id,
|
|
24
|
-
date,
|
|
25
|
-
streams,
|
|
26
|
-
request_streams
|
|
27
|
-
}, { session: this.session });
|
|
28
|
-
await this.db.bucket_report_events.insertMany(buckets.map((bucket) => {
|
|
29
|
-
return {
|
|
30
|
-
state: `synced`,
|
|
31
|
-
checkpoint_id: id,
|
|
32
|
-
client_id,
|
|
33
|
-
user_id,
|
|
34
|
-
name: bucket.bucket,
|
|
35
|
-
operations: bucket.count,
|
|
36
|
-
date: date,
|
|
37
|
-
subscriptions: bucket.subscriptions,
|
|
38
|
-
priority: bucket.priority
|
|
39
|
-
};
|
|
40
|
-
}));
|
|
41
|
-
}, { session: this.session });
|
|
42
|
-
}
|
|
43
|
-
async reportSyncDiffCheckpoint(data) {
|
|
44
|
-
const { user_id, client_id, data: checkData, request_streams } = data;
|
|
45
|
-
const { id, type, last_op_id, updated_buckets, removed_buckets, date, streams } = checkData;
|
|
46
|
-
await this.session.withTransaction(async () => {
|
|
47
|
-
await this.db.sync_report_events.insertOne({
|
|
48
|
-
_id: id,
|
|
49
|
-
user_id,
|
|
50
|
-
client_id,
|
|
51
|
-
type,
|
|
52
|
-
last_op_id,
|
|
53
|
-
date,
|
|
54
|
-
streams,
|
|
55
|
-
request_streams
|
|
56
|
-
}, { session: this.session });
|
|
57
|
-
if (updated_buckets.length > 0) {
|
|
58
|
-
await this.db.bucket_report_events.insertMany(updated_buckets.map((bucket) => {
|
|
59
|
-
return {
|
|
60
|
-
state: `updated`,
|
|
61
|
-
checkpoint_id: id,
|
|
62
|
-
client_id,
|
|
63
|
-
user_id,
|
|
64
|
-
name: bucket.bucket,
|
|
65
|
-
operations: bucket.count,
|
|
66
|
-
date: date,
|
|
67
|
-
subscriptions: bucket.subscriptions,
|
|
68
|
-
priority: bucket.priority
|
|
69
|
-
};
|
|
70
|
-
}), { session: this.session });
|
|
71
|
-
}
|
|
72
|
-
if (removed_buckets.length > 0) {
|
|
73
|
-
await this.db.bucket_report_events.insertMany(removed_buckets.map((bucket) => {
|
|
74
|
-
return {
|
|
75
|
-
state: `removed`,
|
|
76
|
-
checkpoint_id: id,
|
|
77
|
-
client_id,
|
|
78
|
-
user_id,
|
|
79
|
-
name: bucket,
|
|
80
|
-
operations: null,
|
|
81
|
-
subscriptions: null,
|
|
82
|
-
date: date,
|
|
83
|
-
priority: null
|
|
84
|
-
};
|
|
85
|
-
}), { session: this.session });
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
syncBucketFacetPipeline() {
|
|
90
|
-
return {
|
|
91
|
-
$facet: {
|
|
92
|
-
buckets_removed: [
|
|
93
|
-
{ $match: { state: 'removed' } },
|
|
94
|
-
{ $group: { _id: '$checkpoint_id', total: { $sum: 1 } } },
|
|
95
|
-
{
|
|
96
|
-
$project: {
|
|
97
|
-
_id: 0,
|
|
98
|
-
checkpoint_id: '$_id',
|
|
99
|
-
total: 1
|
|
100
|
-
}
|
|
101
|
-
},
|
|
102
|
-
{ $sort: { total: -1 } }
|
|
103
|
-
],
|
|
104
|
-
buckets_updated: [
|
|
105
|
-
{ $match: { state: 'updated' } },
|
|
106
|
-
{ $group: { _id: '$checkpoint_id', total: { $sum: 1 } } },
|
|
107
|
-
{
|
|
108
|
-
$project: {
|
|
109
|
-
_id: 0,
|
|
110
|
-
checkpoint_id: '$_id',
|
|
111
|
-
total: 1
|
|
112
|
-
}
|
|
113
|
-
},
|
|
114
|
-
{ $sort: { total: -1 } }
|
|
115
|
-
],
|
|
116
|
-
buckets_synced: [
|
|
117
|
-
{ $match: { state: 'synced' } },
|
|
118
|
-
{ $group: { _id: '$checkpoint_id', total: { $sum: 1 } } },
|
|
119
|
-
{
|
|
120
|
-
$project: {
|
|
121
|
-
_id: 0,
|
|
122
|
-
checkpoint_id: '$_id',
|
|
123
|
-
total: 1
|
|
124
|
-
}
|
|
125
|
-
},
|
|
126
|
-
{ $sort: { total: -1 } }
|
|
127
|
-
]
|
|
128
|
-
}
|
|
129
|
-
};
|
|
130
|
-
}
|
|
131
|
-
syncBucketProjectPipeline() {
|
|
132
|
-
return {
|
|
133
|
-
$project: {
|
|
134
|
-
buckets_removed: 1,
|
|
135
|
-
buckets_updated: 1,
|
|
136
|
-
buckets_synced: 1
|
|
137
|
-
}
|
|
138
|
-
};
|
|
139
|
-
}
|
|
140
|
-
async getSyncCheckpoint(data) {
|
|
141
|
-
const { cursor, date_range } = data;
|
|
142
|
-
const limit = data?.limit || 100;
|
|
143
|
-
const typeFilter = data.type != null ? { type: data.type } : undefined;
|
|
144
|
-
const date = { date: { $lte: date_range.end, $gte: date_range.start } };
|
|
145
|
-
const user_id = data.user_id != null ? { user_id: data.user_id } : undefined;
|
|
146
|
-
const client_id = data.client_id != null ? { client_id: data.client_id } : undefined;
|
|
147
|
-
return (await createPaginatedSyncCheckpointQuery({
|
|
148
|
-
...client_id,
|
|
149
|
-
...user_id,
|
|
150
|
-
...date,
|
|
151
|
-
...typeFilter
|
|
152
|
-
}, this.db.sync_report_events, limit, cursor));
|
|
153
|
-
}
|
|
154
|
-
async getLastSyncReport(data) {
|
|
155
|
-
const { client_id, user_id } = data;
|
|
156
|
-
const checkpoint = await this.db.sync_report_events.findOne({
|
|
157
|
-
user_id,
|
|
158
|
-
client_id
|
|
159
|
-
}, { session: this.session, sort: { date: -1 } });
|
|
160
|
-
if (!checkpoint) {
|
|
161
|
-
throw new Error('No checkpoint found for the given user_id and client_id');
|
|
162
|
-
}
|
|
163
|
-
const sync_streams = checkpoint.streams.map((stream) => stream.name);
|
|
164
|
-
const subscriptions = checkpoint.request_streams?.subscriptions.length > 0
|
|
165
|
-
? checkpoint.request_streams.subscriptions.map((stream) => stream.name)
|
|
166
|
-
: [];
|
|
167
|
-
const buckets = await this.db.bucket_report_events
|
|
168
|
-
.aggregate([
|
|
169
|
-
{
|
|
170
|
-
$facet: {
|
|
171
|
-
updated_buckets: [
|
|
172
|
-
{
|
|
173
|
-
$match: {
|
|
174
|
-
checkpoint_id: checkpoint._id,
|
|
175
|
-
state: 'updated'
|
|
176
|
-
}
|
|
177
|
-
},
|
|
178
|
-
{
|
|
179
|
-
$sort: {
|
|
180
|
-
operations: -1
|
|
181
|
-
}
|
|
182
|
-
},
|
|
183
|
-
{
|
|
184
|
-
$limit: 10
|
|
185
|
-
},
|
|
186
|
-
{
|
|
187
|
-
$project: {
|
|
188
|
-
_id: 0,
|
|
189
|
-
name: '$name',
|
|
190
|
-
operations: '$operations',
|
|
191
|
-
subscriptions: '$subscriptions',
|
|
192
|
-
priority: '$priority'
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
],
|
|
196
|
-
removed_buckets: [
|
|
197
|
-
{
|
|
198
|
-
$match: {
|
|
199
|
-
checkpoint_id: checkpoint._id,
|
|
200
|
-
state: 'removed'
|
|
201
|
-
}
|
|
202
|
-
},
|
|
203
|
-
{
|
|
204
|
-
$group: {
|
|
205
|
-
_id: null,
|
|
206
|
-
count: { $sum: 1 }
|
|
207
|
-
}
|
|
208
|
-
}
|
|
209
|
-
],
|
|
210
|
-
synced_buckets: [
|
|
211
|
-
{
|
|
212
|
-
$match: {
|
|
213
|
-
checkpoint_id: checkpoint._id,
|
|
214
|
-
state: 'synced'
|
|
215
|
-
}
|
|
216
|
-
},
|
|
217
|
-
{
|
|
218
|
-
$sort: {
|
|
219
|
-
operations: -1
|
|
220
|
-
}
|
|
221
|
-
},
|
|
222
|
-
{
|
|
223
|
-
$limit: 10
|
|
224
|
-
},
|
|
225
|
-
{
|
|
226
|
-
$project: {
|
|
227
|
-
_id: 0,
|
|
228
|
-
name: '$name',
|
|
229
|
-
operations: '$operations',
|
|
230
|
-
subscriptions: '$subscriptions',
|
|
231
|
-
priority: '$priority'
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
]
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
])
|
|
238
|
-
.toArray();
|
|
239
|
-
if (buckets.length === 0) {
|
|
240
|
-
throw new Error('No bucket report events found for the given checkpoint');
|
|
241
|
-
}
|
|
242
|
-
const syncedBuckets = buckets[0].synced_buckets.length > 0
|
|
243
|
-
? buckets[0].synced_buckets.map((bucket) => {
|
|
244
|
-
const subs = {
|
|
245
|
-
default: [],
|
|
246
|
-
sub: []
|
|
247
|
-
};
|
|
248
|
-
for (const subscription of bucket?.subscriptions ?? []) {
|
|
249
|
-
if ('default' in subscription) {
|
|
250
|
-
// @ts-expect-error
|
|
251
|
-
subs.default.push(sync_streams[subscription.default]);
|
|
252
|
-
}
|
|
253
|
-
if ('sub' in subscription) {
|
|
254
|
-
// @ts-expect-error
|
|
255
|
-
subs.sub.push(subscriptions[subscription.sub]);
|
|
256
|
-
}
|
|
257
|
-
}
|
|
258
|
-
return {
|
|
259
|
-
name: bucket.name,
|
|
260
|
-
operations: bucket.operations,
|
|
261
|
-
priority: bucket.priority,
|
|
262
|
-
subscriptions: subs
|
|
263
|
-
};
|
|
264
|
-
})
|
|
265
|
-
: [];
|
|
266
|
-
const updatedBuckets = buckets[0].updated_buckets.length > 0
|
|
267
|
-
? buckets[0].updated_buckets.map((bucket) => {
|
|
268
|
-
const subs = {
|
|
269
|
-
default: [],
|
|
270
|
-
sub: []
|
|
271
|
-
};
|
|
272
|
-
for (const subscription of bucket?.subscriptions ?? []) {
|
|
273
|
-
if ('default' in subscription) {
|
|
274
|
-
// @ts-expect-error
|
|
275
|
-
subs.default.push(sync_streams[subscription.default]);
|
|
276
|
-
}
|
|
277
|
-
if ('sub' in subscription) {
|
|
278
|
-
// @ts-expect-error
|
|
279
|
-
subs.sub.push(subscriptions[subscription.sub]);
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
return {
|
|
283
|
-
name: bucket.name,
|
|
284
|
-
operations: bucket.operations,
|
|
285
|
-
priority: bucket.priority,
|
|
286
|
-
subscriptions: subs
|
|
287
|
-
};
|
|
288
|
-
})
|
|
289
|
-
: [];
|
|
290
|
-
return {
|
|
291
|
-
checkpoint_id: checkpoint._id,
|
|
292
|
-
last_op_id: checkpoint.last_op_id,
|
|
293
|
-
date: checkpoint.date,
|
|
294
|
-
streams: sync_streams,
|
|
295
|
-
subscriptions,
|
|
296
|
-
updated_buckets: updatedBuckets,
|
|
297
|
-
removed_buckets: buckets[0].removed_buckets.length > 0 ? buckets[0].removed_buckets[0].count : 0,
|
|
298
|
-
synced_buckets: syncedBuckets
|
|
299
|
-
};
|
|
300
|
-
}
|
|
301
|
-
async getSyncBucketStats(data) {
|
|
302
|
-
const { date_range } = data;
|
|
303
|
-
const user_id = data.user_id != null ? { user_id: data.user_id } : undefined;
|
|
304
|
-
const client_id = data.client_id != null ? { client_id: data.client_id } : undefined;
|
|
305
|
-
const checkpoint_id = data.checkpoint_id != null ? { checkpoint_id: new bson.ObjectId(data.checkpoint_id) } : undefined;
|
|
306
|
-
const result = await this.db.bucket_report_events
|
|
307
|
-
.aggregate([
|
|
308
|
-
{
|
|
309
|
-
$match: {
|
|
310
|
-
...client_id,
|
|
311
|
-
...user_id,
|
|
312
|
-
...checkpoint_id,
|
|
313
|
-
date: { $lte: date_range.end, $gte: date_range.start }
|
|
314
|
-
}
|
|
315
|
-
},
|
|
316
|
-
this.syncBucketFacetPipeline(),
|
|
317
|
-
this.syncBucketProjectPipeline()
|
|
318
|
-
])
|
|
319
|
-
.toArray();
|
|
320
|
-
return result[0];
|
|
321
|
-
}
|
|
322
|
-
async reportSyncAnalyticsEvent(data) {
|
|
323
|
-
if (data.data.type === event_types.SyncEventCheckpointType.FULL) {
|
|
324
|
-
return this.reportSyncCheckpoint(data);
|
|
325
|
-
}
|
|
326
|
-
return this.reportSyncDiffCheckpoint(data);
|
|
327
7
|
}
|
|
328
8
|
async deleteOldConnectionData(data) {
|
|
329
9
|
const { date } = data;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MongoReportStorage.js","sourceRoot":"","sources":["../../src/storage/MongoReportStorage.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"MongoReportStorage.js","sourceRoot":"","sources":["../../src/storage/MongoReportStorage.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ChecksumMap, FetchPartialBucketChecksum, InternalOpId, PartialChecksumMap } from '@powersync/service-core';
|
|
2
2
|
import { PowerSyncMongo } from './db.js';
|
|
3
|
+
import { StorageConfig } from './models.js';
|
|
3
4
|
/**
|
|
4
5
|
* Checksum calculation options, primarily for tests.
|
|
5
6
|
*/
|
|
@@ -12,6 +13,7 @@ export interface MongoChecksumOptions {
|
|
|
12
13
|
* Limit on the number of documents to calculate a checksum on at a time.
|
|
13
14
|
*/
|
|
14
15
|
operationBatchLimit?: number;
|
|
16
|
+
storageConfig: StorageConfig;
|
|
15
17
|
}
|
|
16
18
|
/**
|
|
17
19
|
* Checksum query implementation.
|
|
@@ -25,9 +27,10 @@ export interface MongoChecksumOptions {
|
|
|
25
27
|
export declare class MongoChecksums {
|
|
26
28
|
private db;
|
|
27
29
|
private group_id;
|
|
28
|
-
private options
|
|
30
|
+
private options;
|
|
29
31
|
private _cache;
|
|
30
|
-
|
|
32
|
+
private readonly storageConfig;
|
|
33
|
+
constructor(db: PowerSyncMongo, group_id: number, options: MongoChecksumOptions);
|
|
31
34
|
/**
|
|
32
35
|
* Lazy-instantiated cache.
|
|
33
36
|
*
|
|
@@ -16,10 +16,12 @@ export class MongoChecksums {
|
|
|
16
16
|
group_id;
|
|
17
17
|
options;
|
|
18
18
|
_cache;
|
|
19
|
+
storageConfig;
|
|
19
20
|
constructor(db, group_id, options) {
|
|
20
21
|
this.db = db;
|
|
21
22
|
this.group_id = group_id;
|
|
22
23
|
this.options = options;
|
|
24
|
+
this.storageConfig = options.storageConfig;
|
|
23
25
|
}
|
|
24
26
|
/**
|
|
25
27
|
* Lazy-instantiated cache.
|
|
@@ -174,6 +176,10 @@ export class MongoChecksums {
|
|
|
174
176
|
}
|
|
175
177
|
});
|
|
176
178
|
}
|
|
179
|
+
// Historically, checksum may be stored as 'int' or 'double'.
|
|
180
|
+
// More recently, this should be a 'long'.
|
|
181
|
+
// $toLong ensures that we always sum it as a long, avoiding inaccuracies in the calculations.
|
|
182
|
+
const checksumLong = this.storageConfig.longChecksums ? '$checksum' : { $toLong: '$checksum' };
|
|
177
183
|
// Aggregate over a max of `batchLimit` operations at a time.
|
|
178
184
|
// Let's say we have 3 buckets (A, B, C), each with 10 operations, and our batch limit is 12.
|
|
179
185
|
// Then we'll do three batches:
|
|
@@ -196,10 +202,7 @@ export class MongoChecksums {
|
|
|
196
202
|
{
|
|
197
203
|
$group: {
|
|
198
204
|
_id: '$_id.b',
|
|
199
|
-
|
|
200
|
-
// More recently, this should be a 'long'.
|
|
201
|
-
// $toLong ensures that we always sum it as a long, avoiding inaccuracies in the calculations.
|
|
202
|
-
checksum_total: { $sum: { $toLong: '$checksum' } },
|
|
205
|
+
checksum_total: { $sum: checksumLong },
|
|
203
206
|
count: { $sum: 1 },
|
|
204
207
|
has_clear_op: {
|
|
205
208
|
$max: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MongoChecksums.js","sourceRoot":"","sources":["../../../src/storage/implementation/MongoChecksums.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,SAAS,MAAM,gCAAgC,CAAC;AAC5D,OAAO,EACL,mBAAmB,EACnB,IAAI,EAEJ,aAAa,EAIb,iBAAiB,EAIlB,MAAM,yBAAyB,CAAC;
|
|
1
|
+
{"version":3,"file":"MongoChecksums.js","sourceRoot":"","sources":["../../../src/storage/implementation/MongoChecksums.ts"],"names":[],"mappings":"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"}
|
|
@@ -16,6 +16,7 @@ export declare class MongoCompactor {
|
|
|
16
16
|
private moveBatchQueryLimit;
|
|
17
17
|
private clearBatchLimit;
|
|
18
18
|
private minBucketChanges;
|
|
19
|
+
private minChangeRatio;
|
|
19
20
|
private maxOpId;
|
|
20
21
|
private buckets;
|
|
21
22
|
private signal?;
|
|
@@ -48,12 +49,26 @@ export declare class MongoCompactor {
|
|
|
48
49
|
populateChecksums(options: {
|
|
49
50
|
minBucketChanges: number;
|
|
50
51
|
}): Promise<PopulateChecksumCacheResults>;
|
|
52
|
+
/**
|
|
53
|
+
* Return batches of dirty buckets.
|
|
54
|
+
*
|
|
55
|
+
* Can be used to iterate through all buckets.
|
|
56
|
+
*
|
|
57
|
+
* minBucketChanges: minimum number of changes for a bucket to be included in the results.
|
|
58
|
+
* minChangeRatio: minimum ratio of changes to total ops for a bucket to be included in the results, number between 0 and 1.
|
|
59
|
+
*/
|
|
60
|
+
private dirtyBucketBatches;
|
|
51
61
|
/**
|
|
52
62
|
* Returns a batch of dirty buckets - buckets with most changes first.
|
|
53
63
|
*
|
|
54
64
|
* This cannot be used to iterate on its own - the client is expected to process these buckets and
|
|
55
65
|
* set estimate_since_compact.count: 0 when done, before fetching the next batch.
|
|
66
|
+
*
|
|
67
|
+
* Unlike dirtyBucketBatches, used for compacting, this is specifically designed to be resuamble after a restart,
|
|
68
|
+
* since it is used as the last step for initial replication.
|
|
69
|
+
*
|
|
70
|
+
* We currently don't get new data while doing populateChecksums, so we don't need to worry about buckets changing while processing.
|
|
56
71
|
*/
|
|
57
|
-
private
|
|
72
|
+
private dirtyBucketBatchForChecksums;
|
|
58
73
|
private updateChecksumsBatch;
|
|
59
74
|
}
|