@producible/cereworker-core 26.520.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/LICENSE +21 -0
- package/dist/abort.d.ts +5 -0
- package/dist/abort.d.ts.map +1 -0
- package/dist/abort.js +36 -0
- package/dist/abort.js.map +1 -0
- package/dist/context.d.ts +20 -0
- package/dist/context.d.ts.map +1 -0
- package/dist/context.js +45 -0
- package/dist/context.js.map +1 -0
- package/dist/conversation.d.ts +48 -0
- package/dist/conversation.d.ts.map +1 -0
- package/dist/conversation.js +358 -0
- package/dist/conversation.js.map +1 -0
- package/dist/discovery.d.ts +32 -0
- package/dist/discovery.d.ts.map +1 -0
- package/dist/discovery.js +165 -0
- package/dist/discovery.js.map +1 -0
- package/dist/events.d.ts +222 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +25 -0
- package/dist/events.js.map +1 -0
- package/dist/http-tools.d.ts +8 -0
- package/dist/http-tools.d.ts.map +1 -0
- package/dist/http-tools.js +137 -0
- package/dist/http-tools.js.map +1 -0
- package/dist/index.d.ts +34 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/instance.d.ts +56 -0
- package/dist/instance.d.ts.map +1 -0
- package/dist/instance.js +136 -0
- package/dist/instance.js.map +1 -0
- package/dist/legacy-sqlite.d.ts +6 -0
- package/dist/legacy-sqlite.d.ts.map +1 -0
- package/dist/legacy-sqlite.js +90 -0
- package/dist/legacy-sqlite.js.map +1 -0
- package/dist/logger.d.ts +15 -0
- package/dist/logger.d.ts.map +1 -0
- package/dist/logger.js +53 -0
- package/dist/logger.js.map +1 -0
- package/dist/orchestrator.d.ts +321 -0
- package/dist/orchestrator.d.ts.map +1 -0
- package/dist/orchestrator.js +2610 -0
- package/dist/orchestrator.js.map +1 -0
- package/dist/pairing.d.ts +41 -0
- package/dist/pairing.d.ts.map +1 -0
- package/dist/pairing.js +215 -0
- package/dist/pairing.js.map +1 -0
- package/dist/plan-store.d.ts +33 -0
- package/dist/plan-store.d.ts.map +1 -0
- package/dist/plan-store.js +113 -0
- package/dist/plan-store.js.map +1 -0
- package/dist/proactive.d.ts +64 -0
- package/dist/proactive.d.ts.map +1 -0
- package/dist/proactive.js +179 -0
- package/dist/proactive.js.map +1 -0
- package/dist/sub-agent-manager.d.ts +45 -0
- package/dist/sub-agent-manager.d.ts.map +1 -0
- package/dist/sub-agent-manager.js +509 -0
- package/dist/sub-agent-manager.js.map +1 -0
- package/dist/sub-agent-tools.d.ts +4 -0
- package/dist/sub-agent-tools.d.ts.map +1 -0
- package/dist/sub-agent-tools.js +94 -0
- package/dist/sub-agent-tools.js.map +1 -0
- package/dist/system-prompt.d.ts +34 -0
- package/dist/system-prompt.d.ts.map +1 -0
- package/dist/system-prompt.js +256 -0
- package/dist/system-prompt.js.map +1 -0
- package/dist/task-schedule.d.ts +13 -0
- package/dist/task-schedule.d.ts.map +1 -0
- package/dist/task-schedule.js +201 -0
- package/dist/task-schedule.js.map +1 -0
- package/dist/task-store.d.ts +22 -0
- package/dist/task-store.d.ts.map +1 -0
- package/dist/task-store.js +141 -0
- package/dist/task-store.js.map +1 -0
- package/dist/text-store.d.ts +18 -0
- package/dist/text-store.d.ts.map +1 -0
- package/dist/text-store.js +212 -0
- package/dist/text-store.js.map +1 -0
- package/dist/tool-runtime.d.ts +76 -0
- package/dist/tool-runtime.d.ts.map +1 -0
- package/dist/tool-runtime.js +443 -0
- package/dist/tool-runtime.js.map +1 -0
- package/dist/types.d.ts +392 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/package.json +31 -0
|
@@ -0,0 +1,509 @@
|
|
|
1
|
+
import { nanoid } from 'nanoid';
|
|
2
|
+
import { existsSync, mkdirSync, writeFileSync, readFileSync, appendFileSync, readdirSync, rmSync, } from 'node:fs';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { homedir } from 'node:os';
|
|
5
|
+
import { ConversationStore } from './conversation.js';
|
|
6
|
+
import { createAbortError, throwIfAborted } from './abort.js';
|
|
7
|
+
import { ToolRuntime } from './tool-runtime.js';
|
|
8
|
+
export class SubAgentManager {
|
|
9
|
+
agents = new Map();
|
|
10
|
+
cerebrum;
|
|
11
|
+
tools;
|
|
12
|
+
maxConcurrent;
|
|
13
|
+
baseDir;
|
|
14
|
+
toolRuntime;
|
|
15
|
+
onProgress;
|
|
16
|
+
constructor(opts) {
|
|
17
|
+
this.cerebrum = opts.cerebrum;
|
|
18
|
+
this.tools = opts.tools;
|
|
19
|
+
this.maxConcurrent = opts.maxConcurrent ?? 5;
|
|
20
|
+
this.baseDir = opts.baseDir ?? join(homedir(), '.cereworker', 'agents');
|
|
21
|
+
this.toolRuntime = opts.toolRuntime ?? new ToolRuntime();
|
|
22
|
+
this.onProgress = opts.onProgress;
|
|
23
|
+
this.ensureDir(this.baseDir);
|
|
24
|
+
}
|
|
25
|
+
ensureDir(dir) {
|
|
26
|
+
if (!existsSync(dir)) {
|
|
27
|
+
mkdirSync(dir, { recursive: true });
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
async spawn(task, opts) {
|
|
31
|
+
const running = this.listAgents().filter((a) => a.status === 'running' || a.status === 'pending');
|
|
32
|
+
if (running.length >= this.maxConcurrent) {
|
|
33
|
+
throw new Error(`Max concurrent sub-agents (${this.maxConcurrent}) reached`);
|
|
34
|
+
}
|
|
35
|
+
const id = nanoid(10);
|
|
36
|
+
const sessionKey = `agent:main:subagent:${id}`;
|
|
37
|
+
const agentDir = join(this.baseDir, id);
|
|
38
|
+
const memoryDir = join(agentDir, 'memory');
|
|
39
|
+
this.ensureDir(agentDir);
|
|
40
|
+
this.ensureDir(memoryDir);
|
|
41
|
+
// Initialize empty MEMORY.md for the agent
|
|
42
|
+
writeFileSync(join(memoryDir, 'MEMORY.md'), '', 'utf-8');
|
|
43
|
+
const conversation = new ConversationStore(join(agentDir, 'conversations.db'));
|
|
44
|
+
const conv = conversation.create();
|
|
45
|
+
const timeoutMs = opts?.timeoutMs ?? 5 * 60_000;
|
|
46
|
+
const instance = {
|
|
47
|
+
id,
|
|
48
|
+
sessionKey,
|
|
49
|
+
parentSessionKey: opts?.parentSessionKey ?? 'agent:main',
|
|
50
|
+
task,
|
|
51
|
+
label: opts?.label,
|
|
52
|
+
status: 'pending',
|
|
53
|
+
cleanup: opts?.cleanup ?? 'delete',
|
|
54
|
+
spawnedAt: Date.now(),
|
|
55
|
+
lastActivityAt: Date.now(),
|
|
56
|
+
timeoutMs,
|
|
57
|
+
deadlineAt: timeoutMs > 0 ? Date.now() + timeoutMs : 0,
|
|
58
|
+
retryCount: 0,
|
|
59
|
+
conversation,
|
|
60
|
+
conversationId: conv.id,
|
|
61
|
+
agentDir,
|
|
62
|
+
abortController: new AbortController(),
|
|
63
|
+
messagesCount: 0,
|
|
64
|
+
toolCallsCount: 0,
|
|
65
|
+
};
|
|
66
|
+
this.agents.set(id, instance);
|
|
67
|
+
this.saveSessionMeta(instance);
|
|
68
|
+
// Run agent asynchronously (fire and forget, errors are captured)
|
|
69
|
+
this.runAgent(instance).catch(() => {
|
|
70
|
+
// Errors are already handled inside runAgent
|
|
71
|
+
});
|
|
72
|
+
return id;
|
|
73
|
+
}
|
|
74
|
+
getAgent(id) {
|
|
75
|
+
const instance = this.agents.get(id);
|
|
76
|
+
if (!instance)
|
|
77
|
+
return null;
|
|
78
|
+
return this.toState(instance);
|
|
79
|
+
}
|
|
80
|
+
listAgents() {
|
|
81
|
+
return Array.from(this.agents.values()).map((i) => this.toState(i));
|
|
82
|
+
}
|
|
83
|
+
getSummary() {
|
|
84
|
+
const agents = this.listAgents();
|
|
85
|
+
return {
|
|
86
|
+
total: agents.length,
|
|
87
|
+
running: agents.filter((a) => a.status === 'running' || a.status === 'pending').length,
|
|
88
|
+
completed: agents.filter((a) => a.status === 'completed').length,
|
|
89
|
+
failed: agents.filter((a) => a.status === 'failed' || a.status === 'timeout' || a.status === 'cancelled').length,
|
|
90
|
+
};
|
|
91
|
+
}
|
|
92
|
+
cancel(id) {
|
|
93
|
+
const instance = this.agents.get(id);
|
|
94
|
+
if (!instance)
|
|
95
|
+
return;
|
|
96
|
+
if (instance.status !== 'running' && instance.status !== 'pending')
|
|
97
|
+
return;
|
|
98
|
+
instance.abortController.abort();
|
|
99
|
+
instance.status = 'cancelled';
|
|
100
|
+
this.saveSessionMeta(instance);
|
|
101
|
+
}
|
|
102
|
+
timeout(id) {
|
|
103
|
+
const instance = this.agents.get(id);
|
|
104
|
+
if (!instance)
|
|
105
|
+
return;
|
|
106
|
+
if (instance.status !== 'running' && instance.status !== 'pending')
|
|
107
|
+
return;
|
|
108
|
+
instance.abortController.abort();
|
|
109
|
+
instance.status = 'timeout';
|
|
110
|
+
this.saveSessionMeta(instance);
|
|
111
|
+
}
|
|
112
|
+
async retry(id) {
|
|
113
|
+
const instance = this.agents.get(id);
|
|
114
|
+
if (!instance)
|
|
115
|
+
throw new Error(`Agent ${id} not found`);
|
|
116
|
+
if (instance.status === 'running' || instance.status === 'pending') {
|
|
117
|
+
throw new Error(`Agent ${id} is still running`);
|
|
118
|
+
}
|
|
119
|
+
// Re-spawn with same task in the same directory
|
|
120
|
+
instance.status = 'pending';
|
|
121
|
+
instance.retryCount++;
|
|
122
|
+
instance.lastActivityAt = Date.now();
|
|
123
|
+
instance.abortController = new AbortController();
|
|
124
|
+
instance.result = undefined;
|
|
125
|
+
instance.error = undefined;
|
|
126
|
+
// Create a new conversation for the retry
|
|
127
|
+
const conv = instance.conversation.create();
|
|
128
|
+
instance.conversationId = conv.id;
|
|
129
|
+
instance.messagesCount = 0;
|
|
130
|
+
instance.toolCallsCount = 0;
|
|
131
|
+
this.saveSessionMeta(instance);
|
|
132
|
+
this.runAgent(instance).catch(() => { });
|
|
133
|
+
return id;
|
|
134
|
+
}
|
|
135
|
+
ping(id) {
|
|
136
|
+
const instance = this.agents.get(id);
|
|
137
|
+
if (!instance || instance.status !== 'running')
|
|
138
|
+
return;
|
|
139
|
+
instance.conversation.appendMessage(instance.conversationId, 'system', 'You appear to be stalled. Please continue working on your task or report your findings.');
|
|
140
|
+
instance.lastActivityAt = Date.now();
|
|
141
|
+
instance.messagesCount++;
|
|
142
|
+
}
|
|
143
|
+
prune(maxAgeMs = 30 * 60_000) {
|
|
144
|
+
const now = Date.now();
|
|
145
|
+
for (const [id, instance] of this.agents) {
|
|
146
|
+
if (instance.status === 'running' || instance.status === 'pending')
|
|
147
|
+
continue;
|
|
148
|
+
if (now - instance.lastActivityAt < maxAgeMs)
|
|
149
|
+
continue;
|
|
150
|
+
if (instance.cleanup === 'delete') {
|
|
151
|
+
try {
|
|
152
|
+
rmSync(instance.agentDir, { recursive: true, force: true });
|
|
153
|
+
}
|
|
154
|
+
catch {
|
|
155
|
+
// Ignore cleanup errors
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
this.agents.delete(id);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
readTranscript(id) {
|
|
162
|
+
const instance = this.agents.get(id);
|
|
163
|
+
if (!instance)
|
|
164
|
+
return null;
|
|
165
|
+
return instance.conversation.getMessages(instance.conversationId);
|
|
166
|
+
}
|
|
167
|
+
async runAgent(instance) {
|
|
168
|
+
instance.status = 'running';
|
|
169
|
+
this.saveSessionMeta(instance);
|
|
170
|
+
// No setTimeout — the Cerebellum monitors agent lifecycle via heartbeat
|
|
171
|
+
try {
|
|
172
|
+
const agentTools = this.createAgentTools(instance);
|
|
173
|
+
// Check if this is a resume (conversation already has messages)
|
|
174
|
+
const existingMessages = instance.conversation.getMessages(instance.conversationId);
|
|
175
|
+
const isResume = existingMessages.length > 0;
|
|
176
|
+
if (isResume) {
|
|
177
|
+
instance.conversation.appendMessage(instance.conversationId, 'system', 'You are being resumed after a restart. Review the conversation above and continue working on your task. Use report_progress to report your current status.');
|
|
178
|
+
instance.messagesCount++;
|
|
179
|
+
}
|
|
180
|
+
else {
|
|
181
|
+
// Send the task as the first message
|
|
182
|
+
const toolNames = Array.from(agentTools.keys()).join(', ');
|
|
183
|
+
const timeLimit = instance.timeoutMs > 0
|
|
184
|
+
? `You have ${Math.round(instance.timeoutMs / 60000)} minutes.`
|
|
185
|
+
: 'You have no time limit — take as long as needed.';
|
|
186
|
+
const systemMsg = `You are a sub-agent with a focused task. ${timeLimit}\n` +
|
|
187
|
+
`Available tools: ${toolNames}\n` +
|
|
188
|
+
`Work autonomously — do not ask questions. Use memory_write to save findings.\n` +
|
|
189
|
+
`For long tasks, call report_progress periodically to report your status.\n` +
|
|
190
|
+
`When done, clearly state: what you found, what you did, and whether it succeeded.`;
|
|
191
|
+
instance.conversation.appendMessage(instance.conversationId, 'system', systemMsg);
|
|
192
|
+
instance.conversation.appendMessage(instance.conversationId, 'user', instance.task);
|
|
193
|
+
instance.messagesCount += 2;
|
|
194
|
+
this.appendTranscript(instance, { role: 'system', content: systemMsg });
|
|
195
|
+
this.appendTranscript(instance, { role: 'user', content: instance.task });
|
|
196
|
+
}
|
|
197
|
+
// Stream the cerebrum response
|
|
198
|
+
const messages = instance.conversation.getMessages(instance.conversationId);
|
|
199
|
+
const toolDefs = Object.fromEntries(agentTools);
|
|
200
|
+
let fullContent = '';
|
|
201
|
+
await new Promise((resolve, reject) => {
|
|
202
|
+
if (instance.abortController.signal.aborted) {
|
|
203
|
+
reject(createAbortError('Agent aborted'));
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
const abortHandler = () => reject(createAbortError('Agent aborted'));
|
|
207
|
+
instance.abortController.signal.addEventListener('abort', abortHandler, { once: true });
|
|
208
|
+
this.cerebrum
|
|
209
|
+
.stream(messages, toolDefs, {
|
|
210
|
+
onChunk: (chunk) => {
|
|
211
|
+
fullContent += chunk;
|
|
212
|
+
instance.lastActivityAt = Date.now();
|
|
213
|
+
},
|
|
214
|
+
onToolCall: async (toolCall) => {
|
|
215
|
+
instance.lastActivityAt = Date.now();
|
|
216
|
+
instance.toolCallsCount++;
|
|
217
|
+
const requestedToolName = toolCall.name;
|
|
218
|
+
const { toolName, result } = await this.toolRuntime.execute({
|
|
219
|
+
toolCall,
|
|
220
|
+
tools: agentTools,
|
|
221
|
+
conversationId: instance.conversationId,
|
|
222
|
+
sessionKey: instance.sessionKey,
|
|
223
|
+
scopeKey: instance.sessionKey,
|
|
224
|
+
abortSignal: instance.abortController.signal,
|
|
225
|
+
});
|
|
226
|
+
throwIfAborted(instance.abortController.signal, 'Agent aborted');
|
|
227
|
+
instance.conversation.appendMessage(instance.conversationId, 'tool', result.output, {
|
|
228
|
+
toolResult: result,
|
|
229
|
+
metadata: {
|
|
230
|
+
toolName,
|
|
231
|
+
...(requestedToolName !== toolName ? { requestedToolName } : {}),
|
|
232
|
+
},
|
|
233
|
+
});
|
|
234
|
+
instance.messagesCount++;
|
|
235
|
+
this.appendTranscript(instance, { role: 'tool', content: result.output, toolName });
|
|
236
|
+
return result;
|
|
237
|
+
},
|
|
238
|
+
onFinish: (content, toolCalls) => {
|
|
239
|
+
instance.conversation.appendMessage(instance.conversationId, 'cerebrum', content, toolCalls?.length ? { toolCalls } : undefined);
|
|
240
|
+
instance.messagesCount++;
|
|
241
|
+
instance.result = content;
|
|
242
|
+
this.appendTranscript(instance, { role: 'cerebrum', content });
|
|
243
|
+
instance.abortController.signal.removeEventListener('abort', abortHandler);
|
|
244
|
+
resolve();
|
|
245
|
+
},
|
|
246
|
+
onError: (error) => {
|
|
247
|
+
instance.abortController.signal.removeEventListener('abort', abortHandler);
|
|
248
|
+
reject(error);
|
|
249
|
+
},
|
|
250
|
+
}, { abortSignal: instance.abortController.signal })
|
|
251
|
+
.catch(reject);
|
|
252
|
+
});
|
|
253
|
+
instance.status = 'completed';
|
|
254
|
+
}
|
|
255
|
+
catch (err) {
|
|
256
|
+
if (instance.abortController.signal.aborted) {
|
|
257
|
+
// Check if it was a timeout or manual cancel (status may have been
|
|
258
|
+
// set to 'cancelled' externally by cancel())
|
|
259
|
+
if (instance.status !== 'cancelled') {
|
|
260
|
+
instance.status = 'timeout';
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
instance.status = 'failed';
|
|
265
|
+
instance.error = err instanceof Error ? err.message : String(err);
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
finally {
|
|
269
|
+
this.saveSessionMeta(instance);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
createAgentTools(instance) {
|
|
273
|
+
const agentTools = new Map();
|
|
274
|
+
const agentDir = instance.agentDir;
|
|
275
|
+
const memoryDir = join(agentDir, 'memory');
|
|
276
|
+
// Copy shared tools (shell, file ops, etc.) but NOT sub-agent tools (no recursion)
|
|
277
|
+
for (const [name, tool] of this.tools) {
|
|
278
|
+
if (name === 'spawn_agent' || name === 'query_agents' || name === 'cancel_agent') {
|
|
279
|
+
continue;
|
|
280
|
+
}
|
|
281
|
+
// Replace memory tools with agent-scoped versions
|
|
282
|
+
if (name.startsWith('memory_')) {
|
|
283
|
+
continue;
|
|
284
|
+
}
|
|
285
|
+
agentTools.set(name, tool);
|
|
286
|
+
}
|
|
287
|
+
// Agent-scoped memory tools
|
|
288
|
+
agentTools.set('memory_read', {
|
|
289
|
+
description: 'Read your memory file (MEMORY.md or a daily log)',
|
|
290
|
+
parameters: {
|
|
291
|
+
file: { type: 'string', description: 'Optional memory file name (defaults to MEMORY.md)', required: false },
|
|
292
|
+
},
|
|
293
|
+
execute: async (args) => {
|
|
294
|
+
const file = args.file ?? 'MEMORY.md';
|
|
295
|
+
const safeName = file.replace(/[/\\]/g, '');
|
|
296
|
+
const path = join(memoryDir, safeName);
|
|
297
|
+
if (!existsSync(path))
|
|
298
|
+
return `File "${file}" not found.`;
|
|
299
|
+
return readFileSync(path, 'utf-8') || '(empty file)';
|
|
300
|
+
},
|
|
301
|
+
});
|
|
302
|
+
agentTools.set('memory_write', {
|
|
303
|
+
description: 'Write/update your MEMORY.md file',
|
|
304
|
+
parameters: {
|
|
305
|
+
content: { type: 'string', description: 'The full content to write to MEMORY.md', required: true },
|
|
306
|
+
},
|
|
307
|
+
execute: async (args) => {
|
|
308
|
+
const content = args.content;
|
|
309
|
+
writeFileSync(join(memoryDir, 'MEMORY.md'), content, 'utf-8');
|
|
310
|
+
return 'MEMORY.md updated successfully.';
|
|
311
|
+
},
|
|
312
|
+
});
|
|
313
|
+
agentTools.set('memory_log', {
|
|
314
|
+
description: "Append a note to today's daily log",
|
|
315
|
+
parameters: {
|
|
316
|
+
content: { type: 'string', description: 'The note content to append to today\'s log', required: true },
|
|
317
|
+
},
|
|
318
|
+
execute: async (args) => {
|
|
319
|
+
const content = args.content;
|
|
320
|
+
const today = new Date().toISOString().slice(0, 10);
|
|
321
|
+
const entry = `\n---\n_${new Date().toISOString()}_\n\n${content}\n`;
|
|
322
|
+
appendFileSync(join(memoryDir, `${today}.md`), entry, 'utf-8');
|
|
323
|
+
return `Logged to ${today}.md`;
|
|
324
|
+
},
|
|
325
|
+
});
|
|
326
|
+
agentTools.set('memory_search', {
|
|
327
|
+
description: 'Search across your memory files',
|
|
328
|
+
parameters: {
|
|
329
|
+
query: { type: 'string', description: 'The text to search for across memory files', required: true },
|
|
330
|
+
},
|
|
331
|
+
execute: async (args) => {
|
|
332
|
+
const query = args.query.toLowerCase();
|
|
333
|
+
const files = existsSync(memoryDir)
|
|
334
|
+
? readdirSync(memoryDir).filter((f) => f.endsWith('.md'))
|
|
335
|
+
: [];
|
|
336
|
+
const results = [];
|
|
337
|
+
for (const file of files) {
|
|
338
|
+
const content = readFileSync(join(memoryDir, file), 'utf-8');
|
|
339
|
+
if (content.toLowerCase().includes(query)) {
|
|
340
|
+
const lines = content
|
|
341
|
+
.split('\n')
|
|
342
|
+
.filter((l) => l.toLowerCase().includes(query))
|
|
343
|
+
.slice(0, 5);
|
|
344
|
+
results.push(`## ${file}\n${lines.join('\n')}`);
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
return results.length > 0 ? results.join('\n\n') : `No matches found for "${query}"`;
|
|
348
|
+
},
|
|
349
|
+
});
|
|
350
|
+
agentTools.set('report_progress', {
|
|
351
|
+
description: 'Report your current progress. Call periodically during long-running tasks so the system knows you are active.',
|
|
352
|
+
parameters: {
|
|
353
|
+
note: { type: 'string', description: 'Brief description of current status', required: true },
|
|
354
|
+
percent: { type: 'number', description: 'Estimated completion percentage (0-100)', required: false },
|
|
355
|
+
},
|
|
356
|
+
execute: async (args) => {
|
|
357
|
+
const { note, percent } = args;
|
|
358
|
+
instance.progressNote = note;
|
|
359
|
+
instance.progressPercent = percent;
|
|
360
|
+
instance.lastProgressAt = Date.now();
|
|
361
|
+
instance.lastActivityAt = Date.now();
|
|
362
|
+
this.saveSessionMeta(instance);
|
|
363
|
+
this.onProgress?.(instance.id, note, percent);
|
|
364
|
+
return 'Progress reported.';
|
|
365
|
+
},
|
|
366
|
+
});
|
|
367
|
+
return agentTools;
|
|
368
|
+
}
|
|
369
|
+
saveSessionMeta(instance) {
|
|
370
|
+
const meta = {
|
|
371
|
+
id: instance.id,
|
|
372
|
+
sessionKey: instance.sessionKey,
|
|
373
|
+
parentSessionKey: instance.parentSessionKey,
|
|
374
|
+
task: instance.task,
|
|
375
|
+
label: instance.label,
|
|
376
|
+
status: instance.status,
|
|
377
|
+
cleanup: instance.cleanup,
|
|
378
|
+
spawnedAt: instance.spawnedAt,
|
|
379
|
+
lastActivityAt: instance.lastActivityAt,
|
|
380
|
+
timeoutMs: instance.timeoutMs,
|
|
381
|
+
deadlineAt: instance.deadlineAt,
|
|
382
|
+
conversationId: instance.conversationId,
|
|
383
|
+
result: instance.result,
|
|
384
|
+
error: instance.error,
|
|
385
|
+
messagesCount: instance.messagesCount,
|
|
386
|
+
toolCallsCount: instance.toolCallsCount,
|
|
387
|
+
retryCount: instance.retryCount,
|
|
388
|
+
progressNote: instance.progressNote,
|
|
389
|
+
progressPercent: instance.progressPercent,
|
|
390
|
+
lastProgressAt: instance.lastProgressAt,
|
|
391
|
+
};
|
|
392
|
+
try {
|
|
393
|
+
writeFileSync(join(instance.agentDir, 'session.json'), JSON.stringify(meta, null, 2), 'utf-8');
|
|
394
|
+
}
|
|
395
|
+
catch {
|
|
396
|
+
// Ignore write errors
|
|
397
|
+
}
|
|
398
|
+
}
|
|
399
|
+
appendTranscript(instance, entry) {
|
|
400
|
+
const line = JSON.stringify({
|
|
401
|
+
...entry,
|
|
402
|
+
timestamp: Date.now(),
|
|
403
|
+
});
|
|
404
|
+
try {
|
|
405
|
+
appendFileSync(join(instance.agentDir, 'transcript.jsonl'), line + '\n', 'utf-8');
|
|
406
|
+
}
|
|
407
|
+
catch {
|
|
408
|
+
// Ignore write errors
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
async recoverFromDisk() {
|
|
412
|
+
const recovered = [];
|
|
413
|
+
if (!existsSync(this.baseDir))
|
|
414
|
+
return recovered;
|
|
415
|
+
const dirs = readdirSync(this.baseDir, { withFileTypes: true })
|
|
416
|
+
.filter((d) => d.isDirectory());
|
|
417
|
+
for (const dir of dirs) {
|
|
418
|
+
const sessionPath = join(this.baseDir, dir.name, 'session.json');
|
|
419
|
+
if (!existsSync(sessionPath))
|
|
420
|
+
continue;
|
|
421
|
+
try {
|
|
422
|
+
const meta = JSON.parse(readFileSync(sessionPath, 'utf-8'));
|
|
423
|
+
if (meta.status !== 'running' && meta.status !== 'pending')
|
|
424
|
+
continue;
|
|
425
|
+
if (this.agents.has(meta.id))
|
|
426
|
+
continue;
|
|
427
|
+
// Check if deadline expired with no recent progress
|
|
428
|
+
const now = Date.now();
|
|
429
|
+
if (meta.deadlineAt && meta.deadlineAt > 0 && now > meta.deadlineAt) {
|
|
430
|
+
const hasRecentProgress = meta.lastProgressAt && (now - meta.lastProgressAt) < 5 * 60_000;
|
|
431
|
+
if (!hasRecentProgress) {
|
|
432
|
+
meta.status = 'timeout';
|
|
433
|
+
writeFileSync(sessionPath, JSON.stringify(meta, null, 2), 'utf-8');
|
|
434
|
+
continue;
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
const agentDir = join(this.baseDir, dir.name);
|
|
438
|
+
const dbPath = join(agentDir, 'conversations.db');
|
|
439
|
+
if (!existsSync(dbPath))
|
|
440
|
+
continue;
|
|
441
|
+
const conversation = new ConversationStore(dbPath);
|
|
442
|
+
const instance = {
|
|
443
|
+
id: meta.id,
|
|
444
|
+
sessionKey: meta.sessionKey,
|
|
445
|
+
parentSessionKey: meta.parentSessionKey ?? 'agent:main',
|
|
446
|
+
task: meta.task,
|
|
447
|
+
label: meta.label,
|
|
448
|
+
status: 'pending',
|
|
449
|
+
cleanup: meta.cleanup ?? 'keep',
|
|
450
|
+
spawnedAt: meta.spawnedAt,
|
|
451
|
+
lastActivityAt: now,
|
|
452
|
+
timeoutMs: meta.timeoutMs ?? 0,
|
|
453
|
+
deadlineAt: meta.deadlineAt ?? 0,
|
|
454
|
+
retryCount: meta.retryCount ?? 0,
|
|
455
|
+
conversation,
|
|
456
|
+
conversationId: meta.conversationId,
|
|
457
|
+
agentDir,
|
|
458
|
+
abortController: new AbortController(),
|
|
459
|
+
messagesCount: meta.messagesCount ?? 0,
|
|
460
|
+
toolCallsCount: meta.toolCallsCount ?? 0,
|
|
461
|
+
progressNote: meta.progressNote,
|
|
462
|
+
progressPercent: meta.progressPercent,
|
|
463
|
+
lastProgressAt: meta.lastProgressAt,
|
|
464
|
+
result: undefined,
|
|
465
|
+
error: undefined,
|
|
466
|
+
};
|
|
467
|
+
this.agents.set(meta.id, instance);
|
|
468
|
+
this.runAgent(instance).catch(() => { });
|
|
469
|
+
recovered.push(meta.id);
|
|
470
|
+
}
|
|
471
|
+
catch {
|
|
472
|
+
// Skip malformed session files
|
|
473
|
+
}
|
|
474
|
+
}
|
|
475
|
+
return recovered;
|
|
476
|
+
}
|
|
477
|
+
persistAllRunning() {
|
|
478
|
+
for (const instance of this.agents.values()) {
|
|
479
|
+
if (instance.status === 'running' || instance.status === 'pending') {
|
|
480
|
+
this.saveSessionMeta(instance);
|
|
481
|
+
}
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
toState(instance) {
|
|
485
|
+
return {
|
|
486
|
+
id: instance.id,
|
|
487
|
+
sessionKey: instance.sessionKey,
|
|
488
|
+
parentSessionKey: instance.parentSessionKey,
|
|
489
|
+
task: instance.task,
|
|
490
|
+
label: instance.label,
|
|
491
|
+
status: instance.status,
|
|
492
|
+
cleanup: instance.cleanup,
|
|
493
|
+
spawnedAt: instance.spawnedAt,
|
|
494
|
+
lastActivityAt: instance.lastActivityAt,
|
|
495
|
+
timeoutMs: instance.timeoutMs,
|
|
496
|
+
result: instance.result,
|
|
497
|
+
error: instance.error,
|
|
498
|
+
messagesCount: instance.messagesCount,
|
|
499
|
+
toolCallsCount: instance.toolCallsCount,
|
|
500
|
+
retryCount: instance.retryCount,
|
|
501
|
+
memoryDir: join(instance.agentDir, 'memory'),
|
|
502
|
+
progressNote: instance.progressNote,
|
|
503
|
+
progressPercent: instance.progressPercent,
|
|
504
|
+
lastProgressAt: instance.lastProgressAt,
|
|
505
|
+
deadlineAt: instance.deadlineAt,
|
|
506
|
+
};
|
|
507
|
+
}
|
|
508
|
+
}
|
|
509
|
+
//# sourceMappingURL=sub-agent-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sub-agent-manager.js","sourceRoot":"","sources":["../src/sub-agent-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,EACL,UAAU,EACV,SAAS,EACT,aAAa,EACb,YAAY,EACZ,cAAc,EACd,WAAW,EACX,MAAM,GACP,MAAM,SAAS,CAAC;AACjB,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AA6ChD,MAAM,OAAO,eAAe;IAClB,MAAM,GAAG,IAAI,GAAG,EAA4B,CAAC;IAC7C,QAAQ,CAAkB;IAC1B,KAAK,CAA8B;IACnC,aAAa,CAAS;IACtB,OAAO,CAAS;IAChB,WAAW,CAAc;IACzB,UAAU,CAA6D;IAE/E,YAAY,IAA4B;QACtC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC;QAC7C,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;QACxE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,IAAI,IAAI,WAAW,EAAE,CAAC;QACzD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAEO,SAAS,CAAC,GAAW;QAC3B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YACrB,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK,CACT,IAAY,EACZ,IAKC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,IAAI,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC;QAClG,IAAI,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACzC,MAAM,IAAI,KAAK,CAAC,8BAA8B,IAAI,CAAC,aAAa,WAAW,CAAC,CAAC;QAC/E,CAAC;QAED,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QACtB,MAAM,UAAU,GAAG,uBAAuB,EAAE,EAAE,CAAC;QAC/C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;QACxC,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAE3C,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACzB,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAE1B,2CAA2C;QAC3C,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,CAAC;QAEzD,MAAM,YAAY,GAAG,IAAI,iBAAiB,CAAC,IAAI,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC,CAAC;QAC/E,MAAM,IAAI,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC;QAEnC,MAAM,SAAS,GAAG,IAAI,EAAE,SAAS,IAAI,CAAC,GAAG,MAAM,CAAC;QAChD,MAAM,QAAQ,GAAqB;YACjC,EAAE;YACF,UAAU;YACV,gBAAgB,EAAE,IAAI,EAAE,gBAAgB,IAAI,YAAY;YACxD,IAAI;YACJ,KAAK,EAAE,IAAI,EAAE,KAAK;YAClB,MAAM,EAAE,SAAS;YACjB,OAAO,EAAE,IAAI,EAAE,OAAO,IAAI,QAAQ;YAClC,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,cAAc,EAAE,IAAI,CAAC,GAAG,EAAE;YAC1B,SAAS;YACT,UAAU,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YACtD,UAAU,EAAE,CAAC;YACb,YAAY;YACZ,cAAc,EAAE,IAAI,CAAC,EAAE;YACvB,QAAQ;YACR,eAAe,EAAE,IAAI,eAAe,EAAE;YACtC,aAAa,EAAE,CAAC;YAChB,cAAc,EAAE,CAAC;SAClB,CAAC;QAEF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;QAC9B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAE/B,kEAAkE;QAClE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE;YACjC,6CAA6C;QAC/C,CAAC,CAAC,CAAC;QAEH,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,QAAQ,CAAC,EAAU;QACjB,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ;YAAE,OAAO,IAAI,CAAC;QAC3B,OAAO,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAChC,CAAC;IAED,UAAU;QACR,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;IACtE,CAAC;IAED,UAAU;QACR,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QACjC,OAAO;YACL,KAAK,EAAE,MAAM,CAAC,MAAM;YACpB,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,SAAS,IAAI,CAAC,CAAC,MAAM,KAAK,SAAS,CAAC,CAAC,MAAM;YACtF,SAAS,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,MAAM;YAChE,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,QAAQ,IAAI,CAAC,CAAC,MAAM,KAAK,SAAS,IAAI,CAAC,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,MAAM;SACjH,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,EAAU;QACf,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ;YAAE,OAAO;QACtB,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS;YAAE,OAAO;QAE3E,QAAQ,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;QACjC,QAAQ,CAAC,MAAM,GAAG,WAAW,CAAC;QAC9B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAED,OAAO,CAAC,EAAU;QAChB,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ;YAAE,OAAO;QACtB,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS;YAAE,OAAO;QAE3E,QAAQ,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC;QACjC,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,EAAU;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ;YAAE,MAAM,IAAI,KAAK,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;QACxD,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;YACnE,MAAM,IAAI,KAAK,CAAC,SAAS,EAAE,mBAAmB,CAAC,CAAC;QAClD,CAAC;QAED,gDAAgD;QAChD,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAC;QAC5B,QAAQ,CAAC,UAAU,EAAE,CAAC;QACtB,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACrC,QAAQ,CAAC,eAAe,GAAG,IAAI,eAAe,EAAE,CAAC;QACjD,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAC;QAC5B,QAAQ,CAAC,KAAK,GAAG,SAAS,CAAC;QAE3B,0CAA0C;QAC1C,MAAM,IAAI,GAAG,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;QAC5C,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC;QAClC,QAAQ,CAAC,aAAa,GAAG,CAAC,CAAC;QAC3B,QAAQ,CAAC,cAAc,GAAG,CAAC,CAAC;QAE5B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAE/B,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QAExC,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,IAAI,CAAC,EAAU;QACb,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS;YAAE,OAAO;QAEvD,QAAQ,CAAC,YAAY,CAAC,aAAa,CACjC,QAAQ,CAAC,cAAc,EACvB,QAAQ,EACR,yFAAyF,CAC1F,CAAC;QACF,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACrC,QAAQ,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED,KAAK,CAAC,WAAmB,EAAE,GAAG,MAAM;QAClC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,KAAK,MAAM,CAAC,EAAE,EAAE,QAAQ,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;YACzC,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS;gBAAE,SAAS;YAC7E,IAAI,GAAG,GAAG,QAAQ,CAAC,cAAc,GAAG,QAAQ;gBAAE,SAAS;YAEvD,IAAI,QAAQ,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;gBAClC,IAAI,CAAC;oBACH,MAAM,CAAC,QAAQ,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC9D,CAAC;gBAAC,MAAM,CAAC;oBACP,wBAAwB;gBAC1B,CAAC;YACH,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;IAED,cAAc,CAAC,EAAU;QACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ;YAAE,OAAO,IAAI,CAAC;QAC3B,OAAO,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IACpE,CAAC;IAEO,KAAK,CAAC,QAAQ,CAAC,QAA0B;QAC/C,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QAE/B,wEAAwE;QAExE,IAAI,CAAC;YACH,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;YAEnD,gEAAgE;YAChE,MAAM,gBAAgB,GAAG,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;YACpF,MAAM,QAAQ,GAAG,gBAAgB,CAAC,MAAM,GAAG,CAAC,CAAC;YAE7C,IAAI,QAAQ,EAAE,CAAC;gBACb,QAAQ,CAAC,YAAY,CAAC,aAAa,CACjC,QAAQ,CAAC,cAAc,EACvB,QAAQ,EACR,4JAA4J,CAC7J,CAAC;gBACF,QAAQ,CAAC,aAAa,EAAE,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,qCAAqC;gBACrC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC3D,MAAM,SAAS,GAAG,QAAQ,CAAC,SAAS,GAAG,CAAC;oBACtC,CAAC,CAAC,YAAY,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,GAAG,KAAK,CAAC,WAAW;oBAC/D,CAAC,CAAC,kDAAkD,CAAC;gBACvD,MAAM,SAAS,GACb,4CAA4C,SAAS,IAAI;oBACzD,oBAAoB,SAAS,IAAI;oBACjC,gFAAgF;oBAChF,4EAA4E;oBAC5E,mFAAmF,CAAC;gBACtF,QAAQ,CAAC,YAAY,CAAC,aAAa,CACjC,QAAQ,CAAC,cAAc,EACvB,QAAQ,EACR,SAAS,CACV,CAAC;gBACF,QAAQ,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;gBACpF,QAAQ,CAAC,aAAa,IAAI,CAAC,CAAC;gBAC5B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;gBACxE,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,IAAI,EAAE,CAAC,CAAC;YAC5E,CAAC;YAED,+BAA+B;YAC/B,MAAM,QAAQ,GAAG,QAAQ,CAAC,YAAY,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;YAC5E,MAAM,QAAQ,GAAG,MAAM,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;YAChD,IAAI,WAAW,GAAG,EAAE,CAAC;YAErB,MAAM,IAAI,OAAO,CAAO,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;gBAC1C,IAAI,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;oBAC5C,MAAM,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC,CAAC;oBAC1C,OAAO;gBACT,CAAC;gBAED,MAAM,YAAY,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC,CAAC;gBACrE,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;gBAExF,IAAI,CAAC,QAAQ;qBACV,MAAM,CAAC,QAAQ,EAAE,QAAQ,EAAE;oBAC1B,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;wBACjB,WAAW,IAAI,KAAK,CAAC;wBACrB,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;oBACvC,CAAC;oBACD,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE;wBAC7B,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;wBACrC,QAAQ,CAAC,cAAc,EAAE,CAAC;wBAC1B,MAAM,iBAAiB,GAAG,QAAQ,CAAC,IAAI,CAAC;wBACxC,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC;4BAC1D,QAAQ;4BACR,KAAK,EAAE,UAAU;4BACjB,cAAc,EAAE,QAAQ,CAAC,cAAc;4BACvC,UAAU,EAAE,QAAQ,CAAC,UAAU;4BAC/B,QAAQ,EAAE,QAAQ,CAAC,UAAU;4BAC7B,WAAW,EAAE,QAAQ,CAAC,eAAe,CAAC,MAAM;yBAC7C,CAAC,CAAC;wBAEH,cAAc,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC;wBAEjE,QAAQ,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CAAC,cAAc,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE;4BAClF,UAAU,EAAE,MAAM;4BAClB,QAAQ,EAAE;gCACR,QAAQ;gCACR,GAAG,CAAC,iBAAiB,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,iBAAiB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;6BACjE;yBACF,CAAC,CAAC;wBACH,QAAQ,CAAC,aAAa,EAAE,CAAC;wBACzB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;wBACpF,OAAO,MAAM,CAAC;oBAChB,CAAC;oBACD,QAAQ,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,EAAE;wBAC/B,QAAQ,CAAC,YAAY,CAAC,aAAa,CACjC,QAAQ,CAAC,cAAc,EAAE,UAAU,EAAE,OAAO,EAC5C,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC,SAAS,CAC9C,CAAC;wBACF,QAAQ,CAAC,aAAa,EAAE,CAAC;wBACzB,QAAQ,CAAC,MAAM,GAAG,OAAO,CAAC;wBAC1B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,CAAC;wBAE/D,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;wBAC3E,OAAO,EAAE,CAAC;oBACZ,CAAC;oBACD,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;wBACjB,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC;wBAC3E,MAAM,CAAC,KAAK,CAAC,CAAC;oBAChB,CAAC;iBACF,EAAE,EAAE,WAAW,EAAE,QAAQ,CAAC,eAAe,CAAC,MAAM,EAAE,CAAC;qBACnD,KAAK,CAAC,MAAM,CAAC,CAAC;YACnB,CAAC,CAAC,CAAC;YAEH,QAAQ,CAAC,MAAM,GAAG,WAAW,CAAC;QAChC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,QAAQ,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;gBAC5C,mEAAmE;gBACnE,6CAA6C;gBAC7C,IAAK,QAAQ,CAAC,MAAiB,KAAK,WAAW,EAAE,CAAC;oBAChD,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAC;gBAC9B,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC,MAAM,GAAG,QAAQ,CAAC;gBAC3B,QAAQ,CAAC,KAAK,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YACpE,CAAC;QACH,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IAEO,gBAAgB,CAAC,QAA0B;QACjD,MAAM,UAAU,GAAG,IAAI,GAAG,EAA0B,CAAC;QACrD,MAAM,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC;QACnC,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAC;QAE3C,mFAAmF;QACnF,KAAK,MAAM,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACtC,IAAI,IAAI,KAAK,aAAa,IAAI,IAAI,KAAK,cAAc,IAAI,IAAI,KAAK,cAAc,EAAE,CAAC;gBACjF,SAAS;YACX,CAAC;YACD,kDAAkD;YAClD,IAAI,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC;gBAC/B,SAAS;YACX,CAAC;YACD,UAAU,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAC7B,CAAC;QAED,4BAA4B;QAC5B,UAAU,CAAC,GAAG,CAAC,aAAa,EAAE;YAC5B,WAAW,EAAE,kDAAkD;YAC/D,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mDAAmD,EAAE,QAAQ,EAAE,KAAK,EAAE;aAC5G;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,IAAI,GAAI,IAA0B,CAAC,IAAI,IAAI,WAAW,CAAC;gBAC7D,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;gBAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;gBACvC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;oBAAE,OAAO,SAAS,IAAI,cAAc,CAAC;gBAC1D,OAAO,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,cAAc,CAAC;YACvD,CAAC;SACF,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,CAAC,cAAc,EAAE;YAC7B,WAAW,EAAE,kCAAkC;YAC/C,UAAU,EAAE;gBACV,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,wCAAwC,EAAE,QAAQ,EAAE,IAAI,EAAE;aACnG;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,OAAO,GAAI,IAA4B,CAAC,OAAO,CAAC;gBACtD,aAAa,CAAC,IAAI,CAAC,SAAS,EAAE,WAAW,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;gBAC9D,OAAO,iCAAiC,CAAC;YAC3C,CAAC;SACF,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,CAAC,YAAY,EAAE;YAC3B,WAAW,EAAE,oCAAoC;YACjD,UAAU,EAAE;gBACV,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,4CAA4C,EAAE,QAAQ,EAAE,IAAI,EAAE;aACvG;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,OAAO,GAAI,IAA4B,CAAC,OAAO,CAAC;gBACtD,MAAM,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;gBACpD,MAAM,KAAK,GAAG,WAAW,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,QAAQ,OAAO,IAAI,CAAC;gBACrE,cAAc,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,KAAK,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;gBAC/D,OAAO,aAAa,KAAK,KAAK,CAAC;YACjC,CAAC;SACF,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,CAAC,eAAe,EAAE;YAC9B,WAAW,EAAE,iCAAiC;YAC9C,UAAU,EAAE;gBACV,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,4CAA4C,EAAE,QAAQ,EAAE,IAAI,EAAE;aACrG;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,KAAK,GAAI,IAA0B,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;gBAC9D,MAAM,KAAK,GAAG,UAAU,CAAC,SAAS,CAAC;oBACjC,CAAC,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;oBACzD,CAAC,CAAC,EAAE,CAAC;gBACP,MAAM,OAAO,GAAa,EAAE,CAAC;gBAE7B,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;oBACzB,MAAM,OAAO,GAAG,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;oBAC7D,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;wBAC1C,MAAM,KAAK,GAAG,OAAO;6BAClB,KAAK,CAAC,IAAI,CAAC;6BACX,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;6BAC9C,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;wBACf,OAAO,CAAC,IAAI,CAAC,MAAM,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBAClD,CAAC;gBACH,CAAC;gBAED,OAAO,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,yBAAyB,KAAK,GAAG,CAAC;YACvF,CAAC;SACF,CAAC,CAAC;QAEH,UAAU,CAAC,GAAG,CAAC,iBAAiB,EAAE;YAChC,WAAW,EAAE,+GAA+G;YAC5H,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,qCAAqC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAC5F,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,yCAAyC,EAAE,QAAQ,EAAE,KAAK,EAAE;aACrG;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,IAA0C,CAAC;gBACrE,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC;gBAC7B,QAAQ,CAAC,eAAe,GAAG,OAAO,CAAC;gBACnC,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACrC,QAAQ,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACrC,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAC/B,IAAI,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,CAAC;gBAC9C,OAAO,oBAAoB,CAAC;YAC9B,CAAC;SACF,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC;IACpB,CAAC;IAEO,eAAe,CAAC,QAA0B;QAChD,MAAM,IAAI,GAAG;YACX,EAAE,EAAE,QAAQ,CAAC,EAAE;YACf,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;YAC3C,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,MAAM,EAAE,QAAQ,CAAC,MAAM;YACvB,OAAO,EAAE,QAAQ,CAAC,OAAO;YACzB,SAAS,EAAE,QAAQ,CAAC,SAAS;YAC7B,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,SAAS,EAAE,QAAQ,CAAC,SAAS;YAC7B,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,MAAM,EAAE,QAAQ,CAAC,MAAM;YACvB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,aAAa,EAAE,QAAQ,CAAC,aAAa;YACrC,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,YAAY,EAAE,QAAQ,CAAC,YAAY;YACnC,eAAe,EAAE,QAAQ,CAAC,eAAe;YACzC,cAAc,EAAE,QAAQ,CAAC,cAAc;SACxC,CAAC;QAEF,IAAI,CAAC;YACH,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,cAAc,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;QACjG,CAAC;QAAC,MAAM,CAAC;YACP,sBAAsB;QACxB,CAAC;IACH,CAAC;IAEO,gBAAgB,CACtB,QAA0B,EAC1B,KAA2D;QAE3D,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC;YAC1B,GAAG,KAAK;YACR,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;SACtB,CAAC,CAAC;QAEH,IAAI,CAAC;YACH,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,kBAAkB,CAAC,EAAE,IAAI,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC;QACpF,CAAC;QAAC,MAAM,CAAC;YACP,sBAAsB;QACxB,CAAC;IACH,CAAC;IAED,KAAK,CAAC,eAAe;QACnB,MAAM,SAAS,GAAa,EAAE,CAAC;QAC/B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC;YAAE,OAAO,SAAS,CAAC;QAEhD,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;aAC5D,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;QAElC,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;YACjE,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC;gBAAE,SAAS;YAEvC,IAAI,CAAC;gBACH,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,WAAW,EAAE,OAAO,CAAC,CAAC,CAAC;gBAC5D,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS;oBAAE,SAAS;gBACrE,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;oBAAE,SAAS;gBAEvC,oDAAoD;gBACpD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBACvB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;oBACpE,MAAM,iBAAiB,GAAG,IAAI,CAAC,cAAc,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC;oBAC1F,IAAI,CAAC,iBAAiB,EAAE,CAAC;wBACvB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;wBACxB,aAAa,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;wBACnE,SAAS;oBACX,CAAC;gBACH,CAAC;gBAED,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;gBAC9C,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,kBAAkB,CAAC,CAAC;gBAClD,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;oBAAE,SAAS;gBAElC,MAAM,YAAY,GAAG,IAAI,iBAAiB,CAAC,MAAM,CAAC,CAAC;gBACnD,MAAM,QAAQ,GAAqB;oBACjC,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,gBAAgB,EAAE,IAAI,CAAC,gBAAgB,IAAI,YAAY;oBACvD,IAAI,EAAE,IAAI,CAAC,IAAI;oBACf,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,MAAM,EAAE,SAAS;oBACjB,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,MAAM;oBAC/B,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,cAAc,EAAE,GAAG;oBACnB,SAAS,EAAE,IAAI,CAAC,SAAS,IAAI,CAAC;oBAC9B,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,CAAC;oBAChC,UAAU,EAAE,IAAI,CAAC,UAAU,IAAI,CAAC;oBAChC,YAAY;oBACZ,cAAc,EAAE,IAAI,CAAC,cAAc;oBACnC,QAAQ;oBACR,eAAe,EAAE,IAAI,eAAe,EAAE;oBACtC,aAAa,EAAE,IAAI,CAAC,aAAa,IAAI,CAAC;oBACtC,cAAc,EAAE,IAAI,CAAC,cAAc,IAAI,CAAC;oBACxC,YAAY,EAAE,IAAI,CAAC,YAAY;oBAC/B,eAAe,EAAE,IAAI,CAAC,eAAe;oBACrC,cAAc,EAAE,IAAI,CAAC,cAAc;oBACnC,MAAM,EAAE,SAAS;oBACjB,KAAK,EAAE,SAAS;iBACjB,CAAC;gBAEF,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC;gBACnC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;gBACxC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1B,CAAC;YAAC,MAAM,CAAC;gBACP,+BAA+B;YACjC,CAAC;QACH,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,iBAAiB;QACf,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC;YAC5C,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,IAAI,QAAQ,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;gBACnE,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;YACjC,CAAC;QACH,CAAC;IACH,CAAC;IAEO,OAAO,CAAC,QAA0B;QACxC,OAAO;YACL,EAAE,EAAE,QAAQ,CAAC,EAAE;YACf,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,gBAAgB,EAAE,QAAQ,CAAC,gBAAgB;YAC3C,IAAI,EAAE,QAAQ,CAAC,IAAI;YACnB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,MAAM,EAAE,QAAQ,CAAC,MAAM;YACvB,OAAO,EAAE,QAAQ,CAAC,OAAO;YACzB,SAAS,EAAE,QAAQ,CAAC,SAAS;YAC7B,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,SAAS,EAAE,QAAQ,CAAC,SAAS;YAC7B,MAAM,EAAE,QAAQ,CAAC,MAAM;YACvB,KAAK,EAAE,QAAQ,CAAC,KAAK;YACrB,aAAa,EAAE,QAAQ,CAAC,aAAa;YACrC,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,QAAQ,CAAC;YAC5C,YAAY,EAAE,QAAQ,CAAC,YAAY;YACnC,eAAe,EAAE,QAAQ,CAAC,eAAe;YACzC,cAAc,EAAE,QAAQ,CAAC,cAAc;YACvC,UAAU,EAAE,QAAQ,CAAC,UAAU;SAChC,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ToolDefinition } from './orchestrator.js';
|
|
2
|
+
import type { SubAgentManager } from './sub-agent-manager.js';
|
|
3
|
+
export declare function createSubAgentTools(manager: SubAgentManager): Record<string, ToolDefinition>;
|
|
4
|
+
//# sourceMappingURL=sub-agent-tools.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sub-agent-tools.d.ts","sourceRoot":"","sources":["../src/sub-agent-tools.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,wBAAgB,mBAAmB,CAAC,OAAO,EAAE,eAAe,GAAG,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAyG5F"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
export function createSubAgentTools(manager) {
|
|
2
|
+
return {
|
|
3
|
+
spawn_agent: {
|
|
4
|
+
description: 'Spawn a sub-agent to handle a task in the background. Returns the agent ID. The sub-agent has its own isolated memory and conversation.',
|
|
5
|
+
parameters: {
|
|
6
|
+
task: { type: 'string', description: 'The task for the sub-agent to complete', required: true },
|
|
7
|
+
timeoutMinutes: { type: 'number', description: 'Max lifetime in minutes (default: 5, 0 = unlimited)', required: false },
|
|
8
|
+
label: { type: 'string', description: 'Optional short label for the agent', required: false },
|
|
9
|
+
cleanup: {
|
|
10
|
+
type: 'string',
|
|
11
|
+
description: '"delete" to remove after completion, "keep" to persist (default: delete)',
|
|
12
|
+
required: false,
|
|
13
|
+
},
|
|
14
|
+
longRunning: {
|
|
15
|
+
type: 'boolean',
|
|
16
|
+
description: 'Set true for long-running tasks — sets unlimited timeout and keeps session files for recovery',
|
|
17
|
+
required: false,
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
execute: async (args) => {
|
|
21
|
+
const { task, timeoutMinutes, label, cleanup, longRunning } = args;
|
|
22
|
+
const effectiveTimeout = longRunning ? 0 : (timeoutMinutes || 5) * 60_000;
|
|
23
|
+
const effectiveCleanup = longRunning ? 'keep' : (cleanup === 'keep' ? 'keep' : 'delete');
|
|
24
|
+
try {
|
|
25
|
+
const id = await manager.spawn(task, {
|
|
26
|
+
timeoutMs: effectiveTimeout,
|
|
27
|
+
label,
|
|
28
|
+
cleanup: effectiveCleanup,
|
|
29
|
+
});
|
|
30
|
+
return `Sub-agent ${id} spawned${label ? ` (${label})` : ''}. Use query_agents to check status.`;
|
|
31
|
+
}
|
|
32
|
+
catch (err) {
|
|
33
|
+
return `Failed to spawn agent: ${err instanceof Error ? err.message : String(err)}`;
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
query_agents: {
|
|
38
|
+
description: 'Query the status of all sub-agents, or a specific one by ID. Returns status, task, result, and other details.',
|
|
39
|
+
parameters: {
|
|
40
|
+
agentId: { type: 'string', description: 'Optional: query a specific agent by ID', required: false },
|
|
41
|
+
},
|
|
42
|
+
execute: async (args) => {
|
|
43
|
+
const { agentId } = args;
|
|
44
|
+
if (agentId) {
|
|
45
|
+
const agent = manager.getAgent(agentId);
|
|
46
|
+
if (!agent)
|
|
47
|
+
return `Agent ${agentId} not found.`;
|
|
48
|
+
return JSON.stringify(agent, null, 2);
|
|
49
|
+
}
|
|
50
|
+
const agents = manager.listAgents();
|
|
51
|
+
if (agents.length === 0)
|
|
52
|
+
return 'No sub-agents.';
|
|
53
|
+
const summary = manager.getSummary();
|
|
54
|
+
const header = `${summary.total} agents: ${summary.running} running, ${summary.completed} completed, ${summary.failed} failed\n`;
|
|
55
|
+
const list = agents
|
|
56
|
+
.map((a) => {
|
|
57
|
+
const elapsed = Math.round((Date.now() - a.spawnedAt) / 1000);
|
|
58
|
+
const line = `- [${a.status}] ${a.id}${a.label ? ` (${a.label})` : ''}: ${a.task.slice(0, 80)}${a.task.length > 80 ? '...' : ''} (${elapsed}s)`;
|
|
59
|
+
if (a.progressNote) {
|
|
60
|
+
const pct = a.progressPercent != null ? ` [${a.progressPercent}%]` : '';
|
|
61
|
+
return `${line}\n Progress: ${a.progressNote}${pct}`;
|
|
62
|
+
}
|
|
63
|
+
if (a.status === 'completed' && a.result) {
|
|
64
|
+
return `${line}\n Result: ${a.result.slice(0, 200)}${a.result.length > 200 ? '...' : ''}`;
|
|
65
|
+
}
|
|
66
|
+
if (a.error) {
|
|
67
|
+
return `${line}\n Error: ${a.error}`;
|
|
68
|
+
}
|
|
69
|
+
return line;
|
|
70
|
+
})
|
|
71
|
+
.join('\n');
|
|
72
|
+
return header + list;
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
cancel_agent: {
|
|
76
|
+
description: 'Cancel a running sub-agent by ID.',
|
|
77
|
+
parameters: {
|
|
78
|
+
agentId: { type: 'string', description: 'The agent ID to cancel', required: true },
|
|
79
|
+
},
|
|
80
|
+
execute: async (args) => {
|
|
81
|
+
const { agentId } = args;
|
|
82
|
+
const agent = manager.getAgent(agentId);
|
|
83
|
+
if (!agent)
|
|
84
|
+
return `Agent ${agentId} not found.`;
|
|
85
|
+
if (agent.status !== 'running' && agent.status !== 'pending') {
|
|
86
|
+
return `Agent ${agentId} is already ${agent.status}.`;
|
|
87
|
+
}
|
|
88
|
+
manager.cancel(agentId);
|
|
89
|
+
return `Agent ${agentId} cancelled.`;
|
|
90
|
+
},
|
|
91
|
+
},
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=sub-agent-tools.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sub-agent-tools.js","sourceRoot":"","sources":["../src/sub-agent-tools.ts"],"names":[],"mappings":"AAGA,MAAM,UAAU,mBAAmB,CAAC,OAAwB;IAC1D,OAAO;QACL,WAAW,EAAE;YACX,WAAW,EACT,yIAAyI;YAC3I,UAAU,EAAE;gBACV,IAAI,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,wCAAwC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAC/F,cAAc,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,qDAAqD,EAAE,QAAQ,EAAE,KAAK,EAAE;gBACvH,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,oCAAoC,EAAE,QAAQ,EAAE,KAAK,EAAE;gBAC7F,OAAO,EAAE;oBACP,IAAI,EAAE,QAAQ;oBACd,WAAW,EAAE,0EAA0E;oBACvF,QAAQ,EAAE,KAAK;iBAChB;gBACD,WAAW,EAAE;oBACX,IAAI,EAAE,SAAS;oBACf,WAAW,EAAE,+FAA+F;oBAC5G,QAAQ,EAAE,KAAK;iBAChB;aACF;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,EAAE,IAAI,EAAE,cAAc,EAAE,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,IAM7D,CAAC;gBAEF,MAAM,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,IAAI,CAAC,CAAC,GAAG,MAAM,CAAC;gBAC1E,MAAM,gBAAgB,GAAG,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;gBAEzF,IAAI,CAAC;oBACH,MAAM,EAAE,GAAG,MAAM,OAAO,CAAC,KAAK,CAAC,IAAI,EAAE;wBACnC,SAAS,EAAE,gBAAgB;wBAC3B,KAAK;wBACL,OAAO,EAAE,gBAAgB;qBAC1B,CAAC,CAAC;oBACH,OAAO,aAAa,EAAE,WAAW,KAAK,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,qCAAqC,CAAC;gBACnG,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,OAAO,0BAA0B,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;gBACtF,CAAC;YACH,CAAC;SACF;QAED,YAAY,EAAE;YACZ,WAAW,EACT,+GAA+G;YACjH,UAAU,EAAE;gBACV,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,wCAAwC,EAAE,QAAQ,EAAE,KAAK,EAAE;aACpG;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,EAAE,OAAO,EAAE,GAAG,IAA4B,CAAC;gBAEjD,IAAI,OAAO,EAAE,CAAC;oBACZ,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;oBACxC,IAAI,CAAC,KAAK;wBAAE,OAAO,SAAS,OAAO,aAAa,CAAC;oBACjD,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;gBACxC,CAAC;gBAED,MAAM,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;gBACpC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;oBAAE,OAAO,gBAAgB,CAAC;gBAEjD,MAAM,OAAO,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;gBACrC,MAAM,MAAM,GAAG,GAAG,OAAO,CAAC,KAAK,YAAY,OAAO,CAAC,OAAO,aAAa,OAAO,CAAC,SAAS,eAAe,OAAO,CAAC,MAAM,WAAW,CAAC;gBAEjI,MAAM,IAAI,GAAG,MAAM;qBAChB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;oBACT,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,CAAC;oBAC9D,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,OAAO,IAAI,CAAC;oBAChJ,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC;wBACnB,MAAM,GAAG,GAAG,CAAC,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,eAAe,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;wBACxE,OAAO,GAAG,IAAI,iBAAiB,CAAC,CAAC,YAAY,GAAG,GAAG,EAAE,CAAC;oBACxD,CAAC;oBACD,IAAI,CAAC,CAAC,MAAM,KAAK,WAAW,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;wBACzC,OAAO,GAAG,IAAI,eAAe,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;oBAC7F,CAAC;oBACD,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;wBACZ,OAAO,GAAG,IAAI,cAAc,CAAC,CAAC,KAAK,EAAE,CAAC;oBACxC,CAAC;oBACD,OAAO,IAAI,CAAC;gBACd,CAAC,CAAC;qBACD,IAAI,CAAC,IAAI,CAAC,CAAC;gBAEd,OAAO,MAAM,GAAG,IAAI,CAAC;YACvB,CAAC;SACF;QAED,YAAY,EAAE;YACZ,WAAW,EAAE,mCAAmC;YAChD,UAAU,EAAE;gBACV,OAAO,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,wBAAwB,EAAE,QAAQ,EAAE,IAAI,EAAE;aACnF;YACD,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;gBACtB,MAAM,EAAE,OAAO,EAAE,GAAG,IAA2B,CAAC;gBAChD,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBACxC,IAAI,CAAC,KAAK;oBAAE,OAAO,SAAS,OAAO,aAAa,CAAC;gBACjD,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;oBAC7D,OAAO,SAAS,OAAO,eAAe,KAAK,CAAC,MAAM,GAAG,CAAC;gBACxD,CAAC;gBACD,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;gBACxB,OAAO,SAAS,OAAO,aAAa,CAAC;YACvC,CAAC;SACF;KACF,CAAC;AACJ,CAAC"}
|