Skip to main content

IContainerRuntimeBase Interface

A reduced set of functionality of IContainerRuntime that a data store context/data store runtime will need TODO: this should be merged into IFluidDataStoreContext

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

/** @sealed */
export interface IContainerRuntimeBase extends IEventProvider<IContainerRuntimeBaseEvents>

Extends: IEventProvider<IContainerRuntimeBaseEvents>

Properties

Property Alerts Modifiers Type Description
baseLogger Alpha readonly ITelemetryBaseLogger
clientDetails Alpha readonly IClientDetails
disposed Alpha readonly boolean
submitSignal Alpha (type: string, content: unknown, targetClientId?: string) => void Submits a container runtime level signal to be sent to other clients.

Methods

Method Alerts Return Type Description
_createDataStoreWithProps(pkg, props, id) Deprecated, Alpha Promise<IDataStore>
createDataStore(pkg, loadingGroupId) Alpha Promise<IDataStore> Creates a data store and returns an object that exposes a handle to the data store's entryPoint, and also serves as the data store's router. The data store is not bound to a container, and in such state is not persisted to storage (file). Storing the entryPoint handle (or any other handle inside the data store, e.g. for DDS) into an already attached DDS (or non-attached DDS that will eventually get attached to storage) will result in this store being attached to storage.
createDetachedDataStore(pkg, loadingGroupId) Alpha IFluidDataStoreContextDetached Creates detached data store context. Only after context.attachRuntime() is called, data store initialization is considered complete.
generateDocumentUniqueId() Alpha number | string

Generates a new ID that is guaranteed to be unique across all sessions for this container. It could be in compact form (non-negative integer, oppotunistic), but it could also be UUID string. UUIDs generated will have low entropy in groups and will compress well. It can be leveraged anywhere in container where container unique IDs are required, i.e. any place that uses uuid() and stores result in container is likely candidate to start leveraging this API. If you always want to convert to string, instead of doing String(generateDocumentUniqueId()), consider doing encodeCompactIdToString(generateDocumentUniqueId()).

For more details, please see IIdCompressor.generateDocumentUniqueId()

getAbsoluteUrl(relativeUrl) Alpha Promise<string | undefined> Get an absolute url for a provided container-relative request. Returns undefined if the container or data store isn't attached to storage.
getAliasedDataStoreEntryPoint(alias) Alpha Promise<IFluidHandle<FluidObject> | undefined> Returns the aliased data store's entryPoint, given the alias.
getAudience() Alpha IAudience Returns the current audience.
getQuorum() Alpha IQuorumClients Returns the current quorum.
getSnapshotForLoadingGroupId(loadingGroupIds, pathParts) Alpha Promise<{ snapshotTree: ISnapshotTree; sequenceNumber: number; }> Api to fetch the snapshot from the service for a loadingGroupIds.
orderSequentially(callback) Alpha void

Invokes the given callback and guarantees that all operations generated within the callback will be ordered sequentially.

If the callback throws an error, the container will close and the error will be logged.

uploadBlob(blob, signal) Alpha Promise<IFluidHandle<ArrayBufferLike>>

Property Details

baseLogger

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

readonly baseLogger: ITelemetryBaseLogger;

Type: ITelemetryBaseLogger

clientDetails

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

readonly clientDetails: IClientDetails;

Type: IClientDetails

disposed

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

readonly disposed: boolean;

Type: boolean

submitSignal

Submits a container runtime level signal to be sent to other clients.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

submitSignal: (type: string, content: unknown, targetClientId?: string) => void;

Type: (type: string, content: unknown, targetClientId?: string) => void

Method Details

_createDataStoreWithProps

WARNING: This API is deprecated and will be removed in a future release.

0.16 Issue #1537, #3631

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

_createDataStoreWithProps(pkg: Readonly<string | string[]>, props?: any, id?: string): Promise<IDataStore>;

Parameters

Parameter Modifiers Type Description
pkg Readonly<string | string[]>
props optional any
id optional string

Returns

Return type: Promise<IDataStore>

createDataStore

Creates a data store and returns an object that exposes a handle to the data store's entryPoint, and also serves as the data store's router. The data store is not bound to a container, and in such state is not persisted to storage (file). Storing the entryPoint handle (or any other handle inside the data store, e.g. for DDS) into an already attached DDS (or non-attached DDS that will eventually get attached to storage) will result in this store being attached to storage.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

