@push.rocks/smartagent 1.7.0 → 3.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.
Files changed (81) hide show
  1. package/dist_ts/00_commitinfo_data.js +3 -3
  2. package/dist_ts/index.d.ts +9 -12
  3. package/dist_ts/index.js +9 -20
  4. package/dist_ts/plugins.d.ts +8 -9
  5. package/dist_ts/plugins.js +10 -12
  6. package/dist_ts/smartagent.classes.agent.d.ts +2 -0
  7. package/dist_ts/smartagent.classes.agent.js +173 -0
  8. package/dist_ts/smartagent.classes.toolregistry.d.ts +12 -0
  9. package/dist_ts/smartagent.classes.toolregistry.js +17 -0
  10. package/dist_ts/smartagent.interfaces.d.ts +47 -231
  11. package/dist_ts/smartagent.interfaces.js +6 -7
  12. package/dist_ts/smartagent.utils.truncation.d.ts +10 -0
  13. package/dist_ts/smartagent.utils.truncation.js +26 -0
  14. package/dist_ts_compaction/index.d.ts +1 -0
  15. package/dist_ts_compaction/index.js +2 -0
  16. package/dist_ts_compaction/plugins.d.ts +4 -0
  17. package/dist_ts_compaction/plugins.js +3 -0
  18. package/dist_ts_compaction/smartagent.compaction.d.ts +10 -0
  19. package/dist_ts_compaction/smartagent.compaction.js +46 -0
  20. package/dist_ts_tools/index.d.ts +8 -0
  21. package/dist_ts_tools/index.js +6 -0
  22. package/dist_ts_tools/plugins.d.ts +15 -0
  23. package/dist_ts_tools/plugins.js +19 -0
  24. package/dist_ts_tools/tool.filesystem.d.ts +6 -0
  25. package/dist_ts_tools/tool.filesystem.js +102 -0
  26. package/dist_ts_tools/tool.http.d.ts +2 -0
  27. package/dist_ts_tools/tool.http.js +65 -0
  28. package/dist_ts_tools/tool.json.d.ts +2 -0
  29. package/dist_ts_tools/tool.json.js +47 -0
  30. package/dist_ts_tools/tool.shell.d.ts +8 -0
  31. package/dist_ts_tools/tool.shell.js +40 -0
  32. package/npmextra.json +1 -1
  33. package/package.json +30 -18
  34. package/readme.hints.md +43 -42
  35. package/readme.md +257 -526
  36. package/ts/00_commitinfo_data.ts +2 -2
  37. package/ts/index.ts +11 -31
  38. package/ts/plugins.ts +22 -21
  39. package/ts/smartagent.classes.agent.ts +198 -0
  40. package/ts/smartagent.classes.toolregistry.ts +20 -0
  41. package/ts/smartagent.interfaces.ts +51 -303
  42. package/ts/smartagent.utils.truncation.ts +39 -0
  43. package/ts_compaction/index.ts +1 -0
  44. package/ts_compaction/plugins.ts +6 -0
  45. package/ts_compaction/smartagent.compaction.ts +51 -0
  46. package/ts_tools/index.ts +8 -0
  47. package/ts_tools/plugins.ts +30 -0
  48. package/ts_tools/tool.filesystem.ts +131 -0
  49. package/ts_tools/tool.http.ts +78 -0
  50. package/ts_tools/tool.json.ts +53 -0
  51. package/ts_tools/tool.shell.ts +62 -0
  52. package/dist_ts/smartagent.classes.driveragent.d.ts +0 -134
  53. package/dist_ts/smartagent.classes.driveragent.js +0 -671
  54. package/dist_ts/smartagent.classes.dualagent.d.ts +0 -79
  55. package/dist_ts/smartagent.classes.dualagent.js +0 -583
  56. package/dist_ts/smartagent.classes.guardianagent.d.ts +0 -46
  57. package/dist_ts/smartagent.classes.guardianagent.js +0 -201
  58. package/dist_ts/smartagent.tools.base.d.ts +0 -52
  59. package/dist_ts/smartagent.tools.base.js +0 -42
  60. package/dist_ts/smartagent.tools.browser.d.ts +0 -17
  61. package/dist_ts/smartagent.tools.browser.js +0 -229
  62. package/dist_ts/smartagent.tools.deno.d.ts +0 -21
  63. package/dist_ts/smartagent.tools.deno.js +0 -191
  64. package/dist_ts/smartagent.tools.filesystem.d.ts +0 -40
  65. package/dist_ts/smartagent.tools.filesystem.js +0 -801
  66. package/dist_ts/smartagent.tools.http.d.ts +0 -16
  67. package/dist_ts/smartagent.tools.http.js +0 -264
  68. package/dist_ts/smartagent.tools.json.d.ts +0 -24
  69. package/dist_ts/smartagent.tools.json.js +0 -202
  70. package/dist_ts/smartagent.tools.shell.d.ts +0 -17
  71. package/dist_ts/smartagent.tools.shell.js +0 -202
  72. package/ts/smartagent.classes.driveragent.ts +0 -775
  73. package/ts/smartagent.classes.dualagent.ts +0 -657
  74. package/ts/smartagent.classes.guardianagent.ts +0 -241
  75. package/ts/smartagent.tools.base.ts +0 -83
  76. package/ts/smartagent.tools.browser.ts +0 -253
  77. package/ts/smartagent.tools.deno.ts +0 -230
  78. package/ts/smartagent.tools.filesystem.ts +0 -885
  79. package/ts/smartagent.tools.http.ts +0 -283
  80. package/ts/smartagent.tools.json.ts +0 -224
  81. package/ts/smartagent.tools.shell.ts +0 -230
