@fluidframework/container-runtime 2.0.0-internal.3.0.1 → 2.0.0-internal.3.0.2

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 (58) hide show
  1. package/dist/containerRuntime.d.ts +1 -1
  2. package/dist/containerRuntime.d.ts.map +1 -1
  3. package/dist/containerRuntime.js +43 -31
  4. package/dist/containerRuntime.js.map +1 -1
  5. package/dist/dataStoreContext.d.ts +12 -0
  6. package/dist/dataStoreContext.d.ts.map +1 -1
  7. package/dist/dataStoreContext.js +43 -5
  8. package/dist/dataStoreContext.js.map +1 -1
  9. package/dist/garbageCollection.d.ts +5 -4
  10. package/dist/garbageCollection.d.ts.map +1 -1
  11. package/dist/garbageCollection.js +15 -6
  12. package/dist/garbageCollection.js.map +1 -1
  13. package/dist/garbageCollectionConstants.d.ts +2 -0
  14. package/dist/garbageCollectionConstants.d.ts.map +1 -1
  15. package/dist/garbageCollectionConstants.js +3 -1
  16. package/dist/garbageCollectionConstants.js.map +1 -1
  17. package/dist/packageVersion.d.ts +1 -1
  18. package/dist/packageVersion.js +1 -1
  19. package/dist/packageVersion.js.map +1 -1
  20. package/dist/summaryFormat.d.ts +19 -0
  21. package/dist/summaryFormat.d.ts.map +1 -1
  22. package/dist/summaryFormat.js.map +1 -1
  23. package/dist/summaryGenerator.d.ts.map +1 -1
  24. package/dist/summaryGenerator.js +1 -1
  25. package/dist/summaryGenerator.js.map +1 -1
  26. package/lib/containerRuntime.d.ts +1 -1
  27. package/lib/containerRuntime.d.ts.map +1 -1
  28. package/lib/containerRuntime.js +43 -31
  29. package/lib/containerRuntime.js.map +1 -1
  30. package/lib/dataStoreContext.d.ts +12 -0
  31. package/lib/dataStoreContext.d.ts.map +1 -1
  32. package/lib/dataStoreContext.js +45 -7
  33. package/lib/dataStoreContext.js.map +1 -1
  34. package/lib/garbageCollection.d.ts +5 -4
  35. package/lib/garbageCollection.d.ts.map +1 -1
  36. package/lib/garbageCollection.js +16 -7
  37. package/lib/garbageCollection.js.map +1 -1
  38. package/lib/garbageCollectionConstants.d.ts +2 -0
  39. package/lib/garbageCollectionConstants.d.ts.map +1 -1
  40. package/lib/garbageCollectionConstants.js +2 -0
  41. package/lib/garbageCollectionConstants.js.map +1 -1
  42. package/lib/packageVersion.d.ts +1 -1
  43. package/lib/packageVersion.js +1 -1
  44. package/lib/packageVersion.js.map +1 -1
  45. package/lib/summaryFormat.d.ts +19 -0
  46. package/lib/summaryFormat.d.ts.map +1 -1
  47. package/lib/summaryFormat.js.map +1 -1
  48. package/lib/summaryGenerator.d.ts.map +1 -1
  49. package/lib/summaryGenerator.js +1 -1
  50. package/lib/summaryGenerator.js.map +1 -1
  51. package/package.json +19 -53
  52. package/src/containerRuntime.ts +78 -49
  53. package/src/dataStoreContext.ts +64 -5
  54. package/src/garbageCollection.ts +24 -9
  55. package/src/garbageCollectionConstants.ts +3 -0
  56. package/src/packageVersion.ts +1 -1
  57. package/src/summaryFormat.ts +22 -0
  58. package/src/summaryGenerator.ts +9 -5
@@ -104,6 +104,12 @@ export declare abstract class FluidDataStoreContext extends TypedEventEmitter<IF
104
104
  private readonly mc;
105
105
  private readonly thresholdOpsCounter;
106
106
  private static readonly pendingOpsCountThreshold;
107
+ /**
108
+ * If the summarizer makes local changes, a telemetry event is logged. This has the potential to be very noisy.
109
+ * So, adding a count of how many telemetry events are logged per data store context. This can be
110
+ * controlled via feature flags.
111
+ */
112
+ private localChangesTelemetryCount;
107
113
  private lastUsedRoutes;
108
114
  readonly id: string;
109
115
  private readonly _containerRuntime;
@@ -222,6 +228,12 @@ export declare abstract class FluidDataStoreContext extends TypedEventEmitter<IF
222
228
  rollback(contents: any, localOpMetadata: unknown): void;
223
229
  applyStashedOp(contents: any): Promise<unknown>;
224
230
  private verifyNotClosed;
231
+ /**
232
+ * Summarizer client should not have local changes. These changes can become part of the summary and can break
233
+ * eventual consistency. For example, the next summary (say at ref seq# 100) may contain these changes whereas
234
+ * other clients that are up-to-date till seq# 100 may not have them yet.
235
+ */
236
+ protected identifyLocalChangeInSummarizer(eventName: string, type?: string): void;
225
237
  getCreateChildSummarizerNodeFn(id: string, createParam: CreateChildSummarizerNodeParam): (summarizeInternal: SummarizeInternalFn, getGCDataFn: (fullGC?: boolean | undefined) => Promise<IGarbageCollectionData>, getBaseGCDetailsFn?: (() => Promise<IGarbageCollectionDetailsBase>) | undefined) => ISummarizerNodeWithGC;
226
238
  uploadBlob(blob: ArrayBufferLike): Promise<IFluidHandle<ArrayBufferLike>>;
227
239
  }
@@ -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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"}
@@ -7,8 +7,8 @@ import { assert, Deferred, LazyPromise, TypedEventEmitter, } from "@fluidframewo
7
7
  import { readAndParse } from "@fluidframework/driver-utils";
8
8
  import { BlobTreeEntry } from "@fluidframework/protocol-base";
9
9
  import { BindState, channelsTreeName, } from "@fluidframework/runtime-definitions";
10
- import { addBlobToSummary, convertSummaryTreeToITree, } from "@fluidframework/runtime-utils";
11
- import { ChildLogger, loggerToMonitoringContext, LoggingError, TelemetryDataTag, ThresholdCounter, } from "@fluidframework/telemetry-utils";
10
+ import { addBlobToSummary, convertSummaryTreeToITree, packagePathToTelemetryProperty, } from "@fluidframework/runtime-utils";
11
+ import { ChildLogger, generateStack, loggerToMonitoringContext, LoggingError, TelemetryDataTag, ThresholdCounter, } from "@fluidframework/telemetry-utils";
12
12
  import { DataCorruptionError, DataProcessingError, extractSafePropertiesFromMessage, } from "@fluidframework/container-utils";
13
13
  import { dataStoreAttributesBlobName, hasIsolatedChannels, wrapSummaryInChannelsTree, getAttributesFormatVersion, getFluidDataStoreAttributes, } from "./summaryFormat";
14
14
  import { throwOnTombstoneUsageKey } from "./garbageCollectionConstants";
