foliko 1.0.75 → 1.0.76

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/.claude/settings.local.json +159 -157
  2. package/cli/bin/foliko.js +12 -12
  3. package/cli/src/commands/chat.js +143 -143
  4. package/cli/src/commands/list.js +93 -93
  5. package/cli/src/index.js +75 -75
  6. package/cli/src/ui/chat-ui.js +201 -201
  7. package/cli/src/utils/ansi.js +40 -40
  8. package/cli/src/utils/markdown.js +292 -292
  9. package/examples/ambient-example.js +194 -194
  10. package/examples/basic.js +115 -115
  11. package/examples/bootstrap.js +121 -121
  12. package/examples/mcp-example.js +56 -56
  13. package/examples/skill-example.js +49 -49
  14. package/examples/test-chat.js +137 -137
  15. package/examples/test-mcp.js +85 -85
  16. package/examples/test-reload.js +59 -59
  17. package/examples/test-telegram.js +50 -50
  18. package/examples/test-tg-bot.js +45 -45
  19. package/examples/test-tg-simple.js +47 -47
  20. package/examples/test-tg.js +62 -62
  21. package/examples/test-think.js +43 -43
  22. package/examples/test-web-plugin.js +103 -103
  23. package/examples/test-weixin-feishu.js +103 -103
  24. package/examples/workflow.js +158 -158
  25. package/package.json +1 -1
  26. package/plugins/ai-plugin.js +102 -102
  27. package/plugins/ambient-agent/EventWatcher.js +113 -113
  28. package/plugins/ambient-agent/ExplorerLoop.js +640 -640
  29. package/plugins/ambient-agent/GoalManager.js +197 -197
  30. package/plugins/ambient-agent/Reflector.js +95 -95
  31. package/plugins/ambient-agent/StateStore.js +90 -90
  32. package/plugins/ambient-agent/constants.js +101 -101
  33. package/plugins/ambient-agent/index.js +579 -579
  34. package/plugins/audit-plugin.js +187 -187
  35. package/plugins/default-plugins.js +662 -662
  36. package/plugins/email/constants.js +64 -64
  37. package/plugins/email/handlers.js +461 -461
  38. package/plugins/email/index.js +278 -278
  39. package/plugins/email/monitor.js +269 -269
  40. package/plugins/email/parser.js +138 -138
  41. package/plugins/email/reply.js +151 -151
  42. package/plugins/email/utils.js +124 -124
  43. package/plugins/feishu-plugin.js +481 -481
  44. package/plugins/file-system-plugin.js +826 -826
  45. package/plugins/install-plugin.js +199 -199
  46. package/plugins/python-executor-plugin.js +367 -367
  47. package/plugins/python-plugin-loader.js +481 -481
  48. package/plugins/rules-plugin.js +294 -294
  49. package/plugins/scheduler-plugin.js +691 -691
  50. package/plugins/session-plugin.js +369 -369
  51. package/plugins/shell-executor-plugin.js +197 -197
  52. package/plugins/storage-plugin.js +240 -240
  53. package/plugins/subagent-plugin.js +845 -845
  54. package/plugins/telegram-plugin.js +482 -482
  55. package/plugins/think-plugin.js +345 -345
  56. package/plugins/tools-plugin.js +196 -196
  57. package/plugins/web-plugin.js +606 -606
  58. package/plugins/weixin-plugin.js +545 -545
  59. package/src/capabilities/index.js +11 -11
  60. package/src/capabilities/skill-manager.js +609 -609
  61. package/src/capabilities/workflow-engine.js +1109 -1109
  62. package/src/core/agent-chat.js +882 -882
  63. package/src/core/agent.js +892 -892
  64. package/src/core/framework.js +465 -465
  65. package/src/core/index.js +19 -19
  66. package/src/core/plugin-base.js +219 -219
  67. package/src/core/plugin-manager.js +863 -863
  68. package/src/core/provider.js +114 -114
  69. package/src/core/sub-agent-config.js +264 -264
  70. package/src/core/system-prompt-builder.js +120 -120
  71. package/src/core/tool-registry.js +517 -517
  72. package/src/core/tool-router.js +297 -297
  73. package/src/executors/executor-base.js +58 -58
  74. package/src/executors/mcp-executor.js +741 -741
  75. package/src/index.js +25 -25
  76. package/src/utils/circuit-breaker.js +301 -301
  77. package/src/utils/error-boundary.js +363 -363
  78. package/src/utils/error.js +374 -374
  79. package/src/utils/event-emitter.js +97 -97
  80. package/src/utils/id.js +133 -133
  81. package/src/utils/index.js +217 -217
  82. package/src/utils/logger.js +181 -181
  83. package/src/utils/plugin-helpers.js +90 -90
  84. package/src/utils/retry.js +122 -122
  85. package/src/utils/sandbox.js +292 -292
  86. package/test/tool-registry-validation.test.js +218 -218
  87. package/website/script.js +136 -136
  88. package/foliko-1.0.75.tgz +0 -0
@@ -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
+ });