Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
-
Moved MinimumVersionForCollab to @fluidframework/runtime-definitions (#25059) 4a7b370667
MinimumVersionForCollab has been moved from @fluidframework/container-runtime to @fluidframework/runtime-definitions. The export in @fluidframework/container-runtime is now deprecated and will be removed in a future version. Consumers should import it from @fluidframework/runtime-definitions going forward.
Dependency updates only.
-
IFluidHandleInternal.bind (deprecated) has been removed (#24974) 07e183795f
IFluidHandleInternal.bindwas deprecated in 2.40 and has now been removed. See release notes entry for more details.
Dependency updates only.
Dependency updates only.
Dependency updates only.
-
IFluidHandleInternal.bind has been deprecated (#24553) 8a4362a7ed
Handle binding is an internal concept used to make sure objects attach to the Container graph when their handle is stored in a DDS which is itself attached. The source of the "bind" operation has been assumed to be any handle, but only one implementation is actually supported (
SharedObjectHandle, not exported itself).So the
bindfunction is now deprecated on theIFluidHandleInterface, moving instead to internal types supporting the one valid implementation. It's also deprecated on the various exported handle implementations that don't support it (each is either no-op, pass-through, or throwing).No replacement is offered, this API was never meant to be called from outside of the Fluid Framework.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
-
New compareFluidHandle function for comparing FluidHandles (#22997) 8d470085fb
The new
compareFluidHandlefunction has been added to allow comparing handles without having to inspect their internals. -
The inbound and outbound properties have been removed from IDeltaManager (#22282) 45a57693f2
The inbound and outbound properties were deprecated in version 2.0.0-rc.2.0.0 and have been removed from
IDeltaManager.IDeltaManager.inboundcontained functionality that could break core runtime features such as summarization and processing batches if used improperly. Data loss or corruption could occur whenIDeltaManger.inbound.pause()orIDeltaManager.inbound.resume()were called.Similarly,
IDeltaManager.outboundcontained functionality that could break core runtime features such as generation of batches and chunking. Data loss or corruption could occur whenIDeltaManger.inbound.pause()orIDeltaManager.inbound.resume()were called.- Alternatives to
IDeltaManager.inbound.on("op", ...)areIDeltaManager.on("op", ...) - Alternatives to calling
IDeltaManager.inbound.pause,IDeltaManager.outbound.pauseforIContainerdisconnect useIContainer.disconnect. - Alternatives to calling
IDeltaManager.inbound.resume,IDeltaManager.outbound.resumeforIContainerreconnect useIContainer.connect.
- Alternatives to
Dependency updates only.
Dependency updates only.
Dependency updates only.
-
New
isFluidHandletype guard to check if an object is anIFluidHandle(#22029) 7827d1040aThe
isFluidHandletype guard function is now exported and can be used to detect which objects areIFluidHandles. SinceIFluidHandleoften needs special handling (for example when serializing since it's not JSON compatible), having a dedicated detection function for it is useful. Doing this detection was possible previously using thetreepackage's schema system viaTree.is(value, new SchemaFactory("").handle), but can now be done with justisFluidHandle(value).
Dependency updates only.
-
Update to TypeScript 5.4 (#21214) 0e6256c722
Update package implementations to use TypeScript 5.4.5.
-
Deprecated members of IFluidHandle are split off into new IFluidHandleInternal interface 96872186d0
Split IFluidHandle into two interfaces,
IFluidHandleandIFluidHandleInternal. Code depending on the previously deprecated members of IFluidHandle can access them by usingtoFluidHandleInternalfrom@fluidframework/runtime-utils/legacy.External implementation of the
IFluidHandleinterface are not supported: this change makes the typing better convey this using theErasedTypepattern. Any existing and previously working, and now broken, external implementations ofIFluidHandleshould still work at runtime, but will need some unsafe type casts to compile. Such handle implementation may break in the future and thus should be replaced with use of handles produced by the Fluid Framework client packages. -
Type Erase IFluidDataStoreRuntime.deltaManager 96872186d0
Make IFluidDataStoreRuntime.deltaManager have an opaque type. Marks the following types which were reachable from it as alpha:
- IConnectionDetails
- IDeltaSender
- IDeltaManagerEvents
- IDeltaManager
- IDeltaQueueEvents
- IDeltaQueue
- ReadOnlyInfo
As a temporary workaround, users needing access to the full delta manager API can use the
@alphatoDeltaManagerInternalAPI to retrieve its members, but should migrate away from requiring access to those APIs.Implementing a custom
IFluidDataStoreRuntimeis not supported: this is now indicated by it being marked with@sealed.
-
Packages now use package.json "exports" and require modern module resolution 97d68aa06b
Fluid Framework packages have been updated to use the package.json "exports" field to define explicit entry points for both TypeScript types and implementation code.
This means that using Fluid Framework packages require the following TypeScript settings in tsconfig.json:
"moduleResolution": "Node16"with"module": "Node16""moduleResolution": "Bundler"with"module": "ESNext"
We recommend using Node16/Node16 unless absolutely necessary. That will produce transpiled JavaScript that is suitable for use with modern versions of Node.js and Bundlers. See the TypeScript documentation for more information regarding the module and moduleResolution options.
Node10 moduleResolution is not supported; it does not support Fluid Framework's API structuring pattern that is used to distinguish stable APIs from those that are in development.
-
container-runtime: New feature: ID compression for DataStores & DDSs (#19859) 51f0d3db73
- A new API IContainerRuntimeBase.generateDocumentUniqueId() is exposed. This API will opportunistically generate IDs in short format (non-negative numbers). If it can't achieve that, it will return UUID strings. 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 data in container is likely candidate to start leveraging this API.
- Data store internal IDs (IDs that are auto generated by FF system) will opportunistically be generated in shorter form. Data stores created in detached container will always have short IDs, data stores created in attached container will opportunistically be short (by using newly added IContainerRuntimeBase.generateDocumentUniqueId() capability)
- Similar DDS names will be opportunistically short (same considerations for detached DDS vs. attached DDS)
- Container level ID Compressor can now be enabled with delay. With such setting, only new IContainerRuntimeBase.generateDocumentUniqueId() is exposed (ID Compressor is not exposed in such case, as leveraging any of its other capabilities requires future container sessions to load ID Compressor on container load, for correctness reasons). Once Container establishes connection and any changes are made in container, newly added API will start generating more compact IDs (in most cases).
- DDS names can no longer start with "_" symbol - this is reserved for FF needs. I've validated that's not an issue for AzureClient (it only creates root object by name, everything else is referred by handle). Our main internal partners almost never use named DDSs (I can find only 4 instances in Loop).
- Data store internal IDs could collide with earlier used names data stores. Earlier versions of FF framework (before DataStore aliasing feature was added) allowed customers to supply IDs for data stores. And thus, files created with earlier versions of framework could have data store IDs that will be similar to names FF will use for newly created data stores ("A", ... "Z", "a"..."z", "AA", etc.). While such collision is possible, it's very unlikely (almost impossible) if user-provided names were at least 4-5 characters long.
- If application runs to these problems, or wants to reduce risks, consider disabling ID compressor via IContainerRuntimeOptions.enableRuntimeIdCompressor = "off".
- IContainerRuntime.createDetachedRootDataStore() is removed. Please use IContainerRuntime.createDetachedDataStore and IDataStore.trySetAlias() instead
- IContainerRuntimeOptions.enableRuntimeIdCompressor has been changes from boolean to tri-state.
-
Updated server dependencies (#19122) 25366b4229
The following Fluid server dependencies have been updated to the latest version, 3.0.0. See the full changelog.
- @fluidframework/gitresources
- @fluidframework/server-kafka-orderer
- @fluidframework/server-lambdas
- @fluidframework/server-lambdas-driver
- @fluidframework/server-local-server
- @fluidframework/server-memory-orderer
- @fluidframework/protocol-base
- @fluidframework/server-routerlicious
- @fluidframework/server-routerlicious-base
- @fluidframework/server-services
- @fluidframework/server-services-client
- @fluidframework/server-services-core
- @fluidframework/server-services-ordering-kafkanode
- @fluidframework/server-services-ordering-rdkafka
- @fluidframework/server-services-ordering-zookeeper
- @fluidframework/server-services-shared
- @fluidframework/server-services-telemetry
- @fluidframework/server-services-utils
- @fluidframework/server-test-utils
- tinylicious
-
Updated @fluidframework/protocol-definitions (#19122) 25366b4229
The @fluidframework/protocol-definitions dependency has been upgraded to v3.1.0. See the full changelog.
-
container-definitions: Fix ISnapshotTreeWithBlobContents and mark internal 9a451d4946
ISnapshotTreeWithBlobContentsis an internal type that should not be used externally. Additionally, the type didn't match the usage, specifically in runtime-utils where ananycast was used to work around undefined blobContents. The type has been updated to reflect that blobContents can be undefined. -
runtime-utils: Removed requestFluidObject 9a451d4946
The
requestFluidObjectutility has been removed. Please migrate all usage of it to the newentryPointpattern.See Removing-IFluidRouter.md for more details.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
-
Dependencies on @fluidframework/protocol-definitions package updated to 3.0.0 871b3493dd
This included the following changes from the protocol-definitions release:
- Updating signal interfaces for some planned improvements. The intention is split the interface between signals
submitted by clients to the server and the resulting signals sent from the server to clients.
- A new optional type member is available on the ISignalMessage interface and a new ISentSignalMessage interface has been added, which will be the typing for signals sent from the client to the server. Both extend a new ISignalMessageBase interface that contains common members.
- The @fluidframework/common-definitions package dependency has been updated to version 1.0.0.
- Updating signal interfaces for some planned improvements. The intention is split the interface between signals
submitted by clients to the server and the resulting signals sent from the server to clients.
-
DEPRECATED: container-loader: Various request related APIs have been deprecated 871b3493dd
Please remove all calls to the following functions and instead use the new
entryPointpattern:requestFluidObjectrequestResolvedObjectFromContainergetDefaultObjectFromContainergetObjectWithIdFromContainergetObjectFromContainer
See Removing-IFluidRouter.md for more details.
-
Server upgrade: dependencies on Fluid server packages updated to 2.0.1 871b3493dd
Dependencies on the following Fluid server package have been updated to version 2.0.1:
- @fluidframework/gitresources: 2.0.1
- @fluidframework/server-kafka-orderer: 2.0.1
- @fluidframework/server-lambdas: 2.0.1
- @fluidframework/server-lambdas-driver: 2.0.1
- @fluidframework/server-local-server: 2.0.1
- @fluidframework/server-memory-orderer: 2.0.1
- @fluidframework/protocol-base: 2.0.1
- @fluidframework/server-routerlicious: 2.0.1
- @fluidframework/server-routerlicious-base: 2.0.1
- @fluidframework/server-services: 2.0.1
- @fluidframework/server-services-client: 2.0.1
- @fluidframework/server-services-core: 2.0.1
- @fluidframework/server-services-ordering-kafkanode: 2.0.1
- @fluidframework/server-services-ordering-rdkafka: 2.0.1
- @fluidframework/server-services-ordering-zookeeper: 2.0.1
- @fluidframework/server-services-shared: 2.0.1
- @fluidframework/server-services-telemetry: 2.0.1
- @fluidframework/server-services-utils: 2.0.1
- @fluidframework/server-test-utils: 2.0.1
- tinylicious: 2.0.1
-
Minimum TypeScript version now 5.1.6 871b3493dd
The minimum supported TypeScript version for Fluid 2.0 clients is now 5.1.6.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
-
Upgraded typescript transpilation target to ES2020 8abce8cdb4
Upgraded typescript transpilation target to ES2020. This is done in order to decrease the bundle sizes of Fluid Framework packages. This has provided size improvements across the board for ex. Loader, Driver, Runtime etc. Reduced bundle sizes helps to load lesser code in apps and hence also helps to improve the perf.If any app wants to target any older versions of browsers with which this target version is not compatible, then they can use packages like babel to transpile to a older target.
-
Remove packagePathToTelemetryProperty Function 8abce8cdb4
packagePathToTelemetryProperty was previously deprecated and is now removed. Use tagCodeArtifacts instead.
Dependency updates only.
Dependency updates only.
Dependency updates only.
Dependency updates only.
- The
@fluidframework/garbage-collectorpackage was deprecated in version 2.0.0-internal.4.1.0. 8b242fdc79 It has now been removed with the following functions, interfaces, and types in it.cloneGCDataconcatGarbageCollectionDataconcatGarbageCollectionStatesGCDataBuildergetGCDataFromSnapshotIGCResultremoveRouteFromAllNodesrunGarbageCollectiontrimLeadingAndTrailingSlashestrimLeadingSlashestrimTrailingSlashesunpackChildNodesGCDetailsunpackChildNodesUsedRoutes
Dependency updates only.
-
GC interfaces removed from runtime-definitions (#14750) 60274eacab
The following interfaces available in
@fluidframework/runtime-definitionsare internal implementation details and have been deprecated for public use. They will be removed in an upcoming release.IGarbageCollectionNodeDataIGarbageCollectionStateIGarbageCollectionSnapshotDataIGarbageCollectionSummaryDetailsLegacy
-
@fluidframework/garbage-collector deprecated (#14750) 60274eacab
The
@fluidframework/garbage-collectorpackage is deprecated with the following functions, interfaces, and types in it. These are internal implementation details and have been deprecated for public use. They will be removed in an upcoming release.cloneGCDataconcatGarbageCollectionDataconcatGarbageCollectionStatesGCDataBuildergetGCDataFromSnapshotIGCResultremoveRouteFromAllNodesrunGarbageCollectiontrimLeadingAndTrailingSlashestrimLeadingSlashestrimTrailingSlashesunpackChildNodesGCDetailsunpackChildNodesUsedRoutes