@@ -32,6 +32,7 @@ export function createAttributesBlob(pkg, isRootDataStore) {
32
32
  export class FluidDataStoreContext extends TypedEventEmitter {
33
33
  constructor(props, existing, bindState, // Used to assert for state tracking purposes
34
34
  isLocalDataStore, makeLocallyVisibleFn) {
35
+ var _a;
35
36
  super();
36
37
  this.existing = existing;
37
38
  this.bindState = bindState;
@@ -72,6 +73,9 @@ export class FluidDataStoreContext extends TypedEventEmitter {
72
73
  this.throwOnTombstoneUsage =
73
74
  this.mc.config.getBoolean(throwOnTombstoneUsageKey) === true &&
74
75
  this.clientDetails.type !== summarizerClientType;
76
+ // By default, a data store can log maximum 10 local changes telemetry in summarizer.
77
+ this.localChangesTelemetryCount =
78
+ (_a = this.mc.config.getNumber("Fluid.Telemetry.LocalChangesTelemetryCount")) !== null && _a !== void 0 ? _a : 10;
75
79
  }
76
80
  get packagePath() {
77
81
  assert(this.pkg !== undefined, 0x139 /* "Undefined package path" */);
@@ -156,8 +160,11 @@ export class FluidDataStoreContext extends TypedEventEmitter {
156
160
  }
157
161
  this._tombstoned = tombstone;
158
162
  }
159
- rejectDeferredRealize(reason, packageName) {
160
- throw new LoggingError(reason, { packageName: { value: packageName, tag: TelemetryDataTag.CodeArtifact } });
163
+ rejectDeferredRealize(reason, failedPkgPath, fullPackageName) {
164
+ throw new LoggingError(reason, {
165
+ failedPkgPath: { value: failedPkgPath, tag: TelemetryDataTag.CodeArtifact },
166
+ fullPackageName: packagePathToTelemetryProperty(fullPackageName),
167
+ });
161
168
  }
162
169
  async realize() {
163
170
  assert(!this.detachedRuntimeCreation, 0x13d /* "Detached runtime creation on realize()" */);
@@ -171,6 +178,7 @@ export class FluidDataStoreContext extends TypedEventEmitter {
171
178
  value: this.id,
172
179
  tag: TelemetryDataTag.CodeArtifact,
173
180
  },
181
+ packageName: packagePathToTelemetryProperty(this.pkg),
174
182
  });
175
183
  (_a = this.channelDeferred) === null || _a === void 0 ? void 0 : _a.reject(errorWrapped);
176
184
  this.logger.sendErrorEvent({ eventName: "RealizeError" }, errorWrapped);
@@ -188,18 +196,18 @@ export class FluidDataStoreContext extends TypedEventEmitter {
188
196
  let lastPkg;
189
197
  for (const pkg of packages) {
190
198
  if (!registry) {
191
- this.rejectDeferredRealize("No registry for package", lastPkg);
199
+ this.rejectDeferredRealize("No registry for package", lastPkg, packages);
192
200
  }
193
201
  lastPkg = pkg;
194
202
  entry = await registry.get(pkg);
195
203
  if (!entry) {
196
- this.rejectDeferredRealize("Registry does not contain entry for the package", pkg);
204
+ this.rejectDeferredRealize("Registry does not contain entry for the package", pkg, packages);
197
205
  }
198
206
  registry = entry.IFluidDataStoreRegistry;
199
207
  }
200
208
  const factory = entry === null || entry === void 0 ? void 0 : entry.IFluidDataStoreFactory;
201
209
  if (factory === undefined) {
202
- this.rejectDeferredRealize("Can't find factory for package", lastPkg);
210
+ this.rejectDeferredRealize("Can't find factory for package", lastPkg, packages);
203
211
  }
204
212
  return { factory, registry };
205
213
  }
@@ -386,6 +394,8 @@ export class FluidDataStoreContext extends TypedEventEmitter {
386
394
  content,
387
395
  type,
388
396
  };
397
+ // Summarizer clients should not submit messages.
398
+ this.identifyLocalChangeInSummarizer("DataStoreMessageSubmittedInSummarizer", type);
389
399
  this._containerRuntime.submitDataStoreOp(this.id, fluidDataStoreContent, localOpMetadata);
390
400
  }
391
401
  /**
@@ -519,6 +529,32 @@ export class FluidDataStoreContext extends TypedEventEmitter {
519
529
  }
520
530
  }
521
531
  }
532
+ /**
533
+ * Summarizer client should not have local changes. These changes can become part of the summary and can break
534
+ * eventual consistency. For example, the next summary (say at ref seq# 100) may contain these changes whereas
535
+ * other clients that are up-to-date till seq# 100 may not have them yet.
536
+ */
537
+ identifyLocalChangeInSummarizer(eventName, type) {
538
+ var _a, _b;
539
+ if (this.clientDetails.type !== summarizerClientType || this.localChangesTelemetryCount <= 0) {
540
+ return;
541
+ }
542
+ // Log a telemetry if there are local changes in the summarizer. This will give us data on how often
543
+ // this is happening and which data stores do this. The eventual goal is to disallow local changes
544
+ // in the summarizer and the data will help us plan this.
545
+ this.mc.logger.sendTelemetryEvent({
546
+ eventName,
547
+ type,
548
+ fluidDataStoreId: {
549
+ value: this.id,
550
+ tag: TelemetryDataTag.CodeArtifact,
551
+ },
552
+ packageName: packagePathToTelemetryProperty(this.pkg),
553
+ isSummaryInProgress: (_b = (_a = this.summarizerNode).isSummaryInProgress) === null || _b === void 0 ? void 0 : _b.call(_a),
554
+ stack: generateStack(),
555
+ });
556
+ this.localChangesTelemetryCount--;
557
+ }
522
558
  getCreateChildSummarizerNodeFn(id, createParam) {
523
559
  return (summarizeInternal, getGCDataFn, getBaseGCDetailsFn) => this.summarizerNode.createChild(summarizeInternal, id, createParam,
524
560
  // DDS will not create failure summaries
@@ -597,6 +633,8 @@ export class RemoteFluidDataStoreContext extends FluidDataStoreContext {
597
633
  export class LocalFluidDataStoreContextBase extends FluidDataStoreContext {
598
634
  constructor(props) {
599
635
  super(props, props.snapshotTree !== undefined ? true : false /* existing */, props.snapshotTree ? BindState.Bound : BindState.NotBound, true /* isLocalDataStore */, props.makeLocallyVisibleFn);
636
+ // Summarizer client should not create local data stores.
637
+ this.identifyLocalChangeInSummarizer("DataStoreCreatedInSummarizer");
600
638
  this.snapshotTree = props.snapshotTree;
601
639
  if (props.isRootDataStore === true) {
602
640
  this.setInMemoryRoot();
@@ -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, ITelemetryProperties } from \"@fluidframework/common-definitions\";\nimport {\n FluidObject,\n IRequest,\n IResponse,\n IFluidHandle,\n} from \"@fluidframework/core-interfaces\";\nimport {\n IAudience,\n IDeltaManager,\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 IQuorumClients,\n ISequencedDocumentMessage,\n ISnapshotTree,\n ITreeEntry,\n} from \"@fluidframework/protocol-definitions\";\nimport {\n IContainerRuntime,\n} from \"@fluidframework/container-runtime-definitions\";\nimport {\n BindState,\n channelsTreeName,\n CreateChildSummarizerNodeFn,\n CreateChildSummarizerNodeParam,\n FluidDataStoreRegistryEntry,\n IAttachMessage,\n IFluidDataStoreChannel,\n IFluidDataStoreContext,\n IFluidDataStoreContextDetached,\n IFluidDataStoreContextEvents,\n IFluidDataStoreRegistry,\n IGarbageCollectionData,\n IGarbageCollectionDetailsBase,\n IInboundSignalMessage,\n IProvideFluidDataStoreFactory,\n ISummarizeInternalResult,\n ISummarizeResult,\n ISummarizerNodeWithGC,\n SummarizeInternalFn,\n ITelemetryContext,\n} from \"@fluidframework/runtime-definitions\";\nimport {\n addBlobToSummary,\n convertSummaryTreeToITree,\n} from \"@fluidframework/runtime-utils\";\nimport {\n ChildLogger,\n loggerToMonitoringContext,\n LoggingError,\n MonitoringContext,\n TelemetryDataTag,\n ThresholdCounter,\n} from \"@fluidframework/telemetry-utils\";\nimport {\n DataCorruptionError,\n DataProcessingError,\n extractSafePropertiesFromMessage,\n} from \"@fluidframework/container-utils\";\n\nimport { ContainerRuntime } from \"./containerRuntime\";\nimport {\n dataStoreAttributesBlobName,\n hasIsolatedChannels,\n wrapSummaryInChannelsTree,\n ReadFluidDataStoreAttributes,\n WriteFluidDataStoreAttributes,\n getAttributesFormatVersion,\n getFluidDataStoreAttributes,\n} from \"./summaryFormat\";\nimport { throwOnTombstoneUsageKey } from \"./garbageCollectionConstants\";\nimport { sendGCTombstoneEvent } from \"./garbageCollectionTombstoneUtils\";\nimport { summarizerClientType } from \"./summarizerClientElection\";\n\nfunction createAttributes(\n pkg: readonly string[],\n isRootDataStore: boolean,\n): WriteFluidDataStoreAttributes {\n const stringifiedPkg = JSON.stringify(pkg);\n return {\n pkg: stringifiedPkg,\n summaryFormatVersion: 2,\n isRootDataStore,\n };\n}\nexport function createAttributesBlob(\n pkg: readonly string[],\n isRootDataStore: boolean,\n): ITreeEntry {\n const attributes = createAttributes(pkg, isRootDataStore);\n return new BlobTreeEntry(dataStoreAttributesBlobName, JSON.stringify(attributes));\n}\n\ninterface ISnapshotDetails {\n pkg: readonly string[];\n isRootDataStore: boolean;\n snapshot?: ISnapshotTree;\n}\n\ninterface FluidDataStoreMessage {\n content: any;\n type: string;\n}\n\n/** Properties necessary for creating a FluidDataStoreContext */\nexport interface IFluidDataStoreContextProps {\n readonly id: string;\n readonly runtime: ContainerRuntime;\n readonly storage: IDocumentStorageService;\n readonly scope: FluidObject;\n readonly createSummarizerNodeFn: CreateChildSummarizerNodeFn;\n readonly pkg?: Readonly<string[]>;\n}\n\n/** Properties necessary for creating a local FluidDataStoreContext */\nexport interface ILocalFluidDataStoreContextProps extends IFluidDataStoreContextProps {\n readonly pkg: Readonly<string[]> | undefined;\n readonly snapshotTree: ISnapshotTree | undefined;\n readonly isRootDataStore: boolean | undefined;\n readonly makeLocallyVisibleFn: () => void;\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n readonly createProps?: any;\n}\n\n/** Properties necessary for creating a remote FluidDataStoreContext */\nexport interface IRemoteFluidDataStoreContextProps extends IFluidDataStoreContextProps {\n readonly snapshotTree: ISnapshotTree | undefined;\n readonly getBaseGCDetails: () => Promise<IGarbageCollectionDetailsBase | undefined>;\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 ensureNoDataModelChanges<T>(callback: () => T): T {\n return this._containerRuntime.ensureNoDataModelChanges(callback);\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 /**\n * Tombstone is a temporary feature that prevents a data store from sending / receiving ops, signals and from\n * loading.\n */\n private _tombstoned = false;\n public get tombstoned() { return this._tombstoned; }\n /** If true, throw an error when a tombstone data store is used. */\n private readonly throwOnTombstoneUsage: boolean;\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 /**\n * A datastore is considered as root if it\n * 1. is root in memory - see isInMemoryRoot\n * 2. is root as part of the base snapshot that the datastore loaded from\n * @returns whether a datastore is root\n */\n public async isRoot(): Promise<boolean> {\n return this.isInMemoryRoot() || (await this.getInitialSnapshotDetails()).isRootDataStore;\n }\n\n /**\n * There are 3 states where isInMemoryRoot needs to be true\n * 1. when a datastore becomes aliased. This can happen for both remote and local datastores\n * 2. when a datastore is created locally as root\n * 3. when a datastore is created locally as root and is rehydrated\n * @returns whether a datastore is root in memory\n */\n protected isInMemoryRoot(): boolean {\n return this._isInMemoryRoot;\n }\n\n protected registry: IFluidDataStoreRegistry | undefined;\n\n protected detachedRuntimeCreation = false;\n /** @deprecated - To be replaced by calling makeLocallyVisible directly */\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 private _isInMemoryRoot: boolean = false;\n protected readonly summarizerNode: ISummarizerNodeWithGC;\n private readonly mc: MonitoringContext;\n private readonly thresholdOpsCounter: ThresholdCounter;\n private static readonly pendingOpsCountThreshold = 1000;\n\n // The used routes of this node as per the last GC run. This is used to update the used routes of the channel\n // if it realizes after GC is run.\n private lastUsedRoutes: string[] | undefined;\n\n public readonly id: string;\n private readonly _containerRuntime: ContainerRuntime;\n public readonly storage: IDocumentStorageService;\n public readonly scope: FluidObject;\n protected pkg?: readonly string[];\n\n constructor(\n props: IFluidDataStoreContextProps,\n private readonly existing: boolean,\n private bindState: BindState, // Used to assert for state tracking purposes\n public readonly isLocalDataStore: boolean,\n private readonly makeLocallyVisibleFn: () => void,\n ) {\n super();\n\n this._containerRuntime = props.runtime;\n this.id = props.id;\n this.storage = props.storage;\n this.scope = props.scope;\n this.pkg = props.pkg;\n\n // URIs use slashes as delimiters. Handles use URIs.\n // Thus having slashes in types almost guarantees trouble down the road!\n assert(!this.id.includes(\"/\"), 0x13a /* Data store ID contains slash */);\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 this.makeLocallyVisible();\n this.bindState = BindState.Bound;\n };\n\n const thisSummarizeInternal =\n async (fullTree: boolean, trackState: boolean, telemetryContext?: ITelemetryContext) =>\n this.summarizeInternal(fullTree, trackState, telemetryContext);\n\n this.summarizerNode = props.createSummarizerNodeFn(\n thisSummarizeInternal,\n async (fullGC?: boolean) => this.getGCDataInternal(fullGC),\n async () => this.getBaseGCDetails(),\n );\n\n this.mc = loggerToMonitoringContext(ChildLogger.create(this.logger, \"FluidDataStoreContext\"));\n this.thresholdOpsCounter = new ThresholdCounter(FluidDataStoreContext.pendingOpsCountThreshold, this.mc.logger);\n\n // Tombstone should only throw when the feature flag is enabled and the client isn't a summarizer\n this.throwOnTombstoneUsage =\n this.mc.config.getBoolean(throwOnTombstoneUsageKey) === true &&\n this.clientDetails.type !== summarizerClientType;\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 public setTombstone(tombstone: boolean) {\n if (this.tombstoned === tombstone) {\n return;\n }\n\n this._tombstoned = tombstone;\n }\n\n private rejectDeferredRealize(reason: string, packageName?: string): never {\n throw new LoggingError(reason, { packageName: { value: packageName, tag: TelemetryDataTag.CodeArtifact } });\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 = DataProcessingError.wrapIfUnrecognized(error, \"realizeFluidDataStoreContext\");\n errorWrapped.addTelemetryProperties({\n fluidDataStoreId: {\n value: this.id,\n tag: TelemetryDataTag.CodeArtifact,\n },\n });\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. Its old ID when in disconnected state and\n * its new client ID when we are connecting or connected.\n */\n public setConnectionState(connected: boolean, clientId?: string) {\n // ConnectionState should not fail in tombstone mode as this is internally run\n this.verifyNotClosed(\"setConnectionState\", false /* checkTombstone */);\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(\"process\", true, extractSafePropertiesFromMessage(messageArg));\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(\"processSignal\");\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(): IQuorumClients {\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 * @param telemetryContext - summary data passed through the layers for telemetry purposes\n */\n public async summarize(\n fullTree: boolean = false,\n trackState: boolean = true,\n telemetryContext?: ITelemetryContext,\n ): Promise<ISummarizeResult> {\n return this.summarizerNode.summarize(fullTree, trackState, telemetryContext);\n }\n\n private async summarizeInternal(\n fullTree: boolean,\n trackState: boolean,\n telemetryContext?: ITelemetryContext,\n ): 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, telemetryContext);\n\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n const pathPartsForChildren = [channelsTreeName];\n\n // Add data store's attributes to the summary.\n const { pkg } = await this.getInitialSnapshotDetails();\n const isRoot = await this.isRoot();\n const attributes = createAttributes(pkg, isRoot);\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\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 *\n * 1. To identify if this data store is being referenced in the document or not.\n *\n * 2. To determine if it needs to re-summarize in case used routes changed since last summary.\n *\n * 3. These are added to the summary generated by the data store.\n *\n * 4. To notify child contexts of their used routes. This is done immediately if the data store is loaded.\n * Else, it is done when realizing the data store.\n *\n * 5. To update the timestamp when this data store or any children are marked as unreferenced.\n *\n * @param usedRoutes - The routes that are used in this data store.\n */\n public updateUsedRoutes(usedRoutes: string[]) {\n // Update the used routes in this data store's summarizer node.\n this.summarizerNode.updateUsedRoutes(usedRoutes);\n\n /**\n * Store the used routes to update the channel if the data store is not loaded yet. If the used routes changed\n * since the previous run, the data store will be loaded during summarize since the used state changed. So, it's\n * safe to only store the last used routes.\n */\n this.lastUsedRoutes = usedRoutes;\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 * Called when a new outbound reference is added to another node. This is used by garbage collection to identify\n * all references added in the system.\n * @param srcHandle - The handle of the node that added the reference.\n * @param outboundHandle - The handle of the outbound node that is referenced.\n */\n public addedGCOutboundReference(srcHandle: IFluidHandle, outboundHandle: IFluidHandle) {\n this._containerRuntime.addedGCOutboundReference(srcHandle, outboundHandle);\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 scenarios:\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 lastUsedRoutes, GC has not run up until this point.\n if (this.lastUsedRoutes === undefined) {\n return;\n }\n\n // Remove the route to this data store, if it exists.\n const usedChannelRoutes = this.lastUsedRoutes.filter(\n (id: string) => { return id !== \"/\" && id !== \"\"; },\n );\n this.channel.updateUsedRoutes(usedChannelRoutes);\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(\"submitMessage\");\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(\"setChannelDirty\");\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(\"submitSignal\");\n\n assert(!!this.channel, 0x147 /* \"Channel must exist on submitting signal\" */);\n return this._containerRuntime.submitDataStoreSignal(this.id, type, content);\n }\n\n /**\n * This is called by the data store channel when it becomes locally visible indicating that it is ready to become\n * globally visible now.\n */\n public makeLocallyVisible() {\n assert(this.channel !== undefined, 0x2cf /* \"undefined channel on datastore context\" */);\n this.makeLocallyVisibleFn();\n }\n\n protected bindRuntime(channel: IFluidDataStoreChannel) {\n if (this.channel) {\n throw new Error(\"Runtime already bound\");\n }\n\n try {\n assert(!this.detachedRuntimeCreation, 0x148 /* \"Detached runtime creation on runtime bind\" */);\n assert(this.channelDeferred !== undefined, 0x149 /* \"Undefined channel deferral\" */);\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 {\n eventName: \"BindRuntimeError\", fluidDataStoreId: {\n value: this.id,\n tag: TelemetryDataTag.CodeArtifact,\n },\n },\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 public abstract getInitialSnapshotDetails(): Promise<ISnapshotDetails>;\n\n /**\n * @deprecated Sets the datastore as root, for aliasing purposes: #7948\n * This method should not be used outside of the aliasing context.\n * It will be removed, as the source of truth for this flag will be the aliasing blob.\n */\n public setInMemoryRoot(): void {\n this._isInMemoryRoot = true;\n }\n\n public abstract getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase>;\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 rollback(contents: any, localOpMetadata: unknown) {\n if (!this.channel) {\n throw new Error(\"Channel must exist when rolling back ops\");\n }\n if (!this.channel.rollback) {\n throw new Error(\"Channel doesn't support rollback\");\n }\n const innerContents = contents as FluidDataStoreMessage;\n this.channel.rollback(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(callSite: string, checkTombstone = true, safeTelemetryProps: ITelemetryProperties = {}) {\n if (this._disposed) {\n throw new Error(`Context is closed! Call site [${callSite}]`);\n }\n\n if (checkTombstone && this.tombstoned) {\n const messageString = `Context is tombstoned! Call site [${callSite}]`;\n const error = new DataCorruptionError(messageString, safeTelemetryProps);\n\n sendGCTombstoneEvent(\n this.mc,\n {\n eventName: \"GC_Tombstone_DataStore_Changed\",\n category: this.throwOnTombstoneUsage ? \"error\" : \"generic\",\n isSummarizerClient: this.clientDetails.type === summarizerClientType,\n callSite,\n },\n this.pkg,\n error,\n );\n if (this.throwOnTombstoneUsage) {\n throw error;\n }\n }\n }\n\n public getCreateChildSummarizerNodeFn(id: string, createParam: CreateChildSummarizerNodeParam) {\n return (\n summarizeInternal: SummarizeInternalFn,\n getGCDataFn: (fullGC?: boolean) => Promise<IGarbageCollectionData>,\n getBaseGCDetailsFn?: () => Promise<IGarbageCollectionDetailsBase>,\n ) => this.summarizerNode.createChild(\n summarizeInternal,\n id,\n createParam,\n // DDS will not create failure summaries\n { throwOnFailure: true },\n getGCDataFn,\n getBaseGCDetailsFn,\n );\n }\n\n public async uploadBlob(blob: ArrayBufferLike): Promise<IFluidHandle<ArrayBufferLike>> {\n return this.containerRuntime.uploadBlob(blob);\n }\n}\n\nexport class RemoteFluidDataStoreContext extends FluidDataStoreContext {\n private readonly initSnapshotValue: ISnapshotTree | undefined;\n private readonly baseGCDetailsP: Promise<IGarbageCollectionDetailsBase>;\n\n constructor(props: IRemoteFluidDataStoreContextProps) {\n super(\n props,\n true /* existing */,\n BindState.Bound,\n false /* isLocalDataStore */,\n () => {\n throw new Error(\"Already attached\");\n },\n );\n\n this.initSnapshotValue = props.snapshotTree;\n this.baseGCDetailsP = new LazyPromise<IGarbageCollectionDetailsBase>(async () => {\n return (await props.getBaseGCDetails()) ?? {};\n });\n\n if (props.snapshotTree !== undefined) {\n this.summarizerNode.updateBaseSummaryState(props.snapshotTree);\n }\n }\n\n private readonly initialSnapshotDetailsP = new LazyPromise<ISnapshotDetails>(async () => {\n let tree = this.initSnapshotValue;\n let isRootDataStore = true;\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 readAndParse<ReadFluidDataStoreAttributes>(this.storage, 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 pkgFromSnapshot = attributes.pkg.startsWith(\"[\\\"\") && attributes.pkg.endsWith(\"\\\"]\")\n ? JSON.parse(attributes.pkg) as string[]\n : [attributes.pkg];\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 isRootDataStore,\n snapshot: tree,\n };\n });\n\n public async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n return this.initialSnapshotDetailsP;\n }\n\n public async getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase> {\n return this.baseGCDetailsP;\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 private readonly snapshotTree: ISnapshotTree | undefined;\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n public readonly createProps?: any;\n\n constructor(props: ILocalFluidDataStoreContextProps) {\n super(\n props,\n props.snapshotTree !== undefined ? true : false /* existing */,\n props.snapshotTree ? BindState.Bound : BindState.NotBound,\n true /* isLocalDataStore */,\n props.makeLocallyVisibleFn,\n );\n\n this.snapshotTree = props.snapshotTree;\n if (props.isRootDataStore === true) {\n this.setInMemoryRoot();\n }\n this.createProps = props.createProps;\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\n const summarizeResult = this.channel.getAttachSummary();\n\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n\n // Add data store's attributes to the summary.\n const attributes = createAttributes(\n this.pkg,\n this.isInMemoryRoot(),\n );\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\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 public async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n let snapshot = this.snapshotTree;\n let attributes: ReadFluidDataStoreAttributes;\n let isRootDataStore = false;\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 if (attributes.isRootDataStore ?? true) {\n isRootDataStore = true;\n this.setInMemoryRoot();\n }\n }\n }\n assert(this.pkg !== undefined, 0x152 /* \"pkg should be available in local data store\" */);\n\n return {\n pkg: this.pkg,\n isRootDataStore,\n snapshot,\n };\n }\n\n public async getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase> {\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(props: ILocalFluidDataStoreContextProps) {\n super(props);\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 constructor(props: ILocalFluidDataStoreContextProps) {\n super(props);\n this.detachedRuntimeCreation = true;\n }\n\n public async attachRuntime(\n registry: IProvideFluidDataStoreFactory,\n dataStoreChannel: IFluidDataStoreChannel) {\n assert(this.detachedRuntimeCreation, 0x154 /* \"runtime creation is already attached\" */);\n this.detachedRuntimeCreation = false;\n\n assert(this.channelDeferred === undefined, 0x155 /* \"channel deferral is already set\" */);\n this.channelDeferred = new Deferred<IFluidDataStoreChannel>();\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 super.bindRuntime(dataStoreChannel);\n\n // Load the handle to the data store's entryPoint to make sure that for a detached data store, the entryPoint\n // initialization function is called before the data store gets attached and potentially connected to the\n // delta stream, so it gets a chance to do things while the data store is still \"purely local\".\n // This preserves the behavior from before we introduced entryPoints, where the instantiateDataStore method\n // of data store factories tends to construct the data object (at least kick off an async method that returns\n // it); that code moved to the entryPoint initialization function, so we want to ensure it still executes\n // before the data store is attached.\n await dataStoreChannel.entryPoint?.get();\n\n if (await this.isRoot()) {\n dataStoreChannel.makeVisibleAndAttachGraph();\n }\n }\n\n public 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, ITelemetryProperties } from \"@fluidframework/common-definitions\";\nimport {\n FluidObject,\n IRequest,\n IResponse,\n IFluidHandle,\n} from \"@fluidframework/core-interfaces\";\nimport {\n IAudience,\n IDeltaManager,\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 IQuorumClients,\n ISequencedDocumentMessage,\n ISnapshotTree,\n ITreeEntry,\n} from \"@fluidframework/protocol-definitions\";\nimport {\n IContainerRuntime,\n} from \"@fluidframework/container-runtime-definitions\";\nimport {\n BindState,\n channelsTreeName,\n CreateChildSummarizerNodeFn,\n CreateChildSummarizerNodeParam,\n FluidDataStoreRegistryEntry,\n IAttachMessage,\n IFluidDataStoreChannel,\n IFluidDataStoreContext,\n IFluidDataStoreContextDetached,\n IFluidDataStoreContextEvents,\n IFluidDataStoreRegistry,\n IGarbageCollectionData,\n IGarbageCollectionDetailsBase,\n IInboundSignalMessage,\n IProvideFluidDataStoreFactory,\n ISummarizeInternalResult,\n ISummarizeResult,\n ISummarizerNodeWithGC,\n SummarizeInternalFn,\n ITelemetryContext,\n} from \"@fluidframework/runtime-definitions\";\nimport {\n addBlobToSummary,\n convertSummaryTreeToITree,\n packagePathToTelemetryProperty,\n} from \"@fluidframework/runtime-utils\";\nimport {\n ChildLogger,\n generateStack,\n loggerToMonitoringContext,\n LoggingError,\n MonitoringContext,\n TelemetryDataTag,\n ThresholdCounter,\n} from \"@fluidframework/telemetry-utils\";\nimport {\n DataCorruptionError,\n DataProcessingError,\n extractSafePropertiesFromMessage,\n} from \"@fluidframework/container-utils\";\n\nimport { ContainerRuntime } from \"./containerRuntime\";\nimport {\n dataStoreAttributesBlobName,\n hasIsolatedChannels,\n wrapSummaryInChannelsTree,\n ReadFluidDataStoreAttributes,\n WriteFluidDataStoreAttributes,\n getAttributesFormatVersion,\n getFluidDataStoreAttributes,\n} from \"./summaryFormat\";\nimport { throwOnTombstoneUsageKey } from \"./garbageCollectionConstants\";\nimport { sendGCTombstoneEvent } from \"./garbageCollectionTombstoneUtils\";\nimport { summarizerClientType } from \"./summarizerClientElection\";\n\nfunction createAttributes(\n pkg: readonly string[],\n isRootDataStore: boolean,\n): WriteFluidDataStoreAttributes {\n const stringifiedPkg = JSON.stringify(pkg);\n return {\n pkg: stringifiedPkg,\n summaryFormatVersion: 2,\n isRootDataStore,\n };\n}\nexport function createAttributesBlob(\n pkg: readonly string[],\n isRootDataStore: boolean,\n): ITreeEntry {\n const attributes = createAttributes(pkg, isRootDataStore);\n return new BlobTreeEntry(dataStoreAttributesBlobName, JSON.stringify(attributes));\n}\n\ninterface ISnapshotDetails {\n pkg: readonly string[];\n isRootDataStore: boolean;\n snapshot?: ISnapshotTree;\n}\n\ninterface FluidDataStoreMessage {\n content: any;\n type: string;\n}\n\n/** Properties necessary for creating a FluidDataStoreContext */\nexport interface IFluidDataStoreContextProps {\n readonly id: string;\n readonly runtime: ContainerRuntime;\n readonly storage: IDocumentStorageService;\n readonly scope: FluidObject;\n readonly createSummarizerNodeFn: CreateChildSummarizerNodeFn;\n readonly pkg?: Readonly<string[]>;\n}\n\n/** Properties necessary for creating a local FluidDataStoreContext */\nexport interface ILocalFluidDataStoreContextProps extends IFluidDataStoreContextProps {\n readonly pkg: Readonly<string[]> | undefined;\n readonly snapshotTree: ISnapshotTree | undefined;\n readonly isRootDataStore: boolean | undefined;\n readonly makeLocallyVisibleFn: () => void;\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n readonly createProps?: any;\n}\n\n/** Properties necessary for creating a remote FluidDataStoreContext */\nexport interface IRemoteFluidDataStoreContextProps extends IFluidDataStoreContextProps {\n readonly snapshotTree: ISnapshotTree | undefined;\n readonly getBaseGCDetails: () => Promise<IGarbageCollectionDetailsBase | undefined>;\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 ensureNoDataModelChanges<T>(callback: () => T): T {\n return this._containerRuntime.ensureNoDataModelChanges(callback);\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 /**\n * Tombstone is a temporary feature that prevents a data store from sending / receiving ops, signals and from\n * loading.\n */\n private _tombstoned = false;\n public get tombstoned() { return this._tombstoned; }\n /** If true, throw an error when a tombstone data store is used. */\n private readonly throwOnTombstoneUsage: boolean;\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 /**\n * A datastore is considered as root if it\n * 1. is root in memory - see isInMemoryRoot\n * 2. is root as part of the base snapshot that the datastore loaded from\n * @returns whether a datastore is root\n */\n public async isRoot(): Promise<boolean> {\n return this.isInMemoryRoot() || (await this.getInitialSnapshotDetails()).isRootDataStore;\n }\n\n /**\n * There are 3 states where isInMemoryRoot needs to be true\n * 1. when a datastore becomes aliased. This can happen for both remote and local datastores\n * 2. when a datastore is created locally as root\n * 3. when a datastore is created locally as root and is rehydrated\n * @returns whether a datastore is root in memory\n */\n protected isInMemoryRoot(): boolean {\n return this._isInMemoryRoot;\n }\n\n protected registry: IFluidDataStoreRegistry | undefined;\n\n protected detachedRuntimeCreation = false;\n /** @deprecated - To be replaced by calling makeLocallyVisible directly */\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 private _isInMemoryRoot: boolean = false;\n protected readonly summarizerNode: ISummarizerNodeWithGC;\n private readonly mc: MonitoringContext;\n private readonly thresholdOpsCounter: ThresholdCounter;\n private static readonly pendingOpsCountThreshold = 1000;\n\n /**\n * If the summarizer makes local changes, a telemetry event is logged. This has the potential to be very noisy.\n * So, adding a count of how many telemetry events are logged per data store context. This can be\n * controlled via feature flags.\n */\n private localChangesTelemetryCount: number;\n\n // The used routes of this node as per the last GC run. This is used to update the used routes of the channel\n // if it realizes after GC is run.\n private lastUsedRoutes: string[] | undefined;\n\n public readonly id: string;\n private readonly _containerRuntime: ContainerRuntime;\n public readonly storage: IDocumentStorageService;\n public readonly scope: FluidObject;\n protected pkg?: readonly string[];\n\n constructor(\n props: IFluidDataStoreContextProps,\n private readonly existing: boolean,\n private bindState: BindState, // Used to assert for state tracking purposes\n public readonly isLocalDataStore: boolean,\n private readonly makeLocallyVisibleFn: () => void,\n ) {\n super();\n\n this._containerRuntime = props.runtime;\n this.id = props.id;\n this.storage = props.storage;\n this.scope = props.scope;\n this.pkg = props.pkg;\n\n // URIs use slashes as delimiters. Handles use URIs.\n // Thus having slashes in types almost guarantees trouble down the road!\n assert(!this.id.includes(\"/\"), 0x13a /* Data store ID contains slash */);\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 this.makeLocallyVisible();\n this.bindState = BindState.Bound;\n };\n\n const thisSummarizeInternal =\n async (fullTree: boolean, trackState: boolean, telemetryContext?: ITelemetryContext) =>\n this.summarizeInternal(fullTree, trackState, telemetryContext);\n\n this.summarizerNode = props.createSummarizerNodeFn(\n thisSummarizeInternal,\n async (fullGC?: boolean) => this.getGCDataInternal(fullGC),\n async () => this.getBaseGCDetails(),\n );\n\n this.mc = loggerToMonitoringContext(ChildLogger.create(this.logger, \"FluidDataStoreContext\"));\n this.thresholdOpsCounter = new ThresholdCounter(FluidDataStoreContext.pendingOpsCountThreshold, this.mc.logger);\n\n // Tombstone should only throw when the feature flag is enabled and the client isn't a summarizer\n this.throwOnTombstoneUsage =\n this.mc.config.getBoolean(throwOnTombstoneUsageKey) === true &&\n this.clientDetails.type !== summarizerClientType;\n\n // By default, a data store can log maximum 10 local changes telemetry in summarizer.\n this.localChangesTelemetryCount =\n this.mc.config.getNumber(\"Fluid.Telemetry.LocalChangesTelemetryCount\") ?? 10;\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 public setTombstone(tombstone: boolean) {\n if (this.tombstoned === tombstone) {\n return;\n }\n\n this._tombstoned = tombstone;\n }\n\n private rejectDeferredRealize(\n reason: string,\n failedPkgPath?: string,\n fullPackageName?: readonly string[],\n ): never {\n throw new LoggingError(reason, {\n failedPkgPath: { value: failedPkgPath, tag: TelemetryDataTag.CodeArtifact },\n fullPackageName: packagePathToTelemetryProperty(fullPackageName),\n });\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 = DataProcessingError.wrapIfUnrecognized(error, \"realizeFluidDataStoreContext\");\n errorWrapped.addTelemetryProperties({\n fluidDataStoreId: {\n value: this.id,\n tag: TelemetryDataTag.CodeArtifact,\n },\n packageName: packagePathToTelemetryProperty(this.pkg),\n });\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, packages);\n }\n lastPkg = pkg;\n entry = await registry.get(pkg);\n if (!entry) {\n this.rejectDeferredRealize(\n \"Registry does not contain entry for the package\",\n pkg,\n packages,\n );\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, packages);\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. Its old ID when in disconnected state and\n * its new client ID when we are connecting or connected.\n */\n public setConnectionState(connected: boolean, clientId?: string) {\n // ConnectionState should not fail in tombstone mode as this is internally run\n this.verifyNotClosed(\"setConnectionState\", false /* checkTombstone */);\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(\"process\", true, extractSafePropertiesFromMessage(messageArg));\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(\"processSignal\");\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(): IQuorumClients {\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 * @param telemetryContext - summary data passed through the layers for telemetry purposes\n */\n public async summarize(\n fullTree: boolean = false,\n trackState: boolean = true,\n telemetryContext?: ITelemetryContext,\n ): Promise<ISummarizeResult> {\n return this.summarizerNode.summarize(fullTree, trackState, telemetryContext);\n }\n\n private async summarizeInternal(\n fullTree: boolean,\n trackState: boolean,\n telemetryContext?: ITelemetryContext,\n ): 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, telemetryContext);\n\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n const pathPartsForChildren = [channelsTreeName];\n\n // Add data store's attributes to the summary.\n const { pkg } = await this.getInitialSnapshotDetails();\n const isRoot = await this.isRoot();\n const attributes = createAttributes(pkg, isRoot);\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\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 *\n * 1. To identify if this data store is being referenced in the document or not.\n *\n * 2. To determine if it needs to re-summarize in case used routes changed since last summary.\n *\n * 3. These are added to the summary generated by the data store.\n *\n * 4. To notify child contexts of their used routes. This is done immediately if the data store is loaded.\n * Else, it is done when realizing the data store.\n *\n * 5. To update the timestamp when this data store or any children are marked as unreferenced.\n *\n * @param usedRoutes - The routes that are used in this data store.\n */\n public updateUsedRoutes(usedRoutes: string[]) {\n // Update the used routes in this data store's summarizer node.\n this.summarizerNode.updateUsedRoutes(usedRoutes);\n\n /**\n * Store the used routes to update the channel if the data store is not loaded yet. If the used routes changed\n * since the previous run, the data store will be loaded during summarize since the used state changed. So, it's\n * safe to only store the last used routes.\n */\n this.lastUsedRoutes = usedRoutes;\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 * Called when a new outbound reference is added to another node. This is used by garbage collection to identify\n * all references added in the system.\n * @param srcHandle - The handle of the node that added the reference.\n * @param outboundHandle - The handle of the outbound node that is referenced.\n */\n public addedGCOutboundReference(srcHandle: IFluidHandle, outboundHandle: IFluidHandle) {\n this._containerRuntime.addedGCOutboundReference(srcHandle, outboundHandle);\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 scenarios:\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 lastUsedRoutes, GC has not run up until this point.\n if (this.lastUsedRoutes === undefined) {\n return;\n }\n\n // Remove the route to this data store, if it exists.\n const usedChannelRoutes = this.lastUsedRoutes.filter(\n (id: string) => { return id !== \"/\" && id !== \"\"; },\n );\n this.channel.updateUsedRoutes(usedChannelRoutes);\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(\"submitMessage\");\n assert(!!this.channel, 0x146 /* \"Channel must exist when submitting message\" */);\n const fluidDataStoreContent: FluidDataStoreMessage = {\n content,\n type,\n };\n\n // Summarizer clients should not submit messages.\n this.identifyLocalChangeInSummarizer(\"DataStoreMessageSubmittedInSummarizer\", 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(\"setChannelDirty\");\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(\"submitSignal\");\n\n assert(!!this.channel, 0x147 /* \"Channel must exist on submitting signal\" */);\n return this._containerRuntime.submitDataStoreSignal(this.id, type, content);\n }\n\n /**\n * This is called by the data store channel when it becomes locally visible indicating that it is ready to become\n * globally visible now.\n */\n public makeLocallyVisible() {\n assert(this.channel !== undefined, 0x2cf /* \"undefined channel on datastore context\" */);\n this.makeLocallyVisibleFn();\n }\n\n protected bindRuntime(channel: IFluidDataStoreChannel) {\n if (this.channel) {\n throw new Error(\"Runtime already bound\");\n }\n\n try {\n assert(!this.detachedRuntimeCreation, 0x148 /* \"Detached runtime creation on runtime bind\" */);\n assert(this.channelDeferred !== undefined, 0x149 /* \"Undefined channel deferral\" */);\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 {\n eventName: \"BindRuntimeError\", fluidDataStoreId: {\n value: this.id,\n tag: TelemetryDataTag.CodeArtifact,\n },\n },\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 public abstract getInitialSnapshotDetails(): Promise<ISnapshotDetails>;\n\n /**\n * @deprecated Sets the datastore as root, for aliasing purposes: #7948\n * This method should not be used outside of the aliasing context.\n * It will be removed, as the source of truth for this flag will be the aliasing blob.\n */\n public setInMemoryRoot(): void {\n this._isInMemoryRoot = true;\n }\n\n public abstract getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase>;\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 rollback(contents: any, localOpMetadata: unknown) {\n if (!this.channel) {\n throw new Error(\"Channel must exist when rolling back ops\");\n }\n if (!this.channel.rollback) {\n throw new Error(\"Channel doesn't support rollback\");\n }\n const innerContents = contents as FluidDataStoreMessage;\n this.channel.rollback(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(callSite: string, checkTombstone = true, safeTelemetryProps: ITelemetryProperties = {}) {\n if (this._disposed) {\n throw new Error(`Context is closed! Call site [${callSite}]`);\n }\n\n if (checkTombstone && this.tombstoned) {\n const messageString = `Context is tombstoned! Call site [${callSite}]`;\n const error = new DataCorruptionError(messageString, safeTelemetryProps);\n\n sendGCTombstoneEvent(\n this.mc,\n {\n eventName: \"GC_Tombstone_DataStore_Changed\",\n category: this.throwOnTombstoneUsage ? \"error\" : \"generic\",\n isSummarizerClient: this.clientDetails.type === summarizerClientType,\n callSite,\n },\n this.pkg,\n error,\n );\n if (this.throwOnTombstoneUsage) {\n throw error;\n }\n }\n }\n\n /**\n * Summarizer client should not have local changes. These changes can become part of the summary and can break\n * eventual consistency. For example, the next summary (say at ref seq# 100) may contain these changes whereas\n * other clients that are up-to-date till seq# 100 may not have them yet.\n */\n protected identifyLocalChangeInSummarizer(eventName: string, type?: string) {\n if (this.clientDetails.type !== summarizerClientType || this.localChangesTelemetryCount <= 0) {\n return;\n }\n\n // Log a telemetry if there are local changes in the summarizer. This will give us data on how often\n // this is happening and which data stores do this. The eventual goal is to disallow local changes\n // in the summarizer and the data will help us plan this.\n this.mc.logger.sendTelemetryEvent({\n eventName,\n type,\n fluidDataStoreId: {\n value: this.id,\n tag: TelemetryDataTag.CodeArtifact,\n },\n packageName: packagePathToTelemetryProperty(this.pkg),\n isSummaryInProgress: this.summarizerNode.isSummaryInProgress?.(),\n stack: generateStack(),\n });\n this.localChangesTelemetryCount--;\n }\n\n public getCreateChildSummarizerNodeFn(id: string, createParam: CreateChildSummarizerNodeParam) {\n return (\n summarizeInternal: SummarizeInternalFn,\n getGCDataFn: (fullGC?: boolean) => Promise<IGarbageCollectionData>,\n getBaseGCDetailsFn?: () => Promise<IGarbageCollectionDetailsBase>,\n ) => this.summarizerNode.createChild(\n summarizeInternal,\n id,\n createParam,\n // DDS will not create failure summaries\n { throwOnFailure: true },\n getGCDataFn,\n getBaseGCDetailsFn,\n );\n }\n\n public async uploadBlob(blob: ArrayBufferLike): Promise<IFluidHandle<ArrayBufferLike>> {\n return this.containerRuntime.uploadBlob(blob);\n }\n}\n\nexport class RemoteFluidDataStoreContext extends FluidDataStoreContext {\n private readonly initSnapshotValue: ISnapshotTree | undefined;\n private readonly baseGCDetailsP: Promise<IGarbageCollectionDetailsBase>;\n\n constructor(props: IRemoteFluidDataStoreContextProps) {\n super(\n props,\n true /* existing */,\n BindState.Bound,\n false /* isLocalDataStore */,\n () => {\n throw new Error(\"Already attached\");\n },\n );\n\n this.initSnapshotValue = props.snapshotTree;\n this.baseGCDetailsP = new LazyPromise<IGarbageCollectionDetailsBase>(async () => {\n return (await props.getBaseGCDetails()) ?? {};\n });\n\n if (props.snapshotTree !== undefined) {\n this.summarizerNode.updateBaseSummaryState(props.snapshotTree);\n }\n }\n\n private readonly initialSnapshotDetailsP = new LazyPromise<ISnapshotDetails>(async () => {\n let tree = this.initSnapshotValue;\n let isRootDataStore = true;\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 readAndParse<ReadFluidDataStoreAttributes>(this.storage, 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 pkgFromSnapshot = attributes.pkg.startsWith(\"[\\\"\") && attributes.pkg.endsWith(\"\\\"]\")\n ? JSON.parse(attributes.pkg) as string[]\n : [attributes.pkg];\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 isRootDataStore,\n snapshot: tree,\n };\n });\n\n public async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n return this.initialSnapshotDetailsP;\n }\n\n public async getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase> {\n return this.baseGCDetailsP;\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 private readonly snapshotTree: ISnapshotTree | undefined;\n /**\n * @deprecated 0.16 Issue #1635, #3631\n */\n public readonly createProps?: any;\n\n constructor(props: ILocalFluidDataStoreContextProps) {\n super(\n props,\n props.snapshotTree !== undefined ? true : false /* existing */,\n props.snapshotTree ? BindState.Bound : BindState.NotBound,\n true /* isLocalDataStore */,\n props.makeLocallyVisibleFn,\n );\n\n // Summarizer client should not create local data stores.\n this.identifyLocalChangeInSummarizer(\"DataStoreCreatedInSummarizer\");\n\n this.snapshotTree = props.snapshotTree;\n if (props.isRootDataStore === true) {\n this.setInMemoryRoot();\n }\n this.createProps = props.createProps;\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\n const summarizeResult = this.channel.getAttachSummary();\n\n // Wrap dds summaries in .channels subtree.\n wrapSummaryInChannelsTree(summarizeResult);\n\n // Add data store's attributes to the summary.\n const attributes = createAttributes(\n this.pkg,\n this.isInMemoryRoot(),\n );\n addBlobToSummary(summarizeResult, dataStoreAttributesBlobName, JSON.stringify(attributes));\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 public async getInitialSnapshotDetails(): Promise<ISnapshotDetails> {\n let snapshot = this.snapshotTree;\n let attributes: ReadFluidDataStoreAttributes;\n let isRootDataStore = false;\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 if (attributes.isRootDataStore ?? true) {\n isRootDataStore = true;\n this.setInMemoryRoot();\n }\n }\n }\n assert(this.pkg !== undefined, 0x152 /* \"pkg should be available in local data store\" */);\n\n return {\n pkg: this.pkg,\n isRootDataStore,\n snapshot,\n };\n }\n\n public async getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase> {\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(props: ILocalFluidDataStoreContextProps) {\n super(props);\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 constructor(props: ILocalFluidDataStoreContextProps) {\n super(props);\n this.detachedRuntimeCreation = true;\n }\n\n public async attachRuntime(\n registry: IProvideFluidDataStoreFactory,\n dataStoreChannel: IFluidDataStoreChannel) {\n assert(this.detachedRuntimeCreation, 0x154 /* \"runtime creation is already attached\" */);\n this.detachedRuntimeCreation = false;\n\n assert(this.channelDeferred === undefined, 0x155 /* \"channel deferral is already set\" */);\n this.channelDeferred = new Deferred<IFluidDataStoreChannel>();\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 super.bindRuntime(dataStoreChannel);\n\n // Load the handle to the data store's entryPoint to make sure that for a detached data store, the entryPoint\n // initialization function is called before the data store gets attached and potentially connected to the\n // delta stream, so it gets a chance to do things while the data store is still \"purely local\".\n // This preserves the behavior from before we introduced entryPoints, where the instantiateDataStore method\n // of data store factories tends to construct the data object (at least kick off an async method that returns\n // it); that code moved to the entryPoint initialization function, so we want to ensure it still executes\n // before the data store is attached.\n await dataStoreChannel.entryPoint?.get();\n\n if (await this.isRoot()) {\n dataStoreChannel.makeVisibleAndAttachGraph();\n }\n }\n\n public 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"]}
@@ -72,7 +72,7 @@ export interface IGarbageCollector {
72
72
  logger?: ITelemetryLogger;
73
73
  runSweep?: boolean;
74
74
  fullGC?: boolean;
75
- }): Promise<IGCStats | undefined>;
75
+ }, telemetryContext?: ITelemetryContext): Promise<IGCStats | undefined>;
76
76
  /** Summarizes the GC data and returns it as a summary tree. */
77
77
  summarize(fullTree: boolean, trackState: boolean, telemetryContext?: ITelemetryContext): ISummarizeResult | undefined;
78
78
  /** Returns the garbage collector specific metadata to be written into the summary. */
@@ -80,7 +80,7 @@ export interface IGarbageCollector {
80
80
  /** Returns the GC details generated from the base snapshot. */
81
81
  getBaseGCDetails(): Promise<IGarbageCollectionDetailsBase>;
82
82
  /** Called when the latest summary of the system has been refreshed. */
83
- refreshLatestSummary(result: RefreshSummaryResult, proposalHandle: string | undefined, summaryRefSeq: number, readAndParseBlob: ReadAndParseBlob): Promise<void>;
83
+ refreshLatestSummary(proposalHandle: string | undefined, result: RefreshSummaryResult, readAndParseBlob: ReadAndParseBlob): Promise<void>;
84
84
  /** Called when a node is updated. Used to detect and log when an inactive node is changed or loaded. */
85
85
  nodeUpdated(nodePath: string, reason: "Loaded" | "Changed", timestampMs?: number, packagePath?: readonly string[], requestHeaders?: IRequestHeader): void;
86
86
  /** Called when a reference is added to a node. Used to identify nodes that were referenced between summaries. */
@@ -226,6 +226,7 @@ export declare class GarbageCollector implements IGarbageCollector {
226
226
  private wasGCRunInLatestSummary;
227
227
  private readonly currentGCVersion;
228
228
  private latestSummaryGCVersion;
229
+ private readonly persistedGcFeatureMatrix;
229
230
  private gcDataFromLastRun;
230
231
  private readonly newReferencesSinceLastRun;
231
232
  private tombstones;
@@ -299,7 +300,7 @@ export declare class GarbageCollector implements IGarbageCollector {
299
300
  runSweep?: boolean;
300
301
  /** True to generate full GC data */
301
302
  fullGC?: boolean;
302
- }): Promise<IGCStats | undefined>;
303
+ }, telemetryContext?: ITelemetryContext): Promise<IGCStats | undefined>;
303
304
  private runPreGCSteps;
304
305
  private runPostGCSteps;
305
306
  /**
@@ -329,7 +330,7 @@ export declare class GarbageCollector implements IGarbageCollector {
329
330
  * Called to refresh the latest summary state. This happens when either a pending summary is acked or a snapshot
330
331
  * is downloaded and should be used to update the state.
331
332
  */
332
- refreshLatestSummary(result: RefreshSummaryResult, proposalHandle: string | undefined, summaryRefSeq: number, readAndParseBlob: ReadAndParseBlob): Promise<void>;
333
+ refreshLatestSummary(proposalHandle: string | undefined, result: RefreshSummaryResult, readAndParseBlob: ReadAndParseBlob): Promise<void>;
333
334
  /**
334
335
  * Called when a node with the given id is updated. If the node is inactive, log an error.
335
336
  * @param nodePath - The id of the node that changed.
@@ -1 +1 @@
1
- {"version":3,"file":"garbageCollection.d.ts","sourceRoot":"","sources":["../src/garbageCollection.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"garbageCollection.d.ts","sourceRoot":"","sources":["../src/garbageCollection.ts"],"names":[],"mappings":"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"}