FluxFlow.Components.Routing 1.1.0

dotnet add package FluxFlow.Components.Routing --version 1.1.0
                    
NuGet\Install-Package FluxFlow.Components.Routing -Version 1.1.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="FluxFlow.Components.Routing" Version="1.1.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="FluxFlow.Components.Routing" Version="1.1.0" />
                    
Directory.Packages.props
<PackageReference Include="FluxFlow.Components.Routing" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add FluxFlow.Components.Routing --version 1.1.0
                    
#r "nuget: FluxFlow.Components.Routing, 1.1.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package FluxFlow.Components.Routing@1.1.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=FluxFlow.Components.Routing&version=1.1.0
                    
Install as a Cake Addin
#tool nuget:?package=FluxFlow.Components.Routing&version=1.1.0
                    
Install as a Cake Tool

FluxFlow.Components.Routing

Reusable expression-driven routing components for FluxFlow.

Nodes

Node type Shape Purpose
flow.switch InputResult, optional Routed, Matched, optional route outputs, Default, Errors Evaluates a route key expression and routes the original input by match status.
flow.correlation Input or Request/ResponseMatched, Timeouts, Errors Pairs request and response style messages by key.
flow.window InputOutput, Errors Groups input items into count or time based windows.
flow.join Left, RightOutput, Timeouts, Errors Joins two typed streams by per-side key expressions.
flow.fork Input → configured named outputs, Errors Copies every input to every configured output.
flow.merge configured named inputs → Output, Errors Combines several same-type streams into one source-tagged stream.

The package does not choose an expression language. Applications provide one or more IFlowExpressionEngine implementations during registration.

var registry = new RuntimeNodeFactoryRegistry()
    .RegisterRoutingComponents(options => options
        .UseExpressionEngine(appExpressionEngine)
        .UseClock(routingClock)
        .RegisterType<AppMessage>("app.message")
        .UseContextFactory(new AppMessageContextFactory()));

UseClock(...) is optional. Without it, routing nodes use the default system clock. Supplying a clock lets hosts and tests make route timestamps, window timers, join timeouts, and correlation timestamps deterministic.

Switch

Basic configuration:

{
  "type": "flow.switch",
  "inputType": "app.message",
  "engine": "my-engine",
  "expression": "category",
  "routes": [ "priority", "standard" ],
  "routeOutputs": {
    "priority": "Priority",
    "standard": "Standard"
  },
  "defaultRoute": "unknown"
}

Result emits FlowSwitchResult<TInput> so downstream links can inspect RouteKey, Matched, and the original Value. Matched emits the original input when the key is in routes. Default emits the original input when the key is empty or not configured.

routeOutputs is optional. When configured, the runtime adds those output ports and emits the original input to the matching route port. Several route keys can map to the same output port. Route output port names must be valid engine port names and cannot collide with built-in switch ports.

If routes is empty, every non-empty route key is treated as matched. This lets hosts use the result envelope and link conditions without predeclaring every route key.

Set emitRouteEnvelope to true when downstream nodes need one neutral route object instead of, or in addition to, direct route ports. Routed emits FlowRoute<TInput> with route key, selected route, match status, default route, matched output port, expression metadata, input type, and original value.

Expression evaluation failures emit FlowError and the node continues processing later messages.

Correlation

Use flow.correlation when a workflow receives related messages and needs to pair them by key.

Single-stream mode uses Input and a sideExpression:

{
  "type": "flow.correlation",
  "inputType": "app.message",
  "engine": "my-engine",
  "keyExpression": "correlationId",
  "sideExpression": "kind",
  "requestSide": "request",
  "responseSide": "response",
  "timeoutMilliseconds": 30000,
  "maxPending": 1024
}

Split-stream mode omits sideExpression and exposes separate Request and Response inputs:

{
  "type": "flow.correlation",
  "inputType": "app.message",
  "engine": "my-engine",
  "keyExpression": "correlationId",
  "timeoutMilliseconds": 30000,
  "maxPending": 1024
}

