@ai-setting/roy-agent-core 1.4.13 → 1.4.14

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 (103) hide show
  1. package/dist/packages/core/src/config/index.js +32 -0
  2. package/dist/packages/core/src/env/agent/index.js +24 -0
  3. package/dist/packages/core/src/env/commands/index.js +14 -0
  4. package/dist/packages/core/src/env/debug/formatters/index.js +11 -0
  5. package/dist/packages/core/src/env/debug/index.js +26 -0
  6. package/dist/packages/core/src/env/hook/index.js +29 -0
  7. package/dist/packages/core/src/env/index.js +81 -0
  8. package/dist/packages/core/src/env/llm/index.js +40 -0
  9. package/dist/packages/core/src/env/log-trace/index.js +83 -0
  10. package/dist/packages/core/src/env/mcp/index.js +39 -0
  11. package/dist/packages/core/src/env/mcp/tool/index.js +14 -0
  12. package/dist/packages/core/src/env/memory/built-in/index.js +11 -0
  13. package/dist/packages/core/src/env/memory/index.js +56 -0
  14. package/dist/packages/core/src/env/memory/plugin/index.js +36 -0
  15. package/dist/packages/core/src/env/prompt/index.js +20 -0
  16. package/dist/packages/core/src/env/session/index.js +25 -0
  17. package/dist/packages/core/src/env/session/storage/index.js +18 -0
  18. package/dist/packages/core/src/env/skill/index.js +34 -0
  19. package/dist/packages/core/src/env/skill/tool/index.js +9 -0
  20. package/dist/packages/core/src/env/task/delegate/index.js +18 -0
  21. package/dist/packages/core/src/env/task/hooks/index.js +7 -0
  22. package/dist/packages/core/src/env/task/index.js +30 -0
  23. package/dist/packages/core/src/env/task/plugins/index.js +23 -0
  24. package/dist/packages/core/src/env/task/storage/index.js +14 -0
  25. package/dist/packages/core/src/env/task/tools/index.js +17 -0
  26. package/dist/packages/core/src/env/task/tools/operation/index.js +15 -0
  27. package/dist/{shared/chunk-1d4rwms4.js → packages/core/src/env/tool/built-in/index.js} +4 -4
  28. package/dist/packages/core/src/env/tool/index.js +39 -0
  29. package/dist/packages/core/src/env/workflow/decorators/index.js +27 -0
  30. package/dist/packages/core/src/env/workflow/engine/index.js +28 -0
  31. package/dist/packages/core/src/env/workflow/index.js +132 -0
  32. package/dist/packages/core/src/env/workflow/nodes/index.js +19 -0
  33. package/dist/packages/core/src/env/workflow/service/index.js +13 -0
  34. package/dist/packages/core/src/env/workflow/storage/index.js +27 -0
  35. package/dist/packages/core/src/env/workflow/tools/index.js +159 -0
  36. package/dist/packages/core/src/env/workflow/types/index.js +94 -0
  37. package/dist/packages/core/src/env/workflow/utils/index.js +637 -0
  38. package/dist/packages/core/src/index.js +398 -0
  39. package/dist/shared/@ai-setting/roy-agent-core-04fm8177.js +393 -0
  40. package/dist/shared/@ai-setting/roy-agent-core-04qgbjbe.js +172 -0
  41. package/dist/shared/@ai-setting/roy-agent-core-084qqd7t.js +11 -0
  42. package/dist/shared/@ai-setting/roy-agent-core-0gekht4e.js +1130 -0
  43. package/dist/shared/@ai-setting/roy-agent-core-0hdry23r.js +419 -0
  44. package/dist/shared/{chunk-ze20rksg.js → @ai-setting/roy-agent-core-0sgn3de4.js} +2 -2
  45. package/dist/shared/@ai-setting/roy-agent-core-12x57kf1.js +286 -0
  46. package/dist/shared/@ai-setting/roy-agent-core-1f3xrrm6.js +393 -0
  47. package/dist/shared/{chunk-q9j99fsm.js → @ai-setting/roy-agent-core-1k28kg7h.js} +6 -6
  48. package/dist/shared/{chunk-2b5kbhx3.js → @ai-setting/roy-agent-core-1z1zv5g8.js} +9 -117
  49. package/dist/shared/@ai-setting/roy-agent-core-2hqxnaf3.js +851 -0
  50. package/dist/shared/@ai-setting/roy-agent-core-3dfq8awb.js +587 -0
  51. package/dist/shared/@ai-setting/roy-agent-core-3takar0s.js +93 -0
  52. package/dist/shared/@ai-setting/roy-agent-core-3tnb2005.js +117 -0
  53. package/dist/shared/@ai-setting/roy-agent-core-4vmcvkav.js +14 -0
  54. package/dist/shared/{chunk-25x2pdtp.js → @ai-setting/roy-agent-core-4ws8atva.js} +2 -2
  55. package/dist/shared/@ai-setting/roy-agent-core-5fbp24se.js +603 -0
  56. package/dist/shared/@ai-setting/roy-agent-core-5my94ywp.js +66 -0
  57. package/dist/shared/{chunk-rncy3rtd.js → @ai-setting/roy-agent-core-6j0zcmwk.js} +128 -1122
  58. package/dist/shared/@ai-setting/roy-agent-core-6w4pmxc7.js +266 -0
  59. package/dist/shared/{chunk-yqmx37vm.js → @ai-setting/roy-agent-core-7vrk3add.js} +2 -2
  60. package/dist/shared/@ai-setting/roy-agent-core-8dvbn7tw.js +64 -0
  61. package/dist/shared/@ai-setting/roy-agent-core-8mbmrwzs.js +171 -0
  62. package/dist/shared/@ai-setting/roy-agent-core-8wzz66qe.js +620 -0
  63. package/dist/shared/@ai-setting/roy-agent-core-9ykq91jc.js +762 -0
  64. package/dist/shared/@ai-setting/roy-agent-core-dde19zke.js +1305 -0
  65. package/dist/shared/@ai-setting/roy-agent-core-f7g67gce.js +913 -0
  66. package/dist/shared/@ai-setting/roy-agent-core-fq5mtxsy.js +341 -0
  67. package/dist/shared/@ai-setting/roy-agent-core-fvd9g6k8.js +1205 -0
  68. package/dist/shared/@ai-setting/roy-agent-core-gv1hrn3x.js +378 -0
  69. package/dist/shared/@ai-setting/roy-agent-core-gy0wp5h7.js +213 -0
  70. package/dist/shared/{chunk-mf5xqbdh.js → @ai-setting/roy-agent-core-hyza1gm7.js} +3 -2
  71. package/dist/shared/{chunk-1qwabsm0.js → @ai-setting/roy-agent-core-j8zx62zr.js} +2 -2
  72. package/dist/shared/@ai-setting/roy-agent-core-jb2exr0d.js +442 -0
  73. package/dist/shared/@ai-setting/roy-agent-core-jv3b7v9w.js +57 -0
  74. package/dist/shared/@ai-setting/roy-agent-core-k1rxf9ya.js +513 -0
  75. package/dist/shared/@ai-setting/roy-agent-core-kydc9nwb.js +60 -0
  76. package/dist/shared/@ai-setting/roy-agent-core-m2x48hw6.js +97 -0
  77. package/dist/shared/@ai-setting/roy-agent-core-m6y668cc.js +377 -0
  78. package/dist/shared/{chunk-1aakcfp1.js → @ai-setting/roy-agent-core-nczzf0ms.js} +3 -3
  79. package/dist/shared/@ai-setting/roy-agent-core-nfj6knp5.js +36 -0
  80. package/dist/shared/@ai-setting/roy-agent-core-ntrp979d.js +204 -0
  81. package/dist/shared/@ai-setting/roy-agent-core-pd7g8z5v.js +1387 -0
  82. package/dist/shared/@ai-setting/roy-agent-core-pzk1syce.js +14 -0
  83. package/dist/shared/@ai-setting/roy-agent-core-q50tg9m2.js +862 -0
  84. package/dist/shared/{chunk-9qzt1v1p.js → @ai-setting/roy-agent-core-qg9tcaph.js} +3 -2
  85. package/dist/shared/{chunk-91bas8w5.js → @ai-setting/roy-agent-core-qhyerewk.js} +5 -5
  86. package/dist/shared/{chunk-1pf5mfgd.js → @ai-setting/roy-agent-core-qxybm159.js} +3 -3
  87. package/dist/shared/{chunk-g6j5n3gv.js → @ai-setting/roy-agent-core-rh9dpkpw.js} +10 -10
  88. package/dist/shared/{chunk-0q6s9wm6.js → @ai-setting/roy-agent-core-rr9p1g43.js} +7 -51
  89. package/dist/shared/@ai-setting/roy-agent-core-sbzvpfn7.js +284 -0
  90. package/dist/shared/@ai-setting/roy-agent-core-t22nqt4d.js +788 -0
  91. package/dist/shared/{chunk-t1rh6jtm.js → @ai-setting/roy-agent-core-tkr5ynkh.js} +8 -13
  92. package/dist/shared/@ai-setting/roy-agent-core-v4aabsf0.js +303 -0
  93. package/dist/shared/@ai-setting/roy-agent-core-w75rafhy.js +202 -0
  94. package/dist/shared/@ai-setting/roy-agent-core-w76hqkmg.js +584 -0
  95. package/dist/shared/@ai-setting/roy-agent-core-yfbgwes2.js +408 -0
  96. package/dist/shared/{chunk-a9qmy3sc.js → @ai-setting/roy-agent-core-yn761yve.js} +7 -4
  97. package/dist/shared/@ai-setting/roy-agent-core-yrzmn4m1.js +492 -0
  98. package/dist/shared/@ai-setting/roy-agent-core-yt8wdh2w.js +206 -0
  99. package/package.json +8 -7
  100. package/dist/index.d.ts +0 -7825
  101. package/dist/index.js +0 -16551
  102. package/dist/shared/chunk-hs7tbmje.js +0 -24
  103. /package/dist/shared/{chunk-wbkh7wat.js → @ai-setting/roy-agent-core-fs0mn2jk.js} +0 -0
