foliko 1.0.81 → 1.0.83

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 (88) hide show
  1. package/cli/bin/foliko.js +12 -12
  2. package/cli/src/commands/chat.js +143 -143
  3. package/cli/src/commands/list.js +93 -93
  4. package/cli/src/index.js +75 -75
  5. package/cli/src/ui/chat-ui.js +201 -201
  6. package/cli/src/utils/ansi.js +40 -40
  7. package/cli/src/utils/markdown.js +292 -292
  8. package/examples/ambient-example.js +194 -194
  9. package/examples/basic.js +115 -115
  10. package/examples/bootstrap.js +121 -121
  11. package/examples/mcp-example.js +56 -56
  12. package/examples/skill-example.js +49 -49
  13. package/examples/test-chat.js +137 -137
  14. package/examples/test-mcp.js +85 -85
  15. package/examples/test-reload.js +59 -59
  16. package/examples/test-telegram.js +50 -50
  17. package/examples/test-tg-bot.js +45 -45
  18. package/examples/test-tg-simple.js +47 -47
  19. package/examples/test-tg.js +62 -62
  20. package/examples/test-think.js +43 -43
  21. package/examples/test-web-plugin.js +103 -103
  22. package/examples/test-weixin-feishu.js +103 -103
  23. package/examples/workflow.js +158 -158
  24. package/package.json +83 -83
  25. package/plugins/ai-plugin.js +102 -102
  26. package/plugins/ambient-agent/EventWatcher.js +113 -113
  27. package/plugins/ambient-agent/ExplorerLoop.js +640 -640
  28. package/plugins/ambient-agent/GoalManager.js +197 -197
  29. package/plugins/ambient-agent/Reflector.js +95 -95
  30. package/plugins/ambient-agent/StateStore.js +90 -90
  31. package/plugins/ambient-agent/constants.js +101 -101
  32. package/plugins/ambient-agent/index.js +579 -579
  33. package/plugins/audit-plugin.js +187 -187
  34. package/plugins/default-plugins.js +548 -548
  35. package/plugins/email/constants.js +64 -64
  36. package/plugins/email/handlers.js +461 -461
  37. package/plugins/email/index.js +278 -278
  38. package/plugins/email/monitor.js +269 -269
  39. package/plugins/email/parser.js +138 -138
  40. package/plugins/email/reply.js +151 -151
  41. package/plugins/email/utils.js +124 -124
  42. package/plugins/extension-executor-plugin.js +326 -326
  43. package/plugins/feishu-plugin.js +481 -481
  44. package/plugins/file-system-plugin.js +920 -920
  45. package/plugins/gate-trading.js +747 -747
  46. package/plugins/install-plugin.js +199 -199
  47. package/plugins/python-executor-plugin.js +367 -367
  48. package/plugins/python-plugin-loader.js +651 -651
  49. package/plugins/rules-plugin.js +294 -294
  50. package/plugins/scheduler-plugin.js +691 -691
  51. package/plugins/session-plugin.js +494 -494
  52. package/plugins/shell-executor-plugin.js +197 -197
  53. package/plugins/storage-plugin.js +263 -263
  54. package/plugins/subagent-plugin.js +845 -845
  55. package/plugins/telegram-plugin.js +482 -482
  56. package/plugins/think-plugin.js +345 -345
  57. package/plugins/tools-plugin.js +196 -196
  58. package/plugins/web-plugin.js +637 -637
  59. package/plugins/weixin-plugin.js +545 -545
  60. package/src/capabilities/index.js +11 -11
  61. package/src/capabilities/skill-manager.js +609 -609
  62. package/src/capabilities/workflow-engine.js +1109 -1109
  63. package/src/core/agent-chat.js +1 -1
  64. package/src/core/agent.js +958 -958
  65. package/src/core/framework.js +465 -465
  66. package/src/core/index.js +19 -19
  67. package/src/core/plugin-base.js +262 -262
  68. package/src/core/plugin-manager.js +863 -863
  69. package/src/core/provider.js +114 -114
  70. package/src/core/sub-agent-config.js +264 -264
  71. package/src/core/system-prompt-builder.js +120 -120
  72. package/src/core/tool-registry.js +517 -517
  73. package/src/core/tool-router.js +297 -297
  74. package/src/executors/executor-base.js +58 -58
  75. package/src/executors/mcp-executor.js +845 -845
  76. package/src/index.js +25 -25
  77. package/src/utils/circuit-breaker.js +301 -301
  78. package/src/utils/error-boundary.js +363 -363
  79. package/src/utils/error.js +374 -374
  80. package/src/utils/event-emitter.js +97 -97
  81. package/src/utils/id.js +133 -133
  82. package/src/utils/index.js +217 -217
  83. package/src/utils/logger.js +181 -181
  84. package/src/utils/plugin-helpers.js +90 -90
  85. package/src/utils/retry.js +122 -122
  86. package/src/utils/sandbox.js +292 -292
  87. package/test/tool-registry-validation.test.js +218 -218
  88. package/website/script.js +136 -136
