2.5 KiB
Orchestrator — Advanced Flow Patterns
Status: Proposed Epic: orchestrator-flow-advanced Depends on: v2.7.17-orchestrator (flow-runner already shipped)
Why
The orchestrator (shipped v2.7.17) runs sequential research/analysis flows on local Qwen. Each step is a linear dependency chain: A → B → C. This works for analysis flows (code-review, investigate) but limits three high-value scenarios:
- Parallel research — "Analyze this from 3 angles" currently requires 3 separate runs. A single flow with parallel branches would halve the wall-clock time.
- Adaptive depth — "Investigate bug, and if it's a security issue, escalate to security review" requires conditional branching. Currently all steps run unconditionally.
- Human-in-the-loop — "Review the diff and approve before applying" requires the orchestrator to pause and wait for user input before proceeding.
The patterns from the Ion hybrid workflow engine (trigger rules, event sourcing, approval gates, variable substitution) provide a proven vocabulary for these scenarios — we adapt the patterns without adopting the project.
What Changes
Trigger rules on step deps
Add trigger_rule?: 'all_success' | 'one_success' | 'all_done' to the Step type. Default all_success preserves existing behavior.
all_success— step runs when ALL dependencies complete successfully (current behavior)one_success— step runs when ANY dependency completes (parallel research: whichever finishes first seeds the synthesis)all_done— step runs when all deps finish regardless of status (cleanup/reporting steps)
Variable substitution in step prompts
Add $stepId.output and $stepId.output.field syntax in step prompts. The flow-runner resolves these before dispatching.
$research.output— the full text output of step with id "research"$classify.output.severity— the "severity" field from step output parsed as YAML/JSON frontmatter
Human approval gate
New kind: 'approval' step type that pauses the flow and publishes a permission frame to the user channel. Flow resumes when the user approves or rejects.
Event-sourced step log
Append-only event log for each step execution (start, complete, fail, skip, pause, resume). Enables deterministic resume after coder restart without polling.
Non-Goals
- No YAML DAG format (stay with TypeScript flow definitions)
- No CLI tool (orchestrator stays in-app)
- No replacement of the existing flow definitions — additive changes only
- No VM sandbox or WASM