![]() |
VOOZH | about |
dotnet add package Mostlylucid.Ephemeral.Atoms.Escalator --version 2.6.3
NuGet\Install-Package Mostlylucid.Ephemeral.Atoms.Escalator -Version 2.6.3
<PackageReference Include="Mostlylucid.Ephemeral.Atoms.Escalator" Version="2.6.3" />
<PackageVersion Include="Mostlylucid.Ephemeral.Atoms.Escalator" Version="2.6.3" />Directory.Packages.props
<PackageReference Include="Mostlylucid.Ephemeral.Atoms.Escalator" />Project file
paket add Mostlylucid.Ephemeral.Atoms.Escalator --version 2.6.3
#r "nuget: Mostlylucid.Ephemeral.Atoms.Escalator, 2.6.3"
#:package Mostlylucid.Ephemeral.Atoms.Escalator@2.6.3
#addin nuget:?package=Mostlylucid.Ephemeral.Atoms.Escalator&version=2.6.3Install as a Cake Addin
#tool nuget:?package=Mostlylucid.Ephemeral.Atoms.Escalator&version=2.6.3Install as a Cake Tool
Promotes typed, ephemeral signals into durable sinks. EscalatorAtoms are the preferred way to persist outputs from short-lived coordinators. They sit at the boundary between in-memory runs and long-term storage.
WARNING - This is still in the 1.x lab phase; APIs may change.
dotnet add package Mostlylucid.Ephemeral.Atoms.Escalator
using Mostlylucid.Ephemeral;
using Mostlylucid.Ephemeral.Atoms.Data.File;
using Mostlylucid.Ephemeral.Atoms.Escalator;
public sealed record EscalationPayload(string Kind, string? EvidenceId, double Confidence);
var sink = new SignalSink();
var typed = new TypedSignalSink<EscalationPayload>(sink);
await using var storage = new FileDataStorageAtom<string, EscalationPayload>(
sink,
new FileDataStorageConfig { DatabaseName = "signals" });
Func<string, CancellationToken, Task> audit = (line, ct) =>
{
Console.WriteLine(line);
return Task.CompletedTask;
};
var targets = new[]
{
new EscalationTarget<EscalationPayload>(
"signals",
(evt, ct) => storage.SaveAsync(evt.Key ?? evt.OperationId.ToString(), evt.Payload, ct)),
new EscalationTarget<EscalationPayload>(
"audit",
(evt, ct) => audit($"{evt.Timestamp:o} {evt.Signal} {evt.Key}", ct))
};
await using var escalator = new EscalatorAtom<EscalationPayload>(
sink,
typed,
targets,
new EscalatorAtomOptions<EscalationPayload>
{
EscalateSignalPattern = "escalate.*",
EmitOnSuccess = "escalation.persisted",
EmitOnFailure = "escalation.failed"
});
// Emit a typed signal from a coordinator or molecule.
typed.Raise("escalate.signal", new EscalationPayload("risk", "file-42", 0.81), key: "order-123");
EscalateSignalPattern: glob pattern to match typed signals (default: escalate.*).ShouldEscalate: predicate to override escalation decisions.CoordinatorOptions: control concurrency, retention, and window size for the internal coordinator.EmitOnSuccess: untyped signal name raised after all targets persist.EmitOnFailure: untyped signal name raised when a target fails (suffix includes exception type).| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net8.0 net8.0 is compatible. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 is compatible. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 is compatible. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
Showing the top 1 NuGet packages that depend on Mostlylucid.Ephemeral.Atoms.Escalator:
| Package | Downloads |
|---|---|
|
mostlylucid.ephemeral.complete
Meta-package that references all Mostlylucid.Ephemeral packages - bounded async execution with signals, atoms, and patterns. Install this single package to get everything. |
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.6.3 | 100 | 5/22/2026 |
| 2.6.2 | 99 | 5/22/2026 |
| 2.6.0 | 95 | 5/22/2026 |
| 2.5.1 | 93 | 5/22/2026 |
| 2.5.0 | 106 | 5/3/2026 |
| 2.4.0 | 106 | 4/17/2026 |
| 2.3.2 | 131 | 1/9/2026 |
| 2.3.1 | 123 | 1/9/2026 |
| 2.3.1-alpha0 | 116 | 1/9/2026 |
| 2.3.0 | 1,198 | 1/8/2026 |
| 2.3.0-alpha1 | 115 | 1/8/2026 |
| 2.1.0 | 128 | 1/8/2026 |
| 2.1.0-preview | 119 | 1/8/2026 |
| 2.0.1 | 128 | 1/8/2026 |
| 2.0.0 | 164 | 1/8/2026 |
| 2.0.0-alpha1 | 116 | 1/8/2026 |
| 2.0.0-alpha0 | 117 | 1/8/2026 |