foliko 1.1.93 → 2.0.0

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 (212) hide show
  1. package/.claude/settings.local.json +2 -1
  2. package/CLAUDE.md +56 -30
  3. package/REFACTORING_PLAN.md +645 -0
  4. package/docs/architecture.md +131 -0
  5. package/docs/migration.md +57 -0
  6. package/docs/public-api.md +138 -0
  7. package/docs/usage.md +385 -0
  8. package/examples/ambient-example.js +20 -137
  9. package/examples/basic.js +21 -48
  10. package/examples/bootstrap.js +16 -74
  11. package/examples/mcp-example.js +6 -29
  12. package/examples/skill-example.js +6 -19
  13. package/examples/workflow.js +8 -56
  14. package/package.json +8 -4
  15. package/plugins/README.md +49 -0
  16. package/plugins/{ambient-agent → ambient}/EventWatcher.js +1 -1
  17. package/plugins/{ambient-agent → ambient}/ExplorerLoop.js +3 -3
  18. package/plugins/{ambient-agent → ambient}/GoalManager.js +2 -2
  19. package/plugins/ambient/README.md +14 -0
  20. package/plugins/{ambient-agent → ambient}/Reflector.js +1 -1
  21. package/plugins/{ambient-agent → ambient}/StateStore.js +1 -1
  22. package/plugins/{ambient-agent → ambient}/index.js +2 -2
  23. package/plugins/{ai-plugin.js → core/ai/index.js} +14 -30
  24. package/plugins/{audit-plugin.js → core/audit/index.js} +3 -30
  25. package/plugins/{coordinator-plugin.js → core/coordinator/index.js} +3 -35
  26. package/plugins/core/default/bootstrap.js +202 -0
  27. package/plugins/core/default/config.js +220 -0
  28. package/plugins/core/default/index.js +58 -0
  29. package/plugins/core/mcp/index.js +1 -0
  30. package/plugins/{python-plugin-loader.js → core/python-loader/index.js} +7 -187
  31. package/plugins/{rules-plugin.js → core/rules/index.js} +121 -64
  32. package/plugins/{scheduler-plugin.js → core/scheduler/index.js} +12 -114
  33. package/plugins/{session-plugin.js → core/session/index.js} +9 -73
  34. package/{src/capabilities/skill-manager.js → plugins/core/skill-manager/index.js} +64 -18
  35. package/plugins/{storage-plugin.js → core/storage/index.js} +5 -29
  36. package/plugins/{subagent-plugin.js → core/sub-agent/index.js} +10 -171
  37. package/plugins/{think-plugin.js → core/think/index.js} +24 -91
  38. package/{src/capabilities/workflow-engine.js → plugins/core/workflow/index.js} +87 -85
  39. package/plugins/default-plugins.js +6 -720
  40. package/plugins/{data-splitter-plugin.js → executors/data-splitter/index.js} +9 -83
  41. package/plugins/{extension-executor-plugin.js → executors/extension/index.js} +13 -97
  42. package/plugins/{python-executor-plugin.js → executors/python/index.js} +6 -31
  43. package/plugins/{shell-executor-plugin.js → executors/shell/index.js} +2 -5
  44. package/plugins/install/README.md +9 -0
  45. package/plugins/{install-plugin.js → install/index.js} +3 -3
  46. package/plugins/{file-system-plugin.js → io/file-system/index.js} +34 -236
  47. package/plugins/{web-plugin.js → io/web/index.js} +11 -113
  48. package/plugins/memory/README.md +13 -0
  49. package/plugins/{memory-plugin.js → memory/index.js} +4 -18
  50. package/plugins/messaging/email/README.md +19 -0
  51. package/plugins/{email → messaging/email}/index.js +2 -2
  52. package/plugins/{feishu-plugin.js → messaging/feishu/index.js} +3 -3
  53. package/plugins/{qq-plugin.js → messaging/qq/index.js} +5 -16
  54. package/plugins/{telegram-plugin.js → messaging/telegram/index.js} +3 -3
  55. package/plugins/{weixin-plugin.js → messaging/weixin/index.js} +15 -15
  56. package/plugins/{plugin-manager-plugin.js → plugin-manager/index.js} +36 -180
  57. package/plugins/{tools-plugin.js → tools/index.js} +68 -116
  58. package/plugins/trading/README.md +15 -0
  59. package/plugins/{gate-trading.js → trading/index.js} +8 -8
  60. package/{examples → sandbox}/test-concurrent-chat.js +2 -2
  61. package/{examples → sandbox}/test-long-chat.js +2 -2
  62. package/{examples → sandbox}/test-session-chat.js +2 -2
  63. package/{examples → sandbox}/test-web-plugin.js +1 -1
  64. package/{examples → sandbox}/test-weixin-feishu.js +2 -2
  65. package/src/agent/base.js +56 -0
  66. package/src/{core/agent-chat.js → agent/chat.js} +11 -11
  67. package/src/{core/coordinator-manager.js → agent/coordinator.js} +3 -3
  68. package/src/agent/index.js +111 -0
  69. package/src/agent/main.js +337 -0
  70. package/src/agent/prompt.js +78 -0
  71. package/src/agent/sub.js +198 -0
  72. package/src/agent/worker.js +104 -0
  73. package/{cli/bin/foliko.js → src/cli/bin.js} +1 -1
  74. package/{cli/src → src/cli}/commands/chat.js +25 -21
  75. package/{cli/src → src/cli}/index.js +1 -0
  76. package/{cli/src → src/cli}/ui/chat-ui-old.js +40 -178
  77. package/{cli/src → src/cli}/ui/chat-ui.js +3 -3
  78. package/{cli/src → src/cli}/ui/components/footer-bar.js +1 -1
  79. package/src/common/errors.js +402 -0
  80. package/src/{utils → common}/logger.js +33 -0
  81. package/src/{utils/chat-queue.js → common/queue.js} +2 -2
  82. package/src/config/plugin-config.js +50 -0
  83. package/src/context/agent.js +32 -0
  84. package/src/context/compaction-prompts.js +170 -0
  85. package/src/context/compaction-utils.js +191 -0
  86. package/src/context/compressor.js +413 -0
  87. package/src/context/index.js +9 -0
  88. package/src/{core/context-manager.js → context/manager.js} +1 -1
  89. package/src/context/request.js +50 -0
  90. package/src/context/session.js +33 -0
  91. package/src/context/storage.js +30 -0
  92. package/src/executors/mcp-client.js +153 -0
  93. package/src/executors/mcp-desc.js +236 -0
  94. package/src/executors/mcp-executor.js +91 -956
  95. package/src/{core → framework}/command-registry.js +1 -1
  96. package/src/framework/framework.js +300 -0
  97. package/src/framework/index.js +18 -0
  98. package/src/framework/lifecycle.js +203 -0
  99. package/src/framework/loader.js +78 -0
  100. package/src/framework/registry.js +86 -0
  101. package/src/{core/ui-extension-context.js → framework/ui-extension.js} +1 -1
  102. package/src/index.js +130 -15
  103. package/src/llm/index.js +26 -0
  104. package/src/llm/provider.js +212 -0
  105. package/src/llm/registry.js +11 -0
  106. package/src/{core/token-counter.js → llm/tokens.js} +4 -37
  107. package/src/{core/plugin-base.js → plugin/base.js} +10 -136
  108. package/src/plugin/index.js +14 -0
  109. package/src/plugin/loader.js +101 -0
  110. package/src/plugin/manager.js +261 -0
  111. package/src/{core → session}/branch-summary-auto.js +2 -2
  112. package/src/{core/chat-session.js → session/chat.js} +2 -2
  113. package/src/session/index.js +7 -0
  114. package/src/{core/session-manager.js → session/session.js} +2 -2
  115. package/src/session/ttl.js +92 -0
  116. package/src/{core/jsonl-storage.js → storage/jsonl.js} +1 -1
  117. package/src/tool/executor.js +85 -0
  118. package/src/tool/index.js +15 -0
  119. package/src/tool/registry.js +143 -0
  120. package/src/{core/tool-router.js → tool/router.js} +17 -124
  121. package/src/tool/schema.js +108 -0
  122. package/src/utils/data-splitter.js +1 -1
  123. package/src/utils/download.js +1 -1
  124. package/src/utils/index.js +6 -6
  125. package/src/utils/message-validator.js +1 -1
  126. package/tests/core/context-storage.test.js +46 -0
  127. package/tests/core/llm.test.js +54 -0
  128. package/tests/core/plugin.test.js +42 -0
  129. package/tests/core/tool.test.js +60 -0
  130. package/tests/setup.js +10 -0
  131. package/tests/smoke.test.js +58 -0
  132. package/vitest.config.js +9 -0
  133. package/cli/src/daemon.js +0 -149
  134. package/docs/CONTEXT_DESIGN.md +0 -1596
  135. package/docs/ai-sdk-optimization.md +0 -655
  136. package/docs/features.md +0 -120
  137. package/docs/qq-bot.md +0 -976
  138. package/docs/quick-reference.md +0 -160
  139. package/docs/user-manual.md +0 -1391
  140. package/images/geometric_shapes.jpg +0 -0
  141. package/images/sunset_mountain_lake.jpg +0 -0
  142. package/skills/poster-guide/SKILL.md +0 -792
  143. package/src/capabilities/index.js +0 -11
  144. package/src/core/agent.js +0 -808
  145. package/src/core/context-compressor.js +0 -959
  146. package/src/core/enhanced-context-compressor.js +0 -210
  147. package/src/core/framework.js +0 -1422
  148. package/src/core/index.js +0 -30
  149. package/src/core/plugin-manager.js +0 -961
  150. package/src/core/provider-registry.js +0 -159
  151. package/src/core/provider.js +0 -156
  152. package/src/core/request-context.js +0 -98
  153. package/src/core/subagent.js +0 -442
  154. package/src/core/system-prompt-builder.js +0 -120
  155. package/src/core/tool-executor.js +0 -202
  156. package/src/core/tool-registry.js +0 -517
  157. package/src/core/worker-agent.js +0 -192
  158. package/src/executors/executor-base.js +0 -58
  159. package/src/utils/error-boundary.js +0 -363
  160. package/src/utils/error.js +0 -374
  161. package/system.md +0 -1645
  162. package/website_v2/README.md +0 -57
  163. package/website_v2/SPEC.md +0 -1
  164. package/website_v2/docs/api.html +0 -128
  165. package/website_v2/docs/configuration.html +0 -147
  166. package/website_v2/docs/plugin-development.html +0 -129
  167. package/website_v2/docs/project-structure.html +0 -89
  168. package/website_v2/docs/skill-development.html +0 -85
  169. package/website_v2/index.html +0 -489
  170. package/website_v2/scripts/main.js +0 -93
  171. package/website_v2/styles/animations.css +0 -8
  172. package/website_v2/styles/docs.css +0 -83
  173. package/website_v2/styles/main.css +0 -417
  174. package/xhs_auth.json +0 -268
  175. package//346/265/267/346/212/245/346/217/222/344/273/266.md +0 -621
  176. /package/plugins/{ambient-agent → ambient}/constants.js +0 -0
  177. /package/plugins/{email → messaging/email}/constants.js +0 -0
  178. /package/plugins/{email → messaging/email}/handlers.js +0 -0
  179. /package/plugins/{email → messaging/email}/monitor.js +0 -0
  180. /package/plugins/{email → messaging/email}/parser.js +0 -0
  181. /package/plugins/{email → messaging/email}/reply.js +0 -0
  182. /package/plugins/{email → messaging/email}/utils.js +0 -0
  183. /package/{examples → sandbox}/test-chat.js +0 -0
  184. /package/{examples → sandbox}/test-mcp.js +0 -0
  185. /package/{examples → sandbox}/test-reload.js +0 -0
  186. /package/{examples → sandbox}/test-telegram.js +0 -0
  187. /package/{examples → sandbox}/test-tg-bot.js +0 -0
  188. /package/{examples → sandbox}/test-tg-simple.js +0 -0
  189. /package/{examples → sandbox}/test-tg.js +0 -0
  190. /package/{examples → sandbox}/test-think.js +0 -0
  191. /package/src/{core/sub-agent-config.js → agent/sub-config.js} +0 -0
  192. /package/{cli/src → src/cli}/commands/daemon.js +0 -0
  193. /package/{cli/src → src/cli}/commands/list.js +0 -0
  194. /package/{cli/src → src/cli}/commands/plugin.js +0 -0
  195. /package/{cli/src → src/cli}/ui/components/agent-mention-provider.js +0 -0
  196. /package/{cli/src → src/cli}/ui/components/chained-autocomplete-provider.js +0 -0
  197. /package/{cli/src → src/cli}/ui/components/message-bubble.js +0 -0
  198. /package/{cli/src → src/cli}/ui/components/status-bar.js +0 -0
  199. /package/{cli/src → src/cli}/utils/ansi.js +0 -0
  200. /package/{cli/src → src/cli}/utils/config.js +0 -0
  201. /package/{cli/src → src/cli}/utils/markdown.js +0 -0
  202. /package/{cli/src → src/cli}/utils/plugin-config.js +0 -0
  203. /package/{cli/src → src/cli}/utils/render-diff.js +0 -0
  204. /package/src/{utils/circuit-breaker.js → common/circuit.js} +0 -0
  205. /package/src/{core → common}/constants.js +0 -0
  206. /package/src/{utils/edit-diff.js → common/diff.js} +0 -0
  207. /package/src/{utils/event-emitter.js → common/events.js} +0 -0
  208. /package/src/{utils → common}/id.js +0 -0
  209. /package/src/{utils → common}/retry.js +0 -0
  210. /package/src/{core/notification-manager.js → notification/manager.js} +0 -0
  211. /package/src/{core/session-entry.js → session/entry.js} +0 -0
  212. /package/src/{core/storage-manager.js → storage/manager.js} +0 -0