createDataStore(pkg: Readonly<string | string[]>, loadingGroupId?: string): Promise<IDataStore>;

Parameters

Parameter Modifiers Type Description
pkg Readonly<string | string[]> Package name of the data store factory
loadingGroupId optional string This represents the group of the datastore within a container or its snapshot. When not specified the datastore will belong to a default group. Read more about it in this README

Returns

Return type: Promise<IDataStore>

createDetachedDataStore

Creates detached data store context. Only after context.attachRuntime() is called, data store initialization is considered complete.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

createDetachedDataStore(pkg: Readonly<string[]>, loadingGroupId?: string): IFluidDataStoreContextDetached;

Parameters

Parameter Modifiers Type Description
pkg Readonly<string[]> Package name of the data store factory
loadingGroupId optional string This represents the group of the datastore within a container or its snapshot. When not specified the datastore will belong to a default group. Read more about it in this README.

Returns

Return type: IFluidDataStoreContextDetached

generateDocumentUniqueId

Generates a new ID that is guaranteed to be unique across all sessions for this container. It could be in compact form (non-negative integer, oppotunistic), but it could also be UUID string. UUIDs generated will have low entropy in groups and will compress well. It can be leveraged anywhere in container where container unique IDs are required, i.e. any place that uses uuid() and stores result in container is likely candidate to start leveraging this API. If you always want to convert to string, instead of doing String(generateDocumentUniqueId()), consider doing encodeCompactIdToString(generateDocumentUniqueId()).

For more details, please see IIdCompressor.generateDocumentUniqueId()

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

generateDocumentUniqueId(): number | string;

Returns

Return type: number | string

getAbsoluteUrl

Get an absolute url for a provided container-relative request. Returns undefined if the container or data store isn't attached to storage.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

getAbsoluteUrl(relativeUrl: string): Promise<string | undefined>;

Parameters

Parameter Type Description
relativeUrl string A relative request within the container

Returns

Return type: Promise<string | undefined>

getAliasedDataStoreEntryPoint

Returns the aliased data store's entryPoint, given the alias.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

getAliasedDataStoreEntryPoint(alias: string): Promise<IFluidHandle<FluidObject> | undefined>;

Parameters

Parameter Type Description
alias string The alias for the data store.

Returns

The data store's entry point (@fluidframework/core-interfaces#IFluidHandle) if it exists and is aliased. Returns undefined if no data store has been assigned the given alias.

Return type: Promise<IFluidHandle<FluidObject> | undefined>

getAudience

Returns the current audience.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

getAudience(): IAudience;

Returns

Return type: IAudience

getQuorum

Returns the current quorum.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

getQuorum(): IQuorumClients;

Returns

Return type: IQuorumClients

getSnapshotForLoadingGroupId

Api to fetch the snapshot from the service for a loadingGroupIds.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

getSnapshotForLoadingGroupId(loadingGroupIds: string[], pathParts: string[]): Promise<{
snapshotTree: ISnapshotTree;
sequenceNumber: number;
}>;

Parameters

Parameter Type Description
loadingGroupIds string[] LoadingGroupId for which the snapshot is asked for.
pathParts string[] Parts of the path, which we want to extract from the snapshot tree.

Returns

  • snapshotTree and the sequence number of the snapshot.

Return type: Promise<{ snapshotTree: ISnapshotTree; sequenceNumber: number; }>

orderSequentially

Invokes the given callback and guarantees that all operations generated within the callback will be ordered sequentially.

If the callback throws an error, the container will close and the error will be logged.

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

orderSequentially(callback: () => void): void;

Parameters

Parameter Type Description
callback () => void

uploadBlob

WARNING: This API is provided as an alpha preview and may change without notice. Use at your own risk.

Signature

uploadBlob(blob: ArrayBufferLike, signal?: AbortSignal): Promise<IFluidHandle<ArrayBufferLike>>;

Parameters

Parameter Modifiers Type Description
blob ArrayBufferLike
signal optional AbortSignal

Returns

Return type: Promise<IFluidHandle<ArrayBufferLike>>