foliko 1.0.74 → 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.
- package/.agent/.shared/ui-ux-pro-max/data/charts.csv +26 -0
- package/.agent/.shared/ui-ux-pro-max/data/colors.csv +97 -0
- package/.agent/.shared/ui-ux-pro-max/data/icons.csv +101 -0
- package/.agent/.shared/ui-ux-pro-max/data/landing.csv +31 -0
- package/.agent/.shared/ui-ux-pro-max/data/products.csv +97 -0
- package/.agent/.shared/ui-ux-pro-max/data/prompts.csv +24 -0
- package/.agent/.shared/ui-ux-pro-max/data/react-performance.csv +45 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/flutter.csv +53 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/nextjs.csv +53 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/react-native.csv +52 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/react.csv +54 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/shadcn.csv +61 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/svelte.csv +54 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/swiftui.csv +51 -0
- package/.agent/.shared/ui-ux-pro-max/data/stacks/vue.csv +50 -0
- package/.agent/.shared/ui-ux-pro-max/data/styles.csv +59 -0
- package/.agent/.shared/ui-ux-pro-max/data/typography.csv +58 -0
- package/.agent/.shared/ui-ux-pro-max/data/ui-reasoning.csv +101 -0
- package/.agent/.shared/ui-ux-pro-max/data/ux-guidelines.csv +100 -0
- package/.agent/.shared/ui-ux-pro-max/data/web-interface.csv +31 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/core.cpython-313.pyc +0 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/__pycache__/design_system.cpython-313.pyc +0 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/core.py +258 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/design_system.py +1067 -0
- package/.agent/.shared/ui-ux-pro-max/scripts/search.py +106 -0
- package/.agent/ARCHITECTURE.md +288 -0
- package/.agent/agents/ambient-agent.md +57 -0
- package/.agent/agents/debugger.md +55 -0
- package/.agent/agents/email-assistant.md +49 -0
- package/.agent/agents/file-manager.md +42 -0
- package/.agent/agents/python-developer.md +60 -0
- package/.agent/agents/scheduler.md +59 -0
- package/.agent/agents/web-developer.md +45 -0
- package/.agent/data/default.json +29 -0
- package/.agent/data/plugins-state.json +255 -0
- package/.agent/mcp_config.json +4 -0
- package/.agent/mcp_config_updated.json +12 -0
- package/.agent/plugins.json +5 -0
- package/.agent/rules/GEMINI.md +273 -0
- package/.agent/rules/allow-rule.md +77 -0
- package/.agent/rules/log-rule.md +83 -0
- package/.agent/rules/security-rule.md +93 -0
- package/.agent/scripts/auto_preview.py +148 -0
- package/.agent/scripts/checklist.py +217 -0
- package/.agent/scripts/session_manager.py +120 -0
- package/.agent/scripts/verify_all.py +327 -0
- package/.agent/skills/api-patterns/SKILL.md +81 -0
- package/.agent/skills/api-patterns/api-style.md +42 -0
- package/.agent/skills/api-patterns/auth.md +24 -0
- package/.agent/skills/api-patterns/documentation.md +26 -0
- package/.agent/skills/api-patterns/graphql.md +41 -0
- package/.agent/skills/api-patterns/rate-limiting.md +31 -0
- package/.agent/skills/api-patterns/response.md +37 -0
- package/.agent/skills/api-patterns/rest.md +40 -0
- package/.agent/skills/api-patterns/scripts/api_validator.py +211 -0
- package/.agent/skills/api-patterns/security-testing.md +122 -0
- package/.agent/skills/api-patterns/trpc.md +41 -0
- package/.agent/skills/api-patterns/versioning.md +22 -0
- package/.agent/skills/app-builder/SKILL.md +75 -0
- package/.agent/skills/app-builder/agent-coordination.md +71 -0
- package/.agent/skills/app-builder/feature-building.md +53 -0
- package/.agent/skills/app-builder/project-detection.md +34 -0
- package/.agent/skills/app-builder/scaffolding.md +118 -0
- package/.agent/skills/app-builder/tech-stack.md +40 -0
- package/.agent/skills/app-builder/templates/SKILL.md +39 -0
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -0
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -0
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -0
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -0
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -0
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -0
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -0
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +122 -0
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +122 -0
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +169 -0
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +134 -0
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -0
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +119 -0
- package/.agent/skills/architecture/SKILL.md +55 -0
- package/.agent/skills/architecture/context-discovery.md +43 -0
- package/.agent/skills/architecture/examples.md +94 -0
- package/.agent/skills/architecture/pattern-selection.md +68 -0
- package/.agent/skills/architecture/patterns-reference.md +50 -0
- package/.agent/skills/architecture/trade-off-analysis.md +77 -0
- package/.agent/skills/clean-code/SKILL.md +201 -0
- package/.agent/skills/doc.md +177 -0
- package/.agent/skills/frontend-design/SKILL.md +418 -0
- package/.agent/skills/frontend-design/animation-guide.md +331 -0
- package/.agent/skills/frontend-design/color-system.md +311 -0
- package/.agent/skills/frontend-design/decision-trees.md +418 -0
- package/.agent/skills/frontend-design/motion-graphics.md +306 -0
- package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -0
- package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -0
- package/.agent/skills/frontend-design/typography-system.md +345 -0
- package/.agent/skills/frontend-design/ux-psychology.md +1116 -0
- package/.agent/skills/frontend-design/visual-effects.md +383 -0
- package/.agent/skills/i18n-localization/SKILL.md +154 -0
- package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -0
- package/.agent/skills/mcp-builder/SKILL.md +176 -0
- package/.agent/skills/web-design-guidelines/SKILL.md +57 -0
- package/.agent/workflows/brainstorm.md +113 -0
- package/.agent/workflows/create.md +59 -0
- package/.agent/workflows/debug.md +103 -0
- package/.agent/workflows/deploy.md +176 -0
- package/.agent/workflows/enhance.md +63 -0
- package/.agent/workflows/orchestrate.md +237 -0
- package/.agent/workflows/plan.md +89 -0
- package/.agent/workflows/preview.md +81 -0
- package/.agent/workflows/simple-test.md +42 -0
- package/.agent/workflows/status.md +86 -0
- package/.agent/workflows/structured-orchestrate.md +180 -0
- package/.agent/workflows/test.md +144 -0
- package/.agent/workflows/ui-ux-pro-max.md +296 -0
- package/.claude/settings.local.json +11 -1
- package/.editorconfig +56 -0
- package/.husky/pre-commit +4 -0
- package/.lintstagedrc +7 -0
- package/.prettierignore +29 -0
- package/.prettierrc +11 -0
- package/CLAUDE.md +2 -0
- package/README.md +64 -55
- package/SPEC.md +102 -61
- package/cli/bin/foliko.js +11 -11
- package/cli/src/commands/chat.js +143 -141
- package/cli/src/commands/list.js +93 -90
- package/cli/src/index.js +75 -75
- package/cli/src/ui/chat-ui.js +201 -199
- package/cli/src/utils/ansi.js +40 -40
- package/cli/src/utils/markdown.js +292 -296
- package/docker-compose.yml +1 -1
- package/docs/ai-sdk-optimization.md +655 -643
- package/docs/features.md +80 -80
- package/docs/quick-reference.md +49 -46
- package/docs/user-manual.md +411 -380
- package/examples/ambient-example.js +194 -196
- package/examples/basic.js +50 -45
- package/examples/bootstrap.js +121 -112
- package/examples/mcp-example.js +19 -16
- package/examples/skill-example.js +20 -20
- package/examples/test-chat.js +137 -135
- package/examples/test-mcp.js +85 -79
- package/examples/test-reload.js +59 -61
- package/examples/test-telegram.js +50 -50
- package/examples/test-tg-bot.js +45 -42
- package/examples/test-tg-simple.js +47 -46
- package/examples/test-tg.js +62 -62
- package/examples/test-think.js +43 -37
- package/examples/test-web-plugin.js +103 -98
- package/examples/test-weixin-feishu.js +103 -100
- package/examples/workflow.js +158 -158
- package/package.json +37 -3
- package/plugins/ai-plugin.js +102 -100
- package/plugins/ambient-agent/EventWatcher.js +113 -0
- package/plugins/ambient-agent/ExplorerLoop.js +640 -0
- package/plugins/ambient-agent/GoalManager.js +197 -0
- package/plugins/ambient-agent/Reflector.js +95 -0
- package/plugins/ambient-agent/StateStore.js +90 -0
- package/plugins/ambient-agent/constants.js +101 -0
- package/plugins/ambient-agent/index.js +579 -0
- package/plugins/audit-plugin.js +187 -187
- package/plugins/default-plugins.js +662 -649
- package/plugins/email/constants.js +64 -0
- package/plugins/email/handlers.js +461 -0
- package/plugins/email/index.js +278 -0
- package/plugins/email/monitor.js +269 -0
- package/plugins/email/parser.js +138 -0
- package/plugins/email/reply.js +151 -0
- package/plugins/email/utils.js +124 -0
- package/plugins/feishu-plugin.js +481 -477
- package/plugins/file-system-plugin.js +826 -476
- package/plugins/install-plugin.js +199 -197
- package/plugins/python-executor-plugin.js +367 -365
- package/plugins/python-plugin-loader.js +481 -479
- package/plugins/rules-plugin.js +294 -292
- package/plugins/scheduler-plugin.js +691 -689
- package/plugins/session-plugin.js +369 -367
- package/plugins/shell-executor-plugin.js +197 -197
- package/plugins/storage-plugin.js +240 -238
- package/plugins/subagent-plugin.js +845 -785
- package/plugins/telegram-plugin.js +482 -475
- package/plugins/think-plugin.js +345 -343
- package/plugins/tools-plugin.js +196 -194
- package/plugins/web-plugin.js +606 -604
- package/plugins/weixin-plugin.js +545 -538
- package/reports/system-health-report-20260401.md +79 -0
- package/skills/ambient-agent/SKILL.md +49 -39
- package/skills/foliko-dev/AGENTS.md +64 -61
- package/skills/foliko-dev/SKILL.md +125 -119
- package/skills/mcp-usage/SKILL.md +19 -17
- package/skills/python-plugin-dev/SKILL.md +16 -15
- package/skills/skill-guide/SKILL.md +12 -12
- package/skills/subagent-guide/SKILL.md +237 -0
- package/skills/workflow-guide/SKILL.md +90 -45
- package/skills/workflow-troubleshooting/DEBUGGING.md +36 -21
- package/skills/workflow-troubleshooting/SKILL.md +156 -79
- package/src/capabilities/index.js +11 -11
- package/src/capabilities/skill-manager.js +609 -595
- package/src/capabilities/workflow-engine.js +1109 -1195
- package/src/core/agent-chat.js +882 -735
- package/src/core/agent.js +892 -688
- package/src/core/framework.js +465 -431
- package/src/core/index.js +19 -19
- package/src/core/plugin-base.js +219 -219
- package/src/core/plugin-manager.js +863 -767
- package/src/core/provider.js +114 -111
- package/src/core/sub-agent-config.js +264 -0
- package/src/core/system-prompt-builder.js +120 -0
- package/src/core/tool-registry.js +517 -134
- package/src/core/tool-router.js +297 -216
- package/src/executors/executor-base.js +12 -12
- package/src/executors/mcp-executor.js +741 -729
- package/src/index.js +25 -37
- package/src/utils/circuit-breaker.js +301 -0
- package/src/utils/error-boundary.js +363 -0
- package/src/utils/error.js +374 -0
- package/src/utils/event-emitter.js +97 -97
- package/src/utils/id.js +133 -0
- package/src/utils/index.js +217 -3
- package/src/utils/logger.js +181 -0
- package/src/utils/plugin-helpers.js +90 -0
- package/src/utils/retry.js +122 -0
- package/src/utils/sandbox.js +292 -0
- package/test/tool-registry-validation.test.js +218 -0
- package/test_report.md +70 -0
- package/website/docs/api.html +169 -107
- package/website/docs/configuration.html +296 -144
- package/website/docs/plugin-development.html +154 -85
- package/website/docs/project-structure.html +110 -109
- package/website/docs/skill-development.html +117 -61
- package/website/index.html +209 -205
- package/website/script.js +136 -133
- package/website/styles.css +1 -1
- package/plugins/ambient-agent-plugin.js +0 -1565
- package/plugins/email.js +0 -1142
package/examples/test-tg.js
CHANGED
|
@@ -1,62 +1,62 @@
|
|
|
1
|
-
require('dotenv').config();
|
|
2
|
-
const { Framework } = require('../src');
|
|
3
|
-
|
|
4
|
-
async function main() {
|
|
5
|
-
const framework = new Framework({ debug: true });
|
|
6
|
-
|
|
7
|
-
await framework.bootstrap({
|
|
8
|
-
agentDir: process.cwd() + '/.agent',
|
|
9
|
-
aiConfig: {
|
|
10
|
-
provider: process.env.FOLIKO_PROVIDER || 'minimax',
|
|
11
|
-
model: process.env.FOLIKO_MODEL || 'MiniMax-M2.7',
|
|
12
|
-
baseURL: process.env.FOLIKO_BASE_URL || 'https://api.minimaxi.com/v1',
|
|
13
|
-
apiKey: process.env.MINIMAX_API_KEY || process.env.DEEPSEEK_API_KEY
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
// 检查 telegram 插件
|
|
18
|
-
const tgPlugin = framework.pluginManager.get('telegram');
|
|
19
|
-
|
|
20
|
-
if (!tgPlugin) {
|
|
21
|
-
console.log('Telegram plugin NOT loaded!');
|
|
22
|
-
await framework.destroy();
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
console.log('\n=== Telegram Plugin Debug ===');
|
|
27
|
-
console.log('Bot token:', tgPlugin.config.botToken ? 'set' : 'NOT set');
|
|
28
|
-
console.log('Bot instance:', tgPlugin._bot ? 'exists' : 'NOT exists');
|
|
29
|
-
console.log('Group mode:', tgPlugin.config.groupMode);
|
|
30
|
-
console.log('===========================\n');
|
|
31
|
-
|
|
32
|
-
if (!tgPlugin._bot) {
|
|
33
|
-
console.log('Bot is not initialized. Check if TELEGRAM_BOT_TOKEN is valid.');
|
|
34
|
-
await framework.destroy();
|
|
35
|
-
return;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// 监听所有事件
|
|
39
|
-
tgPlugin._bot.on('message', (msg) => {
|
|
40
|
-
console.log('\n[MESSAGE RECEIVED]');
|
|
41
|
-
console.log(' chat.id:', msg.chat?.id);
|
|
42
|
-
console.log(' chat.type:', msg.chat?.type);
|
|
43
|
-
console.log(' from.username:', msg.from?.username);
|
|
44
|
-
console.log(' text:', msg.text);
|
|
45
|
-
console.log('===================\n');
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
tgPlugin._bot.on('polling_error', (err) => {
|
|
49
|
-
console.log('\n[POLLING ERROR]', err.message);
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
tgPlugin._bot.on('error', (err) => {
|
|
53
|
-
console.log('\n[BOT ERROR]', err.message);
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
console.log('Waiting for messages... Send a message to your bot.\n');
|
|
57
|
-
|
|
58
|
-
// 保持运行
|
|
59
|
-
await new Promise(() => {});
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
main().catch(console.error);
|
|
1
|
+
require('dotenv').config();
|
|
2
|
+
const { Framework } = require('../src');
|
|
3
|
+
|
|
4
|
+
async function main() {
|
|
5
|
+
const framework = new Framework({ debug: true });
|
|
6
|
+
|
|
7
|
+
await framework.bootstrap({
|
|
8
|
+
agentDir: process.cwd() + '/.agent',
|
|
9
|
+
aiConfig: {
|
|
10
|
+
provider: process.env.FOLIKO_PROVIDER || 'minimax',
|
|
11
|
+
model: process.env.FOLIKO_MODEL || 'MiniMax-M2.7',
|
|
12
|
+
baseURL: process.env.FOLIKO_BASE_URL || 'https://api.minimaxi.com/v1',
|
|
13
|
+
apiKey: process.env.MINIMAX_API_KEY || process.env.DEEPSEEK_API_KEY,
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
// 检查 telegram 插件
|
|
18
|
+
const tgPlugin = framework.pluginManager.get('telegram');
|
|
19
|
+
|
|
20
|
+
if (!tgPlugin) {
|
|
21
|
+
console.log('Telegram plugin NOT loaded!');
|
|
22
|
+
await framework.destroy();
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
console.log('\n=== Telegram Plugin Debug ===');
|
|
27
|
+
console.log('Bot token:', tgPlugin.config.botToken ? 'set' : 'NOT set');
|
|
28
|
+
console.log('Bot instance:', tgPlugin._bot ? 'exists' : 'NOT exists');
|
|
29
|
+
console.log('Group mode:', tgPlugin.config.groupMode);
|
|
30
|
+
console.log('===========================\n');
|
|
31
|
+
|
|
32
|
+
if (!tgPlugin._bot) {
|
|
33
|
+
console.log('Bot is not initialized. Check if TELEGRAM_BOT_TOKEN is valid.');
|
|
34
|
+
await framework.destroy();
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
// 监听所有事件
|
|
39
|
+
tgPlugin._bot.on('message', (msg) => {
|
|
40
|
+
console.log('\n[MESSAGE RECEIVED]');
|
|
41
|
+
console.log(' chat.id:', msg.chat?.id);
|
|
42
|
+
console.log(' chat.type:', msg.chat?.type);
|
|
43
|
+
console.log(' from.username:', msg.from?.username);
|
|
44
|
+
console.log(' text:', msg.text);
|
|
45
|
+
console.log('===================\n');
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
tgPlugin._bot.on('polling_error', (err) => {
|
|
49
|
+
console.log('\n[POLLING ERROR]', err.message);
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
tgPlugin._bot.on('error', (err) => {
|
|
53
|
+
console.log('\n[BOT ERROR]', err.message);
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
console.log('Waiting for messages... Send a message to your bot.\n');
|
|
57
|
+
|
|
58
|
+
// 保持运行
|
|
59
|
+
await new Promise(() => {});
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
main().catch(console.error);
|
package/examples/test-think.js
CHANGED
|
@@ -1,37 +1,43 @@
|
|
|
1
|
-
require('dotenv').config();
|
|
2
|
-
const { Framework } = require('../src');
|
|
3
|
-
|
|
4
|
-
async function main() {
|
|
5
|
-
const framework = new Framework({ debug: false });
|
|
6
|
-
|
|
7
|
-
await framework.bootstrap({
|
|
8
|
-
agentDir: process.cwd() + '/.agent',
|
|
9
|
-
aiConfig: {
|
|
10
|
-
provider: process.env.FOLIKO_PROVIDER || 'minimax',
|
|
11
|
-
model: process.env.FOLIKO_MODEL || 'MiniMax-M2.7',
|
|
12
|
-
baseURL: process.env.FOLIKO_BASE_URL || 'https://api.minimaxi.com/v1',
|
|
13
|
-
apiKey: process.env.MINIMAX_API_KEY || process.env.DEEPSEEK_API_KEY
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
|
|
17
|
-
const agent = framework.createAgent({
|
|
18
|
-
name: 'FolikoAgent',
|
|
19
|
-
systemPrompt: '你是一个有帮助的助手。'
|
|
20
|
-
});
|
|
21
|
-
|
|
22
|
-
console.log(
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
|
|
1
|
+
require('dotenv').config();
|
|
2
|
+
const { Framework } = require('../src');
|
|
3
|
+
|
|
4
|
+
async function main() {
|
|
5
|
+
const framework = new Framework({ debug: false });
|
|
6
|
+
|
|
7
|
+
await framework.bootstrap({
|
|
8
|
+
agentDir: process.cwd() + '/.agent',
|
|
9
|
+
aiConfig: {
|
|
10
|
+
provider: process.env.FOLIKO_PROVIDER || 'minimax',
|
|
11
|
+
model: process.env.FOLIKO_MODEL || 'MiniMax-M2.7',
|
|
12
|
+
baseURL: process.env.FOLIKO_BASE_URL || 'https://api.minimaxi.com/v1',
|
|
13
|
+
apiKey: process.env.MINIMAX_API_KEY || process.env.DEEPSEEK_API_KEY,
|
|
14
|
+
},
|
|
15
|
+
});
|
|
16
|
+
|
|
17
|
+
const agent = framework.createAgent({
|
|
18
|
+
name: 'FolikoAgent',
|
|
19
|
+
systemPrompt: '你是一个有帮助的助手。',
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
console.log(
|
|
23
|
+
'_mainAgent provider:',
|
|
24
|
+
framework._mainAgent ? framework._mainAgent.provider : 'none'
|
|
25
|
+
);
|
|
26
|
+
console.log(
|
|
27
|
+
'_mainAgent has apiKey:',
|
|
28
|
+
framework._mainAgent && framework._mainAgent.apiKey ? 'yes' : 'no'
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
const tools = framework.getTools();
|
|
32
|
+
const thinkTool = tools.find((t) => t.name === 'think_now');
|
|
33
|
+
|
|
34
|
+
if (thinkTool) {
|
|
35
|
+
const result = await thinkTool.execute({ mode: 'reflect', topic: '测试' });
|
|
36
|
+
console.log('think_now success:', result.success);
|
|
37
|
+
if (result.success === false) console.log('Error:', result.error);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
await framework.destroy();
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
main().catch(console.error);
|
|
@@ -1,98 +1,103 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Web 插件测试示例
|
|
3
|
-
* 测试路由注册和请求响应
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
const { WebPlugin } = require('../plugins/web-plugin')
|
|
7
|
-
|
|
8
|
-
async function test() {
|
|
9
|
-
console.log('=== Web 插件测试 ===\n')
|
|
10
|
-
|
|
11
|
-
// 1. 创建插件
|
|
12
|
-
const plugin = new WebPlugin()
|
|
13
|
-
const mockFramework = {
|
|
14
|
-
registerTool: (tool) => console.log(`[工具注册] ${tool.name}`),
|
|
15
|
-
_agents: [],
|
|
16
|
-
pluginManager: { get: () => null }
|
|
17
|
-
}
|
|
18
|
-
plugin.install(mockFramework)
|
|
19
|
-
|
|
20
|
-
// 2. 启动服务
|
|
21
|
-
console.log('\n[1] 启动 Web 服务...')
|
|
22
|
-
const startResult = await plugin._startServer(3099)
|
|
23
|
-
console.log('启动结果:', startResult.success ? '成功' : '失败')
|
|
24
|
-
console.log('服务地址: http://localhost:3099\n')
|
|
25
|
-
|
|
26
|
-
// 3. 注册测试路由
|
|
27
|
-
console.log('[2] 注册测试路由...')
|
|
28
|
-
|
|
29
|
-
// 返回固定字符串
|
|
30
|
-
await plugin._registerRoute('GET', '/test', 'return "1232432"', '返回固定字符串')
|
|
31
|
-
console.log('注册: GET /test -> return "1232432"')
|
|
32
|
-
|
|
33
|
-
// 返回 JSON
|
|
34
|
-
await plugin._registerRoute('GET', '/json', 'return { hello: "world", code: 200 }', '返回 JSON')
|
|
35
|
-
console.log('注册: GET /json -> return { hello: "world", code: 200 }')
|
|
36
|
-
|
|
37
|
-
// 带参数
|
|
38
|
-
await plugin._registerRoute(
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
console.log('
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
console.log('
|
|
60
|
-
|
|
61
|
-
console.log(
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
console.log('
|
|
67
|
-
|
|
68
|
-
console.log(
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
console.log('
|
|
74
|
-
|
|
75
|
-
console.log(
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
console.log('
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Web 插件测试示例
|
|
3
|
+
* 测试路由注册和请求响应
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
const { WebPlugin } = require('../plugins/web-plugin');
|
|
7
|
+
|
|
8
|
+
async function test() {
|
|
9
|
+
console.log('=== Web 插件测试 ===\n');
|
|
10
|
+
|
|
11
|
+
// 1. 创建插件
|
|
12
|
+
const plugin = new WebPlugin();
|
|
13
|
+
const mockFramework = {
|
|
14
|
+
registerTool: (tool) => console.log(`[工具注册] ${tool.name}`),
|
|
15
|
+
_agents: [],
|
|
16
|
+
pluginManager: { get: () => null },
|
|
17
|
+
};
|
|
18
|
+
plugin.install(mockFramework);
|
|
19
|
+
|
|
20
|
+
// 2. 启动服务
|
|
21
|
+
console.log('\n[1] 启动 Web 服务...');
|
|
22
|
+
const startResult = await plugin._startServer(3099);
|
|
23
|
+
console.log('启动结果:', startResult.success ? '成功' : '失败');
|
|
24
|
+
console.log('服务地址: http://localhost:3099\n');
|
|
25
|
+
|
|
26
|
+
// 3. 注册测试路由
|
|
27
|
+
console.log('[2] 注册测试路由...');
|
|
28
|
+
|
|
29
|
+
// 返回固定字符串
|
|
30
|
+
await plugin._registerRoute('GET', '/test', 'return "1232432"', '返回固定字符串');
|
|
31
|
+
console.log('注册: GET /test -> return "1232432"');
|
|
32
|
+
|
|
33
|
+
// 返回 JSON
|
|
34
|
+
await plugin._registerRoute('GET', '/json', 'return { hello: "world", code: 200 }', '返回 JSON');
|
|
35
|
+
console.log('注册: GET /json -> return { hello: "world", code: 200 }');
|
|
36
|
+
|
|
37
|
+
// 带参数
|
|
38
|
+
await plugin._registerRoute(
|
|
39
|
+
'GET',
|
|
40
|
+
'/user/:id',
|
|
41
|
+
'return { userId: context.params.id }',
|
|
42
|
+
'路径参数'
|
|
43
|
+
);
|
|
44
|
+
console.log('注册: GET /user/:id -> return { userId: context.params.id }');
|
|
45
|
+
|
|
46
|
+
// POST 路由
|
|
47
|
+
await plugin._registerRoute('POST', '/echo', 'return { received: context.body }', '回显 body');
|
|
48
|
+
console.log('注册: POST /echo -> return { received: context.body }');
|
|
49
|
+
|
|
50
|
+
// 4. 等待服务就绪
|
|
51
|
+
await new Promise((r) => setTimeout(r, 500));
|
|
52
|
+
|
|
53
|
+
// 5. 测试各路由
|
|
54
|
+
console.log('\n[3] 测试路由响应...\n');
|
|
55
|
+
|
|
56
|
+
// GET /test
|
|
57
|
+
console.log('GET /test:');
|
|
58
|
+
const r1 = await plugin._sendRequest('GET', '/test');
|
|
59
|
+
console.log(' 状态:', r1.status);
|
|
60
|
+
console.log(' 响应:', JSON.stringify(r1.body));
|
|
61
|
+
console.log();
|
|
62
|
+
|
|
63
|
+
// GET /json
|
|
64
|
+
console.log('GET /json:');
|
|
65
|
+
const r2 = await plugin._sendRequest('GET', '/json');
|
|
66
|
+
console.log(' 状态:', r2.status);
|
|
67
|
+
console.log(' 响应:', JSON.stringify(r2.body));
|
|
68
|
+
console.log();
|
|
69
|
+
|
|
70
|
+
// GET /user/123
|
|
71
|
+
console.log('GET /user/123:');
|
|
72
|
+
const r3 = await plugin._sendRequest('GET', '/user/123');
|
|
73
|
+
console.log(' 状态:', r3.status);
|
|
74
|
+
console.log(' 响应:', JSON.stringify(r3.body));
|
|
75
|
+
console.log();
|
|
76
|
+
|
|
77
|
+
// POST /echo
|
|
78
|
+
console.log('POST /echo (body: { name: "test" }):');
|
|
79
|
+
const r4 = await plugin._sendRequest('POST', '/echo', { name: 'test' });
|
|
80
|
+
console.log(' 状态:', r4.status);
|
|
81
|
+
console.log(' 响应:', JSON.stringify(r4.body));
|
|
82
|
+
console.log();
|
|
83
|
+
|
|
84
|
+
// 6. 列出所有路由
|
|
85
|
+
console.log('[4] 已注册的路由:');
|
|
86
|
+
const routes = plugin._listRoutes();
|
|
87
|
+
routes.routes.forEach((r) => {
|
|
88
|
+
console.log(` ${r.method} ${r.path} - ${r.description}`);
|
|
89
|
+
});
|
|
90
|
+
routes.webhooks.forEach((w) => {
|
|
91
|
+
console.log(` WEBHOOK ${w.path}`);
|
|
92
|
+
});
|
|
93
|
+
routes.statics.forEach((s) => {
|
|
94
|
+
console.log(` STATIC ${s.path} -> ${s.folder}`);
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
// 7. 停止服务
|
|
98
|
+
console.log('\n[5] 停止服务...');
|
|
99
|
+
await plugin._stopServer();
|
|
100
|
+
console.log('测试完成!');
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
test().catch(console.error);
|
|
@@ -1,100 +1,103 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 微信/飞书插件测试
|
|
3
|
-
* 测试 chat() 方法(非流式)
|
|
4
|
-
*/
|
|
5
|
-
|
|
6
|
-
const { Framework } = require('../src')
|
|
7
|
-
|
|
8
|
-
async function main() {
|
|
9
|
-
console.log('=== Weixin/Feishu Plugin Test ===\n')
|
|
10
|
-
|
|
11
|
-
const framework = new Framework({ debug: true })
|
|
12
|
-
|
|
13
|
-
// Bootstrap 加载默认插件
|
|
14
|
-
await framework.bootstrap({
|
|
15
|
-
agentDir: './.agent',
|
|
16
|
-
aiConfig: {
|
|
17
|
-
provider: 'deepseek',
|
|
18
|
-
model: 'deepseek-chat',
|
|
19
|
-
apiKey: process.env.DEEPSEEK_API_KEY || 'your-api-key'
|
|
20
|
-
}
|
|
21
|
-
})
|
|
22
|
-
|
|
23
|
-
// 加载微信插件
|
|
24
|
-
const { WeixinPlugin } = require('../plugins/weixin-plugin')
|
|
25
|
-
const weixinPlugin = new WeixinPlugin({
|
|
26
|
-
forceLogin: false,
|
|
27
|
-
allowedUsers: []
|
|
28
|
-
})
|
|
29
|
-
|
|
30
|
-
// 加载飞书插件
|
|
31
|
-
const { FeishuPlugin } = require('../plugins/feishu-plugin')
|
|
32
|
-
const feishuPlugin = new FeishuPlugin({
|
|
33
|
-
// appId: 'your-app-id',
|
|
34
|
-
// appSecret: 'your-app-secret',
|
|
35
|
-
allowedUsers: []
|
|
36
|
-
})
|
|
37
|
-
|
|
38
|
-
// 注册插件(不自动加载)
|
|
39
|
-
// framework.registerPlugin(weixinPlugin)
|
|
40
|
-
// framework.registerPlugin(feishuPlugin)
|
|
41
|
-
|
|
42
|
-
console.log('\n--- Plugins Registered ---')
|
|
43
|
-
console.log(
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
//
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
const
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
console.
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
1
|
+
/**
|
|
2
|
+
* 微信/飞书插件测试
|
|
3
|
+
* 测试 chat() 方法(非流式)
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
const { Framework } = require('../src');
|
|
7
|
+
|
|
8
|
+
async function main() {
|
|
9
|
+
console.log('=== Weixin/Feishu Plugin Test ===\n');
|
|
10
|
+
|
|
11
|
+
const framework = new Framework({ debug: true });
|
|
12
|
+
|
|
13
|
+
// Bootstrap 加载默认插件
|
|
14
|
+
await framework.bootstrap({
|
|
15
|
+
agentDir: './.agent',
|
|
16
|
+
aiConfig: {
|
|
17
|
+
provider: 'deepseek',
|
|
18
|
+
model: 'deepseek-chat',
|
|
19
|
+
apiKey: process.env.DEEPSEEK_API_KEY || 'your-api-key',
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
// 加载微信插件
|
|
24
|
+
const { WeixinPlugin } = require('../plugins/weixin-plugin');
|
|
25
|
+
const weixinPlugin = new WeixinPlugin({
|
|
26
|
+
forceLogin: false,
|
|
27
|
+
allowedUsers: [], // 空数组表示允许所有人
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
// 加载飞书插件
|
|
31
|
+
const { FeishuPlugin } = require('../plugins/feishu-plugin');
|
|
32
|
+
const feishuPlugin = new FeishuPlugin({
|
|
33
|
+
// appId: 'your-app-id',
|
|
34
|
+
// appSecret: 'your-app-secret',
|
|
35
|
+
allowedUsers: [],
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
// 注册插件(不自动加载)
|
|
39
|
+
// framework.registerPlugin(weixinPlugin)
|
|
40
|
+
// framework.registerPlugin(feishuPlugin)
|
|
41
|
+
|
|
42
|
+
console.log('\n--- Plugins Registered ---');
|
|
43
|
+
console.log(
|
|
44
|
+
'Plugins:',
|
|
45
|
+
framework.pluginManager.getAll().map((p) => p.name)
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
// 创建测试 Agent
|
|
49
|
+
const agent = framework.createAgent({
|
|
50
|
+
name: 'TestAgent',
|
|
51
|
+
systemPrompt: '你是一个测试助手,回复要简洁。',
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
// 测试 chat() 方法(模拟消息处理)
|
|
55
|
+
console.log('\n--- Test chat() method ---');
|
|
56
|
+
|
|
57
|
+
// 模拟飞书的消息处理流程
|
|
58
|
+
const mockOpenId = 'test_user_001';
|
|
59
|
+
const mockText = '你好,请介绍一下你自己';
|
|
60
|
+
|
|
61
|
+
// 获取 session agent(内部逻辑)
|
|
62
|
+
const sessionInfo = {
|
|
63
|
+
agent: framework.createSessionAgent(`test_${mockOpenId}`, {
|
|
64
|
+
systemPrompt: feishuPlugin.systemPrompt,
|
|
65
|
+
}),
|
|
66
|
+
sessionId: `test_${mockOpenId}`,
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
try {
|
|
70
|
+
// 使用 chat() 而非 chatStream()
|
|
71
|
+
const result = await sessionInfo.agent.chat(mockText, {
|
|
72
|
+
sessionId: sessionInfo.sessionId,
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
console.log('Result:', result);
|
|
76
|
+
console.log('Message:', result.message);
|
|
77
|
+
console.log('StepCount:', result.stepCount);
|
|
78
|
+
} catch (err) {
|
|
79
|
+
console.error('Chat error:', err.message);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// 测试 chatStream() 对比
|
|
83
|
+
console.log('\n--- Test chatStream() for comparison ---');
|
|
84
|
+
try {
|
|
85
|
+
let fullResponse = '';
|
|
86
|
+
for await (const chunk of sessionInfo.agent.chatStream('今天天气怎么样?', {
|
|
87
|
+
sessionId: sessionInfo.sessionId,
|
|
88
|
+
})) {
|
|
89
|
+
if (chunk.type === 'text' && chunk.text) {
|
|
90
|
+
fullResponse += chunk.text;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
console.log('Stream result:', fullResponse);
|
|
94
|
+
} catch (err) {
|
|
95
|
+
console.error('Stream error:', err.message);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
// 清理
|
|
99
|
+
await framework.destroy();
|
|
100
|
+
console.log('\n[Done]');
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
main().catch(console.error);
|