@@ -1,583 +0,0 @@
1
- import * as plugins from './plugins.js';
2
- import * as interfaces from './smartagent.interfaces.js';
3
- import { BaseToolWrapper } from './smartagent.tools.base.js';
4
- import { DriverAgent } from './smartagent.classes.driveragent.js';
5
- import { GuardianAgent } from './smartagent.classes.guardianagent.js';
6
- import { FilesystemTool } from './smartagent.tools.filesystem.js';
7
- import { HttpTool } from './smartagent.tools.http.js';
8
- import { ShellTool } from './smartagent.tools.shell.js';
9
- import { BrowserTool } from './smartagent.tools.browser.js';
10
- import { DenoTool } from './smartagent.tools.deno.js';
11
- /**
12
- * DualAgentOrchestrator - Coordinates Driver and Guardian agents
13
- * Manages the complete lifecycle of task execution with tool approval
14
- */
15
- export class DualAgentOrchestrator {
16
- options;
17
- smartai;
18
- driverProvider;
19
- guardianProvider;
20
- driver;
21
- guardian;
22
- tools = new Map();
23
- isRunning = false;
24
- conversationHistory = [];
25
- ownsSmartAi = true; // true if we created the SmartAi instance, false if it was provided
26
- constructor(options) {
27
- this.options = {
28
- maxIterations: 20,
29
- maxConsecutiveRejections: 3,
30
- defaultProvider: 'openai',
31
- maxResultChars: 15000,
32
- maxHistoryMessages: 20,
33
- ...options,
34
- };
35
- // Use existing SmartAi instance if provided, otherwise create a new one
36
- if (options.smartAiInstance) {
37
- this.smartai = options.smartAiInstance;
38
- this.ownsSmartAi = false; // Don't manage lifecycle of provided instance
39
- }
40
- else {
41
- this.smartai = new plugins.smartai.SmartAi(options);
42
- this.ownsSmartAi = true;
43
- }
44
- // Note: Don't access providers here - they don't exist until start() is called
45
- }
46
- /**
47
- * Get provider by name
48
- */
49
- getProviderByName(providerName) {
50
- switch (providerName) {
51
- case 'openai':
52
- return this.smartai.openaiProvider;
53
- case 'anthropic':
54
- return this.smartai.anthropicProvider;
55
- case 'perplexity':
56
- return this.smartai.perplexityProvider;
57
- case 'ollama':
58
- return this.smartai.ollamaProvider;
59
- case 'groq':
60
- return this.smartai.groqProvider;
61
- case 'xai':
62
- return this.smartai.xaiProvider;
63
- case 'exo':
64
- return this.smartai.exoProvider;
65
- default:
66
- return this.smartai.openaiProvider;
67
- }
68
- }
69
- /**
70
- * Emit a progress event if callback is configured
71
- */
72
- emitProgress(event) {
73
- if (this.options.onProgress) {
74
- const prefix = this.options.logPrefix ? `${this.options.logPrefix} ` : '';
75
- const { logLevel, logMessage } = this.formatProgressEvent(event, prefix);
76
- this.options.onProgress({
77
- ...event,
78
- timestamp: new Date(),
79
- logLevel,
80
- logMessage,
81
- });
82
- }
83
- }
84
- /**
85
- * Format a progress event into a log level and message
86
- */
87
- formatProgressEvent(event, prefix) {
88
- switch (event.type) {
89
- case 'task_started':
90
- return { logLevel: 'info', logMessage: `${prefix}Task started` };
91
- case 'iteration_started':
92
- return { logLevel: 'info', logMessage: `${prefix}Iteration ${event.iteration}/${event.maxIterations}` };
93
- case 'tool_proposed':
94
- return { logLevel: 'info', logMessage: `${prefix} → Proposing: ${event.toolName}.${event.action}` };
95
- case 'guardian_evaluating':
96
- return { logLevel: 'info', logMessage: `${prefix} ⏳ Guardian evaluating...` };
97
- case 'tool_approved':
98
- return { logLevel: 'info', logMessage: `${prefix} ✓ Approved: ${event.toolName}.${event.action}` };
99
- case 'tool_rejected':
100
- return { logLevel: 'warn', logMessage: `${prefix} ✗ Rejected: ${event.toolName}.${event.action} - ${event.reason}` };
101
- case 'tool_executing':
102
- return { logLevel: 'info', logMessage: `${prefix} ⚡ Executing: ${event.toolName}.${event.action}...` };
103
- case 'tool_completed':
104
- return { logLevel: 'info', logMessage: `${prefix} ✓ Completed: ${event.message}` };
105
- case 'task_completed':
106
- return { logLevel: 'success', logMessage: `${prefix}Task completed in ${event.iteration} iterations` };
107
- case 'clarification_needed':
108
- return { logLevel: 'warn', logMessage: `${prefix}Clarification needed from user` };
109
- case 'max_iterations':
110
- return { logLevel: 'error', logMessage: `${prefix}${event.message}` };
111
- case 'max_rejections':
112
- return { logLevel: 'error', logMessage: `${prefix}${event.message}` };
113
- default:
114
- return { logLevel: 'info', logMessage: `${prefix}${event.type}` };
115
- }
116
- }
117
- /**
118
- * Register a custom tool
119
- */
120
- registerTool(tool) {
121
- this.tools.set(tool.name, tool);
122
- // Register with agents if they exist (they're created in start())
123
- if (this.driver) {
124
- this.driver.registerTool(tool);
125
- }
126
- if (this.guardian) {
127
- this.guardian.registerTool(tool);
128
- }
129
- }
130
- /**
131
- * Register all standard tools
132
- */
133
- registerStandardTools() {
134
- const standardTools = [
135
- new FilesystemTool(),
136
- new HttpTool(),
137
- new ShellTool(),
138
- new BrowserTool(),
139
- new DenoTool(),
140
- ];
141
- for (const tool of standardTools) {
142
- this.registerTool(tool);
143
- }
144
- }
145
- /**
146
- * Register a scoped filesystem tool that can only access files within the specified directory
147
- * @param basePath The directory to scope filesystem operations to
148
- * @param excludePatterns Optional glob patterns to exclude from listings (e.g., ['.nogit/**', 'node_modules/**'])
149
- */
150
- registerScopedFilesystemTool(basePath, excludePatterns) {
151
- const scopedTool = new FilesystemTool({ basePath, excludePatterns });
152
- this.registerTool(scopedTool);
153
- }
154
- /**
155
- * Initialize all tools (eager loading)
156
- */
157
- async start() {
158
- // Start smartai only if we created it (external instances should already be started)
159
- if (this.ownsSmartAi) {
160
- await this.smartai.start();
161
- }
162
- // NOW get providers (after they've been initialized by smartai.start())
163
- this.driverProvider = this.getProviderByName(this.options.defaultProvider);
164
- this.guardianProvider = this.options.guardianProvider
165
- ? this.getProviderByName(this.options.guardianProvider)
166
- : this.driverProvider;
167
- // NOW create agents with initialized providers
168
- // Set up token callback wrapper if streaming is enabled
169
- const driverOnToken = this.options.onToken
170
- ? (token) => this.options.onToken(token, 'driver')
171
- : undefined;
172
- this.driver = new DriverAgent(this.driverProvider, {
173
- systemMessage: this.options.driverSystemMessage,
174
- maxHistoryMessages: this.options.maxHistoryMessages,
175
- onToken: driverOnToken,
176
- });
177
- this.guardian = new GuardianAgent(this.guardianProvider, this.options.guardianPolicyPrompt);
178
- // Register any tools that were added before start() with the agents
179
- for (const tool of this.tools.values()) {
180
- this.driver.registerTool(tool);
181
- this.guardian.registerTool(tool);
182
- }
183
- // Initialize all tools
184
- const initPromises = [];
185
- for (const tool of this.tools.values()) {
186
- initPromises.push(tool.initialize());
187
- }
188
- await Promise.all(initPromises);
189
- this.isRunning = true;
190
- }
191
- /**
192
- * Cleanup all tools
193
- */
194
- async stop() {
195
- const cleanupPromises = [];
196
- for (const tool of this.tools.values()) {
197
- cleanupPromises.push(tool.cleanup());
198
- }
199
- await Promise.all(cleanupPromises);
200
- // Only stop smartai if we created it (don't stop external instances)
201
- if (this.ownsSmartAi) {
202
- await this.smartai.stop();
203
- }
204
- this.isRunning = false;
205
- if (this.driver) {
206
- this.driver.reset();
207
- }
208
- }
209
- /**
210
- * Run a task through the dual-agent system
211
- * @param task The task description
212
- * @param options Optional task run options (e.g., images for vision tasks)
213
- */
214
- async run(task, options) {
215
- if (!this.isRunning) {
216
- throw new Error('Orchestrator not started. Call start() first.');
217
- }
218
- // Use native tool calling if enabled
219
- const useNativeTools = this.options.useNativeToolCalling === true;
220
- this.conversationHistory = [];
221
- let iterations = 0;
222
- let consecutiveRejections = 0;
223
- let completed = false;
224
- let finalResult = null;
225
- // Track pending native tool calls
226
- let pendingNativeToolCalls;
227
- // Extract images from options
228
- const images = options?.images;
229
- // Add initial task to history
230
- this.conversationHistory.push({
231
- role: 'user',
232
- content: task,
233
- });
234
- // Start the driver with the task and optional images
235
- let driverResponse;
236
- if (useNativeTools) {
237
- // Native tool calling mode
238
- const result = await this.driver.startTaskWithNativeTools(task, images);
239
- driverResponse = result.message;
240
- pendingNativeToolCalls = result.toolCalls;
241
- }
242
- else {
243
- // XML parsing mode
244
- driverResponse = await this.driver.startTask(task, images);
245
- }
246
- this.conversationHistory.push(driverResponse);
247
- // Emit task started event
248
- this.emitProgress({
249
- type: 'task_started',
250
- message: task.length > 100 ? task.substring(0, 100) + '...' : task,
251
- });
252
- while (iterations < this.options.maxIterations &&
253
- consecutiveRejections < this.options.maxConsecutiveRejections &&
254
- !completed) {
255
- iterations++;
256
- // Emit iteration started event
257
- this.emitProgress({
258
- type: 'iteration_started',
259
- iteration: iterations,
260
- maxIterations: this.options.maxIterations,
261
- });
262
- // Check if task is complete (for native mode, no pending tool calls and has content)
263
- const isComplete = useNativeTools
264
- ? (!pendingNativeToolCalls || pendingNativeToolCalls.length === 0) && driverResponse.content.length > 0
265
- : this.driver.isTaskComplete(driverResponse.content);
266
- if (isComplete) {
267
- completed = true;
268
- finalResult = useNativeTools
269
- ? driverResponse.content
270
- : (this.driver.extractTaskResult(driverResponse.content) || driverResponse.content);
271
- // Emit task completed event
272
- this.emitProgress({
273
- type: 'task_completed',
274
- iteration: iterations,
275
- message: 'Task completed successfully',
276
- });
277
- break;
278
- }
279
- // Check if driver needs clarification
280
- if (this.driver.needsClarification(driverResponse.content)) {
281
- // Emit clarification needed event
282
- this.emitProgress({
283
- type: 'clarification_needed',
284
- iteration: iterations,
285
- message: 'Driver needs clarification from user',
286
- });
287
- // Return with clarification needed status
288
- return {
289
- success: false,
290
- completed: false,
291
- result: driverResponse.content,
292
- iterations,
293
- history: this.conversationHistory,
294
- status: 'clarification_needed',
295
- };
296
- }
297
- // Parse tool call proposals - native mode uses pendingNativeToolCalls, XML mode parses content
298
- let proposals;
299
- if (useNativeTools && pendingNativeToolCalls && pendingNativeToolCalls.length > 0) {
300
- // Native tool calling mode - convert native tool calls to proposals
301
- proposals = this.driver.parseNativeToolCalls(pendingNativeToolCalls);
302
- pendingNativeToolCalls = undefined; // Clear after processing
303
- }
304
- else if (!useNativeTools) {
305
- // XML parsing mode
306
- proposals = this.driver.parseToolCallProposals(driverResponse.content);
307
- }
308
- else {
309
- proposals = [];
310
- }
311
- if (proposals.length === 0) {
312
- if (useNativeTools) {
313
- // Native mode: no tool calls and no content means we should continue
314
- const result = await this.driver.continueWithNativeTools('Please continue with the task. Use the available tools or provide your final output.');
315
- driverResponse = result.message;
316
- pendingNativeToolCalls = result.toolCalls;
317
- this.conversationHistory.push(driverResponse);
318
- continue;
319
- }
320
- else {
321
- // XML mode: remind the model of the exact XML format
322
- driverResponse = await this.driver.continueWithMessage(`No valid tool call was found in your response. To use a tool, you MUST output the exact XML format:
323
-
324
- <tool_call>
325
- <tool>tool_name</tool>
326
- <action>action_name</action>
327
- <params>{"param1": "value1"}</params>
328
- </tool_call>
329
-
330
- For example, to validate JSON:
331
- <tool_call>
332
- <tool>json</tool>
333
- <action>validate</action>
334
- <params>{"jsonString": "{\\"key\\":\\"value\\"}", "requiredFields": ["key"]}</params>
335
- </tool_call>
336
-
337
- Or to complete the task:
338
- <task_complete>your final JSON output here</task_complete>
339
-
340
- Please output the exact XML format above.`);
341
- this.conversationHistory.push(driverResponse);
342
- continue;
343
- }
344
- }
345
- // Process the first proposal (one at a time)
346
- const proposal = proposals[0];
347
- // Emit tool proposed event
348
- this.emitProgress({
349
- type: 'tool_proposed',
350
- iteration: iterations,
351
- toolName: proposal.toolName,
352
- action: proposal.action,
353
- message: `${proposal.toolName}.${proposal.action}`,
354
- });
355
- // Quick validation first
356
- const quickDecision = this.guardian.quickValidate(proposal);
357
- let decision;
358
- if (quickDecision) {
359
- decision = quickDecision;
360
- }
361
- else {
362
- // Emit guardian evaluating event
363
- this.emitProgress({
364
- type: 'guardian_evaluating',
365
- iteration: iterations,
366
- toolName: proposal.toolName,
367
- action: proposal.action,
368
- });
369
- // Full AI evaluation
370
- decision = await this.guardian.evaluate(proposal, task);
371
- }
372
- if (decision.decision === 'approve') {
373
- consecutiveRejections = 0;
374
- // Emit tool approved event
375
- this.emitProgress({
376
- type: 'tool_approved',
377
- iteration: iterations,
378
- toolName: proposal.toolName,
379
- action: proposal.action,
380
- });
381
- // Execute the tool
382
- const tool = this.tools.get(proposal.toolName);
383
- if (!tool) {
384
- const errorMessage = `Tool "${proposal.toolName}" not found.`;
385
- driverResponse = await this.driver.continueWithMessage(`TOOL ERROR: ${errorMessage}\n\nPlease try a different approach.`);
386
- this.conversationHistory.push(driverResponse);
387
- continue;
388
- }
389
- try {
390
- // Emit tool executing event
391
- this.emitProgress({
392
- type: 'tool_executing',
393
- iteration: iterations,
394
- toolName: proposal.toolName,
395
- action: proposal.action,
396
- });
397
- const result = await tool.execute(proposal.action, proposal.params);
398
- // Emit tool completed event
399
- this.emitProgress({
400
- type: 'tool_completed',
401
- iteration: iterations,
402
- toolName: proposal.toolName,
403
- action: proposal.action,
404
- message: result.success ? 'success' : result.error,
405
- });
406
- // Build result message (prefer summary if provided, otherwise stringify result)
407
- let resultMessage;
408
- if (result.success) {
409
- if (result.summary) {
410
- // Use tool-provided summary
411
- resultMessage = `TOOL RESULT (${proposal.toolName}.${proposal.action}):\n${result.summary}`;
412
- }
413
- else {
414
- // Stringify and potentially truncate
415
- const resultStr = JSON.stringify(result.result, null, 2);
416
- const maxChars = this.options.maxResultChars ?? 15000;
417
- if (maxChars > 0 && resultStr.length > maxChars) {
418
- // Truncate the result
419
- const truncated = resultStr.substring(0, maxChars);
420
- const omittedTokens = Math.round((resultStr.length - maxChars) / 4);
421
- resultMessage = `TOOL RESULT (${proposal.toolName}.${proposal.action}):\n${truncated}\n\n[... output truncated, ~${omittedTokens} tokens omitted. Use more specific parameters to reduce output size.]`;
422
- }
423
- else {
424
- resultMessage = `TOOL RESULT (${proposal.toolName}.${proposal.action}):\n${resultStr}`;
425
- }
426
- }
427
- }
428
- else {
429
- resultMessage = `TOOL ERROR (${proposal.toolName}.${proposal.action}):\n${result.error}`;
430
- }
431
- this.conversationHistory.push({
432
- role: 'system',
433
- content: resultMessage,
434
- toolCall: proposal,
435
- toolResult: result,
436
- });
437
- // Continue with appropriate method based on mode
438
- if (useNativeTools) {
439
- const toolNameForHistory = `${proposal.toolName}_${proposal.action}`;
440
- const continueResult = await this.driver.continueWithNativeTools(resultMessage, toolNameForHistory);
441
- driverResponse = continueResult.message;
442
- pendingNativeToolCalls = continueResult.toolCalls;
443
- }
444
- else {
445
- driverResponse = await this.driver.continueWithMessage(resultMessage);
446
- }
447
- this.conversationHistory.push(driverResponse);
448
- }
449
- catch (error) {
450
- const errorMessage = `Tool execution failed: ${error instanceof Error ? error.message : String(error)}`;
451
- if (useNativeTools) {
452
- const toolNameForHistory = `${proposal.toolName}_${proposal.action}`;
453
- const continueResult = await this.driver.continueWithNativeTools(`TOOL ERROR: ${errorMessage}\n\nPlease try a different approach.`, toolNameForHistory);
454
- driverResponse = continueResult.message;
455
- pendingNativeToolCalls = continueResult.toolCalls;
456
- }
457
- else {
458
- driverResponse = await this.driver.continueWithMessage(`TOOL ERROR: ${errorMessage}\n\nPlease try a different approach.`);
459
- }
460
- this.conversationHistory.push(driverResponse);
461
- }
462
- }
463
- else {
464
- // Rejected
465
- consecutiveRejections++;
466
- // Emit tool rejected event
467
- this.emitProgress({
468
- type: 'tool_rejected',
469
- iteration: iterations,
470
- toolName: proposal.toolName,
471
- action: proposal.action,
472
- reason: decision.reason,
473
- });
474
- // Build rejection feedback
475
- let feedback = `TOOL CALL REJECTED by Guardian:\n`;
476
- feedback += `- Reason: ${decision.reason}\n`;
477
- if (decision.concerns && decision.concerns.length > 0) {
478
- feedback += `- Concerns:\n${decision.concerns.map(c => ` - ${c}`).join('\n')}\n`;
479
- }
480
- if (decision.suggestions) {
481
- feedback += `- Suggestions: ${decision.suggestions}\n`;
482
- }
483
- feedback += `\nPlease adapt your approach based on this feedback.`;
484
- this.conversationHistory.push({
485
- role: 'system',
486
- content: feedback,
487
- toolCall: proposal,
488
- guardianDecision: decision,
489
- });
490
- // Continue with appropriate method based on mode
491
- if (useNativeTools) {
492
- const continueResult = await this.driver.continueWithNativeTools(feedback);
493
- driverResponse = continueResult.message;
494
- pendingNativeToolCalls = continueResult.toolCalls;
495
- }
496
- else {
497
- driverResponse = await this.driver.continueWithMessage(feedback);
498
- }
499
- this.conversationHistory.push(driverResponse);
500
- }
501
- }
502
- // Determine final status
503
- let status = 'completed';
504
- if (!completed) {
505
- if (iterations >= this.options.maxIterations) {
506
- status = 'max_iterations_reached';
507
- // Emit max iterations event
508
- this.emitProgress({
509
- type: 'max_iterations',
510
- iteration: iterations,
511
- maxIterations: this.options.maxIterations,
512
- message: `Maximum iterations (${this.options.maxIterations}) reached`,
513
- });
514
- }
515
- else if (consecutiveRejections >= this.options.maxConsecutiveRejections) {
516
- status = 'max_rejections_reached';
517
- // Emit max rejections event
518
- this.emitProgress({
519
- type: 'max_rejections',
520
- iteration: iterations,
521
- message: `Maximum consecutive rejections (${this.options.maxConsecutiveRejections}) reached`,
522
- });
523
- }
524
- }
525
- return {
526
- success: completed,
527
- completed,
528
- result: finalResult || driverResponse.content,
529
- iterations,
530
- history: this.conversationHistory,
531
- status,
532
- };
533
- }
534
- /**
535
- * Continue an existing task with user input
536
- */
537
- async continueTask(userInput) {
538
- if (!this.isRunning) {
539
- throw new Error('Orchestrator not started. Call start() first.');
540
- }
541
- this.conversationHistory.push({
542
- role: 'user',
543
- content: userInput,
544
- });
545
- const driverResponse = await this.driver.continueWithMessage(userInput);
546
- this.conversationHistory.push(driverResponse);
547
- // Continue the run loop
548
- // For simplicity, we return the current state - full continuation would need refactoring
549
- return {
550
- success: false,
551
- completed: false,
552
- result: driverResponse.content,
553
- iterations: 1,
554
- history: this.conversationHistory,
555
- status: 'in_progress',
556
- };
557
- }
558
- /**
559
- * Get the conversation history
560
- */
561
- getHistory() {
562
- return [...this.conversationHistory];
563
- }
564
- /**
565
- * Update the guardian policy
566
- */
567
- setGuardianPolicy(policyPrompt) {
568
- this.guardian.setPolicy(policyPrompt);
569
- }
570
- /**
571
- * Check if orchestrator is running
572
- */
573
- isActive() {
574
- return this.isRunning;
575
- }
576
- /**
577
- * Get registered tool names
578
- */
579
- getToolNames() {
580
- return Array.from(this.tools.keys());
581
- }
582
- }
583
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRhZ2VudC5jbGFzc2VzLmR1YWxhZ2VudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL3NtYXJ0YWdlbnQuY2xhc3Nlcy5kdWFsYWdlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLE9BQU8sTUFBTSxjQUFjLENBQUM7QUFDeEMsT0FBTyxLQUFLLFVBQVUsTUFBTSw0QkFBNEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDN0QsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUN0RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDbEUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXREOzs7R0FHRztBQUNILE1BQU0sT0FBTyxxQkFBcUI7SUFDeEIsT0FBTyxDQUErQjtJQUN0QyxPQUFPLENBQTBCO0lBQ2pDLGNBQWMsQ0FBa0M7SUFDaEQsZ0JBQWdCLENBQWtDO0lBQ2xELE1BQU0sQ0FBYztJQUNwQixRQUFRLENBQWdCO0lBQ3hCLEtBQUssR0FBaUMsSUFBSSxHQUFHLEVBQUUsQ0FBQztJQUNoRCxTQUFTLEdBQUcsS0FBSyxDQUFDO0lBQ2xCLG1CQUFtQixHQUErQixFQUFFLENBQUM7SUFDckQsV0FBVyxHQUFHLElBQUksQ0FBQyxDQUFDLG9FQUFvRTtJQUVoRyxZQUFZLE9BQXFDO1FBQy9DLElBQUksQ0FBQyxPQUFPLEdBQUc7WUFDYixhQUFhLEVBQUUsRUFBRTtZQUNqQix3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
@@ -1,46 +0,0 @@
1
- import * as plugins from './plugins.js';
2
- import * as interfaces from './smartagent.interfaces.js';
3
- import type { BaseToolWrapper } from './smartagent.tools.base.js';
4
- /**
5
- * GuardianAgent - Evaluates tool call proposals against a policy
6
- * Uses AI reasoning to approve or reject tool calls
7
- */
8
- export declare class GuardianAgent {
9
- private provider;
10
- private policyPrompt;
11
- private tools;
12
- constructor(provider: plugins.smartai.MultiModalModel, policyPrompt: string);
13
- /**
14
- * Register a tool for reference during evaluation
15
- */
16
- registerTool(tool: BaseToolWrapper): void;
17
- /**
18
- * Evaluate a tool call proposal against the policy
19
- */
20
- evaluate(proposal: interfaces.IToolCallProposal, taskContext: string): Promise<interfaces.IGuardianDecision>;
21
- /**
22
- * Build the system message for the Guardian
23
- */
24
- private buildGuardianSystemMessage;
25
- /**
26
- * Build the evaluation prompt for a specific proposal
27
- */
28
- private buildEvaluationPrompt;
29
- /**
30
- * Parse the guardian decision from the response
31
- */
32
- private parseDecision;
33
- /**
34
- * Quick validation without AI (for obviously safe/unsafe operations)
35
- * Returns null if AI evaluation is needed
36
- */
37
- quickValidate(proposal: interfaces.IToolCallProposal): interfaces.IGuardianDecision | null;
38
- /**
39
- * Update the policy prompt
40
- */
41
- setPolicy(policyPrompt: string): void;
42
- /**
43
- * Get current policy
44
- */
45
- getPolicy(): string;
46
- }