@@ -1,218 +1,218 @@
1
- /**
2
- * 工具参数验证测试
3
- */
4
-
5
- const { ToolRegistry } = require('../src/core/tool-registry');
6
- const { z } = require('zod');
7
-
8
- async function runTests() {
9
- console.log('🧪 开始工具参数验证测试\n');
10
- let passed = 0;
11
- let failed = 0;
12
-
13
- // 创建工具注册表
14
- const registry = new ToolRegistry({ circuitBreaker: false });
15
-
16
- // 注册带 Zod schema 的工具
17
- registry.register({
18
- name: 'greet',
19
- description: '打招呼工具',
20
- inputSchema: z.object({
21
- name: z.string().describe('姓名'),
22
- age: z.number().optional().describe('年龄'),
23
- role: z.enum(['admin', 'user', 'guest']).optional().describe('角色'),
24
- }),
25
- execute: async (args) => {
26
- return `Hello, ${args.name}! You are ${args.age || 'unknown age'}.`;
27
- },
28
- });
29
-
30
- // 注册带 JSON Schema 的工具
31
- registry.register({
32
- name: 'calculate',
33
- description: '计算工具',
34
- inputSchema: {
35
- type: 'object',
36
- properties: {
37
- expression: {
38
- type: 'string',
39
- description: '数学表达式',
40
- },
41
- precision: {
42
- type: 'integer',
43
- description: '精度',
44
- minimum: 0,
45
- maximum: 10,
46
- },
47
- },
48
- required: ['expression'],
49
- },
50
- execute: async (args) => {
51
- return `Calculating: ${args.expression}`;
52
- },
53
- });
54
-
55
- // 注册无 schema 的工具
56
- registry.register({
57
- name: 'echo',
58
- description: '回声工具',
59
- execute: async (args) => {
60
- return args;
61
- },
62
- });
63
-
64
- // 测试1: 有效的 Zod schema 参数
65
- try {
66
- const result = await registry.execute('greet', { name: 'Alice', age: 25 });
67
- console.log('✅ 测试1 通过: 有效的 Zod schema 参数');
68
- console.log(` 结果: ${result}\n`);
69
- passed++;
70
- } catch (err) {
71
- console.log('❌ 测试1 失败:', err.message, '\n');
72
- failed++;
73
- }
74
-
75
- // 测试2: 缺少必需参数(Zod schema)
76
- try {
77
- await registry.execute('greet', { age: 25 });
78
- console.log('❌ 测试2 失败: 应该抛出验证错误\n');
79
- failed++;
80
- } catch (err) {
81
- if (err.validationErrors) {
82
- console.log('✅ 测试2 通过: 缺少必需参数正确抛出验证错误');
83
- console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
84
- passed++;
85
- } else {
86
- console.log('❌ 测试2 失败: 错误格式不正确\n');
87
- failed++;
88
- }
89
- }
90
-
91
- // 测试3: 参数类型错误(Zod schema)
92
- try {
93
- await registry.execute('greet', { name: 123, age: 'twenty-five' });
94
- console.log('❌ 测试3 失败: 应该抛出验证错误\n');
95
- failed++;
96
- } catch (err) {
97
- if (err.validationErrors) {
98
- console.log('✅ 测试3 通过: 参数类型错误正确抛出验证错误');
99
- console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
100
- passed++;
101
- } else {
102
- console.log('❌ 测试3 失败: 错误格式不正确\n');
103
- failed++;
104
- }
105
- }
106
-
107
- // 测试4: 有效的 JSON Schema 参数
108
- try {
109
- const result = await registry.execute('calculate', { expression: '2+2', precision: 2 });
110
- console.log('✅ 测试4 通过: 有效的 JSON Schema 参数');
111
- console.log(` 结果: ${result}\n`);
112
- passed++;
113
- } catch (err) {
114
- console.log('❌ 测试4 失败:', err.message, '\n');
115
- failed++;
116
- }
117
-
118
- // 测试5: 缺少必需参数(JSON Schema)
119
- try {
120
- await registry.execute('calculate', { precision: 2 });
121
- console.log('❌ 测试5 失败: 应该抛出验证错误\n');
122
- failed++;
123
- } catch (err) {
124
- if (err.validationErrors) {
125
- console.log('✅ 测试5 通过: JSON Schema 缺少必需参数正确抛出验证错误');
126
- console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
127
- passed++;
128
- } else {
129
- console.log('❌ 测试5 失败: 错误格式不正确\n');
130
- failed++;
131
- }
132
- }
133
-
134
- // 测试6: 超出范围验证(JSON Schema)
135
- try {
136
- await registry.execute('calculate', { expression: '2+2', precision: 15 });
137
- console.log('❌ 测试6 失败: 应该抛出验证错误\n');
138
- failed++;
139
- } catch (err) {
140
- if (err.validationErrors) {
141
- console.log('✅ 测试6 通过: JSON Schema 范围验证正确');
142
- console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
143
- passed++;
144
- } else {
145
- console.log('❌ 测试6 失败: 错误格式不正确\n');
146
- failed++;
147
- }
148
- }
149
-
150
- // 测试7: 无 schema 工具接受任意参数
151
- try {
152
- const result = await registry.execute('echo', { foo: 'bar', num: 42 });
153
- console.log('✅ 测试7 通过: 无 schema 工具接受任意参数');
154
- console.log(` 结果: ${JSON.stringify(result)}\n`);
155
- passed++;
156
- } catch (err) {
157
- console.log('❌ 测试7 失败:', err.message, '\n');
158
- failed++;
159
- }
160
-
161
- // 测试8: 不存在的工具
162
- try {
163
- await registry.execute('nonexistent', {});
164
- console.log('❌ 测试8 失败: 应该抛出工具不存在错误\n');
165
- failed++;
166
- } catch (err) {
167
- if (err.message.includes('not found')) {
168
- console.log('✅ 测试8 通过: 工具不存在正确抛出错误\n');
169
- passed++;
170
- } else {
171
- console.log('❌ 测试8 失败: 错误类型不正确\n');
172
- failed++;
173
- }
174
- }
175
-
176
- // 测试9: 可选参数默认值
177
- try {
178
- const result = await registry.execute('greet', { name: 'Bob' });
179
- console.log('✅ 测试9 通过: 可选参数使用默认值');
180
- console.log(` 结果: ${result}\n`);
181
- passed++;
182
- } catch (err) {
183
- console.log('❌ 测试9 失败:', err.message, '\n');
184
- failed++;
185
- }
186
-
187
- // 测试10: enum 验证
188
- try {
189
- await registry.execute('greet', { name: 'Charlie', role: 'hacker' });
190
- console.log('❌ 测试10 失败: enum 值不正确应抛出错误\n');
191
- failed++;
192
- } catch (err) {
193
- if (err.validationErrors) {
194
- console.log('✅ 测试10 通过: enum 验证正确');
195
- console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
196
- passed++;
197
- } else {
198
- console.log('❌ 测试10 失败: 错误格式不正确\n');
199
- failed++;
200
- }
201
- }
202
-
203
- // 输出测试摘要
204
- console.log('='.repeat(50));
205
- console.log(`测试摘要: ${passed} 通过, ${failed} 失败`);
206
- console.log('='.repeat(50));
207
-
208
- return failed === 0;
209
- }
210
-
211
- runTests()
212
- .then((success) => {
213
- process.exit(success ? 0 : 1);
214
- })
215
- .catch((err) => {
216
- console.error('测试执行失败:', err);
217
- process.exit(1);
218
- });
1
+ /**
2
+ * 工具参数验证测试
3
+ */
4
+
5
+ const { ToolRegistry } = require('../src/core/tool-registry');
6
+ const { z } = require('zod');
7
+
8
+ async function runTests() {
9
+ console.log('🧪 开始工具参数验证测试\n');
10
+ let passed = 0;
11
+ let failed = 0;
12
+
13
+ // 创建工具注册表
14
+ const registry = new ToolRegistry({ circuitBreaker: false });
15
+
16
+ // 注册带 Zod schema 的工具
17
+ registry.register({
18
+ name: 'greet',
19
+ description: '打招呼工具',
20
+ inputSchema: z.object({
21
+ name: z.string().describe('姓名'),
22
+ age: z.number().optional().describe('年龄'),
23
+ role: z.enum(['admin', 'user', 'guest']).optional().describe('角色'),
24
+ }),
25
+ execute: async (args) => {
26
+ return `Hello, ${args.name}! You are ${args.age || 'unknown age'}.`;
27
+ },
28
+ });
29
+
30
+ // 注册带 JSON Schema 的工具
31
+ registry.register({
32
+ name: 'calculate',
33
+ description: '计算工具',
34
+ inputSchema: {
35
+ type: 'object',
36
+ properties: {
37
+ expression: {
38
+ type: 'string',
39
+ description: '数学表达式',
40
+ },
41
+ precision: {
42
+ type: 'integer',
43
+ description: '精度',
44
+ minimum: 0,
45
+ maximum: 10,
46
+ },
47
+ },
48
+ required: ['expression'],
49
+ },
50
+ execute: async (args) => {
51
+ return `Calculating: ${args.expression}`;
52
+ },
53
+ });
54
+
55
+ // 注册无 schema 的工具
56
+ registry.register({
57
+ name: 'echo',
58
+ description: '回声工具',
59
+ execute: async (args) => {
60
+ return args;
61
+ },
62
+ });
63
+
64
+ // 测试1: 有效的 Zod schema 参数
65
+ try {
66
+ const result = await registry.execute('greet', { name: 'Alice', age: 25 });
67
+ console.log('✅ 测试1 通过: 有效的 Zod schema 参数');
68
+ console.log(` 结果: ${result}\n`);
69
+ passed++;
70
+ } catch (err) {
71
+ console.log('❌ 测试1 失败:', err.message, '\n');
72
+ failed++;
73
+ }
74
+
75
+ // 测试2: 缺少必需参数(Zod schema)
76
+ try {
77
+ await registry.execute('greet', { age: 25 });
78
+ console.log('❌ 测试2 失败: 应该抛出验证错误\n');
79
+ failed++;
80
+ } catch (err) {
81
+ if (err.validationErrors) {
82
+ console.log('✅ 测试2 通过: 缺少必需参数正确抛出验证错误');
83
+ console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
84
+ passed++;
85
+ } else {
86
+ console.log('❌ 测试2 失败: 错误格式不正确\n');
87
+ failed++;
88
+ }
89
+ }
90
+
91
+ // 测试3: 参数类型错误(Zod schema)
92
+ try {
93
+ await registry.execute('greet', { name: 123, age: 'twenty-five' });
94
+ console.log('❌ 测试3 失败: 应该抛出验证错误\n');
95
+ failed++;
96
+ } catch (err) {
97
+ if (err.validationErrors) {
98
+ console.log('✅ 测试3 通过: 参数类型错误正确抛出验证错误');
99
+ console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
100
+ passed++;
101
+ } else {
102
+ console.log('❌ 测试3 失败: 错误格式不正确\n');
103
+ failed++;
104
+ }
105
+ }
106
+
107
+ // 测试4: 有效的 JSON Schema 参数
108
+ try {
109
+ const result = await registry.execute('calculate', { expression: '2+2', precision: 2 });
110
+ console.log('✅ 测试4 通过: 有效的 JSON Schema 参数');
111
+ console.log(` 结果: ${result}\n`);
112
+ passed++;
113
+ } catch (err) {
114
+ console.log('❌ 测试4 失败:', err.message, '\n');
115
+ failed++;
116
+ }
117
+
118
+ // 测试5: 缺少必需参数(JSON Schema)
119
+ try {
120
+ await registry.execute('calculate', { precision: 2 });
121
+ console.log('❌ 测试5 失败: 应该抛出验证错误\n');
122
+ failed++;
123
+ } catch (err) {
124
+ if (err.validationErrors) {
125
+ console.log('✅ 测试5 通过: JSON Schema 缺少必需参数正确抛出验证错误');
126
+ console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
127
+ passed++;
128
+ } else {
129
+ console.log('❌ 测试5 失败: 错误格式不正确\n');
130
+ failed++;
131
+ }
132
+ }
133
+
134
+ // 测试6: 超出范围验证(JSON Schema)
135
+ try {
136
+ await registry.execute('calculate', { expression: '2+2', precision: 15 });
137
+ console.log('❌ 测试6 失败: 应该抛出验证错误\n');
138
+ failed++;
139
+ } catch (err) {
140
+ if (err.validationErrors) {
141
+ console.log('✅ 测试6 通过: JSON Schema 范围验证正确');
142
+ console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
143
+ passed++;
144
+ } else {
145
+ console.log('❌ 测试6 失败: 错误格式不正确\n');
146
+ failed++;
147
+ }
148
+ }
149
+
150
+ // 测试7: 无 schema 工具接受任意参数
151
+ try {
152
+ const result = await registry.execute('echo', { foo: 'bar', num: 42 });
153
+ console.log('✅ 测试7 通过: 无 schema 工具接受任意参数');
154
+ console.log(` 结果: ${JSON.stringify(result)}\n`);
155
+ passed++;
156
+ } catch (err) {
157
+ console.log('❌ 测试7 失败:', err.message, '\n');
158
+ failed++;
159
+ }
160
+
161
+ // 测试8: 不存在的工具
162
+ try {
163
+ await registry.execute('nonexistent', {});
164
+ console.log('❌ 测试8 失败: 应该抛出工具不存在错误\n');
165
+ failed++;
166
+ } catch (err) {
167
+ if (err.message.includes('not found')) {
168
+ console.log('✅ 测试8 通过: 工具不存在正确抛出错误\n');
169
+ passed++;
170
+ } else {
171
+ console.log('❌ 测试8 失败: 错误类型不正确\n');
172
+ failed++;
173
+ }
174
+ }
175
+
176
+ // 测试9: 可选参数默认值
177
+ try {
178
+ const result = await registry.execute('greet', { name: 'Bob' });
179
+ console.log('✅ 测试9 通过: 可选参数使用默认值');
180
+ console.log(` 结果: ${result}\n`);
181
+ passed++;
182
+ } catch (err) {
183
+ console.log('❌ 测试9 失败:', err.message, '\n');
184
+ failed++;
185
+ }
186
+
187
+ // 测试10: enum 验证
188
+ try {
189
+ await registry.execute('greet', { name: 'Charlie', role: 'hacker' });
190
+ console.log('❌ 测试10 失败: enum 值不正确应抛出错误\n');
191
+ failed++;
192
+ } catch (err) {
193
+ if (err.validationErrors) {
194
+ console.log('✅ 测试10 通过: enum 验证正确');
195
+ console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
196
+ passed++;
197
+ } else {
198
+ console.log('❌ 测试10 失败: 错误格式不正确\n');
199
+ failed++;
200
+ }
201
+ }
202
+
203
+ // 输出测试摘要
204
+ console.log('='.repeat(50));
205
+ console.log(`测试摘要: ${passed} 通过, ${failed} 失败`);
206
+ console.log('='.repeat(50));
207
+
208
+ return failed === 0;
209
+ }
210
+
211
+ runTests()
212
+ .then((success) => {
213
+ process.exit(success ? 0 : 1);
214
+ })
215
+ .catch((err) => {
216
+ console.error('测试执行失败:', err);
217
+ process.exit(1);
218
+ });