Interface IFlowRunStore
- Namespace
- FlowOrchestrator.Core.Storage
- Assembly
- FlowOrchestrator.Core.dll
Persistence contract for flow run lifecycle: creating runs, recording step progress, completing runs, and querying run history.
public interface IFlowRunStore
Methods
AnnotateDispatchAsync(Guid, string, string, CancellationToken)
Stores the runtime job or message ID returned by the dispatcher alongside the dispatch record. Best-effort — implementations should not throw; failures are silently ignored by the engine.
Task AnnotateDispatchAsync(Guid runId, string stepKey, string jobId, CancellationToken ct = default)
Parameters
runIdGuidstepKeystringjobIdstringctCancellationToken
Returns
CompleteRunAsync(Guid, string)
Marks the run as complete (status: Succeeded, Failed, or Cancelled)
and sets CompletedAt.
Task CompleteRunAsync(Guid runId, string status)
Parameters
Returns
GetActiveRunsAsync()
Returns all runs currently in Running status (used for timeout enforcement).
Task<IReadOnlyList<FlowRunRecord>> GetActiveRunsAsync()
Returns
GetDerivedRunsAsync(Guid)
Returns runs whose SourceRunId equals sourceRunId,
i.e. all re-runs derived from a given run. Used by the dashboard to render lineage.
Task<IReadOnlyList<FlowRunRecord>> GetDerivedRunsAsync(Guid sourceRunId)
Parameters
sourceRunIdGuid
Returns
GetDispatchedStepKeysAsync(Guid)
Returns the set of step keys that have been dispatched (and not yet released) for a run. Used by the recovery service to avoid re-dispatching already-in-flight steps.
Task<IReadOnlySet<string>> GetDispatchedStepKeysAsync(Guid runId)
Parameters
runIdGuid
Returns
GetRunDetailAsync(Guid)
Returns full run detail including all step records and their attempt history,
or null if no run with runId exists.
Task<FlowRunRecord?> GetRunDetailAsync(Guid runId)
Parameters
runIdGuid
Returns
GetRunTimeseriesAsync(RunTimeseriesGranularity, DateTimeOffset, DateTimeOffset, Guid?)
Returns time-bucketed run counts and duration percentiles for the half-open
interval [since, until). Buckets that contain
no runs are still returned (with zero counts) so the caller can render a contiguous
timeline without gap-filling. When flowId is supplied, only runs
for that flow are included.
Task<IReadOnlyList<RunTimeseriesBucket>> GetRunTimeseriesAsync(RunTimeseriesGranularity granularity, DateTimeOffset since, DateTimeOffset until, Guid? flowId = null)
Parameters
granularityRunTimeseriesGranularityHour or Day bucket size.
sinceDateTimeOffsetUTC start of the window (inclusive). Aligned to the granularity boundary.
untilDateTimeOffsetUTC end of the window (exclusive). Aligned to the granularity boundary.
flowIdGuid?Optional filter — when non-null, only runs for this flow are counted.
Returns
GetRunsAsync(Guid?, int, int)
Returns a page of run records, optionally filtered by flowId.
Results are ordered by start time descending.
Task<IReadOnlyList<FlowRunRecord>> GetRunsAsync(Guid? flowId = null, int skip = 0, int take = 50)
Parameters
Returns
GetRunsPageAsync(Guid?, string?, int, int, string?)
Returns a paginated run list with total count, supporting filtering by flow, status, and search text.
Task<(IReadOnlyList<FlowRunRecord> Runs, int TotalCount)> GetRunsPageAsync(Guid? flowId = null, string? status = null, int skip = 0, int take = 50, string? search = null)
Parameters
Returns
GetStatisticsAsync()
Returns aggregate counts used by the dashboard overview panel.
Task<DashboardStatistics> GetStatisticsAsync()
Returns
RecordStepCompleteAsync(Guid, string, string, string?, string?)
Records the outcome of a step attempt: updates status, persists output JSON, and sets error message on failure.
Task RecordStepCompleteAsync(Guid runId, string stepKey, string status, string? outputJson, string? errorMessage)
Parameters
Returns
RecordStepStartAsync(Guid, string, string, string?, string?)
Records the start of a step attempt: sets status to Running, persists inputs, and associates the Hangfire job ID.
Task RecordStepStartAsync(Guid runId, string stepKey, string stepType, string? inputJson, string? jobId)
Parameters
Returns
ReleaseDispatchAsync(Guid, string, CancellationToken)
Removes the dispatch record for a step, allowing it to be re-dispatched. Called by the engine before rescheduling a Pending (polling) step.
Task ReleaseDispatchAsync(Guid runId, string stepKey, CancellationToken ct = default)
Parameters
runIdGuidstepKeystringctCancellationToken
Returns
RetryStepAsync(Guid, string)
Resets a step back to a re-runnable state so it can be re-enqueued by the retry flow.
Clears Running/Failed status and increments attempt count.
Task RetryStepAsync(Guid runId, string stepKey)
Parameters
Returns
StartRunAsync(Guid, string, Guid, string, string?, string?, Guid?)
Creates a new run record in Running status and returns it.
Called once per TriggerAsync invocation.
Task<FlowRunRecord> StartRunAsync(Guid flowId, string flowName, Guid runId, string triggerKey, string? triggerData, string? jobId, Guid? sourceRunId = null)
Parameters
flowIdGuidThe flow definition this run belongs to.
flowNamestringDisplay name of the flow at trigger time.
runIdGuidUnique identifier for this run, generated by the engine.
triggerKeystringThe manifest trigger key that fired (e.g.
"manual","schedule").triggerDatastringJSON-serialised trigger payload, or null.
jobIdstringRuntime job ID (e.g. Hangfire BackgroundJobId) for cross-referencing, or null.
sourceRunIdGuid?When this run was created via "Re-run all" on a previous run, the ID of that run; otherwise null.
Returns
TryRecordDispatchAsync(Guid, string, CancellationToken)
Atomically records that a step has been dispatched for execution. Returns true if this is the first dispatch for this step in this run; false if the step was already dispatched (idempotent guard — caller should skip).
Task<bool> TryRecordDispatchAsync(Guid runId, string stepKey, CancellationToken ct = default)
Parameters
runIdGuidstepKeystringctCancellationToken
Returns
Remarks
Must use an atomic INSERT-if-not-exists primitive (SQL WHERE NOT EXISTS,
PostgreSQL ON CONFLICT DO NOTHING, or TryAdd(TKey, TValue)).