@agentteams/runner 0.0.46

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.
Files changed (158) hide show
  1. package/dist/api-client.d.ts +22 -0
  2. package/dist/api-client.js +201 -0
  3. package/dist/api-client.js.map +1 -0
  4. package/dist/api-client.test.d.ts +1 -0
  5. package/dist/api-client.test.js +118 -0
  6. package/dist/api-client.test.js.map +1 -0
  7. package/dist/autostart.d.ts +19 -0
  8. package/dist/autostart.js +359 -0
  9. package/dist/autostart.js.map +1 -0
  10. package/dist/autostart.test.d.ts +1 -0
  11. package/dist/autostart.test.js +42 -0
  12. package/dist/autostart.test.js.map +1 -0
  13. package/dist/commands/cleanup.d.ts +1 -0
  14. package/dist/commands/cleanup.js +12 -0
  15. package/dist/commands/cleanup.js.map +1 -0
  16. package/dist/commands/init.d.ts +1 -0
  17. package/dist/commands/init.js +57 -0
  18. package/dist/commands/init.js.map +1 -0
  19. package/dist/commands/restart.d.ts +1 -0
  20. package/dist/commands/restart.js +7 -0
  21. package/dist/commands/restart.js.map +1 -0
  22. package/dist/commands/start.d.ts +1 -0
  23. package/dist/commands/start.js +34 -0
  24. package/dist/commands/start.js.map +1 -0
  25. package/dist/commands/status.d.ts +1 -0
  26. package/dist/commands/status.js +20 -0
  27. package/dist/commands/status.js.map +1 -0
  28. package/dist/commands/stop.d.ts +1 -0
  29. package/dist/commands/stop.js +21 -0
  30. package/dist/commands/stop.js.map +1 -0
  31. package/dist/commands/uninstall.d.ts +1 -0
  32. package/dist/commands/uninstall.js +21 -0
  33. package/dist/commands/uninstall.js.map +1 -0
  34. package/dist/commands/update.d.ts +10 -0
  35. package/dist/commands/update.js +58 -0
  36. package/dist/commands/update.js.map +1 -0
  37. package/dist/commands/update.test.d.ts +1 -0
  38. package/dist/commands/update.test.js +104 -0
  39. package/dist/commands/update.test.js.map +1 -0
  40. package/dist/config.d.ts +6 -0
  41. package/dist/config.js +69 -0
  42. package/dist/config.js.map +1 -0
  43. package/dist/config.test.d.ts +1 -0
  44. package/dist/config.test.js +133 -0
  45. package/dist/config.test.js.map +1 -0
  46. package/dist/daemon-control.d.ts +21 -0
  47. package/dist/daemon-control.js +58 -0
  48. package/dist/daemon-control.js.map +1 -0
  49. package/dist/daemon-control.test.d.ts +1 -0
  50. package/dist/daemon-control.test.js +48 -0
  51. package/dist/daemon-control.test.js.map +1 -0
  52. package/dist/executable.d.ts +25 -0
  53. package/dist/executable.js +141 -0
  54. package/dist/executable.js.map +1 -0
  55. package/dist/executable.test.d.ts +1 -0
  56. package/dist/executable.test.js +57 -0
  57. package/dist/executable.test.js.map +1 -0
  58. package/dist/handlers/trigger-handler.d.ts +25 -0
  59. package/dist/handlers/trigger-handler.js +308 -0
  60. package/dist/handlers/trigger-handler.js.map +1 -0
  61. package/dist/handlers/trigger-handler.test.d.ts +1 -0
  62. package/dist/handlers/trigger-handler.test.js +496 -0
  63. package/dist/handlers/trigger-handler.test.js.map +1 -0
  64. package/dist/index.d.ts +2 -0
  65. package/dist/index.js +82 -0
  66. package/dist/index.js.map +1 -0
  67. package/dist/logger.d.ts +5 -0
  68. package/dist/logger.js +25 -0
  69. package/dist/logger.js.map +1 -0
  70. package/dist/pid.d.ts +8 -0
  71. package/dist/pid.js +49 -0
  72. package/dist/pid.js.map +1 -0
  73. package/dist/poller.d.ts +20 -0
  74. package/dist/poller.js +214 -0
  75. package/dist/poller.js.map +1 -0
  76. package/dist/poller.test.d.ts +1 -0
  77. package/dist/poller.test.js +382 -0
  78. package/dist/poller.test.js.map +1 -0
  79. package/dist/runners/amp.d.ts +5 -0
  80. package/dist/runners/amp.js +316 -0
  81. package/dist/runners/amp.js.map +1 -0
  82. package/dist/runners/claude-code.d.ts +6 -0
  83. package/dist/runners/claude-code.js +340 -0
  84. package/dist/runners/claude-code.js.map +1 -0
  85. package/dist/runners/claude-code.test.d.ts +1 -0
  86. package/dist/runners/claude-code.test.js +39 -0
  87. package/dist/runners/claude-code.test.js.map +1 -0
  88. package/dist/runners/codex.d.ts +6 -0
  89. package/dist/runners/codex.js +324 -0
  90. package/dist/runners/codex.js.map +1 -0
  91. package/dist/runners/codex.test.d.ts +1 -0
  92. package/dist/runners/codex.test.js +66 -0
  93. package/dist/runners/codex.test.js.map +1 -0
  94. package/dist/runners/gemini.d.ts +5 -0
  95. package/dist/runners/gemini.js +304 -0
  96. package/dist/runners/gemini.js.map +1 -0
  97. package/dist/runners/gemini.test.d.ts +1 -0
  98. package/dist/runners/gemini.test.js +16 -0
  99. package/dist/runners/gemini.test.js.map +1 -0
  100. package/dist/runners/index.d.ts +2 -0
  101. package/dist/runners/index.js +27 -0
  102. package/dist/runners/index.js.map +1 -0
  103. package/dist/runners/index.test.d.ts +1 -0
  104. package/dist/runners/index.test.js +19 -0
  105. package/dist/runners/index.test.js.map +1 -0
  106. package/dist/runners/log-reporter.d.ts +18 -0
  107. package/dist/runners/log-reporter.js +127 -0
  108. package/dist/runners/log-reporter.js.map +1 -0
  109. package/dist/runners/log-reporter.test.d.ts +1 -0
  110. package/dist/runners/log-reporter.test.js +152 -0
  111. package/dist/runners/log-reporter.test.js.map +1 -0
  112. package/dist/runners/opencode.d.ts +6 -0
  113. package/dist/runners/opencode.js +304 -0
  114. package/dist/runners/opencode.js.map +1 -0
  115. package/dist/runners/stream-json-parser.d.ts +17 -0
  116. package/dist/runners/stream-json-parser.js +116 -0
  117. package/dist/runners/stream-json-parser.js.map +1 -0
  118. package/dist/runners/types.d.ts +26 -0
  119. package/dist/runners/types.js +2 -0
  120. package/dist/runners/types.js.map +1 -0
  121. package/dist/types.d.ts +69 -0
  122. package/dist/types.js +2 -0
  123. package/dist/types.js.map +1 -0
  124. package/dist/utils/auth-path-store.d.ts +3 -0
  125. package/dist/utils/auth-path-store.js +37 -0
  126. package/dist/utils/auth-path-store.js.map +1 -0
  127. package/dist/utils/auth-path-store.test.d.ts +1 -0
  128. package/dist/utils/auth-path-store.test.js +70 -0
  129. package/dist/utils/auth-path-store.test.js.map +1 -0
  130. package/dist/utils/convention-sync.d.ts +8 -0
  131. package/dist/utils/convention-sync.js +41 -0
  132. package/dist/utils/convention-sync.js.map +1 -0
  133. package/dist/utils/convention-sync.test.d.ts +1 -0
  134. package/dist/utils/convention-sync.test.js +75 -0
  135. package/dist/utils/convention-sync.test.js.map +1 -0
  136. package/dist/utils/git-worktree.d.ts +9 -0
  137. package/dist/utils/git-worktree.js +150 -0
  138. package/dist/utils/git-worktree.js.map +1 -0
  139. package/dist/utils/git-worktree.test.d.ts +1 -0
  140. package/dist/utils/git-worktree.test.js +294 -0
  141. package/dist/utils/git-worktree.test.js.map +1 -0
  142. package/dist/utils/origin-issue-safeguard.d.ts +16 -0
  143. package/dist/utils/origin-issue-safeguard.js +198 -0
  144. package/dist/utils/origin-issue-safeguard.js.map +1 -0
  145. package/dist/utils/runner-cleanup.d.ts +10 -0
  146. package/dist/utils/runner-cleanup.js +59 -0
  147. package/dist/utils/runner-cleanup.js.map +1 -0
  148. package/dist/utils/runner-cleanup.test.d.ts +1 -0
  149. package/dist/utils/runner-cleanup.test.js +93 -0
  150. package/dist/utils/runner-cleanup.test.js.map +1 -0
  151. package/dist/utils/runner-history.d.ts +6 -0
  152. package/dist/utils/runner-history.js +13 -0
  153. package/dist/utils/runner-history.js.map +1 -0
  154. package/dist/utils/runner-history.test.d.ts +1 -0
  155. package/dist/utils/runner-history.test.js +25 -0
  156. package/dist/utils/runner-history.test.js.map +1 -0
  157. package/package.json +50 -0
  158. package/readme.md +188 -0
