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.
Files changed (179) hide show
  1. package/README.md +3 -3
  2. package/backend/dist/agent/agent.module.d.ts +2 -0
  3. package/backend/dist/agent/agent.module.js +23 -0
  4. package/backend/dist/agent/agent.module.js.map +1 -0
  5. package/backend/dist/agent/agent.service.d.ts +25 -0
  6. package/backend/dist/agent/agent.service.js +188 -0
  7. package/backend/dist/agent/agent.service.js.map +1 -0
  8. package/backend/dist/agent/index.d.ts +4 -0
  9. package/backend/dist/agent/index.js +21 -0
  10. package/backend/dist/agent/index.js.map +1 -0
  11. package/backend/dist/agent/llm.factory.d.ts +5 -0
  12. package/backend/dist/agent/llm.factory.js +19 -0
  13. package/backend/dist/agent/llm.factory.js.map +1 -0
  14. package/backend/dist/agent/tools/fetch.tool.d.ts +10 -0
  15. package/backend/dist/agent/tools/fetch.tool.js +145 -0
  16. package/backend/dist/agent/tools/fetch.tool.js.map +1 -0
  17. package/backend/dist/agent/tools/file-read.tool.d.ts +17 -0
  18. package/backend/dist/agent/tools/file-read.tool.js +114 -0
  19. package/backend/dist/agent/tools/file-read.tool.js.map +1 -0
  20. package/backend/dist/agent/tools/index.d.ts +31 -0
  21. package/backend/dist/agent/tools/index.js +52 -0
  22. package/backend/dist/agent/tools/index.js.map +1 -0
  23. package/backend/dist/agent/tools/node-repl.tool.d.ts +12 -0
  24. package/backend/dist/agent/tools/node-repl.tool.js +73 -0
  25. package/backend/dist/agent/tools/node-repl.tool.js.map +1 -0
  26. package/backend/dist/agent/tools/rag.tool.d.ts +23 -0
  27. package/backend/dist/agent/tools/rag.tool.js +186 -0
  28. package/backend/dist/agent/tools/rag.tool.js.map +1 -0
  29. package/backend/dist/agent/tools/shell.tool.d.ts +14 -0
  30. package/backend/dist/agent/tools/shell.tool.js +55 -0
  31. package/backend/dist/agent/tools/shell.tool.js.map +1 -0
  32. package/backend/dist/app.module.d.ts +2 -0
  33. package/backend/dist/app.module.js +39 -0
  34. package/backend/dist/app.module.js.map +1 -0
  35. package/backend/dist/chat/chat.controller.d.ts +13 -0
  36. package/backend/dist/chat/chat.controller.js +60 -0
  37. package/backend/dist/chat/chat.controller.js.map +1 -0
  38. package/backend/dist/chat/chat.module.d.ts +2 -0
  39. package/backend/dist/chat/chat.module.js +25 -0
  40. package/backend/dist/chat/chat.module.js.map +1 -0
  41. package/backend/dist/chat/chat.service.d.ts +10 -0
  42. package/backend/dist/chat/chat.service.js +62 -0
  43. package/backend/dist/chat/chat.service.js.map +1 -0
  44. package/backend/dist/chat/dto/chat.dto.d.ts +11 -0
  45. package/backend/dist/chat/dto/chat.dto.js +10 -0
  46. package/backend/dist/chat/dto/chat.dto.js.map +1 -0
  47. package/backend/dist/chat/dto/index.d.ts +1 -0
  48. package/backend/dist/chat/dto/index.js +18 -0
  49. package/backend/dist/chat/dto/index.js.map +1 -0
  50. package/backend/dist/chat/index.d.ts +4 -0
  51. package/backend/dist/chat/index.js +21 -0
  52. package/backend/dist/chat/index.js.map +1 -0
  53. package/backend/dist/config/config.controller.d.ts +18 -0
  54. package/backend/dist/config/config.controller.js +139 -0
  55. package/backend/dist/config/config.controller.js.map +1 -0
  56. package/backend/dist/config/config.module.d.ts +2 -0
  57. package/backend/dist/config/config.module.js +20 -0
  58. package/backend/dist/config/config.module.js.map +1 -0
  59. package/backend/dist/config/constants.d.ts +30 -0
  60. package/backend/dist/config/constants.js +55 -0
  61. package/backend/dist/config/constants.js.map +1 -0
  62. package/backend/dist/config/index.d.ts +3 -0
  63. package/backend/dist/config/index.js +20 -0
  64. package/backend/dist/config/index.js.map +1 -0
  65. package/backend/dist/files/files.controller.d.ts +25 -0
  66. package/backend/dist/files/files.controller.js +145 -0
  67. package/backend/dist/files/files.controller.js.map +1 -0
  68. package/backend/dist/files/files.module.d.ts +2 -0
  69. package/backend/dist/files/files.module.js +20 -0
  70. package/backend/dist/files/files.module.js.map +1 -0
  71. package/backend/dist/files/index.d.ts +2 -0
  72. package/backend/dist/files/index.js +19 -0
  73. package/backend/dist/files/index.js.map +1 -0
  74. package/backend/dist/main.d.ts +1 -0
  75. package/backend/dist/main.js +19 -0
  76. package/backend/dist/main.js.map +1 -0
  77. package/backend/dist/memory/index.d.ts +3 -0
  78. package/backend/dist/memory/index.js +20 -0
  79. package/backend/dist/memory/index.js.map +1 -0
  80. package/backend/dist/memory/memory.module.d.ts +2 -0
  81. package/backend/dist/memory/memory.module.js +23 -0
  82. package/backend/dist/memory/memory.module.js.map +1 -0
  83. package/backend/dist/memory/memory.service.d.ts +30 -0
  84. package/backend/dist/memory/memory.service.js +342 -0
  85. package/backend/dist/memory/memory.service.js.map +1 -0
  86. package/backend/dist/memory/memory.types.d.ts +35 -0
  87. package/backend/dist/memory/memory.types.js +3 -0
  88. package/backend/dist/memory/memory.types.js.map +1 -0
  89. package/backend/dist/sessions/index.d.ts +2 -0
  90. package/backend/dist/sessions/index.js +19 -0
  91. package/backend/dist/sessions/index.js.map +1 -0
  92. package/backend/dist/sessions/sessions.controller.d.ts +19 -0
  93. package/backend/dist/sessions/sessions.controller.js +60 -0
  94. package/backend/dist/sessions/sessions.controller.js.map +1 -0
  95. package/backend/dist/sessions/sessions.module.d.ts +2 -0
  96. package/backend/dist/sessions/sessions.module.js +22 -0
  97. package/backend/dist/sessions/sessions.module.js.map +1 -0
  98. package/backend/dist/skills/index.d.ts +3 -0
  99. package/backend/dist/skills/index.js +20 -0
  100. package/backend/dist/skills/index.js.map +1 -0
  101. package/backend/dist/skills/skill.types.d.ts +24 -0
  102. package/backend/dist/skills/skill.types.js +3 -0
  103. package/backend/dist/skills/skill.types.js.map +1 -0
  104. package/backend/dist/skills/skills.module.d.ts +2 -0
  105. package/backend/dist/skills/skills.module.js +21 -0
  106. package/backend/dist/skills/skills.module.js.map +1 -0
  107. package/backend/dist/skills/skills.service.d.ts +17 -0
  108. package/backend/dist/skills/skills.service.js +167 -0
  109. package/backend/dist/skills/skills.service.js.map +1 -0
  110. package/backend/dist/tsconfig.build.tsbuildinfo +1 -0
  111. package/bin/fotric-claw.js +3 -5
  112. package/frontend/.next/standalone/.next/BUILD_ID +1 -0
  113. package/frontend/.next/standalone/.next/app-build-manifest.json +26 -0
  114. package/frontend/.next/standalone/.next/app-path-routes-manifest.json +1 -0
  115. package/frontend/.next/standalone/.next/build-manifest.json +32 -0
  116. package/frontend/.next/standalone/.next/package.json +1 -0
  117. package/frontend/.next/standalone/.next/prerender-manifest.js +1 -0
  118. package/frontend/.next/standalone/.next/prerender-manifest.json +1 -0
  119. package/frontend/.next/standalone/.next/react-loadable-manifest.json +1 -0
  120. package/frontend/.next/standalone/.next/required-server-files.json +1 -0
  121. package/frontend/.next/standalone/.next/routes-manifest.json +1 -0
  122. package/frontend/.next/standalone/.next/server/app/_not-found.html +1 -0
  123. package/frontend/.next/standalone/.next/server/app/_not-found.js +1 -0
  124. package/frontend/.next/standalone/.next/server/app/_not-found.js.nft.json +1 -0
  125. package/frontend/.next/standalone/.next/server/app/_not-found.meta +5 -0
  126. package/frontend/.next/standalone/.next/server/app/_not-found.rsc +9 -0
  127. package/frontend/.next/standalone/.next/server/app/_not-found_client-reference-manifest.js +1 -0
  128. package/frontend/.next/standalone/.next/server/app/index.html +1 -0
  129. package/frontend/.next/standalone/.next/server/app/index.meta +5 -0
  130. package/frontend/.next/standalone/.next/server/app/index.rsc +7 -0
  131. package/frontend/.next/standalone/.next/server/app/page.js +6 -0
  132. package/frontend/.next/standalone/.next/server/app/page.js.nft.json +1 -0
  133. package/frontend/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -0
  134. package/frontend/.next/standalone/.next/server/app-paths-manifest.json +4 -0
  135. package/frontend/.next/standalone/.next/server/chunks/198.js +1 -0
  136. package/frontend/.next/standalone/.next/server/chunks/72.js +6 -0
  137. package/frontend/.next/standalone/.next/server/font-manifest.json +1 -0
  138. package/frontend/.next/standalone/.next/server/middleware-build-manifest.js +1 -0
  139. package/frontend/.next/standalone/.next/server/middleware-manifest.json +6 -0
  140. package/frontend/.next/standalone/.next/server/middleware-react-loadable-manifest.js +1 -0
  141. package/frontend/.next/standalone/.next/server/next-font-manifest.js +1 -0
  142. package/frontend/.next/standalone/.next/server/next-font-manifest.json +1 -0
  143. package/frontend/.next/standalone/.next/server/pages/404.html +1 -0
  144. package/frontend/.next/standalone/.next/server/pages/500.html +1 -0
  145. package/frontend/.next/standalone/.next/server/pages/_app.js +1 -0
  146. package/frontend/.next/standalone/.next/server/pages/_app.js.nft.json +1 -0
  147. package/frontend/.next/standalone/.next/server/pages/_document.js +1 -0
  148. package/frontend/.next/standalone/.next/server/pages/_document.js.nft.json +1 -0
  149. package/frontend/.next/standalone/.next/server/pages/_error.js +1 -0
  150. package/frontend/.next/standalone/.next/server/pages/_error.js.nft.json +1 -0
  151. package/frontend/.next/standalone/.next/server/pages-manifest.json +1 -0
  152. package/frontend/.next/standalone/.next/server/server-reference-manifest.js +1 -0
  153. package/frontend/.next/standalone/.next/server/server-reference-manifest.json +1 -0
  154. package/frontend/.next/standalone/.next/server/webpack-runtime.js +1 -0
  155. package/frontend/.next/standalone/package.json +33 -0
  156. package/frontend/.next/standalone/server.js +38 -0
  157. package/frontend/.next/static/chunks/69-805ec1f4609643a8.js +1 -0
  158. package/frontend/.next/static/chunks/app/_not-found-f3ef8a2303cba633.js +1 -0
  159. package/frontend/.next/static/chunks/app/layout-de1b1ea4b8b69df0.js +1 -0
  160. package/frontend/.next/static/chunks/app/page-1771b63ea7f81cb8.js +6 -0
  161. package/frontend/.next/static/chunks/fd9d1056-3f67bd7f04959fd0.js +1 -0
  162. package/frontend/.next/static/chunks/framework-f66176bb897dc684.js +33 -0
  163. package/frontend/.next/static/chunks/main-068ac7cb3150df84.js +6 -0
  164. package/frontend/.next/static/chunks/main-app-0aed8e506d485ff1.js +1 -0
  165. package/frontend/.next/static/chunks/pages/_app-75f6107b0260711c.js +1 -0
  166. package/frontend/.next/static/chunks/pages/_error-9a890acb1e81c3fc.js +1 -0
  167. package/frontend/.next/static/chunks/polyfills-c67a75d1b6f99dc8.js +1 -0
  168. package/frontend/.next/static/chunks/webpack-710020a2da4f33c6.js +1 -0
  169. package/frontend/.next/static/css/9fa9af8cbf321465.css +3 -0
  170. package/frontend/.next/static/media/19cfc7226ec3afaa-s.woff2 +0 -0
  171. package/frontend/.next/static/media/21350d82a1f187e9-s.woff2 +0 -0
  172. package/frontend/.next/static/media/8e9860b6e62d6359-s.woff2 +0 -0
  173. package/frontend/.next/static/media/ba9851c3c22cd980-s.woff2 +0 -0
  174. package/frontend/.next/static/media/c5fe6dc8356a8c31-s.woff2 +0 -0
  175. package/frontend/.next/static/media/df0a9ae256c0569c-s.woff2 +0 -0
  176. package/frontend/.next/static/media/e4af272ccee01ff0-s.p.woff2 +0 -0
  177. package/frontend/.next/static/zCAHMEXFOA7RWLDEftDeM/_buildManifest.js +1 -0
  178. package/frontend/.next/static/zCAHMEXFOA7RWLDEftDeM/_ssgManifest.js +1 -0
  179. 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:prod
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:prod Start backend and frontend services (production mode)
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:prod
197
+ fotric-claw start
198
198
  ```
199
199
 
200
200
  **源码安装用户:**
@@ -0,0 +1,2 @@
1
+ export declare class AgentModule {
2
+ }
@@ -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,4 @@
1
+ export * from './agent.service';
2
+ export * from './agent.module';
3
+ export * from './llm.factory';
4
+ export * from './tools';
@@ -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,5 @@
1
+ import { ChatOpenAI } from '@langchain/openai';
2
+ export declare function createLLM(options?: {
3
+ temperature?: number;
4
+ maxTokens?: number;
5
+ }): ChatOpenAI;
@@ -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,10 @@
1
+ import { Tool } from '@langchain/core/tools';
2
+ export interface FetchURLInput {
3
+ url: string;
4
+ selector: string;
5
+ }
6
+ export declare class FetchURLTool extends Tool {
7
+ name: string;
8
+ description: string;
9
+ _call(input: string): Promise<string>;
10
+ }
@@ -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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"}