@jackchen_me/open-multi-agent 0.2.0 → 1.0.0
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/.github/workflows/ci.yml +1 -1
- package/CLAUDE.md +11 -3
- package/README.md +87 -20
- package/README_zh.md +85 -25
- package/dist/agent/agent.d.ts +15 -1
- package/dist/agent/agent.d.ts.map +1 -1
- package/dist/agent/agent.js +144 -10
- package/dist/agent/agent.js.map +1 -1
- package/dist/agent/loop-detector.d.ts +39 -0
- package/dist/agent/loop-detector.d.ts.map +1 -0
- package/dist/agent/loop-detector.js +122 -0
- package/dist/agent/loop-detector.js.map +1 -0
- package/dist/agent/pool.d.ts +2 -1
- package/dist/agent/pool.d.ts.map +1 -1
- package/dist/agent/pool.js +4 -2
- package/dist/agent/pool.js.map +1 -1
- package/dist/agent/runner.d.ts +23 -1
- package/dist/agent/runner.d.ts.map +1 -1
- package/dist/agent/runner.js +113 -12
- package/dist/agent/runner.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/llm/adapter.d.ts +4 -1
- package/dist/llm/adapter.d.ts.map +1 -1
- package/dist/llm/adapter.js +11 -0
- package/dist/llm/adapter.js.map +1 -1
- package/dist/llm/copilot.d.ts.map +1 -1
- package/dist/llm/copilot.js +2 -1
- package/dist/llm/copilot.js.map +1 -1
- package/dist/llm/gemini.d.ts +65 -0
- package/dist/llm/gemini.d.ts.map +1 -0
- package/dist/llm/gemini.js +317 -0
- package/dist/llm/gemini.js.map +1 -0
- package/dist/llm/grok.d.ts +21 -0
- package/dist/llm/grok.d.ts.map +1 -0
- package/dist/llm/grok.js +24 -0
- package/dist/llm/grok.js.map +1 -0
- package/dist/llm/openai-common.d.ts +8 -1
- package/dist/llm/openai-common.d.ts.map +1 -1
- package/dist/llm/openai-common.js +35 -2
- package/dist/llm/openai-common.js.map +1 -1
- package/dist/llm/openai.d.ts +1 -1
- package/dist/llm/openai.d.ts.map +1 -1
- package/dist/llm/openai.js +20 -2
- package/dist/llm/openai.js.map +1 -1
- package/dist/orchestrator/orchestrator.d.ts.map +1 -1
- package/dist/orchestrator/orchestrator.js +89 -9
- package/dist/orchestrator/orchestrator.js.map +1 -1
- package/dist/task/queue.d.ts +31 -2
- package/dist/task/queue.d.ts.map +1 -1
- package/dist/task/queue.js +69 -2
- package/dist/task/queue.js.map +1 -1
- package/dist/tool/text-tool-extractor.d.ts +32 -0
- package/dist/tool/text-tool-extractor.d.ts.map +1 -0
- package/dist/tool/text-tool-extractor.js +187 -0
- package/dist/tool/text-tool-extractor.js.map +1 -0
- package/dist/types.d.ts +139 -7
- package/dist/types.d.ts.map +1 -1
- package/dist/utils/trace.d.ts +12 -0
- package/dist/utils/trace.d.ts.map +1 -0
- package/dist/utils/trace.js +30 -0
- package/dist/utils/trace.js.map +1 -0
- package/examples/06-local-model.ts +1 -0
- package/examples/08-gemma4-local.ts +76 -87
- package/examples/09-structured-output.ts +73 -0
- package/examples/10-task-retry.ts +132 -0
- package/examples/11-trace-observability.ts +133 -0
- package/examples/12-grok.ts +154 -0
- package/examples/13-gemini.ts +48 -0
- package/package.json +11 -1
- package/src/agent/agent.ts +159 -10
- package/src/agent/loop-detector.ts +137 -0
- package/src/agent/pool.ts +9 -2
- package/src/agent/runner.ts +148 -19
- package/src/index.ts +15 -0
- package/src/llm/adapter.ts +12 -1
- package/src/llm/copilot.ts +2 -1
- package/src/llm/gemini.ts +378 -0
- package/src/llm/grok.ts +29 -0
- package/src/llm/openai-common.ts +41 -2
- package/src/llm/openai.ts +23 -3
- package/src/orchestrator/orchestrator.ts +105 -11
- package/src/task/queue.ts +73 -3
- package/src/tool/text-tool-extractor.ts +219 -0
- package/src/types.ts +157 -6
- package/src/utils/trace.ts +34 -0
- package/tests/agent-hooks.test.ts +473 -0
- package/tests/agent-pool.test.ts +212 -0
- package/tests/approval.test.ts +464 -0
- package/tests/built-in-tools.test.ts +393 -0
- package/tests/gemini-adapter.test.ts +97 -0
- package/tests/grok-adapter.test.ts +74 -0
- package/tests/llm-adapters.test.ts +357 -0
- package/tests/loop-detection.test.ts +456 -0
- package/tests/openai-fallback.test.ts +159 -0
- package/tests/orchestrator.test.ts +281 -0
- package/tests/scheduler.test.ts +221 -0
- package/tests/team-messaging.test.ts +329 -0
- package/tests/text-tool-extractor.test.ts +170 -0
- package/tests/trace.test.ts +453 -0
- package/vitest.config.ts +9 -0
- package/examples/09-gemma4-auto-orchestration.ts +0 -162
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Fallback tool-call extractor for local models.
|
|
3
|
+
*
|
|
4
|
+
* When a local model (Ollama, vLLM, LM Studio) returns tool calls as plain
|
|
5
|
+
* text instead of using the OpenAI `tool_calls` wire format, this module
|
|
6
|
+
* attempts to extract them from the text output.
|
|
7
|
+
*
|
|
8
|
+
* Common scenarios:
|
|
9
|
+
* - Ollama thinking-model bug: tool call JSON ends up inside unclosed `<think>` tags
|
|
10
|
+
* - Model outputs raw JSON tool calls without the server parsing them
|
|
11
|
+
* - Model wraps tool calls in markdown code fences
|
|
12
|
+
* - Hermes-format `<tool_call>` tags
|
|
13
|
+
*
|
|
14
|
+
* This is a **safety net**, not the primary path. Native `tool_calls` from
|
|
15
|
+
* the server are always preferred.
|
|
16
|
+
*/
|
|
17
|
+
// ---------------------------------------------------------------------------
|
|
18
|
+
// ID generation
|
|
19
|
+
// ---------------------------------------------------------------------------
|
|
20
|
+
let callCounter = 0;
|
|
21
|
+
/** Generate a unique tool-call ID for extracted calls. */
|
|
22
|
+
function generateToolCallId() {
|
|
23
|
+
return `extracted_call_${Date.now()}_${++callCounter}`;
|
|
24
|
+
}
|
|
25
|
+
// ---------------------------------------------------------------------------
|
|
26
|
+
// Internal parsers
|
|
27
|
+
// ---------------------------------------------------------------------------
|
|
28
|
+
/**
|
|
29
|
+
* Try to parse a single JSON object as a tool call.
|
|
30
|
+
*
|
|
31
|
+
* Accepted shapes:
|
|
32
|
+
* ```json
|
|
33
|
+
* { "name": "bash", "arguments": { "command": "ls" } }
|
|
34
|
+
* { "name": "bash", "parameters": { "command": "ls" } }
|
|
35
|
+
* { "function": { "name": "bash", "arguments": { "command": "ls" } } }
|
|
36
|
+
* ```
|
|
37
|
+
*/
|
|
38
|
+
function parseToolCallJSON(json, knownToolNames) {
|
|
39
|
+
if (json === null || typeof json !== 'object' || Array.isArray(json)) {
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
const obj = json;
|
|
43
|
+
// Shape: { function: { name, arguments } }
|
|
44
|
+
if (typeof obj['function'] === 'object' && obj['function'] !== null) {
|
|
45
|
+
const fn = obj['function'];
|
|
46
|
+
return parseFlat(fn, knownToolNames);
|
|
47
|
+
}
|
|
48
|
+
// Shape: { name, arguments|parameters }
|
|
49
|
+
return parseFlat(obj, knownToolNames);
|
|
50
|
+
}
|
|
51
|
+
function parseFlat(obj, knownToolNames) {
|
|
52
|
+
const name = obj['name'];
|
|
53
|
+
if (typeof name !== 'string' || name.length === 0)
|
|
54
|
+
return null;
|
|
55
|
+
// Whitelist check — don't treat arbitrary JSON as a tool call
|
|
56
|
+
if (knownToolNames.size > 0 && !knownToolNames.has(name))
|
|
57
|
+
return null;
|
|
58
|
+
let input = {};
|
|
59
|
+
const args = obj['arguments'] ?? obj['parameters'] ?? obj['input'];
|
|
60
|
+
if (args !== null && args !== undefined) {
|
|
61
|
+
if (typeof args === 'string') {
|
|
62
|
+
try {
|
|
63
|
+
const parsed = JSON.parse(args);
|
|
64
|
+
if (typeof parsed === 'object' && parsed !== null && !Array.isArray(parsed)) {
|
|
65
|
+
input = parsed;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
catch {
|
|
69
|
+
// Malformed — use empty input
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
else if (typeof args === 'object' && !Array.isArray(args)) {
|
|
73
|
+
input = args;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return {
|
|
77
|
+
type: 'tool_use',
|
|
78
|
+
id: generateToolCallId(),
|
|
79
|
+
name,
|
|
80
|
+
input,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
// ---------------------------------------------------------------------------
|
|
84
|
+
// JSON extraction from text
|
|
85
|
+
// ---------------------------------------------------------------------------
|
|
86
|
+
/**
|
|
87
|
+
* Find all top-level JSON objects in a string by tracking brace depth.
|
|
88
|
+
* Returns the parsed objects (not sub-objects).
|
|
89
|
+
*/
|
|
90
|
+
function extractJSONObjects(text) {
|
|
91
|
+
const results = [];
|
|
92
|
+
let depth = 0;
|
|
93
|
+
let start = -1;
|
|
94
|
+
let inString = false;
|
|
95
|
+
let escape = false;
|
|
96
|
+
for (let i = 0; i < text.length; i++) {
|
|
97
|
+
const ch = text[i];
|
|
98
|
+
if (escape) {
|
|
99
|
+
escape = false;
|
|
100
|
+
continue;
|
|
101
|
+
}
|
|
102
|
+
if (ch === '\\' && inString) {
|
|
103
|
+
escape = true;
|
|
104
|
+
continue;
|
|
105
|
+
}
|
|
106
|
+
if (ch === '"') {
|
|
107
|
+
inString = !inString;
|
|
108
|
+
continue;
|
|
109
|
+
}
|
|
110
|
+
if (inString)
|
|
111
|
+
continue;
|
|
112
|
+
if (ch === '{') {
|
|
113
|
+
if (depth === 0)
|
|
114
|
+
start = i;
|
|
115
|
+
depth++;
|
|
116
|
+
}
|
|
117
|
+
else if (ch === '}') {
|
|
118
|
+
depth--;
|
|
119
|
+
if (depth === 0 && start !== -1) {
|
|
120
|
+
const candidate = text.slice(start, i + 1);
|
|
121
|
+
try {
|
|
122
|
+
results.push(JSON.parse(candidate));
|
|
123
|
+
}
|
|
124
|
+
catch {
|
|
125
|
+
// Not valid JSON — skip
|
|
126
|
+
}
|
|
127
|
+
start = -1;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
return results;
|
|
132
|
+
}
|
|
133
|
+
// ---------------------------------------------------------------------------
|
|
134
|
+
// Hermes format: <tool_call>...</tool_call>
|
|
135
|
+
// ---------------------------------------------------------------------------
|
|
136
|
+
function extractHermesToolCalls(text, knownToolNames) {
|
|
137
|
+
const results = [];
|
|
138
|
+
for (const match of text.matchAll(/<tool_call>\s*([\s\S]*?)\s*<\/tool_call>/g)) {
|
|
139
|
+
const inner = match[1].trim();
|
|
140
|
+
try {
|
|
141
|
+
const parsed = JSON.parse(inner);
|
|
142
|
+
const block = parseToolCallJSON(parsed, knownToolNames);
|
|
143
|
+
if (block !== null)
|
|
144
|
+
results.push(block);
|
|
145
|
+
}
|
|
146
|
+
catch {
|
|
147
|
+
// Malformed hermes content — skip
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
return results;
|
|
151
|
+
}
|
|
152
|
+
// ---------------------------------------------------------------------------
|
|
153
|
+
// Public API
|
|
154
|
+
// ---------------------------------------------------------------------------
|
|
155
|
+
/**
|
|
156
|
+
* Attempt to extract tool calls from a model's text output.
|
|
157
|
+
*
|
|
158
|
+
* Tries multiple strategies in order:
|
|
159
|
+
* 1. Hermes `<tool_call>` tags
|
|
160
|
+
* 2. JSON objects in text (bare or inside code fences)
|
|
161
|
+
*
|
|
162
|
+
* @param text - The model's text output.
|
|
163
|
+
* @param knownToolNames - Whitelist of registered tool names. When non-empty,
|
|
164
|
+
* only JSON objects whose `name` matches a known tool
|
|
165
|
+
* are treated as tool calls.
|
|
166
|
+
* @returns Extracted {@link ToolUseBlock}s, or an empty array if none found.
|
|
167
|
+
*/
|
|
168
|
+
export function extractToolCallsFromText(text, knownToolNames) {
|
|
169
|
+
if (text.length === 0)
|
|
170
|
+
return [];
|
|
171
|
+
const nameSet = new Set(knownToolNames);
|
|
172
|
+
// Strategy 1: Hermes format
|
|
173
|
+
const hermesResults = extractHermesToolCalls(text, nameSet);
|
|
174
|
+
if (hermesResults.length > 0)
|
|
175
|
+
return hermesResults;
|
|
176
|
+
// Strategy 2: Strip code fences, then extract JSON objects
|
|
177
|
+
const stripped = text.replace(/```(?:json)?\s*\n?([\s\S]*?)\n?\s*```/g, '$1');
|
|
178
|
+
const jsonObjects = extractJSONObjects(stripped);
|
|
179
|
+
const results = [];
|
|
180
|
+
for (const obj of jsonObjects) {
|
|
181
|
+
const block = parseToolCallJSON(obj, nameSet);
|
|
182
|
+
if (block !== null)
|
|
183
|
+
results.push(block);
|
|
184
|
+
}
|
|
185
|
+
return results;
|
|
186
|
+
}
|
|
187
|
+
//# sourceMappingURL=text-tool-extractor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"text-tool-extractor.js","sourceRoot":"","sources":["../../src/tool/text-tool-extractor.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
CHANGED
|
@@ -72,7 +72,7 @@ export interface LLMResponse {
|
|
|
72
72
|
* - `error` — an unrecoverable error occurred; `data` is an `Error`
|
|
73
73
|
*/
|
|
74
74
|
export interface StreamEvent {
|
|
75
|
-
readonly type: 'text' | 'tool_use' | 'tool_result' | 'done' | 'error';
|
|
75
|
+
readonly type: 'text' | 'tool_use' | 'tool_result' | 'loop_detected' | 'done' | 'error';
|
|
76
76
|
readonly data: unknown;
|
|
77
77
|
}
|
|
78
78
|
/** The serialisable tool schema sent to the LLM provider. */
|
|
@@ -145,11 +145,18 @@ export interface ToolDefinition<TInput = Record<string, unknown>> {
|
|
|
145
145
|
readonly inputSchema: ZodSchema<TInput>;
|
|
146
146
|
execute(input: TInput, context: ToolUseContext): Promise<ToolResult>;
|
|
147
147
|
}
|
|
148
|
+
/** Context passed to the {@link AgentConfig.beforeRun} hook. */
|
|
149
|
+
export interface BeforeRunHookContext {
|
|
150
|
+
/** The user prompt text. */
|
|
151
|
+
readonly prompt: string;
|
|
152
|
+
/** The agent's static configuration. */
|
|
153
|
+
readonly agent: AgentConfig;
|
|
154
|
+
}
|
|
148
155
|
/** Static configuration for a single agent. */
|
|
149
156
|
export interface AgentConfig {
|
|
150
157
|
readonly name: string;
|
|
151
158
|
readonly model: string;
|
|
152
|
-
readonly provider?: 'anthropic' | 'copilot' | 'openai';
|
|
159
|
+
readonly provider?: 'anthropic' | 'copilot' | 'grok' | 'openai' | 'gemini';
|
|
153
160
|
/**
|
|
154
161
|
* Custom base URL for OpenAI-compatible APIs (Ollama, vLLM, LM Studio, etc.).
|
|
155
162
|
* Note: local servers that don't require auth still need `apiKey` set to a
|
|
@@ -164,12 +171,64 @@ export interface AgentConfig {
|
|
|
164
171
|
readonly maxTurns?: number;
|
|
165
172
|
readonly maxTokens?: number;
|
|
166
173
|
readonly temperature?: number;
|
|
174
|
+
/**
|
|
175
|
+
* Maximum wall-clock time (in milliseconds) for the entire agent run.
|
|
176
|
+
* When exceeded, the run is aborted via `AbortSignal.timeout()`.
|
|
177
|
+
* Useful for local models where inference can be unpredictably slow.
|
|
178
|
+
*/
|
|
179
|
+
readonly timeoutMs?: number;
|
|
180
|
+
/**
|
|
181
|
+
* Loop detection configuration. When set, the agent tracks repeated tool
|
|
182
|
+
* calls and text outputs to detect stuck loops before `maxTurns` is reached.
|
|
183
|
+
*/
|
|
184
|
+
readonly loopDetection?: LoopDetectionConfig;
|
|
167
185
|
/**
|
|
168
186
|
* Optional Zod schema for structured output. When set, the agent's final
|
|
169
187
|
* output is parsed as JSON and validated against this schema. A single
|
|
170
188
|
* retry with error feedback is attempted on validation failure.
|
|
171
189
|
*/
|
|
172
190
|
readonly outputSchema?: ZodSchema;
|
|
191
|
+
/**
|
|
192
|
+
* Called before each agent run. Receives the prompt and agent config.
|
|
193
|
+
* Return a (possibly modified) context to continue, or throw to abort the run.
|
|
194
|
+
* Only `prompt` from the returned context is applied; `agent` is read-only informational.
|
|
195
|
+
*/
|
|
196
|
+
readonly beforeRun?: (context: BeforeRunHookContext) => Promise<BeforeRunHookContext> | BeforeRunHookContext;
|
|
197
|
+
/**
|
|
198
|
+
* Called after each agent run completes successfully. Receives the run result.
|
|
199
|
+
* Return a (possibly modified) result, or throw to mark the run as failed.
|
|
200
|
+
* Not called when the run throws. For error observation, handle errors at the call site.
|
|
201
|
+
*/
|
|
202
|
+
readonly afterRun?: (result: AgentRunResult) => Promise<AgentRunResult> | AgentRunResult;
|
|
203
|
+
}
|
|
204
|
+
/** Configuration for agent loop detection. */
|
|
205
|
+
export interface LoopDetectionConfig {
|
|
206
|
+
/**
|
|
207
|
+
* Maximum consecutive times the same tool call (name + args) or text
|
|
208
|
+
* output can repeat before detection triggers. Default: `3`.
|
|
209
|
+
*/
|
|
210
|
+
readonly maxRepetitions?: number;
|
|
211
|
+
/**
|
|
212
|
+
* Number of recent turns to track for repetition analysis. Default: `4`.
|
|
213
|
+
*/
|
|
214
|
+
readonly loopDetectionWindow?: number;
|
|
215
|
+
/**
|
|
216
|
+
* Action to take when a loop is detected.
|
|
217
|
+
* - `'warn'` — inject a "you appear stuck" message, give the LLM one
|
|
218
|
+
* more chance; terminate if the loop persists (default)
|
|
219
|
+
* - `'terminate'` — stop the run immediately
|
|
220
|
+
* - `function` — custom callback (sync or async); return `'continue'`,
|
|
221
|
+
* `'inject'`, or `'terminate'` to control the outcome
|
|
222
|
+
*/
|
|
223
|
+
readonly onLoopDetected?: 'warn' | 'terminate' | ((info: LoopDetectionInfo) => 'continue' | 'inject' | 'terminate' | Promise<'continue' | 'inject' | 'terminate'>);
|
|
224
|
+
}
|
|
225
|
+
/** Diagnostic payload emitted when a loop is detected. */
|
|
226
|
+
export interface LoopDetectionInfo {
|
|
227
|
+
readonly kind: 'tool_repetition' | 'text_repetition';
|
|
228
|
+
/** Number of consecutive identical occurrences observed. */
|
|
229
|
+
readonly repetitions: number;
|
|
230
|
+
/** Human-readable description of the detected loop. */
|
|
231
|
+
readonly detail: string;
|
|
173
232
|
}
|
|
174
233
|
/** Lifecycle state tracked during an agent run. */
|
|
175
234
|
export interface AgentState {
|
|
@@ -199,6 +258,8 @@ export interface AgentRunResult {
|
|
|
199
258
|
* failed after retry.
|
|
200
259
|
*/
|
|
201
260
|
readonly structured?: unknown;
|
|
261
|
+
/** True when the run was terminated or warned due to loop detection. */
|
|
262
|
+
readonly loopDetected?: boolean;
|
|
202
263
|
}
|
|
203
264
|
/** Static configuration for a team of cooperating agents. */
|
|
204
265
|
export interface TeamConfig {
|
|
@@ -215,7 +276,7 @@ export interface TeamRunResult {
|
|
|
215
276
|
readonly totalTokenUsage: TokenUsage;
|
|
216
277
|
}
|
|
217
278
|
/** Valid states for a {@link Task}. */
|
|
218
|
-
export type TaskStatus = 'pending' | 'in_progress' | 'completed' | 'failed' | 'blocked';
|
|
279
|
+
export type TaskStatus = 'pending' | 'in_progress' | 'completed' | 'failed' | 'blocked' | 'skipped';
|
|
219
280
|
/** A discrete unit of work tracked by the orchestrator. */
|
|
220
281
|
export interface Task {
|
|
221
282
|
readonly id: string;
|
|
@@ -236,9 +297,14 @@ export interface Task {
|
|
|
236
297
|
/** Exponential backoff multiplier (default: 2). */
|
|
237
298
|
readonly retryBackoff?: number;
|
|
238
299
|
}
|
|
239
|
-
/**
|
|
300
|
+
/**
|
|
301
|
+
* Progress event emitted by the orchestrator during a run.
|
|
302
|
+
*
|
|
303
|
+
* **v0.3 addition:** `'task_skipped'` — consumers with exhaustive switches
|
|
304
|
+
* on `type` will need to add a case for this variant.
|
|
305
|
+
*/
|
|
240
306
|
export interface OrchestratorEvent {
|
|
241
|
-
readonly type: 'agent_start' | 'agent_complete' | 'task_start' | 'task_complete' | 'task_retry' | 'message' | 'error';
|
|
307
|
+
readonly type: 'agent_start' | 'agent_complete' | 'task_start' | 'task_complete' | 'task_skipped' | 'task_retry' | 'message' | 'error';
|
|
242
308
|
readonly agent?: string;
|
|
243
309
|
readonly task?: string;
|
|
244
310
|
readonly data?: unknown;
|
|
@@ -247,11 +313,77 @@ export interface OrchestratorEvent {
|
|
|
247
313
|
export interface OrchestratorConfig {
|
|
248
314
|
readonly maxConcurrency?: number;
|
|
249
315
|
readonly defaultModel?: string;
|
|
250
|
-
readonly defaultProvider?: 'anthropic' | 'copilot' | 'openai';
|
|
316
|
+
readonly defaultProvider?: 'anthropic' | 'copilot' | 'grok' | 'openai' | 'gemini';
|
|
251
317
|
readonly defaultBaseURL?: string;
|
|
252
318
|
readonly defaultApiKey?: string;
|
|
253
|
-
onProgress?: (event: OrchestratorEvent) => void;
|
|
319
|
+
readonly onProgress?: (event: OrchestratorEvent) => void;
|
|
320
|
+
readonly onTrace?: (event: TraceEvent) => void | Promise<void>;
|
|
321
|
+
/**
|
|
322
|
+
* Optional approval gate called between task execution rounds.
|
|
323
|
+
*
|
|
324
|
+
* After a batch of tasks completes, this callback receives all
|
|
325
|
+
* completed {@link Task}s from that round and the list of tasks about
|
|
326
|
+
* to start next. Return `true` to continue or `false` to abort —
|
|
327
|
+
* remaining tasks will be marked `'skipped'`.
|
|
328
|
+
*
|
|
329
|
+
* Not called when:
|
|
330
|
+
* - No tasks succeeded in the round (all failed).
|
|
331
|
+
* - No pending tasks remain after the round (final batch).
|
|
332
|
+
*
|
|
333
|
+
* **Note:** Do not mutate the {@link Task} objects passed to this
|
|
334
|
+
* callback — they are live references to queue state. Mutation is
|
|
335
|
+
* undefined behavior.
|
|
336
|
+
*/
|
|
337
|
+
readonly onApproval?: (completedTasks: readonly Task[], nextTasks: readonly Task[]) => Promise<boolean>;
|
|
338
|
+
}
|
|
339
|
+
/** Trace event type discriminants. */
|
|
340
|
+
export type TraceEventType = 'llm_call' | 'tool_call' | 'task' | 'agent';
|
|
341
|
+
/** Shared fields present on every trace event. */
|
|
342
|
+
export interface TraceEventBase {
|
|
343
|
+
/** Unique identifier for the entire run (runTeam / runTasks / runAgent call). */
|
|
344
|
+
readonly runId: string;
|
|
345
|
+
readonly type: TraceEventType;
|
|
346
|
+
/** Unix epoch ms when the span started. */
|
|
347
|
+
readonly startMs: number;
|
|
348
|
+
/** Unix epoch ms when the span ended. */
|
|
349
|
+
readonly endMs: number;
|
|
350
|
+
/** Wall-clock duration in milliseconds (`endMs - startMs`). */
|
|
351
|
+
readonly durationMs: number;
|
|
352
|
+
/** Agent name associated with this span. */
|
|
353
|
+
readonly agent: string;
|
|
354
|
+
/** Task ID associated with this span. */
|
|
355
|
+
readonly taskId?: string;
|
|
356
|
+
}
|
|
357
|
+
/** Emitted for each LLM API call (one per agent turn). */
|
|
358
|
+
export interface LLMCallTrace extends TraceEventBase {
|
|
359
|
+
readonly type: 'llm_call';
|
|
360
|
+
readonly model: string;
|
|
361
|
+
readonly turn: number;
|
|
362
|
+
readonly tokens: TokenUsage;
|
|
363
|
+
}
|
|
364
|
+
/** Emitted for each tool execution. */
|
|
365
|
+
export interface ToolCallTrace extends TraceEventBase {
|
|
366
|
+
readonly type: 'tool_call';
|
|
367
|
+
readonly tool: string;
|
|
368
|
+
readonly isError: boolean;
|
|
369
|
+
}
|
|
370
|
+
/** Emitted when a task completes (wraps the full retry sequence). */
|
|
371
|
+
export interface TaskTrace extends TraceEventBase {
|
|
372
|
+
readonly type: 'task';
|
|
373
|
+
readonly taskId: string;
|
|
374
|
+
readonly taskTitle: string;
|
|
375
|
+
readonly success: boolean;
|
|
376
|
+
readonly retries: number;
|
|
377
|
+
}
|
|
378
|
+
/** Emitted when an agent run completes (wraps the full conversation loop). */
|
|
379
|
+
export interface AgentTrace extends TraceEventBase {
|
|
380
|
+
readonly type: 'agent';
|
|
381
|
+
readonly turns: number;
|
|
382
|
+
readonly tokens: TokenUsage;
|
|
383
|
+
readonly toolCalls: number;
|
|
254
384
|
}
|
|
385
|
+
/** Discriminated union of all trace event types. */
|
|
386
|
+
export type TraceEvent = LLMCallTrace | ToolCallTrace | TaskTrace | AgentTrace;
|
|
255
387
|
/** A single key-value record stored in a {@link MemoryStore}. */
|
|
256
388
|
export interface MemoryEntry {
|
|
257
389
|
readonly key: string;
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,KAAK,CAAA;AAMpC,sEAAsE;AACtE,MAAM,WAAW,SAAS;IACxB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;CACtB;AAED;;;GAGG;AACH,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,IAAI,EAAE,UAAU,CAAA;IACzB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;IACrB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CACxC;AAED;;;GAGG;AACH,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,IAAI,EAAE,aAAa,CAAA;IAC5B,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAA;IAC5B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAA;IACxB,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAC5B;AAED,iEAAiE;AACjE,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAA;IACtB,QAAQ,CAAC,MAAM,EAAE;QACf,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAA;QACvB,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAA;QAC3B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAA;KACtB,CAAA;CACF;AAED,wEAAwE;AACxE,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,YAAY,GAAG,eAAe,GAAG,UAAU,CAAA;AAMlF;;;GAGG;AACH,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,CAAA;IACnC,QAAQ,CAAC,OAAO,EAAE,YAAY,EAAE,CAAA;CACjC;AAED,8CAA8C;AAC9C,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAA;IAC7B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAA;CAC/B;AAED,+EAA+E;AAC/E,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAA;IACnB,QAAQ,CAAC,OAAO,EAAE,YAAY,EAAE,CAAA;IAChC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAA;IACtB,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAA;IAC5B,QAAQ,CAAC,KAAK,EAAE,UAAU,CAAA;CAC3B;AAMD;;;;;;;;GAQG;AACH,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,aAAa,GAAG,MAAM,GAAG,OAAO,CAAA;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Trace emission utilities for the observability layer.
|
|
3
|
+
*/
|
|
4
|
+
import type { TraceEvent } from '../types.js';
|
|
5
|
+
/**
|
|
6
|
+
* Safely emit a trace event. Swallows callback errors so a broken
|
|
7
|
+
* subscriber never crashes agent execution.
|
|
8
|
+
*/
|
|
9
|
+
export declare function emitTrace(fn: ((event: TraceEvent) => void | Promise<void>) | undefined, event: TraceEvent): void;
|
|
10
|
+
/** Generate a unique run ID for trace correlation. */
|
|
11
|
+
export declare function generateRunId(): string;
|
|
12
|
+
//# sourceMappingURL=trace.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trace.d.ts","sourceRoot":"","sources":["../../src/utils/trace.ts"],"names":[],"mappings":"AAAA;;GAEG;AAGH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAE7C;;;GAGG;AACH,wBAAgB,SAAS,CACvB,EAAE,EAAE,CAAC,CAAC,KAAK,EAAE,UAAU,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,SAAS,EAC7D,KAAK,EAAE,UAAU,GAChB,IAAI,CAYN;AAID,sDAAsD;AACtD,wBAAgB,aAAa,IAAI,MAAM,CAEtC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @fileoverview Trace emission utilities for the observability layer.
|
|
3
|
+
*/
|
|
4
|
+
import { randomUUID } from 'node:crypto';
|
|
5
|
+
/**
|
|
6
|
+
* Safely emit a trace event. Swallows callback errors so a broken
|
|
7
|
+
* subscriber never crashes agent execution.
|
|
8
|
+
*/
|
|
9
|
+
export function emitTrace(fn, event) {
|
|
10
|
+
if (!fn)
|
|
11
|
+
return;
|
|
12
|
+
try {
|
|
13
|
+
// Guard async callbacks: if fn returns a Promise, swallow its rejection
|
|
14
|
+
// so an async onTrace never produces an unhandled promise rejection.
|
|
15
|
+
const result = fn(event);
|
|
16
|
+
if (result && typeof result.catch === 'function') {
|
|
17
|
+
;
|
|
18
|
+
result.catch(noop);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
catch {
|
|
22
|
+
// Intentionally swallowed — observability must never break execution.
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
function noop() { }
|
|
26
|
+
/** Generate a unique run ID for trace correlation. */
|
|
27
|
+
export function generateRunId() {
|
|
28
|
+
return randomUUID();
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=trace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trace.js","sourceRoot":"","sources":["../../src/utils/trace.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAGxC;;;GAGG;AACH,MAAM,UAAU,SAAS,CACvB,EAA6D,EAC7D,KAAiB;IAEjB,IAAI,CAAC,EAAE;QAAE,OAAM;IACf,IAAI,CAAC;QACH,wEAAwE;QACxE,qEAAqE;QACrE,MAAM,MAAM,GAAG,EAAE,CAAC,KAAK,CAAY,CAAA;QACnC,IAAI,MAAM,IAAI,OAAQ,MAA2B,CAAC,KAAK,KAAK,UAAU,EAAE,CAAC;YACvE,CAAC;YAAC,MAA2B,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;QAC3C,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,sEAAsE;IACxE,CAAC;AACH,CAAC;AAED,SAAS,IAAI,KAAI,CAAC;AAElB,sDAAsD;AACtD,MAAM,UAAU,aAAa;IAC3B,OAAO,UAAU,EAAE,CAAA;AACrB,CAAC"}
|
|
@@ -64,6 +64,7 @@ Your review MUST include these sections:
|
|
|
64
64
|
Be specific and constructive. Reference line numbers or function names when possible.`,
|
|
65
65
|
tools: ['file_read'],
|
|
66
66
|
maxTurns: 4,
|
|
67
|
+
timeoutMs: 120_000, // 2 min — local models can be slow
|
|
67
68
|
}
|
|
68
69
|
|
|
69
70
|
// ---------------------------------------------------------------------------
|