@@ -0,0 +1,152 @@
1
+ import assert from "node:assert/strict";
2
+ import test, { mock } from "node:test";
3
+ import { logger } from "../logger.js";
4
+ import { TriggerLogReporter, mergeLogs } from "./log-reporter.js";
5
+ test.afterEach(() => {
6
+ mock.restoreAll();
7
+ });
8
+ test("TriggerLogReporter normalizes log messages and drains them on stop", async () => {
9
+ const payloads = [];
10
+ const client = {
11
+ appendTriggerLogs: async (_triggerId, payload) => {
12
+ payloads.push(payload);
13
+ }
14
+ };
15
+ const reporter = new TriggerLogReporter(client, "trigger-1");
16
+ reporter.append("INFO", "\u001B[31m hello \r\n\r\n\r\nworld \u0007");
17
+ reporter.append("WARN", " ");
18
+ await reporter.stop();
19
+ assert.equal(payloads.length, 1);
20
+ assert.deepEqual(payloads[0], {
21
+ logs: [{ level: "INFO", message: "hello \n\nworld" }],
22
+ heartbeat: true
23
+ });
24
+ });
25
+ test("TriggerLogReporter prepends a dropped-log warning when the buffer overflows", async () => {
26
+ const payloads = [];
27
+ const client = {
28
+ appendTriggerLogs: async (_triggerId, payload) => {
29
+ payloads.push(payload);
30
+ }
31
+ };
32
+ const reporter = new TriggerLogReporter(client, "trigger-1");
33
+ for (let index = 0; index < 501; index += 1) {
34
+ reporter.append("INFO", `line-${index}`);
35
+ }
36
+ await reporter.stop();
37
+ const flattened = payloads.flatMap((payload) => payload.logs ?? []);
38
+ assert.match(flattened[0]?.message ?? "", /Dropped 1 log line/);
39
+ // After merging, 501 individual logs are compressed into fewer records.
40
+ // The dropped warning (WARN) splits from the INFO logs, so we get at least 2 records.
41
+ assert.ok(flattened.length < 501, `Expected merged log count to be less than 501, got ${flattened.length}`);
42
+ assert.ok(flattened.length >= 2, `Expected at least 2 merged records (WARN + INFO), got ${flattened.length}`);
43
+ // Last merged record should contain line-500
44
+ assert.match(flattened.at(-1)?.message ?? "", /line-500/);
45
+ });
46
+ test("TriggerLogReporter sends heartbeat flushes on interval and start is idempotent", async () => {
47
+ const payloads = [];
48
+ const intervals = [];
49
+ const intervalHandles = [];
50
+ const originalSetInterval = globalThis.setInterval;
51
+ const originalClearInterval = globalThis.clearInterval;
52
+ globalThis.setInterval = ((callback) => {
53
+ intervals.push(callback);
54
+ const handle = {};
55
+ intervalHandles.push(handle);
56
+ return handle;
57
+ });
58
+ globalThis.clearInterval = ((handle) => {
59
+ assert.equal(intervalHandles.includes(handle), true);
60
+ });
61
+ try {
62
+ const client = {
63
+ appendTriggerLogs: async (_triggerId, payload) => {
64
+ payloads.push(payload);
65
+ }
66
+ };
67
+ const reporter = new TriggerLogReporter(client, "trigger-1", 10);
68
+ reporter.start();
69
+ reporter.start();
70
+ assert.equal(intervals.length, 1);
71
+ await intervals[0]?.();
72
+ await reporter.stop();
73
+ assert.equal(payloads[0]?.heartbeat, true);
74
+ assert.equal(payloads[0]?.logs, undefined);
75
+ }
76
+ finally {
77
+ globalThis.setInterval = originalSetInterval;
78
+ globalThis.clearInterval = originalClearInterval;
79
+ }
80
+ });
81
+ test("TriggerLogReporter logs warnings when log delivery fails", async () => {
82
+ const warnings = [];
83
+ mock.method(logger, "warn", (message, meta) => {
84
+ warnings.push({ message, meta });
85
+ });
86
+ const client = {
87
+ appendTriggerLogs: async () => {
88
+ throw new Error("network down");
89
+ }
90
+ };
91
+ const reporter = new TriggerLogReporter(client, "trigger-1");
92
+ reporter.append("ERROR", "failure");
93
+ await reporter.stop();
94
+ assert.equal(warnings.length, 1);
95
+ assert.match(warnings[0]?.message ?? "", /Failed to report trigger logs/);
96
+ assert.equal(warnings[0]?.meta?.payloadSize, 1);
97
+ });
98
+ test("mergeLogs merges consecutive same-level logs with newline separator", () => {
99
+ const result = mergeLogs([
100
+ { level: "INFO", message: "line 1" },
101
+ { level: "INFO", message: "line 2" },
102
+ { level: "INFO", message: "line 3" }
103
+ ]);
104
+ assert.equal(result.length, 1);
105
+ assert.equal(result[0].level, "INFO");
106
+ assert.equal(result[0].message, "line 1\nline 2\nline 3");
107
+ });
108
+ test("mergeLogs splits at level boundaries", () => {
109
+ const result = mergeLogs([
110
+ { level: "INFO", message: "info 1" },
111
+ { level: "INFO", message: "info 2" },
112
+ { level: "WARN", message: "warn 1" },
113
+ { level: "INFO", message: "info 3" }
114
+ ]);
115
+ assert.equal(result.length, 3);
116
+ assert.deepEqual(result[0], { level: "INFO", message: "info 1\ninfo 2" });
117
+ assert.deepEqual(result[1], { level: "WARN", message: "warn 1" });
118
+ assert.deepEqual(result[2], { level: "INFO", message: "info 3" });
119
+ });
120
+ test("mergeLogs splits when combined message exceeds 2000 chars", () => {
121
+ const longMessage = "x".repeat(1500);
122
+ const result = mergeLogs([
123
+ { level: "INFO", message: longMessage },
124
+ { level: "INFO", message: longMessage }
125
+ ]);
126
+ assert.equal(result.length, 2);
127
+ assert.equal(result[0].message, longMessage);
128
+ assert.equal(result[1].message, longMessage);
129
+ });
130
+ test("mergeLogs returns empty array for empty input", () => {
131
+ assert.deepEqual(mergeLogs([]), []);
132
+ });
133
+ test("TriggerLogReporter merges same-level logs during flush", async () => {
134
+ const payloads = [];
135
+ const client = {
136
+ appendTriggerLogs: async (_triggerId, payload) => {
137
+ payloads.push(payload);
138
+ }
139
+ };
140
+ const reporter = new TriggerLogReporter(client, "trigger-1");
141
+ reporter.append("INFO", "line 1");
142
+ reporter.append("INFO", "line 2");
143
+ reporter.append("WARN", "warning");
144
+ reporter.append("INFO", "line 3");
145
+ await reporter.stop();
146
+ const logs = payloads.flatMap((p) => p.logs ?? []);
147
+ assert.equal(logs.length, 3);
148
+ assert.deepEqual(logs[0], { level: "INFO", message: "line 1\nline 2" });
149
+ assert.deepEqual(logs[1], { level: "WARN", message: "warning" });
150
+ assert.deepEqual(logs[2], { level: "INFO", message: "line 3" });
151
+ });
152
+ //# sourceMappingURL=log-reporter.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"log-reporter.test.js","sourceRoot":"","sources":["../../src/runners/log-reporter.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import type { Runner, RunnerOptions, RunResult } from "./types.js";
2
+ export declare class OpenCodeRunner implements Runner {
3
+ private readonly runnerCmd;
4
+ constructor(runnerCmd?: string);
5
+ run(opts: RunnerOptions): Promise<RunResult>;
6
+ }
@@ -0,0 +1,304 @@
1
+ import { createWriteStream } from "node:fs";
2
+ import { execFileSync, spawn } from "node:child_process";
3
+ import { mkdir } from "node:fs/promises";
4
+ import { platform } from "node:os";
5
+ import { dirname, join } from "node:path";
6
+ import { describeExecutableResolution, resolveExecutablePathWithPreference, spawnExecutable } from "../executable.js";
7
+ import { logger } from "../logger.js";
8
+ const FORCE_KILL_AFTER_MS = 10_000;
9
+ const PROMPT_PREVIEW_MAX = 500;
10
+ const OUTPUT_PREVIEW_MAX = 400;
11
+ const OUTPUT_CAPTURE_MAX = 200_000;
12
+ const toPowerShellEncodedCommand = (resolvedExecutablePath, prompt, model) => {
13
+ const modelSegment = model ? ` '--model' '${model.replaceAll("'", "''")}'` : "";
14
+ const scriptContent = [
15
+ "$ErrorActionPreference = 'Stop'",
16
+ "$utf8NoBom = [System.Text.UTF8Encoding]::new($false)",
17
+ "[Console]::InputEncoding = $utf8NoBom",
18
+ "[Console]::OutputEncoding = $utf8NoBom",
19
+ "$OutputEncoding = $utf8NoBom",
20
+ "chcp 65001 > $null",
21
+ `$promptText = @'`,
22
+ `${prompt.replaceAll("'@", "'@")}`,
23
+ `'@`,
24
+ `$promptText | & '${resolvedExecutablePath.replaceAll("'", "''")}' 'run'${modelSegment}`
25
+ ].join("\r\n");
26
+ return Buffer.from(scriptContent, "utf16le").toString("base64");
27
+ };
28
+ const toPromptPreview = (prompt) => {
29
+ if (prompt.length <= PROMPT_PREVIEW_MAX) {
30
+ return prompt;
31
+ }
32
+ return `${prompt.slice(0, PROMPT_PREVIEW_MAX)}...`;
33
+ };
34
+ const toOutputPreview = (chunk) => {
35
+ const text = (typeof chunk === "string" ? chunk : String(chunk)).trim();
36
+ if (text.length <= OUTPUT_PREVIEW_MAX) {
37
+ return text;
38
+ }
39
+ return `${text.slice(0, OUTPUT_PREVIEW_MAX)}...`;
40
+ };
41
+ const terminateRunnerChild = (child, isWindows, triggerId, reason) => {
42
+ if (!child.pid) {
43
+ return;
44
+ }
45
+ logger.warn(reason === "cancel" ? "Runner cancellation requested; sending SIGTERM" : "Runner fail-safe timeout reached; sending SIGTERM", {
46
+ triggerId,
47
+ pid: child.pid
48
+ });
49
+ try {
50
+ if (isWindows) {
51
+ execFileSync("taskkill", ["/F", "/T", "/PID", String(child.pid)], { stdio: "ignore" });
52
+ }
53
+ else {
54
+ process.kill(-child.pid, "SIGTERM");
55
+ }
56
+ }
57
+ catch {
58
+ // ignore
59
+ }
60
+ if (!isWindows) {
61
+ setTimeout(() => {
62
+ try {
63
+ if (child.pid) {
64
+ process.kill(-child.pid, "SIGKILL");
65
+ }
66
+ }
67
+ catch {
68
+ // ignore
69
+ }
70
+ }, FORCE_KILL_AFTER_MS);
71
+ }
72
+ };
73
+ export class OpenCodeRunner {
74
+ runnerCmd;
75
+ constructor(runnerCmd = "opencode") {
76
+ this.runnerCmd = runnerCmd;
77
+ }
78
+ async run(opts) {
79
+ if (!opts.authPath || opts.authPath.trim().length === 0) {
80
+ logger.error("authPath is missing for trigger");
81
+ return {
82
+ exitCode: 1,
83
+ errorMessage: "authPath is missing for trigger"
84
+ };
85
+ }
86
+ const cwd = opts.authPath;
87
+ const logPath = join(cwd, ".agentteams", "runner", "log", `${opts.triggerId}.log`);
88
+ await mkdir(dirname(logPath), { recursive: true });
89
+ const isWindows = platform() === "win32";
90
+ const resolvedExecutablePath = isWindows
91
+ ? resolveExecutablePathWithPreference(this.runnerCmd, [`${this.runnerCmd}.cmd`, this.runnerCmd])
92
+ : resolveExecutablePathWithPreference(this.runnerCmd, [this.runnerCmd]);
93
+ const windowsEncodedCommand = isWindows
94
+ ? toPowerShellEncodedCommand(resolvedExecutablePath, opts.prompt, opts.model)
95
+ : null;
96
+ const executableInfo = describeExecutableResolution(this.runnerCmd, {
97
+ platform: () => (isWindows ? "win32" : platform())
98
+ });
99
+ logger.info("Runner prompt", {
100
+ triggerId: opts.triggerId,
101
+ promptLength: opts.prompt.length,
102
+ promptPreview: toPromptPreview(opts.prompt),
103
+ requestedCommand: executableInfo.requestedCommand,
104
+ resolvedExecutablePath,
105
+ platform: executableInfo.platform,
106
+ shell: executableInfo.shell,
107
+ detached: isWindows ? false : true,
108
+ windowsWrapper: isWindows ? "powershell.exe -EncodedCommand" : null
109
+ });
110
+ const modelArgs = opts.model ? ["--model", opts.model] : [];
111
+ const child = isWindows
112
+ ? spawn("powershell.exe", [
113
+ "-NoLogo",
114
+ "-NonInteractive",
115
+ "-ExecutionPolicy",
116
+ "Bypass",
117
+ "-EncodedCommand",
118
+ windowsEncodedCommand ?? ""
119
+ ], {
120
+ cwd,
121
+ detached: false,
122
+ shell: false,
123
+ windowsHide: true,
124
+ stdio: ["ignore", "pipe", "pipe"],
125
+ env: {
126
+ ...process.env,
127
+ AGENTTEAMS_API_KEY: opts.apiKey,
128
+ AGENTTEAMS_API_URL: opts.apiUrl,
129
+ AGENTTEAMS_TEAM_ID: opts.teamId,
130
+ AGENTTEAMS_PROJECT_ID: opts.projectId,
131
+ AGENTTEAMS_AGENT_NAME: opts.agentConfigId
132
+ }
133
+ })
134
+ : spawnExecutable(this.runnerCmd, ["run", ...modelArgs, opts.prompt], {
135
+ cwd,
136
+ detached: true,
137
+ stdio: ["ignore", "pipe", "pipe"],
138
+ env: {
139
+ ...process.env,
140
+ AGENTTEAMS_API_KEY: opts.apiKey,
141
+ AGENTTEAMS_API_URL: opts.apiUrl,
142
+ AGENTTEAMS_TEAM_ID: opts.teamId,
143
+ AGENTTEAMS_PROJECT_ID: opts.projectId,
144
+ AGENTTEAMS_AGENT_NAME: opts.agentConfigId
145
+ }
146
+ });
147
+ const logStream = createWriteStream(logPath, { flags: "a" });
148
+ logStream.on("error", (err) => {
149
+ logger.warn("Runner log stream error", { triggerId: opts.triggerId, error: err.message });
150
+ });
151
+ child.stdout?.pipe(logStream);
152
+ child.stderr?.pipe(logStream);
153
+ let lastOutput = "";
154
+ let lastErrorOutput = "";
155
+ let outputText = "";
156
+ const appendOutputText = (chunk) => {
157
+ if (outputText.length >= OUTPUT_CAPTURE_MAX) {
158
+ return;
159
+ }
160
+ outputText += chunk.slice(0, OUTPUT_CAPTURE_MAX - outputText.length);
161
+ };
162
+ const idleTimer = { reset: () => { } };
163
+ child.stdout?.on("data", (chunk) => {
164
+ const rawOutput = Buffer.isBuffer(chunk) ? chunk.toString("utf8") : String(chunk);
165
+ appendOutputText(rawOutput);
166
+ const output = toOutputPreview(rawOutput);
167
+ if (output.length > 0) {
168
+ lastOutput = output;
169
+ idleTimer.reset();
170
+ opts.onStdoutChunk?.(output);
171
+ logger.info("Runner stdout", {
172
+ triggerId: opts.triggerId,
173
+ pid: child.pid,
174
+ output
175
+ });
176
+ }
177
+ });
178
+ child.stderr?.on("data", (chunk) => {
179
+ const output = toOutputPreview(Buffer.isBuffer(chunk) ? chunk.toString("utf8") : chunk);
180
+ if (output.length > 0) {
181
+ lastOutput = output;
182
+ lastErrorOutput = output;
183
+ idleTimer.reset();
184
+ opts.onStderrChunk?.(output);
185
+ logger.warn("Runner stderr", {
186
+ triggerId: opts.triggerId,
187
+ pid: child.pid,
188
+ output
189
+ });
190
+ }
191
+ });
192
+ logger.info("Runner started", {
193
+ triggerId: opts.triggerId,
194
+ cwd,
195
+ logPath,
196
+ pid: child.pid
197
+ });
198
+ return await new Promise((resolve) => {
199
+ let finished = false;
200
+ let timedOut = false;
201
+ let idleTimedOut = false;
202
+ let cancelled = false;
203
+ let idleTimeoutId = null;
204
+ const startIdleTimeout = () => {
205
+ if (idleTimeoutId) {
206
+ clearTimeout(idleTimeoutId);
207
+ }
208
+ idleTimeoutId = setTimeout(() => {
209
+ idleTimedOut = true;
210
+ timedOut = true;
211
+ logger.warn("Runner idle timeout reached; no output for configured idle period", {
212
+ triggerId: opts.triggerId,
213
+ idleTimeoutMs: opts.idleTimeoutMs
214
+ });
215
+ terminateRunnerChild(child, isWindows, opts.triggerId, "timeout");
216
+ }, opts.idleTimeoutMs);
217
+ };
218
+ idleTimer.reset = () => {
219
+ startIdleTimeout();
220
+ };
221
+ startIdleTimeout();
222
+ const cleanup = () => {
223
+ if (finished) {
224
+ return;
225
+ }
226
+ finished = true;
227
+ if (idleTimeoutId) {
228
+ clearTimeout(idleTimeoutId);
229
+ }
230
+ idleTimer.reset = () => { };
231
+ logStream.end();
232
+ if (opts.signal) {
233
+ opts.signal.removeEventListener("abort", handleAbort);
234
+ }
235
+ };
236
+ const handleAbort = () => {
237
+ cancelled = true;
238
+ terminateRunnerChild(child, isWindows, opts.triggerId, "cancel");
239
+ };
240
+ const timeoutId = setTimeout(() => {
241
+ timedOut = true;
242
+ terminateRunnerChild(child, isWindows, opts.triggerId, "timeout");
243
+ }, opts.timeoutMs);
244
+ if (opts.signal?.aborted) {
245
+ handleAbort();
246
+ }
247
+ else if (opts.signal) {
248
+ opts.signal.addEventListener("abort", handleAbort, { once: true });
249
+ }
250
+ child.on("error", (error) => {
251
+ clearTimeout(timeoutId);
252
+ cleanup();
253
+ logger.error("Runner process launch failed", {
254
+ triggerId: opts.triggerId,
255
+ error: error.message
256
+ });
257
+ resolve({
258
+ exitCode: 1,
259
+ lastOutput,
260
+ outputText: outputText.trim() || undefined,
261
+ errorMessage: error.message
262
+ });
263
+ });
264
+ child.on("close", (code) => {
265
+ clearTimeout(timeoutId);
266
+ cleanup();
267
+ logger.info("Runner process closed", {
268
+ triggerId: opts.triggerId,
269
+ pid: child.pid,
270
+ exitCode: code,
271
+ timedOut
272
+ });
273
+ if (timedOut) {
274
+ resolve({
275
+ exitCode: 1,
276
+ lastOutput,
277
+ outputText: outputText.trim() || undefined,
278
+ errorMessage: idleTimedOut
279
+ ? `Runner idle timed out after ${Math.round(opts.idleTimeoutMs / 60_000)}m of no output`
280
+ : `Runner fail-safe timed out after ${Math.round(opts.timeoutMs / 3_600_000)}h`
281
+ });
282
+ return;
283
+ }
284
+ if (cancelled) {
285
+ resolve({
286
+ exitCode: 1,
287
+ cancelled: true,
288
+ lastOutput,
289
+ outputText: outputText.trim() || undefined,
290
+ errorMessage: "Runner cancelled by user"
291
+ });
292
+ return;
293
+ }
294
+ resolve({
295
+ exitCode: code ?? 1,
296
+ lastOutput,
297
+ outputText: outputText.trim() || undefined,
298
+ errorMessage: code === 0 ? undefined : (lastErrorOutput || lastOutput || `Runner exited with code ${code ?? 1}`)
299
+ });
300
+ });
301
+ });
302
+ }
303
+ }
304
+ //# sourceMappingURL=opencode.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"opencode.js","sourceRoot":"","sources":["../../src/runners/opencode.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ /**
2
+ * Parses Claude Code / AMP compatible stream-json lines into structured log entries.
3
+ * Shared by claude-code and amp runners to convert raw JSON output into human-readable logs.
4
+ */
5
+ export type ParsedLogEntry = {
6
+ level: "INFO" | "WARN";
7
+ message: string;
8
+ };
9
+ export declare const parseStreamJsonLine: (line: string) => ParsedLogEntry[];
10
+ /**
11
+ * Creates a line-buffered parser that handles chunked stdout data.
12
+ * Stream data may arrive as partial lines, so this buffers until newlines.
13
+ */
14
+ export declare const createStreamJsonLineParser: (onEntries: (entries: ParsedLogEntry[]) => void) => {
15
+ push: (chunk: string) => void;
16
+ flush: () => void;
17
+ };
@@ -0,0 +1,116 @@
1
+ /**
2
+ * Parses Claude Code / AMP compatible stream-json lines into structured log entries.
3
+ * Shared by claude-code and amp runners to convert raw JSON output into human-readable logs.
4
+ */
5
+ const THINKING_PREVIEW_MAX = 300;
6
+ const TEXT_PREVIEW_MAX = 500;
7
+ const TOOL_INPUT_PREVIEW_MAX = 200;
8
+ const truncate = (text, max) => text.length <= max ? text : `${text.slice(0, max)}...`;
9
+ export const parseStreamJsonLine = (line) => {
10
+ const trimmed = line.trim();
11
+ if (trimmed.length === 0) {
12
+ return [];
13
+ }
14
+ let parsed;
15
+ try {
16
+ parsed = JSON.parse(trimmed);
17
+ }
18
+ catch {
19
+ return [];
20
+ }
21
+ if (!parsed.type) {
22
+ return [];
23
+ }
24
+ const entries = [];
25
+ switch (parsed.type) {
26
+ case "system": {
27
+ if (parsed.subtype === "init") {
28
+ const toolCount = parsed.tools?.length ?? 0;
29
+ const model = parsed.model ?? "unknown";
30
+ entries.push({ level: "INFO", message: `Session initialized (model=${model}, tools=${toolCount})` });
31
+ }
32
+ break;
33
+ }
34
+ case "assistant": {
35
+ const content = parsed.message?.content;
36
+ if (!Array.isArray(content)) {
37
+ break;
38
+ }
39
+ for (const block of content) {
40
+ switch (block.type) {
41
+ case "thinking": {
42
+ const thinking = block.thinking;
43
+ if (thinking && thinking.trim().length > 0) {
44
+ entries.push({ level: "INFO", message: `[Thinking] ${truncate(thinking.trim(), THINKING_PREVIEW_MAX)}` });
45
+ }
46
+ break;
47
+ }
48
+ case "text": {
49
+ const text = block.text;
50
+ if (text && text.trim().length > 0) {
51
+ entries.push({ level: "INFO", message: truncate(text.trim(), TEXT_PREVIEW_MAX) });
52
+ }
53
+ break;
54
+ }
55
+ case "tool_use": {
56
+ const toolBlock = block;
57
+ const name = toolBlock.name ?? "unknown";
58
+ const inputPreview = toolBlock.input
59
+ ? truncate(JSON.stringify(toolBlock.input), TOOL_INPUT_PREVIEW_MAX)
60
+ : "";
61
+ entries.push({ level: "INFO", message: inputPreview ? `[Tool] ${name}: ${inputPreview}` : `[Tool] ${name}` });
62
+ break;
63
+ }
64
+ default:
65
+ break;
66
+ }
67
+ }
68
+ break;
69
+ }
70
+ case "result": {
71
+ const duration = parsed.duration_ms ? `${Math.round(parsed.duration_ms / 1000)}s` : "unknown";
72
+ const turns = parsed.num_turns ?? 0;
73
+ if (parsed.is_error) {
74
+ const result = parsed.result ?? "Unknown error";
75
+ entries.push({ level: "WARN", message: `[Result] Error after ${duration} (${turns} turns): ${truncate(result, TEXT_PREVIEW_MAX)}` });
76
+ }
77
+ else {
78
+ entries.push({ level: "INFO", message: `[Result] Completed in ${duration} (${turns} turns)` });
79
+ }
80
+ break;
81
+ }
82
+ default:
83
+ break;
84
+ }
85
+ return entries;
86
+ };
87
+ /**
88
+ * Creates a line-buffered parser that handles chunked stdout data.
89
+ * Stream data may arrive as partial lines, so this buffers until newlines.
90
+ */
91
+ export const createStreamJsonLineParser = (onEntries) => {
92
+ let buffer = "";
93
+ return {
94
+ push(chunk) {
95
+ buffer += chunk;
96
+ const lines = buffer.split("\n");
97
+ buffer = lines.pop() ?? "";
98
+ for (const line of lines) {
99
+ const entries = parseStreamJsonLine(line);
100
+ if (entries.length > 0) {
101
+ onEntries(entries);
102
+ }
103
+ }
104
+ },
105
+ flush() {
106
+ if (buffer.trim().length > 0) {
107
+ const entries = parseStreamJsonLine(buffer);
108
+ if (entries.length > 0) {
109
+ onEntries(entries);
110
+ }
111
+ }
112
+ buffer = "";
113
+ }
114
+ };
115
+ };
116
+ //# sourceMappingURL=stream-json-parser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stream-json-parser.js","sourceRoot":"","sources":["../../src/runners/stream-json-parser.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ export interface Runner {
2
+ run(opts: RunnerOptions): Promise<RunResult>;
3
+ }
4
+ export interface RunnerOptions {
5
+ triggerId: string;
6
+ prompt: string;
7
+ authPath: string | null;
8
+ apiKey: string;
9
+ apiUrl: string;
10
+ teamId: string;
11
+ projectId: string;
12
+ timeoutMs: number;
13
+ idleTimeoutMs: number;
14
+ agentConfigId: string;
15
+ model?: string | null;
16
+ signal?: AbortSignal;
17
+ onStdoutChunk?: (chunk: string) => void;
18
+ onStderrChunk?: (chunk: string) => void;
19
+ }
20
+ export type RunResult = {
21
+ exitCode: number;
22
+ cancelled?: boolean;
23
+ lastOutput?: string;
24
+ outputText?: string;
25
+ errorMessage?: string;
26
+ };