Matched emits FlowCorrelationMatch<TInput> with the request, response, key, timestamps, and elapsed time. Timeouts emits FlowCorrelationTimeout<TInput> for unmatched pending inputs when the timeout is observed before the next input, and for any remaining pending inputs when the node completes.

Invalid keys, unsupported sides, duplicate same-side messages, expression failures, and pending-capacity failures emit FlowError and the node continues processing later messages.

Window

Use flow.window when a workflow needs batches of items before a downstream node runs.

{
  "type": "flow.window",
  "inputType": "app.message",
  "maxItems": 100,
  "timeMilliseconds": 5000,
  "emitPartialOnCompletion": true
}

Output emits FlowWindow<TInput> with a sequence number, item list, start and emit timestamps, duration, count, and emit reason. maxItems emits when the window reaches the configured count. timeMilliseconds emits when the current window has been open for that duration, even if no later input arrives. When both are configured, whichever condition happens first emits the window.

At least one boundary must be configured. On completion, a partial window is emitted by default. Set emitPartialOnCompletion to false to discard partial windows.

Join

Use flow.join when a workflow needs to pair values from two streams by key.

{
  "type": "flow.join",
  "leftInputType": "app.request",
  "rightInputType": "app.response",
  "engine": "my-engine",
  "leftKeyExpression": "correlationId",
  "rightKeyExpression": "correlationId",
  "timeoutMilliseconds": 30000,
  "maxPending": 1024
}

Output emits FlowJoinResult<TLeft, TRight> with the joined left and right values, key, timestamps, and elapsed time. Timeouts emits FlowJoinTimeout<TLeft, TRight> for unmatched pending values when the timeout expires or when the node completes.

Repeated keys are paired in FIFO order. Key evaluation failures, empty keys, and pending-capacity failures emit FlowError and the node continues processing later values.

Fork

Use flow.fork when every downstream branch must receive every item.

{
  "type": "flow.fork",
  "inputType": "app.message",
  "outputs": [ "Audit", "Transform", "Dashboard" ]
}

Each configured output port emits the original input type. The node sends each item to every output in configured order, then completes all outputs after the input completes. Output names must be valid engine port names and cannot collide with built-in fork ports.

Merge

Use flow.merge when several same-type streams should converge while retaining the source port name.

{
  "type": "flow.merge",
  "inputType": "app.message",
  "inputs": [ "Primary", "Retry", "Replay" ]
}

Output emits FlowMergeItem<TInput> with sequence number, source input port, received timestamp, and original value. The node completes only after every configured input completes. Input names must be valid engine port names and cannot collide with built-in merge ports.

Design Metadata

This package exposes a package-owned IComponentDesignMetadataProvider for its node types. Hosts can compose it through ComponentDesignMetadataCatalog to populate palettes, editors, validation views, and documentation without duplicating package descriptors.

Composition Guidance

Use this package as one part of a host-composed graph. See Component Composition for recommended host boundaries, package boundaries, and extraction timing.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 is compatible.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
1.1.0 6 6/5/2026
1.0.0 47 6/4/2026
0.10.0-alpha.1 80 6/2/2026
0.9.0-alpha.1 40 6/2/2026
0.8.0-alpha.1 37 6/2/2026
0.7.0-alpha.1 37 6/2/2026
0.6.1-alpha.1 44 6/2/2026
0.6.0-alpha.1 54 6/2/2026
0.5.0-alpha.1 33 6/2/2026
0.4.0-alpha.1 35 6/2/2026
0.3.0-alpha.1 33 6/2/2026
0.2.0-alpha.2 32 6/2/2026
0.1.0-alpha.1 35 6/2/2026

Adds package-owned IComponentDesignMetadataProvider metadata for host palettes, editors, validation views, generated docs, and catalog composition while keeping runtime behavior unchanged.