fotric-claw 0.1.1 → 0.1.3
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/README.md +3 -3
- package/backend/dist/agent/agent.module.d.ts +2 -0
- package/backend/dist/agent/agent.module.js +23 -0
- package/backend/dist/agent/agent.module.js.map +1 -0
- package/backend/dist/agent/agent.service.d.ts +25 -0
- package/backend/dist/agent/agent.service.js +188 -0
- package/backend/dist/agent/agent.service.js.map +1 -0
- package/backend/dist/agent/index.d.ts +4 -0
- package/backend/dist/agent/index.js +21 -0
- package/backend/dist/agent/index.js.map +1 -0
- package/backend/dist/agent/llm.factory.d.ts +5 -0
- package/backend/dist/agent/llm.factory.js +19 -0
- package/backend/dist/agent/llm.factory.js.map +1 -0
- package/backend/dist/agent/tools/fetch.tool.d.ts +10 -0
- package/backend/dist/agent/tools/fetch.tool.js +145 -0
- package/backend/dist/agent/tools/fetch.tool.js.map +1 -0
- package/backend/dist/agent/tools/file-read.tool.d.ts +17 -0
- package/backend/dist/agent/tools/file-read.tool.js +114 -0
- package/backend/dist/agent/tools/file-read.tool.js.map +1 -0
- package/backend/dist/agent/tools/index.d.ts +31 -0
- package/backend/dist/agent/tools/index.js +52 -0
- package/backend/dist/agent/tools/index.js.map +1 -0
- package/backend/dist/agent/tools/node-repl.tool.d.ts +12 -0
- package/backend/dist/agent/tools/node-repl.tool.js +73 -0
- package/backend/dist/agent/tools/node-repl.tool.js.map +1 -0
- package/backend/dist/agent/tools/rag.tool.d.ts +23 -0
- package/backend/dist/agent/tools/rag.tool.js +186 -0
- package/backend/dist/agent/tools/rag.tool.js.map +1 -0
- package/backend/dist/agent/tools/shell.tool.d.ts +14 -0
- package/backend/dist/agent/tools/shell.tool.js +55 -0
- package/backend/dist/agent/tools/shell.tool.js.map +1 -0
- package/backend/dist/app.module.d.ts +2 -0
- package/backend/dist/app.module.js +39 -0
- package/backend/dist/app.module.js.map +1 -0
- package/backend/dist/chat/chat.controller.d.ts +13 -0
- package/backend/dist/chat/chat.controller.js +60 -0
- package/backend/dist/chat/chat.controller.js.map +1 -0
- package/backend/dist/chat/chat.module.d.ts +2 -0
- package/backend/dist/chat/chat.module.js +25 -0
- package/backend/dist/chat/chat.module.js.map +1 -0
- package/backend/dist/chat/chat.service.d.ts +10 -0
- package/backend/dist/chat/chat.service.js +62 -0
- package/backend/dist/chat/chat.service.js.map +1 -0
- package/backend/dist/chat/dto/chat.dto.d.ts +11 -0
- package/backend/dist/chat/dto/chat.dto.js +10 -0
- package/backend/dist/chat/dto/chat.dto.js.map +1 -0
- package/backend/dist/chat/dto/index.d.ts +1 -0
- package/backend/dist/chat/dto/index.js +18 -0
- package/backend/dist/chat/dto/index.js.map +1 -0
- package/backend/dist/chat/index.d.ts +4 -0
- package/backend/dist/chat/index.js +21 -0
- package/backend/dist/chat/index.js.map +1 -0
- package/backend/dist/config/config.controller.d.ts +18 -0
- package/backend/dist/config/config.controller.js +139 -0
- package/backend/dist/config/config.controller.js.map +1 -0
- package/backend/dist/config/config.module.d.ts +2 -0
- package/backend/dist/config/config.module.js +20 -0
- package/backend/dist/config/config.module.js.map +1 -0
- package/backend/dist/config/constants.d.ts +30 -0
- package/backend/dist/config/constants.js +55 -0
- package/backend/dist/config/constants.js.map +1 -0
- package/backend/dist/config/index.d.ts +3 -0
- package/backend/dist/config/index.js +20 -0
- package/backend/dist/config/index.js.map +1 -0
- package/backend/dist/files/files.controller.d.ts +25 -0
- package/backend/dist/files/files.controller.js +145 -0
- package/backend/dist/files/files.controller.js.map +1 -0
- package/backend/dist/files/files.module.d.ts +2 -0
- package/backend/dist/files/files.module.js +20 -0
- package/backend/dist/files/files.module.js.map +1 -0
- package/backend/dist/files/index.d.ts +2 -0
- package/backend/dist/files/index.js +19 -0
- package/backend/dist/files/index.js.map +1 -0
- package/backend/dist/main.d.ts +1 -0
- package/backend/dist/main.js +19 -0
- package/backend/dist/main.js.map +1 -0
- package/backend/dist/memory/index.d.ts +3 -0
- package/backend/dist/memory/index.js +20 -0
- package/backend/dist/memory/index.js.map +1 -0
- package/backend/dist/memory/memory.module.d.ts +2 -0
- package/backend/dist/memory/memory.module.js +23 -0
- package/backend/dist/memory/memory.module.js.map +1 -0
- package/backend/dist/memory/memory.service.d.ts +30 -0
- package/backend/dist/memory/memory.service.js +342 -0
- package/backend/dist/memory/memory.service.js.map +1 -0
- package/backend/dist/memory/memory.types.d.ts +35 -0
- package/backend/dist/memory/memory.types.js +3 -0
- package/backend/dist/memory/memory.types.js.map +1 -0
- package/backend/dist/sessions/index.d.ts +2 -0
- package/backend/dist/sessions/index.js +19 -0
- package/backend/dist/sessions/index.js.map +1 -0
- package/backend/dist/sessions/sessions.controller.d.ts +19 -0
- package/backend/dist/sessions/sessions.controller.js +60 -0
- package/backend/dist/sessions/sessions.controller.js.map +1 -0
- package/backend/dist/sessions/sessions.module.d.ts +2 -0
- package/backend/dist/sessions/sessions.module.js +22 -0
- package/backend/dist/sessions/sessions.module.js.map +1 -0
- package/backend/dist/skills/index.d.ts +3 -0
- package/backend/dist/skills/index.js +20 -0
- package/backend/dist/skills/index.js.map +1 -0
- package/backend/dist/skills/skill.types.d.ts +24 -0
- package/backend/dist/skills/skill.types.js +3 -0
- package/backend/dist/skills/skill.types.js.map +1 -0
- package/backend/dist/skills/skills.module.d.ts +2 -0
- package/backend/dist/skills/skills.module.js +21 -0
- package/backend/dist/skills/skills.module.js.map +1 -0
- package/backend/dist/skills/skills.service.d.ts +17 -0
- package/backend/dist/skills/skills.service.js +167 -0
- package/backend/dist/skills/skills.service.js.map +1 -0
- package/backend/dist/tsconfig.build.tsbuildinfo +1 -0
- package/bin/fotric-claw.js +3 -5
- package/frontend/.next/standalone/.next/BUILD_ID +1 -0
- package/frontend/.next/standalone/.next/app-build-manifest.json +26 -0
- package/frontend/.next/standalone/.next/app-path-routes-manifest.json +1 -0
- package/frontend/.next/standalone/.next/build-manifest.json +32 -0
- package/frontend/.next/standalone/.next/package.json +1 -0
- package/frontend/.next/standalone/.next/prerender-manifest.js +1 -0
- package/frontend/.next/standalone/.next/prerender-manifest.json +1 -0
- package/frontend/.next/standalone/.next/react-loadable-manifest.json +1 -0
- package/frontend/.next/standalone/.next/required-server-files.json +1 -0
- package/frontend/.next/standalone/.next/routes-manifest.json +1 -0
- package/frontend/.next/standalone/.next/server/app/_not-found.html +1 -0
- package/frontend/.next/standalone/.next/server/app/_not-found.js +1 -0
- package/frontend/.next/standalone/.next/server/app/_not-found.js.nft.json +1 -0
- package/frontend/.next/standalone/.next/server/app/_not-found.meta +5 -0
- package/frontend/.next/standalone/.next/server/app/_not-found.rsc +9 -0
- package/frontend/.next/standalone/.next/server/app/_not-found_client-reference-manifest.js +1 -0
- package/frontend/.next/standalone/.next/server/app/index.html +1 -0
- package/frontend/.next/standalone/.next/server/app/index.meta +5 -0
- package/frontend/.next/standalone/.next/server/app/index.rsc +7 -0
- package/frontend/.next/standalone/.next/server/app/page.js +6 -0
- package/frontend/.next/standalone/.next/server/app/page.js.nft.json +1 -0
- package/frontend/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -0
- package/frontend/.next/standalone/.next/server/app-paths-manifest.json +4 -0
- package/frontend/.next/standalone/.next/server/chunks/198.js +1 -0
- package/frontend/.next/standalone/.next/server/chunks/72.js +6 -0
- package/frontend/.next/standalone/.next/server/font-manifest.json +1 -0
- package/frontend/.next/standalone/.next/server/middleware-build-manifest.js +1 -0
- package/frontend/.next/standalone/.next/server/middleware-manifest.json +6 -0
- package/frontend/.next/standalone/.next/server/middleware-react-loadable-manifest.js +1 -0
- package/frontend/.next/standalone/.next/server/next-font-manifest.js +1 -0
- package/frontend/.next/standalone/.next/server/next-font-manifest.json +1 -0
- package/frontend/.next/standalone/.next/server/pages/404.html +1 -0
- package/frontend/.next/standalone/.next/server/pages/500.html +1 -0
- package/frontend/.next/standalone/.next/server/pages/_app.js +1 -0
- package/frontend/.next/standalone/.next/server/pages/_app.js.nft.json +1 -0
- package/frontend/.next/standalone/.next/server/pages/_document.js +1 -0
- package/frontend/.next/standalone/.next/server/pages/_document.js.nft.json +1 -0
- package/frontend/.next/standalone/.next/server/pages/_error.js +1 -0
- package/frontend/.next/standalone/.next/server/pages/_error.js.nft.json +1 -0
- package/frontend/.next/standalone/.next/server/pages-manifest.json +1 -0
- package/frontend/.next/standalone/.next/server/server-reference-manifest.js +1 -0
- package/frontend/.next/standalone/.next/server/server-reference-manifest.json +1 -0
- package/frontend/.next/standalone/.next/server/webpack-runtime.js +1 -0
- package/frontend/.next/standalone/package.json +33 -0
- package/frontend/.next/standalone/server.js +38 -0
- package/frontend/.next/static/chunks/69-805ec1f4609643a8.js +1 -0
- package/frontend/.next/static/chunks/app/_not-found-f3ef8a2303cba633.js +1 -0
- package/frontend/.next/static/chunks/app/layout-de1b1ea4b8b69df0.js +1 -0
- package/frontend/.next/static/chunks/app/page-1771b63ea7f81cb8.js +6 -0
- package/frontend/.next/static/chunks/fd9d1056-3f67bd7f04959fd0.js +1 -0
- package/frontend/.next/static/chunks/framework-f66176bb897dc684.js +33 -0
- package/frontend/.next/static/chunks/main-068ac7cb3150df84.js +6 -0
- package/frontend/.next/static/chunks/main-app-0aed8e506d485ff1.js +1 -0
- package/frontend/.next/static/chunks/pages/_app-75f6107b0260711c.js +1 -0
- package/frontend/.next/static/chunks/pages/_error-9a890acb1e81c3fc.js +1 -0
- package/frontend/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +1 -0
- package/frontend/.next/static/chunks/webpack-710020a2da4f33c6.js +1 -0
- package/frontend/.next/static/css/9fa9af8cbf321465.css +3 -0
- package/frontend/.next/static/media/19cfc7226ec3afaa-s.woff2 +0 -0
- package/frontend/.next/static/media/21350d82a1f187e9-s.woff2 +0 -0
- package/frontend/.next/static/media/8e9860b6e62d6359-s.woff2 +0 -0
- package/frontend/.next/static/media/ba9851c3c22cd980-s.woff2 +0 -0
- package/frontend/.next/static/media/c5fe6dc8356a8c31-s.woff2 +0 -0
- package/frontend/.next/static/media/df0a9ae256c0569c-s.woff2 +0 -0
- package/frontend/.next/static/media/e4af272ccee01ff0-s.p.woff2 +0 -0
- package/frontend/.next/static/zCAHMEXFOA7RWLDEftDeM/_buildManifest.js +1 -0
- package/frontend/.next/static/zCAHMEXFOA7RWLDEftDeM/_ssgManifest.js +1 -0
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -22,7 +22,7 @@ npm install -g fotric-claw
|
|
|
22
22
|
fotric-claw config
|
|
23
23
|
|
|
24
24
|
# 启动服务
|
|
25
|
-
fotric-claw start
|
|
25
|
+
fotric-claw start
|
|
26
26
|
```
|
|
27
27
|
|
|
28
28
|
> npm 安装的版本已预编译,无需构建步骤。
|
|
@@ -100,7 +100,7 @@ fotric-claw help
|
|
|
100
100
|
**npm 安装用户可用命令:**
|
|
101
101
|
```
|
|
102
102
|
Commands:
|
|
103
|
-
start
|
|
103
|
+
start Start backend and frontend services
|
|
104
104
|
config Configure LLM API settings
|
|
105
105
|
help Show this help message
|
|
106
106
|
```
|
|
@@ -194,7 +194,7 @@ npm run frontend
|
|
|
194
194
|
**npm 安装用户:**
|
|
195
195
|
|
|
196
196
|
```bash
|
|
197
|
-
fotric-claw start
|
|
197
|
+
fotric-claw start
|
|
198
198
|
```
|
|
199
199
|
|
|
200
200
|
**源码安装用户:**
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AgentModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const agent_service_1 = require("./agent.service");
|
|
12
|
+
const memory_1 = require("../memory");
|
|
13
|
+
let AgentModule = class AgentModule {
|
|
14
|
+
};
|
|
15
|
+
exports.AgentModule = AgentModule;
|
|
16
|
+
exports.AgentModule = AgentModule = __decorate([
|
|
17
|
+
(0, common_1.Module)({
|
|
18
|
+
imports: [memory_1.MemoryModule],
|
|
19
|
+
providers: [agent_service_1.AgentService],
|
|
20
|
+
exports: [agent_service_1.AgentService],
|
|
21
|
+
})
|
|
22
|
+
], AgentModule);
|
|
23
|
+
//# sourceMappingURL=agent.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent.module.js","sourceRoot":"","sources":["../../src/agent/agent.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,mDAA+C;AAC/C,sCAAyC;AAOlC,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IALvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,qBAAY,CAAC;QACvB,SAAS,EAAE,CAAC,4BAAY,CAAC;QACzB,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAAG"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { BaseMessage } from '@langchain/core/messages';
|
|
2
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
3
|
+
import { ToolsConfig } from './tools';
|
|
4
|
+
import { MemoryService } from '../memory';
|
|
5
|
+
export interface AgentState {
|
|
6
|
+
messages: BaseMessage[];
|
|
7
|
+
sessionId: string;
|
|
8
|
+
}
|
|
9
|
+
export declare class AgentService implements OnModuleInit {
|
|
10
|
+
private readonly memoryService;
|
|
11
|
+
private readonly logger;
|
|
12
|
+
private toolsConfig?;
|
|
13
|
+
constructor(memoryService: MemoryService);
|
|
14
|
+
private getLLM;
|
|
15
|
+
onModuleInit(): void;
|
|
16
|
+
setToolsConfig(config: ToolsConfig): void;
|
|
17
|
+
private convertToLangChainMessages;
|
|
18
|
+
streamChat(userMessage: string, sessionId: string, onToolCall?: (toolName: string, args: unknown) => void): AsyncGenerator<{
|
|
19
|
+
type: 'thought' | 'tool_call' | 'content' | 'done';
|
|
20
|
+
content: string;
|
|
21
|
+
toolName?: string;
|
|
22
|
+
toolArgs?: unknown;
|
|
23
|
+
}>;
|
|
24
|
+
chat(userMessage: string, sessionId: string): Promise<string>;
|
|
25
|
+
}
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AgentService = void 0;
|
|
13
|
+
const messages_1 = require("@langchain/core/messages");
|
|
14
|
+
const common_1 = require("@nestjs/common");
|
|
15
|
+
const tools_1 = require("./tools");
|
|
16
|
+
const llm_factory_1 = require("./llm.factory");
|
|
17
|
+
const memory_1 = require("../memory");
|
|
18
|
+
let AgentService = class AgentService {
|
|
19
|
+
constructor(memoryService) {
|
|
20
|
+
this.memoryService = memoryService;
|
|
21
|
+
this.logger = new common_1.Logger('FOTRIC-CLAW:Agent');
|
|
22
|
+
}
|
|
23
|
+
getLLM() {
|
|
24
|
+
return (0, llm_factory_1.createLLM)();
|
|
25
|
+
}
|
|
26
|
+
onModuleInit() {
|
|
27
|
+
this.logger.log('Agent service initialized');
|
|
28
|
+
}
|
|
29
|
+
setToolsConfig(config) {
|
|
30
|
+
this.toolsConfig = config;
|
|
31
|
+
}
|
|
32
|
+
convertToLangChainMessages(messages) {
|
|
33
|
+
if (!messages || !Array.isArray(messages)) {
|
|
34
|
+
return [];
|
|
35
|
+
}
|
|
36
|
+
return messages.map(msg => {
|
|
37
|
+
const content = msg.content || '';
|
|
38
|
+
switch (msg.role) {
|
|
39
|
+
case 'user':
|
|
40
|
+
return new messages_1.HumanMessage(content);
|
|
41
|
+
case 'assistant':
|
|
42
|
+
return new messages_1.AIMessage(content);
|
|
43
|
+
case 'system':
|
|
44
|
+
return new messages_1.SystemMessage(content);
|
|
45
|
+
case 'tool':
|
|
46
|
+
return new messages_1.ToolMessage({
|
|
47
|
+
content: content,
|
|
48
|
+
tool_call_id: msg.toolCallId || 'unknown',
|
|
49
|
+
});
|
|
50
|
+
default:
|
|
51
|
+
return new messages_1.HumanMessage(content);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
async *streamChat(userMessage, sessionId, onToolCall) {
|
|
56
|
+
this.logger.log(`Starting chat for session: ${sessionId}`);
|
|
57
|
+
const systemPrompt = await this.memoryService.buildSystemPrompt();
|
|
58
|
+
let session = await this.memoryService.getSession(sessionId);
|
|
59
|
+
if (!session) {
|
|
60
|
+
session = await this.memoryService.createSession(sessionId);
|
|
61
|
+
}
|
|
62
|
+
const history = this.convertToLangChainMessages(session.messages || []);
|
|
63
|
+
const tools = (0, tools_1.createCoreTools)(this.toolsConfig);
|
|
64
|
+
const llm = this.getLLM();
|
|
65
|
+
const llmWithTools = llm.bindTools(tools);
|
|
66
|
+
const messages = [
|
|
67
|
+
new messages_1.SystemMessage(systemPrompt),
|
|
68
|
+
...history,
|
|
69
|
+
new messages_1.HumanMessage(userMessage),
|
|
70
|
+
];
|
|
71
|
+
await this.memoryService.addMessageToSession(sessionId, {
|
|
72
|
+
role: 'user',
|
|
73
|
+
content: userMessage,
|
|
74
|
+
});
|
|
75
|
+
let iteration = 0;
|
|
76
|
+
const maxIterations = 10;
|
|
77
|
+
let lastContent = '';
|
|
78
|
+
let lastToolResult = '';
|
|
79
|
+
while (iteration < maxIterations) {
|
|
80
|
+
iteration++;
|
|
81
|
+
try {
|
|
82
|
+
const response = await llmWithTools.invoke(messages);
|
|
83
|
+
if (response.tool_calls && response.tool_calls.length > 0) {
|
|
84
|
+
for (const toolCall of response.tool_calls) {
|
|
85
|
+
const toolName = toolCall.name;
|
|
86
|
+
const toolArgs = toolCall.args;
|
|
87
|
+
yield {
|
|
88
|
+
type: 'tool_call',
|
|
89
|
+
content: `Using tool: ${toolName}`,
|
|
90
|
+
toolName,
|
|
91
|
+
toolArgs,
|
|
92
|
+
};
|
|
93
|
+
onToolCall?.(toolName, toolArgs);
|
|
94
|
+
const tool = tools.find(t => t.name === toolName);
|
|
95
|
+
if (tool) {
|
|
96
|
+
try {
|
|
97
|
+
const toolResult = await tool.invoke(toolArgs);
|
|
98
|
+
lastToolResult = typeof toolResult === 'string' ? toolResult : JSON.stringify(toolResult);
|
|
99
|
+
yield {
|
|
100
|
+
type: 'thought',
|
|
101
|
+
content: `Tool ${toolName} result: ${lastToolResult.length > 500
|
|
102
|
+
? lastToolResult.substring(0, 500) + '...'
|
|
103
|
+
: lastToolResult}`,
|
|
104
|
+
};
|
|
105
|
+
messages.push(response);
|
|
106
|
+
messages.push(new messages_1.ToolMessage({
|
|
107
|
+
content: lastToolResult,
|
|
108
|
+
tool_call_id: toolCall.id || '',
|
|
109
|
+
}));
|
|
110
|
+
}
|
|
111
|
+
catch (error) {
|
|
112
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
113
|
+
messages.push(response);
|
|
114
|
+
messages.push(new messages_1.ToolMessage({
|
|
115
|
+
content: `Error: ${errorMessage}`,
|
|
116
|
+
tool_call_id: toolCall.id || '',
|
|
117
|
+
}));
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
this.logger.warn(`Tool not found: ${toolName}`);
|
|
122
|
+
messages.push(response);
|
|
123
|
+
messages.push(new messages_1.ToolMessage({
|
|
124
|
+
content: `Error: Tool '${toolName}' not found. Available tools: ${tools.map(t => t.name).join(', ')}`,
|
|
125
|
+
tool_call_id: toolCall.id || '',
|
|
126
|
+
}));
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
lastContent = typeof response.content === 'string'
|
|
132
|
+
? response.content
|
|
133
|
+
: JSON.stringify(response.content);
|
|
134
|
+
yield {
|
|
135
|
+
type: 'content',
|
|
136
|
+
content: lastContent,
|
|
137
|
+
};
|
|
138
|
+
await this.memoryService.addMessageToSession(sessionId, {
|
|
139
|
+
role: 'assistant',
|
|
140
|
+
content: lastContent,
|
|
141
|
+
});
|
|
142
|
+
break;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
catch (error) {
|
|
146
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
147
|
+
this.logger.error(`Agent error: ${errorMessage}`);
|
|
148
|
+
yield {
|
|
149
|
+
type: 'content',
|
|
150
|
+
content: `Error: ${errorMessage}`,
|
|
151
|
+
};
|
|
152
|
+
break;
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
if (iteration >= maxIterations) {
|
|
156
|
+
if (lastToolResult) {
|
|
157
|
+
lastContent = `任务已执行完成。工具执行结果:${lastToolResult.length > 1000 ? lastToolResult.substring(0, 1000) + '...' : lastToolResult}`;
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
lastContent = '操作已完成,但未能获取明确的响应。请尝试更具体的请求。';
|
|
161
|
+
}
|
|
162
|
+
yield {
|
|
163
|
+
type: 'content',
|
|
164
|
+
content: lastContent,
|
|
165
|
+
};
|
|
166
|
+
await this.memoryService.addMessageToSession(sessionId, {
|
|
167
|
+
role: 'assistant',
|
|
168
|
+
content: lastContent,
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
yield { type: 'done', content: '' };
|
|
172
|
+
}
|
|
173
|
+
async chat(userMessage, sessionId) {
|
|
174
|
+
let result = '';
|
|
175
|
+
for await (const chunk of this.streamChat(userMessage, sessionId)) {
|
|
176
|
+
if (chunk.type === 'content') {
|
|
177
|
+
result = chunk.content;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
return result;
|
|
181
|
+
}
|
|
182
|
+
};
|
|
183
|
+
exports.AgentService = AgentService;
|
|
184
|
+
exports.AgentService = AgentService = __decorate([
|
|
185
|
+
(0, common_1.Injectable)(),
|
|
186
|
+
__metadata("design:paramtypes", [memory_1.MemoryService])
|
|
187
|
+
], AgentService);
|
|
188
|
+
//# sourceMappingURL=agent.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent.service.js","sourceRoot":"","sources":["../../src/agent/agent.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./agent.service"), exports);
|
|
18
|
+
__exportStar(require("./agent.module"), exports);
|
|
19
|
+
__exportStar(require("./llm.factory"), exports);
|
|
20
|
+
__exportStar(require("./tools"), exports);
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/agent/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,iDAA+B;AAC/B,gDAA8B;AAC9B,0CAAwB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createLLM = createLLM;
|
|
4
|
+
const openai_1 = require("@langchain/openai");
|
|
5
|
+
function createLLM(options) {
|
|
6
|
+
const apiKey = process.env.FOTRIC_API_KEY || '';
|
|
7
|
+
const baseURL = process.env.FOTRIC_API_BASE_URL || 'https://api.openai.com/v1';
|
|
8
|
+
const modelName = process.env.FOTRIC_MODEL_NAME || 'gpt-4o';
|
|
9
|
+
return new openai_1.ChatOpenAI({
|
|
10
|
+
modelName,
|
|
11
|
+
openAIApiKey: apiKey || 'placeholder',
|
|
12
|
+
configuration: {
|
|
13
|
+
baseURL,
|
|
14
|
+
},
|
|
15
|
+
temperature: options?.temperature ?? 0.7,
|
|
16
|
+
maxTokens: options?.maxTokens ?? 4096,
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=llm.factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"llm.factory.js","sourceRoot":"","sources":["../../src/agent/llm.factory.ts"],"names":[],"mappings":";;AAEA,8BAiBC;AAnBD,8CAA+C;AAE/C,SAAgB,SAAS,CAAC,OAGzB;IACC,MAAM,MAAM,GAAG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC;IAChD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,2BAA2B,CAAC;IAC/E,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB,IAAI,QAAQ,CAAC;IAE5D,OAAO,IAAI,mBAAU,CAAC;QACpB,SAAS;QACT,YAAY,EAAE,MAAM,IAAI,aAAa;QACrC,aAAa,EAAE;YACb,OAAO;SACR;QACD,WAAW,EAAE,OAAO,EAAE,WAAW,IAAI,GAAG;QACxC,SAAS,EAAE,OAAO,EAAE,SAAS,IAAI,IAAI;KACtC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.FetchURLTool = void 0;
|
|
37
|
+
const tools_1 = require("@langchain/core/tools");
|
|
38
|
+
const cheerio = __importStar(require("cheerio"));
|
|
39
|
+
const html_to_text_1 = require("html-to-text");
|
|
40
|
+
class FetchURLTool extends tools_1.Tool {
|
|
41
|
+
constructor() {
|
|
42
|
+
super(...arguments);
|
|
43
|
+
this.name = 'fetch_url';
|
|
44
|
+
this.description = `Fetch content from a URL and return it as cleaned text/markdown.
|
|
45
|
+
Input should be a JSON object with a "url" field (required) and optional "selector" field.
|
|
46
|
+
Example: {"url": "https://example.com"} or {"url": "https://example.com", "selector": "article"}
|
|
47
|
+
Returns the extracted text content from the webpage.`;
|
|
48
|
+
}
|
|
49
|
+
async _call(input) {
|
|
50
|
+
let parsedInput;
|
|
51
|
+
try {
|
|
52
|
+
parsedInput = JSON.parse(input);
|
|
53
|
+
}
|
|
54
|
+
catch {
|
|
55
|
+
if (input.startsWith('http')) {
|
|
56
|
+
parsedInput = { url: input, selector: '' };
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
return 'Error: Invalid input. Please provide a JSON object with a "url" field.';
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
const { url, selector = '' } = parsedInput;
|
|
63
|
+
if (!url) {
|
|
64
|
+
return 'Error: URL is required.';
|
|
65
|
+
}
|
|
66
|
+
try {
|
|
67
|
+
new URL(url);
|
|
68
|
+
}
|
|
69
|
+
catch {
|
|
70
|
+
return 'Error: Invalid URL format.';
|
|
71
|
+
}
|
|
72
|
+
try {
|
|
73
|
+
const response = await fetch(url, {
|
|
74
|
+
headers: {
|
|
75
|
+
'User-Agent': 'Mozilla/5.0 (compatible; FotricCalw/0.1.0)',
|
|
76
|
+
'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8',
|
|
77
|
+
},
|
|
78
|
+
signal: AbortSignal.timeout(30000),
|
|
79
|
+
});
|
|
80
|
+
if (!response.ok) {
|
|
81
|
+
return `Error: HTTP ${response.status} - ${response.statusText}`;
|
|
82
|
+
}
|
|
83
|
+
const contentType = response.headers.get('content-type') || '';
|
|
84
|
+
if (!contentType.includes('text/html') && !contentType.includes('application/json')) {
|
|
85
|
+
const text = await response.text();
|
|
86
|
+
if (text.length > 10000) {
|
|
87
|
+
return text.substring(0, 10000) + '\n...[content truncated]';
|
|
88
|
+
}
|
|
89
|
+
return text;
|
|
90
|
+
}
|
|
91
|
+
const html = await response.text();
|
|
92
|
+
if (contentType.includes('application/json')) {
|
|
93
|
+
try {
|
|
94
|
+
const json = JSON.parse(html);
|
|
95
|
+
const stringified = JSON.stringify(json, null, 2);
|
|
96
|
+
if (stringified.length > 10000) {
|
|
97
|
+
return stringified.substring(0, 10000) + '\n...[content truncated]';
|
|
98
|
+
}
|
|
99
|
+
return stringified;
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
return html;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
const $ = cheerio.load(html);
|
|
106
|
+
$('script, style, nav, footer, header, aside, noscript, iframe, svg').remove();
|
|
107
|
+
$('[class*="sidebar"], [class*="menu"], [class*="nav"], [class*="footer"], [class*="header"]').remove();
|
|
108
|
+
$('[id*="sidebar"], [id*="menu"], [id*="nav"], [id*="footer"], [id*="header"]').remove();
|
|
109
|
+
let contentElement = selector && selector.trim() ? $(selector) : $('body');
|
|
110
|
+
if (contentElement.length === 0) {
|
|
111
|
+
contentElement = $('body');
|
|
112
|
+
}
|
|
113
|
+
const contentHtml = contentElement.html() || '';
|
|
114
|
+
const text = (0, html_to_text_1.htmlToText)(contentHtml, {
|
|
115
|
+
wordwrap: false,
|
|
116
|
+
selectors: [
|
|
117
|
+
{ selector: 'a', options: { ignoreHref: true } },
|
|
118
|
+
{ selector: 'img', format: 'skip' },
|
|
119
|
+
{ selector: 'h1', options: { uppercase: false } },
|
|
120
|
+
{ selector: 'h2', options: { uppercase: false } },
|
|
121
|
+
{ selector: 'h3', options: { uppercase: false } },
|
|
122
|
+
],
|
|
123
|
+
});
|
|
124
|
+
const cleanedText = text
|
|
125
|
+
.replace(/\n{3,}/g, '\n\n')
|
|
126
|
+
.replace(/[ \t]{2,}/g, ' ')
|
|
127
|
+
.trim();
|
|
128
|
+
if (cleanedText.length > 15000) {
|
|
129
|
+
return cleanedText.substring(0, 15000) + '\n\n...[content truncated]';
|
|
130
|
+
}
|
|
131
|
+
return cleanedText || 'No content extracted from the page.';
|
|
132
|
+
}
|
|
133
|
+
catch (error) {
|
|
134
|
+
if (error instanceof Error) {
|
|
135
|
+
if (error.name === 'AbortError' || error.message.includes('timeout')) {
|
|
136
|
+
return 'Error: Request timed out after 30 seconds.';
|
|
137
|
+
}
|
|
138
|
+
return `Error: ${error.message}`;
|
|
139
|
+
}
|
|
140
|
+
return `Error: ${String(error)}`;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
exports.FetchURLTool = FetchURLTool;
|
|
145
|
+
//# sourceMappingURL=fetch.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetch.tool.js","sourceRoot":"","sources":["../../../src/agent/tools/fetch.tool.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Tool } from '@langchain/core/tools';
|
|
2
|
+
export interface FileReadInput {
|
|
3
|
+
path: string;
|
|
4
|
+
encoding: string;
|
|
5
|
+
startLine: number;
|
|
6
|
+
endLine: number;
|
|
7
|
+
}
|
|
8
|
+
export declare class FileReadTool extends Tool {
|
|
9
|
+
name: string;
|
|
10
|
+
description: string;
|
|
11
|
+
private rootDir;
|
|
12
|
+
constructor(options?: {
|
|
13
|
+
rootDir?: string;
|
|
14
|
+
});
|
|
15
|
+
private isPathSafe;
|
|
16
|
+
_call(input: string): Promise<string>;
|
|
17
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.FileReadTool = void 0;
|
|
37
|
+
const tools_1 = require("@langchain/core/tools");
|
|
38
|
+
const fs = __importStar(require("node:fs/promises"));
|
|
39
|
+
const path = __importStar(require("node:path"));
|
|
40
|
+
const config_1 = require("../../config");
|
|
41
|
+
class FileReadTool extends tools_1.Tool {
|
|
42
|
+
constructor(options) {
|
|
43
|
+
super();
|
|
44
|
+
this.name = 'read_file';
|
|
45
|
+
this.description = `Read the content of a file from the local file system.
|
|
46
|
+
Input should be a JSON object with a "path" field (required) and optional fields:
|
|
47
|
+
- encoding: file encoding (default: utf-8)
|
|
48
|
+
- startLine: start reading from this line number
|
|
49
|
+
- endLine: stop reading at this line number
|
|
50
|
+
Example: {"path": "./src/skills/example/SKILL.md"}
|
|
51
|
+
Returns the file content or error message.`;
|
|
52
|
+
this.rootDir = path.resolve(options?.rootDir ?? config_1.FOTRIC_CONFIG.PATHS.ROOT_DIR);
|
|
53
|
+
}
|
|
54
|
+
isPathSafe(filePath) {
|
|
55
|
+
const resolvedPath = path.resolve(this.rootDir, filePath);
|
|
56
|
+
const relativePath = path.relative(this.rootDir, resolvedPath);
|
|
57
|
+
return !relativePath.startsWith('..') && !path.isAbsolute(relativePath);
|
|
58
|
+
}
|
|
59
|
+
async _call(input) {
|
|
60
|
+
let parsedInput;
|
|
61
|
+
try {
|
|
62
|
+
parsedInput = JSON.parse(input);
|
|
63
|
+
}
|
|
64
|
+
catch {
|
|
65
|
+
parsedInput = { path: input, encoding: 'utf-8', startLine: 0, endLine: 0 };
|
|
66
|
+
}
|
|
67
|
+
const { path: filePath, encoding = 'utf-8', startLine = 0, endLine = 0 } = parsedInput;
|
|
68
|
+
if (!filePath) {
|
|
69
|
+
return 'Error: File path is required.';
|
|
70
|
+
}
|
|
71
|
+
if (!this.isPathSafe(filePath)) {
|
|
72
|
+
return `Error: Access denied. Path must be within the project directory: ${this.rootDir}`;
|
|
73
|
+
}
|
|
74
|
+
const absolutePath = path.resolve(this.rootDir, filePath);
|
|
75
|
+
try {
|
|
76
|
+
const stats = await fs.stat(absolutePath);
|
|
77
|
+
if (stats.size > 1024 * 1024) {
|
|
78
|
+
return `Error: File is too large (${(stats.size / 1024 / 1024).toFixed(2)} MB). Maximum size is 1 MB.`;
|
|
79
|
+
}
|
|
80
|
+
const content = await fs.readFile(absolutePath, encoding);
|
|
81
|
+
if (startLine > 0 || endLine > 0) {
|
|
82
|
+
const lines = content.split('\n');
|
|
83
|
+
const start = Math.max(0, startLine > 0 ? startLine - 1 : 0);
|
|
84
|
+
const end = endLine > 0 ? Math.min(lines.length, endLine) : lines.length;
|
|
85
|
+
const selectedLines = lines.slice(start, end);
|
|
86
|
+
return selectedLines.join('\n');
|
|
87
|
+
}
|
|
88
|
+
if (content.length > 50000) {
|
|
89
|
+
return content.substring(0, 50000) + '\n\n...[content truncated]';
|
|
90
|
+
}
|
|
91
|
+
return content;
|
|
92
|
+
}
|
|
93
|
+
catch (error) {
|
|
94
|
+
if (error instanceof Error) {
|
|
95
|
+
if ('code' in error) {
|
|
96
|
+
const nodeError = error;
|
|
97
|
+
if (nodeError.code === 'ENOENT') {
|
|
98
|
+
return `Error: File not found: ${filePath}`;
|
|
99
|
+
}
|
|
100
|
+
if (nodeError.code === 'EACCES') {
|
|
101
|
+
return `Error: Permission denied: ${filePath}`;
|
|
102
|
+
}
|
|
103
|
+
if (nodeError.code === 'EISDIR') {
|
|
104
|
+
return `Error: Path is a directory, not a file: ${filePath}`;
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
return `Error: ${error.message}`;
|
|
108
|
+
}
|
|
109
|
+
return `Error: ${String(error)}`;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
exports.FileReadTool = FileReadTool;
|
|
114
|
+
//# sourceMappingURL=file-read.tool.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-read.tool.js","sourceRoot":"","sources":["../../../src/agent/tools/file-read.tool.ts"],"names":[],"mappings":"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"}
|