agent-relay 2.3.2 → 2.3.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/index.cjs +1 -1
- package/dist/src/cli/index.js +124 -7
- package/dist/src/cli/index.js.map +1 -1
- package/package.json +20 -26
- package/packages/acp-bridge/package.json +2 -2
- package/packages/bridge/package.json +7 -7
- package/packages/config/dist/cloud-config.d.ts +1 -1
- package/packages/config/dist/cloud-config.d.ts.map +1 -1
- package/packages/config/dist/cloud-config.js.map +1 -1
- package/packages/config/dist/schemas.d.ts +5 -5
- package/packages/config/dist/schemas.js +1 -1
- package/packages/config/dist/schemas.js.map +1 -1
- package/packages/config/package.json +2 -2
- package/packages/config/src/cloud-config.ts +2 -2
- package/packages/config/src/schemas.test.ts +48 -0
- package/packages/config/src/schemas.ts +1 -1
- package/packages/continuity/package.json +2 -2
- package/packages/daemon/package.json +12 -12
- package/packages/hooks/package.json +4 -4
- package/packages/mcp/package.json +5 -5
- package/packages/memory/package.json +2 -2
- package/packages/policy/package.json +2 -2
- package/packages/protocol/package.json +1 -1
- package/packages/resiliency/package.json +1 -1
- package/packages/sdk/dist/index.d.ts +1 -29
- package/packages/sdk/dist/index.d.ts.map +1 -1
- package/packages/sdk/dist/index.js +1 -38
- package/packages/sdk/dist/index.js.map +1 -1
- package/packages/sdk/package.json +4 -25
- package/packages/sdk/src/index.ts +1 -69
- package/packages/sdk-py/README.md +56 -0
- package/packages/sdk-py/pyproject.toml +23 -0
- package/packages/sdk-py/src/agent_relay/__init__.py +27 -0
- package/packages/sdk-py/src/agent_relay/builder.py +367 -0
- package/packages/sdk-py/src/agent_relay/types.py +92 -0
- package/packages/sdk-py/tests/__init__.py +0 -0
- package/packages/sdk-py/tests/test_builder.py +101 -0
- package/packages/sdk-ts/dist/__tests__/facade.test.d.ts +2 -0
- package/packages/sdk-ts/dist/__tests__/facade.test.d.ts.map +1 -0
- package/packages/sdk-ts/dist/__tests__/facade.test.js +257 -0
- package/packages/sdk-ts/dist/__tests__/facade.test.js.map +1 -0
- package/packages/sdk-ts/dist/__tests__/unit.test.d.ts +2 -0
- package/packages/sdk-ts/dist/__tests__/unit.test.d.ts.map +1 -0
- package/packages/sdk-ts/dist/__tests__/unit.test.js +124 -0
- package/packages/sdk-ts/dist/__tests__/unit.test.js.map +1 -0
- package/packages/sdk-ts/dist/client.d.ts +2 -0
- package/packages/sdk-ts/dist/client.d.ts.map +1 -1
- package/packages/sdk-ts/dist/client.js +2 -0
- package/packages/sdk-ts/dist/client.js.map +1 -1
- package/packages/sdk-ts/dist/index.d.ts +1 -0
- package/packages/sdk-ts/dist/index.d.ts.map +1 -1
- package/packages/sdk-ts/dist/index.js +1 -0
- package/packages/sdk-ts/dist/index.js.map +1 -1
- package/packages/sdk-ts/dist/protocol.d.ts +1 -0
- package/packages/sdk-ts/dist/protocol.d.ts.map +1 -1
- package/packages/sdk-ts/dist/relay.d.ts +44 -0
- package/packages/sdk-ts/dist/relay.d.ts.map +1 -1
- package/packages/sdk-ts/dist/relay.js +89 -11
- package/packages/sdk-ts/dist/relay.js.map +1 -1
- package/packages/sdk-ts/dist/relaycast.js +2 -2
- package/packages/sdk-ts/dist/relaycast.js.map +1 -1
- package/packages/sdk-ts/dist/workflows/barrier.d.ts +72 -0
- package/packages/sdk-ts/dist/workflows/barrier.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/barrier.js +162 -0
- package/packages/sdk-ts/dist/workflows/barrier.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/builder.d.ts +101 -0
- package/packages/sdk-ts/dist/workflows/builder.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/builder.js +179 -0
- package/packages/sdk-ts/dist/workflows/builder.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/cli.d.ts +10 -0
- package/packages/sdk-ts/dist/workflows/cli.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/cli.js +82 -0
- package/packages/sdk-ts/dist/workflows/cli.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/coordinator.d.ts +68 -0
- package/packages/sdk-ts/dist/workflows/coordinator.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/coordinator.js +353 -0
- package/packages/sdk-ts/dist/workflows/coordinator.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/index.d.ts +10 -0
- package/packages/sdk-ts/dist/workflows/index.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/index.js +10 -0
- package/packages/sdk-ts/dist/workflows/index.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/memory-db.d.ts +17 -0
- package/packages/sdk-ts/dist/workflows/memory-db.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/memory-db.js +33 -0
- package/packages/sdk-ts/dist/workflows/memory-db.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/run.d.ts +31 -0
- package/packages/sdk-ts/dist/workflows/run.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/run.js +24 -0
- package/packages/sdk-ts/dist/workflows/run.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/runner.d.ts +119 -0
- package/packages/sdk-ts/dist/workflows/runner.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/runner.js +650 -0
- package/packages/sdk-ts/dist/workflows/runner.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/state.d.ts +77 -0
- package/packages/sdk-ts/dist/workflows/state.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/state.js +140 -0
- package/packages/sdk-ts/dist/workflows/state.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/templates.d.ts +47 -0
- package/packages/sdk-ts/dist/workflows/templates.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/templates.js +395 -0
- package/packages/sdk-ts/dist/workflows/templates.js.map +1 -0
- package/packages/sdk-ts/dist/workflows/types.d.ts +126 -0
- package/packages/sdk-ts/dist/workflows/types.d.ts.map +1 -0
- package/packages/sdk-ts/dist/workflows/types.js +8 -0
- package/packages/sdk-ts/dist/workflows/types.js.map +1 -0
- package/packages/sdk-ts/package.json +9 -3
- package/packages/sdk-ts/src/__tests__/error-scenarios.test.ts +682 -0
- package/packages/sdk-ts/src/__tests__/facade.test.ts +296 -0
- package/packages/sdk-ts/src/__tests__/swarm-coordinator.test.ts +416 -0
- package/packages/sdk-ts/src/__tests__/unit.test.ts +152 -0
- package/packages/sdk-ts/src/__tests__/workflow-runner.test.ts +333 -0
- package/packages/sdk-ts/src/client.ts +4 -0
- package/packages/sdk-ts/src/index.ts +1 -0
- package/packages/sdk-ts/src/protocol.ts +1 -1
- package/packages/sdk-ts/src/relay.ts +112 -11
- package/packages/sdk-ts/src/relaycast.ts +2 -2
- package/packages/sdk-ts/src/workflows/README.md +450 -0
- package/packages/sdk-ts/src/workflows/barrier.ts +254 -0
- package/packages/sdk-ts/src/workflows/builder.ts +241 -0
- package/packages/sdk-ts/src/workflows/builtin-templates/bug-fix.yaml +75 -0
- package/packages/sdk-ts/src/workflows/builtin-templates/code-review.yaml +82 -0
- package/packages/sdk-ts/src/workflows/builtin-templates/documentation.yaml +70 -0
- package/packages/sdk-ts/src/workflows/builtin-templates/feature-dev.yaml +76 -0
- package/packages/sdk-ts/src/workflows/builtin-templates/refactor.yaml +82 -0
- package/packages/sdk-ts/src/workflows/builtin-templates/security-audit.yaml +84 -0
- package/packages/sdk-ts/src/workflows/cli.ts +93 -0
- package/packages/sdk-ts/src/workflows/coordinator.ts +520 -0
- package/packages/sdk-ts/src/workflows/index.ts +9 -0
- package/packages/sdk-ts/src/workflows/memory-db.ts +39 -0
- package/packages/sdk-ts/src/workflows/run.ts +47 -0
- package/packages/sdk-ts/src/workflows/runner.ts +873 -0
- package/packages/sdk-ts/src/workflows/schema.json +321 -0
- package/packages/sdk-ts/src/workflows/state.ts +279 -0
- package/packages/sdk-ts/src/workflows/templates.ts +544 -0
- package/packages/sdk-ts/src/workflows/types.ts +178 -0
- package/packages/sdk-ts/tsconfig.json +6 -1
- package/packages/spawner/package.json +1 -1
- package/packages/state/package.json +1 -1
- package/packages/storage/package.json +2 -2
- package/packages/telemetry/package.json +1 -1
- package/packages/trajectory/package.json +2 -2
- package/packages/user-directory/package.json +2 -2
- package/packages/utils/package.json +3 -3
- package/packages/wrapper/package.json +5 -6
- package/scripts/postinstall.js +106 -2
- package/packages/api-types/.trajectories/active/traj_xbsvuzogscey.json +0 -15
- package/packages/api-types/.trajectories/index.json +0 -12
- package/packages/api-types/dist/index.d.ts +0 -21
- package/packages/api-types/dist/index.d.ts.map +0 -1
- package/packages/api-types/dist/index.js +0 -22
- package/packages/api-types/dist/index.js.map +0 -1
- package/packages/api-types/dist/schemas/agent.d.ts +0 -259
- package/packages/api-types/dist/schemas/agent.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/agent.js +0 -102
- package/packages/api-types/dist/schemas/agent.js.map +0 -1
- package/packages/api-types/dist/schemas/api.d.ts +0 -290
- package/packages/api-types/dist/schemas/api.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/api.js +0 -162
- package/packages/api-types/dist/schemas/api.js.map +0 -1
- package/packages/api-types/dist/schemas/decision.d.ts +0 -230
- package/packages/api-types/dist/schemas/decision.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/decision.js +0 -104
- package/packages/api-types/dist/schemas/decision.js.map +0 -1
- package/packages/api-types/dist/schemas/fleet.d.ts +0 -615
- package/packages/api-types/dist/schemas/fleet.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/fleet.js +0 -71
- package/packages/api-types/dist/schemas/fleet.js.map +0 -1
- package/packages/api-types/dist/schemas/history.d.ts +0 -180
- package/packages/api-types/dist/schemas/history.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/history.js +0 -72
- package/packages/api-types/dist/schemas/history.js.map +0 -1
- package/packages/api-types/dist/schemas/index.d.ts +0 -14
- package/packages/api-types/dist/schemas/index.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/index.js +0 -22
- package/packages/api-types/dist/schemas/index.js.map +0 -1
- package/packages/api-types/dist/schemas/message.d.ts +0 -456
- package/packages/api-types/dist/schemas/message.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/message.js +0 -88
- package/packages/api-types/dist/schemas/message.js.map +0 -1
- package/packages/api-types/dist/schemas/session.d.ts +0 -60
- package/packages/api-types/dist/schemas/session.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/session.js +0 -36
- package/packages/api-types/dist/schemas/session.js.map +0 -1
- package/packages/api-types/dist/schemas/task.d.ts +0 -111
- package/packages/api-types/dist/schemas/task.d.ts.map +0 -1
- package/packages/api-types/dist/schemas/task.js +0 -64
- package/packages/api-types/dist/schemas/task.js.map +0 -1
- package/packages/api-types/package.json +0 -61
- package/packages/api-types/scripts/generate-openapi.ts +0 -106
- package/packages/api-types/src/index.ts +0 -22
- package/packages/api-types/src/schemas/agent.test.ts +0 -164
- package/packages/api-types/src/schemas/agent.ts +0 -110
- package/packages/api-types/src/schemas/api.test.ts +0 -372
- package/packages/api-types/src/schemas/api.ts +0 -194
- package/packages/api-types/src/schemas/decision.test.ts +0 -324
- package/packages/api-types/src/schemas/decision.ts +0 -136
- package/packages/api-types/src/schemas/fleet.test.ts +0 -212
- package/packages/api-types/src/schemas/fleet.ts +0 -83
- package/packages/api-types/src/schemas/history.test.ts +0 -242
- package/packages/api-types/src/schemas/history.ts +0 -84
- package/packages/api-types/src/schemas/index.ts +0 -148
- package/packages/api-types/src/schemas/message.test.ts +0 -192
- package/packages/api-types/src/schemas/message.ts +0 -98
- package/packages/api-types/src/schemas/session.test.ts +0 -104
- package/packages/api-types/src/schemas/session.ts +0 -40
- package/packages/api-types/src/schemas/task.test.ts +0 -192
- package/packages/api-types/src/schemas/task.ts +0 -78
- package/packages/api-types/tsconfig.json +0 -19
- package/packages/api-types/vitest.config.ts +0 -9
- package/packages/benchmark/README.md +0 -200
- package/packages/benchmark/datasets/coding-tasks.yaml +0 -127
- package/packages/benchmark/datasets/coordination-tasks.yaml +0 -122
- package/packages/benchmark/datasets/quick-test.yaml +0 -20
- package/packages/benchmark/dist/benchmark.d.ts +0 -47
- package/packages/benchmark/dist/benchmark.d.ts.map +0 -1
- package/packages/benchmark/dist/benchmark.js +0 -224
- package/packages/benchmark/dist/benchmark.js.map +0 -1
- package/packages/benchmark/dist/cli.d.ts +0 -8
- package/packages/benchmark/dist/cli.d.ts.map +0 -1
- package/packages/benchmark/dist/cli.js +0 -185
- package/packages/benchmark/dist/cli.js.map +0 -1
- package/packages/benchmark/dist/harbor.d.ts +0 -53
- package/packages/benchmark/dist/harbor.d.ts.map +0 -1
- package/packages/benchmark/dist/harbor.js +0 -127
- package/packages/benchmark/dist/harbor.js.map +0 -1
- package/packages/benchmark/dist/index.d.ts +0 -48
- package/packages/benchmark/dist/index.d.ts.map +0 -1
- package/packages/benchmark/dist/index.js +0 -50
- package/packages/benchmark/dist/index.js.map +0 -1
- package/packages/benchmark/dist/runners/base.d.ts +0 -63
- package/packages/benchmark/dist/runners/base.d.ts.map +0 -1
- package/packages/benchmark/dist/runners/base.js +0 -156
- package/packages/benchmark/dist/runners/base.js.map +0 -1
- package/packages/benchmark/dist/runners/index.d.ts +0 -10
- package/packages/benchmark/dist/runners/index.d.ts.map +0 -1
- package/packages/benchmark/dist/runners/index.js +0 -10
- package/packages/benchmark/dist/runners/index.js.map +0 -1
- package/packages/benchmark/dist/runners/single.d.ts +0 -19
- package/packages/benchmark/dist/runners/single.d.ts.map +0 -1
- package/packages/benchmark/dist/runners/single.js +0 -111
- package/packages/benchmark/dist/runners/single.js.map +0 -1
- package/packages/benchmark/dist/runners/subagent.d.ts +0 -32
- package/packages/benchmark/dist/runners/subagent.d.ts.map +0 -1
- package/packages/benchmark/dist/runners/subagent.js +0 -212
- package/packages/benchmark/dist/runners/subagent.js.map +0 -1
- package/packages/benchmark/dist/runners/swarm.d.ts +0 -36
- package/packages/benchmark/dist/runners/swarm.d.ts.map +0 -1
- package/packages/benchmark/dist/runners/swarm.js +0 -273
- package/packages/benchmark/dist/runners/swarm.js.map +0 -1
- package/packages/benchmark/dist/types.d.ts +0 -178
- package/packages/benchmark/dist/types.d.ts.map +0 -1
- package/packages/benchmark/dist/types.js +0 -16
- package/packages/benchmark/dist/types.js.map +0 -1
- package/packages/benchmark/package.json +0 -80
- package/packages/benchmark/src/benchmark.ts +0 -298
- package/packages/benchmark/src/cli.ts +0 -240
- package/packages/benchmark/src/harbor.ts +0 -170
- package/packages/benchmark/src/index.ts +0 -73
- package/packages/benchmark/src/runners/base.ts +0 -205
- package/packages/benchmark/src/runners/index.ts +0 -10
- package/packages/benchmark/src/runners/single.ts +0 -121
- package/packages/benchmark/src/runners/subagent.ts +0 -240
- package/packages/benchmark/src/runners/swarm.ts +0 -326
- package/packages/benchmark/src/types.ts +0 -205
- package/packages/benchmark/tsconfig.json +0 -20
- package/packages/cli-tester/README.md +0 -277
- package/packages/cli-tester/dist/index.d.ts +0 -21
- package/packages/cli-tester/dist/index.d.ts.map +0 -1
- package/packages/cli-tester/dist/index.js +0 -21
- package/packages/cli-tester/dist/index.js.map +0 -1
- package/packages/cli-tester/dist/utils/credential-check.d.ts +0 -56
- package/packages/cli-tester/dist/utils/credential-check.d.ts.map +0 -1
- package/packages/cli-tester/dist/utils/credential-check.js +0 -230
- package/packages/cli-tester/dist/utils/credential-check.js.map +0 -1
- package/packages/cli-tester/dist/utils/socket-client.d.ts +0 -76
- package/packages/cli-tester/dist/utils/socket-client.d.ts.map +0 -1
- package/packages/cli-tester/dist/utils/socket-client.js +0 -153
- package/packages/cli-tester/dist/utils/socket-client.js.map +0 -1
- package/packages/cli-tester/docker/Dockerfile +0 -61
- package/packages/cli-tester/docker/docker-compose.yml +0 -71
- package/packages/cli-tester/docker/entrypoint.sh +0 -58
- package/packages/cli-tester/package.json +0 -32
- package/packages/cli-tester/scripts/clear-auth.sh +0 -101
- package/packages/cli-tester/scripts/inject-message.sh +0 -42
- package/packages/cli-tester/scripts/start.sh +0 -71
- package/packages/cli-tester/scripts/test-cli.sh +0 -56
- package/packages/cli-tester/scripts/test-full-spawn.sh +0 -238
- package/packages/cli-tester/scripts/test-registration.sh +0 -182
- package/packages/cli-tester/scripts/test-setup-flow.sh +0 -202
- package/packages/cli-tester/scripts/test-spawn.sh +0 -140
- package/packages/cli-tester/scripts/test-with-daemon.sh +0 -247
- package/packages/cli-tester/scripts/verify-auth.sh +0 -112
- package/packages/cli-tester/src/index.ts +0 -40
- package/packages/cli-tester/src/utils/credential-check.ts +0 -284
- package/packages/cli-tester/src/utils/socket-client.ts +0 -211
- package/packages/cli-tester/tests/credential-check.test.ts +0 -56
- package/packages/cli-tester/tsconfig.json +0 -11
- package/packages/sdk/dist/browser-client.d.ts +0 -212
- package/packages/sdk/dist/browser-client.d.ts.map +0 -1
- package/packages/sdk/dist/browser-client.js +0 -750
- package/packages/sdk/dist/browser-client.js.map +0 -1
- package/packages/sdk/dist/browser-framing.d.ts +0 -46
- package/packages/sdk/dist/browser-framing.d.ts.map +0 -1
- package/packages/sdk/dist/browser-framing.js +0 -122
- package/packages/sdk/dist/browser-framing.js.map +0 -1
- package/packages/sdk/dist/standalone.d.ts +0 -89
- package/packages/sdk/dist/standalone.d.ts.map +0 -1
- package/packages/sdk/dist/standalone.js +0 -131
- package/packages/sdk/dist/standalone.js.map +0 -1
- package/packages/sdk/dist/transports/index.d.ts +0 -92
- package/packages/sdk/dist/transports/index.d.ts.map +0 -1
- package/packages/sdk/dist/transports/index.js +0 -129
- package/packages/sdk/dist/transports/index.js.map +0 -1
- package/packages/sdk/dist/transports/socket-transport.d.ts +0 -30
- package/packages/sdk/dist/transports/socket-transport.d.ts.map +0 -1
- package/packages/sdk/dist/transports/socket-transport.js +0 -94
- package/packages/sdk/dist/transports/socket-transport.js.map +0 -1
- package/packages/sdk/dist/transports/types.d.ts +0 -69
- package/packages/sdk/dist/transports/types.d.ts.map +0 -1
- package/packages/sdk/dist/transports/types.js +0 -10
- package/packages/sdk/dist/transports/types.js.map +0 -1
- package/packages/sdk/dist/transports/websocket-transport.d.ts +0 -55
- package/packages/sdk/dist/transports/websocket-transport.d.ts.map +0 -1
- package/packages/sdk/dist/transports/websocket-transport.js +0 -180
- package/packages/sdk/dist/transports/websocket-transport.js.map +0 -1
- package/packages/sdk/src/browser-client.ts +0 -985
- package/packages/sdk/src/browser-framing.test.ts +0 -115
- package/packages/sdk/src/browser-framing.ts +0 -150
- package/packages/sdk/src/standalone.ts +0 -183
- package/packages/sdk/src/transports/index.ts +0 -197
- package/packages/sdk/src/transports/socket-transport.ts +0 -115
- package/packages/sdk/src/transports/types.ts +0 -77
- package/packages/sdk/src/transports/websocket-transport.ts +0 -245
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Barrier Manager — synchronization barriers with all/any/majority semantics.
|
|
3
|
+
*
|
|
4
|
+
* Barriers gate downstream workflow steps until a set of upstream agents
|
|
5
|
+
* or steps have resolved. Supports three resolution modes:
|
|
6
|
+
*
|
|
7
|
+
* - **all** — every agent in `waitFor` must resolve (default)
|
|
8
|
+
* - **any** — at least one agent resolves
|
|
9
|
+
* - **majority** — more than half of `waitFor` must resolve
|
|
10
|
+
*/
|
|
11
|
+
import { randomBytes } from 'node:crypto';
|
|
12
|
+
import { EventEmitter } from 'node:events';
|
|
13
|
+
// ── Manager ─────────────────────────────────────────────────────────────────
|
|
14
|
+
export class BarrierManager extends EventEmitter {
|
|
15
|
+
db;
|
|
16
|
+
/** In-memory mode tracking (not persisted — set once at creation). */
|
|
17
|
+
modes = new Map();
|
|
18
|
+
timeoutTimers = new Map();
|
|
19
|
+
constructor(db) {
|
|
20
|
+
super();
|
|
21
|
+
this.db = db;
|
|
22
|
+
}
|
|
23
|
+
// ── Create ──────────────────────────────────────────────────────────────
|
|
24
|
+
/**
|
|
25
|
+
* Create a barrier for a workflow run.
|
|
26
|
+
*/
|
|
27
|
+
async createBarrier(runId, definition) {
|
|
28
|
+
const id = `bar_${Date.now()}_${randomBytes(4).toString('hex')}`;
|
|
29
|
+
const now = new Date().toISOString();
|
|
30
|
+
const mode = definition.mode ?? 'all';
|
|
31
|
+
const { rows } = await this.db.query(`INSERT INTO workflow_barriers (id, run_id, barrier_name, wait_for, resolved, is_satisfied, timeout_ms, created_at, updated_at)
|
|
32
|
+
VALUES ($1, $2, $3, $4, '[]'::jsonb, FALSE, $5, $6, $6)
|
|
33
|
+
RETURNING *`, [
|
|
34
|
+
id,
|
|
35
|
+
runId,
|
|
36
|
+
definition.name,
|
|
37
|
+
JSON.stringify(definition.waitFor),
|
|
38
|
+
definition.timeoutMs ?? null,
|
|
39
|
+
now,
|
|
40
|
+
]);
|
|
41
|
+
const barrier = rows[0];
|
|
42
|
+
const key = `${runId}:${definition.name}`;
|
|
43
|
+
this.modes.set(key, mode);
|
|
44
|
+
if (definition.timeoutMs) {
|
|
45
|
+
this.scheduleTimeout(barrier, definition.timeoutMs);
|
|
46
|
+
}
|
|
47
|
+
this.emit('barrier:created', barrier);
|
|
48
|
+
return barrier;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Bulk-create barriers from a list of definitions (e.g. from coordination config).
|
|
52
|
+
*/
|
|
53
|
+
async createBarriers(runId, definitions) {
|
|
54
|
+
const results = [];
|
|
55
|
+
for (const def of definitions) {
|
|
56
|
+
results.push(await this.createBarrier(runId, def));
|
|
57
|
+
}
|
|
58
|
+
return results;
|
|
59
|
+
}
|
|
60
|
+
// ── Resolve ─────────────────────────────────────────────────────────────
|
|
61
|
+
/**
|
|
62
|
+
* Mark an agent/step as resolved for a barrier. Returns whether the
|
|
63
|
+
* barrier is now fully satisfied.
|
|
64
|
+
*/
|
|
65
|
+
async resolve(runId, barrierName, agent) {
|
|
66
|
+
const now = new Date().toISOString();
|
|
67
|
+
// Atomic: append agent to resolved array if not already present.
|
|
68
|
+
const { rows } = await this.db.query(`UPDATE workflow_barriers
|
|
69
|
+
SET resolved = CASE
|
|
70
|
+
WHEN resolved @> $3::jsonb THEN resolved
|
|
71
|
+
ELSE resolved || $3::jsonb
|
|
72
|
+
END,
|
|
73
|
+
updated_at = $4
|
|
74
|
+
WHERE run_id = $1 AND barrier_name = $2 AND is_satisfied = FALSE
|
|
75
|
+
RETURNING *`, [runId, barrierName, JSON.stringify(agent), now]);
|
|
76
|
+
if (rows.length === 0) {
|
|
77
|
+
// Barrier may already be satisfied or not exist.
|
|
78
|
+
const existing = await this.getBarrier(runId, barrierName);
|
|
79
|
+
if (!existing)
|
|
80
|
+
throw new Error(`Barrier ${barrierName} not found for run ${runId}`);
|
|
81
|
+
return { satisfied: existing.isSatisfied, barrier: existing };
|
|
82
|
+
}
|
|
83
|
+
const barrier = rows[0];
|
|
84
|
+
this.emit('barrier:resolved', barrierName, agent);
|
|
85
|
+
const key = `${runId}:${barrierName}`;
|
|
86
|
+
const mode = this.modes.get(key) ?? 'all';
|
|
87
|
+
if (this.checkSatisfied(barrier, mode)) {
|
|
88
|
+
return this.markSatisfied(barrier);
|
|
89
|
+
}
|
|
90
|
+
return { satisfied: false, barrier };
|
|
91
|
+
}
|
|
92
|
+
// ── Queries ─────────────────────────────────────────────────────────────
|
|
93
|
+
async getBarrier(runId, barrierName) {
|
|
94
|
+
const { rows } = await this.db.query(`SELECT * FROM workflow_barriers WHERE run_id = $1 AND barrier_name = $2`, [runId, barrierName]);
|
|
95
|
+
return rows[0] ?? null;
|
|
96
|
+
}
|
|
97
|
+
async getBarriers(runId) {
|
|
98
|
+
const { rows } = await this.db.query(`SELECT * FROM workflow_barriers WHERE run_id = $1 ORDER BY created_at ASC`, [runId]);
|
|
99
|
+
return rows;
|
|
100
|
+
}
|
|
101
|
+
async getUnsatisfiedBarriers(runId) {
|
|
102
|
+
const { rows } = await this.db.query(`SELECT * FROM workflow_barriers WHERE run_id = $1 AND is_satisfied = FALSE ORDER BY created_at ASC`, [runId]);
|
|
103
|
+
return rows;
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Check if a named barrier is satisfied (useful for gating downstream work).
|
|
107
|
+
*/
|
|
108
|
+
async isSatisfied(runId, barrierName) {
|
|
109
|
+
const barrier = await this.getBarrier(runId, barrierName);
|
|
110
|
+
return barrier?.isSatisfied ?? false;
|
|
111
|
+
}
|
|
112
|
+
// ── Cleanup ─────────────────────────────────────────────────────────────
|
|
113
|
+
cleanup() {
|
|
114
|
+
for (const timer of this.timeoutTimers.values())
|
|
115
|
+
clearTimeout(timer);
|
|
116
|
+
this.timeoutTimers.clear();
|
|
117
|
+
this.modes.clear();
|
|
118
|
+
}
|
|
119
|
+
// ── Private ─────────────────────────────────────────────────────────────
|
|
120
|
+
checkSatisfied(barrier, mode) {
|
|
121
|
+
const waitFor = Array.isArray(barrier.waitFor) ? barrier.waitFor : [];
|
|
122
|
+
const resolved = Array.isArray(barrier.resolved) ? barrier.resolved : [];
|
|
123
|
+
switch (mode) {
|
|
124
|
+
case 'all':
|
|
125
|
+
return waitFor.every((w) => resolved.includes(w));
|
|
126
|
+
case 'any':
|
|
127
|
+
return resolved.length > 0;
|
|
128
|
+
case 'majority':
|
|
129
|
+
return resolved.length > waitFor.length / 2;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
async markSatisfied(barrier) {
|
|
133
|
+
const now = new Date().toISOString();
|
|
134
|
+
const { rows } = await this.db.query(`UPDATE workflow_barriers SET is_satisfied = TRUE, updated_at = $2
|
|
135
|
+
WHERE id = $1
|
|
136
|
+
RETURNING *`, [barrier.id, now]);
|
|
137
|
+
const updated = rows[0];
|
|
138
|
+
const key = `${barrier.runId}:${barrier.barrierName}`;
|
|
139
|
+
this.clearTimeout(key);
|
|
140
|
+
this.emit('barrier:satisfied', updated);
|
|
141
|
+
return { satisfied: true, barrier: updated };
|
|
142
|
+
}
|
|
143
|
+
scheduleTimeout(barrier, timeoutMs) {
|
|
144
|
+
const key = `${barrier.runId}:${barrier.barrierName}`;
|
|
145
|
+
const timer = setTimeout(async () => {
|
|
146
|
+
const current = await this.getBarrier(barrier.runId, barrier.barrierName);
|
|
147
|
+
if (current && !current.isSatisfied) {
|
|
148
|
+
this.emit('barrier:timeout', current);
|
|
149
|
+
}
|
|
150
|
+
}, timeoutMs);
|
|
151
|
+
timer.unref();
|
|
152
|
+
this.timeoutTimers.set(key, timer);
|
|
153
|
+
}
|
|
154
|
+
clearTimeout(key) {
|
|
155
|
+
const timer = this.timeoutTimers.get(key);
|
|
156
|
+
if (timer) {
|
|
157
|
+
globalThis.clearTimeout(timer);
|
|
158
|
+
this.timeoutTimers.delete(key);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
//# sourceMappingURL=barrier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"barrier.js","sourceRoot":"","sources":["../../src/workflows/barrier.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
import type { AgentRelayOptions } from '../relay.js';
|
|
2
|
+
import type { AgentCli, RelayYamlConfig, SwarmPattern, VerificationCheck, WorkflowRunRow } from './types.js';
|
|
3
|
+
import { type WorkflowEventListener, type VariableContext } from './runner.js';
|
|
4
|
+
export interface AgentOptions {
|
|
5
|
+
cli: AgentCli;
|
|
6
|
+
role?: string;
|
|
7
|
+
task?: string;
|
|
8
|
+
channels?: string[];
|
|
9
|
+
model?: string;
|
|
10
|
+
maxTokens?: number;
|
|
11
|
+
timeoutMs?: number;
|
|
12
|
+
retries?: number;
|
|
13
|
+
}
|
|
14
|
+
export interface StepOptions {
|
|
15
|
+
agent: string;
|
|
16
|
+
task: string;
|
|
17
|
+
dependsOn?: string[];
|
|
18
|
+
verification?: VerificationCheck;
|
|
19
|
+
timeoutMs?: number;
|
|
20
|
+
retries?: number;
|
|
21
|
+
}
|
|
22
|
+
export interface ErrorOptions {
|
|
23
|
+
maxRetries?: number;
|
|
24
|
+
retryDelayMs?: number;
|
|
25
|
+
notifyChannel?: string;
|
|
26
|
+
}
|
|
27
|
+
export interface WorkflowRunOptions {
|
|
28
|
+
/** Run a specific workflow by name (default: first). */
|
|
29
|
+
workflow?: string;
|
|
30
|
+
/** Template variable substitutions. */
|
|
31
|
+
vars?: VariableContext;
|
|
32
|
+
/** Working directory (default: process.cwd()). */
|
|
33
|
+
cwd?: string;
|
|
34
|
+
/** AgentRelay options (all optional). */
|
|
35
|
+
relay?: AgentRelayOptions;
|
|
36
|
+
/** Progress callback. */
|
|
37
|
+
onEvent?: WorkflowEventListener;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Fluent builder for constructing workflow configurations programmatically.
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* ```typescript
|
|
44
|
+
* import { workflow } from "@agent-relay/broker-sdk/workflows";
|
|
45
|
+
*
|
|
46
|
+
* const result = await workflow("my-workflow")
|
|
47
|
+
* .pattern("dag")
|
|
48
|
+
* .agent("worker", { cli: "claude", role: "Backend engineer" })
|
|
49
|
+
* .step("build", { agent: "worker", task: "Build the project" })
|
|
50
|
+
* .step("test", { agent: "worker", task: "Run tests", dependsOn: ["build"] })
|
|
51
|
+
* .run();
|
|
52
|
+
* ```
|
|
53
|
+
*/
|
|
54
|
+
export declare class WorkflowBuilder {
|
|
55
|
+
private _name;
|
|
56
|
+
private _description?;
|
|
57
|
+
private _pattern;
|
|
58
|
+
private _maxConcurrency?;
|
|
59
|
+
private _timeoutMs?;
|
|
60
|
+
private _channel?;
|
|
61
|
+
private _agents;
|
|
62
|
+
private _steps;
|
|
63
|
+
private _errorHandling?;
|
|
64
|
+
constructor(name: string);
|
|
65
|
+
/** Set workflow description. */
|
|
66
|
+
description(desc: string): this;
|
|
67
|
+
/** Set swarm pattern (default: "dag"). */
|
|
68
|
+
pattern(p: SwarmPattern): this;
|
|
69
|
+
/** Set maximum concurrent agents. */
|
|
70
|
+
maxConcurrency(n: number): this;
|
|
71
|
+
/** Set global timeout in milliseconds. */
|
|
72
|
+
timeout(ms: number): this;
|
|
73
|
+
/** Set the relay channel for agent communication. */
|
|
74
|
+
channel(ch: string): this;
|
|
75
|
+
/** Add an agent definition. */
|
|
76
|
+
agent(name: string, options: AgentOptions): this;
|
|
77
|
+
/** Add a workflow step. */
|
|
78
|
+
step(name: string, options: StepOptions): this;
|
|
79
|
+
/** Set error handling strategy. */
|
|
80
|
+
onError(strategy: 'fail-fast' | 'continue' | 'retry', options?: ErrorOptions): this;
|
|
81
|
+
/** Build and return the RelayYamlConfig object. */
|
|
82
|
+
toConfig(): RelayYamlConfig;
|
|
83
|
+
/** Serialize the config to a YAML string. */
|
|
84
|
+
toYaml(): string;
|
|
85
|
+
/** Build the config and execute it with the WorkflowRunner. */
|
|
86
|
+
run(options?: WorkflowRunOptions): Promise<WorkflowRunRow>;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Create a new workflow builder.
|
|
90
|
+
*
|
|
91
|
+
* @example
|
|
92
|
+
* ```typescript
|
|
93
|
+
* const result = await workflow("my-task")
|
|
94
|
+
* .pattern("fan-out")
|
|
95
|
+
* .agent("worker", { cli: "claude" })
|
|
96
|
+
* .step("do-work", { agent: "worker", task: "Build the feature" })
|
|
97
|
+
* .run();
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
export declare function workflow(name: string): WorkflowBuilder;
|
|
101
|
+
//# sourceMappingURL=builder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.d.ts","sourceRoot":"","sources":["../../src/workflows/builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,179 @@
|
|
|
1
|
+
import { stringify as stringifyYaml } from 'yaml';
|
|
2
|
+
import { WorkflowRunner } from './runner.js';
|
|
3
|
+
// ── WorkflowBuilder ─────────────────────────────────────────────────────────
|
|
4
|
+
/**
|
|
5
|
+
* Fluent builder for constructing workflow configurations programmatically.
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```typescript
|
|
9
|
+
* import { workflow } from "@agent-relay/broker-sdk/workflows";
|
|
10
|
+
*
|
|
11
|
+
* const result = await workflow("my-workflow")
|
|
12
|
+
* .pattern("dag")
|
|
13
|
+
* .agent("worker", { cli: "claude", role: "Backend engineer" })
|
|
14
|
+
* .step("build", { agent: "worker", task: "Build the project" })
|
|
15
|
+
* .step("test", { agent: "worker", task: "Run tests", dependsOn: ["build"] })
|
|
16
|
+
* .run();
|
|
17
|
+
* ```
|
|
18
|
+
*/
|
|
19
|
+
export class WorkflowBuilder {
|
|
20
|
+
_name;
|
|
21
|
+
_description;
|
|
22
|
+
_pattern = 'dag';
|
|
23
|
+
_maxConcurrency;
|
|
24
|
+
_timeoutMs;
|
|
25
|
+
_channel;
|
|
26
|
+
_agents = [];
|
|
27
|
+
_steps = [];
|
|
28
|
+
_errorHandling;
|
|
29
|
+
constructor(name) {
|
|
30
|
+
this._name = name;
|
|
31
|
+
}
|
|
32
|
+
/** Set workflow description. */
|
|
33
|
+
description(desc) {
|
|
34
|
+
this._description = desc;
|
|
35
|
+
return this;
|
|
36
|
+
}
|
|
37
|
+
/** Set swarm pattern (default: "dag"). */
|
|
38
|
+
pattern(p) {
|
|
39
|
+
this._pattern = p;
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
/** Set maximum concurrent agents. */
|
|
43
|
+
maxConcurrency(n) {
|
|
44
|
+
this._maxConcurrency = n;
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
/** Set global timeout in milliseconds. */
|
|
48
|
+
timeout(ms) {
|
|
49
|
+
this._timeoutMs = ms;
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
/** Set the relay channel for agent communication. */
|
|
53
|
+
channel(ch) {
|
|
54
|
+
this._channel = ch;
|
|
55
|
+
return this;
|
|
56
|
+
}
|
|
57
|
+
/** Add an agent definition. */
|
|
58
|
+
agent(name, options) {
|
|
59
|
+
const def = {
|
|
60
|
+
name,
|
|
61
|
+
cli: options.cli,
|
|
62
|
+
};
|
|
63
|
+
if (options.role !== undefined)
|
|
64
|
+
def.role = options.role;
|
|
65
|
+
if (options.task !== undefined)
|
|
66
|
+
def.task = options.task;
|
|
67
|
+
if (options.channels !== undefined)
|
|
68
|
+
def.channels = options.channels;
|
|
69
|
+
if (options.model !== undefined || options.maxTokens !== undefined ||
|
|
70
|
+
options.timeoutMs !== undefined || options.retries !== undefined) {
|
|
71
|
+
def.constraints = {};
|
|
72
|
+
if (options.model !== undefined)
|
|
73
|
+
def.constraints.model = options.model;
|
|
74
|
+
if (options.maxTokens !== undefined)
|
|
75
|
+
def.constraints.maxTokens = options.maxTokens;
|
|
76
|
+
if (options.timeoutMs !== undefined)
|
|
77
|
+
def.constraints.timeoutMs = options.timeoutMs;
|
|
78
|
+
if (options.retries !== undefined)
|
|
79
|
+
def.constraints.retries = options.retries;
|
|
80
|
+
}
|
|
81
|
+
this._agents.push(def);
|
|
82
|
+
return this;
|
|
83
|
+
}
|
|
84
|
+
/** Add a workflow step. */
|
|
85
|
+
step(name, options) {
|
|
86
|
+
const step = {
|
|
87
|
+
name,
|
|
88
|
+
agent: options.agent,
|
|
89
|
+
task: options.task,
|
|
90
|
+
};
|
|
91
|
+
if (options.dependsOn !== undefined)
|
|
92
|
+
step.dependsOn = options.dependsOn;
|
|
93
|
+
if (options.verification !== undefined)
|
|
94
|
+
step.verification = options.verification;
|
|
95
|
+
if (options.timeoutMs !== undefined)
|
|
96
|
+
step.timeoutMs = options.timeoutMs;
|
|
97
|
+
if (options.retries !== undefined)
|
|
98
|
+
step.retries = options.retries;
|
|
99
|
+
this._steps.push(step);
|
|
100
|
+
return this;
|
|
101
|
+
}
|
|
102
|
+
/** Set error handling strategy. */
|
|
103
|
+
onError(strategy, options) {
|
|
104
|
+
this._errorHandling = { strategy };
|
|
105
|
+
if (options?.maxRetries !== undefined)
|
|
106
|
+
this._errorHandling.maxRetries = options.maxRetries;
|
|
107
|
+
if (options?.retryDelayMs !== undefined)
|
|
108
|
+
this._errorHandling.retryDelayMs = options.retryDelayMs;
|
|
109
|
+
if (options?.notifyChannel !== undefined)
|
|
110
|
+
this._errorHandling.notifyChannel = options.notifyChannel;
|
|
111
|
+
return this;
|
|
112
|
+
}
|
|
113
|
+
/** Build and return the RelayYamlConfig object. */
|
|
114
|
+
toConfig() {
|
|
115
|
+
if (this._agents.length === 0) {
|
|
116
|
+
throw new Error('Workflow must have at least one agent');
|
|
117
|
+
}
|
|
118
|
+
if (this._steps.length === 0) {
|
|
119
|
+
throw new Error('Workflow must have at least one step');
|
|
120
|
+
}
|
|
121
|
+
const wfDef = {
|
|
122
|
+
name: `${this._name}-workflow`,
|
|
123
|
+
steps: [...this._steps],
|
|
124
|
+
};
|
|
125
|
+
const config = {
|
|
126
|
+
version: '1.0',
|
|
127
|
+
name: this._name,
|
|
128
|
+
swarm: {
|
|
129
|
+
pattern: this._pattern,
|
|
130
|
+
},
|
|
131
|
+
agents: [...this._agents],
|
|
132
|
+
workflows: [wfDef],
|
|
133
|
+
};
|
|
134
|
+
if (this._description !== undefined)
|
|
135
|
+
config.description = this._description;
|
|
136
|
+
if (this._maxConcurrency !== undefined)
|
|
137
|
+
config.swarm.maxConcurrency = this._maxConcurrency;
|
|
138
|
+
if (this._timeoutMs !== undefined)
|
|
139
|
+
config.swarm.timeoutMs = this._timeoutMs;
|
|
140
|
+
if (this._channel !== undefined)
|
|
141
|
+
config.swarm.channel = this._channel;
|
|
142
|
+
if (this._errorHandling !== undefined)
|
|
143
|
+
config.errorHandling = this._errorHandling;
|
|
144
|
+
return config;
|
|
145
|
+
}
|
|
146
|
+
/** Serialize the config to a YAML string. */
|
|
147
|
+
toYaml() {
|
|
148
|
+
return stringifyYaml(this.toConfig());
|
|
149
|
+
}
|
|
150
|
+
/** Build the config and execute it with the WorkflowRunner. */
|
|
151
|
+
async run(options = {}) {
|
|
152
|
+
const config = this.toConfig();
|
|
153
|
+
const runner = new WorkflowRunner({
|
|
154
|
+
cwd: options.cwd,
|
|
155
|
+
relay: options.relay,
|
|
156
|
+
});
|
|
157
|
+
if (options.onEvent) {
|
|
158
|
+
runner.on(options.onEvent);
|
|
159
|
+
}
|
|
160
|
+
return runner.execute(config, options.workflow, options.vars);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
// ── Entry point ─────────────────────────────────────────────────────────────
|
|
164
|
+
/**
|
|
165
|
+
* Create a new workflow builder.
|
|
166
|
+
*
|
|
167
|
+
* @example
|
|
168
|
+
* ```typescript
|
|
169
|
+
* const result = await workflow("my-task")
|
|
170
|
+
* .pattern("fan-out")
|
|
171
|
+
* .agent("worker", { cli: "claude" })
|
|
172
|
+
* .step("do-work", { agent: "worker", task: "Build the feature" })
|
|
173
|
+
* .run();
|
|
174
|
+
* ```
|
|
175
|
+
*/
|
|
176
|
+
export function workflow(name) {
|
|
177
|
+
return new WorkflowBuilder(name);
|
|
178
|
+
}
|
|
179
|
+
//# sourceMappingURL=builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"builder.js","sourceRoot":"","sources":["../../src/workflows/builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* CLI entry point for running relay.yaml workflows.
|
|
4
|
+
*
|
|
5
|
+
* Usage:
|
|
6
|
+
* relay-workflow <yaml-path> [--workflow <name>]
|
|
7
|
+
* npx @agent-relay/broker-sdk run <yaml-path> [--workflow <name>]
|
|
8
|
+
*/
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=cli.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../src/workflows/cli.ts"],"names":[],"mappings":";AAEA;;;;;;GAMG"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* CLI entry point for running relay.yaml workflows.
|
|
4
|
+
*
|
|
5
|
+
* Usage:
|
|
6
|
+
* relay-workflow <yaml-path> [--workflow <name>]
|
|
7
|
+
* npx @agent-relay/broker-sdk run <yaml-path> [--workflow <name>]
|
|
8
|
+
*/
|
|
9
|
+
import { runWorkflow } from './run.js';
|
|
10
|
+
function printUsage() {
|
|
11
|
+
console.log(`
|
|
12
|
+
Usage: relay-workflow <yaml-path> [options]
|
|
13
|
+
|
|
14
|
+
Run a relay.yaml workflow file.
|
|
15
|
+
|
|
16
|
+
Arguments:
|
|
17
|
+
<yaml-path> Path to the relay.yaml workflow file
|
|
18
|
+
|
|
19
|
+
Options:
|
|
20
|
+
--workflow <name> Run a specific workflow by name (default: first)
|
|
21
|
+
--help Show this help message
|
|
22
|
+
|
|
23
|
+
Examples:
|
|
24
|
+
relay-workflow workflows/daytona-migration.yaml
|
|
25
|
+
relay-workflow workflows/feature-dev.yaml --workflow build-and-test
|
|
26
|
+
`.trim());
|
|
27
|
+
}
|
|
28
|
+
function formatEvent(event) {
|
|
29
|
+
switch (event.type) {
|
|
30
|
+
case 'run:started':
|
|
31
|
+
return `[run] started (${event.runId})`;
|
|
32
|
+
case 'run:completed':
|
|
33
|
+
return `[run] completed`;
|
|
34
|
+
case 'run:failed':
|
|
35
|
+
return `[run] failed: ${event.error}`;
|
|
36
|
+
case 'run:cancelled':
|
|
37
|
+
return `[run] cancelled`;
|
|
38
|
+
case 'step:started':
|
|
39
|
+
return `[step] ${event.stepName} started`;
|
|
40
|
+
case 'step:completed':
|
|
41
|
+
return `[step] ${event.stepName} completed`;
|
|
42
|
+
case 'step:failed':
|
|
43
|
+
return `[step] ${event.stepName} failed: ${event.error}`;
|
|
44
|
+
case 'step:skipped':
|
|
45
|
+
return `[step] ${event.stepName} skipped`;
|
|
46
|
+
case 'step:retrying':
|
|
47
|
+
return `[step] ${event.stepName} retrying (attempt ${event.attempt})`;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async function main() {
|
|
51
|
+
const args = process.argv.slice(2);
|
|
52
|
+
if (args.length === 0 || args.includes('--help')) {
|
|
53
|
+
printUsage();
|
|
54
|
+
process.exit(args.includes('--help') ? 0 : 1);
|
|
55
|
+
}
|
|
56
|
+
const yamlPath = args[0];
|
|
57
|
+
let workflowName;
|
|
58
|
+
const workflowIdx = args.indexOf('--workflow');
|
|
59
|
+
if (workflowIdx !== -1 && args[workflowIdx + 1]) {
|
|
60
|
+
workflowName = args[workflowIdx + 1];
|
|
61
|
+
}
|
|
62
|
+
console.log(`Running workflow from ${yamlPath}...`);
|
|
63
|
+
const result = await runWorkflow(yamlPath, {
|
|
64
|
+
workflow: workflowName,
|
|
65
|
+
onEvent(event) {
|
|
66
|
+
console.log(formatEvent(event));
|
|
67
|
+
},
|
|
68
|
+
});
|
|
69
|
+
if (result.status === 'completed') {
|
|
70
|
+
console.log(`\nWorkflow completed successfully.`);
|
|
71
|
+
process.exit(0);
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
console.error(`\nWorkflow ${result.status}${result.error ? `: ${result.error}` : ''}`);
|
|
75
|
+
process.exit(1);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
main().catch((err) => {
|
|
79
|
+
console.error(`Error: ${err.message}`);
|
|
80
|
+
process.exit(1);
|
|
81
|
+
});
|
|
82
|
+
//# sourceMappingURL=cli.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../src/workflows/cli.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Swarm Coordinator — pattern selection, agent topology, and workflow lifecycle.
|
|
3
|
+
*
|
|
4
|
+
* Orchestrates workflow runs: picks the right swarm pattern (or auto-selects),
|
|
5
|
+
* resolves agent topology from the config, and drives the run through its
|
|
6
|
+
* lifecycle states (pending → running → completed / failed / cancelled).
|
|
7
|
+
*/
|
|
8
|
+
import { EventEmitter } from 'node:events';
|
|
9
|
+
import type { AgentDefinition, RelayYamlConfig, SwarmPattern, WorkflowRunRow, WorkflowRunStatus, WorkflowStepRow } from './types.js';
|
|
10
|
+
/** Minimal database client contract accepted by all services. */
|
|
11
|
+
export interface DbClient {
|
|
12
|
+
query<T = Record<string, unknown>>(sql: string, params?: unknown[]): Promise<{
|
|
13
|
+
rows: T[];
|
|
14
|
+
}>;
|
|
15
|
+
}
|
|
16
|
+
/** Describes the communication graph for a set of agents. */
|
|
17
|
+
export interface AgentTopology {
|
|
18
|
+
pattern: SwarmPattern;
|
|
19
|
+
agents: AgentDefinition[];
|
|
20
|
+
/** Agent name → names it can send messages to. */
|
|
21
|
+
edges: Map<string, string[]>;
|
|
22
|
+
/** Optional hub agent for hub-spoke / hierarchical. */
|
|
23
|
+
hub?: string;
|
|
24
|
+
/** Ordered pipeline stages (pipeline pattern only). */
|
|
25
|
+
pipelineOrder?: string[];
|
|
26
|
+
}
|
|
27
|
+
export interface SwarmCoordinatorEvents {
|
|
28
|
+
'run:created': (run: WorkflowRunRow) => void;
|
|
29
|
+
'run:started': (run: WorkflowRunRow) => void;
|
|
30
|
+
'run:completed': (run: WorkflowRunRow) => void;
|
|
31
|
+
'run:failed': (run: WorkflowRunRow) => void;
|
|
32
|
+
'run:cancelled': (run: WorkflowRunRow) => void;
|
|
33
|
+
'step:started': (step: WorkflowStepRow) => void;
|
|
34
|
+
'step:completed': (step: WorkflowStepRow) => void;
|
|
35
|
+
'step:failed': (step: WorkflowStepRow) => void;
|
|
36
|
+
}
|
|
37
|
+
export declare class SwarmCoordinator extends EventEmitter {
|
|
38
|
+
private db;
|
|
39
|
+
constructor(db: DbClient);
|
|
40
|
+
/**
|
|
41
|
+
* Select the swarm pattern to use for a config. If the config already
|
|
42
|
+
* specifies a pattern, it is returned as-is. Otherwise heuristics apply.
|
|
43
|
+
*/
|
|
44
|
+
selectPattern(config: RelayYamlConfig): SwarmPattern;
|
|
45
|
+
/**
|
|
46
|
+
* Build the agent communication topology for a given config and pattern.
|
|
47
|
+
*/
|
|
48
|
+
resolveTopology(config: RelayYamlConfig, pattern?: SwarmPattern): AgentTopology;
|
|
49
|
+
createRun(workspaceId: string, config: RelayYamlConfig): Promise<WorkflowRunRow>;
|
|
50
|
+
startRun(runId: string): Promise<WorkflowRunRow>;
|
|
51
|
+
completeRun(runId: string, stateSnapshot?: Record<string, unknown>): Promise<WorkflowRunRow>;
|
|
52
|
+
failRun(runId: string, error: string): Promise<WorkflowRunRow>;
|
|
53
|
+
cancelRun(runId: string): Promise<WorkflowRunRow>;
|
|
54
|
+
createSteps(runId: string, config: RelayYamlConfig): Promise<WorkflowStepRow[]>;
|
|
55
|
+
startStep(stepId: string): Promise<WorkflowStepRow>;
|
|
56
|
+
completeStep(stepId: string, output?: string): Promise<WorkflowStepRow>;
|
|
57
|
+
failStep(stepId: string, error: string): Promise<WorkflowStepRow>;
|
|
58
|
+
skipStep(stepId: string): Promise<WorkflowStepRow>;
|
|
59
|
+
getRun(runId: string): Promise<WorkflowRunRow | null>;
|
|
60
|
+
getSteps(runId: string): Promise<WorkflowStepRow[]>;
|
|
61
|
+
getReadySteps(runId: string): Promise<WorkflowStepRow[]>;
|
|
62
|
+
getRunsByWorkspace(workspaceId: string, status?: WorkflowRunStatus): Promise<WorkflowRunRow[]>;
|
|
63
|
+
private transitionRun;
|
|
64
|
+
private pickHub;
|
|
65
|
+
private resolvePipelineOrder;
|
|
66
|
+
private resolveDAGEdges;
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=coordinator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"coordinator.d.ts","sourceRoot":"","sources":["../../src/workflows/coordinator.ts"],"names":[],"mappings":"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"}
|