@verdant-web/store 3.12.0 → 4.0.0-next.0
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/dist/bundle/index.js +11 -13
- package/dist/bundle/index.js.map +4 -4
- package/dist/esm/__tests__/batching.test.js +5 -5
- package/dist/esm/__tests__/batching.test.js.map +1 -1
- package/dist/esm/__tests__/entities.test.js +1 -1
- package/dist/esm/__tests__/entities.test.js.map +1 -1
- package/dist/esm/__tests__/fixtures/testStorage.d.ts +1 -3
- package/dist/esm/__tests__/fixtures/testStorage.js +3 -3
- package/dist/esm/__tests__/fixtures/testStorage.js.map +1 -1
- package/dist/esm/__tests__/queries.test.js.map +1 -1
- package/dist/esm/backup.d.ts +3 -4
- package/dist/esm/backup.js.map +1 -1
- package/dist/esm/client/Client.d.ts +28 -33
- package/dist/esm/client/Client.js +50 -161
- package/dist/esm/client/Client.js.map +1 -1
- package/dist/esm/client/ClientDescriptor.d.ts +8 -11
- package/dist/esm/client/ClientDescriptor.js +39 -141
- package/dist/esm/client/ClientDescriptor.js.map +1 -1
- package/dist/esm/context/Time.d.ts +13 -0
- package/dist/esm/context/Time.js +27 -0
- package/dist/esm/context/Time.js.map +1 -0
- package/dist/esm/context/context.d.ts +170 -0
- package/dist/esm/{context.js.map → context/context.js.map} +1 -1
- package/dist/esm/entities/DocumentManager.js.map +1 -1
- package/dist/esm/entities/Entity.d.ts +4 -5
- package/dist/esm/entities/Entity.js +5 -3
- package/dist/esm/entities/Entity.js.map +1 -1
- package/dist/esm/entities/Entity.test.js +4 -3
- package/dist/esm/entities/Entity.test.js.map +1 -1
- package/dist/esm/entities/EntityCache.d.ts +0 -3
- package/dist/esm/entities/EntityCache.js +0 -9
- package/dist/esm/entities/EntityCache.js.map +1 -1
- package/dist/esm/entities/EntityMetadata.d.ts +1 -1
- package/dist/esm/entities/EntityMetadata.js +6 -5
- package/dist/esm/entities/EntityMetadata.js.map +1 -1
- package/dist/esm/entities/EntityStore.d.ts +2 -6
- package/dist/esm/entities/EntityStore.js +22 -16
- package/dist/esm/entities/EntityStore.js.map +1 -1
- package/dist/esm/entities/OperationBatcher.d.ts +2 -5
- package/dist/esm/entities/OperationBatcher.js +9 -7
- package/dist/esm/entities/OperationBatcher.js.map +1 -1
- package/dist/esm/entities/types.d.ts +1 -1
- package/dist/esm/errors.d.ts +8 -0
- package/dist/esm/errors.js +12 -0
- package/dist/esm/errors.js.map +1 -0
- package/dist/esm/files/EntityFile.d.ts +6 -3
- package/dist/esm/files/EntityFile.js +22 -19
- package/dist/esm/files/EntityFile.js.map +1 -1
- package/dist/esm/files/FileManager.d.ts +8 -39
- package/dist/esm/files/FileManager.js +15 -170
- package/dist/esm/files/FileManager.js.map +1 -1
- package/dist/esm/files/utils.d.ts +0 -1
- package/dist/esm/files/utils.js +0 -14
- package/dist/esm/files/utils.js.map +1 -1
- package/dist/esm/index.d.ts +1 -2
- package/dist/esm/index.js +0 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/{metadata → persistence}/MessageCreator.d.ts +5 -6
- package/dist/esm/{metadata → persistence}/MessageCreator.js +31 -38
- package/dist/esm/persistence/MessageCreator.js.map +1 -0
- package/dist/esm/persistence/PersistenceFiles.d.ts +48 -0
- package/dist/esm/persistence/PersistenceFiles.js +160 -0
- package/dist/esm/persistence/PersistenceFiles.js.map +1 -0
- package/dist/esm/persistence/PersistenceMetadata.d.ts +69 -0
- package/dist/esm/persistence/PersistenceMetadata.js +302 -0
- package/dist/esm/persistence/PersistenceMetadata.js.map +1 -0
- package/dist/esm/persistence/PersistenceQueries.d.ts +34 -0
- package/dist/esm/persistence/PersistenceQueries.js +15 -0
- package/dist/esm/persistence/PersistenceQueries.js.map +1 -0
- package/dist/esm/persistence/PersistenceRebaser.d.ts +32 -0
- package/dist/esm/persistence/PersistenceRebaser.js +120 -0
- package/dist/esm/persistence/PersistenceRebaser.js.map +1 -0
- package/dist/esm/{IDBService.d.ts → persistence/idb/IdbService.d.ts} +9 -7
- package/dist/esm/{IDBService.js → persistence/idb/IdbService.js} +29 -8
- package/dist/esm/persistence/idb/IdbService.js.map +1 -0
- package/dist/esm/persistence/idb/files/IdbPersistenceFileDb.d.ts +58 -0
- package/dist/esm/{files/FileStorage.js → persistence/idb/files/IdbPersistenceFileDb.js} +85 -50
- package/dist/esm/persistence/idb/files/IdbPersistenceFileDb.js.map +1 -0
- package/dist/esm/persistence/idb/idbPersistence.d.ts +19 -0
- package/dist/esm/persistence/idb/idbPersistence.js +80 -0
- package/dist/esm/persistence/idb/idbPersistence.js.map +1 -0
- package/dist/esm/persistence/idb/metadata/IdbMetadataDb.d.ts +72 -0
- package/dist/esm/persistence/idb/metadata/IdbMetadataDb.js +235 -0
- package/dist/esm/persistence/idb/metadata/IdbMetadataDb.js.map +1 -0
- package/dist/esm/{metadata → persistence/idb/metadata}/openMetadataDatabase.d.ts +3 -1
- package/dist/esm/{metadata → persistence/idb/metadata}/openMetadataDatabase.js +12 -3
- package/dist/esm/persistence/idb/metadata/openMetadataDatabase.js.map +1 -0
- package/dist/esm/persistence/idb/queries/IdbQueryDb.d.ts +41 -0
- package/dist/esm/persistence/idb/queries/IdbQueryDb.js +174 -0
- package/dist/esm/persistence/idb/queries/IdbQueryDb.js.map +1 -0
- package/dist/esm/{migration → persistence/idb/queries/migration}/db.d.ts +1 -1
- package/dist/esm/{migration → persistence/idb/queries/migration}/db.js +10 -48
- package/dist/esm/persistence/idb/queries/migration/db.js.map +1 -0
- package/dist/esm/persistence/idb/queries/migration/engine.d.ts +12 -0
- package/dist/esm/{migration → persistence/idb/queries/migration}/engine.js +29 -46
- package/dist/esm/persistence/idb/queries/migration/engine.js.map +1 -0
- package/dist/esm/{migration → persistence/idb/queries/migration}/migrations.d.ts +1 -3
- package/dist/esm/{migration → persistence/idb/queries/migration}/migrations.js +11 -10
- package/dist/esm/persistence/idb/queries/migration/migrations.js.map +1 -0
- package/dist/esm/{migration → persistence/idb/queries/migration}/openQueryDatabase.d.ts +1 -3
- package/dist/esm/{migration → persistence/idb/queries/migration}/openQueryDatabase.js +4 -7
- package/dist/esm/persistence/idb/queries/migration/openQueryDatabase.js.map +1 -0
- package/dist/esm/{migration → persistence/idb/queries/migration}/paths.js +2 -2
- package/dist/esm/persistence/idb/queries/migration/paths.js.map +1 -0
- package/dist/esm/persistence/idb/queries/migration/paths.test.js.map +1 -0
- package/dist/esm/persistence/idb/queries/migration/types.d.ts +6 -0
- package/dist/esm/persistence/idb/queries/migration/types.js.map +1 -0
- package/dist/esm/persistence/idb/queries/ranges.d.ts +2 -0
- package/dist/esm/persistence/idb/queries/ranges.js +66 -0
- package/dist/esm/persistence/idb/queries/ranges.js.map +1 -0
- package/dist/esm/{idb.d.ts → persistence/idb/util.d.ts} +11 -0
- package/dist/esm/{idb.js → persistence/idb/util.js} +58 -1
- package/dist/esm/persistence/idb/util.js.map +1 -0
- package/dist/esm/persistence/interfaces.d.ts +181 -0
- package/dist/esm/persistence/interfaces.js +2 -0
- package/dist/esm/persistence/interfaces.js.map +1 -0
- package/dist/esm/persistence/persistence.d.ts +4 -0
- package/dist/esm/persistence/persistence.js +126 -0
- package/dist/esm/persistence/persistence.js.map +1 -0
- package/dist/esm/queries/BaseQuery.d.ts +2 -1
- package/dist/esm/queries/BaseQuery.js +3 -0
- package/dist/esm/queries/BaseQuery.js.map +1 -1
- package/dist/esm/queries/CollectionQueries.d.ts +1 -1
- package/dist/esm/queries/FindAllQuery.js +1 -3
- package/dist/esm/queries/FindAllQuery.js.map +1 -1
- package/dist/esm/queries/FindInfiniteQuery.js +2 -5
- package/dist/esm/queries/FindInfiniteQuery.js.map +1 -1
- package/dist/esm/queries/FindOneQuery.js +1 -3
- package/dist/esm/queries/FindOneQuery.js.map +1 -1
- package/dist/esm/queries/FindPageQuery.js +1 -3
- package/dist/esm/queries/FindPageQuery.js.map +1 -1
- package/dist/esm/queries/QueryCache.d.ts +1 -1
- package/dist/esm/queries/QueryCache.js +4 -0
- package/dist/esm/queries/QueryCache.js.map +1 -1
- package/dist/esm/sync/FileSync.d.ts +23 -8
- package/dist/esm/sync/FileSync.js +76 -28
- package/dist/esm/sync/FileSync.js.map +1 -1
- package/dist/esm/sync/PresenceManager.d.ts +4 -3
- package/dist/esm/sync/PresenceManager.js +2 -2
- package/dist/esm/sync/PresenceManager.js.map +1 -1
- package/dist/esm/sync/PushPullSync.d.ts +4 -6
- package/dist/esm/sync/PushPullSync.js +13 -12
- package/dist/esm/sync/PushPullSync.js.map +1 -1
- package/dist/esm/sync/Sync.d.ts +9 -11
- package/dist/esm/sync/Sync.js +34 -29
- package/dist/esm/sync/Sync.js.map +1 -1
- package/dist/esm/sync/WebSocketSync.d.ts +4 -6
- package/dist/esm/sync/WebSocketSync.js +20 -22
- package/dist/esm/sync/WebSocketSync.js.map +1 -1
- package/dist/esm/utils/Disposable.d.ts +5 -2
- package/dist/esm/utils/Disposable.js +3 -2
- package/dist/esm/utils/Disposable.js.map +1 -1
- package/dist/esm/utils/wip.d.ts +2 -0
- package/dist/esm/utils/wip.js +5 -0
- package/dist/esm/utils/wip.js.map +1 -0
- package/package.json +2 -2
- package/src/__tests__/batching.test.ts +6 -6
- package/src/__tests__/entities.test.ts +1 -1
- package/src/__tests__/fixtures/testStorage.ts +2 -10
- package/src/__tests__/queries.test.ts +1 -1
- package/src/backup.ts +3 -4
- package/src/client/Client.ts +69 -226
- package/src/client/ClientDescriptor.ts +53 -184
- package/src/context/Time.ts +35 -0
- package/src/context/context.ts +200 -0
- package/src/entities/DocumentManager.ts +0 -3
- package/src/entities/Entity.test.ts +9 -9
- package/src/entities/Entity.ts +6 -12
- package/src/entities/EntityCache.ts +0 -9
- package/src/entities/EntityMetadata.ts +4 -4
- package/src/entities/EntityStore.ts +26 -29
- package/src/entities/OperationBatcher.ts +9 -11
- package/src/entities/types.ts +1 -1
- package/src/errors.ts +13 -0
- package/src/files/EntityFile.ts +16 -5
- package/src/files/FileManager.ts +18 -245
- package/src/files/utils.ts +0 -15
- package/src/index.ts +2 -1
- package/src/{metadata → persistence}/MessageCreator.ts +46 -36
- package/src/persistence/PersistenceFiles.ts +227 -0
- package/src/persistence/PersistenceMetadata.ts +425 -0
- package/src/persistence/PersistenceQueries.ts +22 -0
- package/src/persistence/PersistenceRebaser.ts +171 -0
- package/src/{IDBService.ts → persistence/idb/IdbService.ts} +45 -12
- package/src/{files/FileStorage.ts → persistence/idb/files/IdbPersistenceFileDb.ts} +128 -86
- package/src/persistence/idb/idbPersistence.ts +116 -0
- package/src/persistence/idb/metadata/IdbMetadataDb.ts +460 -0
- package/src/{metadata → persistence/idb/metadata}/openMetadataDatabase.ts +21 -4
- package/src/persistence/idb/queries/IdbQueryDb.ts +251 -0
- package/src/{migration → persistence/idb/queries/migration}/db.ts +18 -72
- package/src/{migration → persistence/idb/queries/migration}/engine.ts +39 -62
- package/src/{migration → persistence/idb/queries/migration}/migrations.ts +13 -18
- package/src/{migration → persistence/idb/queries/migration}/openQueryDatabase.ts +5 -14
- package/src/{migration → persistence/idb/queries/migration}/paths.ts +4 -3
- package/src/persistence/idb/queries/migration/types.ts +8 -0
- package/src/persistence/idb/queries/ranges.ts +107 -0
- package/src/{idb.ts → persistence/idb/util.ts} +75 -0
- package/src/persistence/interfaces.ts +240 -0
- package/src/persistence/persistence.ts +223 -0
- package/src/queries/BaseQuery.ts +5 -1
- package/src/queries/CollectionQueries.ts +2 -2
- package/src/queries/FindAllQuery.ts +1 -3
- package/src/queries/FindInfiniteQuery.ts +2 -5
- package/src/queries/FindOneQuery.ts +1 -3
- package/src/queries/FindPageQuery.ts +1 -3
- package/src/queries/QueryCache.ts +20 -1
- package/src/sync/FileSync.ts +93 -30
- package/src/sync/PresenceManager.ts +5 -7
- package/src/sync/PushPullSync.ts +23 -19
- package/src/sync/Sync.ts +45 -36
- package/src/sync/WebSocketSync.ts +41 -27
- package/src/utils/Disposable.ts +7 -4
- package/src/utils/wip.ts +5 -0
- package/dist/esm/IDBService.js.map +0 -1
- package/dist/esm/__tests__/legacyOids.test.d.ts +0 -1
- package/dist/esm/__tests__/legacyOids.test.js +0 -352
- package/dist/esm/__tests__/legacyOids.test.js.map +0 -1
- package/dist/esm/context.d.ts +0 -45
- package/dist/esm/files/FileStorage.d.ts +0 -47
- package/dist/esm/files/FileStorage.js.map +0 -1
- package/dist/esm/idb.js.map +0 -1
- package/dist/esm/metadata/AckInfoStore.d.ts +0 -10
- package/dist/esm/metadata/AckInfoStore.js +0 -22
- package/dist/esm/metadata/AckInfoStore.js.map +0 -1
- package/dist/esm/metadata/BaselinesStore.d.ts +0 -40
- package/dist/esm/metadata/BaselinesStore.js +0 -102
- package/dist/esm/metadata/BaselinesStore.js.map +0 -1
- package/dist/esm/metadata/LocalReplicaStore.d.ts +0 -19
- package/dist/esm/metadata/LocalReplicaStore.js +0 -56
- package/dist/esm/metadata/LocalReplicaStore.js.map +0 -1
- package/dist/esm/metadata/MessageCreator.js.map +0 -1
- package/dist/esm/metadata/Metadata.d.ts +0 -146
- package/dist/esm/metadata/Metadata.js +0 -452
- package/dist/esm/metadata/Metadata.js.map +0 -1
- package/dist/esm/metadata/OperationsStore.d.ts +0 -62
- package/dist/esm/metadata/OperationsStore.js +0 -175
- package/dist/esm/metadata/OperationsStore.js.map +0 -1
- package/dist/esm/metadata/SchemaStore.d.ts +0 -9
- package/dist/esm/metadata/SchemaStore.js +0 -35
- package/dist/esm/metadata/SchemaStore.js.map +0 -1
- package/dist/esm/metadata/openMetadataDatabase.js.map +0 -1
- package/dist/esm/migration/db.js.map +0 -1
- package/dist/esm/migration/engine.d.ts +0 -15
- package/dist/esm/migration/engine.js.map +0 -1
- package/dist/esm/migration/errors.d.ts +0 -5
- package/dist/esm/migration/errors.js +0 -8
- package/dist/esm/migration/errors.js.map +0 -1
- package/dist/esm/migration/migrations.js.map +0 -1
- package/dist/esm/migration/openQueryDatabase.js.map +0 -1
- package/dist/esm/migration/openWIPDatabase.d.ts +0 -11
- package/dist/esm/migration/openWIPDatabase.js +0 -65
- package/dist/esm/migration/openWIPDatabase.js.map +0 -1
- package/dist/esm/migration/paths.js.map +0 -1
- package/dist/esm/migration/paths.test.js.map +0 -1
- package/dist/esm/migration/types.d.ts +0 -3
- package/dist/esm/migration/types.js.map +0 -1
- package/dist/esm/queries/QueryableStorage.d.ts +0 -20
- package/dist/esm/queries/QueryableStorage.js +0 -90
- package/dist/esm/queries/QueryableStorage.js.map +0 -1
- package/dist/esm/queries/dbQueries.d.ts +0 -22
- package/dist/esm/queries/dbQueries.js +0 -130
- package/dist/esm/queries/dbQueries.js.map +0 -1
- package/src/__tests__/legacyOids.test.ts +0 -375
- package/src/context.ts +0 -55
- package/src/metadata/AckInfoStore.ts +0 -30
- package/src/metadata/BaselinesStore.ts +0 -188
- package/src/metadata/LocalReplicaStore.ts +0 -79
- package/src/metadata/Metadata.ts +0 -685
- package/src/metadata/OperationsStore.ts +0 -332
- package/src/metadata/SchemaStore.ts +0 -47
- package/src/migration/errors.ts +0 -7
- package/src/migration/openWIPDatabase.ts +0 -97
- package/src/migration/types.ts +0 -4
- package/src/queries/QueryableStorage.ts +0 -122
- package/src/queries/dbQueries.ts +0 -161
- /package/dist/esm/{context.js → context/context.js} +0 -0
- /package/dist/esm/{migration → persistence/idb/queries/migration}/paths.d.ts +0 -0
- /package/dist/esm/{migration → persistence/idb/queries/migration}/paths.test.d.ts +0 -0
- /package/dist/esm/{migration → persistence/idb/queries/migration}/paths.test.js +0 -0
- /package/dist/esm/{migration → persistence/idb/queries/migration}/types.js +0 -0
- /package/src/{migration → persistence/idb/queries/migration}/paths.test.ts +0 -0
|
@@ -1,6 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import { Disposable } from '../utils/Disposable.js';
|
|
2
|
+
export class FileSync extends Disposable {
|
|
3
|
+
constructor({ endpointProvider, ctx, }) {
|
|
4
|
+
super();
|
|
5
|
+
this.onFileAdded = async (data) => {
|
|
6
|
+
if (data.remote)
|
|
7
|
+
return;
|
|
8
|
+
this.ctx.log('debug', 'Uploading file', data.id, data.name);
|
|
9
|
+
try {
|
|
10
|
+
await this.uploadFile(data);
|
|
11
|
+
this.ctx.internalEvents.emit(`fileUploaded:${data.id}`);
|
|
12
|
+
}
|
|
13
|
+
catch (e) {
|
|
14
|
+
this.ctx.log('error', 'File upload failed', e);
|
|
15
|
+
}
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Attempts to upload a file to the sync server. Will be retried
|
|
19
|
+
* according to retry config.
|
|
20
|
+
*/
|
|
21
|
+
this.uploadFile = async (data, retries = { current: 0, max: 3 }) => {
|
|
4
22
|
const file = data.file;
|
|
5
23
|
if (!file) {
|
|
6
24
|
throw new Error('Cannot upload a non-local file');
|
|
@@ -19,32 +37,47 @@ export class FileSync {
|
|
|
19
37
|
},
|
|
20
38
|
});
|
|
21
39
|
if (response.ok) {
|
|
22
|
-
this.log('info', 'File upload successful');
|
|
40
|
+
this.ctx.log('info', 'File upload successful');
|
|
23
41
|
return {
|
|
24
42
|
success: true,
|
|
25
|
-
retry: false,
|
|
26
43
|
};
|
|
27
44
|
}
|
|
28
45
|
else {
|
|
29
46
|
const responseText = await response.text();
|
|
30
|
-
this.log('error', 'File upload failed', response.status, responseText);
|
|
47
|
+
this.ctx.log('error', 'File upload failed', response.status, responseText);
|
|
48
|
+
if (response.status < 500 || retries.current >= retries.max) {
|
|
49
|
+
return {
|
|
50
|
+
success: false,
|
|
51
|
+
error: `Failed to upload file: ${response.status} ${responseText}`,
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
55
|
+
return this.uploadFile(data, {
|
|
56
|
+
max: retries.max,
|
|
57
|
+
current: retries.current + 1,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
catch (e) {
|
|
62
|
+
this.ctx.log('error', 'File upload failed', e);
|
|
63
|
+
if (retries.current >= retries.max) {
|
|
31
64
|
return {
|
|
32
65
|
success: false,
|
|
33
|
-
|
|
34
|
-
error: `Failed to upload file: ${response.status} ${responseText}`,
|
|
66
|
+
error: e.message,
|
|
35
67
|
};
|
|
36
68
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
retry: true,
|
|
43
|
-
error: e.message,
|
|
44
|
-
};
|
|
69
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
70
|
+
return this.uploadFile(data, {
|
|
71
|
+
max: retries.max,
|
|
72
|
+
current: retries.current + 1,
|
|
73
|
+
});
|
|
45
74
|
}
|
|
46
75
|
};
|
|
47
|
-
|
|
76
|
+
/**
|
|
77
|
+
* Pulls a file from the server by its ID. Will be retried
|
|
78
|
+
* according to retry config.
|
|
79
|
+
*/
|
|
80
|
+
this.getFile = async (id, retries = { current: 0, max: 3 }) => {
|
|
48
81
|
const { files: fileEndpoint, token } = await this.endpointProvider.getEndpoints();
|
|
49
82
|
try {
|
|
50
83
|
const response = await fetch(fileEndpoint + `/${id}`, {
|
|
@@ -63,24 +96,39 @@ export class FileSync {
|
|
|
63
96
|
};
|
|
64
97
|
}
|
|
65
98
|
else {
|
|
66
|
-
this.log('error', 'File information fetch failed', response.status, await response.text());
|
|
99
|
+
this.ctx.log('error', 'File information fetch failed', response.status, await response.text());
|
|
100
|
+
if ((response.status < 500 && response.status !== 404) ||
|
|
101
|
+
retries.current >= retries.max) {
|
|
102
|
+
return {
|
|
103
|
+
success: false,
|
|
104
|
+
error: `Failed to fetch file: ${response.status}`,
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
108
|
+
return this.getFile(id, {
|
|
109
|
+
current: retries.current + 1,
|
|
110
|
+
max: retries.max,
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
catch (e) {
|
|
115
|
+
this.ctx.log('error', 'File information fetch failed', e);
|
|
116
|
+
if (retries.current >= retries.max) {
|
|
67
117
|
return {
|
|
68
118
|
success: false,
|
|
69
|
-
|
|
119
|
+
error: e.message,
|
|
70
120
|
};
|
|
71
121
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
error: e,
|
|
78
|
-
retry: true,
|
|
79
|
-
};
|
|
122
|
+
await new Promise((resolve) => setTimeout(resolve, 1000));
|
|
123
|
+
return this.getFile(id, {
|
|
124
|
+
current: retries.current + 1,
|
|
125
|
+
max: retries.max,
|
|
126
|
+
});
|
|
80
127
|
}
|
|
81
128
|
};
|
|
82
129
|
this.endpointProvider = endpointProvider;
|
|
83
|
-
this.
|
|
130
|
+
this.ctx = ctx;
|
|
131
|
+
this.addDispose(ctx.internalEvents.subscribe('fileAdded', this.onFileAdded));
|
|
84
132
|
}
|
|
85
133
|
}
|
|
86
134
|
//# sourceMappingURL=FileSync.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FileSync.js","sourceRoot":"","sources":["../../../src/sync/FileSync.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"FileSync.js","sourceRoot":"","sources":["../../../src/sync/FileSync.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ServerMessage, EventSubscriber, VerdantInternalPresence } from '@verdant-web/common';
|
|
2
2
|
import type { UserInfo } from '../index.js';
|
|
3
|
-
import {
|
|
3
|
+
import { Context } from '../context/context.js';
|
|
4
|
+
import { LocalReplicaInfo } from '../persistence/interfaces.js';
|
|
4
5
|
export declare const HANDLE_MESSAGE: unique symbol;
|
|
5
6
|
export declare class PresenceManager<Profile = any, Presence = any> extends EventSubscriber<{
|
|
6
7
|
/**
|
|
@@ -38,11 +39,11 @@ export declare class PresenceManager<Profile = any, Presence = any> extends Even
|
|
|
38
39
|
[x: string]: UserInfo<Profile, Presence>;
|
|
39
40
|
};
|
|
40
41
|
get selfReplicaIds(): Set<string>;
|
|
41
|
-
constructor({ initialPresence, updateBatchTimeout, defaultProfile,
|
|
42
|
+
constructor({ initialPresence, updateBatchTimeout, defaultProfile, ctx, }: {
|
|
42
43
|
initialPresence: Presence;
|
|
43
44
|
defaultProfile: Profile;
|
|
44
45
|
updateBatchTimeout?: number;
|
|
45
|
-
|
|
46
|
+
ctx: Context;
|
|
46
47
|
});
|
|
47
48
|
/**
|
|
48
49
|
* Decides if an update is for the local user or not. Even if it's a different replica
|
|
@@ -19,7 +19,7 @@ export class PresenceManager extends EventSubscriber {
|
|
|
19
19
|
get selfReplicaIds() {
|
|
20
20
|
return this._selfReplicaIds;
|
|
21
21
|
}
|
|
22
|
-
constructor({ initialPresence, updateBatchTimeout = 200, defaultProfile,
|
|
22
|
+
constructor({ initialPresence, updateBatchTimeout = 200, defaultProfile, ctx, }) {
|
|
23
23
|
super();
|
|
24
24
|
this._peers = {};
|
|
25
25
|
this._self = { profile: {} };
|
|
@@ -164,7 +164,7 @@ export class PresenceManager extends EventSubscriber {
|
|
|
164
164
|
this.self.id = '';
|
|
165
165
|
this.self.replicaId = '';
|
|
166
166
|
// set the local replica ID as soon as it's loaded
|
|
167
|
-
|
|
167
|
+
ctx.meta.getLocalReplica().then((info) => {
|
|
168
168
|
this.self.replicaId = info.id;
|
|
169
169
|
});
|
|
170
170
|
this._updateBatcher = new Batcher(this.flushPresenceUpdates);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PresenceManager.js","sourceRoot":"","sources":["../../../src/sync/PresenceManager.ts"],"names":[],"mappings":";AAAA,OAAO,EAEN,eAAe,EACf,OAAO,EAGP,uBAAuB,GACvB,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"PresenceManager.js","sourceRoot":"","sources":["../../../src/sync/PresenceManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,26 +1,24 @@
|
|
|
1
1
|
import { ClientMessage, EventSubscriber, PresenceUpdateMessage } from '@verdant-web/common';
|
|
2
|
-
import { Metadata } from '../metadata/Metadata.js';
|
|
3
2
|
import { PresenceManager } from './PresenceManager.js';
|
|
4
3
|
import { ServerSyncEndpointProvider } from './ServerSyncEndpointProvider.js';
|
|
5
4
|
import { SyncTransport, SyncTransportEvents } from './Sync.js';
|
|
5
|
+
import { Context } from '../context/context.js';
|
|
6
6
|
export declare class PushPullSync extends EventSubscriber<SyncTransportEvents> implements SyncTransport {
|
|
7
|
-
readonly meta: Metadata;
|
|
8
7
|
readonly presence: PresenceManager;
|
|
9
8
|
private endpointProvider;
|
|
10
9
|
private heartbeat;
|
|
11
10
|
private fetch;
|
|
12
11
|
readonly mode = "pull";
|
|
13
|
-
private
|
|
12
|
+
private ctx;
|
|
14
13
|
private _isConnected;
|
|
15
14
|
private _status;
|
|
16
15
|
private _hasSynced;
|
|
17
|
-
constructor({ endpointProvider,
|
|
16
|
+
constructor({ endpointProvider, presence, interval, fetch, ctx, }: {
|
|
18
17
|
endpointProvider: ServerSyncEndpointProvider;
|
|
19
|
-
meta: Metadata;
|
|
20
18
|
presence: PresenceManager;
|
|
21
19
|
interval?: number;
|
|
22
|
-
log?: (...args: any[]) => any;
|
|
23
20
|
fetch?: typeof window.fetch;
|
|
21
|
+
ctx: Context;
|
|
24
22
|
});
|
|
25
23
|
setInterval: (interval: number) => void;
|
|
26
24
|
get interval(): number;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { EventSubscriber, VerdantErrorCode, isVerdantErrorResponse, throttle, } from '@verdant-web/common';
|
|
2
2
|
import { Heartbeat } from './Heartbeat.js';
|
|
3
3
|
export class PushPullSync extends EventSubscriber {
|
|
4
|
-
constructor({ endpointProvider,
|
|
4
|
+
constructor({ endpointProvider, presence, interval = 15 * 1000, fetch = window.fetch.bind(window), ctx, }) {
|
|
5
5
|
super();
|
|
6
6
|
this.mode = 'pull';
|
|
7
7
|
this._isConnected = false;
|
|
@@ -11,7 +11,7 @@ export class PushPullSync extends EventSubscriber {
|
|
|
11
11
|
this.heartbeat.setInterval(interval);
|
|
12
12
|
};
|
|
13
13
|
this.sendRequest = async (messages) => {
|
|
14
|
-
this.log('Sending sync request', messages);
|
|
14
|
+
this.ctx.log('debug', 'Sending sync request', messages);
|
|
15
15
|
try {
|
|
16
16
|
const { http: host, token } = await this.endpointProvider.getEndpoints();
|
|
17
17
|
const response = await this.fetch(host, {
|
|
@@ -39,7 +39,7 @@ export class PushPullSync extends EventSubscriber {
|
|
|
39
39
|
await handlePromise;
|
|
40
40
|
}
|
|
41
41
|
else {
|
|
42
|
-
this.log('Sync request failed', response.status, await response.text());
|
|
42
|
+
this.ctx.log('error', 'Sync request failed', response.status, await response.text());
|
|
43
43
|
if (this._isConnected) {
|
|
44
44
|
this._isConnected = false;
|
|
45
45
|
this.emit('onlineChange', false);
|
|
@@ -63,7 +63,7 @@ export class PushPullSync extends EventSubscriber {
|
|
|
63
63
|
this._isConnected = false;
|
|
64
64
|
this.emit('onlineChange', false);
|
|
65
65
|
}
|
|
66
|
-
this.log(error);
|
|
66
|
+
this.ctx.log('error', error);
|
|
67
67
|
this.heartbeat.keepAlive();
|
|
68
68
|
}
|
|
69
69
|
};
|
|
@@ -73,9 +73,9 @@ export class PushPullSync extends EventSubscriber {
|
|
|
73
73
|
// but we can go ahead and preemptively allow ops to be sent
|
|
74
74
|
this._hasSynced = true;
|
|
75
75
|
if (message.ackThisNonce) {
|
|
76
|
-
this.log('Sending sync ack', message.ackThisNonce);
|
|
76
|
+
this.ctx.log('debug', 'Sending sync ack', message.ackThisNonce);
|
|
77
77
|
await this.sendRequest([
|
|
78
|
-
await this.meta.messageCreator.createAck(message.ackThisNonce),
|
|
78
|
+
await this.ctx.meta.messageCreator.createAck(message.ackThisNonce),
|
|
79
79
|
]);
|
|
80
80
|
}
|
|
81
81
|
}
|
|
@@ -119,22 +119,23 @@ export class PushPullSync extends EventSubscriber {
|
|
|
119
119
|
// will include the client's own presence info and fill in missing profile
|
|
120
120
|
// data on the first request. otherwise it would have to wait for the second.
|
|
121
121
|
this.sendRequest([
|
|
122
|
-
await this.meta.messageCreator.createPresenceUpdate(this.presence.self),
|
|
123
|
-
await this.meta.messageCreator.createSyncStep1(),
|
|
122
|
+
await this.ctx.meta.messageCreator.createPresenceUpdate(this.presence.self),
|
|
123
|
+
await this.ctx.meta.messageCreator.createSyncStep1(),
|
|
124
124
|
]);
|
|
125
125
|
};
|
|
126
126
|
// if the server fails to respond in a certain amount of time, we assume
|
|
127
127
|
// the connection is lost and go offline.
|
|
128
128
|
this.onHeartbeatMissed = async () => {
|
|
129
129
|
this.emit('onlineChange', false);
|
|
130
|
-
this.log('Missed heartbeat');
|
|
130
|
+
this.ctx.log('warn', 'Missed heartbeat');
|
|
131
131
|
this._isConnected = false;
|
|
132
132
|
};
|
|
133
133
|
this.syncOnce = async () => {
|
|
134
|
-
await this.sendRequest([
|
|
134
|
+
await this.sendRequest([
|
|
135
|
+
await this.ctx.meta.messageCreator.createSyncStep1(),
|
|
136
|
+
]);
|
|
135
137
|
};
|
|
136
|
-
this.
|
|
137
|
-
this.meta = meta;
|
|
138
|
+
this.ctx = ctx;
|
|
138
139
|
this.presence = presence;
|
|
139
140
|
this.endpointProvider = endpointProvider;
|
|
140
141
|
this.fetch = fetch;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PushPullSync.js","sourceRoot":"","sources":["../../../src/sync/PushPullSync.ts"],"names":[],"mappings":"AAAA,OAAO,EAEN,eAAe,EAGf,gBAAgB,
|
|
1
|
+
{"version":3,"file":"PushPullSync.js","sourceRoot":"","sources":["../../../src/sync/PushPullSync.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/sync/Sync.d.ts
CHANGED
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import { ClientMessage, DocumentBaseline, EventSubscriber, FileData, Operation, ServerMessage } from '@verdant-web/common';
|
|
2
|
-
import { Metadata } from '../metadata/Metadata.js';
|
|
3
2
|
import { PresenceManager } from './PresenceManager.js';
|
|
4
3
|
import { FilePullResult, FileUploadResult } from './FileSync.js';
|
|
5
4
|
import { ServerSyncEndpointProviderConfig } from './ServerSyncEndpointProvider.js';
|
|
6
|
-
import { Context } from '../context.js';
|
|
5
|
+
import { Context } from '../context/context.js';
|
|
7
6
|
type SyncEvents = {
|
|
8
7
|
onlineChange: (isOnline: boolean) => void;
|
|
9
8
|
syncingChange: (syncing: boolean) => void;
|
|
@@ -58,9 +57,7 @@ export declare class NoSync<Presence = any, Profile = any> extends EventSubscrib
|
|
|
58
57
|
readonly status = "paused";
|
|
59
58
|
readonly pullInterval = 0;
|
|
60
59
|
readonly presence: PresenceManager<any, any>;
|
|
61
|
-
constructor(
|
|
62
|
-
meta: Metadata;
|
|
63
|
-
});
|
|
60
|
+
constructor(ctx: Context);
|
|
64
61
|
uploadFile: () => Promise<{
|
|
65
62
|
success: boolean;
|
|
66
63
|
retry: boolean;
|
|
@@ -135,12 +132,10 @@ export declare class ServerSync<Presence = any, Profile = any> extends EventSubs
|
|
|
135
132
|
private onData;
|
|
136
133
|
private broadcastChannel;
|
|
137
134
|
private _activelySyncing;
|
|
138
|
-
private meta;
|
|
139
135
|
readonly presence: PresenceManager<Profile, Presence>;
|
|
140
136
|
private onOutgoingMessage?;
|
|
141
|
-
private
|
|
142
|
-
constructor({ authEndpoint, fetchAuth, fetch, initialPresence, automaticTransportSelection, autoStart, initialTransport, pullInterval, presenceUpdateBatchTimeout, defaultProfile, useBroadcastChannel, onOutgoingMessage, EXPERIMENTAL_backgroundSync, }: ServerSyncOptions<Profile, Presence>, {
|
|
143
|
-
meta: Metadata;
|
|
137
|
+
private ctx;
|
|
138
|
+
constructor({ authEndpoint, fetchAuth, fetch, initialPresence, automaticTransportSelection, autoStart, initialTransport, pullInterval, presenceUpdateBatchTimeout, defaultProfile, useBroadcastChannel, onOutgoingMessage, EXPERIMENTAL_backgroundSync, }: ServerSyncOptions<Profile, Presence>, { ctx, onData, }: {
|
|
144
139
|
ctx: Context;
|
|
145
140
|
onData: (data: {
|
|
146
141
|
operations: Operation[];
|
|
@@ -151,7 +146,6 @@ export declare class ServerSync<Presence = any, Profile = any> extends EventSubs
|
|
|
151
146
|
get canDoRealtime(): boolean;
|
|
152
147
|
get syncing(): boolean;
|
|
153
148
|
private handleBroadcastChannelMessage;
|
|
154
|
-
private onTokenExpired;
|
|
155
149
|
private handleMessage;
|
|
156
150
|
private handleOnlineChange;
|
|
157
151
|
private handlePresenceUpdate;
|
|
@@ -159,7 +153,11 @@ export declare class ServerSync<Presence = any, Profile = any> extends EventSubs
|
|
|
159
153
|
setPullInterval: (interval: number) => void;
|
|
160
154
|
get pullInterval(): number;
|
|
161
155
|
send: (message: ClientMessage) => Promise<void>;
|
|
162
|
-
uploadFile: (info: FileData) => Promise<FileUploadResult
|
|
156
|
+
uploadFile: (info: FileData) => Promise<FileUploadResult | {
|
|
157
|
+
success: boolean;
|
|
158
|
+
retry: boolean;
|
|
159
|
+
error: string;
|
|
160
|
+
}>;
|
|
163
161
|
getFile: (id: string) => Promise<FilePullResult>;
|
|
164
162
|
start: () => Promise<void>;
|
|
165
163
|
stop: () => void;
|
package/dist/esm/sync/Sync.js
CHANGED
|
@@ -13,7 +13,7 @@ export class NoSync extends EventSubscriber {
|
|
|
13
13
|
reconnect() { }
|
|
14
14
|
setMode() { }
|
|
15
15
|
setPullInterval() { }
|
|
16
|
-
constructor(
|
|
16
|
+
constructor(ctx) {
|
|
17
17
|
super();
|
|
18
18
|
this.mode = 'pull';
|
|
19
19
|
this.destroy = () => { };
|
|
@@ -29,19 +29,19 @@ export class NoSync extends EventSubscriber {
|
|
|
29
29
|
this.getFile = async () => {
|
|
30
30
|
return {
|
|
31
31
|
success: false,
|
|
32
|
-
|
|
32
|
+
error: 'Sync is not active',
|
|
33
33
|
};
|
|
34
34
|
};
|
|
35
35
|
this.syncOnce = async () => { };
|
|
36
36
|
this.presence = new PresenceManager({
|
|
37
37
|
initialPresence: null,
|
|
38
38
|
defaultProfile: null,
|
|
39
|
-
|
|
39
|
+
ctx,
|
|
40
40
|
});
|
|
41
41
|
}
|
|
42
42
|
}
|
|
43
43
|
export class ServerSync extends EventSubscriber {
|
|
44
|
-
constructor({ authEndpoint, fetchAuth, fetch, initialPresence, automaticTransportSelection = true, autoStart, initialTransport, pullInterval, presenceUpdateBatchTimeout, defaultProfile, useBroadcastChannel, onOutgoingMessage, EXPERIMENTAL_backgroundSync, }, {
|
|
44
|
+
constructor({ authEndpoint, fetchAuth, fetch, initialPresence, automaticTransportSelection = true, autoStart, initialTransport, pullInterval, presenceUpdateBatchTimeout, defaultProfile, useBroadcastChannel, onOutgoingMessage, EXPERIMENTAL_backgroundSync, }, { ctx, onData, }) {
|
|
45
45
|
super();
|
|
46
46
|
this.broadcastChannel = null;
|
|
47
47
|
this._activelySyncing = false;
|
|
@@ -50,9 +50,6 @@ export class ServerSync extends EventSubscriber {
|
|
|
50
50
|
this.handleMessage(event.data.message, { source: 'broadcastChannel' });
|
|
51
51
|
}
|
|
52
52
|
};
|
|
53
|
-
this.onTokenExpired = () => {
|
|
54
|
-
this.endpointProvider.clearCache();
|
|
55
|
-
};
|
|
56
53
|
this.handleMessage = async (message, { source } = {
|
|
57
54
|
source: 'network',
|
|
58
55
|
}) => {
|
|
@@ -60,10 +57,10 @@ export class ServerSync extends EventSubscriber {
|
|
|
60
57
|
// TODO: move this into metadata
|
|
61
58
|
if (message.type === 'op-re' || message.type === 'sync-resp') {
|
|
62
59
|
for (const op of message.operations) {
|
|
63
|
-
this.
|
|
60
|
+
this.ctx.time.update(op.timestamp);
|
|
64
61
|
}
|
|
65
62
|
}
|
|
66
|
-
this.log('debug', 'sync message', JSON.stringify(message, null, 2));
|
|
63
|
+
this.ctx.log('debug', 'sync message', JSON.stringify(message, null, 2));
|
|
67
64
|
switch (message.type) {
|
|
68
65
|
case 'op-re':
|
|
69
66
|
await this.onData({
|
|
@@ -71,11 +68,11 @@ export class ServerSync extends EventSubscriber {
|
|
|
71
68
|
baselines: message.baselines,
|
|
72
69
|
});
|
|
73
70
|
if (message.globalAckTimestamp) {
|
|
74
|
-
await this.meta.setGlobalAck(message.globalAckTimestamp);
|
|
71
|
+
await this.ctx.meta.setGlobalAck(message.globalAckTimestamp);
|
|
75
72
|
}
|
|
76
73
|
break;
|
|
77
74
|
case 'global-ack':
|
|
78
|
-
await this.meta.setGlobalAck(message.timestamp);
|
|
75
|
+
await this.ctx.meta.setGlobalAck(message.timestamp);
|
|
79
76
|
break;
|
|
80
77
|
case 'sync-resp':
|
|
81
78
|
this._activelySyncing = true;
|
|
@@ -86,18 +83,19 @@ export class ServerSync extends EventSubscriber {
|
|
|
86
83
|
reset: message.overwriteLocalData,
|
|
87
84
|
});
|
|
88
85
|
if (message.globalAckTimestamp) {
|
|
89
|
-
await this.meta.setGlobalAck(message.globalAckTimestamp);
|
|
86
|
+
await this.ctx.meta.setGlobalAck(message.globalAckTimestamp);
|
|
90
87
|
}
|
|
91
|
-
await this.meta.updateLastSynced(message.ackedTimestamp);
|
|
88
|
+
await this.ctx.meta.updateLastSynced(message.ackedTimestamp);
|
|
92
89
|
this._activelySyncing = false;
|
|
93
90
|
this.emit('syncingChange', false);
|
|
94
91
|
break;
|
|
95
92
|
case 'need-since':
|
|
96
93
|
this.emit('serverReset', message.since);
|
|
97
|
-
this.
|
|
94
|
+
this.ctx.files.onServerReset(message.since);
|
|
95
|
+
this.activeSync.send(await this.ctx.meta.messageCreator.createSyncStep1(message.since));
|
|
98
96
|
break;
|
|
99
97
|
case 'server-ack':
|
|
100
|
-
await this.meta.updateLastSynced(message.timestamp);
|
|
98
|
+
await this.ctx.meta.updateLastSynced(message.timestamp);
|
|
101
99
|
}
|
|
102
100
|
// avoid rebroadcasting messages
|
|
103
101
|
if (source === 'network') {
|
|
@@ -107,13 +105,23 @@ export class ServerSync extends EventSubscriber {
|
|
|
107
105
|
});
|
|
108
106
|
}
|
|
109
107
|
// update presence if necessary
|
|
110
|
-
this.presence[HANDLE_MESSAGE](await this.meta.
|
|
108
|
+
this.presence[HANDLE_MESSAGE](await this.ctx.meta.getLocalReplica(), message);
|
|
111
109
|
};
|
|
112
|
-
this.handleOnlineChange = (online) => {
|
|
110
|
+
this.handleOnlineChange = async (online) => {
|
|
113
111
|
this.emit('onlineChange', online);
|
|
112
|
+
// if online, attempt to upload any unsynced files.
|
|
113
|
+
if (online) {
|
|
114
|
+
const unsyncedFiles = await this.ctx.files.listUnsynced();
|
|
115
|
+
const results = await Promise.allSettled(unsyncedFiles.map((file) => this.fileSync.uploadFile(file)));
|
|
116
|
+
if (results.some((r) => r.status === 'rejected')) {
|
|
117
|
+
this.ctx.log('error', 'Failed to upload unsynced files', results
|
|
118
|
+
.filter((r) => r.status === 'rejected')
|
|
119
|
+
.map((r) => r.reason));
|
|
120
|
+
}
|
|
121
|
+
}
|
|
114
122
|
};
|
|
115
123
|
this.handlePresenceUpdate = async (data) => {
|
|
116
|
-
this.send(await this.meta.messageCreator.createPresenceUpdate(data));
|
|
124
|
+
this.send(await this.ctx.meta.messageCreator.createPresenceUpdate(data));
|
|
117
125
|
};
|
|
118
126
|
this.setMode = (transport) => {
|
|
119
127
|
if (transport === 'realtime' && !this.canDoRealtime) {
|
|
@@ -128,7 +136,7 @@ export class ServerSync extends EventSubscriber {
|
|
|
128
136
|
}
|
|
129
137
|
if (newSync === this.activeSync)
|
|
130
138
|
return;
|
|
131
|
-
this.log('debug', 'switching to', transport, 'mode');
|
|
139
|
+
this.ctx.log('debug', 'switching to', transport, 'mode');
|
|
132
140
|
// transfer state to new sync
|
|
133
141
|
if (this.activeSync.status === 'active') {
|
|
134
142
|
newSync.start();
|
|
@@ -160,7 +168,7 @@ export class ServerSync extends EventSubscriber {
|
|
|
160
168
|
};
|
|
161
169
|
this.uploadFile = async (info) => {
|
|
162
170
|
var _a;
|
|
163
|
-
this.log('info', 'Uploading file', {
|
|
171
|
+
this.ctx.log('info', 'Uploading file', {
|
|
164
172
|
name: info.name,
|
|
165
173
|
type: info.type,
|
|
166
174
|
id: info.id,
|
|
@@ -208,15 +216,14 @@ export class ServerSync extends EventSubscriber {
|
|
|
208
216
|
this.syncOnce = () => {
|
|
209
217
|
return this.pushPullSync.syncOnce();
|
|
210
218
|
};
|
|
211
|
-
this.meta = meta;
|
|
212
219
|
this.onData = onData;
|
|
213
|
-
this.
|
|
220
|
+
this.ctx = ctx;
|
|
214
221
|
this.onOutgoingMessage = onOutgoingMessage;
|
|
215
222
|
this.presence = new PresenceManager({
|
|
216
223
|
initialPresence,
|
|
217
224
|
defaultProfile,
|
|
218
225
|
updateBatchTimeout: presenceUpdateBatchTimeout,
|
|
219
|
-
|
|
226
|
+
ctx,
|
|
220
227
|
});
|
|
221
228
|
this.endpointProvider = new ServerSyncEndpointProvider({
|
|
222
229
|
authEndpoint,
|
|
@@ -225,21 +232,19 @@ export class ServerSync extends EventSubscriber {
|
|
|
225
232
|
});
|
|
226
233
|
this.webSocketSync = new WebSocketSync({
|
|
227
234
|
endpointProvider: this.endpointProvider,
|
|
228
|
-
meta,
|
|
229
235
|
presence: this.presence,
|
|
230
|
-
|
|
236
|
+
ctx,
|
|
231
237
|
});
|
|
232
238
|
this.pushPullSync = new PushPullSync({
|
|
233
239
|
endpointProvider: this.endpointProvider,
|
|
234
|
-
meta,
|
|
235
240
|
presence: this.presence,
|
|
236
|
-
log: ctx.log,
|
|
237
241
|
interval: pullInterval,
|
|
238
242
|
fetch,
|
|
243
|
+
ctx,
|
|
239
244
|
});
|
|
240
245
|
this.fileSync = new FileSync({
|
|
241
246
|
endpointProvider: this.endpointProvider,
|
|
242
|
-
|
|
247
|
+
ctx,
|
|
243
248
|
});
|
|
244
249
|
if (useBroadcastChannel && 'BroadcastChannel' in window) {
|
|
245
250
|
this.broadcastChannel = new BroadcastChannel(`verdant-${ctx.namespace}`);
|
|
@@ -252,7 +257,7 @@ export class ServerSync extends EventSubscriber {
|
|
|
252
257
|
this.activeSync = this.pushPullSync;
|
|
253
258
|
}
|
|
254
259
|
this.presence.subscribe('update', this.handlePresenceUpdate);
|
|
255
|
-
|
|
260
|
+
ctx.meta.events.subscribe('syncMessage', this.send);
|
|
256
261
|
this.webSocketSync.subscribe('message', this.handleMessage);
|
|
257
262
|
this.webSocketSync.subscribe('onlineChange', this.handleOnlineChange);
|
|
258
263
|
this.pushPullSync.subscribe('message', this.handleMessage);
|