@@ -1,374 +0,0 @@
1
- /**
2
- * Foliko Error - 统一错误处理系统
3
- * 标准化项目中的所有错误类型
4
- */
5
-
6
- /**
7
- * Foliko 错误基类
8
- */
9
- class FolikoError extends Error {
10
- /**
11
- * @param {string} message - 错误消息
12
- * @param {Object} [options]
13
- * @param {string} [options.code] - 错误代码
14
- * @param {Object} [options.context] - 错误上下文
15
- * @param {string} [options.stack] - 自定义堆栈
16
- */
17
- constructor(message, options = {}) {
18
- super(message);
19
- this.name = this.constructor.name;
20
- this.code = options.code || 'FOLIKO_ERROR';
21
- this.context = options.context || {};
22
-
23
- // 保留原始堆栈跟踪
24
- if (options.stack) {
25
- this.stack = options.stack;
26
- } else {
27
- Error.captureStackTrace(this, this.constructor);
28
- }
29
- }
30
-
31
- /**
32
- * 将错误转换为 JSON
33
- * @returns {Object}
34
- */
35
- toJSON() {
36
- return {
37
- name: this.name,
38
- message: this.message,
39
- code: this.code,
40
- context: this.context,
41
- stack: this.stack,
42
- };
43
- }
44
- }
45
-
46
- /**
47
- * 插件相关错误
48
- */
49
- class PluginError extends FolikoError {
50
- constructor(message, options = {}) {
51
- super(message, {
52
- code: 'PLUGIN_ERROR',
53
- context: options.context,
54
- });
55
- }
56
- }
57
-
58
- /**
59
- * 工具执行错误
60
- */
61
- class ToolError extends FolikoError {
62
- constructor(message, options = {}) {
63
- super(message, {
64
- code: 'TOOL_ERROR',
65
- context: {
66
- toolName: options.toolName,
67
- args: options.args,
68
- ...options.context,
69
- },
70
- });
71
- }
72
- }
73
-
74
- /**
75
- * AI 执行错误
76
- */
77
- class AIError extends FolikoError {
78
- constructor(message, options = {}) {
79
- super(message, {
80
- code: 'AI_ERROR',
81
- context: {
82
- model: options.model,
83
- provider: options.provider,
84
- statusCode: options.statusCode,
85
- ...options.context,
86
- },
87
- });
88
- }
89
- }
90
-
91
- /**
92
- * 会话相关错误
93
- */
94
- class SessionError extends FolikoError {
95
- constructor(message, options = {}) {
96
- super(message, {
97
- code: 'SESSION_ERROR',
98
- context: {
99
- sessionId: options.sessionId,
100
- ...options.context,
101
- },
102
- });
103
- }
104
- }
105
-
106
- /**
107
- * 配置错误
108
- */
109
- class ConfigError extends FolikoError {
110
- constructor(message, options = {}) {
111
- super(message, {
112
- code: 'CONFIG_ERROR',
113
- context: {
114
- configKey: options.configKey,
115
- expected: options.expected,
116
- actual: options.actual,
117
- ...options.context,
118
- },
119
- });
120
- }
121
- }
122
-
123
- /**
124
- * 工作流执行错误
125
- */
126
- class WorkflowError extends FolikoError {
127
- constructor(message, options = {}) {
128
- super(message, {
129
- code: 'WORKFLOW_ERROR',
130
- context: {
131
- workflowName: options.workflowName,
132
- stepName: options.stepName,
133
- stepIndex: options.stepIndex,
134
- ...options.context,
135
- },
136
- });
137
- }
138
- }
139
-
140
- /**
141
- * 验证错误
142
- */
143
- class ValidationError extends FolikoError {
144
- constructor(message, options = {}) {
145
- super(message, {
146
- code: 'VALIDATION_ERROR',
147
- context: {
148
- field: options.field,
149
- value: options.value,
150
- expected: options.expected,
151
- ...options.context,
152
- },
153
- });
154
- }
155
- }
156
-
157
- /**
158
- * 工具未找到错误
159
- */
160
- class ToolNotFoundError extends ToolError {
161
- constructor(toolName) {
162
- super(`Tool not found: ${toolName}`, { toolName });
163
- this.code = 'TOOL_NOT_FOUND';
164
- }
165
- }
166
-
167
- /**
168
- * 插件未找到错误
169
- */
170
- class PluginNotFoundError extends PluginError {
171
- constructor(pluginName) {
172
- super(`Plugin not found: ${pluginName}`, {
173
- context: { pluginName },
174
- });
175
- this.code = 'PLUGIN_NOT_FOUND';
176
- }
177
- }
178
-
179
- /**
180
- * 检查错误类型
181
- * @param {Error} error
182
- * @param {Function} ErrorClass
183
- * @returns {boolean}
184
- */
185
-
186
- /**
187
- * 网络相关错误
188
- */
189
- class NetworkError extends FolikoError {
190
- constructor(message, options = {}) {
191
- super(message, {
192
- code: 'NETWORK_ERROR',
193
- context: {
194
- host: options.host,
195
- port: options.port,
196
- code: options.code,
197
- ...options.context,
198
- },
199
- });
200
- }
201
- }
202
-
203
- /**
204
- * 认证/授权错误
205
- */
206
- class AuthError extends FolikoError {
207
- constructor(message, options = {}) {
208
- super(message, {
209
- code: 'AUTH_ERROR',
210
- context: {
211
- authType: options.authType,
212
- userId: options.userId,
213
- ...options.context,
214
- },
215
- });
216
- }
217
- }
218
-
219
- /**
220
- * 限流错误
221
- */
222
- class RateLimitError extends FolikoError {
223
- constructor(message, options = {}) {
224
- super(message, {
225
- code: 'RATE_LIMIT_ERROR',
226
- context: {
227
- retryAfter: options.retryAfter,
228
- limit: options.limit,
229
- ...options.context,
230
- },
231
- });
232
- }
233
- }
234
-
235
- /**
236
- * 超时错误
237
- */
238
- class TimeoutError extends FolikoError {
239
- constructor(message, options = {}) {
240
- super(message, {
241
- code: 'TIMEOUT_ERROR',
242
- context: {
243
- timeout: options.timeout,
244
- operation: options.operation,
245
- ...options.context,
246
- },
247
- });
248
- }
249
- }
250
-
251
- /**
252
- * 文件系统错误
253
- */
254
- class FileSystemError extends FolikoError {
255
- constructor(message, options = {}) {
256
- super(message, {
257
- code: 'FS_ERROR',
258
- context: {
259
- path: options.path,
260
- operation: options.operation,
261
- ...options.context,
262
- },
263
- });
264
- }
265
- }
266
-
267
- function isErrorOfType(error, ErrorClass) {
268
- return error instanceof ErrorClass;
269
- }
270
-
271
- /**
272
- * 安全地获取错误信息
273
- * @param {Error} error
274
- * @returns {Object}
275
- */
276
- function safeErrorInfo(error) {
277
- if (error instanceof FolikoError) {
278
- return error.toJSON();
279
- }
280
- return {
281
- name: error.name || 'Error',
282
- message: error.message,
283
- code: 'UNKNOWN_ERROR',
284
- context: {},
285
- stack: error.stack,
286
- };
287
- }
288
-
289
- /**
290
- * 错误工厂函数 - 根据错误类型快速创建错误
291
- * @param {string} type - 错误类型
292
- * @param {string} message - 错误消息
293
- * @param {Object} options - 错误选项
294
- * @returns {FolikoError}
295
- */
296
- function createError(type, message, options = {}) {
297
- const errorClasses = {
298
- plugin: PluginError,
299
- tool: ToolError,
300
- ai: AIError,
301
- session: SessionError,
302
- config: ConfigError,
303
- workflow: WorkflowError,
304
- validation: ValidationError,
305
- network: NetworkError,
306
- auth: AuthError,
307
- rateLimit: RateLimitError,
308
- timeout: TimeoutError,
309
- fs: FileSystemError,
310
- };
311
- const ErrorClass = errorClasses[type] || FolikoError;
312
- return new ErrorClass(message, options);
313
- }
314
-
315
- /**
316
- * 判断错误是否可重试
317
- * @param {Error} error
318
- * @returns {boolean}
319
- */
320
- function isRetryable(error) {
321
- if (error instanceof RateLimitError) return true;
322
- if (error instanceof TimeoutError) return true;
323
- if (error instanceof NetworkError) return true;
324
- if (error instanceof FolikoError) {
325
- const retryableCodes = ['RATE_LIMIT_ERROR', 'TIMEOUT_ERROR', 'NETWORK_ERROR'];
326
- return retryableCodes.includes(error.code);
327
- }
328
- return false;
329
- }
330
-
331
- /**
332
- * 获取用户友好的错误消息
333
- * @param {Error} error
334
- * @returns {string}
335
- */
336
- function getFriendlyMessage(error) {
337
- if (error instanceof FolikoError) {
338
- const messages = {
339
- PLUGIN_NOT_FOUND: '插件未找到,请检查配置',
340
- TOOL_NOT_FOUND: '工具未找到,请检查工具名称',
341
- CONFIG_ERROR: '配置错误,请检查配置文件',
342
- VALIDATION_ERROR: '输入验证失败,请检查输入数据',
343
- RATE_LIMIT_ERROR: '请求过于频繁,请稍后再试',
344
- TIMEOUT_ERROR: '请求超时,请检查网络连接',
345
- NETWORK_ERROR: '网络错误,请检查网络连接',
346
- AUTH_ERROR: '认证失败,请检查凭据是否正确',
347
- };
348
- return messages[error.code] || error.message;
349
- }
350
- return error.message || '发生未知错误';
351
- }
352
-
353
- module.exports = {
354
- FolikoError,
355
- PluginError,
356
- ToolError,
357
- AIError,
358
- SessionError,
359
- ConfigError,
360
- WorkflowError,
361
- ValidationError,
362
- ToolNotFoundError,
363
- PluginNotFoundError,
364
- NetworkError,
365
- AuthError,
366
- RateLimitError,
367
- TimeoutError,
368
- FileSystemError,
369
- isErrorOfType,
370
- safeErrorInfo,
371
- createError,
372
- isRetryable,
373
- getFriendlyMessage,
374
- };