@@ -0,0 +1,266 @@
1
+ import {
2
+ exports_node_registry_helper,
3
+ init_node_registry_helper
4
+ } from "./roy-agent-core-1z1zv5g8.js";
5
+ import {
6
+ askUserTool
7
+ } from "./roy-agent-core-nfj6knp5.js";
8
+ import {
9
+ WorkflowEngine,
10
+ exports_engine,
11
+ init_engine
12
+ } from "./roy-agent-core-6j0zcmwk.js";
13
+ import {
14
+ WorkflowService
15
+ } from "./roy-agent-core-yt8wdh2w.js";
16
+ import {
17
+ BaseComponent
18
+ } from "./roy-agent-core-m2x48hw6.js";
19
+ import {
20
+ createLogger,
21
+ init_logger
22
+ } from "./roy-agent-core-yn761yve.js";
23
+ import {
24
+ __require,
25
+ __toCommonJS
26
+ } from "./roy-agent-core-fs0mn2jk.js";
27
+
28
+ // packages/core/src/env/workflow/workflow-component.ts
29
+ import"reflect-metadata";
30
+ init_engine();
31
+ init_logger();
32
+ init_engine();
33
+ init_node_registry_helper();
34
+ var componentLogger = createLogger("workflow");
35
+
36
+ class SkillRegistryAdapter {
37
+ skillComponent;
38
+ constructor(skillComponent) {
39
+ this.skillComponent = skillComponent;
40
+ }
41
+ getSkill(name) {
42
+ const entry = this.skillComponent.getSkill(name);
43
+ if (!entry)
44
+ return;
45
+ return {
46
+ name: entry.name,
47
+ invoke: async (input, context) => {
48
+ return entry.content;
49
+ }
50
+ };
51
+ }
52
+ hasSkill(name) {
53
+ return this.skillComponent.hasSkill(name);
54
+ }
55
+ }
56
+
57
+ class WorkflowComponent extends BaseComponent {
58
+ name = "workflow";
59
+ version = "1.0.0";
60
+ workflowService = null;
61
+ sessionComponent = null;
62
+ nodeRegistry = null;
63
+ decoratorsRegistered = false;
64
+ getService() {
65
+ return this.workflowService;
66
+ }
67
+ toolComponent;
68
+ llmComponent;
69
+ logTraceComponent;
70
+ _workflowEnv;
71
+ skillRegistry;
72
+ agentRunner;
73
+ async init(options) {
74
+ const opts = options;
75
+ this._status = "initializing";
76
+ componentLogger.info("Initializing WorkflowComponent...");
77
+ this.toolComponent = opts.toolComponent;
78
+ this.llmComponent = opts.llmComponent;
79
+ this.logTraceComponent = opts.logTraceComponent;
80
+ this._workflowEnv = opts.env;
81
+ this.skillRegistry = opts.skillRegistry;
82
+ this.agentRunner = opts.agentRunner;
83
+ try {
84
+ if (opts.autoRegisterDecorators !== false) {
85
+ await this.registerDecorators();
86
+ }
87
+ this._status = "ready";
88
+ componentLogger.info("WorkflowComponent initialized successfully");
89
+ } catch (error) {
90
+ this._status = "error";
91
+ componentLogger.error("Failed to initialize WorkflowComponent:", error);
92
+ throw error;
93
+ }
94
+ }
95
+ async registerDecorators() {
96
+ if (this.decoratorsRegistered)
97
+ return;
98
+ try {
99
+ const { NodeRegistry } = await import("../../packages/core/src/env/workflow/engine/index.js");
100
+ const { registerDecoratorNodeType: registerDecoratorNodeType2 } = await import("./roy-agent-core-hyza1gm7.js");
101
+ this.nodeRegistry = new NodeRegistry;
102
+ registerDecoratorNodeType2(this.nodeRegistry);
103
+ this.decoratorsRegistered = true;
104
+ componentLogger.info("Decorator node type registered");
105
+ } catch (error) {
106
+ componentLogger.error("Failed to register decorator node type:", error);
107
+ throw error;
108
+ }
109
+ }
110
+ createService(options) {
111
+ const skillRegistryAdapter = options.skillRegistry ? new SkillRegistryAdapter(options.skillRegistry) : undefined;
112
+ const sessionComponentForEngine = options.sessionComponent;
113
+ const engineFactory = (workflow, opts) => {
114
+ const { NodeRegistry, WorkflowEngine: WorkflowEngine2 } = (init_engine(), __toCommonJS(exports_engine));
115
+ const registry = new NodeRegistry({
116
+ toolRegistry: options.toolComponent,
117
+ agentComponent: options.env?.getComponent("agent"),
118
+ skillRegistry: skillRegistryAdapter,
119
+ sessionComponent: sessionComponentForEngine
120
+ });
121
+ const { registerDecoratorNodeType: registerDecoratorNodeType2 } = (init_node_registry_helper(), __toCommonJS(exports_node_registry_helper));
122
+ registerDecoratorNodeType2(registry);
123
+ return new WorkflowEngine2(registry, sessionComponentForEngine, options.workflowRepository);
124
+ };
125
+ this.workflowService = new WorkflowService(options.workflowRepository, engineFactory, options.sessionComponent);
126
+ return this.workflowService;
127
+ }
128
+ async runWorkflow(definition, input, options) {
129
+ const { NodeRegistry } = await import("../../packages/core/src/env/workflow/engine/index.js");
130
+ const { registerDecoratorNodeType: registerDecoratorNodeType2 } = await import("./roy-agent-core-hyza1gm7.js");
131
+ const toolComponent = this.toolComponent || this._workflowEnv?.getComponent("tool");
132
+ const skillComponent = this._workflowEnv?.getComponent("skill");
133
+ let agentRunner = this.agentRunner;
134
+ if (!agentRunner && this._workflowEnv) {
135
+ const agentComponent = this._workflowEnv.getComponent("agent");
136
+ if (agentComponent) {
137
+ const { AgentComponentAdapter } = await import("./roy-agent-core-qg9tcaph.js");
138
+ agentRunner = new AgentComponentAdapter(agentComponent);
139
+ }
140
+ }
141
+ const registry = new NodeRegistry({
142
+ toolRegistry: toolComponent,
143
+ skillRegistry: skillComponent,
144
+ agentRunner
145
+ });
146
+ registerDecoratorNodeType2(registry);
147
+ const engine = new WorkflowEngine(registry);
148
+ return engine.runWorkflow(definition, { ...options, input });
149
+ }
150
+ async onStop() {
151
+ componentLogger.info("[WorkflowComponent] Stopping and cleaning up resources...");
152
+ if (this.nodeRegistry) {
153
+ this.nodeRegistry = null;
154
+ }
155
+ if (this.workflowService) {
156
+ this.workflowService = null;
157
+ try {
158
+ const { closeDatabase } = await import("./roy-agent-core-qhyerewk.js");
159
+ closeDatabase();
160
+ componentLogger.info("[WorkflowComponent] SQLite database closed");
161
+ } catch (error) {
162
+ componentLogger.warn("[WorkflowComponent] Failed to close SQLite database:", error);
163
+ }
164
+ }
165
+ this._status = "stopped";
166
+ componentLogger.info("[WorkflowComponent] Cleanup completed");
167
+ }
168
+ async start() {
169
+ await super.start();
170
+ await this.initSqliteService();
171
+ await this.registerAskUserTool();
172
+ }
173
+ async registerAskUserTool() {
174
+ try {
175
+ const toolComponent = this.toolComponent || this._workflowEnv?.getComponent("tool");
176
+ if (!toolComponent) {
177
+ componentLogger.warn("ToolComponent not available, cannot register ask_user tool");
178
+ return;
179
+ }
180
+ if (typeof toolComponent.register === "function") {
181
+ toolComponent.register(askUserTool);
182
+ componentLogger.info("ask_user tool registered to ToolComponent");
183
+ } else if (typeof toolComponent.registerMany === "function") {
184
+ toolComponent.registerMany([askUserTool]);
185
+ componentLogger.info("ask_user tool registered to ToolComponent");
186
+ } else {
187
+ componentLogger.warn("ToolComponent does not support tool registration");
188
+ }
189
+ } catch (error) {
190
+ componentLogger.warn("Failed to register ask_user tool:", error);
191
+ }
192
+ }
193
+ async initSqliteService() {
194
+ try {
195
+ const { getDatabase, initializeTables } = await import("./roy-agent-core-qhyerewk.js");
196
+ const { WorkflowRepository } = await import("./roy-agent-core-4vmcvkav.js");
197
+ const db = getDatabase();
198
+ initializeTables();
199
+ const workflowRepository = new WorkflowRepository(db);
200
+ const toolComponent = this.toolComponent || this._workflowEnv?.getComponent("tool");
201
+ const llmComponent = this.llmComponent || this._workflowEnv?.getComponent("llm");
202
+ const agentComponent = this._workflowEnv?.getComponent("agent");
203
+ const skillComponent = this.skillRegistry || this._workflowEnv?.getComponent("skill");
204
+ const sessionComponent = this._workflowEnv?.getComponent("session");
205
+ componentLogger.info(`initSqliteService - toolComponent: ${!!toolComponent}, llmComponent: ${!!llmComponent}, skillRegistry: ${!!skillComponent}, sessionComponent: ${!!sessionComponent}`);
206
+ this.createService({
207
+ workflowRepository,
208
+ toolComponent,
209
+ llmComponent,
210
+ env: this._workflowEnv,
211
+ skillRegistry: skillComponent,
212
+ sessionComponent
213
+ });
214
+ this.sessionComponent = sessionComponent;
215
+ await this.registerAskUserTool();
216
+ componentLogger.info("SQLite WorkflowService initialized successfully");
217
+ } catch (error) {
218
+ componentLogger.error("Failed to initialize SQLite WorkflowService:", error);
219
+ await this.createInMemoryService();
220
+ }
221
+ }
222
+ createInMemoryService() {
223
+ const workflows = new Map;
224
+ const workflowRepository = {
225
+ create: (wf) => {
226
+ const id = wf.id || `wf_${Date.now()}`;
227
+ const record = { ...wf, id, createdAt: new Date, updatedAt: new Date };
228
+ workflows.set(id, record);
229
+ return record;
230
+ },
231
+ getById: (id) => workflows.get(id) || null,
232
+ getByName: (name) => {
233
+ for (const wf of workflows.values()) {
234
+ if (wf.name === name)
235
+ return wf;
236
+ }
237
+ return null;
238
+ },
239
+ list: () => Array.from(workflows.values()),
240
+ update: (id, updates) => {
241
+ const wf = workflows.get(id);
242
+ if (!wf)
243
+ return null;
244
+ const updated = { ...wf, ...updates, updatedAt: new Date };
245
+ workflows.set(id, updated);
246
+ return updated;
247
+ },
248
+ delete: (id) => workflows.delete(id)
249
+ };
250
+ const sessionComponent = this._workflowEnv?.getComponent("session");
251
+ return this.createService({
252
+ workflowRepository,
253
+ sessionComponent
254
+ });
255
+ }
256
+ async stop() {
257
+ componentLogger.info("Stopping WorkflowComponent...");
258
+ this._status = "stopping";
259
+ this.workflowService = null;
260
+ this.nodeRegistry = null;
261
+ this._status = "stopped";
262
+ componentLogger.info("WorkflowComponent stopped");
263
+ }
264
+ }
265
+
266
+ export { WorkflowComponent };
@@ -1,8 +1,8 @@
1
1
  import {
2
2
  SQLiteSpanStorage,
3
3
  init_span_storage
4
- } from "./chunk-1qwabsm0.js";
5
- import"./chunk-wbkh7wat.js";
4
+ } from "./roy-agent-core-j8zx62zr.js";
5
+ import"./roy-agent-core-fs0mn2jk.js";
6
6
  init_span_storage();
