@fluidframework/driver-utils 1.4.0-115997 → 2.0.0-dev-rc.1.0.0.224419
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 +17 -7
- package/.mocharc.js +12 -0
- package/CHANGELOG.md +141 -0
- package/README.md +68 -1
- package/api-extractor-lint.json +4 -0
- package/api-extractor.json +2 -2
- package/api-report/driver-utils.api.md +401 -0
- package/dist/adapters/compression/compressionTypes.cjs +20 -0
- package/dist/adapters/compression/compressionTypes.cjs.map +1 -0
- package/dist/adapters/compression/compressionTypes.d.ts +23 -0
- package/dist/adapters/compression/compressionTypes.d.ts.map +1 -0
- package/dist/adapters/compression/documentServiceCompressionAdapter.cjs +23 -0
- package/dist/adapters/compression/documentServiceCompressionAdapter.cjs.map +1 -0
- package/dist/adapters/compression/documentServiceCompressionAdapter.d.ts +13 -0
- package/dist/adapters/compression/documentServiceCompressionAdapter.d.ts.map +1 -0
- package/dist/adapters/compression/documentServiceFactoryCompressionAdapter.cjs +31 -0
- package/dist/adapters/compression/documentServiceFactoryCompressionAdapter.cjs.map +1 -0
- package/dist/adapters/compression/documentServiceFactoryCompressionAdapter.d.ts +16 -0
- package/dist/adapters/compression/documentServiceFactoryCompressionAdapter.d.ts.map +1 -0
- package/dist/adapters/compression/index.cjs +15 -0
- package/dist/adapters/compression/index.cjs.map +1 -0
- package/dist/adapters/compression/index.d.ts +8 -0
- package/dist/adapters/compression/index.d.ts.map +1 -0
- package/dist/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.cjs +370 -0
- package/dist/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.cjs.map +1 -0
- package/dist/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.d.ts +165 -0
- package/dist/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.d.ts.map +1 -0
- package/dist/adapters/compression/summaryblob/index.cjs +11 -0
- package/dist/adapters/compression/summaryblob/index.cjs.map +1 -0
- package/dist/adapters/compression/summaryblob/index.d.ts +6 -0
- package/dist/adapters/compression/summaryblob/index.d.ts.map +1 -0
- package/dist/adapters/index.cjs +14 -0
- package/dist/adapters/index.cjs.map +1 -0
- package/dist/adapters/index.d.ts +7 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/predefinedAdapters.cjs +52 -0
- package/dist/adapters/predefinedAdapters.cjs.map +1 -0
- package/dist/adapters/predefinedAdapters.d.ts +21 -0
- package/dist/adapters/predefinedAdapters.d.ts.map +1 -0
- package/dist/blob.cjs +65 -0
- package/dist/blob.cjs.map +1 -0
- package/dist/blob.d.ts +56 -0
- package/dist/blob.d.ts.map +1 -0
- package/dist/{buildSnapshotTree.js → buildSnapshotTree.cjs} +7 -5
- package/dist/buildSnapshotTree.cjs.map +1 -0
- package/dist/buildSnapshotTree.d.ts +1 -0
- package/dist/buildSnapshotTree.d.ts.map +1 -1
- package/dist/documentServiceFactoryProxy.cjs +27 -0
- package/dist/documentServiceFactoryProxy.cjs.map +1 -0
- package/dist/documentServiceFactoryProxy.d.ts +19 -0
- package/dist/documentServiceFactoryProxy.d.ts.map +1 -0
- package/dist/documentServiceProxy.cjs +36 -0
- package/dist/documentServiceProxy.cjs.map +1 -0
- package/dist/documentServiceProxy.d.ts +21 -0
- package/dist/documentServiceProxy.d.ts.map +1 -0
- package/dist/{documentStorageServiceProxy.js → documentStorageServiceProxy.cjs} +10 -8
- package/dist/documentStorageServiceProxy.cjs.map +1 -0
- package/dist/documentStorageServiceProxy.d.ts +5 -2
- package/dist/documentStorageServiceProxy.d.ts.map +1 -1
- package/dist/driver-utils-alpha.d.ts +163 -0
- package/dist/driver-utils-beta.d.ts +178 -0
- package/dist/driver-utils-public.d.ts +178 -0
- package/dist/driver-utils-untrimmed.d.ts +590 -0
- package/dist/{error.js → error.cjs} +10 -3
- package/dist/error.cjs.map +1 -0
- package/dist/error.d.ts +8 -3
- package/dist/error.d.ts.map +1 -1
- package/dist/index.cjs +69 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +16 -21
- package/dist/index.d.ts.map +1 -1
- package/dist/{insecureUrlResolver.js → insecureUrlResolver.cjs} +10 -11
- package/dist/insecureUrlResolver.cjs.map +1 -0
- package/dist/insecureUrlResolver.d.ts +1 -0
- package/dist/insecureUrlResolver.d.ts.map +1 -1
- package/dist/messageRecognition.cjs +38 -0
- package/dist/messageRecognition.cjs.map +1 -0
- package/dist/messageRecognition.d.ts +16 -26
- package/dist/messageRecognition.d.ts.map +1 -1
- package/dist/{network.js → network.cjs} +86 -24
- package/dist/network.cjs.map +1 -0
- package/dist/network.d.ts +69 -20
- package/dist/network.d.ts.map +1 -1
- package/dist/networkUtils.cjs +29 -0
- package/dist/networkUtils.cjs.map +1 -0
- package/dist/networkUtils.d.ts +4 -10
- package/dist/networkUtils.d.ts.map +1 -1
- package/dist/{packageVersion.js → packageVersion.cjs} +2 -2
- package/dist/packageVersion.cjs.map +1 -0
- package/dist/packageVersion.d.ts +1 -1
- package/dist/packageVersion.d.ts.map +1 -1
- package/dist/{parallelRequests.js → parallelRequests.cjs} +146 -74
- package/dist/parallelRequests.cjs.map +1 -0
- package/dist/parallelRequests.d.ts +19 -6
- package/dist/parallelRequests.d.ts.map +1 -1
- package/dist/{prefetchDocumentStorageService.js → prefetchDocumentStorageService.cjs} +7 -4
- package/dist/prefetchDocumentStorageService.cjs.map +1 -0
- package/dist/prefetchDocumentStorageService.d.ts +4 -2
- package/dist/prefetchDocumentStorageService.d.ts.map +1 -1
- package/dist/{rateLimiter.js → rateLimiter.cjs} +6 -3
- package/dist/rateLimiter.cjs.map +1 -0
- package/dist/rateLimiter.d.ts +3 -0
- package/dist/rateLimiter.d.ts.map +1 -1
- package/dist/readAndParse.cjs +28 -0
- package/dist/readAndParse.cjs.map +1 -0
- package/dist/readAndParse.d.ts +10 -4
- package/dist/readAndParse.d.ts.map +1 -1
- package/dist/runWithRetry.cjs +108 -0
- package/dist/runWithRetry.cjs.map +1 -0
- package/dist/runWithRetry.d.ts +26 -7
- package/dist/runWithRetry.d.ts.map +1 -1
- package/dist/{summaryForCreateNew.js → summaryForCreateNew.cjs} +20 -19
- package/dist/summaryForCreateNew.cjs.map +1 -0
- package/dist/summaryForCreateNew.d.ts +17 -4
- package/dist/summaryForCreateNew.d.ts.map +1 -1
- package/dist/{treeConversions.js → treeConversions.cjs} +16 -18
- package/dist/treeConversions.cjs.map +1 -0
- package/dist/treeConversions.d.ts +1 -0
- package/dist/treeConversions.d.ts.map +1 -1
- package/dist/tsdoc-metadata.json +11 -0
- package/lib/adapters/compression/compressionTypes.d.mts +23 -0
- package/lib/adapters/compression/compressionTypes.d.mts.map +1 -0
- package/lib/adapters/compression/compressionTypes.mjs +17 -0
- package/lib/adapters/compression/compressionTypes.mjs.map +1 -0
- package/lib/adapters/compression/documentServiceCompressionAdapter.d.mts +13 -0
- package/lib/adapters/compression/documentServiceCompressionAdapter.d.mts.map +1 -0
- package/lib/adapters/compression/documentServiceCompressionAdapter.mjs +19 -0
- package/lib/adapters/compression/documentServiceCompressionAdapter.mjs.map +1 -0
- package/lib/adapters/compression/documentServiceFactoryCompressionAdapter.d.mts +16 -0
- package/lib/adapters/compression/documentServiceFactoryCompressionAdapter.d.mts.map +1 -0
- package/lib/adapters/compression/documentServiceFactoryCompressionAdapter.mjs +27 -0
- package/lib/adapters/compression/documentServiceFactoryCompressionAdapter.mjs.map +1 -0
- package/lib/adapters/compression/index.d.mts +8 -0
- package/lib/adapters/compression/index.d.mts.map +1 -0
- package/lib/adapters/compression/index.mjs +8 -0
- package/lib/adapters/compression/index.mjs.map +1 -0
- package/lib/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.d.mts +165 -0
- package/lib/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.d.mts.map +1 -0
- package/lib/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.mjs +366 -0
- package/lib/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.mjs.map +1 -0
- package/lib/adapters/compression/summaryblob/index.d.mts +6 -0
- package/lib/adapters/compression/summaryblob/index.d.mts.map +1 -0
- package/lib/adapters/compression/summaryblob/index.mjs +6 -0
- package/lib/adapters/compression/summaryblob/index.mjs.map +1 -0
- package/lib/adapters/index.d.mts +7 -0
- package/lib/adapters/index.d.mts.map +1 -0
- package/lib/adapters/index.mjs +7 -0
- package/lib/adapters/index.mjs.map +1 -0
- package/lib/adapters/predefinedAdapters.d.mts +21 -0
- package/lib/adapters/predefinedAdapters.d.mts.map +1 -0
- package/lib/adapters/predefinedAdapters.mjs +47 -0
- package/lib/adapters/predefinedAdapters.mjs.map +1 -0
- package/lib/blob.d.mts +56 -0
- package/lib/blob.d.mts.map +1 -0
- package/lib/blob.mjs +59 -0
- package/lib/blob.mjs.map +1 -0
- package/lib/{buildSnapshotTree.d.ts → buildSnapshotTree.d.mts} +1 -0
- package/lib/buildSnapshotTree.d.mts.map +1 -0
- package/lib/{buildSnapshotTree.js → buildSnapshotTree.mjs} +6 -4
- package/lib/buildSnapshotTree.mjs.map +1 -0
- package/lib/documentServiceFactoryProxy.d.mts +19 -0
- package/lib/documentServiceFactoryProxy.d.mts.map +1 -0
- package/lib/documentServiceFactoryProxy.mjs +23 -0
- package/lib/documentServiceFactoryProxy.mjs.map +1 -0
- package/lib/documentServiceProxy.d.mts +21 -0
- package/lib/documentServiceProxy.d.mts.map +1 -0
- package/lib/documentServiceProxy.mjs +32 -0
- package/lib/documentServiceProxy.mjs.map +1 -0
- package/lib/{documentStorageServiceProxy.d.ts → documentStorageServiceProxy.d.mts} +5 -2
- package/lib/documentStorageServiceProxy.d.mts.map +1 -0
- package/lib/{documentStorageServiceProxy.js → documentStorageServiceProxy.mjs} +10 -8
- package/lib/documentStorageServiceProxy.mjs.map +1 -0
- package/lib/driver-utils-alpha.d.mts +163 -0
- package/lib/driver-utils-beta.d.mts +178 -0
- package/lib/driver-utils-public.d.mts +178 -0
- package/lib/driver-utils-untrimmed.d.mts +590 -0
- package/lib/error.d.mts +16 -0
- package/lib/error.d.mts.map +1 -0
- package/lib/error.mjs +19 -0
- package/lib/error.mjs.map +1 -0
- package/lib/index.d.mts +21 -0
- package/lib/index.d.mts.map +1 -0
- package/lib/index.mjs +21 -0
- package/lib/index.mjs.map +1 -0
- package/lib/{insecureUrlResolver.d.ts → insecureUrlResolver.d.mts} +1 -0
- package/lib/insecureUrlResolver.d.mts.map +1 -0
- package/lib/{insecureUrlResolver.js → insecureUrlResolver.mjs} +10 -11
- package/lib/insecureUrlResolver.mjs.map +1 -0
- package/lib/messageRecognition.d.mts +24 -0
- package/lib/messageRecognition.d.mts.map +1 -0
- package/lib/messageRecognition.mjs +29 -0
- package/lib/messageRecognition.mjs.map +1 -0
- package/lib/{network.d.ts → network.d.mts} +69 -20
- package/lib/network.d.mts.map +1 -0
- package/lib/{network.js → network.mjs} +85 -23
- package/lib/network.mjs.map +1 -0
- package/lib/networkUtils.d.mts +11 -0
- package/lib/networkUtils.d.mts.map +1 -0
- package/lib/networkUtils.mjs +25 -0
- package/lib/networkUtils.mjs.map +1 -0
- package/lib/{packageVersion.d.ts → packageVersion.d.mts} +1 -1
- package/lib/{packageVersion.d.ts.map → packageVersion.d.mts.map} +1 -1
- package/lib/{packageVersion.js → packageVersion.mjs} +2 -2
- package/lib/packageVersion.mjs.map +1 -0
- package/lib/{parallelRequests.d.ts → parallelRequests.d.mts} +19 -6
- package/lib/parallelRequests.d.mts.map +1 -0
- package/lib/{parallelRequests.js → parallelRequests.mjs} +119 -52
- package/lib/parallelRequests.mjs.map +1 -0
- package/lib/{prefetchDocumentStorageService.d.ts → prefetchDocumentStorageService.d.mts} +5 -7
- package/lib/prefetchDocumentStorageService.d.mts.map +1 -0
- package/lib/{prefetchDocumentStorageService.js → prefetchDocumentStorageService.mjs} +7 -8
- package/lib/prefetchDocumentStorageService.mjs.map +1 -0
- package/lib/{rateLimiter.d.ts → rateLimiter.d.mts} +3 -0
- package/lib/rateLimiter.d.mts.map +1 -0
- package/lib/{rateLimiter.js → rateLimiter.mjs} +5 -2
- package/lib/rateLimiter.mjs.map +1 -0
- package/lib/readAndParse.d.mts +20 -0
- package/lib/readAndParse.d.mts.map +1 -0
- package/lib/readAndParse.mjs +24 -0
- package/lib/readAndParse.mjs.map +1 -0
- package/lib/{runWithRetry.d.ts → runWithRetry.d.mts} +26 -7
- package/lib/runWithRetry.d.mts.map +1 -0
- package/lib/runWithRetry.mjs +103 -0
- package/lib/runWithRetry.mjs.map +1 -0
- package/lib/{summaryForCreateNew.d.ts → summaryForCreateNew.d.mts} +17 -4
- package/lib/summaryForCreateNew.d.mts.map +1 -0
- package/lib/{summaryForCreateNew.js → summaryForCreateNew.mjs} +18 -17
- package/lib/summaryForCreateNew.mjs.map +1 -0
- package/lib/{treeConversions.d.ts → treeConversions.d.mts} +1 -0
- package/lib/treeConversions.d.mts.map +1 -0
- package/lib/{treeConversions.js → treeConversions.mjs} +12 -14
- package/lib/treeConversions.mjs.map +1 -0
- package/package.json +88 -64
- package/prettier.config.cjs +8 -0
- package/src/adapters/compression/compressionTypes.ts +25 -0
- package/src/adapters/compression/documentServiceCompressionAdapter.ts +28 -0
- package/src/adapters/compression/documentServiceFactoryCompressionAdapter.ts +54 -0
- package/src/adapters/compression/index.ts +12 -0
- package/src/adapters/compression/summaryblob/documentStorageServiceSummaryBlobCompressionAdapter.ts +451 -0
- package/src/adapters/compression/summaryblob/index.ts +9 -0
- package/src/adapters/index.ts +13 -0
- package/src/adapters/predefinedAdapters.ts +74 -0
- package/src/blob.ts +77 -0
- package/src/buildSnapshotTree.ts +58 -53
- package/src/documentServiceFactoryProxy.ts +47 -0
- package/src/documentServiceProxy.ts +46 -0
- package/src/documentStorageServiceProxy.ts +52 -37
- package/src/error.ts +13 -8
- package/src/index.ts +51 -21
- package/src/insecureUrlResolver.ts +125 -120
- package/src/messageRecognition.ts +24 -53
- package/src/network.ts +189 -111
- package/src/networkUtils.ts +24 -49
- package/src/packageVersion.ts +1 -1
- package/src/parallelRequests.ts +630 -519
- package/src/prefetchDocumentStorageService.ts +79 -74
- package/src/rateLimiter.ts +33 -30
- package/src/readAndParse.ts +18 -9
- package/src/runWithRetry.ts +145 -85
- package/src/summaryForCreateNew.ts +48 -29
- package/src/treeConversions.ts +49 -70
- package/tsc-multi.test.json +4 -0
- package/tsconfig.json +10 -12
- package/dist/blobAggregationStorage.d.ts +0 -43
- package/dist/blobAggregationStorage.d.ts.map +0 -1
- package/dist/blobAggregationStorage.js +0 -318
- package/dist/blobAggregationStorage.js.map +0 -1
- package/dist/blobCacheStorageService.d.ts +0 -16
- package/dist/blobCacheStorageService.d.ts.map +0 -1
- package/dist/blobCacheStorageService.js +0 -29
- package/dist/blobCacheStorageService.js.map +0 -1
- package/dist/buildSnapshotTree.js.map +0 -1
- package/dist/documentStorageServiceProxy.js.map +0 -1
- package/dist/emptyDocumentDeltaStorageService.d.ts +0 -13
- package/dist/emptyDocumentDeltaStorageService.d.ts.map +0 -1
- package/dist/emptyDocumentDeltaStorageService.js +0 -20
- package/dist/emptyDocumentDeltaStorageService.js.map +0 -1
- package/dist/error.js.map +0 -1
- package/dist/fluidResolvedUrl.d.ts +0 -8
- package/dist/fluidResolvedUrl.d.ts.map +0 -1
- package/dist/fluidResolvedUrl.js +0 -16
- package/dist/fluidResolvedUrl.js.map +0 -1
- package/dist/index.js +0 -38
- package/dist/index.js.map +0 -1
- package/dist/insecureUrlResolver.js.map +0 -1
- package/dist/messageRecognition.js +0 -73
- package/dist/messageRecognition.js.map +0 -1
- package/dist/multiDocumentServiceFactory.d.ts +0 -16
- package/dist/multiDocumentServiceFactory.d.ts.map +0 -1
- package/dist/multiDocumentServiceFactory.js +0 -63
- package/dist/multiDocumentServiceFactory.js.map +0 -1
- package/dist/multiUrlResolver.d.ts +0 -20
- package/dist/multiUrlResolver.d.ts.map +0 -1
- package/dist/multiUrlResolver.js +0 -45
- package/dist/multiUrlResolver.js.map +0 -1
- package/dist/network.js.map +0 -1
- package/dist/networkUtils.js +0 -59
- package/dist/networkUtils.js.map +0 -1
- package/dist/packageVersion.js.map +0 -1
- package/dist/parallelRequests.js.map +0 -1
- package/dist/prefetchDocumentStorageService.js.map +0 -1
- package/dist/rateLimiter.js.map +0 -1
- package/dist/readAndParse.js +0 -22
- package/dist/readAndParse.js.map +0 -1
- package/dist/runWithRetry.js +0 -69
- package/dist/runWithRetry.js.map +0 -1
- package/dist/summaryForCreateNew.js.map +0 -1
- package/dist/treeConversions.js.map +0 -1
- package/dist/treeUtils.d.ts +0 -51
- package/dist/treeUtils.d.ts.map +0 -1
- package/dist/treeUtils.js +0 -85
- package/dist/treeUtils.js.map +0 -1
- package/lib/blobAggregationStorage.d.ts +0 -43
- package/lib/blobAggregationStorage.d.ts.map +0 -1
- package/lib/blobAggregationStorage.js +0 -313
- package/lib/blobAggregationStorage.js.map +0 -1
- package/lib/blobCacheStorageService.d.ts +0 -16
- package/lib/blobCacheStorageService.d.ts.map +0 -1
- package/lib/blobCacheStorageService.js +0 -25
- package/lib/blobCacheStorageService.js.map +0 -1
- package/lib/buildSnapshotTree.d.ts.map +0 -1
- package/lib/buildSnapshotTree.js.map +0 -1
- package/lib/documentStorageServiceProxy.d.ts.map +0 -1
- package/lib/documentStorageServiceProxy.js.map +0 -1
- package/lib/emptyDocumentDeltaStorageService.d.ts +0 -13
- package/lib/emptyDocumentDeltaStorageService.d.ts.map +0 -1
- package/lib/emptyDocumentDeltaStorageService.js +0 -16
- package/lib/emptyDocumentDeltaStorageService.js.map +0 -1
- package/lib/error.d.ts +0 -11
- package/lib/error.d.ts.map +0 -1
- package/lib/error.js +0 -13
- package/lib/error.js.map +0 -1
- package/lib/fluidResolvedUrl.d.ts +0 -8
- package/lib/fluidResolvedUrl.d.ts.map +0 -1
- package/lib/fluidResolvedUrl.js +0 -11
- package/lib/fluidResolvedUrl.js.map +0 -1
- package/lib/index.d.ts +0 -26
- package/lib/index.d.ts.map +0 -1
- package/lib/index.js +0 -26
- package/lib/index.js.map +0 -1
- package/lib/insecureUrlResolver.d.ts.map +0 -1
- package/lib/insecureUrlResolver.js.map +0 -1
- package/lib/messageRecognition.d.ts +0 -38
- package/lib/messageRecognition.d.ts.map +0 -1
- package/lib/messageRecognition.js +0 -67
- package/lib/messageRecognition.js.map +0 -1
- package/lib/multiDocumentServiceFactory.d.ts +0 -16
- package/lib/multiDocumentServiceFactory.d.ts.map +0 -1
- package/lib/multiDocumentServiceFactory.js +0 -59
- package/lib/multiDocumentServiceFactory.js.map +0 -1
- package/lib/multiUrlResolver.d.ts +0 -20
- package/lib/multiUrlResolver.d.ts.map +0 -1
- package/lib/multiUrlResolver.js +0 -40
- package/lib/multiUrlResolver.js.map +0 -1
- package/lib/network.d.ts.map +0 -1
- package/lib/network.js.map +0 -1
- package/lib/networkUtils.d.ts +0 -17
- package/lib/networkUtils.d.ts.map +0 -1
- package/lib/networkUtils.js +0 -54
- package/lib/networkUtils.js.map +0 -1
- package/lib/packageVersion.js.map +0 -1
- package/lib/parallelRequests.d.ts.map +0 -1
- package/lib/parallelRequests.js.map +0 -1
- package/lib/prefetchDocumentStorageService.d.ts.map +0 -1
- package/lib/prefetchDocumentStorageService.js.map +0 -1
- package/lib/rateLimiter.d.ts.map +0 -1
- package/lib/rateLimiter.js.map +0 -1
- package/lib/readAndParse.d.ts +0 -14
- package/lib/readAndParse.d.ts.map +0 -1
- package/lib/readAndParse.js +0 -18
- package/lib/readAndParse.js.map +0 -1
- package/lib/runWithRetry.d.ts.map +0 -1
- package/lib/runWithRetry.js +0 -65
- package/lib/runWithRetry.js.map +0 -1
- package/lib/summaryForCreateNew.d.ts.map +0 -1
- package/lib/summaryForCreateNew.js.map +0 -1
- package/lib/treeConversions.d.ts.map +0 -1
- package/lib/treeConversions.js.map +0 -1
- package/lib/treeUtils.d.ts +0 -51
- package/lib/treeUtils.d.ts.map +0 -1
- package/lib/treeUtils.js +0 -80
- package/lib/treeUtils.js.map +0 -1
- package/src/blobAggregationStorage.ts +0 -374
- package/src/blobCacheStorageService.ts +0 -32
- package/src/emptyDocumentDeltaStorageService.ts +0 -24
- package/src/fluidResolvedUrl.ts +0 -15
- package/src/multiDocumentServiceFactory.ts +0 -80
- package/src/multiUrlResolver.ts +0 -51
- package/src/treeUtils.ts +0 -111
- package/tsconfig.esnext.json +0 -7
|
@@ -3,90 +3,95 @@
|
|
|
3
3
|
* Licensed under the MIT License.
|
|
4
4
|
*/
|
|
5
5
|
import { LoaderCachingPolicy } from "@fluidframework/driver-definitions";
|
|
6
|
-
import {
|
|
7
|
-
ISnapshotTree,
|
|
8
|
-
IVersion,
|
|
9
|
-
} from "@fluidframework/protocol-definitions";
|
|
6
|
+
import { ISnapshotTree, IVersion } from "@fluidframework/protocol-definitions";
|
|
10
7
|
import { DocumentStorageServiceProxy } from "./documentStorageServiceProxy";
|
|
11
8
|
import { canRetryOnError } from "./network";
|
|
12
9
|
|
|
10
|
+
/**
|
|
11
|
+
* @internal
|
|
12
|
+
*/
|
|
13
13
|
export class PrefetchDocumentStorageService extends DocumentStorageServiceProxy {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
14
|
+
// BlobId -> blob prefetchCache cache
|
|
15
|
+
private readonly prefetchCache = new Map<string, Promise<ArrayBufferLike>>();
|
|
16
|
+
private prefetchEnabled = true;
|
|
17
17
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
18
|
+
public get policies() {
|
|
19
|
+
const policies = this.internalStorageService.policies;
|
|
20
|
+
if (policies) {
|
|
21
|
+
return { ...policies, caching: LoaderCachingPolicy.NoCaching };
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
24
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
25
|
+
public async getSnapshotTree(version?: IVersion): Promise<ISnapshotTree | null> {
|
|
26
|
+
const p = this.internalStorageService.getSnapshotTree(version);
|
|
27
|
+
if (this.prefetchEnabled) {
|
|
28
|
+
// We don't care if the prefetch succeeds
|
|
29
|
+
void p.then((tree: ISnapshotTree | null | undefined) => {
|
|
30
|
+
if (tree === null || tree === undefined) {
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
this.prefetchTree(tree);
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
return p;
|
|
37
|
+
}
|
|
36
38
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
39
|
+
public async readBlob(blobId: string): Promise<ArrayBufferLike> {
|
|
40
|
+
return this.cachedRead(blobId);
|
|
41
|
+
}
|
|
42
|
+
public stopPrefetch() {
|
|
43
|
+
this.prefetchEnabled = false;
|
|
44
|
+
this.prefetchCache.clear();
|
|
45
|
+
}
|
|
44
46
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
47
|
+
private async cachedRead(blobId: string): Promise<ArrayBufferLike> {
|
|
48
|
+
if (this.prefetchEnabled) {
|
|
49
|
+
const prefetchedBlobP = this.prefetchCache.get(blobId);
|
|
50
|
+
if (prefetchedBlobP !== undefined) {
|
|
51
|
+
return prefetchedBlobP;
|
|
52
|
+
}
|
|
53
|
+
const prefetchedBlobPFromStorage = this.internalStorageService.readBlob(blobId);
|
|
54
|
+
this.prefetchCache.set(
|
|
55
|
+
blobId,
|
|
56
|
+
prefetchedBlobPFromStorage.catch((error) => {
|
|
57
|
+
if (canRetryOnError(error)) {
|
|
58
|
+
this.prefetchCache.delete(blobId);
|
|
59
|
+
}
|
|
60
|
+
throw error;
|
|
61
|
+
}),
|
|
62
|
+
);
|
|
63
|
+
return prefetchedBlobPFromStorage;
|
|
64
|
+
}
|
|
65
|
+
return this.internalStorageService.readBlob(blobId);
|
|
66
|
+
}
|
|
62
67
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
68
|
+
private prefetchTree(tree: ISnapshotTree) {
|
|
69
|
+
const secondary: string[] = [];
|
|
70
|
+
this.prefetchTreeCore(tree, secondary);
|
|
66
71
|
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
+
for (const blob of secondary) {
|
|
73
|
+
// We don't care if the prefetch succeeds
|
|
74
|
+
void this.cachedRead(blob);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
72
77
|
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
78
|
+
private prefetchTreeCore(tree: ISnapshotTree, secondary: string[]) {
|
|
79
|
+
for (const blobKey of Object.keys(tree.blobs)) {
|
|
80
|
+
const blob = tree.blobs[blobKey];
|
|
81
|
+
if (blobKey.startsWith(".") || blobKey === "header" || blobKey.startsWith("quorum")) {
|
|
82
|
+
if (blob !== null) {
|
|
83
|
+
// We don't care if the prefetch succeeds
|
|
84
|
+
void this.cachedRead(blob);
|
|
85
|
+
}
|
|
86
|
+
} else if (!blobKey.startsWith("deltas")) {
|
|
87
|
+
if (blob !== null) {
|
|
88
|
+
secondary.push(blob);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
87
92
|
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
93
|
+
for (const subTree of Object.keys(tree.trees)) {
|
|
94
|
+
this.prefetchTreeCore(tree.trees[subTree], secondary);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
92
97
|
}
|
package/src/rateLimiter.ts
CHANGED
|
@@ -3,41 +3,44 @@
|
|
|
3
3
|
* Licensed under the MIT License.
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import { assert } from "@fluidframework/
|
|
6
|
+
import { assert } from "@fluidframework/core-utils";
|
|
7
7
|
|
|
8
|
+
/**
|
|
9
|
+
* @alpha
|
|
10
|
+
*/
|
|
8
11
|
export class RateLimiter {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
12
|
+
private readonly tasks: (() => void)[] = [];
|
|
13
|
+
constructor(private maxRequests: number) {
|
|
14
|
+
assert(maxRequests > 0, 0x0ae /* "Tried to create rate limiter with 0 max requests!" */);
|
|
15
|
+
}
|
|
13
16
|
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
+
public get waitQueueLength(): number {
|
|
18
|
+
return this.tasks.length;
|
|
19
|
+
}
|
|
17
20
|
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
21
|
+
// Run when one of the tasks finished running.
|
|
22
|
+
// Release next task if we have one, or allow more tasks to run in future.
|
|
23
|
+
protected readonly release = () => {
|
|
24
|
+
const task = this.tasks.shift();
|
|
25
|
+
if (task !== undefined) {
|
|
26
|
+
return task();
|
|
27
|
+
}
|
|
28
|
+
this.maxRequests++;
|
|
29
|
+
};
|
|
27
30
|
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
31
|
+
protected async acquire() {
|
|
32
|
+
if (this.maxRequests > 0) {
|
|
33
|
+
this.maxRequests--;
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
33
36
|
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
37
|
+
return new Promise<void>((resolve) => {
|
|
38
|
+
this.tasks.push(resolve);
|
|
39
|
+
});
|
|
40
|
+
}
|
|
38
41
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
42
|
+
public async schedule<T>(work: () => Promise<T>) {
|
|
43
|
+
await this.acquire();
|
|
44
|
+
return work().finally(this.release);
|
|
45
|
+
}
|
|
43
46
|
}
|
package/src/readAndParse.ts
CHANGED
|
@@ -3,18 +3,27 @@
|
|
|
3
3
|
* Licensed under the MIT License.
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import { bufferToString } from "@
|
|
6
|
+
import { bufferToString } from "@fluid-internal/client-utils";
|
|
7
7
|
import { IDocumentStorageService } from "@fluidframework/driver-definitions";
|
|
8
8
|
|
|
9
9
|
/**
|
|
10
|
-
* Read a blob from IDocumentStorageService and
|
|
10
|
+
* Read a blob from {@link @fluidframework/driver-definitions#IDocumentStorageService} and
|
|
11
|
+
* {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse | JSON.parse}
|
|
12
|
+
* it into object of type `T`.
|
|
11
13
|
*
|
|
12
|
-
* @param storage -
|
|
13
|
-
* @param id -
|
|
14
|
-
*
|
|
14
|
+
* @param storage - The `DocumentStorageService` to read from.
|
|
15
|
+
* @param id - The ID of the blob to read and parse.
|
|
16
|
+
*
|
|
17
|
+
* @typeParam T - Output type matching JSON format of inpyt blob data.
|
|
18
|
+
*
|
|
19
|
+
* @returns The object that we decoded and parsed via `JSON.parse`.
|
|
20
|
+
* @internal
|
|
15
21
|
*/
|
|
16
|
-
export async function readAndParse<T>(
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
22
|
+
export async function readAndParse<T>(
|
|
23
|
+
storage: Pick<IDocumentStorageService, "readBlob">,
|
|
24
|
+
id: string,
|
|
25
|
+
): Promise<T> {
|
|
26
|
+
const blob = await storage.readBlob(id);
|
|
27
|
+
const decoded = bufferToString(blob, "utf8");
|
|
28
|
+
return JSON.parse(decoded) as T;
|
|
20
29
|
}
|
package/src/runWithRetry.ts
CHANGED
|
@@ -3,103 +3,163 @@
|
|
|
3
3
|
* Licensed under the MIT License.
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
6
|
+
import { ITelemetryLoggerExt, isFluidError } from "@fluidframework/telemetry-utils";
|
|
7
|
+
import { performance } from "@fluid-internal/client-utils";
|
|
8
|
+
import { delay } from "@fluidframework/core-utils";
|
|
9
|
+
import { DriverErrorTypes } from "@fluidframework/driver-definitions";
|
|
10
|
+
import { canRetryOnError, getRetryDelayFromError, NonRetryableError } from "./network";
|
|
10
11
|
import { pkgVersion } from "./packageVersion";
|
|
11
|
-
import { NonRetryableError } from ".";
|
|
12
12
|
|
|
13
13
|
/**
|
|
14
14
|
* Interface describing an object passed to various network APIs.
|
|
15
15
|
* It allows caller to control cancellation, as well as learn about any delays.
|
|
16
|
+
* @internal
|
|
16
17
|
*/
|
|
17
18
|
export interface IProgress {
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
19
|
+
/**
|
|
20
|
+
* Abort signal used to cancel operation.
|
|
21
|
+
*
|
|
22
|
+
* @remarks Note that most of the layers do not use this signal yet. We need to change that over time.
|
|
23
|
+
* Please consult with API documentation / implementation.
|
|
24
|
+
* Note that number of layers may not check this signal while holding this request in a queue,
|
|
25
|
+
* so it may take a while it takes effect. This can be improved in the future.
|
|
26
|
+
*
|
|
27
|
+
* The layers in question are:
|
|
28
|
+
*
|
|
29
|
+
* - driver (RateLimiter)
|
|
30
|
+
*
|
|
31
|
+
* - runWithRetry
|
|
32
|
+
*/
|
|
33
|
+
cancel?: AbortSignal;
|
|
29
34
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
35
|
+
/**
|
|
36
|
+
* Called whenever api returns cancellable error and the call is going to be retried.
|
|
37
|
+
* Any exception thrown from this call back result in cancellation of operation
|
|
38
|
+
* and propagation of thrown exception.
|
|
39
|
+
* @param delayInMs - delay before next retry. This value will depend on internal back-off logic,
|
|
40
|
+
* as well as information provided by service (like 429 error asking to wait for some time before retry)
|
|
41
|
+
* @param error - error object returned from the call.
|
|
42
|
+
*/
|
|
43
|
+
onRetry?(delayInMs: number, error: any): void;
|
|
39
44
|
}
|
|
40
45
|
|
|
46
|
+
/**
|
|
47
|
+
* @internal
|
|
48
|
+
*/
|
|
41
49
|
export async function runWithRetry<T>(
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
50
|
+
api: (cancel?: AbortSignal) => Promise<T>,
|
|
51
|
+
fetchCallName: string,
|
|
52
|
+
logger: ITelemetryLoggerExt,
|
|
53
|
+
progress: IProgress,
|
|
46
54
|
): Promise<T> {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
55
|
+
let result: T | undefined;
|
|
56
|
+
let success = false;
|
|
57
|
+
// We double this value in first try in when we calculate time to wait for in "calculateMaxWaitTime" function.
|
|
58
|
+
let retryAfterMs = 500; // has to be positive!
|
|
59
|
+
let numRetries = 0;
|
|
60
|
+
const startTime = performance.now();
|
|
61
|
+
let lastError: any;
|
|
62
|
+
do {
|
|
63
|
+
try {
|
|
64
|
+
result = await api(progress.cancel);
|
|
65
|
+
success = true;
|
|
66
|
+
} catch (err) {
|
|
67
|
+
// If it is not retriable, then just throw the error.
|
|
68
|
+
if (!canRetryOnError(err)) {
|
|
69
|
+
logger.sendTelemetryEvent(
|
|
70
|
+
{
|
|
71
|
+
eventName: `${fetchCallName}_cancel`,
|
|
72
|
+
retry: numRetries,
|
|
73
|
+
duration: performance.now() - startTime,
|
|
74
|
+
fetchCallName,
|
|
75
|
+
},
|
|
76
|
+
err,
|
|
77
|
+
);
|
|
78
|
+
throw err;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
if (progress.cancel?.aborted === true) {
|
|
82
|
+
logger.sendTelemetryEvent(
|
|
83
|
+
{
|
|
84
|
+
eventName: `${fetchCallName}_runWithRetryAborted`,
|
|
85
|
+
retry: numRetries,
|
|
86
|
+
duration: performance.now() - startTime,
|
|
87
|
+
fetchCallName,
|
|
88
|
+
reason: progress.cancel.reason,
|
|
89
|
+
},
|
|
90
|
+
err,
|
|
91
|
+
);
|
|
92
|
+
throw new NonRetryableError(
|
|
93
|
+
"runWithRetry was Aborted",
|
|
94
|
+
DriverErrorTypes.genericError,
|
|
95
|
+
{
|
|
96
|
+
driverVersion: pkgVersion,
|
|
97
|
+
fetchCallName,
|
|
98
|
+
reason: progress.cancel.reason,
|
|
99
|
+
},
|
|
100
|
+
);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
// logging the first failed retry instead of every attempt. We want to avoid filling telemetry
|
|
104
|
+
// when we have tight loop of retrying in offline mode, but we also want to know what caused
|
|
105
|
+
// the failure in the first place
|
|
106
|
+
if (numRetries === 0) {
|
|
107
|
+
logger.sendTelemetryEvent(
|
|
108
|
+
{
|
|
109
|
+
eventName: `${fetchCallName}_firstFailed`,
|
|
110
|
+
duration: performance.now() - startTime,
|
|
111
|
+
fetchCallName,
|
|
112
|
+
},
|
|
113
|
+
err,
|
|
114
|
+
);
|
|
115
|
+
}
|
|
68
116
|
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
117
|
+
numRetries++;
|
|
118
|
+
lastError = err;
|
|
119
|
+
// Wait for the calculated time before retrying.
|
|
120
|
+
retryAfterMs = calculateMaxWaitTime(retryAfterMs, err);
|
|
121
|
+
if (progress.onRetry) {
|
|
122
|
+
progress.onRetry(retryAfterMs, err);
|
|
123
|
+
}
|
|
124
|
+
await delay(retryAfterMs);
|
|
125
|
+
}
|
|
126
|
+
} while (!success);
|
|
127
|
+
if (numRetries > 0) {
|
|
128
|
+
logger.sendTelemetryEvent(
|
|
129
|
+
{
|
|
130
|
+
eventName: `${fetchCallName}_lastError`,
|
|
131
|
+
retry: numRetries,
|
|
132
|
+
duration: performance.now() - startTime,
|
|
133
|
+
fetchCallName,
|
|
134
|
+
},
|
|
135
|
+
lastError,
|
|
136
|
+
);
|
|
137
|
+
}
|
|
138
|
+
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
139
|
+
return result!;
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
const MaxReconnectDelayInMsWhenEndpointIsReachable = 60000;
|
|
143
|
+
const MaxReconnectDelayInMsWhenEndpointIsNotReachable = 8000;
|
|
82
144
|
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
104
|
-
return result!;
|
|
145
|
+
/**
|
|
146
|
+
* Calculates time to wait for after an error based on the error and wait time for previous iteration.
|
|
147
|
+
* In case endpoint(service or socket) is not reachable, then we maybe offline or may have got some
|
|
148
|
+
* transient error not related to endpoint, in that case we want to try at faster pace and hence the
|
|
149
|
+
* max wait is lesser 8s as compared to when endpoint is reachable in which case it is 60s.
|
|
150
|
+
* @param delayMs - wait time for previous iteration
|
|
151
|
+
* @param error - error based on which we decide wait time.
|
|
152
|
+
* @returns Wait time to wait for.
|
|
153
|
+
* @internal
|
|
154
|
+
*/
|
|
155
|
+
export function calculateMaxWaitTime(delayMs: number, error: unknown): number {
|
|
156
|
+
const retryDelayFromError = getRetryDelayFromError(error);
|
|
157
|
+
let newDelayMs = Math.max(retryDelayFromError ?? 0, delayMs * 2);
|
|
158
|
+
newDelayMs = Math.min(
|
|
159
|
+
delayMs,
|
|
160
|
+
isFluidError(error) && error.getTelemetryProperties().endpointReached === true
|
|
161
|
+
? MaxReconnectDelayInMsWhenEndpointIsReachable
|
|
162
|
+
: MaxReconnectDelayInMsWhenEndpointIsNotReachable,
|
|
163
|
+
);
|
|
164
|
+
return newDelayMs;
|
|
105
165
|
}
|
|
@@ -4,53 +4,72 @@
|
|
|
4
4
|
*/
|
|
5
5
|
|
|
6
6
|
import {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
7
|
+
ISummaryTree,
|
|
8
|
+
SummaryType,
|
|
9
|
+
ISummaryBlob,
|
|
10
|
+
ICommittedProposal,
|
|
11
|
+
IDocumentAttributes,
|
|
12
12
|
} from "@fluidframework/protocol-definitions";
|
|
13
13
|
|
|
14
14
|
/**
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
* @
|
|
15
|
+
* Defines the current layout of an .app + .protocol summary tree
|
|
16
|
+
* this is used internally for create new, and single commit summary
|
|
17
|
+
* @internal
|
|
18
18
|
*/
|
|
19
|
-
export
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
19
|
+
export interface CombinedAppAndProtocolSummary extends ISummaryTree {
|
|
20
|
+
tree: {
|
|
21
|
+
[".app"]: ISummaryTree;
|
|
22
|
+
[".protocol"]: ISummaryTree;
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Validates the current layout of an .app + .protocol summary tree
|
|
28
|
+
* this is used internally for create new, and single commit summary
|
|
29
|
+
* @internal
|
|
30
|
+
*/
|
|
31
|
+
export function isCombinedAppAndProtocolSummary(
|
|
32
|
+
summary: ISummaryTree | undefined,
|
|
33
|
+
...optionalRootTrees: string[]
|
|
34
|
+
): summary is CombinedAppAndProtocolSummary {
|
|
35
|
+
if (
|
|
36
|
+
summary?.tree === undefined ||
|
|
37
|
+
summary.tree?.[".app"]?.type !== SummaryType.Tree ||
|
|
38
|
+
summary.tree?.[".protocol"]?.type !== SummaryType.Tree
|
|
39
|
+
) {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
const treeKeys = Object.keys(summary.tree).filter((t) => !optionalRootTrees.includes(t));
|
|
43
|
+
if (treeKeys.length !== 2) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
return true;
|
|
31
47
|
}
|
|
32
48
|
|
|
33
49
|
/**
|
|
34
50
|
* Extract the attributes from the protocol summary.
|
|
35
51
|
* @param protocolSummary - protocol summary from which the values are to be extracted.
|
|
52
|
+
* @internal
|
|
36
53
|
*/
|
|
37
54
|
export function getDocAttributesFromProtocolSummary(
|
|
38
|
-
|
|
55
|
+
protocolSummary: ISummaryTree,
|
|
39
56
|
): IDocumentAttributes {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
documentAttributes.term = documentAttributes.term ?? 1;
|
|
43
|
-
return documentAttributes;
|
|
57
|
+
const attributesBlob = protocolSummary.tree.attributes as ISummaryBlob;
|
|
58
|
+
return JSON.parse(attributesBlob.content as string) as IDocumentAttributes;
|
|
44
59
|
}
|
|
45
60
|
|
|
46
61
|
/**
|
|
47
62
|
* Extract quorum values from the protocol summary.
|
|
48
63
|
* @param protocolSummary - protocol summary from which the values are to be extracted.
|
|
64
|
+
* @internal
|
|
49
65
|
*/
|
|
50
66
|
export function getQuorumValuesFromProtocolSummary(
|
|
51
|
-
|
|
67
|
+
protocolSummary: ISummaryTree,
|
|
52
68
|
): [string, ICommittedProposal][] {
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
69
|
+
const quorumValuesBlob = protocolSummary.tree.quorumValues as ISummaryBlob;
|
|
70
|
+
const quorumValues = JSON.parse(quorumValuesBlob.content as string) as [
|
|
71
|
+
string,
|
|
72
|
+
ICommittedProposal,
|
|
73
|
+
][];
|
|
74
|
+
return quorumValues;
|
|
56
75
|
}
|