@verdant-web/store 2.0.1 → 2.0.3
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/cjs/BackoffScheduler.d.ts +19 -19
- package/dist/cjs/BackoffScheduler.js +44 -44
- package/dist/cjs/DocumentManager.d.ts +28 -28
- package/dist/cjs/DocumentManager.js +44 -44
- package/dist/cjs/IDBService.d.ts +9 -9
- package/dist/cjs/IDBService.js +46 -46
- package/dist/cjs/UndoHistory.d.ts +16 -16
- package/dist/cjs/UndoHistory.js +50 -50
- package/dist/cjs/__tests__/batching.test.d.ts +1 -1
- package/dist/cjs/__tests__/batching.test.js +44 -44
- package/dist/cjs/__tests__/documents.test.d.ts +1 -1
- package/dist/cjs/__tests__/documents.test.js +398 -398
- package/dist/cjs/__tests__/fixtures/testStorage.d.ts +118 -118
- package/dist/cjs/__tests__/fixtures/testStorage.js +115 -115
- package/dist/cjs/__tests__/queries.test.d.ts +1 -1
- package/dist/cjs/__tests__/queries.test.js +262 -262
- package/dist/cjs/__tests__/setup/indexedDB.d.ts +1 -1
- package/dist/cjs/__tests__/setup/indexedDB.js +3 -3
- package/dist/cjs/__tests__/undo.test.d.ts +1 -1
- package/dist/cjs/__tests__/undo.test.js +86 -86
- package/dist/cjs/client/Client.d.ts +86 -86
- package/dist/cjs/client/Client.js +226 -226
- package/dist/cjs/client/ClientDescriptor.d.ts +62 -62
- package/dist/cjs/client/ClientDescriptor.js +108 -108
- package/dist/cjs/constants.d.ts +1 -1
- package/dist/cjs/constants.js +4 -4
- package/dist/cjs/context.d.ts +17 -17
- package/dist/cjs/context.js +2 -2
- package/dist/cjs/files/EntityFile.d.ts +27 -27
- package/dist/cjs/files/EntityFile.js +71 -71
- package/dist/cjs/files/FileManager.d.ts +42 -42
- package/dist/cjs/files/FileManager.js +145 -145
- package/dist/cjs/files/FileStorage.d.ts +27 -27
- package/dist/cjs/files/FileStorage.js +93 -93
- package/dist/cjs/files/utils.d.ts +8 -8
- package/dist/cjs/files/utils.js +55 -55
- package/dist/cjs/files/utils.test.d.ts +1 -1
- package/dist/cjs/files/utils.test.js +80 -80
- package/dist/cjs/idb.d.ts +8 -8
- package/dist/cjs/idb.js +87 -87
- package/dist/cjs/index.d.ts +19 -19
- package/dist/cjs/index.js +20 -20
- package/dist/cjs/indexes.d.ts +3 -3
- package/dist/cjs/indexes.js +19 -19
- package/dist/cjs/metadata/AckInfoStore.d.ts +10 -10
- package/dist/cjs/metadata/AckInfoStore.js +25 -25
- package/dist/cjs/metadata/BaselinesStore.d.ts +33 -33
- package/dist/cjs/metadata/BaselinesStore.js +59 -59
- package/dist/cjs/metadata/LocalReplicaStore.d.ts +17 -17
- package/dist/cjs/metadata/LocalReplicaStore.js +47 -47
- package/dist/cjs/metadata/MessageCreator.d.ts +19 -19
- package/dist/cjs/metadata/MessageCreator.js +127 -127
- package/dist/cjs/metadata/Metadata.d.ts +106 -106
- package/dist/cjs/metadata/Metadata.js +336 -336
- package/dist/cjs/metadata/OperationsStore.d.ts +50 -50
- package/dist/cjs/metadata/OperationsStore.js +145 -145
- package/dist/cjs/metadata/SchemaStore.d.ts +9 -9
- package/dist/cjs/metadata/SchemaStore.js +38 -38
- package/dist/cjs/metadata/openMetadataDatabase.d.ts +8 -8
- package/dist/cjs/metadata/openMetadataDatabase.js +105 -105
- package/dist/cjs/openDocumentDatabase.d.ts +12 -12
- package/dist/cjs/openDocumentDatabase.js +424 -424
- package/dist/cjs/queries2/BaseQuery.d.ts +39 -39
- package/dist/cjs/queries2/BaseQuery.js +98 -98
- package/dist/cjs/queries2/CollectionQueries.d.ts +55 -55
- package/dist/cjs/queries2/CollectionQueries.js +82 -82
- package/dist/cjs/queries2/FindAllQuery.d.ts +11 -11
- package/dist/cjs/queries2/FindAllQuery.js +33 -33
- package/dist/cjs/queries2/FindInfiniteQuery.d.ts +18 -18
- package/dist/cjs/queries2/FindInfiniteQuery.js +60 -60
- package/dist/cjs/queries2/FindOneQuery.d.ts +11 -11
- package/dist/cjs/queries2/FindOneQuery.js +33 -33
- package/dist/cjs/queries2/FindPageQuery.d.ts +23 -23
- package/dist/cjs/queries2/FindPageQuery.js +67 -67
- package/dist/cjs/queries2/GetQuery.d.ts +10 -10
- package/dist/cjs/queries2/GetQuery.js +29 -29
- package/dist/cjs/queries2/QueryCache.d.ts +16 -16
- package/dist/cjs/queries2/QueryCache.js +39 -39
- package/dist/cjs/queries2/dbQueries.d.ts +22 -22
- package/dist/cjs/queries2/dbQueries.js +125 -125
- package/dist/cjs/queries2/keys.d.ts +10 -10
- package/dist/cjs/queries2/keys.js +33 -33
- package/dist/cjs/queries2/ranges.d.ts +2 -2
- package/dist/cjs/queries2/ranges.js +69 -69
- package/dist/cjs/queries2/types.d.ts +6 -6
- package/dist/cjs/queries2/types.js +2 -2
- package/dist/cjs/queries2/utils.d.ts +1 -1
- package/dist/cjs/queries2/utils.js +19 -19
- package/dist/cjs/reactives/DocumentFamiliyCache.d.ts +51 -47
- package/dist/cjs/reactives/DocumentFamiliyCache.js +214 -210
- package/dist/cjs/reactives/DocumentFamiliyCache.js.map +1 -1
- package/dist/cjs/reactives/Entity.d.ts +192 -191
- package/dist/cjs/reactives/Entity.js +466 -462
- package/dist/cjs/reactives/Entity.js.map +1 -1
- package/dist/cjs/reactives/EntityStore.d.ts +84 -84
- package/dist/cjs/reactives/EntityStore.js +425 -421
- package/dist/cjs/reactives/EntityStore.js.map +1 -1
- package/dist/cjs/reactives/FakeWeakRef.d.ts +11 -11
- package/dist/cjs/reactives/FakeWeakRef.js +18 -18
- package/dist/cjs/sync/FileSync.d.ts +23 -23
- package/dist/cjs/sync/FileSync.js +84 -84
- package/dist/cjs/sync/Heartbeat.d.ts +24 -24
- package/dist/cjs/sync/Heartbeat.js +55 -55
- package/dist/cjs/sync/PresenceManager.d.ts +41 -41
- package/dist/cjs/sync/PresenceManager.js +107 -107
- package/dist/cjs/sync/PushPullSync.d.ts +36 -36
- package/dist/cjs/sync/PushPullSync.js +141 -141
- package/dist/cjs/sync/ServerSyncEndpointProvider.d.ts +27 -27
- package/dist/cjs/sync/ServerSyncEndpointProvider.js +64 -64
- package/dist/cjs/sync/Sync.d.ts +127 -127
- package/dist/cjs/sync/Sync.js +244 -244
- package/dist/cjs/sync/WebSocketSync.d.ts +41 -41
- package/dist/cjs/sync/WebSocketSync.js +183 -183
- package/dist/cjs/types.d.ts +5 -5
- package/dist/cjs/types.js +2 -2
- package/dist/cjs/utils/Disposable.d.ts +6 -6
- package/dist/cjs/utils/Disposable.js +18 -18
- package/dist/cjs/utils/Resolvable.d.ts +8 -8
- package/dist/cjs/utils/Resolvable.js +22 -22
- package/dist/esm/BackoffScheduler.d.ts +19 -19
- package/dist/esm/BackoffScheduler.js +39 -39
- package/dist/esm/DocumentManager.d.ts +28 -28
- package/dist/esm/DocumentManager.js +40 -40
- package/dist/esm/IDBService.d.ts +9 -9
- package/dist/esm/IDBService.js +42 -42
- package/dist/esm/UndoHistory.d.ts +16 -16
- package/dist/esm/UndoHistory.js +46 -46
- package/dist/esm/__tests__/batching.test.d.ts +1 -1
- package/dist/esm/__tests__/batching.test.js +42 -42
- package/dist/esm/__tests__/documents.test.d.ts +1 -1
- package/dist/esm/__tests__/documents.test.js +396 -396
- package/dist/esm/__tests__/fixtures/testStorage.d.ts +118 -118
- package/dist/esm/__tests__/fixtures/testStorage.js +111 -111
- package/dist/esm/__tests__/queries.test.d.ts +1 -1
- package/dist/esm/__tests__/queries.test.js +260 -260
- package/dist/esm/__tests__/setup/indexedDB.d.ts +1 -1
- package/dist/esm/__tests__/setup/indexedDB.js +1 -1
- package/dist/esm/__tests__/undo.test.d.ts +1 -1
- package/dist/esm/__tests__/undo.test.js +84 -84
- package/dist/esm/client/Client.d.ts +86 -86
- package/dist/esm/client/Client.js +222 -222
- package/dist/esm/client/ClientDescriptor.d.ts +62 -62
- package/dist/esm/client/ClientDescriptor.js +104 -104
- package/dist/esm/constants.d.ts +1 -1
- package/dist/esm/constants.js +1 -1
- package/dist/esm/context.d.ts +17 -17
- package/dist/esm/context.js +1 -1
- package/dist/esm/files/EntityFile.d.ts +27 -27
- package/dist/esm/files/EntityFile.js +67 -67
- package/dist/esm/files/FileManager.d.ts +42 -42
- package/dist/esm/files/FileManager.js +141 -141
- package/dist/esm/files/FileStorage.d.ts +27 -27
- package/dist/esm/files/FileStorage.js +88 -88
- package/dist/esm/files/utils.d.ts +8 -8
- package/dist/esm/files/utils.js +46 -46
- package/dist/esm/files/utils.test.d.ts +1 -1
- package/dist/esm/files/utils.test.js +78 -78
- package/dist/esm/idb.d.ts +8 -8
- package/dist/esm/idb.js +79 -79
- package/dist/esm/index.d.ts +19 -19
- package/dist/esm/index.js +11 -11
- package/dist/esm/indexes.d.ts +3 -3
- package/dist/esm/indexes.js +14 -14
- package/dist/esm/metadata/AckInfoStore.d.ts +10 -10
- package/dist/esm/metadata/AckInfoStore.js +21 -21
- package/dist/esm/metadata/BaselinesStore.d.ts +33 -33
- package/dist/esm/metadata/BaselinesStore.js +55 -55
- package/dist/esm/metadata/LocalReplicaStore.d.ts +17 -17
- package/dist/esm/metadata/LocalReplicaStore.js +40 -40
- package/dist/esm/metadata/MessageCreator.d.ts +19 -19
- package/dist/esm/metadata/MessageCreator.js +123 -123
- package/dist/esm/metadata/Metadata.d.ts +106 -106
- package/dist/esm/metadata/Metadata.js +332 -332
- package/dist/esm/metadata/OperationsStore.d.ts +50 -50
- package/dist/esm/metadata/OperationsStore.js +141 -141
- package/dist/esm/metadata/SchemaStore.d.ts +9 -9
- package/dist/esm/metadata/SchemaStore.js +34 -34
- package/dist/esm/metadata/openMetadataDatabase.d.ts +8 -8
- package/dist/esm/metadata/openMetadataDatabase.js +101 -101
- package/dist/esm/openDocumentDatabase.d.ts +12 -12
- package/dist/esm/openDocumentDatabase.js +420 -420
- package/dist/esm/queries2/BaseQuery.d.ts +39 -39
- package/dist/esm/queries2/BaseQuery.js +94 -94
- package/dist/esm/queries2/CollectionQueries.d.ts +55 -55
- package/dist/esm/queries2/CollectionQueries.js +78 -78
- package/dist/esm/queries2/FindAllQuery.d.ts +11 -11
- package/dist/esm/queries2/FindAllQuery.js +29 -29
- package/dist/esm/queries2/FindInfiniteQuery.d.ts +18 -18
- package/dist/esm/queries2/FindInfiniteQuery.js +56 -56
- package/dist/esm/queries2/FindOneQuery.d.ts +11 -11
- package/dist/esm/queries2/FindOneQuery.js +29 -29
- package/dist/esm/queries2/FindPageQuery.d.ts +23 -23
- package/dist/esm/queries2/FindPageQuery.js +63 -63
- package/dist/esm/queries2/GetQuery.d.ts +10 -10
- package/dist/esm/queries2/GetQuery.js +25 -25
- package/dist/esm/queries2/QueryCache.d.ts +16 -16
- package/dist/esm/queries2/QueryCache.js +35 -35
- package/dist/esm/queries2/dbQueries.d.ts +22 -22
- package/dist/esm/queries2/dbQueries.js +119 -119
- package/dist/esm/queries2/keys.d.ts +10 -10
- package/dist/esm/queries2/keys.js +29 -29
- package/dist/esm/queries2/ranges.d.ts +2 -2
- package/dist/esm/queries2/ranges.js +65 -65
- package/dist/esm/queries2/types.d.ts +6 -6
- package/dist/esm/queries2/types.js +1 -1
- package/dist/esm/queries2/utils.d.ts +1 -1
- package/dist/esm/queries2/utils.js +15 -15
- package/dist/esm/reactives/DocumentFamiliyCache.d.ts +51 -47
- package/dist/esm/reactives/DocumentFamiliyCache.js +210 -206
- package/dist/esm/reactives/DocumentFamiliyCache.js.map +1 -1
- package/dist/esm/reactives/Entity.d.ts +192 -191
- package/dist/esm/reactives/Entity.js +461 -457
- package/dist/esm/reactives/Entity.js.map +1 -1
- package/dist/esm/reactives/EntityStore.d.ts +84 -84
- package/dist/esm/reactives/EntityStore.js +421 -417
- package/dist/esm/reactives/EntityStore.js.map +1 -1
- package/dist/esm/reactives/FakeWeakRef.d.ts +11 -11
- package/dist/esm/reactives/FakeWeakRef.js +14 -14
- package/dist/esm/sync/FileSync.d.ts +23 -23
- package/dist/esm/sync/FileSync.js +80 -80
- package/dist/esm/sync/Heartbeat.d.ts +24 -24
- package/dist/esm/sync/Heartbeat.js +51 -51
- package/dist/esm/sync/PresenceManager.d.ts +41 -41
- package/dist/esm/sync/PresenceManager.js +103 -103
- package/dist/esm/sync/PushPullSync.d.ts +36 -36
- package/dist/esm/sync/PushPullSync.js +137 -137
- package/dist/esm/sync/ServerSyncEndpointProvider.d.ts +27 -27
- package/dist/esm/sync/ServerSyncEndpointProvider.js +57 -57
- package/dist/esm/sync/Sync.d.ts +127 -127
- package/dist/esm/sync/Sync.js +239 -239
- package/dist/esm/sync/{WebsocketSync.d.ts → WebSocketSync.d.ts} +41 -41
- package/dist/esm/sync/{WebsocketSync.js → WebSocketSync.js} +179 -179
- package/dist/esm/types.d.ts +5 -5
- package/dist/esm/types.js +1 -1
- package/dist/esm/utils/Disposable.d.ts +6 -6
- package/dist/esm/utils/Disposable.js +14 -14
- package/dist/esm/utils/Resolvable.d.ts +8 -8
- package/dist/esm/utils/Resolvable.js +18 -18
- package/dist/tsconfig-cjs.tsbuildinfo +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/src/reactives/DocumentFamiliyCache.ts +4 -0
- package/src/reactives/Entity.ts +8 -1
- package/src/reactives/EntityStore.ts +18 -13
- package/dist/cjs/AckInfoStore.d.ts +0 -10
- package/dist/cjs/AckInfoStore.js +0 -26
- package/dist/cjs/AckInfoStore.js.map +0 -1
- package/dist/cjs/BaselinesStore.d.ts +0 -10
- package/dist/cjs/BaselinesStore.js +0 -36
- package/dist/cjs/BaselinesStore.js.map +0 -1
- package/dist/cjs/Entity.d.ts +0 -96
- package/dist/cjs/Entity.js +0 -345
- package/dist/cjs/Entity.js.map +0 -1
- package/dist/cjs/EntityStore.d.ts +0 -36
- package/dist/cjs/EntityStore.js +0 -172
- package/dist/cjs/EntityStore.js.map +0 -1
- package/dist/cjs/LocalHistoryStore.d.ts +0 -15
- package/dist/cjs/LocalHistoryStore.js +0 -53
- package/dist/cjs/LocalHistoryStore.js.map +0 -1
- package/dist/cjs/LocalReplicaStore.d.ts +0 -13
- package/dist/cjs/LocalReplicaStore.js +0 -49
- package/dist/cjs/LocalReplicaStore.js.map +0 -1
- package/dist/cjs/MessageCreator.d.ts +0 -19
- package/dist/cjs/MessageCreator.js +0 -104
- package/dist/cjs/MessageCreator.js.map +0 -1
- package/dist/cjs/Metadata.d.ts +0 -91
- package/dist/cjs/Metadata.js +0 -250
- package/dist/cjs/Metadata.js.map +0 -1
- package/dist/cjs/OperationsStore.d.ts +0 -38
- package/dist/cjs/OperationsStore.js +0 -146
- package/dist/cjs/OperationsStore.js.map +0 -1
- package/dist/cjs/PresenceManager.d.ts +0 -30
- package/dist/cjs/PresenceManager.js +0 -89
- package/dist/cjs/PresenceManager.js.map +0 -1
- package/dist/cjs/Query.d.ts +0 -26
- package/dist/cjs/Query.js +0 -86
- package/dist/cjs/Query.js.map +0 -1
- package/dist/cjs/QueryMaker.d.ts +0 -18
- package/dist/cjs/QueryMaker.js +0 -98
- package/dist/cjs/QueryMaker.js.map +0 -1
- package/dist/cjs/QueryStore.d.ts +0 -38
- package/dist/cjs/QueryStore.js +0 -146
- package/dist/cjs/QueryStore.js.map +0 -1
- package/dist/cjs/SchemaStore.d.ts +0 -9
- package/dist/cjs/SchemaStore.js +0 -35
- package/dist/cjs/SchemaStore.js.map +0 -1
- package/dist/cjs/Storage.d.ts +0 -147
- package/dist/cjs/Storage.js +0 -346
- package/dist/cjs/Storage.js.map +0 -1
- package/dist/cjs/Sync.d.ts +0 -117
- package/dist/cjs/Sync.js +0 -561
- package/dist/cjs/Sync.js.map +0 -1
- package/dist/cjs/SyncHarness.d.ts +0 -45
- package/dist/cjs/SyncHarness.js +0 -110
- package/dist/cjs/SyncHarness.js.map +0 -1
- package/dist/cjs/metadata/LocalHistoryStore.d.ts +0 -15
- package/dist/cjs/metadata/LocalHistoryStore.js +0 -53
- package/dist/cjs/metadata/LocalHistoryStore.js.map +0 -1
- package/dist/cjs/queries/LiveQuery.d.ts +0 -28
- package/dist/cjs/queries/LiveQuery.js +0 -96
- package/dist/cjs/queries/LiveQuery.js.map +0 -1
- package/dist/cjs/queries/LiveQueryMaker.d.ts +0 -15
- package/dist/cjs/queries/LiveQueryMaker.js +0 -42
- package/dist/cjs/queries/LiveQueryMaker.js.map +0 -1
- package/dist/cjs/queries/LiveQueryStore.d.ts +0 -33
- package/dist/cjs/queries/LiveQueryStore.js +0 -85
- package/dist/cjs/queries/LiveQueryStore.js.map +0 -1
- package/dist/cjs/queries/Query.d.ts +0 -18
- package/dist/cjs/queries/Query.js +0 -36
- package/dist/cjs/queries/Query.js.map +0 -1
- package/dist/cjs/queries/QueryMaker.d.ts +0 -14
- package/dist/cjs/queries/QueryMaker.js +0 -42
- package/dist/cjs/queries/QueryMaker.js.map +0 -1
- package/dist/cjs/queries/QueryStore.d.ts +0 -35
- package/dist/cjs/queries/QueryStore.js +0 -130
- package/dist/cjs/queries/QueryStore.js.map +0 -1
- package/dist/cjs/queries/ranges.d.ts +0 -2
- package/dist/cjs/queries/ranges.js +0 -70
- package/dist/cjs/queries/ranges.js.map +0 -1
- package/dist/cjs/v2/AckInfoStore.d.ts +0 -10
- package/dist/cjs/v2/AckInfoStore.js +0 -26
- package/dist/cjs/v2/AckInfoStore.js.map +0 -1
- package/dist/cjs/v2/BaselinesStore.d.ts +0 -10
- package/dist/cjs/v2/BaselinesStore.js +0 -36
- package/dist/cjs/v2/BaselinesStore.js.map +0 -1
- package/dist/cjs/v2/DocumentManager.d.ts +0 -19
- package/dist/cjs/v2/DocumentManager.js +0 -47
- package/dist/cjs/v2/DocumentManager.js.map +0 -1
- package/dist/cjs/v2/Entity.d.ts +0 -87
- package/dist/cjs/v2/Entity.js +0 -305
- package/dist/cjs/v2/Entity.js.map +0 -1
- package/dist/cjs/v2/EntityStore.d.ts +0 -37
- package/dist/cjs/v2/EntityStore.js +0 -165
- package/dist/cjs/v2/EntityStore.js.map +0 -1
- package/dist/cjs/v2/IDBService.d.ts +0 -7
- package/dist/cjs/v2/IDBService.js +0 -26
- package/dist/cjs/v2/IDBService.js.map +0 -1
- package/dist/cjs/v2/LocalHistoryStore.d.ts +0 -15
- package/dist/cjs/v2/LocalHistoryStore.js +0 -53
- package/dist/cjs/v2/LocalHistoryStore.js.map +0 -1
- package/dist/cjs/v2/LocalReplicaStore.d.ts +0 -14
- package/dist/cjs/v2/LocalReplicaStore.js +0 -49
- package/dist/cjs/v2/LocalReplicaStore.js.map +0 -1
- package/dist/cjs/v2/MessageCreator.d.ts +0 -19
- package/dist/cjs/v2/MessageCreator.js +0 -99
- package/dist/cjs/v2/MessageCreator.js.map +0 -1
- package/dist/cjs/v2/Metadata.d.ts +0 -90
- package/dist/cjs/v2/Metadata.js +0 -251
- package/dist/cjs/v2/Metadata.js.map +0 -1
- package/dist/cjs/v2/OperationsStore.d.ts +0 -38
- package/dist/cjs/v2/OperationsStore.js +0 -146
- package/dist/cjs/v2/OperationsStore.js.map +0 -1
- package/dist/cjs/v2/PresenceManager.d.ts +0 -24
- package/dist/cjs/v2/PresenceManager.js +0 -73
- package/dist/cjs/v2/PresenceManager.js.map +0 -1
- package/dist/cjs/v2/Query.d.ts +0 -24
- package/dist/cjs/v2/Query.js +0 -79
- package/dist/cjs/v2/Query.js.map +0 -1
- package/dist/cjs/v2/QueryMaker.d.ts +0 -16
- package/dist/cjs/v2/QueryMaker.js +0 -84
- package/dist/cjs/v2/QueryMaker.js.map +0 -1
- package/dist/cjs/v2/QueryStore.d.ts +0 -26
- package/dist/cjs/v2/QueryStore.js +0 -136
- package/dist/cjs/v2/QueryStore.js.map +0 -1
- package/dist/cjs/v2/SchemaStore.d.ts +0 -9
- package/dist/cjs/v2/SchemaStore.js +0 -35
- package/dist/cjs/v2/SchemaStore.js.map +0 -1
- package/dist/cjs/v2/Storage.d.ts +0 -80
- package/dist/cjs/v2/Storage.js +0 -154
- package/dist/cjs/v2/Storage.js.map +0 -1
- package/dist/cjs/v2/Sync.d.ts +0 -42
- package/dist/cjs/v2/Sync.js +0 -98
- package/dist/cjs/v2/Sync.js.map +0 -1
- package/dist/cjs/v2/SyncHarness.d.ts +0 -45
- package/dist/cjs/v2/SyncHarness.js +0 -110
- package/dist/cjs/v2/SyncHarness.js.map +0 -1
- package/dist/cjs/v2/__tests__/documents.test.d.ts +0 -1
- package/dist/cjs/v2/__tests__/documents.test.js +0 -185
- package/dist/cjs/v2/__tests__/documents.test.js.map +0 -1
- package/dist/cjs/v2/__tests__/fixtures/testStorage.d.ts +0 -189
- package/dist/cjs/v2/__tests__/fixtures/testStorage.js +0 -93
- package/dist/cjs/v2/__tests__/fixtures/testStorage.js.map +0 -1
- package/dist/cjs/v2/__tests__/queries.test.d.ts +0 -1
- package/dist/cjs/v2/__tests__/queries.test.js +0 -92
- package/dist/cjs/v2/__tests__/queries.test.js.map +0 -1
- package/dist/cjs/v2/__tests__/setup/indexedDB.d.ts +0 -1
- package/dist/cjs/v2/__tests__/setup/indexedDB.js +0 -4
- package/dist/cjs/v2/__tests__/setup/indexedDB.js.map +0 -1
- package/dist/cjs/v2/constants.d.ts +0 -1
- package/dist/cjs/v2/constants.js +0 -5
- package/dist/cjs/v2/constants.js.map +0 -1
- package/dist/cjs/v2/idb.d.ts +0 -6
- package/dist/cjs/v2/idb.js +0 -71
- package/dist/cjs/v2/idb.js.map +0 -1
- package/dist/cjs/v2/index.d.ts +0 -6
- package/dist/cjs/v2/index.js +0 -14
- package/dist/cjs/v2/index.js.map +0 -1
- package/dist/cjs/v2/indexes.d.ts +0 -3
- package/dist/cjs/v2/indexes.js +0 -20
- package/dist/cjs/v2/indexes.js.map +0 -1
- package/dist/cjs/v2/openDocumentDatabase.d.ts +0 -9
- package/dist/cjs/v2/openDocumentDatabase.js +0 -100
- package/dist/cjs/v2/openDocumentDatabase.js.map +0 -1
- package/dist/cjs/v2/types.d.ts +0 -3
- package/dist/cjs/v2/types.js +0 -3
- package/dist/cjs/v2/types.js.map +0 -1
- package/dist/esm/AckInfoStore.d.ts +0 -10
- package/dist/esm/AckInfoStore.js +0 -22
- package/dist/esm/AckInfoStore.js.map +0 -1
- package/dist/esm/BaselinesStore.d.ts +0 -10
- package/dist/esm/BaselinesStore.js +0 -32
- package/dist/esm/BaselinesStore.js.map +0 -1
- package/dist/esm/Entity.d.ts +0 -96
- package/dist/esm/Entity.js +0 -337
- package/dist/esm/Entity.js.map +0 -1
- package/dist/esm/EntityStore.d.ts +0 -36
- package/dist/esm/EntityStore.js +0 -168
- package/dist/esm/EntityStore.js.map +0 -1
- package/dist/esm/LocalHistoryStore.d.ts +0 -15
- package/dist/esm/LocalHistoryStore.js +0 -49
- package/dist/esm/LocalHistoryStore.js.map +0 -1
- package/dist/esm/LocalReplicaStore.d.ts +0 -13
- package/dist/esm/LocalReplicaStore.js +0 -42
- package/dist/esm/LocalReplicaStore.js.map +0 -1
- package/dist/esm/MessageCreator.d.ts +0 -19
- package/dist/esm/MessageCreator.js +0 -97
- package/dist/esm/MessageCreator.js.map +0 -1
- package/dist/esm/Metadata.d.ts +0 -91
- package/dist/esm/Metadata.js +0 -245
- package/dist/esm/Metadata.js.map +0 -1
- package/dist/esm/OperationsStore.d.ts +0 -38
- package/dist/esm/OperationsStore.js +0 -142
- package/dist/esm/OperationsStore.js.map +0 -1
- package/dist/esm/PresenceManager.d.ts +0 -30
- package/dist/esm/PresenceManager.js +0 -85
- package/dist/esm/PresenceManager.js.map +0 -1
- package/dist/esm/Query.d.ts +0 -26
- package/dist/esm/Query.js +0 -82
- package/dist/esm/Query.js.map +0 -1
- package/dist/esm/QueryMaker.d.ts +0 -18
- package/dist/esm/QueryMaker.js +0 -94
- package/dist/esm/QueryMaker.js.map +0 -1
- package/dist/esm/QueryStore.d.ts +0 -38
- package/dist/esm/QueryStore.js +0 -142
- package/dist/esm/QueryStore.js.map +0 -1
- package/dist/esm/SchemaStore.d.ts +0 -9
- package/dist/esm/SchemaStore.js +0 -31
- package/dist/esm/SchemaStore.js.map +0 -1
- package/dist/esm/Storage.d.ts +0 -147
- package/dist/esm/Storage.js +0 -341
- package/dist/esm/Storage.js.map +0 -1
- package/dist/esm/Sync.d.ts +0 -117
- package/dist/esm/Sync.js +0 -553
- package/dist/esm/Sync.js.map +0 -1
- package/dist/esm/SyncHarness.d.ts +0 -45
- package/dist/esm/SyncHarness.js +0 -105
- package/dist/esm/SyncHarness.js.map +0 -1
- package/dist/esm/metadata/LocalHistoryStore.d.ts +0 -15
- package/dist/esm/metadata/LocalHistoryStore.js +0 -49
- package/dist/esm/metadata/LocalHistoryStore.js.map +0 -1
- package/dist/esm/queries/LiveQuery.d.ts +0 -28
- package/dist/esm/queries/LiveQuery.js +0 -92
- package/dist/esm/queries/LiveQuery.js.map +0 -1
- package/dist/esm/queries/LiveQueryMaker.d.ts +0 -15
- package/dist/esm/queries/LiveQueryMaker.js +0 -38
- package/dist/esm/queries/LiveQueryMaker.js.map +0 -1
- package/dist/esm/queries/LiveQueryStore.d.ts +0 -33
- package/dist/esm/queries/LiveQueryStore.js +0 -81
- package/dist/esm/queries/LiveQueryStore.js.map +0 -1
- package/dist/esm/queries/Query.d.ts +0 -18
- package/dist/esm/queries/Query.js +0 -32
- package/dist/esm/queries/Query.js.map +0 -1
- package/dist/esm/queries/QueryMaker.d.ts +0 -14
- package/dist/esm/queries/QueryMaker.js +0 -38
- package/dist/esm/queries/QueryMaker.js.map +0 -1
- package/dist/esm/queries/QueryStore.d.ts +0 -35
- package/dist/esm/queries/QueryStore.js +0 -126
- package/dist/esm/queries/QueryStore.js.map +0 -1
- package/dist/esm/queries/ranges.d.ts +0 -2
- package/dist/esm/queries/ranges.js +0 -66
- package/dist/esm/queries/ranges.js.map +0 -1
- package/dist/esm/v2/AckInfoStore.d.ts +0 -10
- package/dist/esm/v2/AckInfoStore.js +0 -22
- package/dist/esm/v2/AckInfoStore.js.map +0 -1
- package/dist/esm/v2/BaselinesStore.d.ts +0 -10
- package/dist/esm/v2/BaselinesStore.js +0 -32
- package/dist/esm/v2/BaselinesStore.js.map +0 -1
- package/dist/esm/v2/DocumentManager.d.ts +0 -19
- package/dist/esm/v2/DocumentManager.js +0 -43
- package/dist/esm/v2/DocumentManager.js.map +0 -1
- package/dist/esm/v2/Entity.d.ts +0 -91
- package/dist/esm/v2/Entity.js +0 -305
- package/dist/esm/v2/Entity.js.map +0 -1
- package/dist/esm/v2/EntityStore.d.ts +0 -37
- package/dist/esm/v2/EntityStore.js +0 -166
- package/dist/esm/v2/EntityStore.js.map +0 -1
- package/dist/esm/v2/IDBService.d.ts +0 -7
- package/dist/esm/v2/IDBService.js +0 -22
- package/dist/esm/v2/IDBService.js.map +0 -1
- package/dist/esm/v2/LocalHistoryStore.d.ts +0 -15
- package/dist/esm/v2/LocalHistoryStore.js +0 -49
- package/dist/esm/v2/LocalHistoryStore.js.map +0 -1
- package/dist/esm/v2/LocalReplicaStore.d.ts +0 -14
- package/dist/esm/v2/LocalReplicaStore.js +0 -42
- package/dist/esm/v2/LocalReplicaStore.js.map +0 -1
- package/dist/esm/v2/MessageCreator.d.ts +0 -19
- package/dist/esm/v2/MessageCreator.js +0 -92
- package/dist/esm/v2/MessageCreator.js.map +0 -1
- package/dist/esm/v2/Metadata.d.ts +0 -90
- package/dist/esm/v2/Metadata.js +0 -246
- package/dist/esm/v2/Metadata.js.map +0 -1
- package/dist/esm/v2/OperationsStore.d.ts +0 -38
- package/dist/esm/v2/OperationsStore.js +0 -142
- package/dist/esm/v2/OperationsStore.js.map +0 -1
- package/dist/esm/v2/PresenceManager.d.ts +0 -24
- package/dist/esm/v2/PresenceManager.js +0 -69
- package/dist/esm/v2/PresenceManager.js.map +0 -1
- package/dist/esm/v2/Query.d.ts +0 -24
- package/dist/esm/v2/Query.js +0 -75
- package/dist/esm/v2/Query.js.map +0 -1
- package/dist/esm/v2/QueryMaker.d.ts +0 -16
- package/dist/esm/v2/QueryMaker.js +0 -80
- package/dist/esm/v2/QueryMaker.js.map +0 -1
- package/dist/esm/v2/QueryStore.d.ts +0 -26
- package/dist/esm/v2/QueryStore.js +0 -132
- package/dist/esm/v2/QueryStore.js.map +0 -1
- package/dist/esm/v2/SchemaStore.d.ts +0 -9
- package/dist/esm/v2/SchemaStore.js +0 -31
- package/dist/esm/v2/SchemaStore.js.map +0 -1
- package/dist/esm/v2/Storage.d.ts +0 -80
- package/dist/esm/v2/Storage.js +0 -149
- package/dist/esm/v2/Storage.js.map +0 -1
- package/dist/esm/v2/Sync.d.ts +0 -42
- package/dist/esm/v2/Sync.js +0 -94
- package/dist/esm/v2/Sync.js.map +0 -1
- package/dist/esm/v2/SyncHarness.d.ts +0 -45
- package/dist/esm/v2/SyncHarness.js +0 -105
- package/dist/esm/v2/SyncHarness.js.map +0 -1
- package/dist/esm/v2/__tests__/documents.test.d.ts +0 -1
- package/dist/esm/v2/__tests__/documents.test.js +0 -208
- package/dist/esm/v2/__tests__/documents.test.js.map +0 -1
- package/dist/esm/v2/__tests__/fixtures/testStorage.d.ts +0 -223
- package/dist/esm/v2/__tests__/fixtures/testStorage.js +0 -106
- package/dist/esm/v2/__tests__/fixtures/testStorage.js.map +0 -1
- package/dist/esm/v2/__tests__/queries.test.d.ts +0 -1
- package/dist/esm/v2/__tests__/queries.test.js +0 -90
- package/dist/esm/v2/__tests__/queries.test.js.map +0 -1
- package/dist/esm/v2/__tests__/setup/indexedDB.d.ts +0 -1
- package/dist/esm/v2/__tests__/setup/indexedDB.js +0 -2
- package/dist/esm/v2/__tests__/setup/indexedDB.js.map +0 -1
- package/dist/esm/v2/constants.d.ts +0 -1
- package/dist/esm/v2/constants.js +0 -2
- package/dist/esm/v2/constants.js.map +0 -1
- package/dist/esm/v2/idb.d.ts +0 -6
- package/dist/esm/v2/idb.js +0 -65
- package/dist/esm/v2/idb.js.map +0 -1
- package/dist/esm/v2/index.d.ts +0 -6
- package/dist/esm/v2/index.js +0 -5
- package/dist/esm/v2/index.js.map +0 -1
- package/dist/esm/v2/indexes.d.ts +0 -3
- package/dist/esm/v2/indexes.js +0 -15
- package/dist/esm/v2/indexes.js.map +0 -1
- package/dist/esm/v2/openDocumentDatabase.d.ts +0 -9
- package/dist/esm/v2/openDocumentDatabase.js +0 -96
- package/dist/esm/v2/openDocumentDatabase.js.map +0 -1
- package/dist/esm/v2/types.d.ts +0 -3
- package/dist/esm/v2/types.js +0 -2
- package/dist/esm/v2/types.js.map +0 -1
- /package/dist/esm/sync/{WebsocketSync.js.map → WebSocketSync.js.map} +0 -0
|
@@ -1,432 +1,432 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.openDocumentDatabase = void 0;
|
|
4
|
-
const common_1 = require("@verdant-web/common");
|
|
5
|
-
const dbQueries_js_1 = require("./queries2/dbQueries.js");
|
|
6
|
-
const globalIDB = typeof window !== 'undefined' ? window.indexedDB : undefined;
|
|
7
|
-
async function openDocumentDatabase({ version, indexedDB = globalIDB, migrations, meta, context, }) {
|
|
8
|
-
const currentVersion = await getDatabaseVersion(indexedDB, context.namespace, version, context.log);
|
|
9
|
-
context.log('Current database version:', currentVersion, 'target version:', version);
|
|
10
|
-
const toRunVersions = (0, common_1.migrationRange)(currentVersion, version);
|
|
11
|
-
const toRun = toRunVersions.map((ver) => migrations.find((m) => m.version === ver));
|
|
12
|
-
if (toRun.some((m) => !m)) {
|
|
13
|
-
throw new Error(`No migration found for version(s) ${toRunVersions}`);
|
|
14
|
-
}
|
|
15
|
-
if (toRun.length > 0) {
|
|
16
|
-
await acquireLock(context.namespace, async () => {
|
|
17
|
-
// now the fun part
|
|
18
|
-
for (const migration of toRun) {
|
|
19
|
-
// special case: if this is the version 1 migration, we have no pre-existing database
|
|
20
|
-
// to use for the migration.
|
|
21
|
-
let engine;
|
|
22
|
-
if (migration.version === 1) {
|
|
23
|
-
engine = getVersion1MigrationEngine({
|
|
24
|
-
meta,
|
|
25
|
-
migration,
|
|
26
|
-
context,
|
|
27
|
-
});
|
|
28
|
-
await migration.migrate(engine);
|
|
29
|
-
}
|
|
30
|
-
else {
|
|
31
|
-
// open the database with the current (old) version for this migration. this should
|
|
32
|
-
// align with the database's current version.
|
|
33
|
-
const originalDatabase = await openDatabase(indexedDB, context.namespace, migration.oldSchema.version);
|
|
34
|
-
// this will only write to our metadata store via operations!
|
|
35
|
-
engine = getMigrationEngine({
|
|
36
|
-
meta,
|
|
37
|
-
migration,
|
|
38
|
-
context: Object.assign(Object.assign({}, context), { documentDb: originalDatabase }),
|
|
39
|
-
});
|
|
40
|
-
await migration.migrate(engine);
|
|
41
|
-
// wait on any out-of-band async operations to complete
|
|
42
|
-
await Promise.all(engine.awaitables);
|
|
43
|
-
// now we have to open the database again with the next version and
|
|
44
|
-
// make the appropriate schema changes during the upgrade.
|
|
45
|
-
await closeDatabase(originalDatabase);
|
|
46
|
-
}
|
|
47
|
-
await upgradeDatabase(indexedDB, context.namespace, migration.newSchema.version, (transaction, db) => {
|
|
48
|
-
for (const newCollection of migration.addedCollections) {
|
|
49
|
-
db.createObjectStore(newCollection, {
|
|
50
|
-
keyPath: migration.newSchema.collections[newCollection].primaryKey,
|
|
51
|
-
autoIncrement: false,
|
|
52
|
-
});
|
|
53
|
-
}
|
|
54
|
-
for (const collection of migration.allCollections) {
|
|
55
|
-
const store = transaction.objectStore(collection);
|
|
56
|
-
// apply new indexes
|
|
57
|
-
for (const newIndex of migration.addedIndexes[collection] || []) {
|
|
58
|
-
store.createIndex(newIndex.name, newIndex.name, {
|
|
59
|
-
multiEntry: newIndex.multiEntry,
|
|
60
|
-
});
|
|
61
|
-
}
|
|
62
|
-
// remove old indexes
|
|
63
|
-
for (const oldIndex of migration.removedIndexes[collection] ||
|
|
64
|
-
[]) {
|
|
65
|
-
store.deleteIndex(oldIndex.name);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
for (const removedCollection of migration.removedCollections) {
|
|
69
|
-
// !! can't delete the store, because old operations that relate to
|
|
70
|
-
// this store may still exist in history. instead, we can clear it out
|
|
71
|
-
// and leave it in place
|
|
72
|
-
transaction.objectStore(removedCollection).clear();
|
|
73
|
-
}
|
|
74
|
-
}, context.log);
|
|
75
|
-
// once the schema is ready, we can write back the migrated documents
|
|
76
|
-
const upgradedDatabase = await openDatabase(indexedDB, context.namespace, migration.newSchema.version);
|
|
77
|
-
for (const collection of migration.allCollections) {
|
|
78
|
-
// first step is to read in all the keys we need to rewrite
|
|
79
|
-
const documentReadTransaction = upgradedDatabase.transaction(collection, 'readwrite');
|
|
80
|
-
const readStore = documentReadTransaction.objectStore(collection);
|
|
81
|
-
const keys = await getAllKeys(readStore);
|
|
82
|
-
// map the keys to OIDs
|
|
83
|
-
const oids = keys.map((key) => (0, common_1.createOid)(collection, `${key}`, []));
|
|
84
|
-
oids.push(...engine.newOids.filter((oid) => {
|
|
85
|
-
return (0, common_1.decomposeOid)(oid).collection === collection;
|
|
86
|
-
}));
|
|
87
|
-
const snapshots = await Promise.all(oids.map(async (oid) => {
|
|
88
|
-
try {
|
|
89
|
-
const snap = await meta.getDocumentSnapshot(oid);
|
|
90
|
-
return [oid, snap];
|
|
91
|
-
}
|
|
92
|
-
catch (e) {
|
|
93
|
-
// this seems to happen with baselines/ops which are not fully
|
|
94
|
-
// cleaned up after deletion?
|
|
95
|
-
context.log('error', 'Could not regenerate snapshot during migration for oid', oid, 'this document will not be preserved', e);
|
|
96
|
-
return null;
|
|
97
|
-
}
|
|
98
|
-
}));
|
|
99
|
-
const views = snapshots
|
|
100
|
-
.filter((s) => !!s)
|
|
101
|
-
.map(([oid, snapshot]) => {
|
|
102
|
-
if (!snapshot)
|
|
103
|
-
return [oid, undefined];
|
|
104
|
-
const view = (0, common_1.assignIndexValues)(migration.newSchema.collections[collection], snapshot);
|
|
105
|
-
// TODO: remove the need for this by only storing index values!
|
|
106
|
-
(0, common_1.assignOidPropertiesToAllSubObjects)(view);
|
|
107
|
-
return [oid, view];
|
|
108
|
-
});
|
|
109
|
-
// now we can write the documents back
|
|
110
|
-
const documentWriteTransaction = upgradedDatabase.transaction(collection, 'readwrite');
|
|
111
|
-
const writeStore = documentWriteTransaction.objectStore(collection);
|
|
112
|
-
await Promise.all(views.map(([oid, view]) => {
|
|
113
|
-
if (view) {
|
|
114
|
-
return putView(writeStore, view);
|
|
115
|
-
}
|
|
116
|
-
else {
|
|
117
|
-
const { id } = (0, common_1.decomposeOid)(oid);
|
|
118
|
-
return deleteView(writeStore, id);
|
|
119
|
-
}
|
|
120
|
-
}));
|
|
121
|
-
}
|
|
122
|
-
await closeDatabase(upgradedDatabase);
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.openDocumentDatabase = void 0;
|
|
4
|
+
const common_1 = require("@verdant-web/common");
|
|
5
|
+
const dbQueries_js_1 = require("./queries2/dbQueries.js");
|
|
6
|
+
const globalIDB = typeof window !== 'undefined' ? window.indexedDB : undefined;
|
|
7
|
+
async function openDocumentDatabase({ version, indexedDB = globalIDB, migrations, meta, context, }) {
|
|
8
|
+
const currentVersion = await getDatabaseVersion(indexedDB, context.namespace, version, context.log);
|
|
9
|
+
context.log('Current database version:', currentVersion, 'target version:', version);
|
|
10
|
+
const toRunVersions = (0, common_1.migrationRange)(currentVersion, version);
|
|
11
|
+
const toRun = toRunVersions.map((ver) => migrations.find((m) => m.version === ver));
|
|
12
|
+
if (toRun.some((m) => !m)) {
|
|
13
|
+
throw new Error(`No migration found for version(s) ${toRunVersions}`);
|
|
14
|
+
}
|
|
15
|
+
if (toRun.length > 0) {
|
|
16
|
+
await acquireLock(context.namespace, async () => {
|
|
17
|
+
// now the fun part
|
|
18
|
+
for (const migration of toRun) {
|
|
19
|
+
// special case: if this is the version 1 migration, we have no pre-existing database
|
|
20
|
+
// to use for the migration.
|
|
21
|
+
let engine;
|
|
22
|
+
if (migration.version === 1) {
|
|
23
|
+
engine = getVersion1MigrationEngine({
|
|
24
|
+
meta,
|
|
25
|
+
migration,
|
|
26
|
+
context,
|
|
27
|
+
});
|
|
28
|
+
await migration.migrate(engine);
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
// open the database with the current (old) version for this migration. this should
|
|
32
|
+
// align with the database's current version.
|
|
33
|
+
const originalDatabase = await openDatabase(indexedDB, context.namespace, migration.oldSchema.version);
|
|
34
|
+
// this will only write to our metadata store via operations!
|
|
35
|
+
engine = getMigrationEngine({
|
|
36
|
+
meta,
|
|
37
|
+
migration,
|
|
38
|
+
context: Object.assign(Object.assign({}, context), { documentDb: originalDatabase }),
|
|
39
|
+
});
|
|
40
|
+
await migration.migrate(engine);
|
|
41
|
+
// wait on any out-of-band async operations to complete
|
|
42
|
+
await Promise.all(engine.awaitables);
|
|
43
|
+
// now we have to open the database again with the next version and
|
|
44
|
+
// make the appropriate schema changes during the upgrade.
|
|
45
|
+
await closeDatabase(originalDatabase);
|
|
46
|
+
}
|
|
47
|
+
await upgradeDatabase(indexedDB, context.namespace, migration.newSchema.version, (transaction, db) => {
|
|
48
|
+
for (const newCollection of migration.addedCollections) {
|
|
49
|
+
db.createObjectStore(newCollection, {
|
|
50
|
+
keyPath: migration.newSchema.collections[newCollection].primaryKey,
|
|
51
|
+
autoIncrement: false,
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
for (const collection of migration.allCollections) {
|
|
55
|
+
const store = transaction.objectStore(collection);
|
|
56
|
+
// apply new indexes
|
|
57
|
+
for (const newIndex of migration.addedIndexes[collection] || []) {
|
|
58
|
+
store.createIndex(newIndex.name, newIndex.name, {
|
|
59
|
+
multiEntry: newIndex.multiEntry,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
// remove old indexes
|
|
63
|
+
for (const oldIndex of migration.removedIndexes[collection] ||
|
|
64
|
+
[]) {
|
|
65
|
+
store.deleteIndex(oldIndex.name);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
for (const removedCollection of migration.removedCollections) {
|
|
69
|
+
// !! can't delete the store, because old operations that relate to
|
|
70
|
+
// this store may still exist in history. instead, we can clear it out
|
|
71
|
+
// and leave it in place
|
|
72
|
+
transaction.objectStore(removedCollection).clear();
|
|
73
|
+
}
|
|
74
|
+
}, context.log);
|
|
75
|
+
// once the schema is ready, we can write back the migrated documents
|
|
76
|
+
const upgradedDatabase = await openDatabase(indexedDB, context.namespace, migration.newSchema.version);
|
|
77
|
+
for (const collection of migration.allCollections) {
|
|
78
|
+
// first step is to read in all the keys we need to rewrite
|
|
79
|
+
const documentReadTransaction = upgradedDatabase.transaction(collection, 'readwrite');
|
|
80
|
+
const readStore = documentReadTransaction.objectStore(collection);
|
|
81
|
+
const keys = await getAllKeys(readStore);
|
|
82
|
+
// map the keys to OIDs
|
|
83
|
+
const oids = keys.map((key) => (0, common_1.createOid)(collection, `${key}`, []));
|
|
84
|
+
oids.push(...engine.newOids.filter((oid) => {
|
|
85
|
+
return (0, common_1.decomposeOid)(oid).collection === collection;
|
|
86
|
+
}));
|
|
87
|
+
const snapshots = await Promise.all(oids.map(async (oid) => {
|
|
88
|
+
try {
|
|
89
|
+
const snap = await meta.getDocumentSnapshot(oid);
|
|
90
|
+
return [oid, snap];
|
|
91
|
+
}
|
|
92
|
+
catch (e) {
|
|
93
|
+
// this seems to happen with baselines/ops which are not fully
|
|
94
|
+
// cleaned up after deletion?
|
|
95
|
+
context.log('error', 'Could not regenerate snapshot during migration for oid', oid, 'this document will not be preserved', e);
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
}));
|
|
99
|
+
const views = snapshots
|
|
100
|
+
.filter((s) => !!s)
|
|
101
|
+
.map(([oid, snapshot]) => {
|
|
102
|
+
if (!snapshot)
|
|
103
|
+
return [oid, undefined];
|
|
104
|
+
const view = (0, common_1.assignIndexValues)(migration.newSchema.collections[collection], snapshot);
|
|
105
|
+
// TODO: remove the need for this by only storing index values!
|
|
106
|
+
(0, common_1.assignOidPropertiesToAllSubObjects)(view);
|
|
107
|
+
return [oid, view];
|
|
108
|
+
});
|
|
109
|
+
// now we can write the documents back
|
|
110
|
+
const documentWriteTransaction = upgradedDatabase.transaction(collection, 'readwrite');
|
|
111
|
+
const writeStore = documentWriteTransaction.objectStore(collection);
|
|
112
|
+
await Promise.all(views.map(([oid, view]) => {
|
|
113
|
+
if (view) {
|
|
114
|
+
return putView(writeStore, view);
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
const { id } = (0, common_1.decomposeOid)(oid);
|
|
118
|
+
return deleteView(writeStore, id);
|
|
119
|
+
}
|
|
120
|
+
}));
|
|
121
|
+
}
|
|
122
|
+
await closeDatabase(upgradedDatabase);
|
|
123
123
|
context.log(`
|
|
124
124
|
⬆️ v${migration.newSchema.version} Migration complete. Here's the rundown:
|
|
125
125
|
- Added collections: ${migration.addedCollections.join(', ')}
|
|
126
126
|
- Removed collections: ${migration.removedCollections.join(', ')}
|
|
127
127
|
- Changed collections: ${migration.changedCollections.join(', ')}
|
|
128
|
-
- New indexes: ${Object.keys(migration.addedIndexes)
|
|
129
|
-
.map((col) => migration.addedIndexes[col].map((i) => `${col}.${i.name}`))
|
|
130
|
-
.flatMap((i) => i)
|
|
128
|
+
- New indexes: ${Object.keys(migration.addedIndexes)
|
|
129
|
+
.map((col) => migration.addedIndexes[col].map((i) => `${col}.${i.name}`))
|
|
130
|
+
.flatMap((i) => i)
|
|
131
131
|
.join(', ')}
|
|
132
|
-
- Removed indexes: ${Object.keys(migration.removedIndexes)
|
|
133
|
-
.map((col) => migration.removedIndexes[col].map((i) => `${col}.${i.name}`))
|
|
134
|
-
.flatMap((i) => i)
|
|
132
|
+
- Removed indexes: ${Object.keys(migration.removedIndexes)
|
|
133
|
+
.map((col) => migration.removedIndexes[col].map((i) => `${col}.${i.name}`))
|
|
134
|
+
.flatMap((i) => i)
|
|
135
135
|
.join(', ')}
|
|
136
|
-
`);
|
|
137
|
-
}
|
|
138
|
-
});
|
|
139
|
-
return openDatabase(indexedDB, context.namespace, version);
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
// just open the database
|
|
143
|
-
return openDatabase(indexedDB, context.namespace, version);
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
exports.openDocumentDatabase = openDocumentDatabase;
|
|
147
|
-
async function getDatabaseVersion(indexedDB, namespace, version, log) {
|
|
148
|
-
function openAndGetVersion(resolve, reject) {
|
|
149
|
-
let currentVersion;
|
|
150
|
-
let database;
|
|
151
|
-
const request = indexedDB.open([namespace, 'collections'].join('_'), version);
|
|
152
|
-
request.onupgradeneeded = async (event) => {
|
|
153
|
-
currentVersion = event.oldVersion;
|
|
154
|
-
const transaction = request.transaction;
|
|
155
|
-
database = request.result;
|
|
156
|
-
transaction.abort();
|
|
157
|
-
};
|
|
158
|
-
request.onsuccess = (event) => {
|
|
159
|
-
resolve([request.result.version, request.result]);
|
|
160
|
-
};
|
|
161
|
-
request.onblocked = (event) => {
|
|
162
|
-
// retry if blocked
|
|
163
|
-
log === null || log === void 0 ? void 0 : log('Database blocked, waiting...');
|
|
164
|
-
// setTimeout(() => {
|
|
165
|
-
// openAndGetVersion(resolve, reject);
|
|
166
|
-
// }, 200);
|
|
167
|
-
};
|
|
168
|
-
request.onerror = (event) => {
|
|
169
|
-
// FIXME: this fails if the code is older than the local database
|
|
170
|
-
resolve([currentVersion, database]);
|
|
171
|
-
};
|
|
172
|
-
}
|
|
173
|
-
const [currentVersion, db] = await new Promise(openAndGetVersion);
|
|
174
|
-
await closeDatabase(db);
|
|
175
|
-
return currentVersion;
|
|
176
|
-
}
|
|
177
|
-
async function openDatabase(indexedDb, namespace, version) {
|
|
178
|
-
const db = await new Promise((resolve, reject) => {
|
|
179
|
-
const request = indexedDb.open([namespace, 'collections'].join('_'), version);
|
|
180
|
-
request.onupgradeneeded = async (event) => {
|
|
181
|
-
const transaction = request.transaction;
|
|
182
|
-
transaction.abort();
|
|
183
|
-
reject(new Error('Migration error: database version changed while migrating'));
|
|
184
|
-
};
|
|
185
|
-
request.onsuccess = (event) => {
|
|
186
|
-
resolve(request.result);
|
|
187
|
-
};
|
|
188
|
-
request.onblocked = (event) => {
|
|
189
|
-
reject(new Error('Migration error: database blocked'));
|
|
190
|
-
};
|
|
191
|
-
request.onerror = (event) => {
|
|
192
|
-
reject(new Error('Migration error: database error'));
|
|
193
|
-
};
|
|
194
|
-
});
|
|
195
|
-
db.addEventListener('versionchange', (event) => {
|
|
196
|
-
db.close();
|
|
197
|
-
});
|
|
198
|
-
return db;
|
|
199
|
-
}
|
|
200
|
-
function getMigrationMutations({ migration, meta, getMigrationNow, newOids, }) {
|
|
201
|
-
return migration.allCollections.reduce((acc, collectionName) => {
|
|
202
|
-
acc[collectionName] = {
|
|
203
|
-
put: async (doc) => {
|
|
204
|
-
// add defaults
|
|
205
|
-
(0, common_1.addFieldDefaults)(migration.newSchema.collections[collectionName], doc);
|
|
206
|
-
const primaryKey = doc[migration.newSchema.collections[collectionName].primaryKey];
|
|
207
|
-
const oid = (0, common_1.createOid)(collectionName, primaryKey, []);
|
|
208
|
-
newOids.push(oid);
|
|
209
|
-
await meta.insertLocalOperation((0, common_1.initialToPatches)(doc, oid, getMigrationNow));
|
|
210
|
-
return doc;
|
|
211
|
-
},
|
|
212
|
-
delete: (id) => {
|
|
213
|
-
const oid = (0, common_1.createOid)(collectionName, id, []);
|
|
214
|
-
return meta.insertLocalOperation([
|
|
215
|
-
{
|
|
216
|
-
oid,
|
|
217
|
-
timestamp: getMigrationNow(),
|
|
218
|
-
data: { op: 'delete' },
|
|
219
|
-
},
|
|
220
|
-
]);
|
|
221
|
-
},
|
|
222
|
-
};
|
|
223
|
-
return acc;
|
|
224
|
-
}, {});
|
|
225
|
-
}
|
|
226
|
-
function getMigrationEngine({ meta, migration, context, }) {
|
|
227
|
-
function getMigrationNow() {
|
|
228
|
-
return meta.time.zero(migration.version);
|
|
229
|
-
}
|
|
230
|
-
const newOids = new Array();
|
|
231
|
-
const queries = migration.oldCollections.reduce((acc, collectionName) => {
|
|
232
|
-
acc[collectionName] = {
|
|
233
|
-
get: async (id) => {
|
|
234
|
-
const oid = (0, common_1.createOid)(collectionName, id, []);
|
|
235
|
-
const doc = await meta.getDocumentSnapshot(oid);
|
|
236
|
-
(0, common_1.removeOidsFromAllSubObjects)(doc);
|
|
237
|
-
return doc;
|
|
238
|
-
},
|
|
239
|
-
findOne: async (filter) => {
|
|
240
|
-
const oid = await (0, dbQueries_js_1.findOneOid)({
|
|
241
|
-
collection: collectionName,
|
|
242
|
-
index: filter,
|
|
243
|
-
context,
|
|
244
|
-
});
|
|
245
|
-
if (!oid)
|
|
246
|
-
return null;
|
|
247
|
-
const doc = await meta.getDocumentSnapshot(oid);
|
|
248
|
-
(0, common_1.removeOidsFromAllSubObjects)(doc);
|
|
249
|
-
return doc;
|
|
250
|
-
},
|
|
251
|
-
findAll: async (filter) => {
|
|
252
|
-
const oids = await (0, dbQueries_js_1.findAllOids)({
|
|
253
|
-
collection: collectionName,
|
|
254
|
-
index: filter,
|
|
255
|
-
context,
|
|
256
|
-
});
|
|
257
|
-
const docs = await Promise.all(oids.map((oid) => meta.getDocumentSnapshot(oid)));
|
|
258
|
-
docs.forEach((doc) => (0, common_1.removeOidsFromAllSubObjects)(doc));
|
|
259
|
-
return docs;
|
|
260
|
-
},
|
|
261
|
-
};
|
|
262
|
-
return acc;
|
|
263
|
-
}, {});
|
|
264
|
-
const mutations = getMigrationMutations({
|
|
265
|
-
migration,
|
|
266
|
-
getMigrationNow,
|
|
267
|
-
newOids,
|
|
268
|
-
meta,
|
|
269
|
-
});
|
|
270
|
-
const awaitables = new Array();
|
|
271
|
-
const engine = {
|
|
272
|
-
newOids,
|
|
273
|
-
migrate: async (collection, strategy) => {
|
|
274
|
-
const docs = await new Promise((resolve, reject) => {
|
|
275
|
-
const transaction = context.documentDb.transaction(collection, 'readonly');
|
|
276
|
-
const store = transaction.objectStore(collection);
|
|
277
|
-
const cursorReq = store.openCursor();
|
|
278
|
-
const documentsToMigrate = [];
|
|
279
|
-
cursorReq.onsuccess = async (event) => {
|
|
280
|
-
const cursor = cursorReq.result;
|
|
281
|
-
if (cursor) {
|
|
282
|
-
documentsToMigrate.push(cursor.value);
|
|
283
|
-
cursor.continue();
|
|
284
|
-
}
|
|
285
|
-
else {
|
|
286
|
-
resolve(documentsToMigrate);
|
|
287
|
-
}
|
|
288
|
-
};
|
|
289
|
-
cursorReq.onerror = (event) => {
|
|
290
|
-
reject(cursorReq.error);
|
|
291
|
-
};
|
|
292
|
-
});
|
|
293
|
-
await Promise.all(docs.map(async (doc) => {
|
|
294
|
-
const original = (0, common_1.cloneDeep)(doc);
|
|
295
|
-
// remove any indexes before computing the diff
|
|
296
|
-
const collectionSpec = migration.oldSchema.collections[collection];
|
|
297
|
-
const indexKeys = [
|
|
298
|
-
...Object.keys(collectionSpec.synthetics || {}),
|
|
299
|
-
...Object.keys(collectionSpec.compounds || {}),
|
|
300
|
-
];
|
|
301
|
-
indexKeys.forEach((key) => {
|
|
302
|
-
delete doc[key];
|
|
303
|
-
});
|
|
304
|
-
// @ts-ignore - excessive type resolution
|
|
305
|
-
const newValue = await strategy(doc);
|
|
306
|
-
if (newValue) {
|
|
307
|
-
// the migration has altered the shape of our document. we need
|
|
308
|
-
// to create the operation from the diff and write it to meta as
|
|
309
|
-
// a migration patch
|
|
310
|
-
(0, common_1.removeOidPropertiesFromAllSubObjects)(original);
|
|
311
|
-
(0, common_1.removeOidPropertiesFromAllSubObjects)(newValue);
|
|
312
|
-
(0, common_1.assignOidsToAllSubObjects)(newValue);
|
|
313
|
-
const patches = (0, common_1.diffToPatches)(original, newValue, getMigrationNow, [], undefined, [], {
|
|
314
|
-
mergeUnknownObjects: true,
|
|
315
|
-
});
|
|
316
|
-
if (patches.length > 0) {
|
|
317
|
-
await meta.insertLocalOperation(patches);
|
|
318
|
-
}
|
|
319
|
-
}
|
|
320
|
-
}));
|
|
321
|
-
},
|
|
322
|
-
queries,
|
|
323
|
-
mutations,
|
|
324
|
-
awaitables,
|
|
325
|
-
};
|
|
326
|
-
return engine;
|
|
327
|
-
}
|
|
328
|
-
function getVersion1MigrationEngine({ meta, migration, }) {
|
|
329
|
-
function getMigrationNow() {
|
|
330
|
-
return meta.time.zero(migration.version);
|
|
331
|
-
}
|
|
332
|
-
const newOids = new Array();
|
|
333
|
-
const queries = new Proxy({}, {
|
|
334
|
-
get() {
|
|
335
|
-
throw new Error('Queries are not available in version 1 migrations; there is no database yet!');
|
|
336
|
-
},
|
|
337
|
-
});
|
|
338
|
-
const mutations = getMigrationMutations({
|
|
339
|
-
migration,
|
|
340
|
-
getMigrationNow,
|
|
341
|
-
newOids,
|
|
342
|
-
meta,
|
|
343
|
-
});
|
|
344
|
-
const engine = {
|
|
345
|
-
newOids,
|
|
346
|
-
migrate: (collection, strategy) => {
|
|
347
|
-
throw new Error('Calling migrate() in version 1 migrations is not supported! Use version 1 migrations to seed initial data using mutations.');
|
|
348
|
-
},
|
|
349
|
-
queries,
|
|
350
|
-
mutations,
|
|
351
|
-
awaitables: [],
|
|
352
|
-
};
|
|
353
|
-
return engine;
|
|
354
|
-
}
|
|
355
|
-
async function closeDatabase(db) {
|
|
356
|
-
db.close();
|
|
357
|
-
// FIXME: this isn't right!!!!
|
|
358
|
-
await new Promise((resolve) => resolve());
|
|
359
|
-
}
|
|
360
|
-
async function upgradeDatabase(indexedDb, namespace, version, upgrader, log) {
|
|
361
|
-
function openAndUpgrade(resolve, reject) {
|
|
362
|
-
const request = indexedDb.open([namespace, 'collections'].join('_'), version);
|
|
363
|
-
let wasUpgraded = false;
|
|
364
|
-
request.onupgradeneeded = (event) => {
|
|
365
|
-
const transaction = request.transaction;
|
|
366
|
-
upgrader(transaction, request.result, event);
|
|
367
|
-
wasUpgraded = true;
|
|
368
|
-
};
|
|
369
|
-
request.onsuccess = (event) => {
|
|
370
|
-
request.result.close();
|
|
371
|
-
if (wasUpgraded) {
|
|
372
|
-
resolve();
|
|
373
|
-
}
|
|
374
|
-
else {
|
|
375
|
-
reject(new Error('Database was not upgraded when a version change was expected'));
|
|
376
|
-
}
|
|
377
|
-
};
|
|
378
|
-
request.onerror = (event) => {
|
|
379
|
-
reject(request.error || new Error('Unknown error'));
|
|
380
|
-
};
|
|
381
|
-
request.onblocked = (event) => {
|
|
382
|
-
log === null || log === void 0 ? void 0 : log('Database upgrade blocked, waiting...');
|
|
383
|
-
// setTimeout(() => {
|
|
384
|
-
// openAndUpgrade(resolve, reject);
|
|
385
|
-
// }, 200);
|
|
386
|
-
};
|
|
387
|
-
}
|
|
388
|
-
return new Promise(openAndUpgrade);
|
|
389
|
-
}
|
|
390
|
-
async function getAllKeys(store) {
|
|
391
|
-
return new Promise((resolve, reject) => {
|
|
392
|
-
const request = store.getAllKeys();
|
|
393
|
-
request.onsuccess = (event) => {
|
|
394
|
-
resolve(request.result);
|
|
395
|
-
};
|
|
396
|
-
request.onerror = (event) => {
|
|
397
|
-
reject(request.error);
|
|
398
|
-
};
|
|
399
|
-
});
|
|
400
|
-
}
|
|
401
|
-
async function deleteView(store, id) {
|
|
402
|
-
const request = store.delete(id);
|
|
403
|
-
return new Promise((resolve, reject) => {
|
|
404
|
-
request.onsuccess = (event) => {
|
|
405
|
-
resolve();
|
|
406
|
-
};
|
|
407
|
-
request.onerror = (event) => {
|
|
408
|
-
reject(request.error);
|
|
409
|
-
};
|
|
410
|
-
});
|
|
411
|
-
}
|
|
412
|
-
async function putView(store, view) {
|
|
413
|
-
const request = store.put(view);
|
|
414
|
-
return new Promise((resolve, reject) => {
|
|
415
|
-
request.onsuccess = (event) => {
|
|
416
|
-
resolve();
|
|
417
|
-
};
|
|
418
|
-
request.onerror = (event) => {
|
|
419
|
-
reject(request.error);
|
|
420
|
-
};
|
|
421
|
-
});
|
|
422
|
-
}
|
|
423
|
-
async function acquireLock(namespace, procedure) {
|
|
424
|
-
if (typeof navigator !== 'undefined' && navigator.locks) {
|
|
425
|
-
await navigator.locks.request(`lo-fi_migration_${namespace}`, procedure);
|
|
426
|
-
}
|
|
427
|
-
else {
|
|
428
|
-
// TODO: is there a fallback?
|
|
429
|
-
await procedure();
|
|
430
|
-
}
|
|
431
|
-
}
|
|
136
|
+
`);
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
return openDatabase(indexedDB, context.namespace, version);
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
// just open the database
|
|
143
|
+
return openDatabase(indexedDB, context.namespace, version);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
exports.openDocumentDatabase = openDocumentDatabase;
|
|
147
|
+
async function getDatabaseVersion(indexedDB, namespace, version, log) {
|
|
148
|
+
function openAndGetVersion(resolve, reject) {
|
|
149
|
+
let currentVersion;
|
|
150
|
+
let database;
|
|
151
|
+
const request = indexedDB.open([namespace, 'collections'].join('_'), version);
|
|
152
|
+
request.onupgradeneeded = async (event) => {
|
|
153
|
+
currentVersion = event.oldVersion;
|
|
154
|
+
const transaction = request.transaction;
|
|
155
|
+
database = request.result;
|
|
156
|
+
transaction.abort();
|
|
157
|
+
};
|
|
158
|
+
request.onsuccess = (event) => {
|
|
159
|
+
resolve([request.result.version, request.result]);
|
|
160
|
+
};
|
|
161
|
+
request.onblocked = (event) => {
|
|
162
|
+
// retry if blocked
|
|
163
|
+
log === null || log === void 0 ? void 0 : log('Database blocked, waiting...');
|
|
164
|
+
// setTimeout(() => {
|
|
165
|
+
// openAndGetVersion(resolve, reject);
|
|
166
|
+
// }, 200);
|
|
167
|
+
};
|
|
168
|
+
request.onerror = (event) => {
|
|
169
|
+
// FIXME: this fails if the code is older than the local database
|
|
170
|
+
resolve([currentVersion, database]);
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
const [currentVersion, db] = await new Promise(openAndGetVersion);
|
|
174
|
+
await closeDatabase(db);
|
|
175
|
+
return currentVersion;
|
|
176
|
+
}
|
|
177
|
+
async function openDatabase(indexedDb, namespace, version) {
|
|
178
|
+
const db = await new Promise((resolve, reject) => {
|
|
179
|
+
const request = indexedDb.open([namespace, 'collections'].join('_'), version);
|
|
180
|
+
request.onupgradeneeded = async (event) => {
|
|
181
|
+
const transaction = request.transaction;
|
|
182
|
+
transaction.abort();
|
|
183
|
+
reject(new Error('Migration error: database version changed while migrating'));
|
|
184
|
+
};
|
|
185
|
+
request.onsuccess = (event) => {
|
|
186
|
+
resolve(request.result);
|
|
187
|
+
};
|
|
188
|
+
request.onblocked = (event) => {
|
|
189
|
+
reject(new Error('Migration error: database blocked'));
|
|
190
|
+
};
|
|
191
|
+
request.onerror = (event) => {
|
|
192
|
+
reject(new Error('Migration error: database error'));
|
|
193
|
+
};
|
|
194
|
+
});
|
|
195
|
+
db.addEventListener('versionchange', (event) => {
|
|
196
|
+
db.close();
|
|
197
|
+
});
|
|
198
|
+
return db;
|
|
199
|
+
}
|
|
200
|
+
function getMigrationMutations({ migration, meta, getMigrationNow, newOids, }) {
|
|
201
|
+
return migration.allCollections.reduce((acc, collectionName) => {
|
|
202
|
+
acc[collectionName] = {
|
|
203
|
+
put: async (doc) => {
|
|
204
|
+
// add defaults
|
|
205
|
+
(0, common_1.addFieldDefaults)(migration.newSchema.collections[collectionName], doc);
|
|
206
|
+
const primaryKey = doc[migration.newSchema.collections[collectionName].primaryKey];
|
|
207
|
+
const oid = (0, common_1.createOid)(collectionName, primaryKey, []);
|
|
208
|
+
newOids.push(oid);
|
|
209
|
+
await meta.insertLocalOperation((0, common_1.initialToPatches)(doc, oid, getMigrationNow));
|
|
210
|
+
return doc;
|
|
211
|
+
},
|
|
212
|
+
delete: (id) => {
|
|
213
|
+
const oid = (0, common_1.createOid)(collectionName, id, []);
|
|
214
|
+
return meta.insertLocalOperation([
|
|
215
|
+
{
|
|
216
|
+
oid,
|
|
217
|
+
timestamp: getMigrationNow(),
|
|
218
|
+
data: { op: 'delete' },
|
|
219
|
+
},
|
|
220
|
+
]);
|
|
221
|
+
},
|
|
222
|
+
};
|
|
223
|
+
return acc;
|
|
224
|
+
}, {});
|
|
225
|
+
}
|
|
226
|
+
function getMigrationEngine({ meta, migration, context, }) {
|
|
227
|
+
function getMigrationNow() {
|
|
228
|
+
return meta.time.zero(migration.version);
|
|
229
|
+
}
|
|
230
|
+
const newOids = new Array();
|
|
231
|
+
const queries = migration.oldCollections.reduce((acc, collectionName) => {
|
|
232
|
+
acc[collectionName] = {
|
|
233
|
+
get: async (id) => {
|
|
234
|
+
const oid = (0, common_1.createOid)(collectionName, id, []);
|
|
235
|
+
const doc = await meta.getDocumentSnapshot(oid);
|
|
236
|
+
(0, common_1.removeOidsFromAllSubObjects)(doc);
|
|
237
|
+
return doc;
|
|
238
|
+
},
|
|
239
|
+
findOne: async (filter) => {
|
|
240
|
+
const oid = await (0, dbQueries_js_1.findOneOid)({
|
|
241
|
+
collection: collectionName,
|
|
242
|
+
index: filter,
|
|
243
|
+
context,
|
|
244
|
+
});
|
|
245
|
+
if (!oid)
|
|
246
|
+
return null;
|
|
247
|
+
const doc = await meta.getDocumentSnapshot(oid);
|
|
248
|
+
(0, common_1.removeOidsFromAllSubObjects)(doc);
|
|
249
|
+
return doc;
|
|
250
|
+
},
|
|
251
|
+
findAll: async (filter) => {
|
|
252
|
+
const oids = await (0, dbQueries_js_1.findAllOids)({
|
|
253
|
+
collection: collectionName,
|
|
254
|
+
index: filter,
|
|
255
|
+
context,
|
|
256
|
+
});
|
|
257
|
+
const docs = await Promise.all(oids.map((oid) => meta.getDocumentSnapshot(oid)));
|
|
258
|
+
docs.forEach((doc) => (0, common_1.removeOidsFromAllSubObjects)(doc));
|
|
259
|
+
return docs;
|
|
260
|
+
},
|
|
261
|
+
};
|
|
262
|
+
return acc;
|
|
263
|
+
}, {});
|
|
264
|
+
const mutations = getMigrationMutations({
|
|
265
|
+
migration,
|
|
266
|
+
getMigrationNow,
|
|
267
|
+
newOids,
|
|
268
|
+
meta,
|
|
269
|
+
});
|
|
270
|
+
const awaitables = new Array();
|
|
271
|
+
const engine = {
|
|
272
|
+
newOids,
|
|
273
|
+
migrate: async (collection, strategy) => {
|
|
274
|
+
const docs = await new Promise((resolve, reject) => {
|
|
275
|
+
const transaction = context.documentDb.transaction(collection, 'readonly');
|
|
276
|
+
const store = transaction.objectStore(collection);
|
|
277
|
+
const cursorReq = store.openCursor();
|
|
278
|
+
const documentsToMigrate = [];
|
|
279
|
+
cursorReq.onsuccess = async (event) => {
|
|
280
|
+
const cursor = cursorReq.result;
|
|
281
|
+
if (cursor) {
|
|
282
|
+
documentsToMigrate.push(cursor.value);
|
|
283
|
+
cursor.continue();
|
|
284
|
+
}
|
|
285
|
+
else {
|
|
286
|
+
resolve(documentsToMigrate);
|
|
287
|
+
}
|
|
288
|
+
};
|
|
289
|
+
cursorReq.onerror = (event) => {
|
|
290
|
+
reject(cursorReq.error);
|
|
291
|
+
};
|
|
292
|
+
});
|
|
293
|
+
await Promise.all(docs.map(async (doc) => {
|
|
294
|
+
const original = (0, common_1.cloneDeep)(doc);
|
|
295
|
+
// remove any indexes before computing the diff
|
|
296
|
+
const collectionSpec = migration.oldSchema.collections[collection];
|
|
297
|
+
const indexKeys = [
|
|
298
|
+
...Object.keys(collectionSpec.synthetics || {}),
|
|
299
|
+
...Object.keys(collectionSpec.compounds || {}),
|
|
300
|
+
];
|
|
301
|
+
indexKeys.forEach((key) => {
|
|
302
|
+
delete doc[key];
|
|
303
|
+
});
|
|
304
|
+
// @ts-ignore - excessive type resolution
|
|
305
|
+
const newValue = await strategy(doc);
|
|
306
|
+
if (newValue) {
|
|
307
|
+
// the migration has altered the shape of our document. we need
|
|
308
|
+
// to create the operation from the diff and write it to meta as
|
|
309
|
+
// a migration patch
|
|
310
|
+
(0, common_1.removeOidPropertiesFromAllSubObjects)(original);
|
|
311
|
+
(0, common_1.removeOidPropertiesFromAllSubObjects)(newValue);
|
|
312
|
+
(0, common_1.assignOidsToAllSubObjects)(newValue);
|
|
313
|
+
const patches = (0, common_1.diffToPatches)(original, newValue, getMigrationNow, [], undefined, [], {
|
|
314
|
+
mergeUnknownObjects: true,
|
|
315
|
+
});
|
|
316
|
+
if (patches.length > 0) {
|
|
317
|
+
await meta.insertLocalOperation(patches);
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
}));
|
|
321
|
+
},
|
|
322
|
+
queries,
|
|
323
|
+
mutations,
|
|
324
|
+
awaitables,
|
|
325
|
+
};
|
|
326
|
+
return engine;
|
|
327
|
+
}
|
|
328
|
+
function getVersion1MigrationEngine({ meta, migration, }) {
|
|
329
|
+
function getMigrationNow() {
|
|
330
|
+
return meta.time.zero(migration.version);
|
|
331
|
+
}
|
|
332
|
+
const newOids = new Array();
|
|
333
|
+
const queries = new Proxy({}, {
|
|
334
|
+
get() {
|
|
335
|
+
throw new Error('Queries are not available in version 1 migrations; there is no database yet!');
|
|
336
|
+
},
|
|
337
|
+
});
|
|
338
|
+
const mutations = getMigrationMutations({
|
|
339
|
+
migration,
|
|
340
|
+
getMigrationNow,
|
|
341
|
+
newOids,
|
|
342
|
+
meta,
|
|
343
|
+
});
|
|
344
|
+
const engine = {
|
|
345
|
+
newOids,
|
|
346
|
+
migrate: (collection, strategy) => {
|
|
347
|
+
throw new Error('Calling migrate() in version 1 migrations is not supported! Use version 1 migrations to seed initial data using mutations.');
|
|
348
|
+
},
|
|
349
|
+
queries,
|
|
350
|
+
mutations,
|
|
351
|
+
awaitables: [],
|
|
352
|
+
};
|
|
353
|
+
return engine;
|
|
354
|
+
}
|
|
355
|
+
async function closeDatabase(db) {
|
|
356
|
+
db.close();
|
|
357
|
+
// FIXME: this isn't right!!!!
|
|
358
|
+
await new Promise((resolve) => resolve());
|
|
359
|
+
}
|
|
360
|
+
async function upgradeDatabase(indexedDb, namespace, version, upgrader, log) {
|
|
361
|
+
function openAndUpgrade(resolve, reject) {
|
|
362
|
+
const request = indexedDb.open([namespace, 'collections'].join('_'), version);
|
|
363
|
+
let wasUpgraded = false;
|
|
364
|
+
request.onupgradeneeded = (event) => {
|
|
365
|
+
const transaction = request.transaction;
|
|
366
|
+
upgrader(transaction, request.result, event);
|
|
367
|
+
wasUpgraded = true;
|
|
368
|
+
};
|
|
369
|
+
request.onsuccess = (event) => {
|
|
370
|
+
request.result.close();
|
|
371
|
+
if (wasUpgraded) {
|
|
372
|
+
resolve();
|
|
373
|
+
}
|
|
374
|
+
else {
|
|
375
|
+
reject(new Error('Database was not upgraded when a version change was expected'));
|
|
376
|
+
}
|
|
377
|
+
};
|
|
378
|
+
request.onerror = (event) => {
|
|
379
|
+
reject(request.error || new Error('Unknown error'));
|
|
380
|
+
};
|
|
381
|
+
request.onblocked = (event) => {
|
|
382
|
+
log === null || log === void 0 ? void 0 : log('Database upgrade blocked, waiting...');
|
|
383
|
+
// setTimeout(() => {
|
|
384
|
+
// openAndUpgrade(resolve, reject);
|
|
385
|
+
// }, 200);
|
|
386
|
+
};
|
|
387
|
+
}
|
|
388
|
+
return new Promise(openAndUpgrade);
|
|
389
|
+
}
|
|
390
|
+
async function getAllKeys(store) {
|
|
391
|
+
return new Promise((resolve, reject) => {
|
|
392
|
+
const request = store.getAllKeys();
|
|
393
|
+
request.onsuccess = (event) => {
|
|
394
|
+
resolve(request.result);
|
|
395
|
+
};
|
|
396
|
+
request.onerror = (event) => {
|
|
397
|
+
reject(request.error);
|
|
398
|
+
};
|
|
399
|
+
});
|
|
400
|
+
}
|
|
401
|
+
async function deleteView(store, id) {
|
|
402
|
+
const request = store.delete(id);
|
|
403
|
+
return new Promise((resolve, reject) => {
|
|
404
|
+
request.onsuccess = (event) => {
|
|
405
|
+
resolve();
|
|
406
|
+
};
|
|
407
|
+
request.onerror = (event) => {
|
|
408
|
+
reject(request.error);
|
|
409
|
+
};
|
|
410
|
+
});
|
|
411
|
+
}
|
|
412
|
+
async function putView(store, view) {
|
|
413
|
+
const request = store.put(view);
|
|
414
|
+
return new Promise((resolve, reject) => {
|
|
415
|
+
request.onsuccess = (event) => {
|
|
416
|
+
resolve();
|
|
417
|
+
};
|
|
418
|
+
request.onerror = (event) => {
|
|
419
|
+
reject(request.error);
|
|
420
|
+
};
|
|
421
|
+
});
|
|
422
|
+
}
|
|
423
|
+
async function acquireLock(namespace, procedure) {
|
|
424
|
+
if (typeof navigator !== 'undefined' && navigator.locks) {
|
|
425
|
+
await navigator.locks.request(`lo-fi_migration_${namespace}`, procedure);
|
|
426
|
+
}
|
|
427
|
+
else {
|
|
428
|
+
// TODO: is there a fallback?
|
|
429
|
+
await procedure();
|
|
430
|
+
}
|
|
431
|
+
}
|
|
432
432
|
//# sourceMappingURL=openDocumentDatabase.js.map
|