@push.rocks/smartagent 1.8.0 → 3.0.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.
Files changed (87) hide show
  1. package/dist_ts/00_commitinfo_data.js +3 -3
  2. package/dist_ts/index.d.ts +8 -14
  3. package/dist_ts/index.js +8 -24
  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 +7 -70
  9. package/dist_ts/smartagent.classes.toolregistry.js +11 -155
  10. package/dist_ts/smartagent.interfaces.d.ts +47 -283
  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 +38 -84
  35. package/readme.md +254 -682
  36. package/ts/00_commitinfo_data.ts +2 -2
  37. package/ts/index.ts +10 -37
  38. package/ts/plugins.ts +22 -21
  39. package/ts/smartagent.classes.agent.ts +198 -0
  40. package/ts/smartagent.classes.toolregistry.ts +11 -179
  41. package/ts/smartagent.interfaces.ts +51 -363
  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 -93
  55. package/dist_ts/smartagent.classes.dualagent.js +0 -614
  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.expert.d.ts +0 -27
  65. package/dist_ts/smartagent.tools.expert.js +0 -126
  66. package/dist_ts/smartagent.tools.filesystem.d.ts +0 -40
  67. package/dist_ts/smartagent.tools.filesystem.js +0 -801
  68. package/dist_ts/smartagent.tools.http.d.ts +0 -16
  69. package/dist_ts/smartagent.tools.http.js +0 -264
  70. package/dist_ts/smartagent.tools.json.d.ts +0 -24
  71. package/dist_ts/smartagent.tools.json.js +0 -202
  72. package/dist_ts/smartagent.tools.search.d.ts +0 -29
  73. package/dist_ts/smartagent.tools.search.js +0 -215
  74. package/dist_ts/smartagent.tools.shell.d.ts +0 -17
  75. package/dist_ts/smartagent.tools.shell.js +0 -202
  76. package/ts/smartagent.classes.driveragent.ts +0 -775
  77. package/ts/smartagent.classes.dualagent.ts +0 -692
  78. package/ts/smartagent.classes.guardianagent.ts +0 -241
  79. package/ts/smartagent.tools.base.ts +0 -83
  80. package/ts/smartagent.tools.browser.ts +0 -253
  81. package/ts/smartagent.tools.deno.ts +0 -230
  82. package/ts/smartagent.tools.expert.ts +0 -144
  83. package/ts/smartagent.tools.filesystem.ts +0 -885
  84. package/ts/smartagent.tools.http.ts +0 -283
  85. package/ts/smartagent.tools.json.ts +0 -224
  86. package/ts/smartagent.tools.search.ts +0 -237
  87. package/ts/smartagent.tools.shell.ts +0 -230
