@caoxupei/ai-agent-cli 1.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.
- package/LICENSE +21 -0
- package/README.md +350 -0
- package/bin/ai-agent-cli.js +14 -0
- package/dist/adapters/anthropic.d.ts +15 -0
- package/dist/adapters/anthropic.d.ts.map +1 -0
- package/dist/adapters/anthropic.js +83 -0
- package/dist/adapters/anthropic.js.map +1 -0
- package/dist/adapters/base.d.ts +45 -0
- package/dist/adapters/base.d.ts.map +1 -0
- package/dist/adapters/base.js +27 -0
- package/dist/adapters/base.js.map +1 -0
- package/dist/adapters/factory.d.ts +17 -0
- package/dist/adapters/factory.d.ts.map +1 -0
- package/dist/adapters/factory.js +34 -0
- package/dist/adapters/factory.js.map +1 -0
- package/dist/adapters/gemini.d.ts +16 -0
- package/dist/adapters/gemini.d.ts.map +1 -0
- package/dist/adapters/gemini.js +164 -0
- package/dist/adapters/gemini.js.map +1 -0
- package/dist/adapters/openai.d.ts +15 -0
- package/dist/adapters/openai.d.ts.map +1 -0
- package/dist/adapters/openai.js +175 -0
- package/dist/adapters/openai.js.map +1 -0
- package/dist/commands/skillCommands.d.ts +21 -0
- package/dist/commands/skillCommands.d.ts.map +1 -0
- package/dist/commands/skillCommands.js +320 -0
- package/dist/commands/skillCommands.js.map +1 -0
- package/dist/config/Config.d.ts +35 -0
- package/dist/config/Config.d.ts.map +1 -0
- package/dist/config/Config.js +108 -0
- package/dist/config/Config.js.map +1 -0
- package/dist/config/types.d.ts +48 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +32 -0
- package/dist/config/types.js.map +1 -0
- package/dist/core/agents.d.ts +32 -0
- package/dist/core/agents.d.ts.map +1 -0
- package/dist/core/agents.js +93 -0
- package/dist/core/agents.js.map +1 -0
- package/dist/core/constants.d.ts +97 -0
- package/dist/core/constants.d.ts.map +1 -0
- package/dist/core/constants.js +119 -0
- package/dist/core/constants.js.map +1 -0
- package/dist/core/loop.d.ts +33 -0
- package/dist/core/loop.d.ts.map +1 -0
- package/dist/core/loop.js +134 -0
- package/dist/core/loop.js.map +1 -0
- package/dist/core/outputStyles.d.ts +50 -0
- package/dist/core/outputStyles.d.ts.map +1 -0
- package/dist/core/outputStyles.js +165 -0
- package/dist/core/outputStyles.js.map +1 -0
- package/dist/core/planMode.d.ts +40 -0
- package/dist/core/planMode.d.ts.map +1 -0
- package/dist/core/planMode.js +143 -0
- package/dist/core/planMode.js.map +1 -0
- package/dist/core/projectContext.d.ts +68 -0
- package/dist/core/projectContext.d.ts.map +1 -0
- package/dist/core/projectContext.js +183 -0
- package/dist/core/projectContext.js.map +1 -0
- package/dist/core/prompts.d.ts +26 -0
- package/dist/core/prompts.d.ts.map +1 -0
- package/dist/core/prompts.js +267 -0
- package/dist/core/prompts.js.map +1 -0
- package/dist/core/reminder.d.ts +72 -0
- package/dist/core/reminder.d.ts.map +1 -0
- package/dist/core/reminder.js +152 -0
- package/dist/core/reminder.js.map +1 -0
- package/dist/core/theme.d.ts +35 -0
- package/dist/core/theme.d.ts.map +1 -0
- package/dist/core/theme.js +56 -0
- package/dist/core/theme.js.map +1 -0
- package/dist/core/types.d.ts +55 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +5 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/ui/Banner.d.ts +47 -0
- package/dist/core/ui/Banner.d.ts.map +1 -0
- package/dist/core/ui/Banner.js +122 -0
- package/dist/core/ui/Banner.js.map +1 -0
- package/dist/core/ui/Input.d.ts +51 -0
- package/dist/core/ui/Input.d.ts.map +1 -0
- package/dist/core/ui/Input.js +322 -0
- package/dist/core/ui/Input.js.map +1 -0
- package/dist/core/ui/Logo.d.ts +21 -0
- package/dist/core/ui/Logo.d.ts.map +1 -0
- package/dist/core/ui/Logo.js +31 -0
- package/dist/core/ui/Logo.js.map +1 -0
- package/dist/core/ui/Messages.d.ts +45 -0
- package/dist/core/ui/Messages.d.ts.map +1 -0
- package/dist/core/ui/Messages.js +76 -0
- package/dist/core/ui/Messages.js.map +1 -0
- package/dist/core/ui/Spinner.d.ts +29 -0
- package/dist/core/ui/Spinner.d.ts.map +1 -0
- package/dist/core/ui/Spinner.js +64 -0
- package/dist/core/ui/Spinner.js.map +1 -0
- package/dist/core/ui/ToolDisplay.d.ts +49 -0
- package/dist/core/ui/ToolDisplay.d.ts.map +1 -0
- package/dist/core/ui/ToolDisplay.js +99 -0
- package/dist/core/ui/ToolDisplay.js.map +1 -0
- package/dist/core/ui/index.d.ts +16 -0
- package/dist/core/ui/index.d.ts.map +1 -0
- package/dist/core/ui/index.js +17 -0
- package/dist/core/ui/index.js.map +1 -0
- package/dist/core/ui/utils.d.ts +28 -0
- package/dist/core/ui/utils.d.ts.map +1 -0
- package/dist/core/ui/utils.js +76 -0
- package/dist/core/ui/utils.js.map +1 -0
- package/dist/entrypoints/cli.d.ts +5 -0
- package/dist/entrypoints/cli.d.ts.map +1 -0
- package/dist/entrypoints/cli.js +199 -0
- package/dist/entrypoints/cli.js.map +1 -0
- package/dist/entrypoints/index.d.ts +18 -0
- package/dist/entrypoints/index.d.ts.map +1 -0
- package/dist/entrypoints/index.js +21 -0
- package/dist/entrypoints/index.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +14 -0
- package/dist/index.js.map +1 -0
- package/dist/services/ai/adapters/anthropic.d.ts +15 -0
- package/dist/services/ai/adapters/anthropic.d.ts.map +1 -0
- package/dist/services/ai/adapters/anthropic.js +83 -0
- package/dist/services/ai/adapters/anthropic.js.map +1 -0
- package/dist/services/ai/adapters/base.d.ts +47 -0
- package/dist/services/ai/adapters/base.d.ts.map +1 -0
- package/dist/services/ai/adapters/base.js +24 -0
- package/dist/services/ai/adapters/base.js.map +1 -0
- package/dist/services/ai/adapters/factory.d.ts +17 -0
- package/dist/services/ai/adapters/factory.d.ts.map +1 -0
- package/dist/services/ai/adapters/factory.js +34 -0
- package/dist/services/ai/adapters/factory.js.map +1 -0
- package/dist/services/ai/adapters/gemini.d.ts +16 -0
- package/dist/services/ai/adapters/gemini.d.ts.map +1 -0
- package/dist/services/ai/adapters/gemini.js +164 -0
- package/dist/services/ai/adapters/gemini.js.map +1 -0
- package/dist/services/ai/adapters/openai.d.ts +15 -0
- package/dist/services/ai/adapters/openai.d.ts.map +1 -0
- package/dist/services/ai/adapters/openai.js +175 -0
- package/dist/services/ai/adapters/openai.js.map +1 -0
- package/dist/services/ai/index.d.ts +10 -0
- package/dist/services/ai/index.d.ts.map +1 -0
- package/dist/services/ai/index.js +11 -0
- package/dist/services/ai/index.js.map +1 -0
- package/dist/services/config/Config.d.ts +41 -0
- package/dist/services/config/Config.d.ts.map +1 -0
- package/dist/services/config/Config.js +131 -0
- package/dist/services/config/Config.js.map +1 -0
- package/dist/services/config/configStore.d.ts +42 -0
- package/dist/services/config/configStore.d.ts.map +1 -0
- package/dist/services/config/configStore.js +77 -0
- package/dist/services/config/configStore.js.map +1 -0
- package/dist/services/config/index.d.ts +7 -0
- package/dist/services/config/index.d.ts.map +1 -0
- package/dist/services/config/index.js +6 -0
- package/dist/services/config/index.js.map +1 -0
- package/dist/services/config/setup.d.ts +13 -0
- package/dist/services/config/setup.d.ts.map +1 -0
- package/dist/services/config/setup.js +157 -0
- package/dist/services/config/setup.js.map +1 -0
- package/dist/services/config/types.d.ts +56 -0
- package/dist/services/config/types.d.ts.map +1 -0
- package/dist/services/config/types.js +32 -0
- package/dist/services/config/types.js.map +1 -0
- package/dist/services/customCommands.d.ts +37 -0
- package/dist/services/customCommands.d.ts.map +1 -0
- package/dist/services/customCommands.js +453 -0
- package/dist/services/customCommands.js.map +1 -0
- package/dist/services/index.d.ts +7 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +10 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/skillMarketplace.d.ts +74 -0
- package/dist/services/skillMarketplace.d.ts.map +1 -0
- package/dist/services/skillMarketplace.js +486 -0
- package/dist/services/skillMarketplace.js.map +1 -0
- package/dist/services/system/index.d.ts +6 -0
- package/dist/services/system/index.d.ts.map +1 -0
- package/dist/services/system/index.js +6 -0
- package/dist/services/system/index.js.map +1 -0
- package/dist/services/system/security.d.ts +30 -0
- package/dist/services/system/security.d.ts.map +1 -0
- package/dist/services/system/security.js +124 -0
- package/dist/services/system/security.js.map +1 -0
- package/dist/tools/agent/index.d.ts +6 -0
- package/dist/tools/agent/index.d.ts.map +1 -0
- package/dist/tools/agent/index.js +6 -0
- package/dist/tools/agent/index.js.map +1 -0
- package/dist/tools/agent/planMode.d.ts +12 -0
- package/dist/tools/agent/planMode.d.ts.map +1 -0
- package/dist/tools/agent/planMode.js +23 -0
- package/dist/tools/agent/planMode.js.map +1 -0
- package/dist/tools/agent/task.d.ts +10 -0
- package/dist/tools/agent/task.d.ts.map +1 -0
- package/dist/tools/agent/task.js +127 -0
- package/dist/tools/agent/task.js.map +1 -0
- package/dist/tools/ai/index.d.ts +5 -0
- package/dist/tools/ai/index.d.ts.map +1 -0
- package/dist/tools/ai/index.js +5 -0
- package/dist/tools/ai/index.js.map +1 -0
- package/dist/tools/ai/skill.d.ts +78 -0
- package/dist/tools/ai/skill.d.ts.map +1 -0
- package/dist/tools/ai/skill.js +315 -0
- package/dist/tools/ai/skill.js.map +1 -0
- package/dist/tools/askQuestion.d.ts +25 -0
- package/dist/tools/askQuestion.d.ts.map +1 -0
- package/dist/tools/askQuestion.js +99 -0
- package/dist/tools/askQuestion.js.map +1 -0
- package/dist/tools/bash.d.ts +11 -0
- package/dist/tools/bash.d.ts.map +1 -0
- package/dist/tools/bash.js +58 -0
- package/dist/tools/bash.js.map +1 -0
- package/dist/tools/definitions.d.ts +26 -0
- package/dist/tools/definitions.d.ts.map +1 -0
- package/dist/tools/definitions.js +599 -0
- package/dist/tools/definitions.js.map +1 -0
- package/dist/tools/dispatcher.d.ts +38 -0
- package/dist/tools/dispatcher.d.ts.map +1 -0
- package/dist/tools/dispatcher.js +75 -0
- package/dist/tools/dispatcher.js.map +1 -0
- package/dist/tools/fileOps.d.ts +16 -0
- package/dist/tools/fileOps.d.ts.map +1 -0
- package/dist/tools/fileOps.js +115 -0
- package/dist/tools/fileOps.js.map +1 -0
- package/dist/tools/filesystem/bash.d.ts +11 -0
- package/dist/tools/filesystem/bash.d.ts.map +1 -0
- package/dist/tools/filesystem/bash.js +58 -0
- package/dist/tools/filesystem/bash.js.map +1 -0
- package/dist/tools/filesystem/fileOps.d.ts +16 -0
- package/dist/tools/filesystem/fileOps.d.ts.map +1 -0
- package/dist/tools/filesystem/fileOps.js +115 -0
- package/dist/tools/filesystem/fileOps.js.map +1 -0
- package/dist/tools/filesystem/index.d.ts +1 -0
- package/dist/tools/filesystem/index.d.ts.map +1 -0
- package/dist/tools/filesystem/index.js +2 -0
- package/dist/tools/filesystem/index.js.map +1 -0
- package/dist/tools/glob.d.ts +18 -0
- package/dist/tools/glob.d.ts.map +1 -0
- package/dist/tools/glob.js +63 -0
- package/dist/tools/glob.js.map +1 -0
- package/dist/tools/grep.d.ts +26 -0
- package/dist/tools/grep.d.ts.map +1 -0
- package/dist/tools/grep.js +137 -0
- package/dist/tools/grep.js.map +1 -0
- package/dist/tools/index.d.ts +13 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +14 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/interaction/askQuestion.d.ts +25 -0
- package/dist/tools/interaction/askQuestion.d.ts.map +1 -0
- package/dist/tools/interaction/askQuestion.js +99 -0
- package/dist/tools/interaction/askQuestion.js.map +1 -0
- package/dist/tools/interaction/index.d.ts +6 -0
- package/dist/tools/interaction/index.d.ts.map +1 -0
- package/dist/tools/interaction/index.js +6 -0
- package/dist/tools/interaction/index.js.map +1 -0
- package/dist/tools/interaction/todo.d.ts +36 -0
- package/dist/tools/interaction/todo.d.ts.map +1 -0
- package/dist/tools/interaction/todo.js +137 -0
- package/dist/tools/interaction/todo.js.map +1 -0
- package/dist/tools/network/index.d.ts +6 -0
- package/dist/tools/network/index.d.ts.map +1 -0
- package/dist/tools/network/index.js +6 -0
- package/dist/tools/network/index.js.map +1 -0
- package/dist/tools/network/webFetch.d.ts +8 -0
- package/dist/tools/network/webFetch.d.ts.map +1 -0
- package/dist/tools/network/webFetch.js +87 -0
- package/dist/tools/network/webFetch.js.map +1 -0
- package/dist/tools/network/webSearch.d.ts +8 -0
- package/dist/tools/network/webSearch.d.ts.map +1 -0
- package/dist/tools/network/webSearch.js +84 -0
- package/dist/tools/network/webSearch.js.map +1 -0
- package/dist/tools/planMode.d.ts +12 -0
- package/dist/tools/planMode.d.ts.map +1 -0
- package/dist/tools/planMode.js +23 -0
- package/dist/tools/planMode.js.map +1 -0
- package/dist/tools/search/glob.d.ts +18 -0
- package/dist/tools/search/glob.d.ts.map +1 -0
- package/dist/tools/search/glob.js +63 -0
- package/dist/tools/search/glob.js.map +1 -0
- package/dist/tools/search/grep.d.ts +26 -0
- package/dist/tools/search/grep.d.ts.map +1 -0
- package/dist/tools/search/grep.js +137 -0
- package/dist/tools/search/grep.js.map +1 -0
- package/dist/tools/search/index.d.ts +6 -0
- package/dist/tools/search/index.d.ts.map +1 -0
- package/dist/tools/search/index.js +6 -0
- package/dist/tools/search/index.js.map +1 -0
- package/dist/tools/skill.d.ts +41 -0
- package/dist/tools/skill.d.ts.map +1 -0
- package/dist/tools/skill.js +149 -0
- package/dist/tools/skill.js.map +1 -0
- package/dist/tools/system/index.d.ts +6 -0
- package/dist/tools/system/index.d.ts.map +1 -0
- package/dist/tools/system/index.js +6 -0
- package/dist/tools/system/index.js.map +1 -0
- package/dist/tools/task.d.ts +10 -0
- package/dist/tools/task.d.ts.map +1 -0
- package/dist/tools/task.js +127 -0
- package/dist/tools/task.js.map +1 -0
- package/dist/tools/todo.d.ts +36 -0
- package/dist/tools/todo.d.ts.map +1 -0
- package/dist/tools/todo.js +137 -0
- package/dist/tools/todo.js.map +1 -0
- package/dist/tools/types.d.ts +139 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +5 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/tools/webFetch.d.ts +8 -0
- package/dist/tools/webFetch.d.ts.map +1 -0
- package/dist/tools/webFetch.js +87 -0
- package/dist/tools/webFetch.js.map +1 -0
- package/dist/tools/webSearch.d.ts +8 -0
- package/dist/tools/webSearch.d.ts.map +1 -0
- package/dist/tools/webSearch.js +84 -0
- package/dist/tools/webSearch.js.map +1 -0
- package/dist/ui/Banner.d.ts +47 -0
- package/dist/ui/Banner.d.ts.map +1 -0
- package/dist/ui/Banner.js +122 -0
- package/dist/ui/Banner.js.map +1 -0
- package/dist/ui/Input.d.ts +42 -0
- package/dist/ui/Input.d.ts.map +1 -0
- package/dist/ui/Input.js +270 -0
- package/dist/ui/Input.js.map +1 -0
- package/dist/ui/Logo.d.ts +21 -0
- package/dist/ui/Logo.d.ts.map +1 -0
- package/dist/ui/Logo.js +31 -0
- package/dist/ui/Logo.js.map +1 -0
- package/dist/ui/Messages.d.ts +45 -0
- package/dist/ui/Messages.d.ts.map +1 -0
- package/dist/ui/Messages.js +76 -0
- package/dist/ui/Messages.js.map +1 -0
- package/dist/ui/Spinner.d.ts +29 -0
- package/dist/ui/Spinner.d.ts.map +1 -0
- package/dist/ui/Spinner.js +64 -0
- package/dist/ui/Spinner.js.map +1 -0
- package/dist/ui/ToolDisplay.d.ts +49 -0
- package/dist/ui/ToolDisplay.d.ts.map +1 -0
- package/dist/ui/ToolDisplay.js +99 -0
- package/dist/ui/ToolDisplay.js.map +1 -0
- package/dist/ui/components/Banner.d.ts +46 -0
- package/dist/ui/components/Banner.d.ts.map +1 -0
- package/dist/ui/components/Banner.js +121 -0
- package/dist/ui/components/Banner.js.map +1 -0
- package/dist/ui/components/Input.d.ts +51 -0
- package/dist/ui/components/Input.d.ts.map +1 -0
- package/dist/ui/components/Input.js +322 -0
- package/dist/ui/components/Input.js.map +1 -0
- package/dist/ui/components/Logo.d.ts +21 -0
- package/dist/ui/components/Logo.d.ts.map +1 -0
- package/dist/ui/components/Logo.js +31 -0
- package/dist/ui/components/Logo.js.map +1 -0
- package/dist/ui/components/Messages.d.ts +45 -0
- package/dist/ui/components/Messages.d.ts.map +1 -0
- package/dist/ui/components/Messages.js +76 -0
- package/dist/ui/components/Messages.js.map +1 -0
- package/dist/ui/components/Spinner.d.ts +29 -0
- package/dist/ui/components/Spinner.d.ts.map +1 -0
- package/dist/ui/components/Spinner.js +64 -0
- package/dist/ui/components/Spinner.js.map +1 -0
- package/dist/ui/components/ToolDisplay.d.ts +49 -0
- package/dist/ui/components/ToolDisplay.d.ts.map +1 -0
- package/dist/ui/components/ToolDisplay.js +99 -0
- package/dist/ui/components/ToolDisplay.js.map +1 -0
- package/dist/ui/index.d.ts +16 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +17 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/theme.d.ts +34 -0
- package/dist/ui/theme.d.ts.map +1 -0
- package/dist/ui/theme.js +55 -0
- package/dist/ui/theme.js.map +1 -0
- package/dist/ui/utils.d.ts +28 -0
- package/dist/ui/utils.d.ts.map +1 -0
- package/dist/ui/utils.js +76 -0
- package/dist/ui/utils.js.map +1 -0
- package/dist/utils/fs/index.d.ts +24 -0
- package/dist/utils/fs/index.d.ts.map +1 -0
- package/dist/utils/fs/index.js +50 -0
- package/dist/utils/fs/index.js.map +1 -0
- package/dist/utils/index.d.ts +7 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +10 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/security.d.ts +26 -0
- package/dist/utils/security.d.ts.map +1 -0
- package/dist/utils/security.js +123 -0
- package/dist/utils/security.js.map +1 -0
- package/dist/utils/text/index.d.ts +28 -0
- package/dist/utils/text/index.d.ts.map +1 -0
- package/dist/utils/text/index.js +51 -0
- package/dist/utils/text/index.js.map +1 -0
- package/package.json +84 -0
- package/skills/web-dev/SKILL.md +91 -0
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 安全工具函数
|
|
3
|
+
* 提供路径安全检查、命令验证等功能
|
|
4
|
+
*/
|
|
5
|
+
import path from 'node:path';
|
|
6
|
+
/**
|
|
7
|
+
* 危险命令模式列表
|
|
8
|
+
*/
|
|
9
|
+
const DANGEROUS_PATTERNS = [
|
|
10
|
+
/rm\s+-rf\s+[\/~]/i, // rm -rf / 或 rm -rf ~
|
|
11
|
+
/rm\s+-rf\s+\*/i, // rm -rf *
|
|
12
|
+
/>\s*\/dev\/sd[a-z]/i, // 写入磁盘设备
|
|
13
|
+
/mkfs\./i, // 格式化命令
|
|
14
|
+
/dd\s+if=/i, // dd 命令
|
|
15
|
+
/:(){ :|:& };:/i, // fork bomb
|
|
16
|
+
/chmod\s+-R\s+777\s+\//i, // 危险权限修改
|
|
17
|
+
/curl.*\|\s*(ba)?sh/i, // curl | bash
|
|
18
|
+
/wget.*\|\s*(ba)?sh/i, // wget | bash
|
|
19
|
+
];
|
|
20
|
+
/**
|
|
21
|
+
* 只读命令白名单(用于 explore 代理)
|
|
22
|
+
*/
|
|
23
|
+
const READ_ONLY_COMMANDS = [
|
|
24
|
+
'ls',
|
|
25
|
+
'cat',
|
|
26
|
+
'head',
|
|
27
|
+
'tail',
|
|
28
|
+
'less',
|
|
29
|
+
'more',
|
|
30
|
+
'grep',
|
|
31
|
+
'find',
|
|
32
|
+
'wc',
|
|
33
|
+
'diff',
|
|
34
|
+
'file',
|
|
35
|
+
'stat',
|
|
36
|
+
'du',
|
|
37
|
+
'df',
|
|
38
|
+
'pwd',
|
|
39
|
+
'echo',
|
|
40
|
+
'which',
|
|
41
|
+
'whereis',
|
|
42
|
+
'type',
|
|
43
|
+
'git log',
|
|
44
|
+
'git diff',
|
|
45
|
+
'git status',
|
|
46
|
+
'git show',
|
|
47
|
+
'git branch',
|
|
48
|
+
'git remote',
|
|
49
|
+
'tree',
|
|
50
|
+
'env',
|
|
51
|
+
'printenv',
|
|
52
|
+
];
|
|
53
|
+
/**
|
|
54
|
+
* 安全路径检查
|
|
55
|
+
* 确保路径在工作目录内,防止路径遍历攻击
|
|
56
|
+
*/
|
|
57
|
+
export function safePath(workdir, filePath) {
|
|
58
|
+
// 解析绝对路径
|
|
59
|
+
const resolved = path.resolve(workdir, filePath);
|
|
60
|
+
// 规范化路径
|
|
61
|
+
const normalizedWorkdir = path.normalize(workdir);
|
|
62
|
+
const normalizedResolved = path.normalize(resolved);
|
|
63
|
+
// 检查是否在工作目录内
|
|
64
|
+
if (!normalizedResolved.startsWith(normalizedWorkdir)) {
|
|
65
|
+
throw new Error(`路径越界: ${filePath} 不在工作目录 ${workdir} 内`);
|
|
66
|
+
}
|
|
67
|
+
return resolved;
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* 验证 bash 命令安全性
|
|
71
|
+
*/
|
|
72
|
+
export function validateBashCommand(command) {
|
|
73
|
+
// 检查危险模式
|
|
74
|
+
for (const pattern of DANGEROUS_PATTERNS) {
|
|
75
|
+
if (pattern.test(command)) {
|
|
76
|
+
throw new Error(`危险命令被阻止: ${command}`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* 验证只读命令(用于 explore 代理)
|
|
82
|
+
*/
|
|
83
|
+
export function validateReadOnlyCommand(command) {
|
|
84
|
+
// 提取命令的第一个词
|
|
85
|
+
const firstWord = command.trim().split(/\s+/)[0];
|
|
86
|
+
// 检查是否在白名单中
|
|
87
|
+
const isAllowed = READ_ONLY_COMMANDS.some((allowed) => {
|
|
88
|
+
if (allowed.includes(' ')) {
|
|
89
|
+
// 多词命令(如 git log)
|
|
90
|
+
return command.trim().startsWith(allowed);
|
|
91
|
+
}
|
|
92
|
+
return firstWord === allowed;
|
|
93
|
+
});
|
|
94
|
+
if (!isAllowed) {
|
|
95
|
+
throw new Error(`只读模式下不允许执行: ${command}`);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* 截断过长的输出
|
|
100
|
+
*/
|
|
101
|
+
export function truncateOutput(output, maxLength) {
|
|
102
|
+
if (output.length <= maxLength) {
|
|
103
|
+
return output;
|
|
104
|
+
}
|
|
105
|
+
const truncated = output.slice(0, maxLength);
|
|
106
|
+
const remaining = output.length - maxLength;
|
|
107
|
+
return `${truncated}\n\n... (输出已截断,省略 ${remaining} 字符)`;
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* 检查文件扩展名是否安全
|
|
111
|
+
*/
|
|
112
|
+
export function isSafeFileExtension(filePath) {
|
|
113
|
+
const dangerousExtensions = ['.exe', '.dll', '.so', '.dylib', '.sh', '.bat', '.cmd', '.ps1'];
|
|
114
|
+
const ext = path.extname(filePath).toLowerCase();
|
|
115
|
+
return !dangerousExtensions.includes(ext);
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* 清理用户输入
|
|
119
|
+
*/
|
|
120
|
+
export function sanitizeInput(input) {
|
|
121
|
+
// 移除控制字符
|
|
122
|
+
return input.replace(/[\x00-\x1F\x7F]/g, '');
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=security.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"security.js","sourceRoot":"","sources":["../../../src/services/system/security.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tools/agent/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/agent/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 规划模式工具
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* 进入规划模式
|
|
6
|
+
*/
|
|
7
|
+
export declare function runEnterPlanMode(taskDescription: string, workdir: string): Promise<string>;
|
|
8
|
+
/**
|
|
9
|
+
* 退出规划模式
|
|
10
|
+
*/
|
|
11
|
+
export declare function runExitPlanMode(workdir: string): Promise<string>;
|
|
12
|
+
//# sourceMappingURL=planMode.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"planMode.d.ts","sourceRoot":"","sources":["../../../src/tools/agent/planMode.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH;;GAEG;AACH,wBAAsB,gBAAgB,CACpC,eAAe,EAAE,MAAM,EACvB,OAAO,EAAE,MAAM,GACd,OAAO,CAAC,MAAM,CAAC,CAGjB;AAED;;GAEG;AACH,wBAAsB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAStE"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 规划模式工具
|
|
3
|
+
*/
|
|
4
|
+
import { getPlanModeManager } from '../../core/planMode.js';
|
|
5
|
+
/**
|
|
6
|
+
* 进入规划模式
|
|
7
|
+
*/
|
|
8
|
+
export async function runEnterPlanMode(taskDescription, workdir) {
|
|
9
|
+
const manager = getPlanModeManager(workdir);
|
|
10
|
+
return manager.enterPlanMode(taskDescription);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* 退出规划模式
|
|
14
|
+
*/
|
|
15
|
+
export async function runExitPlanMode(workdir) {
|
|
16
|
+
const manager = getPlanModeManager(workdir);
|
|
17
|
+
const result = manager.exitPlanMode();
|
|
18
|
+
if (!result.success) {
|
|
19
|
+
return result.error || '退出规划模式失败';
|
|
20
|
+
}
|
|
21
|
+
return result.plan;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=planMode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"planMode.js","sourceRoot":"","sources":["../../../src/tools/agent/planMode.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAE5D;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,eAAuB,EACvB,OAAe;IAEf,MAAM,OAAO,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC5C,OAAO,OAAO,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC;AAChD,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAAe;IACnD,MAAM,OAAO,GAAG,kBAAkB,CAAC,OAAO,CAAC,CAAC;IAC5C,MAAM,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAEtC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;QACpB,OAAO,MAAM,CAAC,KAAK,IAAI,UAAU,CAAC;IACpC,CAAC;IAED,OAAO,MAAM,CAAC,IAAI,CAAC;AACrB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 子代理任务执行器
|
|
3
|
+
*/
|
|
4
|
+
import type { AgentType, ToolDefinition, ExecuteToolFunc } from '../../core/types.js';
|
|
5
|
+
import type { ProtocolAdapter } from '../../services/ai/adapters/base.js';
|
|
6
|
+
/**
|
|
7
|
+
* 执行子代理任务
|
|
8
|
+
*/
|
|
9
|
+
export declare function runTask(description: string, prompt: string, agentType: AgentType, workdir: string, adapter: ProtocolAdapter, _systemPrompt: string, _tools: ToolDefinition[], _executeTool: ExecuteToolFunc): Promise<string>;
|
|
10
|
+
//# sourceMappingURL=task.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task.d.ts","sourceRoot":"","sources":["../../../src/tools/agent/task.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAW,cAAc,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAC/F,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AAyE1E;;GAEG;AACH,wBAAsB,OAAO,CAC3B,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,eAAe,EACxB,aAAa,EAAE,MAAM,EACrB,MAAM,EAAE,cAAc,EAAE,EACxB,YAAY,EAAE,eAAe,GAC5B,OAAO,CAAC,MAAM,CAAC,CAsFjB"}
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 子代理任务执行器
|
|
3
|
+
*/
|
|
4
|
+
import { agentLoop } from '../../core/loop.js';
|
|
5
|
+
import { getToolsForAgentType } from '../definitions.js';
|
|
6
|
+
import { createSubagentSystemPrompt } from '../../core/prompts.js';
|
|
7
|
+
import { getTheme } from '../../ui/theme.js';
|
|
8
|
+
/**
|
|
9
|
+
* 子代理进度显示
|
|
10
|
+
*/
|
|
11
|
+
class SubagentProgress {
|
|
12
|
+
description;
|
|
13
|
+
agentType;
|
|
14
|
+
toolCount = 0;
|
|
15
|
+
startTime;
|
|
16
|
+
theme = getTheme();
|
|
17
|
+
constructor(description, agentType) {
|
|
18
|
+
this.description = description;
|
|
19
|
+
this.agentType = agentType;
|
|
20
|
+
this.startTime = Date.now();
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* 开始显示
|
|
24
|
+
*/
|
|
25
|
+
start() {
|
|
26
|
+
process.stdout.write(this.theme.textDim(` [${this.agentType}] ${this.description}`));
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* 更新进度(同一行覆盖)
|
|
30
|
+
*/
|
|
31
|
+
update(toolName, count, elapsed) {
|
|
32
|
+
this.toolCount = count;
|
|
33
|
+
// 清除当前行并重写
|
|
34
|
+
process.stdout.write('\r\x1b[K');
|
|
35
|
+
process.stdout.write(this.theme.textDim(` [${this.agentType}] ${this.description} ... ${toolName} (+${count} tools, ${elapsed.toFixed(1)}s)`));
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* 完成显示
|
|
39
|
+
*/
|
|
40
|
+
complete() {
|
|
41
|
+
const elapsed = (Date.now() - this.startTime) / 1000;
|
|
42
|
+
process.stdout.write('\r\x1b[K');
|
|
43
|
+
console.log(this.theme.success(` [${this.agentType}] ${this.description} - done (${this.toolCount} tools, ${elapsed.toFixed(1)}s)`));
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* 错误显示
|
|
47
|
+
*/
|
|
48
|
+
error(message) {
|
|
49
|
+
process.stdout.write('\r\x1b[K');
|
|
50
|
+
console.log(this.theme.error(` [${this.agentType}] ${this.description} - error: ${message}`));
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* 执行子代理任务
|
|
55
|
+
*/
|
|
56
|
+
export async function runTask(description, prompt, agentType, workdir, adapter, _systemPrompt, _tools, _executeTool) {
|
|
57
|
+
const progress = new SubagentProgress(description, agentType);
|
|
58
|
+
try {
|
|
59
|
+
progress.start();
|
|
60
|
+
// 1. 根据 agentType 过滤工具
|
|
61
|
+
const subagentTools = getToolsForAgentType(agentType);
|
|
62
|
+
// 2. 创建子代理的系统提示词
|
|
63
|
+
const subagentSystem = createSubagentSystemPrompt(workdir, agentType, description);
|
|
64
|
+
// 3. 创建隔离的消息历史
|
|
65
|
+
const subagentHistory = [
|
|
66
|
+
{
|
|
67
|
+
role: 'user',
|
|
68
|
+
content: prompt,
|
|
69
|
+
},
|
|
70
|
+
];
|
|
71
|
+
// 4. 调用代理循环(静默模式 + 进度回调)
|
|
72
|
+
const resultHistory = await agentLoop(subagentHistory, subagentSystem, subagentTools, adapter,
|
|
73
|
+
// 创建子代理专用的 executeTool,传入 agentType 进行安全检查
|
|
74
|
+
(toolName, input) => {
|
|
75
|
+
// 为子代理创建带有 agentType 的执行函数
|
|
76
|
+
const { createExecuteTool } = require('../dispatcher.js');
|
|
77
|
+
const { getSkillLoader } = require('./skill.js');
|
|
78
|
+
const subExecutor = createExecuteTool({
|
|
79
|
+
workdir,
|
|
80
|
+
skillLoader: getSkillLoader(workdir + '/skills'),
|
|
81
|
+
adapter,
|
|
82
|
+
systemPrompt: _systemPrompt,
|
|
83
|
+
tools: _tools,
|
|
84
|
+
agentType, // 传入当前子代理类型
|
|
85
|
+
});
|
|
86
|
+
return subExecutor(toolName, input);
|
|
87
|
+
}, {
|
|
88
|
+
maxTokens: 4096,
|
|
89
|
+
maxTurns: 10, // 子代理最多 10 轮
|
|
90
|
+
silent: true, // 静默模式,不打印工具调用
|
|
91
|
+
onToolCall: (name, count, elapsed) => {
|
|
92
|
+
progress.update(name, count, elapsed);
|
|
93
|
+
},
|
|
94
|
+
});
|
|
95
|
+
// 5. 完成进度显示
|
|
96
|
+
progress.complete();
|
|
97
|
+
// 6. 提取最后一条助手消息作为总结
|
|
98
|
+
const lastAssistantMsg = resultHistory
|
|
99
|
+
.slice()
|
|
100
|
+
.reverse()
|
|
101
|
+
.find((msg) => msg.role === 'assistant');
|
|
102
|
+
if (!lastAssistantMsg) {
|
|
103
|
+
return `子代理任务完成: ${description}\n(无输出)`;
|
|
104
|
+
}
|
|
105
|
+
// 提取文本内容
|
|
106
|
+
let summary = '';
|
|
107
|
+
if (typeof lastAssistantMsg.content === 'string') {
|
|
108
|
+
summary = lastAssistantMsg.content;
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
const textBlocks = lastAssistantMsg.content.filter((block) => block.type === 'text');
|
|
112
|
+
summary = textBlocks.map((block) => ('text' in block ? block.text : '')).join('\n\n');
|
|
113
|
+
}
|
|
114
|
+
return `子代理任务结果 (${description}, ${agentType}):
|
|
115
|
+
|
|
116
|
+
${summary}
|
|
117
|
+
|
|
118
|
+
---
|
|
119
|
+
子代理执行完成`;
|
|
120
|
+
}
|
|
121
|
+
catch (error) {
|
|
122
|
+
const errorMsg = error instanceof Error ? error.message : String(error);
|
|
123
|
+
progress.error(errorMsg);
|
|
124
|
+
return `错误: 子代理执行失败: ${errorMsg}`;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
//# sourceMappingURL=task.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"task.js","sourceRoot":"","sources":["../../../src/tools/agent/task.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,EAAE,0BAA0B,EAAE,MAAM,uBAAuB,CAAC;AACnE,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AAE7C;;GAEG;AACH,MAAM,gBAAgB;IACZ,WAAW,CAAS;IACpB,SAAS,CAAY;IACrB,SAAS,GAAG,CAAC,CAAC;IACd,SAAS,CAAS;IAClB,KAAK,GAAG,QAAQ,EAAE,CAAC;IAE3B,YAAY,WAAmB,EAAE,SAAoB;QACnD,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,KAAK;QACH,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC,CAChE,CAAC;IACJ,CAAC;IAGD;;OAEG;IACH,MAAM,CAAC,QAAgB,EAAE,KAAa,EAAE,OAAe;QACrD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QAEvB,WAAW;QACX,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACjC,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,IAAI,CAAC,KAAK,CAAC,OAAO,CAChB,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,WAAW,QAAQ,QAAQ,MAAM,KAAK,WAAW,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CACtG,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,QAAQ;QACN,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;QACrD,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACjC,OAAO,CAAC,GAAG,CACT,IAAI,CAAC,KAAK,CAAC,OAAO,CAChB,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,WAAW,YAAY,IAAI,CAAC,SAAS,WAAW,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CACrG,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAe;QACnB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QACjC,OAAO,CAAC,GAAG,CACT,IAAI,CAAC,KAAK,CAAC,KAAK,CACd,MAAM,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,WAAW,aAAa,OAAO,EAAE,CAChE,CACF,CAAC;IACJ,CAAC;CACF;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,WAAmB,EACnB,MAAc,EACd,SAAoB,EACpB,OAAe,EACf,OAAwB,EACxB,aAAqB,EACrB,MAAwB,EACxB,YAA6B;IAE7B,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;IAE9D,IAAI,CAAC;QACH,QAAQ,CAAC,KAAK,EAAE,CAAC;QAEjB,uBAAuB;QACvB,MAAM,aAAa,GAAG,oBAAoB,CAAC,SAAS,CAAC,CAAC;QAEtD,iBAAiB;QACjB,MAAM,cAAc,GAAG,0BAA0B,CAAC,OAAO,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QAEnF,eAAe;QACf,MAAM,eAAe,GAAc;YACjC;gBACE,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,MAAM;aAChB;SACF,CAAC;QAEF,yBAAyB;QACzB,MAAM,aAAa,GAAG,MAAM,SAAS,CACnC,eAAe,EACf,cAAc,EACd,aAAa,EACb,OAAO;QACP,2CAA2C;QAC3C,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE;YAClB,2BAA2B;YAC3B,MAAM,EAAE,iBAAiB,EAAE,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAAC;YAC1D,MAAM,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;YAEjD,MAAM,WAAW,GAAG,iBAAiB,CAAC;gBACpC,OAAO;gBACP,WAAW,EAAE,cAAc,CAAC,OAAO,GAAG,SAAS,CAAC;gBAChD,OAAO;gBACP,YAAY,EAAE,aAAa;gBAC3B,KAAK,EAAE,MAAM;gBACb,SAAS,EAAE,YAAY;aACxB,CAAC,CAAC;YAEH,OAAO,WAAW,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QACtC,CAAC,EACD;YACE,SAAS,EAAE,IAAI;YACf,QAAQ,EAAE,EAAE,EAAE,aAAa;YAC3B,MAAM,EAAE,IAAI,EAAE,eAAe;YAC7B,UAAU,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;gBACnC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;YACxC,CAAC;SACF,CACF,CAAC;QAEF,YAAY;QACZ,QAAQ,CAAC,QAAQ,EAAE,CAAC;QAEpB,oBAAoB;QACpB,MAAM,gBAAgB,GAAG,aAAa;aACnC,KAAK,EAAE;aACP,OAAO,EAAE;aACT,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,WAAW,CAAC,CAAC;QAE3C,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACtB,OAAO,YAAY,WAAW,SAAS,CAAC;QAC1C,CAAC;QAED,SAAS;QACT,IAAI,OAAO,GAAG,EAAE,CAAC;QACjB,IAAI,OAAO,gBAAgB,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;YACjD,OAAO,GAAG,gBAAgB,CAAC,OAAO,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,MAAM,UAAU,GAAG,gBAAgB,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;YACrF,OAAO,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACxF,CAAC;QAED,OAAO,YAAY,WAAW,KAAK,SAAS;;EAE9C,OAAO;;;QAGD,CAAC;IACP,CAAC;IAAC,OAAO,KAAc,EAAE,CAAC;QACxB,MAAM,QAAQ,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACxE,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QACzB,OAAO,gBAAgB,QAAQ,EAAE,CAAC;IACpC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/tools/ai/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/ai/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 技能加载工具 - Production-grade
|
|
3
|
+
* 支持多目录加载、完整 frontmatter、AI 自动调用
|
|
4
|
+
*/
|
|
5
|
+
import type { Skill, SkillResult } from '../types.js';
|
|
6
|
+
import { getCustomCommandDirectories } from '../../services/customCommands.js';
|
|
7
|
+
/**
|
|
8
|
+
* 技能加载器配置
|
|
9
|
+
*/
|
|
10
|
+
export interface SkillLoaderConfig {
|
|
11
|
+
skillsDir?: string;
|
|
12
|
+
cwd?: string;
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* 技能加载器 (Production-grade)
|
|
16
|
+
*/
|
|
17
|
+
export declare class SkillLoader {
|
|
18
|
+
private skills;
|
|
19
|
+
private config;
|
|
20
|
+
constructor(configOrSkillsDir: string | SkillLoaderConfig);
|
|
21
|
+
/**
|
|
22
|
+
* 同步加载技能
|
|
23
|
+
*/
|
|
24
|
+
private loadSkillsSync;
|
|
25
|
+
/**
|
|
26
|
+
* 异步重新加载技能
|
|
27
|
+
*/
|
|
28
|
+
reload(): Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* 获取技能
|
|
31
|
+
*/
|
|
32
|
+
getSkill(name: string): Skill | undefined;
|
|
33
|
+
/**
|
|
34
|
+
* 获取所有技能的描述(用于系统提示词 - Layer 1)
|
|
35
|
+
*/
|
|
36
|
+
getDescriptions(): string;
|
|
37
|
+
/**
|
|
38
|
+
* 生成 AI 工具提示词(对标 Kode-cli SkillTool.prompt)
|
|
39
|
+
*/
|
|
40
|
+
getToolPrompt(): Promise<string>;
|
|
41
|
+
/**
|
|
42
|
+
* 获取技能的完整内容(Layer 2 + Layer 3)
|
|
43
|
+
*/
|
|
44
|
+
getSkillContent(name: string): string | null;
|
|
45
|
+
/**
|
|
46
|
+
* 列出所有技能名称
|
|
47
|
+
*/
|
|
48
|
+
listSkills(): string[];
|
|
49
|
+
/**
|
|
50
|
+
* 获取技能数量
|
|
51
|
+
*/
|
|
52
|
+
getCount(): number;
|
|
53
|
+
/**
|
|
54
|
+
* 获取所有加载的技能
|
|
55
|
+
*/
|
|
56
|
+
getAllSkills(): Skill[];
|
|
57
|
+
/**
|
|
58
|
+
* 获取技能目录信息
|
|
59
|
+
*/
|
|
60
|
+
getDirectories(): ReturnType<typeof getCustomCommandDirectories>;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* 获取 SkillLoader 实例
|
|
64
|
+
*/
|
|
65
|
+
export declare function getSkillLoader(configOrSkillsDir: string | SkillLoaderConfig): SkillLoader;
|
|
66
|
+
/**
|
|
67
|
+
* 重置 SkillLoader 实例
|
|
68
|
+
*/
|
|
69
|
+
export declare function resetSkillLoader(): void;
|
|
70
|
+
/**
|
|
71
|
+
* 执行 Skill 工具 (Production-grade)
|
|
72
|
+
*/
|
|
73
|
+
export declare function runSkill(skillLoader: SkillLoader, skillName: string, args?: string): Promise<SkillResult>;
|
|
74
|
+
/**
|
|
75
|
+
* 执行 Skill 工具(向后兼容 - 返回字符串)
|
|
76
|
+
*/
|
|
77
|
+
export declare function runSkillLegacy(skillLoader: SkillLoader, skillName: string): Promise<string>;
|
|
78
|
+
//# sourceMappingURL=skill.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skill.d.ts","sourceRoot":"","sources":["../../../src/tools/ai/skill.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAIH,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AACtD,OAAO,EAIL,2BAA2B,EAC5B,MAAM,kCAAkC,CAAC;AAgC1C;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd;AAED;;GAEG;AACH,qBAAa,WAAW;IACtB,OAAO,CAAC,MAAM,CAAiC;IAC/C,OAAO,CAAC,MAAM,CAAoB;gBAEtB,iBAAiB,EAAE,MAAM,GAAG,iBAAiB;IAWzD;;OAEG;IACH,OAAO,CAAC,cAAc;IAYtB;;OAEG;IACG,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC;IAa7B;;OAEG;IACH,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK,GAAG,SAAS;IAiBzC;;OAEG;IACH,eAAe,IAAI,MAAM;IAczB;;OAEG;IACG,aAAa,IAAI,OAAO,CAAC,MAAM,CAAC;IA4DtC;;OAEG;IACH,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAmC5C;;OAEG;IACH,UAAU,IAAI,MAAM,EAAE;IAItB;;OAEG;IACH,QAAQ,IAAI,MAAM;IAIlB;;OAEG;IACH,YAAY,IAAI,KAAK,EAAE;IAIvB;;OAEG;IACH,cAAc,IAAI,UAAU,CAAC,OAAO,2BAA2B,CAAC;CAGjE;AAQD;;GAEG;AACH,wBAAgB,cAAc,CAAC,iBAAiB,EAAE,MAAM,GAAG,iBAAiB,GAAG,WAAW,CAKzF;AAED;;GAEG;AACH,wBAAgB,gBAAgB,IAAI,IAAI,CAGvC;AAmBD;;GAEG;AACH,wBAAsB,QAAQ,CAC5B,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,MAAM,EACjB,IAAI,CAAC,EAAE,MAAM,GACZ,OAAO,CAAC,WAAW,CAAC,CA2CtB;AAED;;GAEG;AACH,wBAAsB,cAAc,CAClC,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,MAAM,CAAC,CAajB"}
|