@fluidframework/container-runtime 0.51.3 → 0.53.0-46105

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.
Files changed (112) hide show
  1. package/dist/connectionTelemetry.d.ts +4 -0
  2. package/dist/connectionTelemetry.d.ts.map +1 -1
  3. package/dist/connectionTelemetry.js +6 -2
  4. package/dist/connectionTelemetry.js.map +1 -1
  5. package/dist/containerHandleContext.d.ts +0 -1
  6. package/dist/containerHandleContext.d.ts.map +1 -1
  7. package/dist/containerHandleContext.js +0 -1
  8. package/dist/containerHandleContext.js.map +1 -1
  9. package/dist/containerRuntime.d.ts +40 -13
  10. package/dist/containerRuntime.d.ts.map +1 -1
  11. package/dist/containerRuntime.js +255 -133
  12. package/dist/containerRuntime.js.map +1 -1
  13. package/dist/dataStoreContext.d.ts +10 -7
  14. package/dist/dataStoreContext.d.ts.map +1 -1
  15. package/dist/dataStoreContext.js +16 -13
  16. package/dist/dataStoreContext.js.map +1 -1
  17. package/dist/dataStores.d.ts +8 -8
  18. package/dist/dataStores.d.ts.map +1 -1
  19. package/dist/dataStores.js +20 -36
  20. package/dist/dataStores.js.map +1 -1
  21. package/dist/garbageCollection.d.ts +61 -14
  22. package/dist/garbageCollection.d.ts.map +1 -1
  23. package/dist/garbageCollection.js +275 -20
  24. package/dist/garbageCollection.js.map +1 -1
  25. package/dist/index.d.ts +2 -2
  26. package/dist/index.d.ts.map +1 -1
  27. package/dist/index.js +11 -2
  28. package/dist/index.js.map +1 -1
  29. package/dist/packageVersion.d.ts +1 -1
  30. package/dist/packageVersion.d.ts.map +1 -1
  31. package/dist/packageVersion.js +1 -1
  32. package/dist/packageVersion.js.map +1 -1
  33. package/dist/summarizer.d.ts +1 -3
  34. package/dist/summarizer.d.ts.map +1 -1
  35. package/dist/summarizer.js +0 -12
  36. package/dist/summarizer.js.map +1 -1
  37. package/dist/summarizerTypes.d.ts +14 -3
  38. package/dist/summarizerTypes.d.ts.map +1 -1
  39. package/dist/summarizerTypes.js +3 -0
  40. package/dist/summarizerTypes.js.map +1 -1
  41. package/dist/summaryFormat.d.ts +9 -1
  42. package/dist/summaryFormat.d.ts.map +1 -1
  43. package/dist/summaryFormat.js +2 -1
  44. package/dist/summaryFormat.js.map +1 -1
  45. package/dist/summaryGenerator.d.ts.map +1 -1
  46. package/dist/summaryGenerator.js +1 -3
  47. package/dist/summaryGenerator.js.map +1 -1
  48. package/dist/summaryManager.d.ts.map +1 -1
  49. package/dist/summaryManager.js.map +1 -1
  50. package/lib/connectionTelemetry.d.ts +4 -0
  51. package/lib/connectionTelemetry.d.ts.map +1 -1
  52. package/lib/connectionTelemetry.js +5 -1
  53. package/lib/connectionTelemetry.js.map +1 -1
  54. package/lib/containerHandleContext.d.ts +0 -1
  55. package/lib/containerHandleContext.d.ts.map +1 -1
  56. package/lib/containerHandleContext.js +0 -1
  57. package/lib/containerHandleContext.js.map +1 -1
  58. package/lib/containerRuntime.d.ts +40 -13
  59. package/lib/containerRuntime.d.ts.map +1 -1
  60. package/lib/containerRuntime.js +259 -138
  61. package/lib/containerRuntime.js.map +1 -1
  62. package/lib/dataStoreContext.d.ts +10 -7
  63. package/lib/dataStoreContext.d.ts.map +1 -1
  64. package/lib/dataStoreContext.js +16 -13
  65. package/lib/dataStoreContext.js.map +1 -1
  66. package/lib/dataStores.d.ts +8 -8
  67. package/lib/dataStores.d.ts.map +1 -1
  68. package/lib/dataStores.js +23 -39
  69. package/lib/dataStores.js.map +1 -1
  70. package/lib/garbageCollection.d.ts +61 -14
  71. package/lib/garbageCollection.d.ts.map +1 -1
  72. package/lib/garbageCollection.js +276 -21
  73. package/lib/garbageCollection.js.map +1 -1
  74. package/lib/index.d.ts +2 -2
  75. package/lib/index.d.ts.map +1 -1
  76. package/lib/index.js +2 -1
  77. package/lib/index.js.map +1 -1
  78. package/lib/packageVersion.d.ts +1 -1
  79. package/lib/packageVersion.d.ts.map +1 -1
  80. package/lib/packageVersion.js +1 -1
  81. package/lib/packageVersion.js.map +1 -1
  82. package/lib/summarizer.d.ts +1 -3
  83. package/lib/summarizer.d.ts.map +1 -1
  84. package/lib/summarizer.js +0 -12
  85. package/lib/summarizer.js.map +1 -1
  86. package/lib/summarizerTypes.d.ts +14 -3
  87. package/lib/summarizerTypes.d.ts.map +1 -1
  88. package/lib/summarizerTypes.js +3 -0
  89. package/lib/summarizerTypes.js.map +1 -1
  90. package/lib/summaryFormat.d.ts +9 -1
  91. package/lib/summaryFormat.d.ts.map +1 -1
  92. package/lib/summaryFormat.js +2 -1
  93. package/lib/summaryFormat.js.map +1 -1
  94. package/lib/summaryGenerator.d.ts.map +1 -1
  95. package/lib/summaryGenerator.js +1 -3
  96. package/lib/summaryGenerator.js.map +1 -1
  97. package/lib/summaryManager.d.ts.map +1 -1
  98. package/lib/summaryManager.js.map +1 -1
  99. package/package.json +16 -16
  100. package/src/connectionTelemetry.ts +6 -1
  101. package/src/containerHandleContext.ts +0 -1
  102. package/src/containerRuntime.ts +327 -160
  103. package/src/dataStoreContext.ts +21 -20
  104. package/src/dataStores.ts +32 -50
  105. package/src/garbageCollection.ts +390 -18
  106. package/src/index.ts +20 -2
  107. package/src/packageVersion.ts +1 -1
  108. package/src/summarizer.ts +0 -15
  109. package/src/summarizerTypes.ts +16 -4
  110. package/src/summaryFormat.ts +10 -1
  111. package/src/summaryGenerator.ts +2 -3
  112. package/src/summaryManager.ts +8 -3
@@ -3,7 +3,7 @@
3
3
  * Licensed under the MIT License.
4
4
  */
5
5
  import { IDisposable, ITelemetryLogger } from "@fluidframework/common-definitions";
6
- import { IFluidObject, IRequest, IResponse, IFluidHandle } from "@fluidframework/core-interfaces";
6
+ import { FluidObject, IRequest, IResponse, IFluidHandle } from "@fluidframework/core-interfaces";
7
7
  import { IAudience, IDeltaManager, ContainerWarning, BindState, AttachState, ILoaderOptions } from "@fluidframework/container-definitions";
8
8
  import { Deferred, TypedEventEmitter } from "@fluidframework/common-utils";
9
9
  import { IDocumentStorageService } from "@fluidframework/driver-definitions";
@@ -29,7 +29,7 @@ export declare abstract class FluidDataStoreContext extends TypedEventEmitter<IF
29
29
  readonly id: string;
30
30
  private readonly existing;
31
31
  readonly storage: IDocumentStorageService;
32
- readonly scope: IFluidObject;
32
+ readonly scope: FluidObject | FluidObject;
33
33
  private bindState;
34
34
  readonly isLocalDataStore: boolean;
35
35
  protected pkg?: readonly string[] | undefined;
@@ -50,6 +50,8 @@ export declare abstract class FluidDataStoreContext extends TypedEventEmitter<IF
50
50
  get IFluidDataStoreRegistry(): IFluidDataStoreRegistry | undefined;
51
51
  isRoot(): Promise<boolean>;
52
52
  protected get disableIsolatedChannels(): boolean;
53
+ /** Tells whether GC data will be written at the root of the summary tree. If so, data store should not write it. */
54
+ protected get writeGCDataAtRoot(): boolean;
53
55
  protected registry: IFluidDataStoreRegistry | undefined;
54
56
  protected detachedRuntimeCreation: boolean;
55
57
  readonly bindToContext: () => void;
@@ -64,7 +66,7 @@ export declare abstract class FluidDataStoreContext extends TypedEventEmitter<IF
64
66
  private readonly thresholdOpsCounter;
65
67
  private static readonly pendingOpsCountThreshold;
66
68
  private lastUsedState;
67
- constructor(_containerRuntime: ContainerRuntime, id: string, existing: boolean, storage: IDocumentStorageService, scope: IFluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindState: BindState, isLocalDataStore: boolean, bindChannel: (channel: IFluidDataStoreChannel) => void, pkg?: readonly string[] | undefined);
69
+ constructor(_containerRuntime: ContainerRuntime, id: string, existing: boolean, storage: IDocumentStorageService, scope: FluidObject | FluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindState: BindState, isLocalDataStore: boolean, bindChannel: (channel: IFluidDataStoreChannel) => void, pkg?: readonly string[] | undefined);
68
70
  dispose(): void;
69
71
  private rejectDeferredRealize;
70
72
  realize(): Promise<IFluidDataStoreChannel>;
@@ -156,7 +158,8 @@ export declare abstract class FluidDataStoreContext extends TypedEventEmitter<IF
156
158
  }