7
7
 
8
8
  export {
@@ -0,0 +1,64 @@
1
+ import {
2
+ __esm
3
+ } from "./roy-agent-core-fs0mn2jk.js";
4
+
5
+ // packages/core/src/env/workflow/types/workflow-hil.ts
6
+ function createNodeInterruptEvent(runId, nodeId, nodeType, query, agentSessionId) {
7
+ return {
8
+ type: "node.interrupt",
9
+ run_id: runId,
10
+ timestamp: Date.now(),
11
+ node_id: nodeId,
12
+ node_type: nodeType,
13
+ query,
14
+ ...agentSessionId ? { agent_session_id: agentSessionId } : {}
15
+ };
16
+ }
17
+ function createWorkflowAskUserEvent(runId, sessionId, nodeId, nodeType, query) {
18
+ return {
19
+ type: "workflow.ask-user",
20
+ run_id: runId,
21
+ timestamp: Date.now(),
22
+ session_id: sessionId,
23
+ node_id: nodeId,
24
+ node_type: nodeType,
25
+ query
26
+ };
27
+ }
28
+ var AskUserError;
29
+ var init_workflow_hil = __esm(() => {
30
+ AskUserError = class AskUserError extends Error {
31
+ runId;
32
+ sessionId;
33
+ nodeId;
34
+ nodeType;
35
+ query;
36
+ agentSessionId;
37
+ timestamp;
38
+ type = "ask-user";
39
+ name = "AskUserError";
40
+ constructor(runId, sessionId, nodeId, nodeType, query, agentSessionId, timestamp = Date.now()) {
41
+ super(`[${nodeType}:${nodeId}] Ask user: ${query}`);
42
+ this.runId = runId;
43
+ this.sessionId = sessionId;
44
+ this.nodeId = nodeId;
45
+ this.nodeType = nodeType;
46
+ this.query = query;
47
+ this.agentSessionId = agentSessionId;
48
+ this.timestamp = timestamp;
49
+ }
50
+ toEvent() {
51
+ return {
52
+ type: "workflow.ask-user",
53
+ run_id: this.runId,
54
+ timestamp: this.timestamp,
55
+ session_id: this.sessionId,
56
+ node_id: this.nodeId,
57
+ node_type: this.nodeType,
58
+ query: this.query
59
+ };
60
+ }
61
+ };
62
+ });
63
+
64
+ export { createNodeInterruptEvent, createWorkflowAskUserEvent, AskUserError, init_workflow_hil };
@@ -0,0 +1,171 @@
1
+ // packages/core/src/env/memory/built-in/record-memory.ts
2
+ import { z } from "zod";
3
+ var RecordMemorySchema = z.object({
4
+ scope: z.enum(["project", "global"]).describe("作用域: project/global"),
5
+ mode: z.enum(["append", "prepend", "overwrite", "delete"]).describe("模式: append(追加)/prepend(插入)/overwrite(覆盖)/delete(删除)"),
6
+ content: z.string().optional().describe("记忆内容"),
7
+ title: z.string().optional().describe("章节标题")
8
+ });
9
+ function createRecordMemoryTool(recordMemory, getMemoryPaths, getMemoryFile) {
10
+ return {
11
+ name: "record_memory",
12
+ description: buildDescription(getMemoryPaths, getMemoryFile),
13
+ parameters: RecordMemorySchema,
14
+ execute: async (args, _ctx) => {
15
+ const params = RecordMemorySchema.parse(args);
16
+ const startTime = Date.now();
17
+ try {
18
+ const result = await recordMemory({
19
+ scope: params.scope,
20
+ mode: params.mode,
21
+ content: params.content,
22
+ title: params.title
23
+ });
24
+ if (!result) {
25
+ return {
26
+ success: false,
27
+ output: "",
28
+ error: "未配置 memory 路径,无法记录记忆",
29
+ metadata: { execution_time_ms: Date.now() - startTime }
30
+ };
31
+ }
32
+ const actionMessages = {
33
+ created: "已创建记忆文件",
34
+ overwrite: "已覆盖记忆文件",
35
+ append: "已追加内容到记忆文件",
36
+ prepend: "已插入内容到记忆文件开头",
37
+ delete: "已删除记忆文件"
38
+ };
39
+ return {
40
+ success: true,
41
+ output: `${actionMessages[result.action]}: ${result.path}`,
42
+ metadata: {
43
+ execution_time_ms: Date.now() - startTime,
44
+ path: result.path,
45
+ action: result.action
46
+ }
47
+ };
48
+ } catch (error) {
49
+ return {
50
+ success: false,
51
+ output: "",
52
+ error: error instanceof Error ? error.message : String(error),
53
+ metadata: { execution_time_ms: Date.now() - startTime }
54
+ };
55
+ }
56
+ }
57
+ };
58
+ }
59
+ function buildDescription(getMemoryPaths, getMemoryFile) {
60
+ const paths = getMemoryPaths();
61
+ const memoryFile = getMemoryFile();
62
+ const lines = [
63
+ `# Record Memory Tool`,
64
+ "",
65
+ `Record memory to file. Writes to the memory.md file in the specified scope.`,
66
+ "",
67
+ `## Modes`,
68
+ "",
69
+ "| Mode | Description |",
70
+ "|------|-------------|",
71
+ "| **append** | 追加内容到 ${memoryFile} 尾部 |",
72
+ "| **prepend** | 插入内容到 ${memoryFile} 开头 |",
73
+ "| **overwrite** | 覆盖 ${memoryFile} |",
74
+ "| **delete** | 删除 ${memoryFile} |",
75
+ "",
76
+ `## Parameters`,
77
+ "",
78
+ "- **scope** (required): 作用域 - project 或 global",
79
+ "- **mode** (required): 操作模式",
80
+ "- **content** (optional): 记忆内容",
81
+ "- **title** (optional): 章节标题",
82
+ "",
83
+ `## Memory Paths`,
84
+ ""
85
+ ];
86
+ if (paths.length === 0) {
87
+ lines.push("No memory paths configured.");
88
+ } else {
89
+ lines.push("Files will be written to:");
90
+ for (const p of paths) {
91
+ lines.push(`- **[${p.type}]** ${p.path}/${memoryFile}`);
92
+ }
93
+ }
94
+ return lines.join(`
95
+ `);
96
+ }
97
+
98
+ // packages/core/src/env/memory/built-in/recall-memory.ts
99
+ import { z as z2 } from "zod";
100
+ var RecallMemorySchema = z2.object({
101
+ scope: z2.enum(["project", "global"]).optional().describe("作用域(可选,不传则读取所有)")
102
+ });
103
+ function createRecallMemoryTool(recallMemory, getMemoryPaths, getMemoryFile) {
104
+ return {
105
+ name: "recall_memory",
106
+ description: buildDescription2(getMemoryPaths, getMemoryFile),
107
+ parameters: RecallMemorySchema,
108
+ execute: async (args, _ctx) => {
109
+ const params = RecallMemorySchema.parse(args);
110
+ const startTime = Date.now();
111
+ try {
112
+ const content = await recallMemory(params.scope);
113
+ if (!content) {
114
+ return {
115
+ success: true,
116
+ output: "(No memory files found)",
117
+ metadata: { execution_time_ms: Date.now() - startTime }
118
+ };
119
+ }
120
+ return {
121
+ success: true,
122
+ output: content,
123
+ metadata: { execution_time_ms: Date.now() - startTime }
124
+ };
125
+ } catch (error) {
126
+ return {
127
+ success: false,
128
+ output: "",
129
+ error: error instanceof Error ? error.message : String(error),
130
+ metadata: { execution_time_ms: Date.now() - startTime }
131
+ };
132
+ }
133
+ }
134
+ };
135
+ }
136
+ function buildDescription2(getMemoryPaths, getMemoryFile) {
137
+ const paths = getMemoryPaths();
138
+ const memoryFile = getMemoryFile();
139
+ const lines = [
140
+ `# Recall Memory Tool`,
141
+ "",
142
+ `Recall memory from memory files. Reads from the memory.md file in the specified scope.`,
143
+ "",
144
+ `## Parameters`,
145
+ "",
146
+ "- **scope** (optional): 作用域 - project 或 global(不传则读取所有)",
147
+ "",
148
+ `## Memory Files`,
149
+ ""
150
+ ];
151
+ if (paths.length === 0) {
152
+ lines.push("No memory paths configured.");
153
+ } else {
154
+ lines.push("Files will be read from:");
155
+ for (const p of paths) {
156
+ lines.push(`- **[${p.type}]** ${p.path}/${memoryFile}`);
157
+ }
158
+ }
159
+ return lines.join(`
160
+ `);
161
+ }
162
+
163
+ // packages/core/src/env/memory/built-in/index.ts
164
+ function createMemoryTools(recordMemory, recallMemory, config) {
165
+ return [
166
+ createRecordMemoryTool(recordMemory, config.getMemoryPaths, config.getMemoryFile),
167
+ createRecallMemoryTool(recallMemory, config.getMemoryPaths, config.getMemoryFile)
168
+ ];
169
+ }
170
+
171
+ export { RecordMemorySchema, RecallMemorySchema, createMemoryTools };