@fluidframework/container-runtime 2.0.0-dev.2.2.0.111723 → 2.0.0-dev.3.1.0.125672
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/.eslintrc.js +21 -10
- package/.mocharc.js +2 -2
- package/api-extractor.json +2 -2
- package/dist/batchTracker.d.ts +1 -2
- package/dist/batchTracker.d.ts.map +1 -1
- package/dist/batchTracker.js +2 -1
- package/dist/batchTracker.js.map +1 -1
- package/dist/blobManager.d.ts +62 -28
- package/dist/blobManager.d.ts.map +1 -1
- package/dist/blobManager.js +256 -102
- package/dist/blobManager.js.map +1 -1
- package/dist/connectionTelemetry.d.ts.map +1 -1
- package/dist/connectionTelemetry.js +11 -9
- package/dist/connectionTelemetry.js.map +1 -1
- package/dist/containerHandleContext.d.ts.map +1 -1
- package/dist/containerHandleContext.js +3 -1
- package/dist/containerHandleContext.js.map +1 -1
- package/dist/containerRuntime.d.ts +110 -78
- package/dist/containerRuntime.d.ts.map +1 -1
- package/dist/containerRuntime.js +336 -331
- package/dist/containerRuntime.js.map +1 -1
- package/dist/dataStore.d.ts.map +1 -1
- package/dist/dataStore.js +11 -9
- package/dist/dataStore.js.map +1 -1
- package/dist/dataStoreContext.d.ts +2 -1
- package/dist/dataStoreContext.d.ts.map +1 -1
- package/dist/dataStoreContext.js +40 -23
- package/dist/dataStoreContext.js.map +1 -1
- package/dist/dataStoreContexts.d.ts.map +1 -1
- package/dist/dataStoreContexts.js +7 -3
- package/dist/dataStoreContexts.js.map +1 -1
- package/dist/dataStoreRegistry.d.ts.map +1 -1
- package/dist/dataStoreRegistry.js +3 -1
- package/dist/dataStoreRegistry.js.map +1 -1
- package/dist/dataStores.d.ts +12 -9
- package/dist/dataStores.d.ts.map +1 -1
- package/dist/dataStores.js +69 -46
- package/dist/dataStores.js.map +1 -1
- package/dist/deltaScheduler.d.ts.map +1 -1
- package/dist/deltaScheduler.js +8 -3
- package/dist/deltaScheduler.js.map +1 -1
- package/dist/garbageCollection.d.ts +57 -42
- package/dist/garbageCollection.d.ts.map +1 -1
- package/dist/garbageCollection.js +371 -239
- package/dist/garbageCollection.js.map +1 -1
- package/dist/garbageCollectionConstants.d.ts +23 -0
- package/dist/garbageCollectionConstants.d.ts.map +1 -0
- package/dist/garbageCollectionConstants.js +36 -0
- package/dist/garbageCollectionConstants.js.map +1 -0
- package/dist/garbageCollectionHelpers.d.ts +15 -0
- package/dist/garbageCollectionHelpers.d.ts.map +1 -0
- package/dist/garbageCollectionHelpers.js +27 -0
- package/dist/garbageCollectionHelpers.js.map +1 -0
- package/dist/gcSweepReadyUsageDetection.d.ts +5 -5
- package/dist/gcSweepReadyUsageDetection.d.ts.map +1 -1
- package/dist/gcSweepReadyUsageDetection.js +15 -11
- package/dist/gcSweepReadyUsageDetection.js.map +1 -1
- package/dist/index.d.ts +4 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -6
- package/dist/index.js.map +1 -1
- package/dist/opLifecycle/batchManager.d.ts +42 -0
- package/dist/opLifecycle/batchManager.d.ts.map +1 -0
- package/dist/opLifecycle/batchManager.js +124 -0
- package/dist/opLifecycle/batchManager.js.map +1 -0
- package/dist/opLifecycle/definitions.d.ts +64 -0
- package/dist/opLifecycle/definitions.d.ts.map +1 -0
- package/dist/opLifecycle/definitions.js +7 -0
- package/dist/opLifecycle/definitions.js.map +1 -0
- package/dist/opLifecycle/index.d.ts +12 -0
- package/dist/opLifecycle/index.d.ts.map +1 -0
- package/dist/opLifecycle/index.js +22 -0
- package/dist/opLifecycle/index.js.map +1 -0
- package/dist/{opCompressor.d.ts → opLifecycle/opCompressor.d.ts} +3 -3
- package/dist/opLifecycle/opCompressor.d.ts.map +1 -0
- package/dist/opLifecycle/opCompressor.js +67 -0
- package/dist/opLifecycle/opCompressor.js.map +1 -0
- package/dist/{opDecompressor.d.ts → opLifecycle/opDecompressor.d.ts} +2 -1
- package/dist/opLifecycle/opDecompressor.d.ts.map +1 -0
- package/dist/{opDecompressor.js → opLifecycle/opDecompressor.js} +37 -21
- package/dist/opLifecycle/opDecompressor.js.map +1 -0
- package/dist/opLifecycle/opSplitter.d.ts +49 -0
- package/dist/opLifecycle/opSplitter.d.ts.map +1 -0
- package/dist/opLifecycle/opSplitter.js +173 -0
- package/dist/opLifecycle/opSplitter.js.map +1 -0
- package/dist/opLifecycle/outbox.d.ts +52 -0
- package/dist/opLifecycle/outbox.d.ts.map +1 -0
- package/dist/opLifecycle/outbox.js +164 -0
- package/dist/opLifecycle/outbox.js.map +1 -0
- package/dist/opLifecycle/remoteMessageProcessor.d.ts +26 -0
- package/dist/opLifecycle/remoteMessageProcessor.d.ts.map +1 -0
- package/dist/opLifecycle/remoteMessageProcessor.js +96 -0
- package/dist/opLifecycle/remoteMessageProcessor.js.map +1 -0
- package/dist/opProperties.d.ts.map +1 -1
- package/dist/opProperties.js +1 -3
- package/dist/opProperties.js.map +1 -1
- package/dist/orderedClientElection.d.ts.map +1 -1
- package/dist/orderedClientElection.js +10 -4
- package/dist/orderedClientElection.js.map +1 -1
- package/dist/packageVersion.d.ts +1 -1
- package/dist/packageVersion.js +1 -1
- package/dist/packageVersion.js.map +1 -1
- package/dist/pendingStateManager.d.ts +4 -13
- package/dist/pendingStateManager.d.ts.map +1 -1
- package/dist/pendingStateManager.js +134 -161
- package/dist/pendingStateManager.js.map +1 -1
- package/dist/runWhileConnectedCoordinator.d.ts.map +1 -1
- package/dist/runWhileConnectedCoordinator.js.map +1 -1
- package/dist/runningSummarizer.d.ts.map +1 -1
- package/dist/runningSummarizer.js +34 -22
- package/dist/runningSummarizer.js.map +1 -1
- package/dist/scheduleManager.d.ts +0 -1
- package/dist/scheduleManager.d.ts.map +1 -1
- package/dist/scheduleManager.js +11 -21
- package/dist/scheduleManager.js.map +1 -1
- package/dist/serializedSnapshotStorage.d.ts.map +1 -1
- package/dist/serializedSnapshotStorage.js +3 -1
- package/dist/serializedSnapshotStorage.js.map +1 -1
- package/dist/summarizer.d.ts +2 -3
- package/dist/summarizer.d.ts.map +1 -1
- package/dist/summarizer.js +39 -18
- package/dist/summarizer.js.map +1 -1
- package/dist/summarizerClientElection.d.ts +1 -2
- package/dist/summarizerClientElection.d.ts.map +1 -1
- package/dist/summarizerClientElection.js +3 -30
- package/dist/summarizerClientElection.js.map +1 -1
- package/dist/summarizerHandle.d.ts.map +1 -1
- package/dist/summarizerHandle.js.map +1 -1
- package/dist/summarizerHeuristics.d.ts.map +1 -1
- package/dist/summarizerHeuristics.js +6 -9
- package/dist/summarizerHeuristics.js.map +1 -1
- package/dist/summarizerTypes.d.ts +22 -25
- package/dist/summarizerTypes.d.ts.map +1 -1
- package/dist/summarizerTypes.js.map +1 -1
- package/dist/summaryCollection.d.ts.map +1 -1
- package/dist/summaryCollection.js +18 -8
- package/dist/summaryCollection.js.map +1 -1
- package/dist/summaryFormat.d.ts.map +1 -1
- package/dist/summaryFormat.js +18 -11
- package/dist/summaryFormat.js.map +1 -1
- package/dist/summaryGenerator.d.ts.map +1 -1
- package/dist/summaryGenerator.js +32 -14
- package/dist/summaryGenerator.js.map +1 -1
- package/dist/summaryManager.d.ts.map +1 -1
- package/dist/summaryManager.js +21 -9
- package/dist/summaryManager.js.map +1 -1
- package/dist/throttler.d.ts +2 -2
- package/dist/throttler.d.ts.map +1 -1
- package/dist/throttler.js +4 -4
- package/dist/throttler.js.map +1 -1
- package/garbageCollection.md +15 -2
- package/lib/batchTracker.d.ts +1 -2
- package/lib/batchTracker.d.ts.map +1 -1
- package/lib/batchTracker.js +2 -1
- package/lib/batchTracker.js.map +1 -1
- package/lib/blobManager.d.ts +62 -28
- package/lib/blobManager.d.ts.map +1 -1
- package/lib/blobManager.js +259 -105
- package/lib/blobManager.js.map +1 -1
- package/lib/connectionTelemetry.d.ts.map +1 -1
- package/lib/connectionTelemetry.js +11 -9
- package/lib/connectionTelemetry.js.map +1 -1
- package/lib/containerHandleContext.d.ts.map +1 -1
- package/lib/containerHandleContext.js +3 -1
- package/lib/containerHandleContext.js.map +1 -1
- package/lib/containerRuntime.d.ts +110 -78
- package/lib/containerRuntime.d.ts.map +1 -1
- package/lib/containerRuntime.js +340 -334
- package/lib/containerRuntime.js.map +1 -1
- package/lib/dataStore.d.ts.map +1 -1
- package/lib/dataStore.js +11 -9
- package/lib/dataStore.js.map +1 -1
- package/lib/dataStoreContext.d.ts +2 -1
- package/lib/dataStoreContext.d.ts.map +1 -1
- package/lib/dataStoreContext.js +41 -24
- package/lib/dataStoreContext.js.map +1 -1
- package/lib/dataStoreContexts.d.ts.map +1 -1
- package/lib/dataStoreContexts.js +7 -3
- package/lib/dataStoreContexts.js.map +1 -1
- package/lib/dataStoreRegistry.d.ts.map +1 -1
- package/lib/dataStoreRegistry.js +3 -1
- package/lib/dataStoreRegistry.js.map +1 -1
- package/lib/dataStores.d.ts +12 -9
- package/lib/dataStores.d.ts.map +1 -1
- package/lib/dataStores.js +75 -52
- package/lib/dataStores.js.map +1 -1
- package/lib/deltaScheduler.d.ts.map +1 -1
- package/lib/deltaScheduler.js +9 -4
- package/lib/deltaScheduler.js.map +1 -1
- package/lib/garbageCollection.d.ts +57 -42
- package/lib/garbageCollection.d.ts.map +1 -1
- package/lib/garbageCollection.js +364 -232
- package/lib/garbageCollection.js.map +1 -1
- package/lib/garbageCollectionConstants.d.ts +23 -0
- package/lib/garbageCollectionConstants.d.ts.map +1 -0
- package/lib/garbageCollectionConstants.js +33 -0
- package/lib/garbageCollectionConstants.js.map +1 -0
- package/lib/garbageCollectionHelpers.d.ts +15 -0
- package/lib/garbageCollectionHelpers.d.ts.map +1 -0
- package/lib/garbageCollectionHelpers.js +23 -0
- package/lib/garbageCollectionHelpers.js.map +1 -0
- package/lib/gcSweepReadyUsageDetection.d.ts +5 -5
- package/lib/gcSweepReadyUsageDetection.d.ts.map +1 -1
- package/lib/gcSweepReadyUsageDetection.js +15 -11
- package/lib/gcSweepReadyUsageDetection.js.map +1 -1
- package/lib/index.d.ts +4 -3
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +3 -3
- package/lib/index.js.map +1 -1
- package/lib/opLifecycle/batchManager.d.ts +42 -0
- package/lib/opLifecycle/batchManager.d.ts.map +1 -0
- package/lib/opLifecycle/batchManager.js +120 -0
- package/lib/opLifecycle/batchManager.js.map +1 -0
- package/lib/opLifecycle/definitions.d.ts +64 -0
- package/lib/opLifecycle/definitions.d.ts.map +1 -0
- package/lib/opLifecycle/definitions.js +6 -0
- package/lib/opLifecycle/definitions.js.map +1 -0
- package/lib/opLifecycle/index.d.ts +12 -0
- package/lib/opLifecycle/index.d.ts.map +1 -0
- package/lib/opLifecycle/index.js +11 -0
- package/lib/opLifecycle/index.js.map +1 -0
- package/lib/{opCompressor.d.ts → opLifecycle/opCompressor.d.ts} +3 -3
- package/lib/opLifecycle/opCompressor.d.ts.map +1 -0
- package/lib/opLifecycle/opCompressor.js +63 -0
- package/lib/opLifecycle/opCompressor.js.map +1 -0
- package/lib/{opDecompressor.d.ts → opLifecycle/opDecompressor.d.ts} +2 -1
- package/lib/opLifecycle/opDecompressor.d.ts.map +1 -0
- package/lib/{opDecompressor.js → opLifecycle/opDecompressor.js} +37 -21
- package/lib/opLifecycle/opDecompressor.js.map +1 -0
- package/lib/opLifecycle/opSplitter.d.ts +49 -0
- package/lib/opLifecycle/opSplitter.d.ts.map +1 -0
- package/lib/opLifecycle/opSplitter.js +168 -0
- package/lib/opLifecycle/opSplitter.js.map +1 -0
- package/lib/opLifecycle/outbox.d.ts +52 -0
- package/lib/opLifecycle/outbox.d.ts.map +1 -0
- package/lib/opLifecycle/outbox.js +160 -0
- package/lib/opLifecycle/outbox.js.map +1 -0
- package/lib/opLifecycle/remoteMessageProcessor.d.ts +26 -0
- package/lib/opLifecycle/remoteMessageProcessor.d.ts.map +1 -0
- package/lib/opLifecycle/remoteMessageProcessor.js +91 -0
- package/lib/opLifecycle/remoteMessageProcessor.js.map +1 -0
- package/lib/opProperties.d.ts.map +1 -1
- package/lib/opProperties.js +1 -3
- package/lib/opProperties.js.map +1 -1
- package/lib/orderedClientElection.d.ts.map +1 -1
- package/lib/orderedClientElection.js +10 -4
- package/lib/orderedClientElection.js.map +1 -1
- package/lib/packageVersion.d.ts +1 -1
- package/lib/packageVersion.js +1 -1
- package/lib/packageVersion.js.map +1 -1
- package/lib/pendingStateManager.d.ts +4 -13
- package/lib/pendingStateManager.d.ts.map +1 -1
- package/lib/pendingStateManager.js +134 -161
- package/lib/pendingStateManager.js.map +1 -1
- package/lib/runWhileConnectedCoordinator.d.ts.map +1 -1
- package/lib/runWhileConnectedCoordinator.js.map +1 -1
- package/lib/runningSummarizer.d.ts.map +1 -1
- package/lib/runningSummarizer.js +35 -23
- package/lib/runningSummarizer.js.map +1 -1
- package/lib/scheduleManager.d.ts +0 -1
- package/lib/scheduleManager.d.ts.map +1 -1
- package/lib/scheduleManager.js +11 -21
- package/lib/scheduleManager.js.map +1 -1
- package/lib/serializedSnapshotStorage.d.ts.map +1 -1
- package/lib/serializedSnapshotStorage.js +3 -1
- package/lib/serializedSnapshotStorage.js.map +1 -1
- package/lib/summarizer.d.ts +2 -3
- package/lib/summarizer.d.ts.map +1 -1
- package/lib/summarizer.js +39 -18
- package/lib/summarizer.js.map +1 -1
- package/lib/summarizerClientElection.d.ts +1 -2
- package/lib/summarizerClientElection.d.ts.map +1 -1
- package/lib/summarizerClientElection.js +3 -30
- package/lib/summarizerClientElection.js.map +1 -1
- package/lib/summarizerHandle.d.ts.map +1 -1
- package/lib/summarizerHandle.js.map +1 -1
- package/lib/summarizerHeuristics.d.ts.map +1 -1
- package/lib/summarizerHeuristics.js +6 -9
- package/lib/summarizerHeuristics.js.map +1 -1
- package/lib/summarizerTypes.d.ts +22 -25
- package/lib/summarizerTypes.d.ts.map +1 -1
- package/lib/summarizerTypes.js.map +1 -1
- package/lib/summaryCollection.d.ts.map +1 -1
- package/lib/summaryCollection.js +18 -8
- package/lib/summaryCollection.js.map +1 -1
- package/lib/summaryFormat.d.ts.map +1 -1
- package/lib/summaryFormat.js +20 -13
- package/lib/summaryFormat.js.map +1 -1
- package/lib/summaryGenerator.d.ts.map +1 -1
- package/lib/summaryGenerator.js +32 -14
- package/lib/summaryGenerator.js.map +1 -1
- package/lib/summaryManager.d.ts.map +1 -1
- package/lib/summaryManager.js +21 -9
- package/lib/summaryManager.js.map +1 -1
- package/lib/throttler.d.ts +2 -2
- package/lib/throttler.d.ts.map +1 -1
- package/lib/throttler.js +4 -4
- package/lib/throttler.js.map +1 -1
- package/package.json +28 -38
- package/prettier.config.cjs +1 -1
- package/src/batchTracker.ts +55 -50
- package/src/blobManager.ts +802 -541
- package/src/connectionTelemetry.ts +280 -249
- package/src/containerHandleContext.ts +27 -29
- package/src/containerRuntime.ts +3125 -2982
- package/src/dataStore.ts +172 -159
- package/src/dataStoreContext.ts +1049 -992
- package/src/dataStoreContexts.ts +178 -161
- package/src/dataStoreRegistry.ts +25 -20
- package/src/dataStores.ts +785 -711
- package/src/deltaScheduler.ts +158 -150
- package/src/garbageCollection.ts +1797 -1558
- package/src/garbageCollectionConstants.ts +38 -0
- package/src/garbageCollectionHelpers.ts +37 -0
- package/src/gcSweepReadyUsageDetection.ts +90 -84
- package/src/index.ts +68 -69
- package/src/opLifecycle/batchManager.ts +167 -0
- package/src/opLifecycle/definitions.ts +70 -0
- package/src/opLifecycle/index.ts +18 -0
- package/src/opLifecycle/opCompressor.ts +82 -0
- package/src/opLifecycle/opDecompressor.ts +124 -0
- package/src/opLifecycle/opSplitter.ts +238 -0
- package/src/opLifecycle/outbox.ts +228 -0
- package/src/opLifecycle/remoteMessageProcessor.ts +106 -0
- package/src/opProperties.ts +11 -9
- package/src/orderedClientElection.ts +489 -457
- package/src/packageVersion.ts +1 -1
- package/src/pendingStateManager.ts +379 -381
- package/src/runWhileConnectedCoordinator.ts +78 -71
- package/src/runningSummarizer.ts +619 -582
- package/src/scheduleManager.ts +299 -280
- package/src/serializedSnapshotStorage.ts +116 -111
- package/src/summarizer.ts +417 -381
- package/src/summarizerClientElection.ts +107 -129
- package/src/summarizerHandle.ts +11 -9
- package/src/summarizerHeuristics.ts +183 -186
- package/src/summarizerTypes.ts +344 -333
- package/src/summaryCollection.ts +378 -349
- package/src/summaryFormat.ts +146 -127
- package/src/summaryGenerator.ts +464 -406
- package/src/summaryManager.ts +377 -348
- package/src/throttler.ts +131 -122
- package/tsconfig.esnext.json +6 -6
- package/tsconfig.json +9 -13
- package/dist/batchManager.d.ts +0 -42
- package/dist/batchManager.d.ts.map +0 -1
- package/dist/batchManager.js +0 -83
- package/dist/batchManager.js.map +0 -1
- package/dist/opCompressor.d.ts.map +0 -1
- package/dist/opCompressor.js +0 -50
- package/dist/opCompressor.js.map +0 -1
- package/dist/opDecompressor.d.ts.map +0 -1
- package/dist/opDecompressor.js.map +0 -1
- package/lib/batchManager.d.ts +0 -42
- package/lib/batchManager.d.ts.map +0 -1
- package/lib/batchManager.js +0 -79
- package/lib/batchManager.js.map +0 -1
- package/lib/opCompressor.d.ts.map +0 -1
- package/lib/opCompressor.js +0 -46
- package/lib/opCompressor.js.map +0 -1
- package/lib/opDecompressor.d.ts.map +0 -1
- package/lib/opDecompressor.js.map +0 -1
- package/src/batchManager.ts +0 -108
- package/src/opCompressor.ts +0 -59
- package/src/opDecompressor.ts +0 -82
package/src/summaryFormat.ts
CHANGED
|
@@ -6,37 +6,44 @@
|
|
|
6
6
|
import { assert } from "@fluidframework/common-utils";
|
|
7
7
|
import { IDocumentStorageService } from "@fluidframework/driver-definitions";
|
|
8
8
|
import { readAndParse } from "@fluidframework/driver-utils";
|
|
9
|
-
import {
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
import {
|
|
10
|
+
ISequencedDocumentMessage,
|
|
11
|
+
ISnapshotTree,
|
|
12
|
+
SummaryType,
|
|
13
|
+
} from "@fluidframework/protocol-definitions";
|
|
14
|
+
import {
|
|
15
|
+
channelsTreeName,
|
|
16
|
+
gcTreeKey,
|
|
17
|
+
ISummaryTreeWithStats,
|
|
18
|
+
} from "@fluidframework/runtime-definitions";
|
|
12
19
|
|
|
13
20
|
type OmitAttributesVersions<T> = Omit<T, "snapshotFormatVersion" | "summaryFormatVersion">;
|
|
14
21
|
interface IFluidDataStoreAttributes0 {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
22
|
+
readonly snapshotFormatVersion?: undefined;
|
|
23
|
+
readonly summaryFormatVersion?: undefined;
|
|
24
|
+
pkg: string;
|
|
25
|
+
/**
|
|
26
|
+
* This tells whether a data store is root. Root data stores are never collected.
|
|
27
|
+
* Non-root data stores may be collected if they are not used. If this is not present, default it to
|
|
28
|
+
* true. This will ensure that older data stores are incorrectly collected.
|
|
29
|
+
*/
|
|
30
|
+
readonly isRootDataStore?: boolean;
|
|
24
31
|
}
|
|
25
32
|
interface IFluidDataStoreAttributes1 extends OmitAttributesVersions<IFluidDataStoreAttributes0> {
|
|
26
|
-
|
|
27
|
-
|
|
33
|
+
readonly snapshotFormatVersion: "0.1";
|
|
34
|
+
readonly summaryFormatVersion?: undefined;
|
|
28
35
|
}
|
|
29
36
|
interface IFluidDataStoreAttributes2 extends OmitAttributesVersions<IFluidDataStoreAttributes1> {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
37
|
+
/** Switch from snapshotFormatVersion to summaryFormatVersion */
|
|
38
|
+
readonly snapshotFormatVersion?: undefined;
|
|
39
|
+
readonly summaryFormatVersion: 2;
|
|
40
|
+
/**
|
|
41
|
+
* True if channels are not isolated in .channels subtrees, otherwise isolated.
|
|
42
|
+
* This is required in both datastore attributes as well as the root container,
|
|
43
|
+
* because reused summary handles may cause different format versions in each
|
|
44
|
+
* datastore subtree within the summary.
|
|
45
|
+
*/
|
|
46
|
+
readonly disableIsolatedChannels?: true;
|
|
40
47
|
}
|
|
41
48
|
/**
|
|
42
49
|
* Added IFluidDataStoreAttributes similar to IChannelAttributes which will tell the attributes of a
|
|
@@ -44,111 +51,116 @@ interface IFluidDataStoreAttributes2 extends OmitAttributesVersions<IFluidDataSt
|
|
|
44
51
|
* snapshotFormatVersion.
|
|
45
52
|
*/
|
|
46
53
|
export type ReadFluidDataStoreAttributes =
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
54
|
+
| IFluidDataStoreAttributes0
|
|
55
|
+
| IFluidDataStoreAttributes1
|
|
56
|
+
| IFluidDataStoreAttributes2;
|
|
50
57
|
export type WriteFluidDataStoreAttributes = IFluidDataStoreAttributes1 | IFluidDataStoreAttributes2;
|
|
51
58
|
|
|
52
59
|
export function getAttributesFormatVersion(attributes: ReadFluidDataStoreAttributes): number {
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
60
|
+
if (attributes.summaryFormatVersion) {
|
|
61
|
+
/**
|
|
62
|
+
* Version 2+: Introduces .channels trees for isolation of
|
|
63
|
+
* channel trees from data store objects.
|
|
64
|
+
*/
|
|
65
|
+
return attributes.summaryFormatVersion;
|
|
66
|
+
} else if (attributes.snapshotFormatVersion === "0.1") {
|
|
67
|
+
/**
|
|
68
|
+
* Version 1: from this version the pkg within the data store
|
|
69
|
+
* attributes blob is a JSON array rather than a string.
|
|
70
|
+
*/
|
|
71
|
+
return 1;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Version 0: format version is missing from summary.
|
|
75
|
+
* This indicates it is an older version.
|
|
76
|
+
*/
|
|
77
|
+
return 0;
|
|
71
78
|
}
|
|
72
79
|
|
|
73
80
|
export function hasIsolatedChannels(attributes: ReadFluidDataStoreAttributes): boolean {
|
|
74
|
-
|
|
81
|
+
return !!attributes.summaryFormatVersion && !attributes.disableIsolatedChannels;
|
|
75
82
|
}
|
|
76
83
|
export interface IContainerRuntimeMetadata extends ICreateContainerMetadata, IGCMetadata {
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
+
readonly summaryFormatVersion: 1;
|
|
85
|
+
/** The last message processed at the time of summary. Only primitive property types are added to the summary. */
|
|
86
|
+
readonly message: ISummaryMetadataMessage | undefined;
|
|
87
|
+
/** True if channels are not isolated in .channels subtrees, otherwise isolated. */
|
|
88
|
+
readonly disableIsolatedChannels?: true;
|
|
89
|
+
/** The summary number for a container's summary. Incremented on summaries throughout its lifetime. */
|
|
90
|
+
readonly summaryNumber?: number;
|
|
84
91
|
}
|
|
85
92
|
|
|
86
93
|
export interface ICreateContainerMetadata {
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
94
|
+
/** Runtime version of the container when it was first created */
|
|
95
|
+
createContainerRuntimeVersion?: string;
|
|
96
|
+
/** Timestamp of the container when it was first created */
|
|
97
|
+
createContainerTimestamp?: number;
|
|
91
98
|
}
|
|
92
99
|
|
|
93
100
|
export type GCVersion = number;
|
|
94
101
|
export interface IGCMetadata {
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
102
|
+
/**
|
|
103
|
+
* The version of the GC code that was run to generate the GC data that is written in the summary.
|
|
104
|
+
* Also, used to determine whether GC is enabled for this container or not:
|
|
105
|
+
* - A value of 0 or undefined means GC is disabled.
|
|
106
|
+
* - A value greater than 0 means GC is enabled.
|
|
107
|
+
*/
|
|
108
|
+
readonly gcFeature?: GCVersion;
|
|
109
|
+
/**
|
|
110
|
+
* Tells whether the GC sweep phase is enabled for this container.
|
|
111
|
+
* - True means sweep phase is enabled.
|
|
112
|
+
* - False means sweep phase is disabled. If GC is disabled as per gcFeature, sweep is also disabled.
|
|
113
|
+
*/
|
|
114
|
+
readonly sweepEnabled?: boolean;
|
|
115
|
+
/** If this is present, the session for this container will expire after this time and the container will close */
|
|
116
|
+
readonly sessionExpiryTimeoutMs?: number;
|
|
117
|
+
/** How long to wait after an object is unreferenced before deleting it via GC Sweep */
|
|
118
|
+
readonly sweepTimeoutMs?: number;
|
|
112
119
|
}
|
|
113
120
|
|
|
114
121
|
/** The properties of an ISequencedDocumentMessage to be stored in the metadata blob in summary. */
|
|
115
|
-
export type ISummaryMetadataMessage = Pick<
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
122
|
+
export type ISummaryMetadataMessage = Pick<
|
|
123
|
+
ISequencedDocumentMessage,
|
|
124
|
+
| "clientId"
|
|
125
|
+
| "clientSequenceNumber"
|
|
126
|
+
| "minimumSequenceNumber"
|
|
127
|
+
| "referenceSequenceNumber"
|
|
128
|
+
| "sequenceNumber"
|
|
129
|
+
| "timestamp"
|
|
130
|
+
| "type"
|
|
131
|
+
>;
|
|
123
132
|
|
|
124
133
|
/**
|
|
125
134
|
* Extracts the properties from an ISequencedDocumentMessage as defined by ISummaryMetadataMessage. This message is
|
|
126
135
|
* added to the metadata blob in summary.
|
|
127
136
|
*/
|
|
128
137
|
export const extractSummaryMetadataMessage = (
|
|
129
|
-
|
|
130
|
-
): ISummaryMetadataMessage | undefined =>
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
138
|
+
message?: ISequencedDocumentMessage,
|
|
139
|
+
): ISummaryMetadataMessage | undefined =>
|
|
140
|
+
message === undefined
|
|
141
|
+
? undefined
|
|
142
|
+
: {
|
|
143
|
+
clientId: message.clientId,
|
|
144
|
+
clientSequenceNumber: message.clientSequenceNumber,
|
|
145
|
+
minimumSequenceNumber: message.minimumSequenceNumber,
|
|
146
|
+
referenceSequenceNumber: message.referenceSequenceNumber,
|
|
147
|
+
sequenceNumber: message.sequenceNumber,
|
|
148
|
+
timestamp: message.timestamp,
|
|
149
|
+
type: message.type,
|
|
150
|
+
};
|
|
139
151
|
|
|
140
152
|
export function getMetadataFormatVersion(metadata?: IContainerRuntimeMetadata): number {
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
153
|
+
/**
|
|
154
|
+
* Version 2+: Introduces runtime sequence number for data verification.
|
|
155
|
+
*
|
|
156
|
+
* Version 1+: Introduces .metadata blob and .channels trees for isolation of
|
|
157
|
+
* data store trees from container-level objects.
|
|
158
|
+
* Also introduces enableGC option stored in the summary.
|
|
159
|
+
*
|
|
160
|
+
* Version 0: metadata blob missing; format version is missing from summary.
|
|
161
|
+
* This indicates it is an older version.
|
|
162
|
+
*/
|
|
163
|
+
return metadata?.summaryFormatVersion ?? 0;
|
|
152
164
|
}
|
|
153
165
|
|
|
154
166
|
export const aliasBlobName = ".aliases";
|
|
@@ -158,15 +170,15 @@ export const electedSummarizerBlobName = ".electedSummarizer";
|
|
|
158
170
|
export const blobsTreeName = ".blobs";
|
|
159
171
|
|
|
160
172
|
export function rootHasIsolatedChannels(metadata?: IContainerRuntimeMetadata): boolean {
|
|
161
|
-
|
|
173
|
+
return !!metadata && !metadata.disableIsolatedChannels;
|
|
162
174
|
}
|
|
163
175
|
|
|
164
176
|
export function getGCVersion(metadata?: IGCMetadata): GCVersion {
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
177
|
+
if (!metadata) {
|
|
178
|
+
// Force to 0/disallowed in prior versions
|
|
179
|
+
return 0;
|
|
180
|
+
}
|
|
181
|
+
return metadata.gcFeature ?? 0;
|
|
170
182
|
}
|
|
171
183
|
|
|
172
184
|
export const protocolTreeName = ".protocol";
|
|
@@ -177,7 +189,13 @@ export const protocolTreeName = ".protocol";
|
|
|
177
189
|
* isolated data stores namespace. Without the namespace, this must
|
|
178
190
|
* be used to prevent name collisions with data store IDs.
|
|
179
191
|
*/
|
|
180
|
-
export const nonDataStorePaths = [
|
|
192
|
+
export const nonDataStorePaths = [
|
|
193
|
+
protocolTreeName,
|
|
194
|
+
".logTail",
|
|
195
|
+
".serviceProtocol",
|
|
196
|
+
blobsTreeName,
|
|
197
|
+
gcTreeKey,
|
|
198
|
+
];
|
|
181
199
|
|
|
182
200
|
export const dataStoreAttributesBlobName = ".component";
|
|
183
201
|
|
|
@@ -211,25 +229,26 @@ export const dataStoreAttributesBlobName = ".component";
|
|
|
211
229
|
* And adds +1 to treeNodeCount in stats.
|
|
212
230
|
*/
|
|
213
231
|
export function wrapSummaryInChannelsTree(summarizeResult: ISummaryTreeWithStats): void {
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
232
|
+
summarizeResult.summary = {
|
|
233
|
+
type: SummaryType.Tree,
|
|
234
|
+
tree: { [channelsTreeName]: summarizeResult.summary },
|
|
235
|
+
};
|
|
236
|
+
summarizeResult.stats.treeNodeCount++;
|
|
219
237
|
}
|
|
220
238
|
|
|
221
239
|
export async function getFluidDataStoreAttributes(
|
|
222
|
-
|
|
223
|
-
|
|
240
|
+
storage: IDocumentStorageService,
|
|
241
|
+
snapshot: ISnapshotTree,
|
|
224
242
|
): Promise<ReadFluidDataStoreAttributes> {
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
243
|
+
const attributes = await readAndParse<ReadFluidDataStoreAttributes>(
|
|
244
|
+
storage,
|
|
245
|
+
snapshot.blobs[dataStoreAttributesBlobName],
|
|
246
|
+
);
|
|
247
|
+
// Use the snapshotFormatVersion to determine how the pkg is encoded in the snapshot.
|
|
248
|
+
// For snapshotFormatVersion = "0.1" (1) or above, pkg is jsonified, otherwise it is just a string.
|
|
249
|
+
// However the feature of loading a detached container from snapshot, is added when the
|
|
250
|
+
// snapshotFormatVersion is at least "0.1" (1), so we don't expect it to be anything else.
|
|
251
|
+
const formatVersion = getAttributesFormatVersion(attributes);
|
|
252
|
+
assert(formatVersion > 0, 0x1d5 /* Invalid snapshot format version */);
|
|
253
|
+
return attributes;
|
|
235
254
|
}
|