157
159
  export declare class RemotedFluidDataStoreContext extends FluidDataStoreContext {
158
160
  private readonly initSnapshotValue;
159
- constructor(id: string, initSnapshotValue: ISnapshotTree | string | undefined, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: IFluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, pkg?: string[]);
161
+ private readonly getBaseSummaryGCDetails;
162
+ constructor(id: string, initSnapshotValue: ISnapshotTree | string | undefined, getBaseSummaryGCDetails: () => Promise<IGarbageCollectionSummaryDetails | undefined>, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: FluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, pkg?: string[]);
160
163
  private readonly initialSnapshotDetailsP;
161
164
  private readonly gcDetailsInInitialSummaryP;
162
165
  protected getInitialSnapshotDetails(): Promise<ISnapshotDetails>;
@@ -173,7 +176,7 @@ export declare class LocalFluidDataStoreContextBase extends FluidDataStoreContex
173
176
  * @deprecated 0.16 Issue #1635, #3631
174
177
  */
175
178
  readonly createProps?: any;
176
- constructor(id: string, pkg: Readonly<string[]> | undefined, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: IFluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindChannel: (channel: IFluidDataStoreChannel) => void, snapshotTree: ISnapshotTree | undefined, isRootDataStore: boolean | undefined,
179
+ constructor(id: string, pkg: Readonly<string[]> | undefined, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: FluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindChannel: (channel: IFluidDataStoreChannel) => void, snapshotTree: ISnapshotTree | undefined, isRootDataStore: boolean | undefined,
177
180
  /**
178
181
  * @deprecated 0.16 Issue #1635, #3631
179
182
  */
@@ -190,7 +193,7 @@ export declare class LocalFluidDataStoreContextBase extends FluidDataStoreContex
190
193
  * Runtime is created using data store factory that is associated with this context.
191
194
  */
192
195
  export declare class LocalFluidDataStoreContext extends LocalFluidDataStoreContextBase {
193
- constructor(id: string, pkg: string[] | undefined, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: IFluidObject & IFluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindChannel: (channel: IFluidDataStoreChannel) => void, snapshotTree: ISnapshotTree | undefined, isRootDataStore: boolean | undefined,
196
+ constructor(id: string, pkg: string[] | undefined, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: FluidObject & FluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindChannel: (channel: IFluidDataStoreChannel) => void, snapshotTree: ISnapshotTree | undefined, isRootDataStore: boolean | undefined,
194
197
  /**
195
198
  * @deprecated 0.16 Issue #1635, #3631
196
199
  */
@@ -203,7 +206,7 @@ export declare class LocalFluidDataStoreContext extends LocalFluidDataStoreConte
203
206
  * Attachment process provides all missing parts - package path, data store runtime, and data store factory
204
207
  */
205
208
  export declare class LocalDetachedFluidDataStoreContext extends LocalFluidDataStoreContextBase implements IFluidDataStoreContextDetached {
206
- constructor(id: string, pkg: Readonly<string[]>, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: IFluidObject & IFluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindChannel: (channel: IFluidDataStoreChannel) => void, isRootDataStore: boolean);
209
+ constructor(id: string, pkg: Readonly<string[]>, runtime: ContainerRuntime, storage: IDocumentStorageService, scope: FluidObject & FluidObject, createSummarizerNode: CreateChildSummarizerNodeFn, bindChannel: (channel: IFluidDataStoreChannel) => void, isRootDataStore: boolean);
207
210
  attachRuntime(registry: IProvideFluidDataStoreFactory, dataStoreRuntime: IFluidDataStoreChannel): Promise<void>;
208
211
  protected getInitialSnapshotDetails(): Promise<ISnapshotDetails>;
209
212
  }
@@ -1 +1 @@
1
- {"version":3,"file":"dataStoreContext.d.ts","sourceRoot":"","sources":["../src/dataStoreContext.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dataStoreContext.d.ts","sourceRoot":"","sources":["../src/dataStoreContext.ts"],"names":[],"mappings":"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"}
@@ -109,6 +109,10 @@ export class FluidDataStoreContext extends TypedEventEmitter {
109
109
  get disableIsolatedChannels() {
110
110
  return this._containerRuntime.disableIsolatedChannels;
111
111
  }
112
+ /** Tells whether GC data will be written at the root of the summary tree. If so, data store should not write it. */
113
+ get writeGCDataAtRoot() {
114
+ return this._containerRuntime.writeGCDataAtRoot;
115
+ }
112
116
  dispose() {
113
117
  if (this._disposed) {
114
118
  return;
@@ -247,8 +251,10 @@ export class FluidDataStoreContext extends TypedEventEmitter {
247
251
  const { pkg, isRootDataStore } = await this.getInitialSnapshotDetails();
248
252
  const attributes = createAttributes(pkg, isRootDataStore, this.disableIsolatedChannels);
249
253
  addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));
250
- // Add GC details to the summary.
251
- addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));
254
+ // Add GC data to the summary if it's not written at the root.
255
+ if (!this.writeGCDataAtRoot) {
256
+ addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));
257
+ }
252
258
  // If we are not referenced, mark the summary tree as unreferenced. Also, update unreferenced blob
253
259
  // size in the summary stats with the blobs size of this data store.
254
260
  if (!this.summarizerNode.isReferenced()) {
@@ -442,11 +448,12 @@ export class FluidDataStoreContext extends TypedEventEmitter {
442
448
  }
443
449
  FluidDataStoreContext.pendingOpsCountThreshold = 1000;
444
450
  export class RemotedFluidDataStoreContext extends FluidDataStoreContext {
445
- constructor(id, initSnapshotValue, runtime, storage, scope, createSummarizerNode, pkg) {
451
+ constructor(id, initSnapshotValue, getBaseSummaryGCDetails, runtime, storage, scope, createSummarizerNode, pkg) {
446
452
  super(runtime, id, true, storage, scope, createSummarizerNode, BindState.Bound, false, () => {
447
453
  throw new Error("Already attached");
448
454
  }, pkg);
449
455
  this.initSnapshotValue = initSnapshotValue;
456
+ this.getBaseSummaryGCDetails = getBaseSummaryGCDetails;
450
457
  this.initialSnapshotDetailsP = new LazyPromise(async () => {
451
458
  var _a, _b;
452
459
  let tree;
@@ -504,14 +511,8 @@ export class RemotedFluidDataStoreContext extends FluidDataStoreContext {
504
511
  };
505
512
  });
506
513
  this.gcDetailsInInitialSummaryP = new LazyPromise(async () => {
507
- // If the initial snapshot is undefined or string, the snapshot is in old format and won't have GC details.
508
- if (!(!this.initSnapshotValue || typeof this.initSnapshotValue === "string")
509
- && this.initSnapshotValue.blobs[gcBlobKey] !== undefined) {
510
- return readAndParse(this.storage, this.initSnapshotValue.blobs[gcBlobKey]);
511
- }
512
- else {
513
- return {};
514
- }
514
+ var _a;
515
+ return (_a = (await this.getBaseSummaryGCDetails())) !== null && _a !== void 0 ? _a : {};
515
516
  });
516
517
  }
517
518
  async getInitialSnapshotDetails() {
@@ -561,8 +562,10 @@ export class LocalFluidDataStoreContextBase extends FluidDataStoreContext {
561
562
  // Add data store's attributes to the summary.
562
563
  const attributes = createAttributes(this.pkg, this.isRootDataStore, this.disableIsolatedChannels);
563
564
  addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));
564
- // Add GC details to the summary.
565
- addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));
565
+ // Add GC data to the summary if it's not written at the root.
566
+ if (!this.writeGCDataAtRoot) {
567
+ addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));
568
+ }
566
569
  // Attach message needs the summary in ITree format. Convert the ISummaryTree into an ITree.
567
570
  const snapshot = convertSummaryTreeToITree(summarizeResult.summary);
568
571
  const message = {
@@ -1 +1 @@
1
- {"version":3,"file":"dataStoreContext.js","sourceRoot":"","sources":["../src/dataStoreContext.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { IDisposable, ITelemetryLogger } from \"@fluidframework/common-definitions\";\nimport {\n IFluidObject,\n IRequest,\n IResponse,\n IFluidHandle,\n} from \"@fluidframework/core-interfaces\";\nimport {\n IAudience,\n IDeltaManager,\n ContainerWarning,\n BindState,\n AttachState,\n ILoaderOptions,\n} from \"@fluidframework/container-definitions\";\nimport {\n assert,\n Deferred,\n LazyPromise,\n TypedEventEmitter,\n} from \"@fluidframework/common-utils\";\nimport { IDocumentStorageService } from \"@fluidframework/driver-definitions\";\nimport { readAndParse } from \"@fluidframework/driver-utils\";\nimport { BlobTreeEntry } from \"@fluidframework/protocol-base\";\nimport {\n IClientDetails,\n IDocumentMessage,\n IQuorum,\n ISequencedDocumentMessage,\n ISnapshotTree,\n ITreeEntry,\n} from \"@fluidframework/protocol-definitions\";\nimport {\n IContainerRuntime,\n} from \"@fluidframework/container-runtime-definitions\";\nimport {\n channelsTreeName,\n CreateChildSummarizerNodeFn,\n CreateChildSummarizerNodeParam,\n FluidDataStoreRegistryEntry,\n gcBlobKey,\n IAttachMessage,\n IFluidDataStoreChannel,\n IFluidDataStoreContext,\n IFluidDataStoreContextDetached,\n IFluidDataStoreContextEvents,\n IFluidDataStoreRegistry,\n IGarbageCollectionData,\n IGarbageCollectionSummaryDetails,\n IInboundSignalMessage,\n IProvideFluidDataStoreFactory,\n ISummarizeInternalResult,\n ISummarizeResult,\n ISummarizerNodeWithGC,\n SummarizeInternalFn,\n} from \"@fluidframework/runtime-definitions\";\nimport { addBlobToSummary, convertSummaryTreeToITree } from \"@fluidframework/runtime-utils\";\nimport {\n ChildLogger,\n LoggingError,\n TelemetryDataTag,\n ThresholdCounter,\n} from \"@fluidframework/telemetry-utils\";\nimport { CreateProcessingError } from \"@fluidframework/container-utils\";\nimport { ContainerRuntime } from \"./containerRuntime\";\nimport {\n dataStoreAttributesBlobName,\n hasIsolatedChannels,\n wrapSummaryInChannelsTree,\n ReadFluidDataStoreAttributes,\n WriteFluidDataStoreAttributes,\n getAttributesFormatVersion,\n getFluidDataStoreAttributes,\n} from \"./summaryFormat\";\n\nfunction createAttributes(\n pkg: readonly string[],\n isRootDataStore: boolean,\n disableIsolatedChannels: boolean,\n): WriteFluidDataStoreAttributes {\n const stringifiedPkg = JSON.stringify(pkg);\n return disableIsolatedChannels ? {\n pkg: stringifiedPkg,\n snapshotFormatVersion: \"0.1\",\n isRootDataStore,\n } : {\n pkg: stringifiedPkg,\n summaryFormatVersion: 2,\n isRootDataStore,\n };\n}\nexport function createAttributesBlob(\n pkg: readonly string[],\n isRootDataStore: boolean,\n disableIsolatedChannels: boolean,\n): ITreeEntry {\n const attributes = createAttributes(pkg, isRootDataStore, disableIsolatedChannels);\n return new BlobTreeEntry(dataStoreAttributesBlobName, JSON.stringify(attributes));\n}\n\ninterface ISnapshotDetails {\n pkg: readonly string[];\n /**\n * This tells whether a data store is root. Root data stores are never collected.\n * Non-root data stores may be collected if they are not used.\n */\n isRootDataStore: boolean;\n snapshot?: ISnapshotTree;\n}\n\ninterface FluidDataStoreMessage {\n content: any;\n type: string;\n}\n\n/**\n * Represents the context for the store. This context is passed to the store runtime.\n */\nexport abstract class FluidDataStoreContext extends TypedEventEmitter<IFluidDataStoreContextEvents> implements\n IFluidDataStoreContext,\n IDisposable {\n public get packagePath(): readonly string[] {\n assert(this.pkg !== undefined, 0x139 /* \"Undefined package path\" */);\n return this.pkg;\n }\n\n public get options(): ILoaderOptions {\n return this._containerRuntime.options;\n }\n\n public get clientId(): string | undefined {\n return this._containerRuntime.clientId;\n }\n\n public get clientDetails(): IClientDetails {\n return this._containerRuntime.clientDetails;\n }\n\n public get logger(): ITelemetryLogger {\n return this._containerRuntime.logger;\n }\n\n public get deltaManager(): IDeltaManager<ISequencedDocumentMessage, IDocumentMessage> {\n return this._containerRuntime.deltaManager;\n }\n\n public get connected(): boolean {\n return this._containerRuntime.connected;\n }\n\n public get IFluidHandleContext() {\n return this._containerRuntime.IFluidHandleContext;\n }\n\n public get containerRuntime(): IContainerRuntime {\n return this._containerRuntime;\n }\n\n public get isLoaded(): boolean {\n return this.loaded;\n }\n\n public get baseSnapshot(): ISnapshotTree | undefined {\n return this._baseSnapshot;\n }\n\n private _disposed = false;\n public get disposed() { return this._disposed; }\n\n public get attachState(): AttachState {\n return this._attachState;\n }\n\n public get IFluidDataStoreRegistry(): IFluidDataStoreRegistry | undefined {\n return this.registry;\n }\n\n public async isRoot(): Promise<boolean> {\n return (await this.getInitialSnapshotDetails()).isRootDataStore;\n }\n\n protected get disableIsolatedChannels(): boolean {\n return this._containerRuntime.disableIsolatedChannels;\n }\n\n protected registry: IFluidDataStoreRegistry | undefined;\n\n protected detachedRuntimeCreation = false;\n public readonly bindToContext: () => void;\n protected channel: IFluidDataStoreChannel | undefined;\n private loaded = false;\n protected pending: ISequencedDocumentMessage[] | undefined = [];\n protected channelDeferred: Deferred<IFluidDataStoreChannel> | undefined;\n private _baseSnapshot: ISnapshotTree | undefined;\n protected _attachState: AttachState;\n protected readonly summarizerNode: ISummarizerNodeWithGC;\n private readonly subLogger: ITelemetryLogger;\n private readonly thresholdOpsCounter: ThresholdCounter;\n private static readonly pendingOpsCountThreshold = 1000;\n\n // The used state of this node as per the last GC run. This is used to update the used state of the channel\n // if it realizes after GC is run.\n private lastUsedState: { usedRoutes: string[], gcTimestamp?: number } | undefined;\n\n constructor(\n private readonly _containerRuntime: ContainerRuntime,\n public readonly id: string,\n private readonly existing: boolean,\n public readonly storage: IDocumentStorageService,\n public readonly scope: IFluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n private bindState: BindState,\n public readonly isLocalDataStore: boolean,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n protected pkg?: readonly string[],\n ) {\n super();\n\n // URIs use slashes as delimiters. Handles use URIs.\n // Thus having slashes in types almost guarantees trouble down the road!\n assert(id.indexOf(\"/\") === -1, 0x13a /* `Data store ID contains slash: ${id}` */);\n\n this._attachState = this.containerRuntime.attachState !== AttachState.Detached && this.existing ?\n this.containerRuntime.attachState : AttachState.Detached;\n\n this.bindToContext = () => {\n assert(this.bindState === BindState.NotBound, 0x13b /* \"datastore context is already in bound state\" */);\n this.bindState = BindState.Binding;\n assert(this.channel !== undefined, 0x13c /* \"undefined channel on datastore context\" */);\n bindChannel(this.channel);\n this.bindState = BindState.Bound;\n };\n\n const thisSummarizeInternal =\n async (fullTree: boolean, trackState: boolean) => this.summarizeInternal(fullTree, trackState);\n\n this.summarizerNode = createSummarizerNode(\n thisSummarizeInternal,\n async (fullGC?: boolean) => this.getGCDataInternal(fullGC),\n async () => this.getInitialGCSummaryDetails(),\n );\n\n this.subLogger = ChildLogger.create(this.logger, \"FluidDataStoreContext\");\n this.thresholdOpsCounter = new ThresholdCounter(FluidDataStoreContext.pendingOpsCountThreshold, this.subLogger);\n }\n\n public dispose(): void {\n if (this._disposed) {\n return;\n }\n this._disposed = true;\n\n // Dispose any pending runtime after it gets fulfilled\n // Errors are logged where this.channelDeferred is consumed/generated (realizeCore(), bindRuntime())\n if (this.channelDeferred) {\n this.channelDeferred.promise.then((runtime) => {\n runtime.dispose();\n }).catch((error) => {});\n }\n }\n\n private rejectDeferredRealize(reason: string, packageName?: string): never {\n throw new LoggingError(reason, { packageName: { value: packageName, tag: TelemetryDataTag.PackageData }});\n }\n\n public async realize(): Promise<IFluidDataStoreChannel> {\n assert(!this.detachedRuntimeCreation, 0x13d /* \"Detached runtime creation on realize()\" */);\n if (!this.channelDeferred) {\n this.channelDeferred = new Deferred<IFluidDataStoreChannel>();\n this.realizeCore(this.existing).catch((error) => {\n const errorWrapped = CreateProcessingError(error, \"realizeFluidDataStoreContext\");\n errorWrapped.addTelemetryProperties({ fluidDataStoreId: { value: this.id, tag: \"PackageData\"} });\n this.channelDeferred?.reject(errorWrapped);\n this.logger.sendErrorEvent({ eventName: \"RealizeError\"}, errorWrapped);\n });\n }\n return this.channelDeferred.promise;\n }\n\n protected async factoryFromPackagePath(packages?: readonly string[]) {\n assert(this.pkg === packages, 0x13e /* \"Unexpected package path\" */);\n if (packages === undefined) {\n this.rejectDeferredRealize(\"packages is undefined\");\n }\n\n let entry: FluidDataStoreRegistryEntry | undefined;\n let registry: IFluidDataStoreRegistry | undefined = this._containerRuntime.IFluidDataStoreRegistry;\n let lastPkg: string | undefined;\n for (const pkg of packages) {\n if (!registry) {\n this.rejectDeferredRealize(\"No registry for package\", lastPkg);\n }\n lastPkg = pkg;\n entry = await registry.get(pkg);\n if (!entry) {\n this.rejectDeferredRealize(\"Registry does not contain entry for the package\", pkg);\n }\n registry = entry.IFluidDataStoreRegistry;\n }\n const factory = entry?.IFluidDataStoreFactory;\n if (factory === undefined) {\n this.rejectDeferredRealize(\"Can't find factory for package\", lastPkg);\n }\n\n return { factory, registry };\n }\n\n private async realizeCore(existing: boolean): Promise<void> {\n const details = await this.getInitialSnapshotDetails();\n // Base snapshot is the baseline where pending ops are applied to.\n // It is important that this be in sync with the pending ops, and also\n // that it is set here, before bindRuntime is called.\n this._baseSnapshot = details.snapshot;\n const packages = details.pkg;\n\n const { factory, registry } = await this.factoryFromPackagePath(packages);\n\n assert(this.registry === undefined, 0x13f /* \"datastore context registry is already set\" */);\n this.registry = registry;\n\n const channel = await factory.instantiateDataStore(this, existing);\n assert(channel !== undefined, 0x140 /* \"undefined channel on datastore context\" */);\n this.bindRuntime(channel);\n }\n\n /**\n * Notifies this object about changes in the connection state.\n * @param value - New connection state.\n * @param clientId - ID of the client. It's old ID when in disconnected state and\n * it's new client ID when we are connecting or connected.\n */\n public setConnectionState(connected: boolean, clientId?: string) {\n this.verifyNotClosed();\n\n // Connection events are ignored if the store is not yet loaded\n if (!this.loaded) {\n return;\n }\n\n assert(this.connected === connected, 0x141 /* \"Unexpected connected state\" */);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.channel!.setConnectionState(connected, clientId);\n }\n\n public process(messageArg: ISequencedDocumentMessage, local: boolean, localOpMetadata: unknown): void {\n this.verifyNotClosed();\n\n const innerContents = messageArg.contents as FluidDataStoreMessage;\n const message = {\n ...messageArg,\n type: innerContents.type,\n contents: innerContents.content,\n };\n\n this.summarizerNode.recordChange(message);\n\n if (this.loaded) {\n return this.channel?.process(message, local, localOpMetadata);\n } else {\n assert(!local, 0x142 /* \"local store channel is not loaded\" */);\n assert(this.pending !== undefined, 0x23d /* \"pending is undefined\" */);\n this.pending.push(message);\n this.thresholdOpsCounter.sendIfMultiple(\"StorePendingOps\", this.pending.length);\n }\n }\n\n public processSignal(message: IInboundSignalMessage, local: boolean): void {\n this.verifyNotClosed();\n\n // Signals are ignored if the store is not yet loaded\n if (!this.loaded) {\n return;\n }\n\n this.channel?.processSignal(message, local);\n }\n\n public getQuorum(): IQuorum {\n return this._containerRuntime.getQuorum();\n }\n\n public getAudience(): IAudience {\n return this._containerRuntime.getAudience();\n }\n\n /**\n * Returns a summary at the current sequence number.\n * @param fullTree - true to bypass optimizations and force a full summary tree\n * @param trackState - This tells whether we should track state from this summary.\n */\n public async summarize(fullTree: boolean = false, trackState: boolean = true): Promise<ISummarizeResult> {\n return this.summarizerNode.summarize(fullTree, trackState);\n }\n\n private async summarizeInternal(fullTree: boolean, trackState: boolean): Promise<ISummarizeInternalResult> {\n await this.realize();\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const summarizeResult = await this.channel!.summarize(fullTree, trackState);\n let pathPartsForChildren: string[] | undefined;\n\n if (!this.disableIsolatedChannels) {\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n pathPartsForChildren = [channelsTreeName];\n }\n\n // Add data store's attributes to the summary.\n const { pkg, isRootDataStore } = await this.getInitialSnapshotDetails();\n const attributes = createAttributes(pkg, isRootDataStore, this.disableIsolatedChannels);\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\n\n // Add GC details to the summary.\n addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));\n\n // If we are not referenced, mark the summary tree as unreferenced. Also, update unreferenced blob\n // size in the summary stats with the blobs size of this data store.\n if (!this.summarizerNode.isReferenced()) {\n summarizeResult.summary.unreferenced = true;\n summarizeResult.stats.unreferencedBlobSize = summarizeResult.stats.totalBlobSize;\n }\n\n return {\n ...summarizeResult,\n id: this.id,\n pathPartsForChildren,\n };\n }\n\n /**\n * Returns the data used for garbage collection. This includes a list of GC nodes that represent this data store\n * including any of its child channel contexts. Each node has a set of outbound routes to other GC nodes in the\n * document.\n * If there is no new data in this data store since the last summary, previous GC data is used.\n * If there is new data, the GC data is generated again (by calling getGCDataInternal).\n * @param fullGC - true to bypass optimizations and force full generation of GC data.\n */\n public async getGCData(fullGC: boolean = false): Promise<IGarbageCollectionData> {\n return this.summarizerNode.getGCData(fullGC);\n }\n\n /**\n * Generates data used for garbage collection. This is called when there is new data since last summary. It\n * realizes the data store and calls into each channel context to get its GC data.\n * @param fullGC - true to bypass optimizations and force full generation of GC data.\n */\n private async getGCDataInternal(fullGC: boolean = false): Promise<IGarbageCollectionData> {\n await this.realize();\n assert(this.channel !== undefined, 0x143 /* \"Channel should not be undefined when running GC\" */);\n\n return this.channel.getGCData(fullGC);\n }\n\n /**\n * After GC has run, called to notify the data store of routes used in it. These are used for the following:\n * 1. To identify if this data store is being referenced in the document or not.\n * 2. To determine if it needs to re-summarize in case used routes changed since last summary.\n * 3. These are added to the summary generated by the data store.\n * 4. To notify child contexts of their used routes. This is done immediately if the data store is loaded. Else,\n * it is done when realizing the data store.\n * 5. To update the timestamp when this data store or any children are marked as unreferenced.\n * @param usedRoutes - The routes that are used in this data store.\n * @param gcTimestamp - The time when GC was run that generated these used routes. If any node becomes unreferenced\n * as part of this GC run, this should be used to update the time when it happens.\n */\n public updateUsedRoutes(usedRoutes: string[], gcTimestamp?: number) {\n // Update the used routes in this data store's summarizer node.\n this.summarizerNode.updateUsedRoutes(usedRoutes, gcTimestamp);\n\n /**\n * If the data store has not been realized yet, we need this used state to update the used state of the channel\n * when it realizes. It's safe to keep only the last used state because if something changes because of this GC\n * run, the data store will be immediately realized as part of the summary that follows GC. For example, if a\n * child's reference state changes, the gcTimestamp has to be used to update its unreferencedTimestamp. Since\n * it will result in a change in this data store's used routes, it will be realized to regenerate its summary.\n */\n this.lastUsedState = { usedRoutes, gcTimestamp };\n\n // If we are loaded, call the channel so it can update the used routes of the child contexts.\n // If we are not loaded, we will update this when we are realized.\n if (this.loaded) {\n this.updateChannelUsedRoutes();\n }\n }\n\n /**\n * Updates the used routes of the channel and its child contexts. The channel must be loaded before calling this.\n * It is called in these two scenarions:\n * 1. When the used routes of the data store is updated and the data store is loaded.\n * 2. When the data store is realized. This updates the channel's used routes as per last GC run.\n */\n private updateChannelUsedRoutes() {\n assert(this.loaded, 0x144 /* \"Channel should be loaded when updating used routes\" */);\n assert(this.channel !== undefined, 0x145 /* \"Channel should be present when data store is loaded\" */);\n\n // If there is no lastUsedState, GC has not run up until this point.\n if (this.lastUsedState === undefined) {\n return;\n }\n\n // Remove the route to this data store, if it exists.\n const usedChannelRoutes = this.lastUsedState.usedRoutes.filter(\n (id: string) => { return id !== \"/\" && id !== \"\"; },\n );\n this.channel.updateUsedRoutes(usedChannelRoutes, this.lastUsedState.gcTimestamp);\n }\n\n /**\n * @deprecated 0.18.Should call request on the runtime directly\n */\n public async request(request: IRequest): Promise<IResponse> {\n const runtime = await this.realize();\n return runtime.request(request);\n }\n\n public submitMessage(type: string, content: any, localOpMetadata: unknown): void {\n this.verifyNotClosed();\n assert(!!this.channel, 0x146 /* \"Channel must exist when submitting message\" */);\n const fluidDataStoreContent: FluidDataStoreMessage = {\n content,\n type,\n };\n this._containerRuntime.submitDataStoreOp(\n this.id,\n fluidDataStoreContent,\n localOpMetadata);\n }\n\n /**\n * This is called from a SharedSummaryBlock that does not generate ops but only wants to be part of the summary.\n * It indicates that there is data in the object that needs to be summarized.\n * We will update the latestSequenceNumber of the summary tracker of this\n * store and of the object's channel.\n *\n * @param address - The address of the channel that is dirty.\n *\n */\n public setChannelDirty(address: string): void {\n this.verifyNotClosed();\n\n // Get the latest sequence number.\n const latestSequenceNumber = this.deltaManager.lastSequenceNumber;\n\n this.summarizerNode.invalidate(latestSequenceNumber);\n\n const channelSummarizerNode = this.summarizerNode.getChild(address);\n\n if (channelSummarizerNode) {\n channelSummarizerNode.invalidate(latestSequenceNumber); // TODO: lazy load problem?\n }\n }\n\n public submitSignal(type: string, content: any) {\n this.verifyNotClosed();\n assert(!!this.channel, 0x147 /* \"Channel must exist on submitting signal\" */);\n return this._containerRuntime.submitDataStoreSignal(this.id, type, content);\n }\n\n // @deprecated Warnings are being deprecated\n public raiseContainerWarning(warning: ContainerWarning): void {\n this.containerRuntime.raiseContainerWarning(warning);\n }\n\n protected bindRuntime(channel: IFluidDataStoreChannel) {\n if (this.channel) {\n throw new Error(\"Runtime already bound\");\n }\n\n try\n {\n assert(!this.detachedRuntimeCreation, 0x148 /* \"Detached runtime creation on runtime bind\" */);\n assert(this.channelDeferred !== undefined, 0x149 /* \"Undefined channel defferal\" */);\n assert(this.pkg !== undefined, 0x14a /* \"Undefined package path\" */);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const pending = this.pending!;\n\n // Apply all pending ops\n for (const op of pending) {\n channel.process(op, false, undefined /* localOpMetadata */);\n }\n\n this.thresholdOpsCounter.send(\"ProcessPendingOps\", pending.length);\n this.pending = undefined;\n\n // And now mark the runtime active\n this.loaded = true;\n this.channel = channel;\n\n // Freeze the package path to ensure that someone doesn't modify it when it is\n // returned in packagePath().\n Object.freeze(this.pkg);\n\n /**\n * Update the used routes of the channel. If GC has run before this data store was realized, we will have\n * the used routes saved. So, this will ensure that all the child contexts have up-to-date used routes as\n * per the last time GC was run.\n * Also, this data store may have been realized during summarize. In that case, the child contexts need to\n * have their used routes updated to determine if its needs to summarize again and to add it to the summary.\n */\n this.updateChannelUsedRoutes();\n\n // And notify the pending promise it is now available\n this.channelDeferred.resolve(this.channel);\n } catch (error) {\n this.channelDeferred?.reject(error);\n this.logger.sendErrorEvent(\n { eventName: \"BindRuntimeError\", fluidDataStoreId: { value: this.id, tag: \"PackageData\"} },\n error);\n }\n }\n\n public async getAbsoluteUrl(relativeUrl: string): Promise<string | undefined> {\n if (this.attachState !== AttachState.Attached) {\n return undefined;\n }\n return this._containerRuntime.getAbsoluteUrl(relativeUrl);\n }\n\n public abstract generateAttachMessage(): IAttachMessage;\n\n protected abstract getInitialSnapshotDetails(): Promise<ISnapshotDetails>;\n\n public abstract getInitialGCSummaryDetails(): Promise<IGarbageCollectionSummaryDetails>;\n\n public reSubmit(contents: any, localOpMetadata: unknown) {\n assert(!!this.channel, 0x14b /* \"Channel must exist when resubmitting ops\" */);\n const innerContents = contents as FluidDataStoreMessage;\n this.channel.reSubmit(innerContents.type, innerContents.content, localOpMetadata);\n }\n\n public async applyStashedOp(contents: any): Promise<unknown> {\n if (!this.channel) {\n await this.realize();\n }\n assert(!!this.channel, 0x14c /* \"Channel must exist when rebasing ops\" */);\n const innerContents = contents as FluidDataStoreMessage;\n return this.channel.applyStashedOp(innerContents.content);\n }\n\n private verifyNotClosed() {\n if (this._disposed) {\n throw new Error(\"Context is closed\");\n }\n }\n\n public getCreateChildSummarizerNodeFn(id: string, createParam: CreateChildSummarizerNodeParam) {\n return (\n summarizeInternal: SummarizeInternalFn,\n getGCDataFn: (fullGC?: boolean) => Promise<IGarbageCollectionData>,\n getInitialGCSummaryDetailsFn: () => Promise<IGarbageCollectionSummaryDetails>,\n ) => this.summarizerNode.createChild(\n summarizeInternal,\n id,\n createParam,\n // DDS will not create failure summaries\n { throwOnFailure: true },\n getGCDataFn,\n getInitialGCSummaryDetailsFn,\n );\n }\n\n public async uploadBlob(blob: ArrayBufferLike): Promise<IFluidHandle<ArrayBufferLike>> {\n return this.containerRuntime.uploadBlob(blob);\n }\n}\n\nexport class RemotedFluidDataStoreContext extends FluidDataStoreContext {\n constructor(\n id: string,\n private readonly initSnapshotValue: ISnapshotTree | string | undefined,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: IFluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n pkg?: string[],\n ) {\n super(\n runtime,\n id,\n true,\n storage,\n scope,\n createSummarizerNode,\n BindState.Bound,\n false,\n () => {\n throw new Error(\"Already attached\");\n },\n pkg,\n );\n }\n\n private readonly initialSnapshotDetailsP = new LazyPromise<ISnapshotDetails>(async () => {\n let tree: ISnapshotTree | undefined;\n let isRootDataStore = true;\n\n if (typeof this.initSnapshotValue === \"string\") {\n const commit = (await this.storage.getVersions(this.initSnapshotValue, 1))[0];\n tree = await this.storage.getSnapshotTree(commit) ?? undefined;\n } else {\n tree = this.initSnapshotValue;\n }\n\n const localReadAndParse = async <T>(id: string) => readAndParse<T>(this.storage, id);\n if (tree) {\n const loadedSummary = await this.summarizerNode.loadBaseSummary(tree, localReadAndParse);\n tree = loadedSummary.baseSummary;\n // Prepend outstanding ops to pending queue of ops to process.\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.pending = loadedSummary.outstandingOps.concat(this.pending!);\n }\n\n if (!!tree && tree.blobs[dataStoreAttributesBlobName] !== undefined) {\n // Need to get through snapshot and use that to populate extraBlobs\n const attributes =\n await localReadAndParse<ReadFluidDataStoreAttributes>(tree.blobs[dataStoreAttributesBlobName]);\n\n let pkgFromSnapshot: string[];\n // Use the snapshotFormatVersion to determine how the pkg is encoded in the snapshot.\n // For snapshotFormatVersion = \"0.1\" (1) or above, pkg is jsonified, otherwise it is just a string.\n const formatVersion = getAttributesFormatVersion(attributes);\n if (formatVersion < 1) {\n if (attributes.pkg.startsWith(\"[\\\"\") && attributes.pkg.endsWith(\"\\\"]\")) {\n pkgFromSnapshot = JSON.parse(attributes.pkg) as string[];\n } else {\n pkgFromSnapshot = [attributes.pkg];\n }\n } else {\n pkgFromSnapshot = JSON.parse(attributes.pkg) as string[];\n }\n this.pkg = pkgFromSnapshot;\n\n /**\n * If there is no isRootDataStore in the attributes blob, set it to true. This will ensure that\n * data stores in older documents are not garbage collected incorrectly. This may lead to additional\n * roots in the document but they won't break.\n */\n isRootDataStore = attributes.isRootDataStore ?? true;\n\n if (hasIsolatedChannels(attributes)) {\n tree = tree.trees[channelsTreeName];\n assert(tree !== undefined,\n 0x1fe /* \"isolated channels subtree should exist in remote datastore snapshot\" */);\n }\n }\n\n return {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n pkg: this.pkg!,\n snapshot: tree,\n isRootDataStore,\n };\n });\n\n private readonly gcDetailsInInitialSummaryP = new LazyPromise<IGarbageCollectionSummaryDetails>(async () => {\n // If the initial snapshot is undefined or string, the snapshot is in old format and won't have GC details.\n if (!(!this.initSnapshotValue || typeof this.initSnapshotValue === \"string\")\n && this.initSnapshotValue.blobs[gcBlobKey] !== undefined) {\n return readAndParse<IGarbageCollectionSummaryDetails>(\n this.storage,\n this.initSnapshotValue.blobs[gcBlobKey],\n );\n } else {\n return {};\n }\n });\n\n protected async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n return this.initialSnapshotDetailsP;\n }\n\n public async getInitialGCSummaryDetails(): Promise<IGarbageCollectionSummaryDetails> {\n return this.gcDetailsInInitialSummaryP;\n }\n\n public generateAttachMessage(): IAttachMessage {\n throw new Error(\"Cannot attach remote store\");\n }\n}\n\n/**\n * Base class for detached & attached context classes\n */\nexport class LocalFluidDataStoreContextBase extends FluidDataStoreContext {\n constructor(\n id: string,\n pkg: Readonly<string[]> | undefined,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: IFluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n private readonly snapshotTree: ISnapshotTree | undefined,\n protected isRootDataStore: boolean | undefined,\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n public readonly createProps?: any,\n ) {\n super(\n runtime,\n id,\n snapshotTree !== undefined ? true : false,\n storage,\n scope,\n createSummarizerNode,\n snapshotTree ? BindState.Bound : BindState.NotBound,\n true,\n bindChannel,\n pkg);\n this.attachListeners();\n }\n\n private attachListeners(): void {\n this.once(\"attaching\", () => {\n assert(this.attachState === AttachState.Detached, 0x14d /* \"Should move from detached to attaching\" */);\n this._attachState = AttachState.Attaching;\n });\n this.once(\"attached\", () => {\n assert(this.attachState === AttachState.Attaching, 0x14e /* \"Should move from attaching to attached\" */);\n this._attachState = AttachState.Attached;\n });\n }\n\n public generateAttachMessage(): IAttachMessage {\n assert(this.channel !== undefined, 0x14f /* \"There should be a channel when generating attach message\" */);\n assert(this.pkg !== undefined, 0x150 /* \"pkg should be available in local data store context\" */);\n assert(this.isRootDataStore !== undefined,\n 0x151 /* \"isRootDataStore should be available in local data store context\" */);\n\n const summarizeResult = this.channel.getAttachSummary();\n\n if (!this.disableIsolatedChannels) {\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n }\n\n // Add data store's attributes to the summary.\n const attributes = createAttributes(\n this.pkg,\n this.isRootDataStore,\n this.disableIsolatedChannels,\n );\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\n\n // Add GC details to the summary.\n addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));\n\n // Attach message needs the summary in ITree format. Convert the ISummaryTree into an ITree.\n const snapshot = convertSummaryTreeToITree(summarizeResult.summary);\n\n const message: IAttachMessage = {\n id: this.id,\n snapshot,\n type: this.pkg[this.pkg.length - 1],\n };\n\n return message;\n }\n\n protected async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n let snapshot = this.snapshotTree;\n let attributes: ReadFluidDataStoreAttributes;\n if (snapshot !== undefined) {\n // Get the dataStore attributes.\n // Note: storage can be undefined in special case while detached.\n attributes = await getFluidDataStoreAttributes(this.storage, snapshot);\n if (hasIsolatedChannels(attributes)) {\n snapshot = snapshot.trees[channelsTreeName];\n assert(snapshot !== undefined,\n 0x1ff /* \"isolated channels subtree should exist in local datastore snapshot\" */);\n }\n if (this.pkg === undefined) {\n this.pkg = JSON.parse(attributes.pkg) as string[];\n // If there is no isRootDataStore in the attributes blob, set it to true. This ensures that data\n // stores in older documents are not garbage collected incorrectly. This may lead to additional\n // roots in the document but they won't break.\n this.isRootDataStore = attributes.isRootDataStore ?? true;\n }\n }\n assert(this.pkg !== undefined, 0x152 /* \"pkg should be available in local data store\" */);\n assert(this.isRootDataStore !== undefined,\n 0x153 /* \"isRootDataStore should be available in local data store\" */);\n\n return {\n pkg: this.pkg,\n snapshot,\n isRootDataStore: this.isRootDataStore,\n };\n }\n\n public async getInitialGCSummaryDetails(): Promise<IGarbageCollectionSummaryDetails> {\n // Local data store does not have initial summary.\n return {};\n }\n}\n\n/**\n * context implementation for \"attached\" data store runtime.\n * Various workflows (snapshot creation, requests) result in .realize() being called\n * on context, resulting in instantiation and attachment of runtime.\n * Runtime is created using data store factory that is associated with this context.\n */\nexport class LocalFluidDataStoreContext extends LocalFluidDataStoreContextBase {\n constructor(\n id: string,\n pkg: string[] | undefined,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: IFluidObject & IFluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n snapshotTree: ISnapshotTree | undefined,\n isRootDataStore: boolean | undefined,\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n createProps?: any,\n ) {\n super(\n id,\n pkg,\n runtime,\n storage,\n scope,\n createSummarizerNode,\n bindChannel,\n snapshotTree,\n isRootDataStore,\n createProps);\n }\n}\n\n/**\n * Detached context. Data Store runtime will be attached to it by attachRuntime() call\n * Before attachment happens, this context is not associated with particular type of runtime\n * or factory, i.e. it's package path is undefined.\n * Attachment process provides all missing parts - package path, data store runtime, and data store factory\n */\nexport class LocalDetachedFluidDataStoreContext\n extends LocalFluidDataStoreContextBase\n implements IFluidDataStoreContextDetached\n{\n constructor(\n id: string,\n pkg: Readonly<string[]>,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: IFluidObject & IFluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n isRootDataStore: boolean,\n ) {\n super(\n id,\n pkg,\n runtime,\n storage,\n scope,\n createSummarizerNode,\n bindChannel,\n undefined,\n isRootDataStore,\n );\n this.detachedRuntimeCreation = true;\n }\n\n public async attachRuntime(\n registry: IProvideFluidDataStoreFactory,\n dataStoreRuntime: IFluidDataStoreChannel)\n {\n assert(this.detachedRuntimeCreation, 0x154 /* \"runtime creation is already attached\" */);\n assert(this.channelDeferred === undefined, 0x155 /* \"channel deferral is already set\" */);\n\n const factory = registry.IFluidDataStoreFactory;\n\n const entry = await this.factoryFromPackagePath(this.pkg);\n assert(entry.factory === factory, 0x156 /* \"Unexpected factory for package path\" */);\n\n assert(this.registry === undefined, 0x157 /* \"datastore registry already attached\" */);\n this.registry = entry.registry;\n\n this.detachedRuntimeCreation = false;\n this.channelDeferred = new Deferred<IFluidDataStoreChannel>();\n\n super.bindRuntime(dataStoreRuntime);\n\n if (this.isRootDataStore) {\n dataStoreRuntime.bindToContext();\n }\n }\n\n protected async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n if (this.detachedRuntimeCreation) {\n throw new Error(\"Detached Fluid Data Store context can't be realized! Please attach runtime first!\");\n }\n return super.getInitialSnapshotDetails();\n }\n}\n"]}
1
+ {"version":3,"file":"dataStoreContext.js","sourceRoot":"","sources":["../src/dataStoreContext.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { IDisposable, ITelemetryLogger } from \"@fluidframework/common-definitions\";\nimport {\n FluidObject,\n IRequest,\n IResponse,\n IFluidHandle,\n} from \"@fluidframework/core-interfaces\";\nimport {\n IAudience,\n IDeltaManager,\n ContainerWarning,\n BindState,\n AttachState,\n ILoaderOptions,\n} from \"@fluidframework/container-definitions\";\nimport {\n assert,\n Deferred,\n LazyPromise,\n TypedEventEmitter,\n} from \"@fluidframework/common-utils\";\nimport { IDocumentStorageService } from \"@fluidframework/driver-definitions\";\nimport { readAndParse } from \"@fluidframework/driver-utils\";\nimport { BlobTreeEntry } from \"@fluidframework/protocol-base\";\nimport {\n IClientDetails,\n IDocumentMessage,\n IQuorum,\n ISequencedDocumentMessage,\n ISnapshotTree,\n ITreeEntry,\n} from \"@fluidframework/protocol-definitions\";\nimport {\n IContainerRuntime,\n} from \"@fluidframework/container-runtime-definitions\";\nimport {\n channelsTreeName,\n CreateChildSummarizerNodeFn,\n CreateChildSummarizerNodeParam,\n FluidDataStoreRegistryEntry,\n gcBlobKey,\n IAttachMessage,\n IFluidDataStoreChannel,\n IFluidDataStoreContext,\n IFluidDataStoreContextDetached,\n IFluidDataStoreContextEvents,\n IFluidDataStoreRegistry,\n IGarbageCollectionData,\n IGarbageCollectionSummaryDetails,\n IInboundSignalMessage,\n IProvideFluidDataStoreFactory,\n ISummarizeInternalResult,\n ISummarizeResult,\n ISummarizerNodeWithGC,\n SummarizeInternalFn,\n} from \"@fluidframework/runtime-definitions\";\nimport { addBlobToSummary, convertSummaryTreeToITree } from \"@fluidframework/runtime-utils\";\nimport {\n ChildLogger,\n LoggingError,\n TelemetryDataTag,\n ThresholdCounter,\n} from \"@fluidframework/telemetry-utils\";\nimport { CreateProcessingError } from \"@fluidframework/container-utils\";\nimport { ContainerRuntime } from \"./containerRuntime\";\nimport {\n dataStoreAttributesBlobName,\n hasIsolatedChannels,\n wrapSummaryInChannelsTree,\n ReadFluidDataStoreAttributes,\n WriteFluidDataStoreAttributes,\n getAttributesFormatVersion,\n getFluidDataStoreAttributes,\n} from \"./summaryFormat\";\n\nfunction createAttributes(\n pkg: readonly string[],\n isRootDataStore: boolean,\n disableIsolatedChannels: boolean,\n): WriteFluidDataStoreAttributes {\n const stringifiedPkg = JSON.stringify(pkg);\n return disableIsolatedChannels ? {\n pkg: stringifiedPkg,\n snapshotFormatVersion: \"0.1\",\n isRootDataStore,\n } : {\n pkg: stringifiedPkg,\n summaryFormatVersion: 2,\n isRootDataStore,\n };\n}\nexport function createAttributesBlob(\n pkg: readonly string[],\n isRootDataStore: boolean,\n disableIsolatedChannels: boolean,\n): ITreeEntry {\n const attributes = createAttributes(pkg, isRootDataStore, disableIsolatedChannels);\n return new BlobTreeEntry(dataStoreAttributesBlobName, JSON.stringify(attributes));\n}\n\ninterface ISnapshotDetails {\n pkg: readonly string[];\n /**\n * This tells whether a data store is root. Root data stores are never collected.\n * Non-root data stores may be collected if they are not used.\n */\n isRootDataStore: boolean;\n snapshot?: ISnapshotTree;\n}\n\ninterface FluidDataStoreMessage {\n content: any;\n type: string;\n}\n\n/**\n * Represents the context for the store. This context is passed to the store runtime.\n */\nexport abstract class FluidDataStoreContext extends TypedEventEmitter<IFluidDataStoreContextEvents> implements\n IFluidDataStoreContext,\n IDisposable {\n public get packagePath(): readonly string[] {\n assert(this.pkg !== undefined, 0x139 /* \"Undefined package path\" */);\n return this.pkg;\n }\n\n public get options(): ILoaderOptions {\n return this._containerRuntime.options;\n }\n\n public get clientId(): string | undefined {\n return this._containerRuntime.clientId;\n }\n\n public get clientDetails(): IClientDetails {\n return this._containerRuntime.clientDetails;\n }\n\n public get logger(): ITelemetryLogger {\n return this._containerRuntime.logger;\n }\n\n public get deltaManager(): IDeltaManager<ISequencedDocumentMessage, IDocumentMessage> {\n return this._containerRuntime.deltaManager;\n }\n\n public get connected(): boolean {\n return this._containerRuntime.connected;\n }\n\n public get IFluidHandleContext() {\n return this._containerRuntime.IFluidHandleContext;\n }\n\n public get containerRuntime(): IContainerRuntime {\n return this._containerRuntime;\n }\n\n public get isLoaded(): boolean {\n return this.loaded;\n }\n\n public get baseSnapshot(): ISnapshotTree | undefined {\n return this._baseSnapshot;\n }\n\n private _disposed = false;\n public get disposed() { return this._disposed; }\n\n public get attachState(): AttachState {\n return this._attachState;\n }\n\n public get IFluidDataStoreRegistry(): IFluidDataStoreRegistry | undefined {\n return this.registry;\n }\n\n public async isRoot(): Promise<boolean> {\n return (await this.getInitialSnapshotDetails()).isRootDataStore;\n }\n\n protected get disableIsolatedChannels(): boolean {\n return this._containerRuntime.disableIsolatedChannels;\n }\n\n /** Tells whether GC data will be written at the root of the summary tree. If so, data store should not write it. */\n protected get writeGCDataAtRoot(): boolean {\n return this._containerRuntime.writeGCDataAtRoot;\n }\n\n protected registry: IFluidDataStoreRegistry | undefined;\n\n protected detachedRuntimeCreation = false;\n public readonly bindToContext: () => void;\n protected channel: IFluidDataStoreChannel | undefined;\n private loaded = false;\n protected pending: ISequencedDocumentMessage[] | undefined = [];\n protected channelDeferred: Deferred<IFluidDataStoreChannel> | undefined;\n private _baseSnapshot: ISnapshotTree | undefined;\n protected _attachState: AttachState;\n protected readonly summarizerNode: ISummarizerNodeWithGC;\n private readonly subLogger: ITelemetryLogger;\n private readonly thresholdOpsCounter: ThresholdCounter;\n private static readonly pendingOpsCountThreshold = 1000;\n\n // The used state of this node as per the last GC run. This is used to update the used state of the channel\n // if it realizes after GC is run.\n private lastUsedState: { usedRoutes: string[], gcTimestamp?: number } | undefined;\n\n constructor(\n private readonly _containerRuntime: ContainerRuntime,\n public readonly id: string,\n private readonly existing: boolean,\n public readonly storage: IDocumentStorageService,\n public readonly scope: FluidObject | FluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n private bindState: BindState,\n public readonly isLocalDataStore: boolean,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n protected pkg?: readonly string[],\n ) {\n super();\n\n // URIs use slashes as delimiters. Handles use URIs.\n // Thus having slashes in types almost guarantees trouble down the road!\n assert(id.indexOf(\"/\") === -1, 0x13a /* `Data store ID contains slash: ${id}` */);\n\n this._attachState = this.containerRuntime.attachState !== AttachState.Detached && this.existing ?\n this.containerRuntime.attachState : AttachState.Detached;\n\n this.bindToContext = () => {\n assert(this.bindState === BindState.NotBound, 0x13b /* \"datastore context is already in bound state\" */);\n this.bindState = BindState.Binding;\n assert(this.channel !== undefined, 0x13c /* \"undefined channel on datastore context\" */);\n bindChannel(this.channel);\n this.bindState = BindState.Bound;\n };\n\n const thisSummarizeInternal =\n async (fullTree: boolean, trackState: boolean) => this.summarizeInternal(fullTree, trackState);\n\n this.summarizerNode = createSummarizerNode(\n thisSummarizeInternal,\n async (fullGC?: boolean) => this.getGCDataInternal(fullGC),\n async () => this.getInitialGCSummaryDetails(),\n );\n\n this.subLogger = ChildLogger.create(this.logger, \"FluidDataStoreContext\");\n this.thresholdOpsCounter = new ThresholdCounter(FluidDataStoreContext.pendingOpsCountThreshold, this.subLogger);\n }\n\n public dispose(): void {\n if (this._disposed) {\n return;\n }\n this._disposed = true;\n\n // Dispose any pending runtime after it gets fulfilled\n // Errors are logged where this.channelDeferred is consumed/generated (realizeCore(), bindRuntime())\n if (this.channelDeferred) {\n this.channelDeferred.promise.then((runtime) => {\n runtime.dispose();\n }).catch((error) => {});\n }\n }\n\n private rejectDeferredRealize(reason: string, packageName?: string): never {\n throw new LoggingError(reason, { packageName: { value: packageName, tag: TelemetryDataTag.PackageData }});\n }\n\n public async realize(): Promise<IFluidDataStoreChannel> {\n assert(!this.detachedRuntimeCreation, 0x13d /* \"Detached runtime creation on realize()\" */);\n if (!this.channelDeferred) {\n this.channelDeferred = new Deferred<IFluidDataStoreChannel>();\n this.realizeCore(this.existing).catch((error) => {\n const errorWrapped = CreateProcessingError(error, \"realizeFluidDataStoreContext\");\n errorWrapped.addTelemetryProperties({ fluidDataStoreId: { value: this.id, tag: \"PackageData\"} });\n this.channelDeferred?.reject(errorWrapped);\n this.logger.sendErrorEvent({ eventName: \"RealizeError\"}, errorWrapped);\n });\n }\n return this.channelDeferred.promise;\n }\n\n protected async factoryFromPackagePath(packages?: readonly string[]) {\n assert(this.pkg === packages, 0x13e /* \"Unexpected package path\" */);\n if (packages === undefined) {\n this.rejectDeferredRealize(\"packages is undefined\");\n }\n\n let entry: FluidDataStoreRegistryEntry | undefined;\n let registry: IFluidDataStoreRegistry | undefined = this._containerRuntime.IFluidDataStoreRegistry;\n let lastPkg: string | undefined;\n for (const pkg of packages) {\n if (!registry) {\n this.rejectDeferredRealize(\"No registry for package\", lastPkg);\n }\n lastPkg = pkg;\n entry = await registry.get(pkg);\n if (!entry) {\n this.rejectDeferredRealize(\"Registry does not contain entry for the package\", pkg);\n }\n registry = entry.IFluidDataStoreRegistry;\n }\n const factory = entry?.IFluidDataStoreFactory;\n if (factory === undefined) {\n this.rejectDeferredRealize(\"Can't find factory for package\", lastPkg);\n }\n\n return { factory, registry };\n }\n\n private async realizeCore(existing: boolean): Promise<void> {\n const details = await this.getInitialSnapshotDetails();\n // Base snapshot is the baseline where pending ops are applied to.\n // It is important that this be in sync with the pending ops, and also\n // that it is set here, before bindRuntime is called.\n this._baseSnapshot = details.snapshot;\n const packages = details.pkg;\n\n const { factory, registry } = await this.factoryFromPackagePath(packages);\n\n assert(this.registry === undefined, 0x13f /* \"datastore context registry is already set\" */);\n this.registry = registry;\n\n const channel = await factory.instantiateDataStore(this, existing);\n assert(channel !== undefined, 0x140 /* \"undefined channel on datastore context\" */);\n this.bindRuntime(channel);\n }\n\n /**\n * Notifies this object about changes in the connection state.\n * @param value - New connection state.\n * @param clientId - ID of the client. It's old ID when in disconnected state and\n * it's new client ID when we are connecting or connected.\n */\n public setConnectionState(connected: boolean, clientId?: string) {\n this.verifyNotClosed();\n\n // Connection events are ignored if the store is not yet loaded\n if (!this.loaded) {\n return;\n }\n\n assert(this.connected === connected, 0x141 /* \"Unexpected connected state\" */);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.channel!.setConnectionState(connected, clientId);\n }\n\n public process(messageArg: ISequencedDocumentMessage, local: boolean, localOpMetadata: unknown): void {\n this.verifyNotClosed();\n\n const innerContents = messageArg.contents as FluidDataStoreMessage;\n const message = {\n ...messageArg,\n type: innerContents.type,\n contents: innerContents.content,\n };\n\n this.summarizerNode.recordChange(message);\n\n if (this.loaded) {\n return this.channel?.process(message, local, localOpMetadata);\n } else {\n assert(!local, 0x142 /* \"local store channel is not loaded\" */);\n assert(this.pending !== undefined, 0x23d /* \"pending is undefined\" */);\n this.pending.push(message);\n this.thresholdOpsCounter.sendIfMultiple(\"StorePendingOps\", this.pending.length);\n }\n }\n\n public processSignal(message: IInboundSignalMessage, local: boolean): void {\n this.verifyNotClosed();\n\n // Signals are ignored if the store is not yet loaded\n if (!this.loaded) {\n return;\n }\n\n this.channel?.processSignal(message, local);\n }\n\n public getQuorum(): IQuorum {\n return this._containerRuntime.getQuorum();\n }\n\n public getAudience(): IAudience {\n return this._containerRuntime.getAudience();\n }\n\n /**\n * Returns a summary at the current sequence number.\n * @param fullTree - true to bypass optimizations and force a full summary tree\n * @param trackState - This tells whether we should track state from this summary.\n */\n public async summarize(fullTree: boolean = false, trackState: boolean = true): Promise<ISummarizeResult> {\n return this.summarizerNode.summarize(fullTree, trackState);\n }\n\n private async summarizeInternal(fullTree: boolean, trackState: boolean): Promise<ISummarizeInternalResult> {\n await this.realize();\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const summarizeResult = await this.channel!.summarize(fullTree, trackState);\n let pathPartsForChildren: string[] | undefined;\n\n if (!this.disableIsolatedChannels) {\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n pathPartsForChildren = [channelsTreeName];\n }\n\n // Add data store's attributes to the summary.\n const { pkg, isRootDataStore } = await this.getInitialSnapshotDetails();\n const attributes = createAttributes(pkg, isRootDataStore, this.disableIsolatedChannels);\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\n\n // Add GC data to the summary if it's not written at the root.\n if (!this.writeGCDataAtRoot) {\n addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));\n }\n\n // If we are not referenced, mark the summary tree as unreferenced. Also, update unreferenced blob\n // size in the summary stats with the blobs size of this data store.\n if (!this.summarizerNode.isReferenced()) {\n summarizeResult.summary.unreferenced = true;\n summarizeResult.stats.unreferencedBlobSize = summarizeResult.stats.totalBlobSize;\n }\n\n return {\n ...summarizeResult,\n id: this.id,\n pathPartsForChildren,\n };\n }\n\n /**\n * Returns the data used for garbage collection. This includes a list of GC nodes that represent this data store\n * including any of its child channel contexts. Each node has a set of outbound routes to other GC nodes in the\n * document.\n * If there is no new data in this data store since the last summary, previous GC data is used.\n * If there is new data, the GC data is generated again (by calling getGCDataInternal).\n * @param fullGC - true to bypass optimizations and force full generation of GC data.\n */\n public async getGCData(fullGC: boolean = false): Promise<IGarbageCollectionData> {\n return this.summarizerNode.getGCData(fullGC);\n }\n\n /**\n * Generates data used for garbage collection. This is called when there is new data since last summary. It\n * realizes the data store and calls into each channel context to get its GC data.\n * @param fullGC - true to bypass optimizations and force full generation of GC data.\n */\n private async getGCDataInternal(fullGC: boolean = false): Promise<IGarbageCollectionData> {\n await this.realize();\n assert(this.channel !== undefined, 0x143 /* \"Channel should not be undefined when running GC\" */);\n\n return this.channel.getGCData(fullGC);\n }\n\n /**\n * After GC has run, called to notify the data store of routes used in it. These are used for the following:\n * 1. To identify if this data store is being referenced in the document or not.\n * 2. To determine if it needs to re-summarize in case used routes changed since last summary.\n * 3. These are added to the summary generated by the data store.\n * 4. To notify child contexts of their used routes. This is done immediately if the data store is loaded. Else,\n * it is done when realizing the data store.\n * 5. To update the timestamp when this data store or any children are marked as unreferenced.\n * @param usedRoutes - The routes that are used in this data store.\n * @param gcTimestamp - The time when GC was run that generated these used routes. If any node becomes unreferenced\n * as part of this GC run, this should be used to update the time when it happens.\n */\n public updateUsedRoutes(usedRoutes: string[], gcTimestamp?: number) {\n // Update the used routes in this data store's summarizer node.\n this.summarizerNode.updateUsedRoutes(usedRoutes, gcTimestamp);\n\n /**\n * If the data store has not been realized yet, we need this used state to update the used state of the channel\n * when it realizes. It's safe to keep only the last used state because if something changes because of this GC\n * run, the data store will be immediately realized as part of the summary that follows GC. For example, if a\n * child's reference state changes, the gcTimestamp has to be used to update its unreferencedTimestamp. Since\n * it will result in a change in this data store's used routes, it will be realized to regenerate its summary.\n */\n this.lastUsedState = { usedRoutes, gcTimestamp };\n\n // If we are loaded, call the channel so it can update the used routes of the child contexts.\n // If we are not loaded, we will update this when we are realized.\n if (this.loaded) {\n this.updateChannelUsedRoutes();\n }\n }\n\n /**\n * Updates the used routes of the channel and its child contexts. The channel must be loaded before calling this.\n * It is called in these two scenarions:\n * 1. When the used routes of the data store is updated and the data store is loaded.\n * 2. When the data store is realized. This updates the channel's used routes as per last GC run.\n */\n private updateChannelUsedRoutes() {\n assert(this.loaded, 0x144 /* \"Channel should be loaded when updating used routes\" */);\n assert(this.channel !== undefined, 0x145 /* \"Channel should be present when data store is loaded\" */);\n\n // If there is no lastUsedState, GC has not run up until this point.\n if (this.lastUsedState === undefined) {\n return;\n }\n\n // Remove the route to this data store, if it exists.\n const usedChannelRoutes = this.lastUsedState.usedRoutes.filter(\n (id: string) => { return id !== \"/\" && id !== \"\"; },\n );\n this.channel.updateUsedRoutes(usedChannelRoutes, this.lastUsedState.gcTimestamp);\n }\n\n /**\n * @deprecated 0.18.Should call request on the runtime directly\n */\n public async request(request: IRequest): Promise<IResponse> {\n const runtime = await this.realize();\n return runtime.request(request);\n }\n\n public submitMessage(type: string, content: any, localOpMetadata: unknown): void {\n this.verifyNotClosed();\n assert(!!this.channel, 0x146 /* \"Channel must exist when submitting message\" */);\n const fluidDataStoreContent: FluidDataStoreMessage = {\n content,\n type,\n };\n this._containerRuntime.submitDataStoreOp(\n this.id,\n fluidDataStoreContent,\n localOpMetadata);\n }\n\n /**\n * This is called from a SharedSummaryBlock that does not generate ops but only wants to be part of the summary.\n * It indicates that there is data in the object that needs to be summarized.\n * We will update the latestSequenceNumber of the summary tracker of this\n * store and of the object's channel.\n *\n * @param address - The address of the channel that is dirty.\n *\n */\n public setChannelDirty(address: string): void {\n this.verifyNotClosed();\n\n // Get the latest sequence number.\n const latestSequenceNumber = this.deltaManager.lastSequenceNumber;\n\n this.summarizerNode.invalidate(latestSequenceNumber);\n\n const channelSummarizerNode = this.summarizerNode.getChild(address);\n\n if (channelSummarizerNode) {\n channelSummarizerNode.invalidate(latestSequenceNumber); // TODO: lazy load problem?\n }\n }\n\n public submitSignal(type: string, content: any) {\n this.verifyNotClosed();\n assert(!!this.channel, 0x147 /* \"Channel must exist on submitting signal\" */);\n return this._containerRuntime.submitDataStoreSignal(this.id, type, content);\n }\n\n // @deprecated Warnings are being deprecated\n public raiseContainerWarning(warning: ContainerWarning): void {\n this.containerRuntime.raiseContainerWarning(warning);\n }\n\n protected bindRuntime(channel: IFluidDataStoreChannel) {\n if (this.channel) {\n throw new Error(\"Runtime already bound\");\n }\n\n try\n {\n assert(!this.detachedRuntimeCreation, 0x148 /* \"Detached runtime creation on runtime bind\" */);\n assert(this.channelDeferred !== undefined, 0x149 /* \"Undefined channel defferal\" */);\n assert(this.pkg !== undefined, 0x14a /* \"Undefined package path\" */);\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const pending = this.pending!;\n\n // Apply all pending ops\n for (const op of pending) {\n channel.process(op, false, undefined /* localOpMetadata */);\n }\n\n this.thresholdOpsCounter.send(\"ProcessPendingOps\", pending.length);\n this.pending = undefined;\n\n // And now mark the runtime active\n this.loaded = true;\n this.channel = channel;\n\n // Freeze the package path to ensure that someone doesn't modify it when it is\n // returned in packagePath().\n Object.freeze(this.pkg);\n\n /**\n * Update the used routes of the channel. If GC has run before this data store was realized, we will have\n * the used routes saved. So, this will ensure that all the child contexts have up-to-date used routes as\n * per the last time GC was run.\n * Also, this data store may have been realized during summarize. In that case, the child contexts need to\n * have their used routes updated to determine if its needs to summarize again and to add it to the summary.\n */\n this.updateChannelUsedRoutes();\n\n // And notify the pending promise it is now available\n this.channelDeferred.resolve(this.channel);\n } catch (error) {\n this.channelDeferred?.reject(error);\n this.logger.sendErrorEvent(\n { eventName: \"BindRuntimeError\", fluidDataStoreId: { value: this.id, tag: \"PackageData\"} },\n error);\n }\n }\n\n public async getAbsoluteUrl(relativeUrl: string): Promise<string | undefined> {\n if (this.attachState !== AttachState.Attached) {\n return undefined;\n }\n return this._containerRuntime.getAbsoluteUrl(relativeUrl);\n }\n\n public abstract generateAttachMessage(): IAttachMessage;\n\n protected abstract getInitialSnapshotDetails(): Promise<ISnapshotDetails>;\n\n public abstract getInitialGCSummaryDetails(): Promise<IGarbageCollectionSummaryDetails>;\n\n public reSubmit(contents: any, localOpMetadata: unknown) {\n assert(!!this.channel, 0x14b /* \"Channel must exist when resubmitting ops\" */);\n const innerContents = contents as FluidDataStoreMessage;\n this.channel.reSubmit(innerContents.type, innerContents.content, localOpMetadata);\n }\n\n public async applyStashedOp(contents: any): Promise<unknown> {\n if (!this.channel) {\n await this.realize();\n }\n assert(!!this.channel, 0x14c /* \"Channel must exist when rebasing ops\" */);\n const innerContents = contents as FluidDataStoreMessage;\n return this.channel.applyStashedOp(innerContents.content);\n }\n\n private verifyNotClosed() {\n if (this._disposed) {\n throw new Error(\"Context is closed\");\n }\n }\n\n public getCreateChildSummarizerNodeFn(id: string, createParam: CreateChildSummarizerNodeParam) {\n return (\n summarizeInternal: SummarizeInternalFn,\n getGCDataFn: (fullGC?: boolean) => Promise<IGarbageCollectionData>,\n getInitialGCSummaryDetailsFn: () => Promise<IGarbageCollectionSummaryDetails>,\n ) => this.summarizerNode.createChild(\n summarizeInternal,\n id,\n createParam,\n // DDS will not create failure summaries\n { throwOnFailure: true },\n getGCDataFn,\n getInitialGCSummaryDetailsFn,\n );\n }\n\n public async uploadBlob(blob: ArrayBufferLike): Promise<IFluidHandle<ArrayBufferLike>> {\n return this.containerRuntime.uploadBlob(blob);\n }\n}\n\nexport class RemotedFluidDataStoreContext extends FluidDataStoreContext {\n constructor(\n id: string,\n private readonly initSnapshotValue: ISnapshotTree | string | undefined,\n private readonly getBaseSummaryGCDetails: () => Promise<IGarbageCollectionSummaryDetails | undefined>,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: FluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n pkg?: string[],\n ) {\n super(\n runtime,\n id,\n true,\n storage,\n scope,\n createSummarizerNode,\n BindState.Bound,\n false,\n () => {\n throw new Error(\"Already attached\");\n },\n pkg,\n );\n }\n\n private readonly initialSnapshotDetailsP = new LazyPromise<ISnapshotDetails>(async () => {\n let tree: ISnapshotTree | undefined;\n let isRootDataStore = true;\n\n if (typeof this.initSnapshotValue === \"string\") {\n const commit = (await this.storage.getVersions(this.initSnapshotValue, 1))[0];\n tree = await this.storage.getSnapshotTree(commit) ?? undefined;\n } else {\n tree = this.initSnapshotValue;\n }\n\n const localReadAndParse = async <T>(id: string) => readAndParse<T>(this.storage, id);\n if (tree) {\n const loadedSummary = await this.summarizerNode.loadBaseSummary(tree, localReadAndParse);\n tree = loadedSummary.baseSummary;\n // Prepend outstanding ops to pending queue of ops to process.\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.pending = loadedSummary.outstandingOps.concat(this.pending!);\n }\n\n if (!!tree && tree.blobs[dataStoreAttributesBlobName] !== undefined) {\n // Need to get through snapshot and use that to populate extraBlobs\n const attributes =\n await localReadAndParse<ReadFluidDataStoreAttributes>(tree.blobs[dataStoreAttributesBlobName]);\n\n let pkgFromSnapshot: string[];\n // Use the snapshotFormatVersion to determine how the pkg is encoded in the snapshot.\n // For snapshotFormatVersion = \"0.1\" (1) or above, pkg is jsonified, otherwise it is just a string.\n const formatVersion = getAttributesFormatVersion(attributes);\n if (formatVersion < 1) {\n if (attributes.pkg.startsWith(\"[\\\"\") && attributes.pkg.endsWith(\"\\\"]\")) {\n pkgFromSnapshot = JSON.parse(attributes.pkg) as string[];\n } else {\n pkgFromSnapshot = [attributes.pkg];\n }\n } else {\n pkgFromSnapshot = JSON.parse(attributes.pkg) as string[];\n }\n this.pkg = pkgFromSnapshot;\n\n /**\n * If there is no isRootDataStore in the attributes blob, set it to true. This will ensure that\n * data stores in older documents are not garbage collected incorrectly. This may lead to additional\n * roots in the document but they won't break.\n */\n isRootDataStore = attributes.isRootDataStore ?? true;\n\n if (hasIsolatedChannels(attributes)) {\n tree = tree.trees[channelsTreeName];\n assert(tree !== undefined,\n 0x1fe /* \"isolated channels subtree should exist in remote datastore snapshot\" */);\n }\n }\n\n return {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n pkg: this.pkg!,\n snapshot: tree,\n isRootDataStore,\n };\n });\n\n private readonly gcDetailsInInitialSummaryP = new LazyPromise<IGarbageCollectionSummaryDetails>(async () => {\n return (await this.getBaseSummaryGCDetails()) ?? {};\n });\n\n protected async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n return this.initialSnapshotDetailsP;\n }\n\n public async getInitialGCSummaryDetails(): Promise<IGarbageCollectionSummaryDetails> {\n return this.gcDetailsInInitialSummaryP;\n }\n\n public generateAttachMessage(): IAttachMessage {\n throw new Error(\"Cannot attach remote store\");\n }\n}\n\n/**\n * Base class for detached & attached context classes\n */\nexport class LocalFluidDataStoreContextBase extends FluidDataStoreContext {\n constructor(\n id: string,\n pkg: Readonly<string[]> | undefined,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: FluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n private readonly snapshotTree: ISnapshotTree | undefined,\n protected isRootDataStore: boolean | undefined,\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n public readonly createProps?: any,\n ) {\n super(\n runtime,\n id,\n snapshotTree !== undefined ? true : false,\n storage,\n scope,\n createSummarizerNode,\n snapshotTree ? BindState.Bound : BindState.NotBound,\n true,\n bindChannel,\n pkg);\n this.attachListeners();\n }\n\n private attachListeners(): void {\n this.once(\"attaching\", () => {\n assert(this.attachState === AttachState.Detached, 0x14d /* \"Should move from detached to attaching\" */);\n this._attachState = AttachState.Attaching;\n });\n this.once(\"attached\", () => {\n assert(this.attachState === AttachState.Attaching, 0x14e /* \"Should move from attaching to attached\" */);\n this._attachState = AttachState.Attached;\n });\n }\n\n public generateAttachMessage(): IAttachMessage {\n assert(this.channel !== undefined, 0x14f /* \"There should be a channel when generating attach message\" */);\n assert(this.pkg !== undefined, 0x150 /* \"pkg should be available in local data store context\" */);\n assert(this.isRootDataStore !== undefined,\n 0x151 /* \"isRootDataStore should be available in local data store context\" */);\n\n const summarizeResult = this.channel.getAttachSummary();\n\n if (!this.disableIsolatedChannels) {\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n }\n\n // Add data store's attributes to the summary.\n const attributes = createAttributes(\n this.pkg,\n this.isRootDataStore,\n this.disableIsolatedChannels,\n );\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\n\n // Add GC data to the summary if it's not written at the root.\n if (!this.writeGCDataAtRoot) {\n addBlobToSummary(summarizeResult, gcBlobKey, JSON.stringify(this.summarizerNode.getGCSummaryDetails()));\n }\n\n // Attach message needs the summary in ITree format. Convert the ISummaryTree into an ITree.\n const snapshot = convertSummaryTreeToITree(summarizeResult.summary);\n\n const message: IAttachMessage = {\n id: this.id,\n snapshot,\n type: this.pkg[this.pkg.length - 1],\n };\n\n return message;\n }\n\n protected async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n let snapshot = this.snapshotTree;\n let attributes: ReadFluidDataStoreAttributes;\n if (snapshot !== undefined) {\n // Get the dataStore attributes.\n // Note: storage can be undefined in special case while detached.\n attributes = await getFluidDataStoreAttributes(this.storage, snapshot);\n if (hasIsolatedChannels(attributes)) {\n snapshot = snapshot.trees[channelsTreeName];\n assert(snapshot !== undefined,\n 0x1ff /* \"isolated channels subtree should exist in local datastore snapshot\" */);\n }\n if (this.pkg === undefined) {\n this.pkg = JSON.parse(attributes.pkg) as string[];\n // If there is no isRootDataStore in the attributes blob, set it to true. This ensures that data\n // stores in older documents are not garbage collected incorrectly. This may lead to additional\n // roots in the document but they won't break.\n this.isRootDataStore = attributes.isRootDataStore ?? true;\n }\n }\n assert(this.pkg !== undefined, 0x152 /* \"pkg should be available in local data store\" */);\n assert(this.isRootDataStore !== undefined,\n 0x153 /* \"isRootDataStore should be available in local data store\" */);\n\n return {\n pkg: this.pkg,\n snapshot,\n isRootDataStore: this.isRootDataStore,\n };\n }\n\n public async getInitialGCSummaryDetails(): Promise<IGarbageCollectionSummaryDetails> {\n // Local data store does not have initial summary.\n return {};\n }\n}\n\n/**\n * context implementation for \"attached\" data store runtime.\n * Various workflows (snapshot creation, requests) result in .realize() being called\n * on context, resulting in instantiation and attachment of runtime.\n * Runtime is created using data store factory that is associated with this context.\n */\nexport class LocalFluidDataStoreContext extends LocalFluidDataStoreContextBase {\n constructor(\n id: string,\n pkg: string[] | undefined,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: FluidObject & FluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n snapshotTree: ISnapshotTree | undefined,\n isRootDataStore: boolean | undefined,\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n createProps?: any,\n ) {\n super(\n id,\n pkg,\n runtime,\n storage,\n scope,\n createSummarizerNode,\n bindChannel,\n snapshotTree,\n isRootDataStore,\n createProps);\n }\n}\n\n/**\n * Detached context. Data Store runtime will be attached to it by attachRuntime() call\n * Before attachment happens, this context is not associated with particular type of runtime\n * or factory, i.e. it's package path is undefined.\n * Attachment process provides all missing parts - package path, data store runtime, and data store factory\n */\nexport class LocalDetachedFluidDataStoreContext\n extends LocalFluidDataStoreContextBase\n implements IFluidDataStoreContextDetached\n{\n constructor(\n id: string,\n pkg: Readonly<string[]>,\n runtime: ContainerRuntime,\n storage: IDocumentStorageService,\n scope: FluidObject & FluidObject,\n createSummarizerNode: CreateChildSummarizerNodeFn,\n bindChannel: (channel: IFluidDataStoreChannel) => void,\n isRootDataStore: boolean,\n ) {\n super(\n id,\n pkg,\n runtime,\n storage,\n scope,\n createSummarizerNode,\n bindChannel,\n undefined,\n isRootDataStore,\n );\n this.detachedRuntimeCreation = true;\n }\n\n public async attachRuntime(\n registry: IProvideFluidDataStoreFactory,\n dataStoreRuntime: IFluidDataStoreChannel)\n {\n assert(this.detachedRuntimeCreation, 0x154 /* \"runtime creation is already attached\" */);\n assert(this.channelDeferred === undefined, 0x155 /* \"channel deferral is already set\" */);\n\n const factory = registry.IFluidDataStoreFactory;\n\n const entry = await this.factoryFromPackagePath(this.pkg);\n assert(entry.factory === factory, 0x156 /* \"Unexpected factory for package path\" */);\n\n assert(this.registry === undefined, 0x157 /* \"datastore registry already attached\" */);\n this.registry = entry.registry;\n\n this.detachedRuntimeCreation = false;\n this.channelDeferred = new Deferred<IFluidDataStoreChannel>();\n\n super.bindRuntime(dataStoreRuntime);\n\n if (this.isRootDataStore) {\n dataStoreRuntime.bindToContext();\n }\n }\n\n protected async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n if (this.detachedRuntimeCreation) {\n throw new Error(\"Detached Fluid Data Store context can't be realized! Please attach runtime first!\");\n }\n return super.getInitialSnapshotDetails();\n }\n}\n"]}
@@ -3,8 +3,8 @@
3
3
  * Licensed under the MIT License.
4
4
  */
5
5
  import { ITelemetryBaseLogger, IDisposable } from "@fluidframework/common-definitions";
6
- import { ISequencedDocumentMessage, ISnapshotTree, ITreeEntry } from "@fluidframework/protocol-definitions";
7
- import { CreateChildSummarizerNodeFn, CreateChildSummarizerNodeParam, IAttachMessage, IFluidDataStoreChannel, IFluidDataStoreContextDetached, IGarbageCollectionData, IInboundSignalMessage, ISummaryTreeWithStats } from "@fluidframework/runtime-definitions";
6
+ import { ISequencedDocumentMessage, ISnapshotTree } from "@fluidframework/protocol-definitions";
7
+ import { CreateChildSummarizerNodeFn, CreateChildSummarizerNodeParam, IAttachMessage, IFluidDataStoreChannel, IFluidDataStoreContextDetached, IGarbageCollectionData, IGarbageCollectionSummaryDetails, IInboundSignalMessage, ISummaryTreeWithStats } from "@fluidframework/runtime-definitions";
8
8
  import { AttachState } from "@fluidframework/container-definitions";
9
9
  import { DataStoreContexts } from "./dataStoreContexts";
10
10
  import { ContainerRuntime } from "./containerRuntime";
@@ -21,12 +21,17 @@ export declare class DataStores implements IDisposable {
21
21
  private readonly submitAttachFn;
22
22
  private readonly getCreateChildSummarizerNodeFn;
23
23
  private readonly deleteChildSummarizerNodeFn;
24
+ private readonly dataStoreChanged;
24
25
  private readonly contexts;
25
26
  private readonly pendingAttach;
26
27
  readonly attachOpFiredForDataStore: Set<string>;
27
28
  private readonly logger;
28
29
  private readonly disposeOnce;
29
- constructor(baseSnapshot: ISnapshotTree | undefined, runtime: ContainerRuntime, submitAttachFn: (attachContent: any) => void, getCreateChildSummarizerNodeFn: (id: string, createParam: CreateChildSummarizerNodeParam) => CreateChildSummarizerNodeFn, deleteChildSummarizerNodeFn: (id: string) => void, baseLogger: ITelemetryBaseLogger, contexts?: DataStoreContexts);
30
+ readonly containerLoadStats: {
31
+ readonly containerLoadDataStoreCount: number;
32
+ readonly referencedDataStoreCount: number;
33
+ };
34
+ constructor(baseSnapshot: ISnapshotTree | undefined, runtime: ContainerRuntime, submitAttachFn: (attachContent: any) => void, getCreateChildSummarizerNodeFn: (id: string, createParam: CreateChildSummarizerNodeParam) => CreateChildSummarizerNodeFn, deleteChildSummarizerNodeFn: (id: string) => void, baseLogger: ITelemetryBaseLogger, getDataStoreBaseGCDetails: () => Promise<Map<string, IGarbageCollectionSummaryDetails>>, dataStoreChanged: (id: string) => void, contexts?: DataStoreContexts);
30
35
  processAttachMessage(message: ISequencedDocumentMessage, local: boolean): void;
31
36
  bindFluidDataStore(fluidDataStoreRuntime: IFluidDataStoreChannel): void;
32
37
  createDetachedDataStoreCore(pkg: Readonly<string[]>, isRoot: boolean, id?: string): IFluidDataStoreContextDetached;
@@ -41,11 +46,6 @@ export declare class DataStores implements IDisposable {
41
46
  processSignal(address: string, message: IInboundSignalMessage, local: boolean): void;
42
47
  setConnectionState(connected: boolean, clientId?: string): void;
43
48
  setAttachState(attachState: AttachState.Attaching | AttachState.Attached): void;
44
- /**
45
- * Notifies this object to take the snapshot of the container.
46
- * @deprecated - Use summarize to get summary of the container runtime.
47
- */
48
- snapshot(): Promise<ITreeEntry[]>;
49
49
  get size(): number;
50
50
  summarize(fullTree: boolean, trackState: boolean): Promise<ISummaryTreeWithStats>;
51
51
  createSummary(): ISummaryTreeWithStats;
@@ -1 +1 @@
1
- {"version":3,"file":"dataStores.d.ts","sourceRoot":"","sources":["../src/dataStores.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dataStores.d.ts","sourceRoot":"","sources":["../src/dataStores.ts"],"names":[],"mappings":"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"}