@@ -1,801 +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
- /**
5
- * Filesystem tool for file and directory operations
6
- * Wraps @push.rocks/smartfs
7
- */
8
- export class FilesystemTool extends BaseToolWrapper {
9
- name = 'filesystem';
10
- description = 'Read, write, list, and delete files and directories';
11
- /** Base path to scope all operations to */
12
- basePath;
13
- /** Glob patterns to exclude from listings */
14
- excludePatterns;
15
- constructor(options) {
16
- super();
17
- if (options?.basePath) {
18
- this.basePath = plugins.path.resolve(options.basePath);
19
- }
20
- this.excludePatterns = options?.excludePatterns || [];
21
- }
22
- /**
23
- * Check if a relative path should be excluded based on exclude patterns
24
- */
25
- isExcluded(relativePath) {
26
- if (this.excludePatterns.length === 0)
27
- return false;
28
- return this.excludePatterns.some(pattern => plugins.minimatch(relativePath, pattern, { dot: true }));
29
- }
30
- /**
31
- * Validate that a path is within the allowed base path
32
- * @throws Error if path is outside allowed directory
33
- */
34
- validatePath(pathArg) {
35
- const resolved = plugins.path.resolve(pathArg);
36
- if (this.basePath) {
37
- // Ensure the resolved path starts with the base path
38
- if (!resolved.startsWith(this.basePath + plugins.path.sep) && resolved !== this.basePath) {
39
- throw new Error(`Access denied: path "${pathArg}" is outside allowed directory "${this.basePath}"`);
40
- }
41
- }
42
- return resolved;
43
- }
44
- actions = [
45
- {
46
- name: 'read',
47
- description: 'Read file contents (full or specific line range)',
48
- parameters: {
49
- type: 'object',
50
- properties: {
51
- path: { type: 'string', description: 'Path to the file' },
52
- encoding: {
53
- type: 'string',
54
- enum: ['utf8', 'binary', 'base64'],
55
- default: 'utf8',
56
- description: 'File encoding',
57
- },
58
- startLine: {
59
- type: 'number',
60
- description: 'First line to read (1-indexed, inclusive). If omitted, reads from beginning.',
61
- },
62
- endLine: {
63
- type: 'number',
64
- description: 'Last line to read (1-indexed, inclusive). If omitted, reads to end.',
65
- },
66
- },
67
- required: ['path'],
68
- },
69
- },
70
- {
71
- name: 'write',
72
- description: 'Write content to a file (creates or overwrites)',
73
- parameters: {
74
- type: 'object',
75
- properties: {
76
- path: { type: 'string', description: 'Absolute path to the file' },
77
- content: { type: 'string', description: 'Content to write' },
78
- encoding: {
79
- type: 'string',
80
- enum: ['utf8', 'binary', 'base64'],
81
- default: 'utf8',
82
- description: 'File encoding',
83
- },
84
- },
85
- required: ['path', 'content'],
86
- },
87
- },
88
- {
89
- name: 'append',
90
- description: 'Append content to a file',
91
- parameters: {
92
- type: 'object',
93
- properties: {
94
- path: { type: 'string', description: 'Absolute path to the file' },
95
- content: { type: 'string', description: 'Content to append' },
96
- },
97
- required: ['path', 'content'],
98
- },
99
- },
100
- {
101
- name: 'list',
102
- description: 'List files and directories in a path',
103
- parameters: {
104
- type: 'object',
105
- properties: {
106
- path: { type: 'string', description: 'Directory path to list' },
107
- recursive: { type: 'boolean', default: false, description: 'List recursively' },
108
- filter: { type: 'string', description: 'Glob pattern to filter results (e.g., "*.ts")' },
109
- },
110
- required: ['path'],
111
- },
112
- },
113
- {
114
- name: 'delete',
115
- description: 'Delete a file or directory',
116
- parameters: {
117
- type: 'object',
118
- properties: {
119
- path: { type: 'string', description: 'Path to delete' },
120
- recursive: {
121
- type: 'boolean',
122
- default: false,
123
- description: 'For directories, delete recursively',
124
- },
125
- },
126
- required: ['path'],
127
- },
128
- },
129
- {
130
- name: 'exists',
131
- description: 'Check if a file or directory exists',
132
- parameters: {
133
- type: 'object',
134
- properties: {
135
- path: { type: 'string', description: 'Path to check' },
136
- },
137
- required: ['path'],
138
- },
139
- },
140
- {
141
- name: 'stat',
142
- description: 'Get file or directory statistics (size, dates, etc.)',
143
- parameters: {
144
- type: 'object',
145
- properties: {
146
- path: { type: 'string', description: 'Path to get stats for' },
147
- },
148
- required: ['path'],
149
- },
150
- },
151
- {
152
- name: 'copy',
153
- description: 'Copy a file to a new location',
154
- parameters: {
155
- type: 'object',
156
- properties: {
157
- source: { type: 'string', description: 'Source file path' },
158
- destination: { type: 'string', description: 'Destination file path' },
159
- },
160
- required: ['source', 'destination'],
161
- },
162
- },
163
- {
164
- name: 'move',
165
- description: 'Move a file to a new location',
166
- parameters: {
167
- type: 'object',
168
- properties: {
169
- source: { type: 'string', description: 'Source file path' },
170
- destination: { type: 'string', description: 'Destination file path' },
171
- },
172
- required: ['source', 'destination'],
173
- },
174
- },
175
- {
176
- name: 'mkdir',
177
- description: 'Create a directory',
178
- parameters: {
179
- type: 'object',
180
- properties: {
181
- path: { type: 'string', description: 'Directory path to create' },
182
- recursive: {
183
- type: 'boolean',
184
- default: true,
185
- description: 'Create parent directories if needed',
186
- },
187
- },
188
- required: ['path'],
189
- },
190
- },
191
- {
192
- name: 'tree',
193
- description: 'Show directory structure as a tree (no file contents)',
194
- parameters: {
195
- type: 'object',
196
- properties: {
197
- path: { type: 'string', description: 'Root directory path' },
198
- maxDepth: {
199
- type: 'number',
200
- default: 3,
201
- description: 'Maximum depth to traverse (default: 3)',
202
- },
203
- filter: {
204
- type: 'string',
205
- description: 'Glob pattern to filter files (e.g., "*.ts")',
206
- },
207
- showSizes: {
208
- type: 'boolean',
209
- default: false,
210
- description: 'Include file sizes in output',
211
- },
212
- format: {
213
- type: 'string',
214
- enum: ['string', 'json'],
215
- default: 'string',
216
- description: 'Output format: "string" for human-readable tree, "json" for structured array',
217
- },
218
- },
219
- required: ['path'],
220
- },
221
- },
222
- {
223
- name: 'glob',
224
- description: 'Find files matching a glob pattern',
225
- parameters: {
226
- type: 'object',
227
- properties: {
228
- pattern: {
229
- type: 'string',
230
- description: 'Glob pattern (e.g., "**/*.ts", "src/**/*.js")',
231
- },
232
- path: {
233
- type: 'string',
234
- description: 'Base path to search from (defaults to current directory)',
235
- },
236
- },
237
- required: ['pattern'],
238
- },
239
- },
240
- ];
241
- smartfs;
242
- async initialize() {
243
- this.smartfs = new plugins.smartfs.SmartFs(new plugins.smartfs.SmartFsProviderNode());
244
- this.isInitialized = true;
245
- }
246
- async cleanup() {
247
- this.isInitialized = false;
248
- }
249
- async execute(action, params) {
250
- this.validateAction(action);
251
- this.ensureInitialized();
252
- try {
253
- switch (action) {
254
- case 'read': {
255
- const validatedPath = this.validatePath(params.path);
256
- const encoding = params.encoding || 'utf8';
257
- const startLine = params.startLine;
258
- const endLine = params.endLine;
259
- const fullContent = await this.smartfs
260
- .file(validatedPath)
261
- .encoding(encoding)
262
- .read();
263
- const contentStr = fullContent.toString();
264
- const lines = contentStr.split('\n');
265
- const totalLines = lines.length;
266
- // Apply line range if specified
267
- let resultContent;
268
- let resultStartLine = 1;
269
- let resultEndLine = totalLines;
270
- if (startLine !== undefined || endLine !== undefined) {
271
- const start = Math.max(1, startLine ?? 1);
272
- const end = Math.min(totalLines, endLine ?? totalLines);
273
- resultStartLine = start;
274
- resultEndLine = end;
275
- // Convert to 0-indexed for array slicing
276
- const selectedLines = lines.slice(start - 1, end);
277
- // Add line numbers to output for context
278
- resultContent = selectedLines
279
- .map((line, idx) => `${String(start + idx).padStart(5)}│ ${line}`)
280
- .join('\n');
281
- }
282
- else {
283
- // No range specified - return full content but warn if large
284
- const MAX_LINES_WITHOUT_RANGE = 500;
285
- if (totalLines > MAX_LINES_WITHOUT_RANGE) {
286
- // Return first portion with warning
287
- const selectedLines = lines.slice(0, MAX_LINES_WITHOUT_RANGE);
288
- resultContent = selectedLines
289
- .map((line, idx) => `${String(idx + 1).padStart(5)}│ ${line}`)
290
- .join('\n');
291
- resultContent += `\n\n[... ${totalLines - MAX_LINES_WITHOUT_RANGE} more lines. Use startLine/endLine to read specific ranges.]`;
292
- resultEndLine = MAX_LINES_WITHOUT_RANGE;
293
- }
294
- else {
295
- resultContent = contentStr;
296
- }
297
- }
298
- return {
299
- success: true,
300
- result: {
301
- path: params.path,
302
- content: resultContent,
303
- encoding,
304
- totalLines,
305
- startLine: resultStartLine,
306
- endLine: resultEndLine,
307
- },
308
- };
309
- }
310
- case 'write': {
311
- const validatedPath = this.validatePath(params.path);
312
- const encoding = params.encoding || 'utf8';
313
- await this.smartfs
314
- .file(validatedPath)
315
- .encoding(encoding)
316
- .write(params.content);
317
- return {
318
- success: true,
319
- result: {
320
- path: params.path,
321
- written: true,
322
- bytesWritten: params.content.length,
323
- },
324
- };
325
- }
326
- case 'append': {
327
- const validatedPath = this.validatePath(params.path);
328
- await this.smartfs.file(validatedPath).append(params.content);
329
- return {
330
- success: true,
331
- result: {
332
- path: params.path,
333
- appended: true,
334
- },
335
- };
336
- }
337
- case 'list': {
338
- const validatedPath = this.validatePath(params.path);
339
- let dir = this.smartfs.directory(validatedPath);
340
- if (params.recursive) {
341
- dir = dir.recursive();
342
- }
343
- if (params.filter) {
344
- dir = dir.filter(params.filter);
345
- }
346
- let entries = await dir.list();
347
- // Filter out excluded paths
348
- if (this.excludePatterns.length > 0) {
349
- entries = entries.filter(entry => {
350
- const relativePath = plugins.path.relative(validatedPath, entry.path);
351
- return !this.isExcluded(relativePath) && !this.isExcluded(entry.name);
352
- });
353
- }
354
- return {
355
- success: true,
356
- result: {
357
- path: params.path,
358
- entries,
359
- count: entries.length,
360
- },
361
- };
362
- }
363
- case 'delete': {
364
- const validatedPath = this.validatePath(params.path);
365
- // Check if it's a directory or file
366
- const exists = await this.smartfs.file(validatedPath).exists();
367
- if (exists) {
368
- // Try to get stats to check if it's a directory
369
- try {
370
- const stats = await this.smartfs.file(validatedPath).stat();
371
- if (stats.isDirectory && params.recursive) {
372
- await this.smartfs.directory(validatedPath).recursive().delete();
373
- }
374
- else {
375
- await this.smartfs.file(validatedPath).delete();
376
- }
377
- }
378
- catch {
379
- await this.smartfs.file(validatedPath).delete();
380
- }
381
- }
382
- return {
383
- success: true,
384
- result: {
385
- path: params.path,
386
- deleted: true,
387
- },
388
- };
389
- }
390
- case 'exists': {
391
- const validatedPath = this.validatePath(params.path);
392
- const exists = await this.smartfs.file(validatedPath).exists();
393
- return {
394
- success: true,
395
- result: {
396
- path: params.path,
397
- exists,
398
- },
399
- };
400
- }
401
- case 'stat': {
402
- const validatedPath = this.validatePath(params.path);
403
- const stats = await this.smartfs.file(validatedPath).stat();
404
- return {
405
- success: true,
406
- result: {
407
- path: params.path,
408
- stats,
409
- },
410
- };
411
- }
412
- case 'copy': {
413
- const validatedSource = this.validatePath(params.source);
414
- const validatedDest = this.validatePath(params.destination);
415
- await this.smartfs.file(validatedSource).copy(validatedDest);
416
- return {
417
- success: true,
418
- result: {
419
- source: params.source,
420
- destination: params.destination,
421
- copied: true,
422
- },
423
- };
424
- }
425
- case 'move': {
426
- const validatedSource = this.validatePath(params.source);
427
- const validatedDest = this.validatePath(params.destination);
428
- await this.smartfs.file(validatedSource).move(validatedDest);
429
- return {
430
- success: true,
431
- result: {
432
- source: params.source,
433
- destination: params.destination,
434
- moved: true,
435
- },
436
- };
437
- }
438
- case 'mkdir': {
439
- const validatedPath = this.validatePath(params.path);
440
- let dir = this.smartfs.directory(validatedPath);
441
- if (params.recursive !== false) {
442
- dir = dir.recursive();
443
- }
444
- await dir.create();
445
- return {
446
- success: true,
447
- result: {
448
- path: params.path,
449
- created: true,
450
- },
451
- };
452
- }
453
- case 'tree': {
454
- const validatedPath = this.validatePath(params.path);
455
- const maxDepth = params.maxDepth ?? 3;
456
- const filter = params.filter;
457
- const showSizes = params.showSizes ?? false;
458
- const format = params.format ?? 'string';
459
- const entries = [];
460
- const collectEntries = async (dirPath, depth, relativePath) => {
461
- if (depth > maxDepth)
462
- return;
463
- let dir = this.smartfs.directory(dirPath);
464
- if (filter) {
465
- dir = dir.filter(filter);
466
- }
467
- const items = await dir.list();
468
- for (const item of items) {
469
- // item is IDirectoryEntry with name, path, isFile, isDirectory properties
470
- const itemPath = item.path;
471
- const itemRelPath = relativePath ? `${relativePath}/${item.name}` : item.name;
472
- const isDir = item.isDirectory;
473
- // Skip excluded paths
474
- if (this.isExcluded(itemRelPath) || this.isExcluded(item.name)) {
475
- continue;
476
- }
477
- const entry = {
478
- path: itemPath,
479
- relativePath: itemRelPath,
480
- isDir,
481
- depth,
482
- };
483
- if (showSizes && !isDir && item.stats) {
484
- entry.size = item.stats.size;
485
- }
486
- entries.push(entry);
487
- // Recurse into directories
488
- if (isDir && depth < maxDepth) {
489
- await collectEntries(itemPath, depth + 1, itemRelPath);
490
- }
491
- }
492
- };
493
- await collectEntries(validatedPath, 0, '');
494
- // Sort entries by path for consistent output
495
- entries.sort((a, b) => a.relativePath.localeCompare(b.relativePath));
496
- if (format === 'json') {
497
- return {
498
- success: true,
499
- result: {
500
- path: params.path,
501
- entries: entries.map((e) => ({
502
- path: e.relativePath,
503
- isDir: e.isDir,
504
- depth: e.depth,
505
- ...(e.size !== undefined ? { size: e.size } : {}),
506
- })),
507
- count: entries.length,
508
- },
509
- };
510
- }
511
- // Format as string tree
512
- const formatSize = (bytes) => {
513
- if (bytes < 1024)
514
- return `${bytes}B`;
515
- if (bytes < 1024 * 1024)
516
- return `${(bytes / 1024).toFixed(1)}KB`;
517
- return `${(bytes / (1024 * 1024)).toFixed(1)}MB`;
518
- };
519
- // Build tree string with proper indentation
520
- let treeStr = `${params.path}/\n`;
521
- const pathParts = new Map(); // Track which paths are last in their parent
522
- // Group by parent to determine last child
523
- const parentChildCount = new Map();
524
- const parentCurrentChild = new Map();
525
- for (const entry of entries) {
526
- const parentPath = entry.relativePath.includes('/')
527
- ? entry.relativePath.substring(0, entry.relativePath.lastIndexOf('/'))
528
- : '';
529
- parentChildCount.set(parentPath, (parentChildCount.get(parentPath) || 0) + 1);
530
- }
531
- for (const entry of entries) {
532
- const parentPath = entry.relativePath.includes('/')
533
- ? entry.relativePath.substring(0, entry.relativePath.lastIndexOf('/'))
534
- : '';
535
- parentCurrentChild.set(parentPath, (parentCurrentChild.get(parentPath) || 0) + 1);
536
- const isLast = parentCurrentChild.get(parentPath) === parentChildCount.get(parentPath);
537
- // Build prefix based on depth
538
- let prefix = '';
539
- const parts = entry.relativePath.split('/');
540
- for (let i = 0; i < parts.length - 1; i++) {
541
- prefix += '│ ';
542
- }
543
- prefix += isLast ? '└── ' : '├── ';
544
- const name = parts[parts.length - 1];
545
- const suffix = entry.isDir ? '/' : '';
546
- const sizeStr = showSizes && entry.size !== undefined ? ` (${formatSize(entry.size)})` : '';
547
- treeStr += `${prefix}${name}${suffix}${sizeStr}\n`;
548
- }
549
- return {
550
- success: true,
551
- result: {
552
- path: params.path,
553
- tree: treeStr,
554
- count: entries.length,
555
- },
556
- };
557
- }
558
- case 'glob': {
559
- const pattern = params.pattern;
560
- const basePath = params.path ? this.validatePath(params.path) : (this.basePath || process.cwd());
561
- // Use smartfs to list with filter
562
- const dir = this.smartfs.directory(basePath).recursive().filter(pattern);
563
- const matches = await dir.list();
564
- // Return file paths relative to base path for readability
565
- // Filter out excluded paths
566
- const files = matches
567
- .map((entry) => ({
568
- path: entry.path,
569
- relativePath: plugins.path.relative(basePath, entry.path),
570
- isDirectory: entry.isDirectory,
571
- }))
572
- .filter((file) => !this.isExcluded(file.relativePath));
573
- return {
574
- success: true,
575
- result: {
576
- pattern,
577
- basePath,
578
- files,
579
- count: files.length,
580
- },
581
- };
582
- }
583
- default:
584
- return {
585
- success: false,
586
- error: `Unknown action: ${action}`,
587
- };
588
- }
589
- }
590
- catch (error) {
591
- return {
592
- success: false,
593
- error: error instanceof Error ? error.message : String(error),
594
- };
595
- }
596
- }
597
- getToolExplanation() {
598
- return `## Tool: filesystem
599
- Read, write, list, and delete files and directories.
600
-
601
- ### Actions:
602
-
603
- **read** - Read file contents (full or specific line range)
604
- Parameters:
605
- - path (required): Path to the file
606
- - encoding (optional): File encoding - "utf8" (default), "binary", or "base64"
607
- - startLine (optional): First line to read (1-indexed, inclusive)
608
- - endLine (optional): Last line to read (1-indexed, inclusive)
609
-
610
- Example:
611
- <tool_call>
612
- <tool>filesystem</tool>
613
- <action>read</action>
614
- <params>{"path": "/path/to/file.txt"}</params>
615
- </tool_call>
616
-
617
- Example with line range:
618
- <tool_call>
619
- <tool>filesystem</tool>
620
- <action>read</action>
621
- <params>{"path": "/path/to/file.txt", "startLine": 10, "endLine": 20}</params>
622
- </tool_call>
623
-
624
- **write** - Write content to a file (creates or overwrites)
625
- Parameters:
626
- - path (required): Absolute path to the file
627
- - content (required): Content to write
628
- - encoding (optional): File encoding - "utf8" (default), "binary", or "base64"
629
-
630
- Example:
631
- <tool_call>
632
- <tool>filesystem</tool>
633
- <action>write</action>
634
- <params>{"path": "/path/to/output.txt", "content": "Hello, World!"}</params>
635
- </tool_call>
636
-
637
- **list** - List files and directories in a path
638
- Parameters:
639
- - path (required): Directory path to list
640
- - recursive (optional): List recursively (default: false)
641
- - filter (optional): Glob pattern to filter results (e.g., "*.ts")
642
-
643
- Example:
644
- <tool_call>
645
- <tool>filesystem</tool>
646
- <action>list</action>
647
- <params>{"path": "/path/to/dir", "recursive": true, "filter": "*.ts"}</params>
648
- </tool_call>
649
-
650
- **exists** - Check if a file or directory exists
651
- Parameters:
652
- - path (required): Path to check
653
-
654
- Example:
655
- <tool_call>
656
- <tool>filesystem</tool>
657
- <action>exists</action>
658
- <params>{"path": "/path/to/check"}</params>
659
- </tool_call>
660
-
661
- **mkdir** - Create a directory
662
- Parameters:
663
- - path (required): Directory path to create
664
- - recursive (optional): Create parent directories if needed (default: true)
665
-
666
- Example:
667
- <tool_call>
668
- <tool>filesystem</tool>
669
- <action>mkdir</action>
670
- <params>{"path": "/path/to/new/dir"}</params>
671
- </tool_call>
672
-
673
- **delete** - Delete a file or directory
674
- Parameters:
675
- - path (required): Path to delete
676
- - recursive (optional): For directories, delete recursively (default: false)
677
-
678
- Example:
679
- <tool_call>
680
- <tool>filesystem</tool>
681
- <action>delete</action>
682
- <params>{"path": "/path/to/delete", "recursive": true}</params>
683
- </tool_call>
684
-
685
- **copy** - Copy a file to a new location
686
- Parameters:
687
- - source (required): Source file path
688
- - destination (required): Destination file path
689
-
690
- Example:
691
- <tool_call>
692
- <tool>filesystem</tool>
693
- <action>copy</action>
694
- <params>{"source": "/path/to/source.txt", "destination": "/path/to/dest.txt"}</params>
695
- </tool_call>
696
-
697
- **move** - Move a file to a new location
698
- Parameters:
699
- - source (required): Source file path
700
- - destination (required): Destination file path
701
-
702
- Example:
703
- <tool_call>
704
- <tool>filesystem</tool>
705
- <action>move</action>
706
- <params>{"source": "/path/to/old.txt", "destination": "/path/to/new.txt"}</params>
707
- </tool_call>
708
-
709
- **stat** - Get file or directory statistics (size, dates, etc.)
710
- Parameters:
711
- - path (required): Path to get stats for
712
-
713
- Example:
714
- <tool_call>
715
- <tool>filesystem</tool>
716
- <action>stat</action>
717
- <params>{"path": "/path/to/file.txt"}</params>
718
- </tool_call>
719
-
720
- **append** - Append content to a file
721
- Parameters:
722
- - path (required): Absolute path to the file
723
- - content (required): Content to append
724
-
725
- Example:
726
- <tool_call>
727
- <tool>filesystem</tool>
728
- <action>append</action>
729
- <params>{"path": "/path/to/log.txt", "content": "New log entry\\n"}</params>
730
- </tool_call>
731
-
732
- **tree** - Show directory structure as a tree
733
- Parameters:
734
- - path (required): Root directory path
735
- - maxDepth (optional): Maximum depth to traverse (default: 3)
736
- - filter (optional): Glob pattern to filter files
737
- - showSizes (optional): Include file sizes in output (default: false)
738
- - format (optional): Output format - "string" (default) or "json"
739
-
740
- Example:
741
- <tool_call>
742
- <tool>filesystem</tool>
743
- <action>tree</action>
744
- <params>{"path": "/path/to/dir", "maxDepth": 2}</params>
745
- </tool_call>
746
-
747
- **glob** - Find files matching a glob pattern
748
- Parameters:
749
- - pattern (required): Glob pattern (e.g., "**/*.ts", "src/**/*.js")
750
- - path (optional): Base path to search from
751
-
752
- Example:
753
- <tool_call>
754
- <tool>filesystem</tool>
755
- <action>glob</action>
756
- <params>{"pattern": "**/*.ts", "path": "/path/to/project"}</params>
757
- </tool_call>
758
- `;
759
- }
760
- getCallSummary(action, params) {
761
- switch (action) {
762
- case 'read': {
763
- const lineRange = params.startLine || params.endLine
764
- ? ` lines ${params.startLine || 1}-${params.endLine || 'end'}`
765
- : '';
766
- return `Read file "${params.path}"${lineRange}`;
767
- }
768
- case 'write': {
769
- const content = params.content;
770
- const preview = content.length > 100 ? content.substring(0, 100) + '...' : content;
771
- return `Write ${content.length} bytes to "${params.path}". Content preview: "${preview}"`;
772
- }
773
- case 'append': {
774
- const content = params.content;
775
- const preview = content.length > 100 ? content.substring(0, 100) + '...' : content;
776
- return `Append ${content.length} bytes to "${params.path}". Content preview: "${preview}"`;
777
- }
778
- case 'list':
779
- return `List directory "${params.path}"${params.recursive ? ' recursively' : ''}${params.filter ? ` with filter "${params.filter}"` : ''}`;
780
- case 'delete':
781
- return `Delete "${params.path}"${params.recursive ? ' recursively' : ''}`;
782
- case 'exists':
783
- return `Check if "${params.path}" exists`;
784
- case 'stat':
785
- return `Get statistics for "${params.path}"`;
786
- case 'copy':
787
- return `Copy "${params.source}" to "${params.destination}"`;
788
- case 'move':
789
- return `Move "${params.source}" to "${params.destination}"`;
790
- case 'mkdir':
791
- return `Create directory "${params.path}"${params.recursive !== false ? ' (with parents)' : ''}`;
792
- case 'tree':
793
- return `Show tree of "${params.path}" (depth: ${params.maxDepth ?? 3}, format: ${params.format ?? 'string'})`;
794
- case 'glob':
795
- return `Find files matching "${params.pattern}"${params.path ? ` in "${params.path}"` : ''}`;
796
- default:
797
- return `Unknown action: ${action}`;
798
- }
799
- }
800
- }
801
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic21hcnRhZ2VudC50b29scy5maWxlc3lzdGVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvc21hcnRhZ2VudC50b29scy5maWxlc3lzdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxPQUFPLE1BQU0sY0FBYyxDQUFDO0FBQ3hDLE9BQU8sS0FBSyxVQUFVLE1BQU0sNEJBQTRCLENBQUM7QUFDekQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBWTdEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxjQUFlLFNBQVEsZUFBZTtJQUMxQyxJQUFJLEdBQUcsWUFBWSxDQUFDO0lBQ3BCLFdBQVcsR0FBRyxxREFBcUQsQ0FBQztJQUUzRSwyQ0FBMkM7SUFDbkMsUUFBUSxDQUFVO0lBQzFCLDZDQUE2QztJQUNyQyxlQUFlLENBQVc7SUFFbEMsWUFBWSxPQUFnQztRQUMxQyxLQUFLLEVBQUUsQ0FBQztRQUNSLElBQUksT0FBTyxFQUFFLFFBQVEsRUFBRSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxRQUFRLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ3pELENBQUM7UUFDRCxJQUFJLENBQUMsZUFBZSxHQUFHLE9BQU8sRUFBRSxlQUFlLElBQUksRUFBRSxDQUFDO0lBQ3hELENBQUM7SUFFRDs7T0FFRztJQUNLLFVBQVUsQ0FBQyxZQUFvQjtRQUNyQyxJQUFJLElBQUksQ0FBQyxlQUFlLENBQUMsTUFBTSxLQUFLLENBQUM7WUFBRSxPQUFPLEtBQUssQ0FBQztRQUNwRCxPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQ3pDLE9BQU8sQ0FBQyxTQUFTLENBQUMsWUFBWSxFQUFFLE9BQU8sRUFBRSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUN4RCxDQUFDO0lBQ0osQ0FBQztJQUVE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