@powersync/service-module-mongodb-storage 0.12.12 → 0.12.13

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 CHANGED
@@ -1,5 +1,20 @@
1
1
  # @powersync/service-module-mongodb-storage
2
2
 
3
+ ## 0.12.13
4
+
5
+ ### Patch Changes
6
+
7
+ - 57f7660: General client connections analytics added
8
+ - Updated dependencies [57f7660]
9
+ - Updated dependencies [c050acd]
10
+ - Updated dependencies [0156d10]
11
+ - Updated dependencies [6eee0b3]
12
+ - @powersync/service-core@1.17.0
13
+ - @powersync/service-types@0.13.2
14
+ - @powersync/service-sync-rules@0.29.8
15
+ - @powersync/lib-services-framework@0.7.11
16
+ - @powersync/lib-service-mongodb@0.6.13
17
+
3
18
  ## 0.12.12
4
19
 
5
20
  ### Patch Changes
@@ -6,6 +6,7 @@ export declare class MongoReportStorage implements storage.ReportStorage {
6
6
  constructor(db: PowerSyncMongo);
7
7
  deleteOldConnectionData(data: event_types.DeleteOldConnectionData): Promise<void>;
8
8
  getClientConnectionReports(data: event_types.ClientConnectionReportRequest): Promise<event_types.ClientConnectionReportResponse>;
9
+ getGeneralClientConnectionAnalytics(data: event_types.ClientConnectionAnalyticsRequest): Promise<event_types.PaginatedResponse<event_types.ClientConnection>>;
9
10
  reportClientConnection(data: event_types.ClientConnectionBucketData): Promise<void>;
10
11
  reportClientDisconnection(data: event_types.ClientDisconnectionEventData): Promise<void>;
11
12
  getConnectedClients(): Promise<event_types.ClientConnectionReportResponse>;
@@ -1,4 +1,5 @@
1
1
  import { logger } from '@powersync/lib-services-framework';
2
+ import { createPaginatedConnectionQuery } from '../utils/util.js';
2
3
  export class MongoReportStorage {
3
4
  db;
4
5
  constructor(db) {
@@ -32,6 +33,18 @@ export class MongoReportStorage {
32
33
  .toArray();
33
34
  return result[0];
34
35
  }
36
+ async getGeneralClientConnectionAnalytics(data) {
37
+ const { cursor, date_range } = data;
38
+ const limit = data?.limit || 100;
39
+ const connected_at = date_range ? { connected_at: { $lte: date_range.end, $gte: date_range.start } } : undefined;
40
+ const user_id = data.user_id != null ? { user_id: data.user_id } : undefined;
41
+ const client_id = data.client_id != null ? { client_id: data.client_id } : undefined;
42
+ return (await createPaginatedConnectionQuery({
43
+ ...client_id,
44
+ ...user_id,
45
+ ...connected_at
46
+ }, this.db.connection_report_events, limit, cursor));
47
+ }
35
48
  async reportClientConnection(data) {
36
49
  const updateFilter = this.updateDocFilter(data.user_id, data.client_id);
37
50
  await this.db.connection_report_events.findOneAndUpdate(updateFilter, {
@@ -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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"}
@@ -22,3 +22,10 @@ export declare function readSingleBatch<T>(cursor: mongo.AbstractCursor<T>): Pro
22
22
  export declare function mapOpEntry(row: BucketDataDocument): utils.OplogEntry;
23
23
  export declare function replicaIdToSubkey(table: bson.ObjectId, id: storage.ReplicaId): string;
24
24
  export declare function setSessionSnapshotTime(session: mongo.ClientSession, time: bson.Timestamp): void;
25
+ export declare const createPaginatedConnectionQuery: <T extends mongo.Document>(query: mongo.Filter<T>, collection: mongo.Collection<T>, limit: number, cursor?: string) => Promise<{
26
+ items: mongo.WithId<T>[];
27
+ count: number;
28
+ /** Setting the cursor to the connected at date of the last item in the list */
29
+ cursor: any;
30
+ more: boolean;
31
+ }>;
@@ -106,4 +106,36 @@ export function setSessionSnapshotTime(session, time) {
106
106
  throw new ServiceAssertionError(`Session snapshotTime is already set`);
107
107
  }
108
108
  }
109
+ export const createPaginatedConnectionQuery = async (query, collection, limit, cursor) => {
110
+ const createQuery = (cursor) => {
111
+ if (!cursor) {
112
+ return query;
113
+ }
114
+ const connected_at = query.connected_at
115
+ ? { $lt: new Date(cursor), $gte: query.connected_at.$gte }
116
+ : { $lt: new Date(cursor) };
117
+ return {
118
+ ...query,
119
+ connected_at
120
+ };
121
+ };
122
+ const findCursor = collection.find(createQuery(cursor), {
123
+ sort: {
124
+ /** We are sorting by connected at date descending to match cursor Postgres implementation */
125
+ connected_at: -1
126
+ }
127
+ });
128
+ const items = await findCursor.limit(limit).toArray();
129
+ const count = items.length;
130
+ /** The returned total has been defaulted to 0 due to the overhead using documentCount from the mogo driver.
131
+ * cursor.count has been deprecated.
132
+ * */
133
+ return {
134
+ items,
135
+ count,
136
+ /** Setting the cursor to the connected at date of the last item in the list */
137
+ cursor: count === limit ? items[items.length - 1].connected_at.toISOString() : undefined,
138
+ more: !(count !== limit)
139
+ };
140
+ };
109
141
  //# sourceMappingURL=util.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/utils/util.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"util.js","sourceRoot":"","sources":["../../src/utils/util.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@powersync/service-module-mongodb-storage",
3
3
  "repository": "https://github.com/powersync-ja/powersync-service",
4
4
  "types": "dist/index.d.ts",
5
- "version": "0.12.12",
5
+ "version": "0.12.13",
6
6
  "main": "dist/index.js",
7
7
  "license": "FSL-1.1-ALv2",
8
8
  "type": "module",
@@ -27,15 +27,15 @@
27
27
  "lru-cache": "^10.2.2",
28
28
  "ts-codec": "^1.3.0",
29
29
  "uuid": "^11.1.0",
30
- "@powersync/lib-service-mongodb": "0.6.12",
31
- "@powersync/lib-services-framework": "0.7.10",
32
- "@powersync/service-core": "1.16.3",
30
+ "@powersync/lib-service-mongodb": "0.6.13",
31
+ "@powersync/lib-services-framework": "0.7.11",
32
+ "@powersync/service-core": "1.17.0",
33
33
  "@powersync/service-jsonbig": "0.17.12",
34
- "@powersync/service-sync-rules": "0.29.7",
35
- "@powersync/service-types": "0.13.1"
34
+ "@powersync/service-sync-rules": "0.29.8",
35
+ "@powersync/service-types": "0.13.2"
36
36
  },
37
37
  "devDependencies": {
38
- "@powersync/service-core-tests": "0.12.12"
38
+ "@powersync/service-core-tests": "0.12.13"
39
39
  },
40
40
  "scripts": {
41
41
  "build": "tsc -b",
@@ -2,6 +2,7 @@ import { storage } from '@powersync/service-core';
2
2
  import { event_types } from '@powersync/service-types';
3
3
  import { PowerSyncMongo } from './implementation/db.js';
4
4
  import { logger } from '@powersync/lib-services-framework';
5
+ import { createPaginatedConnectionQuery } from '../utils/util.js';
5
6
 
6
7
  export class MongoReportStorage implements storage.ReportStorage {
7
8
  public readonly db: PowerSyncMongo;
@@ -43,6 +44,27 @@ export class MongoReportStorage implements storage.ReportStorage {
43
44
  return result[0];
44
45
  }
45
46
 
47
+ async getGeneralClientConnectionAnalytics(
48
+ data: event_types.ClientConnectionAnalyticsRequest
49
+ ): Promise<event_types.PaginatedResponse<event_types.ClientConnection>> {
50
+ const { cursor, date_range } = data;
51
+ const limit = data?.limit || 100;
52
+
53
+ const connected_at = date_range ? { connected_at: { $lte: date_range.end, $gte: date_range.start } } : undefined;
54
+ const user_id = data.user_id != null ? { user_id: data.user_id } : undefined;
55
+ const client_id = data.client_id != null ? { client_id: data.client_id } : undefined;
56
+ return (await createPaginatedConnectionQuery(
57
+ {
58
+ ...client_id,
59
+ ...user_id,
60
+ ...connected_at
61
+ },
62
+ this.db.connection_report_events,
63
+ limit,
64
+ cursor
65
+ )) as event_types.PaginatedResponse<event_types.ClientConnection>;
66
+ }
67
+
46
68
  async reportClientConnection(data: event_types.ClientConnectionBucketData): Promise<void> {
47
69
  const updateFilter = this.updateDocFilter(data.user_id, data.client_id!);
48
70
  await this.db.connection_report_events.findOneAndUpdate(
package/src/utils/util.ts CHANGED
@@ -114,3 +114,43 @@ export function setSessionSnapshotTime(session: mongo.ClientSession, time: bson.
114
114
  throw new ServiceAssertionError(`Session snapshotTime is already set`);
115
115
  }
116
116
  }
117
+
118
+ export const createPaginatedConnectionQuery = async <T extends mongo.Document>(
119
+ query: mongo.Filter<T>,
120
+ collection: mongo.Collection<T>,
121
+ limit: number,
122
+ cursor?: string
123
+ ) => {
124
+ const createQuery = (cursor?: string) => {
125
+ if (!cursor) {
126
+ return query;
127
+ }
128
+ const connected_at = query.connected_at
129
+ ? { $lt: new Date(cursor), $gte: query.connected_at.$gte }
130
+ : { $lt: new Date(cursor) };
131
+ return {
132
+ ...query,
133
+ connected_at
134
+ } as mongo.Filter<T>;
135
+ };
136
+
137
+ const findCursor = collection.find(createQuery(cursor), {
138
+ sort: {
139
+ /** We are sorting by connected at date descending to match cursor Postgres implementation */
140
+ connected_at: -1
141
+ }
142
+ });
143
+
144
+ const items = await findCursor.limit(limit).toArray();
145
+ const count = items.length;
146
+ /** The returned total has been defaulted to 0 due to the overhead using documentCount from the mogo driver.
147
+ * cursor.count has been deprecated.
148
+ * */
149
+ return {
150
+ items,
151
+ count,
152
+ /** Setting the cursor to the connected at date of the last item in the list */
153
+ cursor: count === limit ? items[items.length - 1].connected_at.toISOString() : undefined,
154
+ more: !(count !== limit)
155
+ };
156
+ };
@@ -3,13 +3,13 @@
3
3
  exports[`Connection reporting storage > Should create a connection report if its after a day 1`] = `
4
4
  [
5
5
  {
6
- "client_id": "client_week",
6
+ "client_id": "client_one",
7
7
  "sdk": "powersync-js/1.24.5",
8
8
  "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
9
9
  "user_id": "user_week",
10
10
  },
11
11
  {
12
- "client_id": "client_week",
12
+ "client_id": "client_one",
13
13
  "sdk": "powersync-js/1.24.5",
14
14
  "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
15
15
  "user_id": "user_week",
@@ -213,3 +213,239 @@ exports[`Report storage tests > Should show currently connected users 1`] = `
213
213
  "users": 2,
214
214
  }
215
215
  `;
216
+
217
+ exports[`Report storage tests > Should show paginated response of all connections of specified client_id 1`] = `
218
+ {
219
+ "count": 1,
220
+ "cursor": undefined,
221
+ "items": [
222
+ {
223
+ "client_id": "client_two",
224
+ "sdk": "powersync-js/1.21.1",
225
+ "user_agent": "powersync-js/1.21.0 powersync-web Chromium/138 linux",
226
+ "user_id": "user_two",
227
+ },
228
+ ],
229
+ "more": false,
230
+ }
231
+ `;
232
+
233
+ exports[`Report storage tests > Should show paginated response of all connections with a limit 1`] = `
234
+ {
235
+ "count": 4,
236
+ "cursor": "<removed-for-snapshot>",
237
+ "items": [
238
+ {
239
+ "client_id": "client_one",
240
+ "sdk": "powersync-dart/1.6.4",
241
+ "user_agent": "powersync-dart/1.6.4 Dart (flutter-web) Chrome/128 android",
242
+ "user_id": "user_one",
243
+ },
244
+ {
245
+ "client_id": "client_four",
246
+ "sdk": "powersync-js/1.21.4",
247
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
248
+ "user_id": "user_four",
249
+ },
250
+ {
251
+ "client_id": "",
252
+ "sdk": "unknown",
253
+ "user_agent": "Dart (flutter-web) Chrome/128 android",
254
+ "user_id": "user_one",
255
+ },
256
+ {
257
+ "client_id": "client_two",
258
+ "sdk": "powersync-js/1.21.1",
259
+ "user_agent": "powersync-js/1.21.0 powersync-web Chromium/138 linux",
260
+ "user_id": "user_two",
261
+ },
262
+ ],
263
+ "more": true,
264
+ }
265
+ `;
266
+
267
+ exports[`Report storage tests > Should show paginated response of all connections with a limit 2`] = `
268
+ {
269
+ "count": 4,
270
+ "cursor": undefined,
271
+ "items": [
272
+ {
273
+ "client_id": "client_three",
274
+ "sdk": "powersync-js/1.21.2",
275
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
276
+ "user_id": "user_three",
277
+ },
278
+ {
279
+ "client_id": "client_one",
280
+ "sdk": "powersync-js/1.24.5",
281
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
282
+ "user_id": "user_week",
283
+ },
284
+ {
285
+ "client_id": "client_month",
286
+ "sdk": "powersync-js/1.23.6",
287
+ "user_agent": "powersync-js/1.23.0 powersync-web Firefox/141 linux",
288
+ "user_id": "user_month",
289
+ },
290
+ {
291
+ "client_id": "client_expired",
292
+ "sdk": "powersync-js/1.23.7",
293
+ "user_agent": "powersync-js/1.23.0 powersync-web Firefox/141 linux",
294
+ "user_id": "user_expired",
295
+ },
296
+ ],
297
+ "more": false,
298
+ }
299
+ `;
300
+
301
+ exports[`Report storage tests > Should show paginated response of all connections with a limit with date range 1`] = `
302
+ {
303
+ "count": 4,
304
+ "cursor": "<removed-for-snapshot>",
305
+ "items": [
306
+ {
307
+ "client_id": "",
308
+ "sdk": "unknown",
309
+ "user_agent": "Dart (flutter-web) Chrome/128 android",
310
+ "user_id": "user_one",
311
+ },
312
+ {
313
+ "client_id": "client_two",
314
+ "sdk": "powersync-js/1.21.1",
315
+ "user_agent": "powersync-js/1.21.0 powersync-web Chromium/138 linux",
316
+ "user_id": "user_two",
317
+ },
318
+ {
319
+ "client_id": "client_three",
320
+ "sdk": "powersync-js/1.21.2",
321
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
322
+ "user_id": "user_three",
323
+ },
324
+ {
325
+ "client_id": "client_one",
326
+ "sdk": "powersync-js/1.24.5",
327
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
328
+ "user_id": "user_week",
329
+ },
330
+ ],
331
+ "more": true,
332
+ }
333
+ `;
334
+
335
+ exports[`Report storage tests > Should show paginated response of all connections with a limit with date range 2`] = `
336
+ {
337
+ "count": 2,
338
+ "cursor": undefined,
339
+ "items": [
340
+ {
341
+ "client_id": "",
342
+ "sdk": "unknown",
343
+ "user_agent": "Dart (flutter-web) Chrome/128 android",
344
+ "user_id": "user_one",
345
+ },
346
+ {
347
+ "client_id": "client_two",
348
+ "sdk": "powersync-js/1.21.1",
349
+ "user_agent": "powersync-js/1.21.0 powersync-web Chromium/138 linux",
350
+ "user_id": "user_two",
351
+ },
352
+ {
353
+ "client_id": "client_three",
354
+ "sdk": "powersync-js/1.21.2",
355
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
356
+ "user_id": "user_three",
357
+ },
358
+ {
359
+ "client_id": "client_one",
360
+ "sdk": "powersync-js/1.24.5",
361
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
362
+ "user_id": "user_week",
363
+ },
364
+ ],
365
+ "more": false,
366
+ }
367
+ `;
368
+
369
+ exports[`Report storage tests > Should show paginated response of connections of specified user_id 1`] = `
370
+ {
371
+ "count": 2,
372
+ "cursor": undefined,
373
+ "items": [
374
+ {
375
+ "client_id": "client_one",
376
+ "sdk": "powersync-dart/1.6.4",
377
+ "user_agent": "powersync-dart/1.6.4 Dart (flutter-web) Chrome/128 android",
378
+ "user_id": "user_one",
379
+ },
380
+ {
381
+ "client_id": "",
382
+ "sdk": "unknown",
383
+ "user_agent": "Dart (flutter-web) Chrome/128 android",
384
+ "user_id": "user_one",
385
+ },
386
+ ],
387
+ "more": false,
388
+ }
389
+ `;
390
+
391
+ exports[`Report storage tests > Should show paginated response of connections over a date range 1`] = `
392
+ {
393
+ "count": 6,
394
+ "cursor": undefined,
395
+ "items": [
396
+ {
397
+ "client_id": "client_one",
398
+ "sdk": "powersync-dart/1.6.4",
399
+ "user_agent": "powersync-dart/1.6.4 Dart (flutter-web) Chrome/128 android",
400
+ "user_id": "user_one",
401
+ },
402
+ {
403
+ "client_id": "client_four",
404
+ "sdk": "powersync-js/1.21.4",
405
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
406
+ "user_id": "user_four",
407
+ },
408
+ {
409
+ "client_id": "client_two",
410
+ "sdk": "powersync-js/1.21.1",
411
+ "user_agent": "powersync-js/1.21.0 powersync-web Chromium/138 linux",
412
+ "user_id": "user_two",
413
+ },
414
+ {
415
+ "client_id": "",
416
+ "sdk": "unknown",
417
+ "user_agent": "Dart (flutter-web) Chrome/128 android",
418
+ "user_id": "user_one",
419
+ },
420
+ {
421
+ "client_id": "client_three",
422
+ "sdk": "powersync-js/1.21.2",
423
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
424
+ "user_id": "user_three",
425
+ },
426
+ {
427
+ "client_id": "client_one",
428
+ "sdk": "powersync-js/1.24.5",
429
+ "user_agent": "powersync-js/1.21.0 powersync-web Firefox/141 linux",
430
+ "user_id": "user_week",
431
+ },
432
+ ],
433
+ "more": false,
434
+ }
435
+ `;
436
+
437
+ exports[`Report storage tests > Should show paginated response of connections over a date range of specified client_id and user_id 1`] = `
438
+ {
439
+ "count": 1,
440
+ "cursor": undefined,
441
+ "items": [
442
+ {
443
+ "client_id": "client_one",
444
+ "sdk": "powersync-dart/1.6.4",
445
+ "user_agent": "powersync-dart/1.6.4 Dart (flutter-web) Chrome/128 android",
446
+ "user_id": "user_one",
447
+ },
448
+ ],
449
+ "more": false,
450
+ }
451
+ `;