acpx 0.5.3 → 0.6.1
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 +12 -4
- package/dist/{cli-ChWsO-bb.js → cli-Ddxpnz9X.js} +4 -4
- package/dist/{cli-ChWsO-bb.js.map → cli-Ddxpnz9X.js.map} +1 -1
- package/dist/cli.d.ts +1 -1
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +147 -75
- package/dist/cli.js.map +1 -1
- package/dist/{client-D-4_aZf2.d.ts → client-2fTFutRH.d.ts} +4 -2
- package/dist/client-2fTFutRH.d.ts.map +1 -0
- package/dist/{flags-ceSqz2T6.js → flags-yXzUm7Aq.js} +25 -6
- package/dist/flags-yXzUm7Aq.js.map +1 -0
- package/dist/{flows-_KmnuUXd.js → flows-CDsfbaA2.js} +13 -6
- package/dist/flows-CDsfbaA2.js.map +1 -0
- package/dist/flows.d.ts +2 -8
- package/dist/flows.d.ts.map +1 -1
- package/dist/flows.js +1 -1
- package/dist/{ipc-BM335WFg.js → ipc-BruTG5Fb.js} +50 -19
- package/dist/ipc-BruTG5Fb.js.map +1 -0
- package/dist/{output-C4QhjpM6.js → output-DmHvT8vm.js} +141 -12
- package/dist/output-DmHvT8vm.js.map +1 -0
- package/dist/{perf-metrics-D0um6IR6.js → perf-metrics-C2pXfxvR.js} +12 -2
- package/dist/perf-metrics-C2pXfxvR.js.map +1 -0
- package/dist/{prompt-turn-CXMtXBl-.js → prompt-turn-BY5SwU1F.js} +256 -80
- package/dist/prompt-turn-BY5SwU1F.js.map +1 -0
- package/dist/{render-Br-kVPK_.js → render-yqwtaOX4.js} +35 -3
- package/dist/{render-Br-kVPK_.js.map → render-yqwtaOX4.js.map} +1 -1
- package/dist/runtime.d.ts +84 -10
- package/dist/runtime.d.ts.map +1 -1
- package/dist/runtime.js +425 -190
- package/dist/runtime.js.map +1 -1
- package/dist/{session-BtwAKtJ3.js → session-BwgaPK8-.js} +119 -81
- package/dist/session-BwgaPK8-.js.map +1 -0
- package/dist/session-options-pCbHn_n7.d.ts +13 -0
- package/dist/session-options-pCbHn_n7.d.ts.map +1 -0
- package/dist/{types-yxf-gcOE.d.ts → types-CVBeQyi3.d.ts} +9 -1
- package/dist/types-CVBeQyi3.d.ts.map +1 -0
- package/package.json +21 -21
- package/skills/acpx/SKILL.md +9 -4
- package/dist/client-D-4_aZf2.d.ts.map +0 -1
- package/dist/flags-ceSqz2T6.js.map +0 -1
- package/dist/flows-_KmnuUXd.js.map +0 -1
- package/dist/ipc-BM335WFg.js.map +0 -1
- package/dist/output-C4QhjpM6.js.map +0 -1
- package/dist/perf-metrics-D0um6IR6.js.map +0 -1
- package/dist/prompt-turn-CXMtXBl-.js.map +0 -1
- package/dist/session-BtwAKtJ3.js.map +0 -1
- package/dist/types-yxf-gcOE.d.ts.map +0 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { a as PermissionMode, c as PromptInput, i as NonInteractivePermissionPolicy, o as PermissionStats, t as AcpClientOptions } from "./types-
|
|
1
|
+
import { a as PermissionMode, c as PromptInput, i as NonInteractivePermissionPolicy, o as PermissionStats, t as AcpClientOptions } from "./types-CVBeQyi3.js";
|
|
2
2
|
import { InitializeResponse, PromptResponse, SessionModelState, SetSessionConfigOptionResponse } from "@agentclientprotocol/sdk";
|
|
3
3
|
|
|
4
4
|
//#region src/acp/client.d.ts
|
|
@@ -65,6 +65,7 @@ declare class AcpClient {
|
|
|
65
65
|
updateRuntimeOptions(options: {
|
|
66
66
|
permissionMode?: PermissionMode;
|
|
67
67
|
nonInteractivePermissions?: NonInteractivePermissionPolicy;
|
|
68
|
+
terminal?: boolean;
|
|
68
69
|
suppressSdkConsoleErrors?: boolean;
|
|
69
70
|
verbose?: boolean;
|
|
70
71
|
}): void;
|
|
@@ -91,6 +92,7 @@ declare class AcpClient {
|
|
|
91
92
|
private captureStartupStderr;
|
|
92
93
|
private summarizeStartupStderr;
|
|
93
94
|
private createStartupFailureWatcher;
|
|
95
|
+
private normalizeInitializeError;
|
|
94
96
|
private selectAuthMethod;
|
|
95
97
|
private authenticateIfRequired;
|
|
96
98
|
private handlePermissionRequest;
|
|
@@ -118,4 +120,4 @@ declare class AcpClient {
|
|
|
118
120
|
}
|
|
119
121
|
//#endregion
|
|
120
122
|
export { AcpClient as t };
|
|
121
|
-
//# sourceMappingURL=client-
|
|
123
|
+
//# sourceMappingURL=client-2fTFutRH.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-2fTFutRH.d.ts","names":[],"sources":["../src/acp/client.ts"],"mappings":"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"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import "./session-
|
|
1
|
+
import { A as OUTPUT_FORMATS, D as NON_INTERACTIVE_PERMISSION_POLICIES, T as AUTH_POLICIES } from "./perf-metrics-C2pXfxvR.js";
|
|
2
|
+
import { Q as resolveAgentCommand } from "./prompt-turn-BY5SwU1F.js";
|
|
3
|
+
import "./session-BwgaPK8-.js";
|
|
4
4
|
import path from "node:path";
|
|
5
5
|
import { InvalidArgumentError } from "commander";
|
|
6
6
|
//#region src/cli/flags.ts
|
|
@@ -44,6 +44,16 @@ function parseHistoryLimit(value) {
|
|
|
44
44
|
if (!Number.isInteger(parsed) || parsed <= 0) throw new InvalidArgumentError("Limit must be a positive integer");
|
|
45
45
|
return parsed;
|
|
46
46
|
}
|
|
47
|
+
function parseDaysOlderThan(value) {
|
|
48
|
+
const parsed = Number(value);
|
|
49
|
+
if (!Number.isInteger(parsed) || parsed <= 0) throw new InvalidArgumentError("--older-than must be a positive integer number of days");
|
|
50
|
+
return parsed;
|
|
51
|
+
}
|
|
52
|
+
function parsePruneBeforeDate(value) {
|
|
53
|
+
const date = new Date(value);
|
|
54
|
+
if (Number.isNaN(date.getTime())) throw new InvalidArgumentError(`--before must be a valid date (e.g. 2026-01-01 or 2026-01-01T00:00:00Z)`);
|
|
55
|
+
return date;
|
|
56
|
+
}
|
|
47
57
|
function parseAllowedTools(value) {
|
|
48
58
|
const trimmed = value.trim();
|
|
49
59
|
if (trimmed.length === 0) return [];
|
|
@@ -56,6 +66,13 @@ function parseMaxTurns(value) {
|
|
|
56
66
|
if (!Number.isInteger(parsed) || parsed <= 0) throw new InvalidArgumentError("Max turns must be a positive integer");
|
|
57
67
|
return parsed;
|
|
58
68
|
}
|
|
69
|
+
function resolveSystemPromptFlag(opts) {
|
|
70
|
+
const replace = typeof opts.systemPrompt === "string" && opts.systemPrompt.length > 0 ? opts.systemPrompt : void 0;
|
|
71
|
+
const append = typeof opts.appendSystemPrompt === "string" && opts.appendSystemPrompt.length > 0 ? opts.appendSystemPrompt : void 0;
|
|
72
|
+
if (replace !== void 0 && append !== void 0) throw new InvalidArgumentError("Use only one of --system-prompt or --append-system-prompt");
|
|
73
|
+
if (replace !== void 0) return replace;
|
|
74
|
+
if (append !== void 0) return { append };
|
|
75
|
+
}
|
|
59
76
|
function parsePromptRetries(value) {
|
|
60
77
|
const parsed = Number(value);
|
|
61
78
|
if (!Number.isInteger(parsed) || parsed < 0) throw new InvalidArgumentError("Prompt retries must be a non-negative integer");
|
|
@@ -73,7 +90,7 @@ function resolvePermissionMode(flags, defaultMode) {
|
|
|
73
90
|
return defaultMode;
|
|
74
91
|
}
|
|
75
92
|
function addGlobalFlags(command) {
|
|
76
|
-
return command.option("--agent <command>", "Raw ACP agent command (escape hatch)").option("--cwd <dir>", "Working directory", process.cwd()).option("--auth-policy <policy>", "Authentication policy: skip or fail when auth is required", parseAuthPolicy).option("--approve-all", "Auto-approve all permission requests").option("--approve-reads", "Auto-approve read/search requests and prompt for writes").option("--deny-all", "Deny all permission requests").option("--non-interactive-permissions <policy>", "When prompting is unavailable: deny or fail", parseNonInteractivePermissionPolicy).option("--format <fmt>", "Output format: text, json, quiet", parseOutputFormat).option("--suppress-reads", "Suppress raw read-file contents in output").option("--model <id>", "Agent model id").option("--allowed-tools <list>", "Allowed tool names as a comma-separated list (use \"\" for no tools)", parseAllowedTools).option("--max-turns <count>", "Maximum turns for the session", parseMaxTurns).option("--prompt-retries <count>", "Retry failed prompt turns on transient errors (default: 0)", parsePromptRetries).option("--json-strict", "Strict JSON mode: requires --format json and suppresses non-JSON stderr output").option("--timeout <seconds>", "Maximum time to wait for agent response", parseTimeoutSeconds).option("--ttl <seconds>", "Queue owner idle TTL before shutdown (0 = keep alive forever) (default: 300)", parseTtlSeconds).option("--verbose", "Enable verbose debug logs");
|
|
93
|
+
return command.option("--agent <command>", "Raw ACP agent command (escape hatch)").option("--cwd <dir>", "Working directory", process.cwd()).option("--auth-policy <policy>", "Authentication policy: skip or fail when auth is required", parseAuthPolicy).option("--approve-all", "Auto-approve all permission requests").option("--approve-reads", "Auto-approve read/search requests and prompt for writes").option("--deny-all", "Deny all permission requests").option("--non-interactive-permissions <policy>", "When prompting is unavailable: deny or fail", parseNonInteractivePermissionPolicy).option("--format <fmt>", "Output format: text, json, quiet", parseOutputFormat).option("--suppress-reads", "Suppress raw read-file contents in output").option("--model <id>", "Agent model id").option("--allowed-tools <list>", "Allowed tool names as a comma-separated list (use \"\" for no tools)", parseAllowedTools).option("--max-turns <count>", "Maximum turns for the session", parseMaxTurns).option("--system-prompt <text>", "Replace the agent system prompt (claude-agent-acp via ACP _meta.systemPrompt)", (value) => parseNonEmptyValue("System prompt", value)).option("--append-system-prompt <text>", "Append text to the agent system prompt (claude-agent-acp via ACP _meta.systemPrompt.append)", (value) => parseNonEmptyValue("Append system prompt", value)).option("--prompt-retries <count>", "Retry failed prompt turns on transient errors (default: 0)", parsePromptRetries).option("--json-strict", "Strict JSON mode: requires --format json and suppresses non-JSON stderr output").option("--no-terminal", "Do not advertise ACP terminal capability").option("--timeout <seconds>", "Maximum time to wait for agent response", parseTimeoutSeconds).option("--ttl <seconds>", "Queue owner idle TTL before shutdown (0 = keep alive forever) (default: 300)", parseTtlSeconds).option("--verbose", "Enable verbose debug logs");
|
|
77
94
|
}
|
|
78
95
|
function addSessionOption(command) {
|
|
79
96
|
return command.option("-s, --session <name>", "Use named session instead of cwd default", parseSessionName).option("--no-wait", "Queue prompt and return immediately when another prompt is already running");
|
|
@@ -105,6 +122,7 @@ function resolveGlobalFlags(command, config) {
|
|
|
105
122
|
nonInteractivePermissions: opts.nonInteractivePermissions ?? config.nonInteractivePermissions,
|
|
106
123
|
jsonStrict,
|
|
107
124
|
suppressReads: opts.suppressReads === true,
|
|
125
|
+
terminal: opts.terminal === false ? false : void 0,
|
|
108
126
|
timeout: opts.timeout ?? config.timeoutMs,
|
|
109
127
|
ttl: opts.ttl ?? config.ttlMs ?? 3e5,
|
|
110
128
|
verbose,
|
|
@@ -112,6 +130,7 @@ function resolveGlobalFlags(command, config) {
|
|
|
112
130
|
model: typeof opts.model === "string" ? parseNonEmptyValue("Model", opts.model) : void 0,
|
|
113
131
|
allowedTools: Array.isArray(opts.allowedTools) ? opts.allowedTools : void 0,
|
|
114
132
|
maxTurns: typeof opts.maxTurns === "number" ? opts.maxTurns : void 0,
|
|
133
|
+
systemPrompt: resolveSystemPromptFlag(opts),
|
|
115
134
|
promptRetries: typeof opts.promptRetries === "number" ? opts.promptRetries : void 0,
|
|
116
135
|
approveAll: opts.approveAll ? true : void 0,
|
|
117
136
|
approveReads: opts.approveReads ? true : void 0,
|
|
@@ -139,6 +158,6 @@ function resolveAgentInvocation(explicitAgentName, globalFlags, config) {
|
|
|
139
158
|
};
|
|
140
159
|
}
|
|
141
160
|
//#endregion
|
|
142
|
-
export { hasExplicitPermissionModeFlag as a,
|
|
161
|
+
export { resolvePermissionMode as _, hasExplicitPermissionModeFlag as a, parseHistoryLimit as c, parsePruneBeforeDate as d, parseSessionName as f, resolveOutputPolicy as g, resolveGlobalFlags as h, addSessionOption as i, parseMaxTurns as l, resolveAgentInvocation as m, addPromptInputOption as n, parseAllowedTools as o, parseTtlSeconds as p, addSessionNameOption as r, parseDaysOlderThan as s, addGlobalFlags as t, parseNonEmptyValue as u, resolveSessionNameFromFlags as v };
|
|
143
162
|
|
|
144
|
-
//# sourceMappingURL=flags-
|
|
163
|
+
//# sourceMappingURL=flags-yXzUm7Aq.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flags-yXzUm7Aq.js","names":["resolveAgentCommandFromRegistry"],"sources":["../src/cli/flags.ts"],"sourcesContent":["import path from \"node:path\";\nimport { InvalidArgumentError } from \"commander\";\nimport type { Command } from \"commander\";\nimport {\n DEFAULT_AGENT_NAME,\n resolveAgentCommand as resolveAgentCommandFromRegistry,\n} from \"../agent-registry.js\";\nimport type { SystemPromptOption } from \"../runtime/engine/session-options.js\";\nimport { DEFAULT_QUEUE_OWNER_TTL_MS } from \"../session/session.js\";\nimport {\n AUTH_POLICIES,\n NON_INTERACTIVE_PERMISSION_POLICIES,\n OUTPUT_FORMATS,\n type AuthPolicy,\n type NonInteractivePermissionPolicy,\n type OutputFormat,\n type OutputPolicy,\n type PermissionMode,\n} from \"../types.js\";\nimport type { ResolvedAcpxConfig } from \"./config.js\";\n\nexport type PermissionFlags = {\n approveAll?: boolean;\n approveReads?: boolean;\n denyAll?: boolean;\n};\n\nexport function hasExplicitPermissionModeFlag(flags: PermissionFlags): boolean {\n return flags.approveAll === true || flags.approveReads === true || flags.denyAll === true;\n}\n\nexport type GlobalFlags = PermissionFlags & {\n agent?: string;\n cwd: string;\n authPolicy?: AuthPolicy;\n nonInteractivePermissions: NonInteractivePermissionPolicy;\n jsonStrict?: boolean;\n suppressReads?: boolean;\n terminal?: boolean;\n timeout?: number;\n ttl: number;\n verbose?: boolean;\n format: OutputFormat;\n model?: string;\n allowedTools?: string[];\n maxTurns?: number;\n systemPrompt?: SystemPromptOption;\n promptRetries?: number;\n};\n\nexport type PromptFlags = {\n session?: string;\n wait?: boolean;\n file?: string;\n};\n\nexport type ExecFlags = {\n file?: string;\n};\n\nexport type SessionsNewFlags = {\n name?: string;\n resumeSession?: string;\n};\n\nexport type SessionsHistoryFlags = {\n limit: number;\n};\n\nexport type StatusFlags = {\n session?: string;\n};\n\nexport type SessionsPruneFlags = {\n dryRun?: boolean;\n before?: Date;\n olderThan?: number;\n includeHistory?: boolean;\n};\n\nexport function parseOutputFormat(value: string): OutputFormat {\n if (!OUTPUT_FORMATS.includes(value as OutputFormat)) {\n throw new InvalidArgumentError(\n `Invalid format \"${value}\". Expected one of: ${OUTPUT_FORMATS.join(\", \")}`,\n );\n }\n return value as OutputFormat;\n}\n\nexport function parseAuthPolicy(value: string): AuthPolicy {\n if (!AUTH_POLICIES.includes(value as AuthPolicy)) {\n throw new InvalidArgumentError(\n `Invalid auth policy \"${value}\". Expected one of: ${AUTH_POLICIES.join(\", \")}`,\n );\n }\n return value as AuthPolicy;\n}\n\nexport function parseNonInteractivePermissionPolicy(value: string): NonInteractivePermissionPolicy {\n if (!NON_INTERACTIVE_PERMISSION_POLICIES.includes(value as NonInteractivePermissionPolicy)) {\n throw new InvalidArgumentError(\n `Invalid non-interactive permission policy \"${value}\". Expected one of: ${NON_INTERACTIVE_PERMISSION_POLICIES.join(\", \")}`,\n );\n }\n return value as NonInteractivePermissionPolicy;\n}\n\nexport function parseTimeoutSeconds(value: string): number {\n const parsed = Number(value);\n if (!Number.isFinite(parsed) || parsed <= 0) {\n throw new InvalidArgumentError(\"Timeout must be a positive number of seconds\");\n }\n return Math.round(parsed * 1000);\n}\n\nexport function parseTtlSeconds(value: string): number {\n const parsed = Number(value);\n if (!Number.isFinite(parsed) || parsed < 0) {\n throw new InvalidArgumentError(\"TTL must be a non-negative number of seconds\");\n }\n return Math.round(parsed * 1000);\n}\n\nexport function parseSessionName(value: string): string {\n const trimmed = value.trim();\n if (trimmed.length === 0) {\n throw new InvalidArgumentError(\"Session name must not be empty\");\n }\n return trimmed;\n}\n\nexport function parseNonEmptyValue(label: string, value: string): string {\n const trimmed = value.trim();\n if (trimmed.length === 0) {\n throw new InvalidArgumentError(`${label} must not be empty`);\n }\n return trimmed;\n}\n\nexport function parseHistoryLimit(value: string): number {\n const parsed = Number(value);\n if (!Number.isInteger(parsed) || parsed <= 0) {\n throw new InvalidArgumentError(\"Limit must be a positive integer\");\n }\n return parsed;\n}\n\nexport function parseDaysOlderThan(value: string): number {\n const parsed = Number(value);\n if (!Number.isInteger(parsed) || parsed <= 0) {\n throw new InvalidArgumentError(\"--older-than must be a positive integer number of days\");\n }\n return parsed;\n}\n\nexport function parsePruneBeforeDate(value: string): Date {\n const date = new Date(value);\n if (Number.isNaN(date.getTime())) {\n throw new InvalidArgumentError(\n `--before must be a valid date (e.g. 2026-01-01 or 2026-01-01T00:00:00Z)`,\n );\n }\n return date;\n}\n\nexport function parseAllowedTools(value: string): string[] {\n const trimmed = value.trim();\n if (trimmed.length === 0) {\n return [];\n }\n\n const items = trimmed.split(\",\").map((item) => item.trim());\n if (items.some((item) => item.length === 0)) {\n throw new InvalidArgumentError(\n \"Allowed tools must be a comma-separated list without empty entries\",\n );\n }\n\n return items;\n}\n\nexport function parseMaxTurns(value: string): number {\n const parsed = Number(value);\n if (!Number.isInteger(parsed) || parsed <= 0) {\n throw new InvalidArgumentError(\"Max turns must be a positive integer\");\n }\n return parsed;\n}\n\nexport function resolveSystemPromptFlag(opts: {\n systemPrompt?: unknown;\n appendSystemPrompt?: unknown;\n}): SystemPromptOption | undefined {\n const replace =\n typeof opts.systemPrompt === \"string\" && opts.systemPrompt.length > 0\n ? opts.systemPrompt\n : undefined;\n const append =\n typeof opts.appendSystemPrompt === \"string\" && opts.appendSystemPrompt.length > 0\n ? opts.appendSystemPrompt\n : undefined;\n\n if (replace !== undefined && append !== undefined) {\n throw new InvalidArgumentError(\"Use only one of --system-prompt or --append-system-prompt\");\n }\n if (replace !== undefined) {\n return replace;\n }\n if (append !== undefined) {\n return { append };\n }\n return undefined;\n}\n\nexport function parsePromptRetries(value: string): number {\n const parsed = Number(value);\n if (!Number.isInteger(parsed) || parsed < 0) {\n throw new InvalidArgumentError(\"Prompt retries must be a non-negative integer\");\n }\n return parsed;\n}\n\nexport function resolvePermissionMode(\n flags: PermissionFlags,\n defaultMode: PermissionMode,\n): PermissionMode {\n const selected = [flags.approveAll, flags.approveReads, flags.denyAll].filter(Boolean).length;\n\n if (selected > 1) {\n throw new InvalidArgumentError(\n \"Use only one permission mode: --approve-all, --approve-reads, or --deny-all\",\n );\n }\n\n if (flags.approveAll) {\n return \"approve-all\";\n }\n if (flags.approveReads) {\n return \"approve-reads\";\n }\n if (flags.denyAll) {\n return \"deny-all\";\n }\n\n return defaultMode;\n}\n\nexport function addGlobalFlags(command: Command): Command {\n return command\n .option(\"--agent <command>\", \"Raw ACP agent command (escape hatch)\")\n .option(\"--cwd <dir>\", \"Working directory\", process.cwd())\n .option(\n \"--auth-policy <policy>\",\n \"Authentication policy: skip or fail when auth is required\",\n parseAuthPolicy,\n )\n .option(\"--approve-all\", \"Auto-approve all permission requests\")\n .option(\"--approve-reads\", \"Auto-approve read/search requests and prompt for writes\")\n .option(\"--deny-all\", \"Deny all permission requests\")\n .option(\n \"--non-interactive-permissions <policy>\",\n \"When prompting is unavailable: deny or fail\",\n parseNonInteractivePermissionPolicy,\n )\n .option(\"--format <fmt>\", \"Output format: text, json, quiet\", parseOutputFormat)\n .option(\"--suppress-reads\", \"Suppress raw read-file contents in output\")\n .option(\"--model <id>\", \"Agent model id\")\n .option(\n \"--allowed-tools <list>\",\n 'Allowed tool names as a comma-separated list (use \"\" for no tools)',\n parseAllowedTools,\n )\n .option(\"--max-turns <count>\", \"Maximum turns for the session\", parseMaxTurns)\n .option(\n \"--system-prompt <text>\",\n \"Replace the agent system prompt (claude-agent-acp via ACP _meta.systemPrompt)\",\n (value: string) => parseNonEmptyValue(\"System prompt\", value),\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent system prompt (claude-agent-acp via ACP _meta.systemPrompt.append)\",\n (value: string) => parseNonEmptyValue(\"Append system prompt\", value),\n )\n .option(\n \"--prompt-retries <count>\",\n \"Retry failed prompt turns on transient errors (default: 0)\",\n parsePromptRetries,\n )\n .option(\n \"--json-strict\",\n \"Strict JSON mode: requires --format json and suppresses non-JSON stderr output\",\n )\n .option(\"--no-terminal\", \"Do not advertise ACP terminal capability\")\n .option(\"--timeout <seconds>\", \"Maximum time to wait for agent response\", parseTimeoutSeconds)\n .option(\n \"--ttl <seconds>\",\n \"Queue owner idle TTL before shutdown (0 = keep alive forever) (default: 300)\",\n parseTtlSeconds,\n )\n .option(\"--verbose\", \"Enable verbose debug logs\");\n}\n\nexport function addSessionOption(command: Command): Command {\n return command\n .option(\"-s, --session <name>\", \"Use named session instead of cwd default\", parseSessionName)\n .option(\n \"--no-wait\",\n \"Queue prompt and return immediately when another prompt is already running\",\n );\n}\n\nexport function addSessionNameOption(command: Command): Command {\n return command.option(\n \"-s, --session <name>\",\n \"Use named session instead of cwd default\",\n parseSessionName,\n );\n}\n\nexport function resolveSessionNameFromFlags(\n flags: StatusFlags,\n command: Command,\n): string | undefined {\n if (flags.session) {\n return flags.session;\n }\n\n // Commander parses options on the parent command when flags appear before the\n // subcommand (e.g. `acpx codex -s foo cancel`). Use optsWithGlobals() so\n // subcommands can still access those values.\n const allOpts = (command as unknown as { optsWithGlobals?: () => unknown }).optsWithGlobals?.();\n if (allOpts && typeof (allOpts as { session?: unknown }).session === \"string\") {\n return parseSessionName((allOpts as { session: string }).session);\n }\n\n const parentOpts = command.parent?.opts?.();\n if (parentOpts && typeof (parentOpts as { session?: unknown }).session === \"string\") {\n return parseSessionName((parentOpts as { session: string }).session);\n }\n\n return undefined;\n}\n\nexport function addPromptInputOption(command: Command): Command {\n return command.option(\"-f, --file <path>\", \"Read prompt text from file path (use - for stdin)\");\n}\n\nexport function resolveGlobalFlags(command: Command, config: ResolvedAcpxConfig): GlobalFlags {\n const opts = command.optsWithGlobals();\n const format = opts.format ?? config.format ?? \"text\";\n const jsonStrict = opts.jsonStrict === true;\n const verbose = opts.verbose === true;\n\n if (jsonStrict && format !== \"json\") {\n throw new InvalidArgumentError(\"--json-strict requires --format json\");\n }\n\n if (jsonStrict && verbose) {\n throw new InvalidArgumentError(\"--json-strict cannot be combined with --verbose\");\n }\n\n return {\n agent: opts.agent,\n cwd: opts.cwd ?? process.cwd(),\n authPolicy: opts.authPolicy ?? config.authPolicy,\n nonInteractivePermissions: opts.nonInteractivePermissions ?? config.nonInteractivePermissions,\n jsonStrict,\n suppressReads: opts.suppressReads === true,\n terminal: opts.terminal === false ? false : undefined,\n timeout: opts.timeout ?? config.timeoutMs,\n ttl: opts.ttl ?? config.ttlMs ?? DEFAULT_QUEUE_OWNER_TTL_MS,\n verbose,\n format,\n model: typeof opts.model === \"string\" ? parseNonEmptyValue(\"Model\", opts.model) : undefined,\n allowedTools: Array.isArray(opts.allowedTools) ? opts.allowedTools : undefined,\n maxTurns: typeof opts.maxTurns === \"number\" ? opts.maxTurns : undefined,\n systemPrompt: resolveSystemPromptFlag(opts),\n promptRetries: typeof opts.promptRetries === \"number\" ? opts.promptRetries : undefined,\n approveAll: opts.approveAll ? true : undefined,\n approveReads: opts.approveReads ? true : undefined,\n denyAll: opts.denyAll ? true : undefined,\n };\n}\n\nexport function resolveOutputPolicy(format: OutputFormat, jsonStrict: boolean): OutputPolicy {\n return {\n format,\n jsonStrict,\n suppressReads: false,\n suppressNonJsonStderr: jsonStrict,\n queueErrorAlreadyEmitted: format !== \"quiet\",\n suppressSdkConsoleErrors: jsonStrict,\n };\n}\n\nexport function resolveAgentInvocation(\n explicitAgentName: string | undefined,\n globalFlags: GlobalFlags,\n config: ResolvedAcpxConfig,\n): {\n agentName: string;\n agentCommand: string;\n cwd: string;\n} {\n const override = globalFlags.agent?.trim();\n if (override && explicitAgentName) {\n throw new InvalidArgumentError(\"Do not combine positional agent with --agent override\");\n }\n\n const agentName = explicitAgentName ?? config.defaultAgent ?? DEFAULT_AGENT_NAME;\n const agentCommand =\n override && override.length > 0\n ? override\n : resolveAgentCommandFromRegistry(agentName, config.agents);\n\n return {\n agentName,\n agentCommand,\n cwd: path.resolve(globalFlags.cwd),\n };\n}\n"],"mappings":"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"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { c as createSessionWithClient, i as sendSessionDirect, l as cancelSessionPrompt, r as runOnce } from "./session-
|
|
4
|
-
import { t as createOutputFormatter } from "./output-
|
|
1
|
+
import { M as SESSION_RECORD_SCHEMA, g as textPrompt, h as promptToDisplayText, j as PERMISSION_MODES } from "./perf-metrics-C2pXfxvR.js";
|
|
2
|
+
import { G as InterruptedError, J as withTimeout, K as TimeoutError, P as resolveSessionRecord, R as defaultSessionEventLog, _ as createSessionConversation, b as recordSessionUpdate, h as cloneSessionAcpxState, q as withInterrupt, v as recordClientOperation, y as recordPromptSubmission } from "./prompt-turn-BY5SwU1F.js";
|
|
3
|
+
import { c as createSessionWithClient, i as sendSessionDirect, l as cancelSessionPrompt, r as runOnce } from "./session-BwgaPK8-.js";
|
|
4
|
+
import { t as createOutputFormatter } from "./output-DmHvT8vm.js";
|
|
5
5
|
import path from "node:path";
|
|
6
6
|
import fs from "node:fs/promises";
|
|
7
7
|
import os from "node:os";
|
|
@@ -901,6 +901,7 @@ function snapshotNode(node) {
|
|
|
901
901
|
hasRun: typeof node.run === "function"
|
|
902
902
|
};
|
|
903
903
|
}
|
|
904
|
+
throw new Error(`Unsupported flow node type: ${String(node)}`);
|
|
904
905
|
}
|
|
905
906
|
function snapshotCwd(cwd) {
|
|
906
907
|
if (typeof cwd === "function") return { mode: "dynamic" };
|
|
@@ -1663,8 +1664,14 @@ var FlowRunner = class {
|
|
|
1663
1664
|
};
|
|
1664
1665
|
//#endregion
|
|
1665
1666
|
//#region src/flows/json.ts
|
|
1667
|
+
function normalizeJsonText(text) {
|
|
1668
|
+
if (typeof text === "string") return text.trim();
|
|
1669
|
+
if (text == null) return "";
|
|
1670
|
+
if (typeof text === "number" || typeof text === "boolean" || typeof text === "bigint" || typeof text === "symbol") return String(text).trim();
|
|
1671
|
+
return "";
|
|
1672
|
+
}
|
|
1666
1673
|
function parseJsonObject(text, options = {}) {
|
|
1667
|
-
const trimmed =
|
|
1674
|
+
const trimmed = normalizeJsonText(text);
|
|
1668
1675
|
if (!trimmed) throw new Error("Expected JSON output, got empty text");
|
|
1669
1676
|
const mode = options.mode ?? "compat";
|
|
1670
1677
|
const direct = tryParse(trimmed);
|
|
@@ -1738,4 +1745,4 @@ function scanBalanced(text, startIndex) {
|
|
|
1738
1745
|
//#endregion
|
|
1739
1746
|
export { flowRunsBaseDir as a, action as c, defineFlow as d, shell as f, FlowRunner as i, checkpoint as l, parseJsonObject as n, validateFlowDefinition as o, isDefinedFlow as p, parseStrictJsonObject as r, acp as s, extractJsonObject as t, compute as u };
|
|
1740
1747
|
|
|
1741
|
-
//# sourceMappingURL=flows-
|
|
1748
|
+
//# sourceMappingURL=flows-CDsfbaA2.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flows-CDsfbaA2.js","names":["isoNow","isoNow","exhaustive","recordConversationSessionUpdate","recordConversationClientOperation"],"sources":["../src/flows/authoring.ts","../src/flows/schema.ts","../src/flows/definition.ts","../src/flows/executors/shell.ts","../src/flows/graph.ts","../src/flows/runtime-support.ts","../src/flows/store.ts","../src/flows/runtime.ts","../src/flows/json.ts"],"sourcesContent":["import type { FlowDefinition } from \"./types.js\";\n\nconst FLOW_DEFINITION_BRAND = Symbol.for(\"acpx.flow.definition\");\n\nexport function markDefinedFlow<TFlow extends FlowDefinition>(definition: TFlow): TFlow {\n if (isDefinedFlow(definition)) {\n return definition;\n }\n\n Object.defineProperty(definition, FLOW_DEFINITION_BRAND, {\n value: true,\n enumerable: false,\n configurable: false,\n writable: false,\n });\n return definition;\n}\n\nexport function isDefinedFlow(value: unknown): value is FlowDefinition {\n return (\n value != null &&\n typeof value === \"object\" &&\n (value as Record<PropertyKey, unknown>)[FLOW_DEFINITION_BRAND] === true\n );\n}\n","import { ZodError, z } from \"zod\";\nimport { PERMISSION_MODES } from \"../types.js\";\nimport type {\n AcpNodeDefinition,\n ActionNodeDefinition,\n CheckpointNodeDefinition,\n ComputeNodeDefinition,\n FlowDefinition,\n FlowRunDefinition,\n FunctionActionNodeDefinition,\n ShellActionNodeDefinition,\n} from \"./types.js\";\n\nconst FLOW_NODE_TYPES = [\"acp\", \"compute\", \"action\", \"checkpoint\"] as const;\n\nconst finiteNonNegativeNumberSchema = z.number().finite().nonnegative();\nconst nonEmptyTrimmedStringSchema = z.string().refine((value) => value.trim().length > 0, {\n message: \"must not be empty\",\n});\n\nfunction extensibleObject<TShape extends z.ZodRawShape>(shape: TShape) {\n return z.object(shape).passthrough();\n}\n\nfunction functionSchema<T extends Function>(label: string): z.ZodType<T> {\n return z.custom<T>((value) => typeof value === \"function\", {\n message: `${label} must be a function`,\n });\n}\n\nconst flowNodeCommonShape = {\n timeoutMs: finiteNonNegativeNumberSchema.optional(),\n heartbeatMs: finiteNonNegativeNumberSchema.optional(),\n statusDetail: z.string().optional(),\n} satisfies z.ZodRawShape;\n\nconst flowPermissionRequirementsSchema = extensibleObject({\n requiredMode: z.enum(PERMISSION_MODES),\n requireExplicitGrant: z.boolean().optional(),\n reason: nonEmptyTrimmedStringSchema.optional(),\n});\n\nconst flowRunDefinitionSchema = extensibleObject({\n title: z\n .union([\n z.string(),\n functionSchema<Exclude<FlowRunDefinition[\"title\"], string | undefined>>(\"run.title\"),\n ])\n .optional(),\n});\n\nconst acpSessionSchema = extensibleObject({\n handle: z.string().optional(),\n isolated: z.boolean().optional(),\n});\n\nconst acpNodeSchema = extensibleObject({\n ...flowNodeCommonShape,\n nodeType: z.literal(\"acp\"),\n profile: z.string().optional(),\n cwd: z\n .union([\n z.string(),\n functionSchema<Exclude<AcpNodeDefinition[\"cwd\"], string | undefined>>(\"cwd\"),\n ])\n .optional(),\n session: acpSessionSchema.optional(),\n prompt: functionSchema<AcpNodeDefinition[\"prompt\"]>(\"prompt\"),\n parse: functionSchema<NonNullable<AcpNodeDefinition[\"parse\"]>>(\"parse\").optional(),\n});\n\nconst computeNodeSchema = extensibleObject({\n ...flowNodeCommonShape,\n nodeType: z.literal(\"compute\"),\n run: functionSchema<ComputeNodeDefinition[\"run\"]>(\"run\"),\n});\n\nconst functionActionNodeSchema = extensibleObject({\n ...flowNodeCommonShape,\n nodeType: z.literal(\"action\"),\n run: functionSchema<FunctionActionNodeDefinition[\"run\"]>(\"run\"),\n});\n\nconst shellActionNodeSchema = extensibleObject({\n ...flowNodeCommonShape,\n nodeType: z.literal(\"action\"),\n exec: functionSchema<ShellActionNodeDefinition[\"exec\"]>(\"exec\"),\n parse: functionSchema<NonNullable<ShellActionNodeDefinition[\"parse\"]>>(\"parse\").optional(),\n}).refine((node) => !hasOwn(node, \"run\"), {\n message: \"shell action nodes must not define run\",\n});\n\nconst checkpointNodeSchema = extensibleObject({\n ...flowNodeCommonShape,\n nodeType: z.literal(\"checkpoint\"),\n summary: z.string().optional(),\n run: functionSchema<NonNullable<CheckpointNodeDefinition[\"run\"]>>(\"run\").optional(),\n});\n\nconst directFlowEdgeSchema = extensibleObject({\n from: z.string(),\n to: z.string(),\n});\n\nconst switchFlowEdgeSchema = extensibleObject({\n from: z.string(),\n switch: extensibleObject({\n on: z.string(),\n cases: z.record(z.string(), z.string()),\n }),\n});\n\nconst flowDefinitionSchema = extensibleObject({\n name: nonEmptyTrimmedStringSchema,\n run: flowRunDefinitionSchema.optional(),\n permissions: flowPermissionRequirementsSchema.optional(),\n startAt: z.string(),\n nodes: z.record(z.string(), z.unknown()),\n edges: z.array(z.unknown()),\n});\n\nconst flowNodeTypeSchema = z.object({\n nodeType: z.enum(FLOW_NODE_TYPES),\n});\n\nexport function assertValidFlowDefinitionShape(flow: FlowDefinition): void {\n const parsed = parseWithSchema(\"flow definition\", flowDefinitionSchema, flow);\n\n for (const [nodeId, node] of Object.entries(parsed.nodes)) {\n assertValidFlowNodeDefinitionShape(node, `flow node \"${nodeId}\"`);\n }\n parsed.edges.forEach((edge, index) => {\n assertValidFlowEdgeShape(edge, `flow definition: edges.${index}`);\n });\n}\n\nexport function assertValidAcpNodeDefinition(node: AcpNodeDefinition): void {\n parseWithSchema(\"acp node definition\", acpNodeSchema, node);\n}\n\nexport function assertValidComputeNodeDefinition(node: ComputeNodeDefinition): void {\n parseWithSchema(\"compute node definition\", computeNodeSchema, node);\n}\n\nexport function assertValidActionNodeDefinition(node: ActionNodeDefinition): void {\n assertValidActionNodeDefinitionShape(node, \"action node definition\");\n}\n\nexport function assertValidShellActionNodeDefinition(node: ShellActionNodeDefinition): void {\n parseWithSchema(\"shell action node definition\", shellActionNodeSchema, node);\n}\n\nexport function assertValidCheckpointNodeDefinition(node: CheckpointNodeDefinition): void {\n parseWithSchema(\"checkpoint node definition\", checkpointNodeSchema, node);\n}\n\nfunction assertValidFlowNodeDefinitionShape(node: unknown, label: string): void {\n const { nodeType } = parseWithSchema(label, flowNodeTypeSchema, node);\n\n switch (nodeType) {\n case \"acp\":\n parseWithSchema(label, acpNodeSchema, node);\n return;\n case \"compute\":\n parseWithSchema(label, computeNodeSchema, node);\n return;\n case \"action\":\n assertValidActionNodeDefinitionShape(node, label);\n return;\n case \"checkpoint\":\n parseWithSchema(label, checkpointNodeSchema, node);\n return;\n }\n}\n\nfunction assertValidActionNodeDefinitionShape(node: unknown, label: string): void {\n const hasRun = hasOwn(node, \"run\");\n const hasExec = hasOwn(node, \"exec\");\n\n if (hasRun === hasExec) {\n throw new Error(`Invalid ${label}: action nodes must define exactly one of run or exec`);\n }\n\n if (hasExec) {\n parseWithSchema(label, shellActionNodeSchema, node);\n return;\n }\n\n parseWithSchema(label, functionActionNodeSchema, node);\n}\n\nfunction assertValidFlowEdgeShape(edge: unknown, label: string): void {\n const hasTo = hasOwn(edge, \"to\");\n const hasSwitch = hasOwn(edge, \"switch\");\n\n if (hasTo === hasSwitch) {\n throw new Error(`Invalid ${label}: edge must define exactly one of to or switch`);\n }\n\n if (hasTo) {\n parseWithSchema(label, directFlowEdgeSchema, edge);\n return;\n }\n\n parseWithSchema(label, switchFlowEdgeSchema, edge);\n}\n\nfunction parseWithSchema<T>(label: string, schema: z.ZodType<T>, value: unknown): T {\n try {\n return schema.parse(value);\n } catch (error) {\n if (error instanceof ZodError) {\n throw new Error(formatValidationError(label, error), { cause: error });\n }\n throw error;\n }\n}\n\nfunction formatValidationError(label: string, error: ZodError): string {\n const details = Array.from(new Set(error.issues.flatMap((issue) => formatIssue(issue)))).join(\n \"; \",\n );\n return `Invalid ${label}: ${details}`;\n}\n\nfunction formatIssue(issue: z.ZodIssue, parentPath: string[] = []): string[] {\n const path = [...parentPath, ...issue.path.map(String)];\n\n if (issue.code === \"invalid_union\") {\n return issue.errors.flatMap((branch) =>\n branch.flatMap((nestedIssue) => formatIssue(nestedIssue, path)),\n );\n }\n\n const renderedPath = path.join(\".\");\n return [renderedPath ? `${renderedPath}: ${issue.message}` : issue.message];\n}\n\nfunction hasOwn(value: unknown, key: string): boolean {\n return (\n value != null && typeof value === \"object\" && Object.prototype.hasOwnProperty.call(value, key)\n );\n}\n","import { markDefinedFlow } from \"./authoring.js\";\nimport {\n assertValidAcpNodeDefinition,\n assertValidActionNodeDefinition,\n assertValidCheckpointNodeDefinition,\n assertValidComputeNodeDefinition,\n assertValidFlowDefinitionShape,\n assertValidShellActionNodeDefinition,\n} from \"./schema.js\";\nimport type {\n AcpNodeDefinition,\n ActionNodeDefinition,\n CheckpointNodeDefinition,\n ComputeNodeDefinition,\n FlowDefinition,\n FunctionActionNodeDefinition,\n ShellActionNodeDefinition,\n} from \"./types.js\";\n\nexport function defineFlow<TFlow extends FlowDefinition>(definition: TFlow): TFlow {\n assertValidFlowDefinitionShape(definition);\n return markDefinedFlow(definition);\n}\n\nexport function acp(definition: Omit<AcpNodeDefinition, \"nodeType\">): AcpNodeDefinition {\n const node: AcpNodeDefinition = {\n nodeType: \"acp\",\n ...definition,\n };\n assertValidAcpNodeDefinition(node);\n return node;\n}\n\nexport function compute(\n definition: Omit<ComputeNodeDefinition, \"nodeType\">,\n): ComputeNodeDefinition {\n const node: ComputeNodeDefinition = {\n nodeType: \"compute\",\n ...definition,\n };\n assertValidComputeNodeDefinition(node);\n return node;\n}\n\nexport function action(\n definition: Omit<FunctionActionNodeDefinition, \"nodeType\">,\n): FunctionActionNodeDefinition;\nexport function action(\n definition: Omit<ShellActionNodeDefinition, \"nodeType\">,\n): ShellActionNodeDefinition;\nexport function action(\n definition:\n | Omit<FunctionActionNodeDefinition, \"nodeType\">\n | Omit<ShellActionNodeDefinition, \"nodeType\">,\n): ActionNodeDefinition {\n const node: ActionNodeDefinition = {\n nodeType: \"action\",\n ...definition,\n } as ActionNodeDefinition;\n assertValidActionNodeDefinition(node);\n return node;\n}\n\nexport function shell(\n definition: Omit<ShellActionNodeDefinition, \"nodeType\">,\n): ShellActionNodeDefinition {\n const node: ShellActionNodeDefinition = {\n nodeType: \"action\",\n ...definition,\n };\n assertValidShellActionNodeDefinition(node);\n return node;\n}\n\nexport function checkpoint(\n definition: Omit<CheckpointNodeDefinition, \"nodeType\"> = {},\n): CheckpointNodeDefinition {\n const node: CheckpointNodeDefinition = {\n nodeType: \"checkpoint\",\n ...definition,\n };\n assertValidCheckpointNodeDefinition(node);\n return node;\n}\n","import { spawn } from \"node:child_process\";\nimport { TimeoutError } from \"../../async-control.js\";\nimport type { ShellActionExecution, ShellActionResult } from \"../runtime.js\";\n\nexport function formatShellActionSummary(spec: ShellActionExecution): string {\n return `shell: ${renderShellCommand(spec.command, spec.args ?? [])}`;\n}\n\nexport function renderShellCommand(command: string, args: string[]): string {\n const renderedArgs = args.map((arg) => JSON.stringify(arg)).join(\" \");\n return renderedArgs.length > 0 ? `${command} ${renderedArgs}` : command;\n}\n\nexport async function runShellAction(spec: ShellActionExecution): Promise<ShellActionResult> {\n const cwd = spec.cwd ?? process.cwd();\n const args = spec.args ?? [];\n const startMs = Date.now();\n const child = spawn(spec.command, args, {\n cwd,\n env: {\n ...process.env,\n ...spec.env,\n },\n shell: spec.shell,\n stdio: [\"pipe\", \"pipe\", \"pipe\"],\n windowsHide: true,\n });\n\n let stdout = \"\";\n let stderr = \"\";\n let timedOut = false;\n let timeout: NodeJS.Timeout | undefined;\n\n const finish = new Promise<ShellActionResult>((resolve, reject) => {\n child.stdout.setEncoding(\"utf8\");\n child.stderr.setEncoding(\"utf8\");\n child.stdout.on(\"data\", (chunk: string) => {\n stdout += chunk;\n });\n child.stderr.on(\"data\", (chunk: string) => {\n stderr += chunk;\n });\n\n child.once(\"error\", reject);\n child.once(\"exit\", (exitCode, signal) => {\n const result: ShellActionResult = {\n command: spec.command,\n args,\n cwd,\n stdout,\n stderr,\n combinedOutput: `${stdout}${stderr}`,\n exitCode,\n signal,\n durationMs: Date.now() - startMs,\n };\n\n if (timedOut) {\n reject(new TimeoutError(spec.timeoutMs ?? 0));\n return;\n }\n\n if (((exitCode ?? 0) !== 0 || signal != null) && spec.allowNonZeroExit !== true) {\n reject(\n new Error(\n `Shell action failed (${renderShellCommand(spec.command, args)}): ${signal ? `signal ${signal}` : `exit ${String(exitCode)}`}${stderr.length > 0 ? `\\n${stderr.trim()}` : \"\"}`,\n ),\n );\n return;\n }\n\n resolve(result);\n });\n });\n\n if (spec.stdin != null) {\n child.stdin.write(spec.stdin);\n }\n child.stdin.end();\n\n if (spec.timeoutMs != null && spec.timeoutMs > 0) {\n timeout = setTimeout(() => {\n timedOut = true;\n child.kill(\"SIGTERM\");\n setTimeout(() => {\n child.kill(\"SIGKILL\");\n }, 1_000).unref();\n }, spec.timeoutMs);\n }\n\n try {\n return await finish;\n } finally {\n if (timeout) {\n clearTimeout(timeout);\n }\n }\n}\n","import { assertValidFlowDefinitionShape } from \"./schema.js\";\nimport type { FlowDefinition, FlowEdge, FlowNodeResult } from \"./types.js\";\n\nexport function validateFlowDefinition(flow: FlowDefinition): void {\n assertValidFlowDefinitionShape(flow);\n if (!flow.nodes[flow.startAt]) {\n throw new Error(`Flow start node is missing: ${flow.startAt}`);\n }\n\n const outgoingEdges = new Set<string>();\n for (const edge of flow.edges) {\n if (!flow.nodes[edge.from]) {\n throw new Error(`Flow edge references unknown from-node: ${edge.from}`);\n }\n if (outgoingEdges.has(edge.from)) {\n throw new Error(`Flow node must not declare multiple outgoing edges: ${edge.from}`);\n }\n outgoingEdges.add(edge.from);\n if (\"to\" in edge) {\n if (!flow.nodes[edge.to]) {\n throw new Error(`Flow edge references unknown to-node: ${edge.to}`);\n }\n continue;\n }\n for (const target of Object.values(edge.switch.cases)) {\n if (!flow.nodes[target]) {\n throw new Error(`Flow switch references unknown to-node: ${target}`);\n }\n }\n }\n}\n\nexport function resolveNext(\n edges: FlowEdge[],\n from: string,\n output: unknown,\n result?: FlowNodeResult,\n): string | null {\n const edge = edges.find((candidate) => candidate.from === from);\n if (!edge) {\n return null;\n }\n\n if (\"to\" in edge) {\n return edge.to;\n }\n\n const value = getBySwitchPath(output, result, edge.switch.on);\n if (typeof value !== \"string\" && typeof value !== \"number\" && typeof value !== \"boolean\") {\n throw new Error(`Flow switch value must be scalar for ${edge.switch.on}`);\n }\n const next = edge.switch.cases[String(value)];\n if (!next) {\n throw new Error(`No flow switch case for ${edge.switch.on}=${JSON.stringify(value)}`);\n }\n return next;\n}\n\nexport function resolveNextForOutcome(\n edges: FlowEdge[],\n from: string,\n result: FlowNodeResult,\n): string | null {\n const edge = edges.find((candidate) => candidate.from === from);\n if (!edge || \"to\" in edge) {\n return null;\n }\n if (!edge.switch.on.startsWith(\"$result.\")) {\n return null;\n }\n const value = getBySwitchPath(undefined, result, edge.switch.on);\n if (typeof value !== \"string\" && typeof value !== \"number\" && typeof value !== \"boolean\") {\n throw new Error(`Flow switch value must be scalar for ${edge.switch.on}`);\n }\n const next = edge.switch.cases[String(value)];\n if (!next) {\n throw new Error(`No flow switch case for ${edge.switch.on}=${JSON.stringify(value)}`);\n }\n return next;\n}\n\nfunction getBySwitchPath(\n output: unknown,\n result: FlowNodeResult | undefined,\n jsonPath: string,\n): unknown {\n if (jsonPath.startsWith(\"$result.\")) {\n return getByPath(result, `$.${jsonPath.slice(\"$result.\".length)}`);\n }\n if (jsonPath.startsWith(\"$output.\")) {\n return getByPath(output, `$.${jsonPath.slice(\"$output.\".length)}`);\n }\n return getByPath(output, jsonPath);\n}\n\nfunction getByPath(value: unknown, jsonPath: string): unknown {\n if (!jsonPath.startsWith(\"$.\")) {\n throw new Error(`Unsupported JSON path: ${jsonPath}`);\n }\n\n return jsonPath\n .slice(2)\n .split(\".\")\n .reduce((current: unknown, key) => {\n if (current == null || typeof current !== \"object\") {\n return undefined;\n }\n return (current as Record<string, unknown>)[key];\n }, value);\n}\n","import { createHash, randomUUID } from \"node:crypto\";\nimport path from \"node:path\";\nimport { InterruptedError, TimeoutError } from \"../async-control.js\";\nimport { createOutputFormatter } from \"../cli/output/output.js\";\nimport { textPrompt } from \"../prompt-content.js\";\nimport { defaultSessionEventLog } from \"../session/event-log.js\";\nimport { SESSION_RECORD_SCHEMA } from \"../types.js\";\nimport type { PromptInput, SessionRecord } from \"../types.js\";\nimport type { FlowRunStore } from \"./store.js\";\nimport type {\n AcpNodeDefinition,\n FlowDefinition,\n FlowNodeContext,\n FlowNodeDefinition,\n FlowNodeOutcome,\n FlowNodeResult,\n FlowRunState,\n FlowSessionBinding,\n FlowStepTrace,\n ResolvedFlowAgent,\n} from \"./types.js\";\n\ntype MemoryWritable = {\n write(chunk: string): void;\n};\n\nexport function isoNow(): string {\n return new Date().toISOString();\n}\n\nexport function persistRunFailure(\n store: FlowRunStore,\n runDir: string,\n state: FlowRunState,\n error: unknown,\n): Promise<void> {\n if (\n state.finishedAt !== undefined &&\n (state.status === \"failed\" || state.status === \"timed_out\")\n ) {\n return Promise.resolve();\n }\n\n state.status = error instanceof TimeoutError ? \"timed_out\" : \"failed\";\n state.updatedAt = isoNow();\n state.finishedAt = state.updatedAt;\n state.error = error instanceof Error ? error.message : String(error);\n state.statusDetail = state.currentNode\n ? `Failed in ${state.currentNode}: ${state.error}`\n : state.error;\n return store.writeSnapshot(runDir, state, {\n scope: \"run\",\n type: \"run_failed\",\n payload: {\n status: state.status,\n error: state.error,\n },\n });\n}\n\nexport function makeFlowNodeContext(\n state: FlowRunState,\n input: unknown,\n services: FlowNodeContext[\"services\"],\n): FlowNodeContext {\n return {\n input,\n outputs: state.outputs,\n results: state.results,\n state,\n services,\n };\n}\n\nexport function markNodeStarted(\n state: FlowRunState,\n nodeId: string,\n attemptId: string,\n nodeType: FlowNodeDefinition[\"nodeType\"],\n startedAt: string,\n detail?: string,\n): void {\n state.status = \"running\";\n state.waitingOn = undefined;\n state.currentNode = nodeId;\n state.currentAttemptId = attemptId;\n state.currentNodeType = nodeType;\n state.currentNodeStartedAt = startedAt;\n state.lastHeartbeatAt = startedAt;\n state.statusDetail = detail ?? `Running ${nodeType} node ${nodeId}`;\n}\n\nexport function clearActiveNode(state: FlowRunState, detail?: string): void {\n state.currentNode = undefined;\n state.currentAttemptId = undefined;\n state.currentNodeType = undefined;\n state.currentNodeStartedAt = undefined;\n state.lastHeartbeatAt = undefined;\n state.statusDetail = detail;\n}\n\nexport function updateStatusDetail(state: FlowRunState, detail?: string): void {\n if (!detail) {\n return;\n }\n state.statusDetail = detail;\n}\n\nexport async function finalizeStepTrace(\n store: FlowRunStore,\n runDir: string,\n state: FlowRunState,\n nodeId: string,\n attemptId: string,\n output: unknown,\n baseTrace: FlowStepTrace | null,\n): Promise<FlowStepTrace | null> {\n const trace: FlowStepTrace = baseTrace ? structuredClone(baseTrace) : {};\n if (output !== undefined) {\n const inlineOutput = toInlineOutput(output);\n if (inlineOutput !== undefined) {\n trace.outputInline = inlineOutput;\n } else {\n trace.outputArtifact = await store.writeArtifact(runDir, state, output, {\n mediaType: outputArtifactMediaType(output),\n extension: outputArtifactExtension(output),\n nodeId,\n attemptId,\n });\n }\n }\n return Object.keys(trace).length > 0 ? trace : null;\n}\n\nexport function normalizePromptInput(prompt: PromptInput | string): PromptInput {\n return typeof prompt === \"string\" ? textPrompt(prompt) : prompt;\n}\n\nexport async function resolveNodeCwd(\n defaultCwd: string,\n cwd: AcpNodeDefinition[\"cwd\"],\n context: FlowNodeContext,\n): Promise<string> {\n if (typeof cwd === \"function\") {\n const resolved = (await cwd(context)) ?? defaultCwd;\n return path.resolve(defaultCwd, resolved);\n }\n return path.resolve(defaultCwd, cwd ?? defaultCwd);\n}\n\nexport function resolveShellActionCwd(defaultCwd: string, cwd: string | undefined): string {\n return path.resolve(defaultCwd, cwd ?? defaultCwd);\n}\n\nexport function summarizePrompt(promptText: string, explicitDetail?: string): string {\n if (explicitDetail) {\n return explicitDetail;\n }\n\n const line = promptText\n .split(\"\\n\")\n .map((candidate) => candidate.trim())\n .find((candidate) => candidate.length > 0);\n\n if (!line) {\n return \"Running ACP prompt\";\n }\n\n const truncated = line.length > 120 ? `${line.slice(0, 117)}...` : line;\n return `ACP: ${truncated}`;\n}\n\nexport function createQuietCaptureOutput(): {\n formatter: ReturnType<typeof createOutputFormatter>;\n read: () => string;\n} {\n const chunks: string[] = [];\n const stdout: MemoryWritable = {\n write(chunk: string) {\n chunks.push(chunk);\n },\n };\n\n return {\n formatter: createOutputFormatter(\"quiet\", {\n stdout,\n }),\n read: () => chunks.join(\"\").trim(),\n };\n}\n\nexport async function resolveFlowRunTitle(\n flow: FlowDefinition,\n input: unknown,\n flowPath?: string,\n): Promise<string | undefined> {\n const titleDefinition = flow.run?.title;\n if (titleDefinition === undefined) {\n return undefined;\n }\n\n const resolved =\n typeof titleDefinition === \"function\"\n ? await Promise.resolve(titleDefinition({ input, flowName: flow.name, flowPath }))\n : titleDefinition;\n\n return normalizeFlowRunTitle(resolved);\n}\n\nexport function normalizeFlowRunTitle(value: string | undefined): string | undefined {\n const trimmed = value?.trim();\n return trimmed ? trimmed : undefined;\n}\n\nexport function createRunId(flowName: string): string {\n const stamp = isoNow().replaceAll(\":\", \"\").replaceAll(\".\", \"\");\n const slug = flowName\n .replace(/[^a-z0-9]+/gi, \"-\")\n .replace(/^-+|-+$/g, \"\")\n .toLowerCase();\n return `${stamp}-${slug}-${randomUUID().slice(0, 8)}`;\n}\n\nexport function createSessionBindingKey(agentCommand: string, cwd: string, handle: string): string {\n return `${agentCommand}::${cwd}::${handle}`;\n}\n\nexport function createSessionName(\n flowName: string,\n handle: string,\n cwd: string,\n runId: string,\n): string {\n const stamp = stableShortHash(cwd);\n return `${flowName}-${handle}-${stamp}-${runId.slice(-8)}`;\n}\n\nexport function createSessionBundleId(handle: string, key: string): string {\n const safeHandle = handle\n .replace(/[^a-z0-9]+/gi, \"-\")\n .replace(/^-+|-+$/g, \"\")\n .toLowerCase();\n return `${safeHandle || \"session\"}-${stableShortHash(key)}`;\n}\n\nexport function createIsolatedSessionBinding(\n flowName: string,\n runId: string,\n attemptId: string,\n profile: string | undefined,\n agent: ResolvedFlowAgent,\n): FlowSessionBinding {\n const key = `isolated::${attemptId}`;\n const handle = \"isolated\";\n return {\n key,\n handle,\n bundleId: createSessionBundleId(`${handle}-${attemptId}`, `${key}::${agent.cwd}`),\n name: `${flowName}-${attemptId}-${runId.slice(-8)}`,\n profile,\n agentName: agent.agentName,\n agentCommand: agent.agentCommand,\n cwd: agent.cwd,\n acpxRecordId: key,\n acpSessionId: key,\n };\n}\n\nexport function createSyntheticSessionRecord(options: {\n binding: FlowSessionBinding;\n createdAt: string;\n updatedAt: string;\n conversation: Pick<\n SessionRecord,\n \"title\" | \"messages\" | \"updated_at\" | \"cumulative_token_usage\" | \"request_token_usage\"\n >;\n acpxState: SessionRecord[\"acpx\"] | undefined;\n lastSeq: number;\n}): SessionRecord {\n return {\n schema: SESSION_RECORD_SCHEMA,\n acpxRecordId: options.binding.acpxRecordId,\n acpSessionId: options.binding.acpSessionId,\n agentSessionId: options.binding.agentSessionId,\n agentCommand: options.binding.agentCommand,\n cwd: options.binding.cwd,\n name: options.binding.name,\n createdAt: options.createdAt,\n lastUsedAt: options.updatedAt,\n lastSeq: options.lastSeq,\n lastRequestId: undefined,\n eventLog: defaultSessionEventLog(options.binding.acpxRecordId),\n closed: true,\n closedAt: options.updatedAt,\n title: options.conversation.title,\n messages: options.conversation.messages,\n updated_at: options.conversation.updated_at,\n cumulative_token_usage: options.conversation.cumulative_token_usage,\n request_token_usage: options.conversation.request_token_usage,\n acpx: options.acpxState,\n };\n}\n\nexport function createNodeResult(options: {\n attemptId: string;\n nodeId: string;\n nodeType: FlowNodeDefinition[\"nodeType\"];\n outcome: FlowNodeOutcome;\n startedAt: string;\n finishedAt: string;\n output?: unknown;\n error?: string;\n}): FlowNodeResult {\n return {\n attemptId: options.attemptId,\n nodeId: options.nodeId,\n nodeType: options.nodeType,\n outcome: options.outcome,\n startedAt: options.startedAt,\n finishedAt: options.finishedAt,\n durationMs: new Date(options.finishedAt).getTime() - new Date(options.startedAt).getTime(),\n output: options.output,\n error: options.error,\n };\n}\n\nexport function outcomeForError(error: unknown): FlowNodeOutcome {\n if (error instanceof TimeoutError) {\n return \"timed_out\";\n }\n if (error instanceof InterruptedError) {\n return \"cancelled\";\n }\n return \"failed\";\n}\n\nfunction stableShortHash(value: string): string {\n return createHash(\"sha1\").update(value).digest(\"hex\").slice(0, 8);\n}\n\nexport function nextAttemptId(attemptCounts: Map<string, number>, nodeId: string): string {\n const next = (attemptCounts.get(nodeId) ?? 0) + 1;\n attemptCounts.set(nodeId, next);\n return `${nodeId}#${next}`;\n}\n\nexport function createNodeOutcomePayload(\n result: FlowNodeResult,\n trace: FlowStepTrace | null,\n): Record<string, unknown> {\n return {\n nodeType: result.nodeType,\n outcome: result.outcome,\n durationMs: result.durationMs,\n error: result.error ?? null,\n ...trace,\n };\n}\n\nexport function attachStepTrace(error: unknown, trace: FlowStepTrace | null): Error {\n const attached =\n error instanceof Error ? error : new Error(typeof error === \"string\" ? error : String(error));\n (attached as Error & { flowStepTrace?: FlowStepTrace | null }).flowStepTrace = trace;\n return attached;\n}\n\nexport function extractAttachedStepTrace(error: unknown): FlowStepTrace | null | undefined {\n if (!(error instanceof Error)) {\n return undefined;\n }\n return (error as Error & { flowStepTrace?: FlowStepTrace | null }).flowStepTrace;\n}\n\nfunction toInlineOutput(value: unknown): undefined | null | boolean | number | string | object {\n if (value == null || typeof value === \"number\" || typeof value === \"boolean\") {\n return value;\n }\n if (typeof value === \"string\") {\n return value.length <= 200 && !value.includes(\"\\n\") ? value : undefined;\n }\n try {\n const serialized = JSON.stringify(value);\n if (serialized.length <= 200 && !serialized.includes(\"\\n\")) {\n return value;\n }\n } catch {\n return undefined;\n }\n return undefined;\n}\n\nfunction outputArtifactMediaType(value: unknown): string {\n return typeof value === \"string\" ? \"text/plain\" : \"application/json\";\n}\n\nfunction outputArtifactExtension(value: unknown): string {\n return typeof value === \"string\" ? \"txt\" : \"json\";\n}\n\nexport function findConversationDeltaStart(\n before: SessionRecord[\"messages\"],\n after: SessionRecord[\"messages\"],\n): number {\n const maxOverlap = Math.min(before.length, after.length);\n for (let overlap = maxOverlap; overlap >= 0; overlap -= 1) {\n let matches = true;\n for (let index = 0; index < overlap; index += 1) {\n const beforeMessage = before[before.length - overlap + index];\n const afterMessage = after[index];\n if (!deepEqualJson(beforeMessage, afterMessage)) {\n matches = false;\n break;\n }\n }\n if (matches) {\n return overlap;\n }\n }\n return 0;\n}\n\nfunction deepEqualJson(left: unknown, right: unknown): boolean {\n return JSON.stringify(left) === JSON.stringify(right);\n}\n","import { createHash, randomUUID } from \"node:crypto\";\nimport fs from \"node:fs/promises\";\nimport os from \"node:os\";\nimport path from \"node:path\";\nimport type { AcpJsonRpcMessage, AcpMessageDirection, SessionRecord } from \"../types.js\";\nimport type {\n AcpNodeDefinition,\n FlowArtifactRef,\n FlowDefinition,\n FlowDefinitionSnapshot,\n FlowManifestSessionEntry,\n FlowNodeDefinition,\n FlowRunManifest,\n FlowRunState,\n FlowSessionBinding,\n FlowTraceEvent,\n FlowTraceEventDraft,\n} from \"./types.js\";\n\nconst FLOW_BUNDLE_SCHEMA = \"acpx.flow-run-bundle.v1\" as const;\nconst FLOW_TRACE_SCHEMA = \"acpx.flow-trace-event.v1\" as const;\nconst FLOW_SNAPSHOT_SCHEMA = \"acpx.flow-definition-snapshot.v1\" as const;\n\nconst MANIFEST_PATH = \"manifest.json\";\nconst FLOW_SNAPSHOT_PATH = \"flow.json\";\nconst TRACE_PATH = \"trace.ndjson\";\nconst PROJECTIONS_DIR = \"projections\";\nconst RUN_PROJECTION_PATH = \"projections/run.json\";\nconst LIVE_PROJECTION_PATH = \"projections/live.json\";\nconst STEPS_PROJECTION_PATH = \"projections/steps.json\";\nconst SESSIONS_DIR = \"sessions\";\nconst ARTIFACTS_DIR = \"artifacts\";\n\ntype FlowLiveState = {\n runId: string;\n flowName: string;\n runTitle?: string;\n flowPath?: string;\n startedAt: string;\n finishedAt?: string;\n updatedAt: string;\n status: FlowRunState[\"status\"];\n currentNode?: string;\n currentAttemptId?: string;\n currentNodeType?: FlowRunState[\"currentNodeType\"];\n currentNodeStartedAt?: string;\n lastHeartbeatAt?: string;\n statusDetail?: string;\n waitingOn?: string;\n error?: string;\n sessionBindings: FlowRunState[\"sessionBindings\"];\n};\n\ntype WriteArtifactOptions = {\n mediaType: string;\n extension: string;\n nodeId?: string;\n attemptId?: string;\n sessionId?: string;\n emitTrace?: boolean;\n};\n\nexport function flowRunsBaseDir(homeDir: string = os.homedir()): string {\n return path.join(homeDir, \".acpx\", \"flows\", \"runs\");\n}\n\nexport class FlowRunStore {\n readonly outputRoot: string;\n private readonly traceSeqByRun = new Map<string, number>();\n private readonly sessionSeqByBundle = new Map<string, number>();\n private readonly manifestByRun = new Map<string, FlowRunManifest>();\n private readonly appendChainByPath = new Map<string, Promise<void>>();\n\n constructor(outputRoot: string = flowRunsBaseDir()) {\n this.outputRoot = outputRoot;\n }\n\n async createRunDir(runId: string): Promise<string> {\n const runDir = path.join(this.outputRoot, runId);\n await fs.mkdir(path.join(runDir, PROJECTIONS_DIR), { recursive: true });\n await fs.mkdir(path.join(runDir, SESSIONS_DIR), { recursive: true });\n await fs.mkdir(path.join(runDir, ARTIFACTS_DIR), { recursive: true });\n this.traceSeqByRun.set(runDir, 0);\n return runDir;\n }\n\n async initializeRunBundle(\n runDir: string,\n options: {\n flow: FlowDefinition;\n state: FlowRunState;\n inputArtifact?: FlowArtifactRef;\n },\n ): Promise<void> {\n const snapshot = createFlowDefinitionSnapshot(options.flow);\n const manifest: FlowRunManifest = {\n schema: FLOW_BUNDLE_SCHEMA,\n runId: options.state.runId,\n flowName: options.state.flowName,\n runTitle: options.state.runTitle,\n flowPath: options.state.flowPath,\n startedAt: options.state.startedAt,\n finishedAt: options.state.finishedAt,\n status: options.state.status,\n traceSchema: FLOW_TRACE_SCHEMA,\n paths: {\n flow: FLOW_SNAPSHOT_PATH,\n trace: TRACE_PATH,\n runProjection: RUN_PROJECTION_PATH,\n liveProjection: LIVE_PROJECTION_PATH,\n stepsProjection: STEPS_PROJECTION_PATH,\n sessionsDir: SESSIONS_DIR,\n artifactsDir: ARTIFACTS_DIR,\n },\n sessions: [],\n };\n\n this.manifestByRun.set(runDir, manifest);\n await writeJsonAtomic(this.resolveRunPath(runDir, FLOW_SNAPSHOT_PATH), snapshot);\n await writeJsonAtomic(this.resolveRunPath(runDir, MANIFEST_PATH), manifest);\n await writeJsonAtomic(this.resolveRunPath(runDir, RUN_PROJECTION_PATH), options.state);\n await writeJsonAtomic(\n this.resolveRunPath(runDir, LIVE_PROJECTION_PATH),\n createLiveState(options.state),\n );\n await writeJsonAtomic(this.resolveRunPath(runDir, STEPS_PROJECTION_PATH), options.state.steps);\n await ensureFile(this.resolveRunPath(runDir, TRACE_PATH));\n\n await this.appendTrace(runDir, options.state, {\n scope: \"run\",\n type: \"run_started\",\n payload: {\n flowName: options.state.flowName,\n ...(options.state.runTitle ? { runTitle: options.state.runTitle } : {}),\n ...(options.state.flowPath ? { flowPath: options.state.flowPath } : {}),\n ...(options.inputArtifact ? { inputArtifact: options.inputArtifact } : {}),\n },\n });\n }\n\n async writeSnapshot(\n runDir: string,\n state: FlowRunState,\n event: FlowTraceEventDraft,\n ): Promise<void> {\n state.updatedAt = isoNow();\n await writeJsonAtomic(this.resolveRunPath(runDir, RUN_PROJECTION_PATH), state);\n await writeJsonAtomic(\n this.resolveRunPath(runDir, LIVE_PROJECTION_PATH),\n createLiveState(state),\n );\n await writeJsonAtomic(this.resolveRunPath(runDir, STEPS_PROJECTION_PATH), state.steps);\n await this.writeManifest(runDir, state);\n await this.appendTrace(runDir, state, event);\n }\n\n async writeLive(runDir: string, state: FlowRunState, event: FlowTraceEventDraft): Promise<void> {\n state.updatedAt = isoNow();\n await writeJsonAtomic(\n this.resolveRunPath(runDir, LIVE_PROJECTION_PATH),\n createLiveState(state),\n );\n await this.writeManifest(runDir, state);\n await this.appendTrace(runDir, state, event);\n }\n\n async appendTrace(\n runDir: string,\n state: FlowRunState,\n event: FlowTraceEventDraft,\n ): Promise<FlowTraceEvent> {\n const traceEvent: FlowTraceEvent = {\n seq: this.nextTraceSeq(runDir),\n at: isoNow(),\n runId: state.runId,\n ...event,\n };\n await this.appendJsonLine(this.resolveRunPath(runDir, TRACE_PATH), traceEvent);\n return traceEvent;\n }\n\n async writeArtifact(\n runDir: string,\n state: FlowRunState,\n content: unknown,\n options: WriteArtifactOptions,\n ): Promise<FlowArtifactRef> {\n const buffer = toArtifactBuffer(content, options.mediaType);\n const sha256 = createHash(\"sha256\").update(buffer).digest(\"hex\");\n const relativePath = path.posix.join(\n ARTIFACTS_DIR,\n `sha256-${sha256}${normalizeArtifactExtension(options.extension)}`,\n );\n const filePath = this.resolveRunPath(runDir, relativePath);\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n try {\n await fs.access(filePath);\n } catch {\n await fs.writeFile(filePath, buffer);\n }\n\n const artifact: FlowArtifactRef = {\n path: relativePath,\n mediaType: options.mediaType,\n bytes: buffer.byteLength,\n sha256,\n };\n if (options.emitTrace !== false) {\n await this.appendTrace(runDir, state, {\n scope: \"artifact\",\n type: \"artifact_written\",\n nodeId: options.nodeId,\n attemptId: options.attemptId,\n sessionId: options.sessionId,\n artifact,\n payload: {\n artifact,\n },\n });\n }\n return artifact;\n }\n\n async ensureSessionBundle(\n runDir: string,\n state: FlowRunState,\n binding: FlowSessionBinding,\n record?: SessionRecord,\n ): Promise<void> {\n const sessionDir = this.resolveRunPath(runDir, sessionDirPath(binding.bundleId));\n await fs.mkdir(sessionDir, { recursive: true });\n await writeJsonAtomic(path.join(sessionDir, \"binding.json\"), binding);\n await ensureFile(path.join(sessionDir, \"events.ndjson\"));\n if (record) {\n await this.writeSessionRecord(runDir, state, binding, record);\n }\n\n const manifest = this.getManifest(runDir, state);\n const existing = manifest.sessions.find((entry) => entry.id === binding.bundleId);\n const isNew = !existing;\n if (isNew) {\n const entry: FlowManifestSessionEntry = {\n id: binding.bundleId,\n handle: binding.handle,\n bindingPath: path.posix.join(sessionDirPath(binding.bundleId), \"binding.json\"),\n recordPath: path.posix.join(sessionDirPath(binding.bundleId), \"record.json\"),\n eventsPath: path.posix.join(sessionDirPath(binding.bundleId), \"events.ndjson\"),\n };\n manifest.sessions.push(entry);\n await writeJsonAtomic(this.resolveRunPath(runDir, MANIFEST_PATH), manifest);\n }\n\n if (isNew) {\n await this.appendTrace(runDir, state, {\n scope: \"session\",\n type: \"session_bound\",\n sessionId: binding.bundleId,\n payload: {\n sessionId: binding.bundleId,\n handle: binding.handle,\n bindingArtifact: {\n path: path.posix.join(sessionDirPath(binding.bundleId), \"binding.json\"),\n mediaType: \"application/json\",\n sha256: await fileSha256(path.join(sessionDir, \"binding.json\")),\n },\n },\n });\n }\n }\n\n async writeSessionRecord(\n runDir: string,\n _state: FlowRunState,\n binding: FlowSessionBinding,\n record: SessionRecord,\n ): Promise<void> {\n const bundleSeq = this.sessionSeqByBundle.get(`${runDir}::${binding.bundleId}`) ?? 0;\n const bundledRecord = createBundledSessionRecord(binding, record, bundleSeq);\n await writeJsonAtomic(\n this.resolveRunPath(runDir, path.posix.join(sessionDirPath(binding.bundleId), \"record.json\")),\n bundledRecord,\n );\n }\n\n async appendSessionEvent(\n runDir: string,\n binding: FlowSessionBinding,\n direction: AcpMessageDirection,\n message: AcpJsonRpcMessage,\n ): Promise<number> {\n const sessionKey = `${runDir}::${binding.bundleId}`;\n const seq = (this.sessionSeqByBundle.get(sessionKey) ?? 0) + 1;\n this.sessionSeqByBundle.set(sessionKey, seq);\n await this.appendJsonLine(\n this.resolveRunPath(\n runDir,\n path.posix.join(sessionDirPath(binding.bundleId), \"events.ndjson\"),\n ),\n {\n seq,\n at: isoNow(),\n direction,\n message,\n },\n );\n return seq;\n }\n\n private getManifest(runDir: string, state: FlowRunState): FlowRunManifest {\n const existing = this.manifestByRun.get(runDir);\n if (existing) {\n existing.startedAt = state.startedAt;\n existing.finishedAt = state.finishedAt;\n existing.status = state.status;\n existing.flowPath = state.flowPath;\n existing.flowName = state.flowName;\n existing.runTitle = state.runTitle;\n return existing;\n }\n\n const created: FlowRunManifest = {\n schema: FLOW_BUNDLE_SCHEMA,\n runId: state.runId,\n flowName: state.flowName,\n runTitle: state.runTitle,\n flowPath: state.flowPath,\n startedAt: state.startedAt,\n finishedAt: state.finishedAt,\n status: state.status,\n traceSchema: FLOW_TRACE_SCHEMA,\n paths: {\n flow: FLOW_SNAPSHOT_PATH,\n trace: TRACE_PATH,\n runProjection: RUN_PROJECTION_PATH,\n liveProjection: LIVE_PROJECTION_PATH,\n stepsProjection: STEPS_PROJECTION_PATH,\n sessionsDir: SESSIONS_DIR,\n artifactsDir: ARTIFACTS_DIR,\n },\n sessions: [],\n };\n this.manifestByRun.set(runDir, created);\n return created;\n }\n\n private async writeManifest(runDir: string, state: FlowRunState): Promise<void> {\n const manifest = this.getManifest(runDir, state);\n await writeJsonAtomic(this.resolveRunPath(runDir, MANIFEST_PATH), manifest);\n }\n\n private nextTraceSeq(runDir: string): number {\n const next = (this.traceSeqByRun.get(runDir) ?? 0) + 1;\n this.traceSeqByRun.set(runDir, next);\n return next;\n }\n\n private resolveRunPath(runDir: string, relativePath: string): string {\n return path.join(runDir, ...relativePath.split(\"/\"));\n }\n\n private async appendJsonLine(filePath: string, value: unknown): Promise<void> {\n const prior = this.appendChainByPath.get(filePath) ?? Promise.resolve();\n const nextWrite = prior.then(async () => {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.appendFile(filePath, `${JSON.stringify(value)}\\n`, \"utf8\");\n });\n const tracked = nextWrite.finally(() => {\n if (this.appendChainByPath.get(filePath) === tracked) {\n this.appendChainByPath.delete(filePath);\n }\n });\n this.appendChainByPath.set(filePath, tracked);\n await tracked;\n }\n}\n\nfunction createLiveState(state: FlowRunState): FlowLiveState {\n return {\n runId: state.runId,\n flowName: state.flowName,\n runTitle: state.runTitle,\n flowPath: state.flowPath,\n startedAt: state.startedAt,\n finishedAt: state.finishedAt,\n updatedAt: state.updatedAt,\n status: state.status,\n currentNode: state.currentNode,\n currentAttemptId: state.currentAttemptId,\n currentNodeType: state.currentNodeType,\n currentNodeStartedAt: state.currentNodeStartedAt,\n lastHeartbeatAt: state.lastHeartbeatAt,\n statusDetail: state.statusDetail,\n waitingOn: state.waitingOn,\n error: state.error,\n sessionBindings: state.sessionBindings,\n };\n}\n\nfunction createFlowDefinitionSnapshot(flow: FlowDefinition): FlowDefinitionSnapshot {\n return {\n schema: FLOW_SNAPSHOT_SCHEMA,\n name: flow.name,\n ...(flow.run?.title !== undefined ? { run: { hasTitle: true } } : {}),\n ...(flow.permissions ? { permissions: structuredClone(flow.permissions) } : {}),\n startAt: flow.startAt,\n nodes: Object.fromEntries(\n Object.entries(flow.nodes).map(([nodeId, node]) => [nodeId, snapshotNode(node)]),\n ),\n edges: structuredClone(flow.edges),\n };\n}\n\nfunction snapshotNode(node: FlowNodeDefinition): FlowDefinitionSnapshot[\"nodes\"][string] {\n const common = {\n nodeType: node.nodeType,\n ...(node.timeoutMs !== undefined ? { timeoutMs: node.timeoutMs } : {}),\n ...(node.heartbeatMs !== undefined ? { heartbeatMs: node.heartbeatMs } : {}),\n ...(node.statusDetail ? { statusDetail: node.statusDetail } : {}),\n };\n\n switch (node.nodeType) {\n case \"acp\":\n return {\n ...common,\n ...(node.profile ? { profile: node.profile } : {}),\n session: {\n ...(node.session?.handle ? { handle: node.session.handle } : {}),\n ...(node.session?.isolated ? { isolated: true } : {}),\n },\n cwd: snapshotCwd(node.cwd),\n hasPrompt: true,\n hasParse: typeof node.parse === \"function\",\n };\n case \"compute\":\n return {\n ...common,\n hasRun: true,\n };\n case \"action\": {\n const actionExecution: \"shell\" | \"function\" = \"exec\" in node ? \"shell\" : \"function\";\n return {\n ...common,\n actionExecution,\n hasRun: \"run\" in node,\n hasExec: \"exec\" in node,\n hasParse: \"parse\" in node && typeof node.parse === \"function\",\n };\n }\n case \"checkpoint\":\n return {\n ...common,\n ...(node.summary ? { summary: node.summary } : {}),\n hasRun: typeof node.run === \"function\",\n };\n }\n\n throw new Error(`Unsupported flow node type: ${String(node satisfies never)}`);\n}\n\nfunction snapshotCwd(cwd: AcpNodeDefinition[\"cwd\"]): {\n mode: \"default\" | \"static\" | \"dynamic\";\n value?: string;\n} {\n if (typeof cwd === \"function\") {\n return { mode: \"dynamic\" };\n }\n if (typeof cwd === \"string\") {\n return { mode: \"static\", value: cwd };\n }\n return { mode: \"default\" };\n}\n\nfunction createBundledSessionRecord(\n binding: FlowSessionBinding,\n record: SessionRecord,\n bundleLastSeq: number,\n): SessionRecord {\n return {\n ...structuredClone(record),\n lastSeq: bundleLastSeq,\n eventLog: {\n ...structuredClone(record.eventLog),\n active_path: path.posix.join(sessionDirPath(binding.bundleId), \"events.ndjson\"),\n segment_count: 1,\n max_segments: 1,\n },\n };\n}\n\nasync function writeJsonAtomic(filePath: string, value: unknown): Promise<void> {\n const tempPath = `${filePath}.${process.pid}.${Date.now()}.${randomUUID()}.tmp`;\n const payload = JSON.stringify(value, null, 2);\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.writeFile(tempPath, `${payload}\\n`, \"utf8\");\n await fs.rename(tempPath, filePath);\n}\n\nasync function ensureFile(filePath: string): Promise<void> {\n await fs.mkdir(path.dirname(filePath), { recursive: true });\n await fs.appendFile(filePath, \"\", \"utf8\");\n}\n\nasync function fileSha256(filePath: string): Promise<string> {\n const payload = await fs.readFile(filePath);\n return createHash(\"sha256\").update(payload).digest(\"hex\");\n}\n\nfunction toArtifactBuffer(content: unknown, mediaType: string): Buffer {\n if (typeof content === \"string\") {\n return Buffer.from(content, \"utf8\");\n }\n if (Buffer.isBuffer(content)) {\n return content;\n }\n if (content instanceof Uint8Array) {\n return Buffer.from(content);\n }\n if (mediaType === \"application/json\") {\n return Buffer.from(`${JSON.stringify(content, null, 2)}\\n`, \"utf8\");\n }\n return Buffer.from(String(content), \"utf8\");\n}\n\nfunction normalizeArtifactExtension(extension: string): string {\n if (!extension) {\n return \"\";\n }\n return extension.startsWith(\".\") ? extension : `.${extension}`;\n}\n\nfunction sessionDirPath(bundleId: string): string {\n return path.posix.join(SESSIONS_DIR, bundleId);\n}\n\nfunction isoNow(): string {\n return new Date().toISOString();\n}\n","import { randomUUID } from \"node:crypto\";\nimport type { AcpClient } from \"../acp/client.js\";\nimport { InterruptedError, TimeoutError, withInterrupt, withTimeout } from \"../async-control.js\";\nimport { promptToDisplayText } from \"../prompt-content.js\";\nimport {\n cloneSessionAcpxState,\n createSessionConversation,\n recordClientOperation as recordConversationClientOperation,\n recordPromptSubmission,\n recordSessionUpdate as recordConversationSessionUpdate,\n} from \"../session/conversation-model.js\";\nimport { resolveSessionRecord } from \"../session/persistence.js\";\nimport {\n cancelSessionPrompt,\n createSessionWithClient,\n runOnce,\n sendSessionDirect,\n} from \"../session/session.js\";\nimport type { PromptInput, SessionRecord } from \"../types.js\";\nimport { acp, action, checkpoint, compute, defineFlow, shell } from \"./definition.js\";\nimport { formatShellActionSummary, runShellAction } from \"./executors/shell.js\";\nimport { resolveNext, resolveNextForOutcome, validateFlowDefinition } from \"./graph.js\";\nimport {\n attachStepTrace,\n clearActiveNode,\n createIsolatedSessionBinding,\n createNodeOutcomePayload,\n createNodeResult,\n createQuietCaptureOutput,\n createRunId,\n createSessionBindingKey,\n createSessionBundleId,\n createSessionName,\n createSyntheticSessionRecord,\n extractAttachedStepTrace,\n finalizeStepTrace,\n findConversationDeltaStart,\n isoNow,\n makeFlowNodeContext,\n markNodeStarted,\n nextAttemptId,\n normalizePromptInput,\n outcomeForError,\n persistRunFailure,\n resolveFlowRunTitle,\n resolveNodeCwd,\n resolveShellActionCwd,\n summarizePrompt,\n updateStatusDetail,\n} from \"./runtime-support.js\";\nimport { FlowRunStore } from \"./store.js\";\nimport type {\n AcpNodeDefinition,\n ActionNodeDefinition,\n CheckpointNodeDefinition,\n ComputeNodeDefinition,\n FlowDefinition,\n FlowNodeCommon,\n FlowNodeContext,\n FlowNodeDefinition,\n FlowStepTrace,\n FlowPermissionRequirements,\n FlowRunResult,\n FlowRunState,\n FlowRunnerOptions,\n FlowSessionBinding,\n FlowEdge,\n FlowStepRecord,\n FlowNodeOutcome,\n FlowNodeResult,\n FunctionActionNodeDefinition,\n ResolvedFlowAgent,\n ShellActionExecution,\n ShellActionNodeDefinition,\n ShellActionResult,\n} from \"./types.js\";\n\nexport { acp, action, checkpoint, compute, defineFlow, shell };\nexport type {\n AcpNodeDefinition,\n ActionNodeDefinition,\n CheckpointNodeDefinition,\n ComputeNodeDefinition,\n FlowDefinition,\n FlowEdge,\n FlowNodeCommon,\n FlowNodeContext,\n FlowNodeDefinition,\n FlowPermissionRequirements,\n FlowNodeOutcome,\n FlowNodeResult,\n FlowRunResult,\n FlowRunState,\n FlowRunnerOptions,\n FlowSessionBinding,\n FlowStepRecord,\n FunctionActionNodeDefinition,\n ResolvedFlowAgent,\n ShellActionExecution,\n ShellActionNodeDefinition,\n ShellActionResult,\n} from \"./types.js\";\n\nconst DEFAULT_FLOW_HEARTBEAT_MS = 5_000;\nconst DEFAULT_FLOW_STEP_TIMEOUT_MS = 15 * 60_000;\n\ntype FlowNodeExecutionResult = {\n output: unknown;\n promptText: string | null;\n rawText: string | null;\n sessionInfo: FlowSessionBinding | null;\n agentInfo: ResolvedFlowAgent | null;\n trace: FlowStepTrace | null;\n};\n\ntype TracedPromptResult = {\n rawText: string;\n sessionInfo: FlowSessionBinding;\n conversation: {\n sessionId: string;\n messageStart: number;\n messageEnd: number;\n eventStartSeq: number;\n eventEndSeq: number;\n };\n};\n\nexport class FlowRunner {\n private readonly resolveAgent;\n private readonly defaultCwd;\n private readonly permissionMode;\n private readonly mcpServers?;\n private readonly nonInteractivePermissions?;\n private readonly authCredentials?;\n private readonly authPolicy?;\n private readonly timeoutMs?;\n private readonly defaultNodeTimeoutMs;\n private readonly verbose?;\n private readonly suppressSdkConsoleErrors?;\n private readonly sessionOptions?;\n private readonly services;\n private readonly store;\n private readonly pendingPersistentSessionClients = new Map<string, AcpClient>();\n\n constructor(options: FlowRunnerOptions) {\n this.resolveAgent = options.resolveAgent;\n this.defaultCwd = options.resolveAgent(undefined).cwd;\n this.permissionMode = options.permissionMode;\n this.mcpServers = options.mcpServers;\n this.nonInteractivePermissions = options.nonInteractivePermissions;\n this.authCredentials = options.authCredentials;\n this.authPolicy = options.authPolicy;\n this.timeoutMs = options.timeoutMs;\n this.defaultNodeTimeoutMs =\n options.defaultNodeTimeoutMs ?? options.timeoutMs ?? DEFAULT_FLOW_STEP_TIMEOUT_MS;\n this.verbose = options.verbose;\n this.suppressSdkConsoleErrors = options.suppressSdkConsoleErrors;\n this.sessionOptions = options.sessionOptions;\n this.services = options.services ?? {};\n this.store = new FlowRunStore(options.outputRoot);\n }\n\n async run(\n flow: FlowDefinition,\n input: unknown,\n options: { flowPath?: string } = {},\n ): Promise<FlowRunResult> {\n validateFlowDefinition(flow);\n\n const runId = createRunId(flow.name);\n const runTitle = await resolveFlowRunTitle(flow, input, options.flowPath);\n const runDir = await this.store.createRunDir(runId);\n const state: FlowRunState = {\n runId,\n flowName: flow.name,\n runTitle,\n flowPath: options.flowPath,\n startedAt: isoNow(),\n updatedAt: isoNow(),\n status: \"running\",\n input,\n outputs: {},\n results: {},\n steps: [],\n sessionBindings: {},\n };\n const inputArtifact = await this.store.writeArtifact(runDir, state, input, {\n mediaType: \"application/json\",\n extension: \"json\",\n emitTrace: false,\n });\n await this.store.initializeRunBundle(runDir, {\n flow,\n state,\n inputArtifact,\n });\n\n let current: string | null = flow.startAt;\n const attemptCounts = new Map<string, number>();\n\n try {\n return await withInterrupt(\n async () => {\n try {\n while (current) {\n const node = flow.nodes[current];\n if (!node) {\n throw new Error(`Unknown flow node: ${current}`);\n }\n\n const attemptId = nextAttemptId(attemptCounts, current);\n const startedAt = isoNow();\n const context = makeFlowNodeContext(state, input, this.services);\n let output: unknown;\n let promptText: string | null = null;\n let rawText: string | null = null;\n let sessionInfo: FlowSessionBinding | null = null;\n let agentInfo: ResolvedFlowAgent | null = null;\n let trace: FlowStepTrace | null = null;\n markNodeStarted(\n state,\n current,\n attemptId,\n node.nodeType,\n startedAt,\n node.statusDetail,\n );\n await this.store.writeSnapshot(runDir, state, {\n scope: \"node\",\n type: \"node_started\",\n nodeId: current,\n attemptId,\n payload: {\n nodeType: node.nodeType,\n ...(node.timeoutMs !== undefined\n ? { timeoutMs: node.timeoutMs ?? this.defaultNodeTimeoutMs }\n : { timeoutMs: this.defaultNodeTimeoutMs }),\n ...(state.statusDetail ? { statusDetail: state.statusDetail } : {}),\n },\n });\n let nodeResult: FlowNodeResult | undefined;\n let executionError: unknown;\n try {\n ({ output, promptText, rawText, sessionInfo, agentInfo, trace } =\n await this.executeNode(runDir, state, flow, current, node, context));\n trace = await finalizeStepTrace(\n this.store,\n runDir,\n state,\n current,\n attemptId,\n output,\n trace,\n );\n nodeResult = createNodeResult({\n attemptId,\n nodeId: current,\n nodeType: node.nodeType,\n outcome: \"ok\",\n startedAt,\n finishedAt: isoNow(),\n output,\n });\n } catch (error) {\n executionError = error;\n trace = extractAttachedStepTrace(error) ?? trace;\n trace = await finalizeStepTrace(\n this.store,\n runDir,\n state,\n current,\n attemptId,\n undefined,\n trace,\n );\n nodeResult = createNodeResult({\n attemptId,\n nodeId: current,\n nodeType: node.nodeType,\n outcome: outcomeForError(error),\n startedAt,\n finishedAt: isoNow(),\n error: error instanceof Error ? error.message : String(error),\n });\n }\n\n state.results[current] = nodeResult;\n\n if (nodeResult.outcome === \"ok\" && node.nodeType === \"checkpoint\") {\n state.outputs[current] = output;\n state.waitingOn = current;\n state.updatedAt = isoNow();\n state.status = \"waiting\";\n clearActiveNode(state, (output as { summary?: string } | null)?.summary ?? current);\n state.steps.push({\n attemptId,\n nodeId: current,\n nodeType: node.nodeType,\n outcome: nodeResult.outcome,\n startedAt,\n finishedAt: nodeResult.finishedAt,\n promptText,\n rawText,\n output,\n session: null,\n agent: null,\n ...(trace ? { trace } : {}),\n });\n await this.store.writeSnapshot(runDir, state, {\n scope: \"node\",\n type: \"node_outcome\",\n nodeId: current,\n attemptId,\n payload: createNodeOutcomePayload(nodeResult, trace),\n });\n return {\n runDir,\n state,\n };\n }\n\n if (nodeResult.outcome === \"ok\") {\n state.outputs[current] = output;\n }\n state.updatedAt = isoNow();\n clearActiveNode(state);\n state.steps.push({\n attemptId,\n nodeId: current,\n nodeType: node.nodeType,\n outcome: nodeResult.outcome,\n startedAt,\n finishedAt: nodeResult.finishedAt,\n promptText,\n rawText,\n output,\n error: nodeResult.error,\n session: sessionInfo,\n agent: agentInfo,\n ...(trace ? { trace } : {}),\n });\n\n await this.store.writeSnapshot(runDir, state, {\n scope: \"node\",\n type: \"node_outcome\",\n nodeId: current,\n attemptId,\n payload: createNodeOutcomePayload(nodeResult, trace),\n });\n\n if (nodeResult.outcome === \"ok\") {\n current = resolveNext(flow.edges, current, output, nodeResult);\n continue;\n }\n\n const next = resolveNextForOutcome(flow.edges, current, nodeResult);\n if (next) {\n current = next;\n continue;\n }\n\n throw executionError;\n }\n\n state.status = \"completed\";\n state.finishedAt = isoNow();\n state.updatedAt = state.finishedAt;\n clearActiveNode(state);\n await this.store.writeSnapshot(runDir, state, {\n scope: \"run\",\n type: \"run_completed\",\n payload: {\n status: state.status,\n },\n });\n return {\n runDir,\n state,\n };\n } catch (error) {\n await persistRunFailure(this.store, runDir, state, error);\n throw error;\n }\n },\n async () => {\n await persistRunFailure(this.store, runDir, state, new InterruptedError());\n },\n );\n } finally {\n await this.closePendingPersistentSessionClients();\n }\n }\n\n private async executeNode(\n runDir: string,\n state: FlowRunState,\n flow: FlowDefinition,\n nodeId: string,\n node: FlowNodeDefinition,\n context: FlowNodeContext,\n ): Promise<FlowNodeExecutionResult> {\n switch (node.nodeType) {\n case \"compute\":\n return await this.executeComputeNode(runDir, state, node, context);\n case \"action\":\n return await this.executeActionNode(runDir, state, node, context);\n case \"checkpoint\":\n return await this.executeCheckpointNode(runDir, state, nodeId, node, context);\n case \"acp\":\n return await this.executeAcpNode(runDir, state, flow, node, context);\n default: {\n const exhaustive: never = node;\n throw new Error(`Unsupported flow node: ${String(exhaustive)}`);\n }\n }\n }\n\n private async executeComputeNode(\n runDir: string,\n state: FlowRunState,\n node: ComputeNodeDefinition,\n context: FlowNodeContext,\n ): Promise<FlowNodeExecutionResult> {\n const nodeTimeoutMs = node.timeoutMs ?? this.defaultNodeTimeoutMs;\n const output = await this.runWithHeartbeat(\n runDir,\n state,\n state.currentNode ?? \"\",\n node,\n nodeTimeoutMs,\n async () => await Promise.resolve(node.run(context)),\n );\n return {\n output,\n promptText: null,\n rawText: null,\n sessionInfo: null,\n agentInfo: null,\n trace: null,\n };\n }\n\n private async executeActionNode(\n runDir: string,\n state: FlowRunState,\n node: ActionNodeDefinition,\n context: FlowNodeContext,\n ): Promise<FlowNodeExecutionResult> {\n const nodeTimeoutMs = node.timeoutMs ?? this.defaultNodeTimeoutMs;\n if (\"run\" in node) {\n const output = await this.runWithHeartbeat(\n runDir,\n state,\n state.currentNode ?? \"\",\n node,\n nodeTimeoutMs,\n async () => await Promise.resolve(node.run(context)),\n );\n return {\n output,\n promptText: null,\n rawText: null,\n sessionInfo: null,\n agentInfo: null,\n trace: {\n action: {\n actionType: \"function\",\n },\n },\n };\n }\n\n const { output, rawText, trace } = await this.runWithHeartbeat(\n runDir,\n state,\n state.currentNode ?? \"\",\n node,\n nodeTimeoutMs,\n async () => {\n const execution = await Promise.resolve(node.exec(context));\n const effectiveExecution: ShellActionExecution = {\n ...execution,\n cwd: resolveShellActionCwd(this.defaultCwd, execution.cwd),\n timeoutMs: execution.timeoutMs ?? nodeTimeoutMs,\n };\n updateStatusDetail(state, formatShellActionSummary(effectiveExecution));\n await this.store.writeLive(runDir, state, {\n scope: \"node\",\n type: \"node_heartbeat\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n payload: {\n statusDetail: state.statusDetail,\n },\n });\n await this.store.appendTrace(runDir, state, {\n scope: \"action\",\n type: \"action_prepared\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n payload: {\n action: {\n actionType: \"shell\",\n command: effectiveExecution.command,\n args: effectiveExecution.args ?? [],\n cwd: effectiveExecution.cwd,\n },\n },\n });\n const result = await runShellAction(effectiveExecution);\n const stdoutArtifact = await this.store.writeArtifact(runDir, state, result.stdout, {\n mediaType: \"text/plain\",\n extension: \"txt\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n });\n const stderrArtifact = await this.store.writeArtifact(runDir, state, result.stderr, {\n mediaType: \"text/plain\",\n extension: \"txt\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n });\n await this.store.appendTrace(runDir, state, {\n scope: \"action\",\n type: \"action_completed\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n payload: {\n action: {\n actionType: \"shell\",\n command: result.command,\n args: result.args,\n cwd: result.cwd,\n exitCode: result.exitCode,\n signal: result.signal,\n durationMs: result.durationMs,\n },\n stdoutArtifact,\n stderrArtifact,\n },\n });\n const trace: FlowStepTrace = {\n action: {\n actionType: \"shell\",\n command: result.command,\n args: result.args,\n cwd: result.cwd,\n exitCode: result.exitCode,\n signal: result.signal,\n durationMs: result.durationMs,\n },\n stdoutArtifact,\n stderrArtifact,\n };\n let parsedOutput: unknown;\n try {\n parsedOutput = node.parse ? await node.parse(result, context) : result;\n } catch (error) {\n throw attachStepTrace(error, trace);\n }\n return {\n output: parsedOutput,\n rawText: result.combinedOutput,\n trace,\n };\n },\n );\n return {\n output,\n promptText: null,\n rawText,\n sessionInfo: null,\n agentInfo: null,\n trace,\n };\n }\n\n private async executeCheckpointNode(\n runDir: string,\n state: FlowRunState,\n nodeId: string,\n node: CheckpointNodeDefinition,\n context: FlowNodeContext,\n ): Promise<FlowNodeExecutionResult> {\n const nodeTimeoutMs = node.timeoutMs ?? this.defaultNodeTimeoutMs;\n const output =\n typeof node.run === \"function\"\n ? await this.runWithHeartbeat(\n runDir,\n state,\n state.currentNode ?? \"\",\n node,\n nodeTimeoutMs,\n async () => await Promise.resolve(node.run?.(context)),\n )\n : {\n checkpoint: nodeId,\n summary: node.summary ?? nodeId,\n };\n return {\n output,\n promptText: null,\n rawText: null,\n sessionInfo: null,\n agentInfo: null,\n trace: null,\n };\n }\n\n private async executeAcpNode(\n runDir: string,\n state: FlowRunState,\n flow: FlowDefinition,\n node: AcpNodeDefinition,\n context: FlowNodeContext,\n ): Promise<FlowNodeExecutionResult> {\n const nodeTimeoutMs = node.timeoutMs ?? this.defaultNodeTimeoutMs;\n let boundSession: FlowSessionBinding | null = null;\n return await this.runWithHeartbeat(\n runDir,\n state,\n state.currentNode ?? \"\",\n node,\n nodeTimeoutMs,\n async () => {\n const resolvedAgent = this.resolveAgent(node.profile);\n const agentInfo = {\n ...resolvedAgent,\n cwd: await resolveNodeCwd(resolvedAgent.cwd, node.cwd, context),\n };\n const prompt = normalizePromptInput(await Promise.resolve(node.prompt(context)));\n const promptText = promptToDisplayText(prompt);\n updateStatusDetail(state, summarizePrompt(promptText, node.statusDetail));\n await this.store.writeLive(runDir, state, {\n scope: \"node\",\n type: \"node_heartbeat\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n payload: {\n statusDetail: state.statusDetail,\n },\n });\n const promptArtifact = await this.store.writeArtifact(runDir, state, promptText, {\n mediaType: \"text/plain\",\n extension: \"txt\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n });\n\n if (node.session?.isolated) {\n const isolatedBinding = createIsolatedSessionBinding(\n flow.name,\n state.runId,\n state.currentAttemptId ?? randomUUID(),\n node.profile,\n agentInfo,\n );\n const initialIsolatedRecord = createSyntheticSessionRecord({\n binding: isolatedBinding,\n createdAt: state.currentNodeStartedAt ?? isoNow(),\n updatedAt: state.currentNodeStartedAt ?? isoNow(),\n conversation: createSessionConversation(state.currentNodeStartedAt ?? isoNow()),\n acpxState: undefined,\n lastSeq: 0,\n });\n await this.store.ensureSessionBundle(\n runDir,\n state,\n isolatedBinding,\n initialIsolatedRecord,\n );\n await this.store.appendTrace(runDir, state, {\n scope: \"acp\",\n type: \"acp_prompt_prepared\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n sessionId: isolatedBinding.bundleId,\n payload: {\n sessionId: isolatedBinding.bundleId,\n promptArtifact,\n },\n });\n const isolatedPrompt = await this.runIsolatedPrompt(\n runDir,\n state,\n isolatedBinding,\n agentInfo,\n prompt,\n nodeTimeoutMs,\n );\n const rawResponseArtifact = await this.store.writeArtifact(\n runDir,\n state,\n isolatedPrompt.rawText,\n {\n mediaType: \"text/plain\",\n extension: \"txt\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n sessionId: isolatedBinding.bundleId,\n },\n );\n await this.store.appendTrace(runDir, state, {\n scope: \"acp\",\n type: \"acp_response_parsed\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n sessionId: isolatedBinding.bundleId,\n payload: {\n sessionId: isolatedBinding.bundleId,\n conversation: isolatedPrompt.conversation,\n rawResponseArtifact,\n },\n });\n const trace: FlowStepTrace = {\n sessionId: isolatedBinding.bundleId,\n promptArtifact,\n rawResponseArtifact,\n conversation: isolatedPrompt.conversation,\n };\n let parsedOutput: unknown;\n try {\n parsedOutput = node.parse\n ? await node.parse(isolatedPrompt.rawText, context)\n : isolatedPrompt.rawText;\n } catch (error) {\n throw attachStepTrace(error, trace);\n }\n return {\n output: parsedOutput,\n promptText,\n rawText: isolatedPrompt.rawText,\n sessionInfo: isolatedBinding,\n agentInfo,\n trace,\n };\n }\n\n boundSession = await this.ensureSessionBinding(\n runDir,\n state,\n flow,\n node,\n agentInfo,\n nodeTimeoutMs,\n );\n await this.store.appendTrace(runDir, state, {\n scope: \"acp\",\n type: \"acp_prompt_prepared\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n sessionId: boundSession.bundleId,\n payload: {\n sessionId: boundSession.bundleId,\n promptArtifact,\n },\n });\n const persistentPrompt = await this.runPersistentPrompt(\n runDir,\n state,\n boundSession,\n prompt,\n nodeTimeoutMs,\n );\n const rawResponseArtifact = await this.store.writeArtifact(\n runDir,\n state,\n persistentPrompt.rawText,\n {\n mediaType: \"text/plain\",\n extension: \"txt\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n sessionId: persistentPrompt.sessionInfo.bundleId,\n },\n );\n await this.store.appendTrace(runDir, state, {\n scope: \"acp\",\n type: \"acp_response_parsed\",\n nodeId: state.currentNode,\n attemptId: state.currentAttemptId,\n sessionId: persistentPrompt.sessionInfo.bundleId,\n payload: {\n sessionId: persistentPrompt.sessionInfo.bundleId,\n conversation: persistentPrompt.conversation,\n rawResponseArtifact,\n },\n });\n const trace: FlowStepTrace = {\n sessionId: persistentPrompt.sessionInfo.bundleId,\n promptArtifact,\n rawResponseArtifact,\n conversation: persistentPrompt.conversation,\n };\n let parsedOutput: unknown;\n try {\n parsedOutput = node.parse\n ? await node.parse(persistentPrompt.rawText, context)\n : persistentPrompt.rawText;\n } catch (error) {\n throw attachStepTrace(error, trace);\n }\n return {\n output: parsedOutput,\n promptText,\n rawText: persistentPrompt.rawText,\n sessionInfo: persistentPrompt.sessionInfo,\n agentInfo,\n trace,\n };\n },\n async () => {\n if (!boundSession) {\n return;\n }\n await cancelSessionPrompt({\n sessionId: boundSession.acpxRecordId,\n });\n },\n );\n }\n\n private async runWithHeartbeat<T>(\n runDir: string,\n state: FlowRunState,\n nodeId: string,\n node: FlowNodeCommon,\n timeoutMs: number | undefined,\n run: () => Promise<T>,\n onTimeout?: () => Promise<void>,\n ): Promise<T> {\n const heartbeatMs = Math.max(0, Math.round(node.heartbeatMs ?? DEFAULT_FLOW_HEARTBEAT_MS));\n let timer: NodeJS.Timeout | undefined;\n let active = true;\n const heartbeat = async (): Promise<void> => {\n if (!active) {\n return;\n }\n state.lastHeartbeatAt = isoNow();\n state.updatedAt = state.lastHeartbeatAt;\n await this.store.writeLive(runDir, state, {\n scope: \"node\",\n type: \"node_heartbeat\",\n nodeId,\n attemptId: state.currentAttemptId,\n payload: {\n statusDetail: state.statusDetail,\n },\n });\n };\n\n if (heartbeatMs > 0) {\n timer = setInterval(() => {\n void heartbeat();\n }, heartbeatMs);\n }\n\n try {\n return await withTimeout(run(), timeoutMs);\n } catch (error) {\n if (error instanceof TimeoutError && onTimeout) {\n await onTimeout().catch(() => {\n // best effort cancellation only\n });\n }\n throw error;\n } finally {\n active = false;\n if (timer) {\n clearInterval(timer);\n }\n }\n }\n\n private async ensureSessionBinding(\n runDir: string,\n state: FlowRunState,\n flow: FlowDefinition,\n node: AcpNodeDefinition,\n agent: ResolvedFlowAgent,\n timeoutMs: number | undefined,\n ): Promise<FlowSessionBinding> {\n const handle = node.session?.handle ?? \"main\";\n const key = createSessionBindingKey(agent.agentCommand, agent.cwd, handle);\n const existing = state.sessionBindings[key];\n if (existing) {\n await this.store.ensureSessionBundle(runDir, state, existing);\n return existing;\n }\n\n const name = createSessionName(flow.name, handle, agent.cwd, state.runId);\n const created = await createSessionWithClient({\n agentCommand: agent.agentCommand,\n cwd: agent.cwd,\n name,\n mcpServers: this.mcpServers,\n permissionMode: this.permissionMode,\n nonInteractivePermissions: this.nonInteractivePermissions,\n authCredentials: this.authCredentials,\n authPolicy: this.authPolicy,\n timeoutMs,\n verbose: this.verbose,\n sessionOptions: this.sessionOptions,\n });\n\n const binding: FlowSessionBinding = {\n key,\n handle,\n bundleId: createSessionBundleId(handle, key),\n name,\n profile: node.profile,\n agentName: agent.agentName,\n agentCommand: agent.agentCommand,\n cwd: agent.cwd,\n acpxRecordId: created.record.acpxRecordId,\n acpSessionId: created.record.acpSessionId,\n agentSessionId: created.record.agentSessionId,\n };\n state.sessionBindings[key] = binding;\n this.pendingPersistentSessionClients.set(binding.key, created.client);\n await this.store.ensureSessionBundle(runDir, state, binding, created.record);\n return binding;\n }\n\n private async refreshSessionBinding(binding: FlowSessionBinding): Promise<FlowSessionBinding> {\n const record = await resolveSessionRecord(binding.acpxRecordId);\n return {\n ...binding,\n acpSessionId: record.acpSessionId,\n agentSessionId: record.agentSessionId,\n };\n }\n\n private async runPersistentPrompt(\n runDir: string,\n state: FlowRunState,\n binding: FlowSessionBinding,\n prompt: PromptInput,\n timeoutMs?: number,\n ): Promise<TracedPromptResult> {\n const capture = createQuietCaptureOutput();\n const beforeRecord = await resolveSessionRecord(binding.acpxRecordId);\n let eventStartSeq: number | undefined;\n let eventEndSeq: number | undefined;\n const pendingEventWrites: Promise<void>[] = [];\n const initialClient = this.pendingPersistentSessionClients.get(binding.key);\n if (initialClient) {\n this.pendingPersistentSessionClients.delete(binding.key);\n }\n\n try {\n await sendSessionDirect({\n sessionId: binding.acpxRecordId,\n prompt,\n resumePolicy: \"same-session-only\",\n mcpServers: this.mcpServers,\n permissionMode: this.permissionMode,\n nonInteractivePermissions: this.nonInteractivePermissions,\n authCredentials: this.authCredentials,\n authPolicy: this.authPolicy,\n outputFormatter: capture.formatter,\n onAcpMessage: (direction, message) => {\n const pending = this.store\n .appendSessionEvent(runDir, binding, direction, message)\n .then((seq) => {\n eventStartSeq = eventStartSeq === undefined ? seq : Math.min(eventStartSeq, seq);\n eventEndSeq = eventEndSeq === undefined ? seq : Math.max(eventEndSeq, seq);\n });\n pendingEventWrites.push(pending);\n },\n suppressSdkConsoleErrors: this.suppressSdkConsoleErrors,\n timeoutMs,\n verbose: this.verbose,\n client: initialClient,\n });\n await Promise.all(pendingEventWrites);\n const sessionInfo = await this.refreshSessionBinding(binding);\n state.sessionBindings[sessionInfo.key] = sessionInfo;\n await this.store.ensureSessionBundle(runDir, state, sessionInfo);\n const afterRecord = await resolveSessionRecord(sessionInfo.acpxRecordId);\n await this.store.writeSessionRecord(runDir, state, sessionInfo, afterRecord);\n const messageStartResolved = findConversationDeltaStart(\n beforeRecord.messages,\n afterRecord.messages,\n );\n\n return {\n rawText: capture.read(),\n sessionInfo,\n conversation: {\n sessionId: sessionInfo.bundleId,\n messageStart: messageStartResolved,\n messageEnd: Math.max(messageStartResolved, afterRecord.messages.length - 1),\n eventStartSeq:\n eventStartSeq ??\n (() => {\n throw new Error(`Missing ACP event capture for session ${sessionInfo.bundleId}`);\n })(),\n eventEndSeq:\n eventEndSeq ??\n (() => {\n throw new Error(`Missing ACP event capture for session ${sessionInfo.bundleId}`);\n })(),\n },\n };\n } finally {\n if (initialClient) {\n await initialClient.close().catch(() => {\n // best effort cleanup; persisted session state already exists\n });\n }\n }\n }\n\n private async closePendingPersistentSessionClients(): Promise<void> {\n const pendingClients = [...this.pendingPersistentSessionClients.values()];\n this.pendingPersistentSessionClients.clear();\n await Promise.all(\n pendingClients.map(async (client) => {\n await client.close().catch(() => {\n // best effort on flow shutdown\n });\n }),\n );\n }\n\n private async runIsolatedPrompt(\n runDir: string,\n state: FlowRunState,\n binding: FlowSessionBinding,\n agent: ResolvedFlowAgent,\n prompt: PromptInput,\n timeoutMs?: number,\n ): Promise<TracedPromptResult> {\n const capture = createQuietCaptureOutput();\n const conversation = createSessionConversation(state.currentNodeStartedAt ?? isoNow());\n let acpxState: SessionRecord[\"acpx\"] | undefined;\n recordPromptSubmission(conversation, prompt, state.currentNodeStartedAt ?? isoNow());\n let eventStartSeq: number | undefined;\n let eventEndSeq: number | undefined;\n const pendingEventWrites: Promise<void>[] = [];\n const result = await runOnce({\n agentCommand: agent.agentCommand,\n cwd: agent.cwd,\n prompt,\n mcpServers: this.mcpServers,\n permissionMode: this.permissionMode,\n nonInteractivePermissions: this.nonInteractivePermissions,\n authCredentials: this.authCredentials,\n authPolicy: this.authPolicy,\n outputFormatter: capture.formatter,\n onAcpMessage: (direction, message) => {\n const pending = this.store\n .appendSessionEvent(runDir, binding, direction, message)\n .then((seq) => {\n eventStartSeq = eventStartSeq === undefined ? seq : Math.min(eventStartSeq, seq);\n eventEndSeq = eventEndSeq === undefined ? seq : Math.max(eventEndSeq, seq);\n });\n pendingEventWrites.push(pending);\n },\n onSessionUpdate: (notification) => {\n acpxState = recordConversationSessionUpdate(conversation, acpxState, notification);\n },\n onClientOperation: (operation) => {\n acpxState = recordConversationClientOperation(conversation, acpxState, operation);\n },\n suppressSdkConsoleErrors: this.suppressSdkConsoleErrors,\n timeoutMs,\n verbose: this.verbose,\n sessionOptions: this.sessionOptions,\n });\n await Promise.all(pendingEventWrites);\n const sessionInfo: FlowSessionBinding = {\n ...binding,\n acpxRecordId: result.sessionId,\n acpSessionId: result.sessionId,\n };\n await this.store.ensureSessionBundle(runDir, state, sessionInfo);\n const syntheticRecord = createSyntheticSessionRecord({\n binding: sessionInfo,\n createdAt: state.currentNodeStartedAt ?? isoNow(),\n updatedAt: conversation.updated_at,\n conversation,\n acpxState: cloneSessionAcpxState(acpxState),\n lastSeq: eventEndSeq ?? 0,\n });\n await this.store.writeSessionRecord(runDir, state, sessionInfo, syntheticRecord);\n return {\n rawText: capture.read(),\n sessionInfo,\n conversation: {\n sessionId: sessionInfo.bundleId,\n messageStart: 0,\n messageEnd: Math.max(0, conversation.messages.length - 1),\n eventStartSeq:\n eventStartSeq ??\n (() => {\n throw new Error(`Missing ACP event capture for session ${sessionInfo.bundleId}`);\n })(),\n eventEndSeq:\n eventEndSeq ??\n (() => {\n throw new Error(`Missing ACP event capture for session ${sessionInfo.bundleId}`);\n })(),\n },\n };\n }\n}\n","export type JsonObjectParseMode = \"strict\" | \"fenced\" | \"compat\";\n\nfunction normalizeJsonText(text: unknown): string {\n if (typeof text === \"string\") {\n return text.trim();\n }\n if (text == null) {\n return \"\";\n }\n if (\n typeof text === \"number\" ||\n typeof text === \"boolean\" ||\n typeof text === \"bigint\" ||\n typeof text === \"symbol\"\n ) {\n return String(text).trim();\n }\n return \"\";\n}\n\n// The generic entrypoint when a workflow wants to choose its tolerance level\n// explicitly. Most callers should still use one of the small helpers below.\nexport function parseJsonObject(\n text: string,\n options: {\n mode?: JsonObjectParseMode;\n } = {},\n): unknown {\n const trimmed = normalizeJsonText(text);\n if (!trimmed) {\n throw new Error(\"Expected JSON output, got empty text\");\n }\n const mode = options.mode ?? \"compat\";\n\n const direct = tryParse(trimmed);\n if (direct.ok) {\n return direct.value;\n }\n\n if (mode === \"fenced\" || mode === \"compat\") {\n const fencedMatch = trimmed.match(/```(?:json)?\\s*([\\s\\S]*?)```/i);\n if (fencedMatch) {\n const fenced = tryParse(fencedMatch[1].trim());\n if (fenced.ok) {\n return fenced.value;\n }\n }\n }\n\n if (mode === \"compat\") {\n for (const candidate of extractBalancedJsonCandidates(trimmed)) {\n const parsed = tryParse(candidate);\n if (parsed.ok) {\n return parsed.value;\n }\n }\n }\n\n throw new Error(`Could not parse JSON from assistant output:\\n${trimmed}`);\n}\n\n// Use this when the model contract must be exact JSON and any extra text\n// should fail the step immediately.\nexport function parseStrictJsonObject(text: string): unknown {\n return parseJsonObject(text, { mode: \"strict\" });\n}\n\n// Default workflow parser: direct JSON first, fenced JSON second, and finally\n// a balanced embedded object for compatibility with chatty model output.\nexport function extractJsonObject(text: string): unknown {\n return parseJsonObject(text, { mode: \"compat\" });\n}\n\nfunction tryParse(text: string): { ok: true; value: unknown } | { ok: false } {\n try {\n return {\n ok: true,\n value: JSON.parse(text),\n };\n } catch {\n return {\n ok: false,\n };\n }\n}\n\nfunction extractBalancedJsonCandidates(text: string): string[] {\n const candidates: string[] = [];\n\n for (let index = 0; index < text.length; index += 1) {\n if (text[index] !== \"{\" && text[index] !== \"[\") {\n continue;\n }\n\n const result = scanBalanced(text, index);\n if (result) {\n candidates.push(result);\n }\n }\n\n return candidates;\n}\n\nfunction scanBalanced(text: string, startIndex: number): string | null {\n const stack: string[] = [];\n let inString = false;\n let escaped = false;\n\n for (let index = startIndex; index < text.length; index += 1) {\n const char = text[index];\n\n if (inString) {\n if (escaped) {\n escaped = false;\n } else if (char === \"\\\\\") {\n escaped = true;\n } else if (char === '\"') {\n inString = false;\n }\n continue;\n }\n\n if (char === '\"') {\n inString = true;\n continue;\n }\n\n if (char === \"{\" || char === \"[\") {\n stack.push(char);\n continue;\n }\n\n if (char !== \"}\" && char !== \"]\") {\n continue;\n }\n\n const last = stack.at(-1);\n if ((last === \"{\" && char !== \"}\") || (last === \"[\" && char !== \"]\")) {\n return null;\n }\n\n stack.pop();\n if (stack.length === 0) {\n return text.slice(startIndex, index + 1);\n }\n }\n\n return null;\n}\n"],"mappings":"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"}
|
package/dist/flows.d.ts
CHANGED
|
@@ -1,13 +1,7 @@
|
|
|
1
|
-
import { a as PermissionMode, c as PromptInput, i as NonInteractivePermissionPolicy, n as AuthPolicy, r as McpServer$1 } from "./types-
|
|
1
|
+
import { a as PermissionMode, c as PromptInput, i as NonInteractivePermissionPolicy, n as AuthPolicy, r as McpServer$1 } from "./types-CVBeQyi3.js";
|
|
2
|
+
import { t as SessionAgentOptions } from "./session-options-pCbHn_n7.js";
|
|
2
3
|
import { SetSessionConfigOptionResponse } from "@agentclientprotocol/sdk";
|
|
3
4
|
|
|
4
|
-
//#region src/runtime/engine/session-options.d.ts
|
|
5
|
-
type SessionAgentOptions = {
|
|
6
|
-
model?: string;
|
|
7
|
-
allowedTools?: string[];
|
|
8
|
-
maxTurns?: number;
|
|
9
|
-
};
|
|
10
|
-
//#endregion
|
|
11
5
|
//#region src/flows/types.d.ts
|
|
12
6
|
type MaybePromise<T> = T | Promise<T>;
|
|
13
7
|
type FlowRunDefinition<TInput = unknown> = {
|
package/dist/flows.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"flows.d.ts","names":[],"sources":["../src/
|
|
1
|
+
{"version":3,"file":"flows.d.ts","names":[],"sources":["../src/flows/types.ts","../src/flows/definition.ts","../src/flows/runtime.ts","../src/flows/store.ts","../src/flows/json.ts"],"mappings":"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"}
|
package/dist/flows.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { a as flowRunsBaseDir, c as action, d as defineFlow, f as shell, i as FlowRunner, l as checkpoint, n as parseJsonObject, r as parseStrictJsonObject, s as acp, t as extractJsonObject, u as compute } from "./flows-
|
|
1
|
+
import { a as flowRunsBaseDir, c as action, d as defineFlow, f as shell, i as FlowRunner, l as checkpoint, n as parseJsonObject, r as parseStrictJsonObject, s as acp, t as extractJsonObject, u as compute } from "./flows-CDsfbaA2.js";
|
|
2
2
|
export { FlowRunner, acp, action, checkpoint, compute, defineFlow, extractJsonObject, flowRunsBaseDir, parseJsonObject, parseStrictJsonObject, shell };
|