@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.
Files changed (393) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +350 -0
  3. package/bin/ai-agent-cli.js +14 -0
  4. package/dist/adapters/anthropic.d.ts +15 -0
  5. package/dist/adapters/anthropic.d.ts.map +1 -0
  6. package/dist/adapters/anthropic.js +83 -0
  7. package/dist/adapters/anthropic.js.map +1 -0
  8. package/dist/adapters/base.d.ts +45 -0
  9. package/dist/adapters/base.d.ts.map +1 -0
  10. package/dist/adapters/base.js +27 -0
  11. package/dist/adapters/base.js.map +1 -0
  12. package/dist/adapters/factory.d.ts +17 -0
  13. package/dist/adapters/factory.d.ts.map +1 -0
  14. package/dist/adapters/factory.js +34 -0
  15. package/dist/adapters/factory.js.map +1 -0
  16. package/dist/adapters/gemini.d.ts +16 -0
  17. package/dist/adapters/gemini.d.ts.map +1 -0
  18. package/dist/adapters/gemini.js +164 -0
  19. package/dist/adapters/gemini.js.map +1 -0
  20. package/dist/adapters/openai.d.ts +15 -0
  21. package/dist/adapters/openai.d.ts.map +1 -0
  22. package/dist/adapters/openai.js +175 -0
  23. package/dist/adapters/openai.js.map +1 -0
  24. package/dist/commands/skillCommands.d.ts +21 -0
  25. package/dist/commands/skillCommands.d.ts.map +1 -0
  26. package/dist/commands/skillCommands.js +320 -0
  27. package/dist/commands/skillCommands.js.map +1 -0
  28. package/dist/config/Config.d.ts +35 -0
  29. package/dist/config/Config.d.ts.map +1 -0
  30. package/dist/config/Config.js +108 -0
  31. package/dist/config/Config.js.map +1 -0
  32. package/dist/config/types.d.ts +48 -0
  33. package/dist/config/types.d.ts.map +1 -0
  34. package/dist/config/types.js +32 -0
  35. package/dist/config/types.js.map +1 -0
  36. package/dist/core/agents.d.ts +32 -0
  37. package/dist/core/agents.d.ts.map +1 -0
  38. package/dist/core/agents.js +93 -0
  39. package/dist/core/agents.js.map +1 -0
  40. package/dist/core/constants.d.ts +97 -0
  41. package/dist/core/constants.d.ts.map +1 -0
  42. package/dist/core/constants.js +119 -0
  43. package/dist/core/constants.js.map +1 -0
  44. package/dist/core/loop.d.ts +33 -0
  45. package/dist/core/loop.d.ts.map +1 -0
  46. package/dist/core/loop.js +134 -0
  47. package/dist/core/loop.js.map +1 -0
  48. package/dist/core/outputStyles.d.ts +50 -0
  49. package/dist/core/outputStyles.d.ts.map +1 -0
  50. package/dist/core/outputStyles.js +165 -0
  51. package/dist/core/outputStyles.js.map +1 -0
  52. package/dist/core/planMode.d.ts +40 -0
  53. package/dist/core/planMode.d.ts.map +1 -0
  54. package/dist/core/planMode.js +143 -0
  55. package/dist/core/planMode.js.map +1 -0
  56. package/dist/core/projectContext.d.ts +68 -0
  57. package/dist/core/projectContext.d.ts.map +1 -0
  58. package/dist/core/projectContext.js +183 -0
  59. package/dist/core/projectContext.js.map +1 -0
  60. package/dist/core/prompts.d.ts +26 -0
  61. package/dist/core/prompts.d.ts.map +1 -0
  62. package/dist/core/prompts.js +267 -0
  63. package/dist/core/prompts.js.map +1 -0
  64. package/dist/core/reminder.d.ts +72 -0
  65. package/dist/core/reminder.d.ts.map +1 -0
  66. package/dist/core/reminder.js +152 -0
  67. package/dist/core/reminder.js.map +1 -0
  68. package/dist/core/theme.d.ts +35 -0
  69. package/dist/core/theme.d.ts.map +1 -0
  70. package/dist/core/theme.js +56 -0
  71. package/dist/core/theme.js.map +1 -0
  72. package/dist/core/types.d.ts +55 -0
  73. package/dist/core/types.d.ts.map +1 -0
  74. package/dist/core/types.js +5 -0
  75. package/dist/core/types.js.map +1 -0
  76. package/dist/core/ui/Banner.d.ts +47 -0
  77. package/dist/core/ui/Banner.d.ts.map +1 -0
  78. package/dist/core/ui/Banner.js +122 -0
  79. package/dist/core/ui/Banner.js.map +1 -0
  80. package/dist/core/ui/Input.d.ts +51 -0
  81. package/dist/core/ui/Input.d.ts.map +1 -0
  82. package/dist/core/ui/Input.js +322 -0
  83. package/dist/core/ui/Input.js.map +1 -0
  84. package/dist/core/ui/Logo.d.ts +21 -0
  85. package/dist/core/ui/Logo.d.ts.map +1 -0
  86. package/dist/core/ui/Logo.js +31 -0
  87. package/dist/core/ui/Logo.js.map +1 -0
  88. package/dist/core/ui/Messages.d.ts +45 -0
  89. package/dist/core/ui/Messages.d.ts.map +1 -0
  90. package/dist/core/ui/Messages.js +76 -0
  91. package/dist/core/ui/Messages.js.map +1 -0
  92. package/dist/core/ui/Spinner.d.ts +29 -0
  93. package/dist/core/ui/Spinner.d.ts.map +1 -0
  94. package/dist/core/ui/Spinner.js +64 -0
  95. package/dist/core/ui/Spinner.js.map +1 -0
  96. package/dist/core/ui/ToolDisplay.d.ts +49 -0
  97. package/dist/core/ui/ToolDisplay.d.ts.map +1 -0
  98. package/dist/core/ui/ToolDisplay.js +99 -0
  99. package/dist/core/ui/ToolDisplay.js.map +1 -0
  100. package/dist/core/ui/index.d.ts +16 -0
  101. package/dist/core/ui/index.d.ts.map +1 -0
  102. package/dist/core/ui/index.js +17 -0
  103. package/dist/core/ui/index.js.map +1 -0
  104. package/dist/core/ui/utils.d.ts +28 -0
  105. package/dist/core/ui/utils.d.ts.map +1 -0
  106. package/dist/core/ui/utils.js +76 -0
  107. package/dist/core/ui/utils.js.map +1 -0
  108. package/dist/entrypoints/cli.d.ts +5 -0
  109. package/dist/entrypoints/cli.d.ts.map +1 -0
  110. package/dist/entrypoints/cli.js +199 -0
  111. package/dist/entrypoints/cli.js.map +1 -0
  112. package/dist/entrypoints/index.d.ts +18 -0
  113. package/dist/entrypoints/index.d.ts.map +1 -0
  114. package/dist/entrypoints/index.js +21 -0
  115. package/dist/entrypoints/index.js.map +1 -0
  116. package/dist/index.d.ts +9 -0
  117. package/dist/index.d.ts.map +1 -0
  118. package/dist/index.js +14 -0
  119. package/dist/index.js.map +1 -0
  120. package/dist/services/ai/adapters/anthropic.d.ts +15 -0
  121. package/dist/services/ai/adapters/anthropic.d.ts.map +1 -0
  122. package/dist/services/ai/adapters/anthropic.js +83 -0
  123. package/dist/services/ai/adapters/anthropic.js.map +1 -0
  124. package/dist/services/ai/adapters/base.d.ts +47 -0
  125. package/dist/services/ai/adapters/base.d.ts.map +1 -0
  126. package/dist/services/ai/adapters/base.js +24 -0
  127. package/dist/services/ai/adapters/base.js.map +1 -0
  128. package/dist/services/ai/adapters/factory.d.ts +17 -0
  129. package/dist/services/ai/adapters/factory.d.ts.map +1 -0
  130. package/dist/services/ai/adapters/factory.js +34 -0
  131. package/dist/services/ai/adapters/factory.js.map +1 -0
  132. package/dist/services/ai/adapters/gemini.d.ts +16 -0
  133. package/dist/services/ai/adapters/gemini.d.ts.map +1 -0
  134. package/dist/services/ai/adapters/gemini.js +164 -0
  135. package/dist/services/ai/adapters/gemini.js.map +1 -0
  136. package/dist/services/ai/adapters/openai.d.ts +15 -0
  137. package/dist/services/ai/adapters/openai.d.ts.map +1 -0
  138. package/dist/services/ai/adapters/openai.js +175 -0
  139. package/dist/services/ai/adapters/openai.js.map +1 -0
  140. package/dist/services/ai/index.d.ts +10 -0
  141. package/dist/services/ai/index.d.ts.map +1 -0
  142. package/dist/services/ai/index.js +11 -0
  143. package/dist/services/ai/index.js.map +1 -0
  144. package/dist/services/config/Config.d.ts +41 -0
  145. package/dist/services/config/Config.d.ts.map +1 -0
  146. package/dist/services/config/Config.js +131 -0
  147. package/dist/services/config/Config.js.map +1 -0
  148. package/dist/services/config/configStore.d.ts +42 -0
  149. package/dist/services/config/configStore.d.ts.map +1 -0
  150. package/dist/services/config/configStore.js +77 -0
  151. package/dist/services/config/configStore.js.map +1 -0
  152. package/dist/services/config/index.d.ts +7 -0
  153. package/dist/services/config/index.d.ts.map +1 -0
  154. package/dist/services/config/index.js +6 -0
  155. package/dist/services/config/index.js.map +1 -0
  156. package/dist/services/config/setup.d.ts +13 -0
  157. package/dist/services/config/setup.d.ts.map +1 -0
  158. package/dist/services/config/setup.js +157 -0
  159. package/dist/services/config/setup.js.map +1 -0
  160. package/dist/services/config/types.d.ts +56 -0
  161. package/dist/services/config/types.d.ts.map +1 -0
  162. package/dist/services/config/types.js +32 -0
  163. package/dist/services/config/types.js.map +1 -0
  164. package/dist/services/customCommands.d.ts +37 -0
  165. package/dist/services/customCommands.d.ts.map +1 -0
  166. package/dist/services/customCommands.js +453 -0
  167. package/dist/services/customCommands.js.map +1 -0
  168. package/dist/services/index.d.ts +7 -0
  169. package/dist/services/index.d.ts.map +1 -0
  170. package/dist/services/index.js +10 -0
  171. package/dist/services/index.js.map +1 -0
  172. package/dist/services/skillMarketplace.d.ts +74 -0
  173. package/dist/services/skillMarketplace.d.ts.map +1 -0
  174. package/dist/services/skillMarketplace.js +486 -0
  175. package/dist/services/skillMarketplace.js.map +1 -0
  176. package/dist/services/system/index.d.ts +6 -0
  177. package/dist/services/system/index.d.ts.map +1 -0
  178. package/dist/services/system/index.js +6 -0
  179. package/dist/services/system/index.js.map +1 -0
  180. package/dist/services/system/security.d.ts +30 -0
  181. package/dist/services/system/security.d.ts.map +1 -0
  182. package/dist/services/system/security.js +124 -0
  183. package/dist/services/system/security.js.map +1 -0
  184. package/dist/tools/agent/index.d.ts +6 -0
  185. package/dist/tools/agent/index.d.ts.map +1 -0
  186. package/dist/tools/agent/index.js +6 -0
  187. package/dist/tools/agent/index.js.map +1 -0
  188. package/dist/tools/agent/planMode.d.ts +12 -0
  189. package/dist/tools/agent/planMode.d.ts.map +1 -0
  190. package/dist/tools/agent/planMode.js +23 -0
  191. package/dist/tools/agent/planMode.js.map +1 -0
  192. package/dist/tools/agent/task.d.ts +10 -0
  193. package/dist/tools/agent/task.d.ts.map +1 -0
  194. package/dist/tools/agent/task.js +127 -0
  195. package/dist/tools/agent/task.js.map +1 -0
  196. package/dist/tools/ai/index.d.ts +5 -0
  197. package/dist/tools/ai/index.d.ts.map +1 -0
  198. package/dist/tools/ai/index.js +5 -0
  199. package/dist/tools/ai/index.js.map +1 -0
  200. package/dist/tools/ai/skill.d.ts +78 -0
  201. package/dist/tools/ai/skill.d.ts.map +1 -0
  202. package/dist/tools/ai/skill.js +315 -0
  203. package/dist/tools/ai/skill.js.map +1 -0
  204. package/dist/tools/askQuestion.d.ts +25 -0
  205. package/dist/tools/askQuestion.d.ts.map +1 -0
  206. package/dist/tools/askQuestion.js +99 -0
  207. package/dist/tools/askQuestion.js.map +1 -0
  208. package/dist/tools/bash.d.ts +11 -0
  209. package/dist/tools/bash.d.ts.map +1 -0
  210. package/dist/tools/bash.js +58 -0
  211. package/dist/tools/bash.js.map +1 -0
  212. package/dist/tools/definitions.d.ts +26 -0
  213. package/dist/tools/definitions.d.ts.map +1 -0
  214. package/dist/tools/definitions.js +599 -0
  215. package/dist/tools/definitions.js.map +1 -0
  216. package/dist/tools/dispatcher.d.ts +38 -0
  217. package/dist/tools/dispatcher.d.ts.map +1 -0
  218. package/dist/tools/dispatcher.js +75 -0
  219. package/dist/tools/dispatcher.js.map +1 -0
  220. package/dist/tools/fileOps.d.ts +16 -0
  221. package/dist/tools/fileOps.d.ts.map +1 -0
  222. package/dist/tools/fileOps.js +115 -0
  223. package/dist/tools/fileOps.js.map +1 -0
  224. package/dist/tools/filesystem/bash.d.ts +11 -0
  225. package/dist/tools/filesystem/bash.d.ts.map +1 -0
  226. package/dist/tools/filesystem/bash.js +58 -0
  227. package/dist/tools/filesystem/bash.js.map +1 -0
  228. package/dist/tools/filesystem/fileOps.d.ts +16 -0
  229. package/dist/tools/filesystem/fileOps.d.ts.map +1 -0
  230. package/dist/tools/filesystem/fileOps.js +115 -0
  231. package/dist/tools/filesystem/fileOps.js.map +1 -0
  232. package/dist/tools/filesystem/index.d.ts +1 -0
  233. package/dist/tools/filesystem/index.d.ts.map +1 -0
  234. package/dist/tools/filesystem/index.js +2 -0
  235. package/dist/tools/filesystem/index.js.map +1 -0
  236. package/dist/tools/glob.d.ts +18 -0
  237. package/dist/tools/glob.d.ts.map +1 -0
  238. package/dist/tools/glob.js +63 -0
  239. package/dist/tools/glob.js.map +1 -0
  240. package/dist/tools/grep.d.ts +26 -0
  241. package/dist/tools/grep.d.ts.map +1 -0
  242. package/dist/tools/grep.js +137 -0
  243. package/dist/tools/grep.js.map +1 -0
  244. package/dist/tools/index.d.ts +13 -0
  245. package/dist/tools/index.d.ts.map +1 -0
  246. package/dist/tools/index.js +14 -0
  247. package/dist/tools/index.js.map +1 -0
  248. package/dist/tools/interaction/askQuestion.d.ts +25 -0
  249. package/dist/tools/interaction/askQuestion.d.ts.map +1 -0
  250. package/dist/tools/interaction/askQuestion.js +99 -0
  251. package/dist/tools/interaction/askQuestion.js.map +1 -0
  252. package/dist/tools/interaction/index.d.ts +6 -0
  253. package/dist/tools/interaction/index.d.ts.map +1 -0
  254. package/dist/tools/interaction/index.js +6 -0
  255. package/dist/tools/interaction/index.js.map +1 -0
  256. package/dist/tools/interaction/todo.d.ts +36 -0
  257. package/dist/tools/interaction/todo.d.ts.map +1 -0
  258. package/dist/tools/interaction/todo.js +137 -0
  259. package/dist/tools/interaction/todo.js.map +1 -0
  260. package/dist/tools/network/index.d.ts +6 -0
  261. package/dist/tools/network/index.d.ts.map +1 -0
  262. package/dist/tools/network/index.js +6 -0
  263. package/dist/tools/network/index.js.map +1 -0
  264. package/dist/tools/network/webFetch.d.ts +8 -0
  265. package/dist/tools/network/webFetch.d.ts.map +1 -0
  266. package/dist/tools/network/webFetch.js +87 -0
  267. package/dist/tools/network/webFetch.js.map +1 -0
  268. package/dist/tools/network/webSearch.d.ts +8 -0
  269. package/dist/tools/network/webSearch.d.ts.map +1 -0
  270. package/dist/tools/network/webSearch.js +84 -0
  271. package/dist/tools/network/webSearch.js.map +1 -0
  272. package/dist/tools/planMode.d.ts +12 -0
  273. package/dist/tools/planMode.d.ts.map +1 -0
  274. package/dist/tools/planMode.js +23 -0
  275. package/dist/tools/planMode.js.map +1 -0
  276. package/dist/tools/search/glob.d.ts +18 -0
  277. package/dist/tools/search/glob.d.ts.map +1 -0
  278. package/dist/tools/search/glob.js +63 -0
  279. package/dist/tools/search/glob.js.map +1 -0
  280. package/dist/tools/search/grep.d.ts +26 -0
  281. package/dist/tools/search/grep.d.ts.map +1 -0
  282. package/dist/tools/search/grep.js +137 -0
  283. package/dist/tools/search/grep.js.map +1 -0
  284. package/dist/tools/search/index.d.ts +6 -0
  285. package/dist/tools/search/index.d.ts.map +1 -0
  286. package/dist/tools/search/index.js +6 -0
  287. package/dist/tools/search/index.js.map +1 -0
  288. package/dist/tools/skill.d.ts +41 -0
  289. package/dist/tools/skill.d.ts.map +1 -0
  290. package/dist/tools/skill.js +149 -0
  291. package/dist/tools/skill.js.map +1 -0
  292. package/dist/tools/system/index.d.ts +6 -0
  293. package/dist/tools/system/index.d.ts.map +1 -0
  294. package/dist/tools/system/index.js +6 -0
  295. package/dist/tools/system/index.js.map +1 -0
  296. package/dist/tools/task.d.ts +10 -0
  297. package/dist/tools/task.d.ts.map +1 -0
  298. package/dist/tools/task.js +127 -0
  299. package/dist/tools/task.js.map +1 -0
  300. package/dist/tools/todo.d.ts +36 -0
  301. package/dist/tools/todo.d.ts.map +1 -0
  302. package/dist/tools/todo.js +137 -0
  303. package/dist/tools/todo.js.map +1 -0
  304. package/dist/tools/types.d.ts +139 -0
  305. package/dist/tools/types.d.ts.map +1 -0
  306. package/dist/tools/types.js +5 -0
  307. package/dist/tools/types.js.map +1 -0
  308. package/dist/tools/webFetch.d.ts +8 -0
  309. package/dist/tools/webFetch.d.ts.map +1 -0
  310. package/dist/tools/webFetch.js +87 -0
  311. package/dist/tools/webFetch.js.map +1 -0
  312. package/dist/tools/webSearch.d.ts +8 -0
  313. package/dist/tools/webSearch.d.ts.map +1 -0
  314. package/dist/tools/webSearch.js +84 -0
  315. package/dist/tools/webSearch.js.map +1 -0
  316. package/dist/ui/Banner.d.ts +47 -0
  317. package/dist/ui/Banner.d.ts.map +1 -0
  318. package/dist/ui/Banner.js +122 -0
  319. package/dist/ui/Banner.js.map +1 -0
  320. package/dist/ui/Input.d.ts +42 -0
  321. package/dist/ui/Input.d.ts.map +1 -0
  322. package/dist/ui/Input.js +270 -0
  323. package/dist/ui/Input.js.map +1 -0
  324. package/dist/ui/Logo.d.ts +21 -0
  325. package/dist/ui/Logo.d.ts.map +1 -0
  326. package/dist/ui/Logo.js +31 -0
  327. package/dist/ui/Logo.js.map +1 -0
  328. package/dist/ui/Messages.d.ts +45 -0
  329. package/dist/ui/Messages.d.ts.map +1 -0
  330. package/dist/ui/Messages.js +76 -0
  331. package/dist/ui/Messages.js.map +1 -0
  332. package/dist/ui/Spinner.d.ts +29 -0
  333. package/dist/ui/Spinner.d.ts.map +1 -0
  334. package/dist/ui/Spinner.js +64 -0
  335. package/dist/ui/Spinner.js.map +1 -0
  336. package/dist/ui/ToolDisplay.d.ts +49 -0
  337. package/dist/ui/ToolDisplay.d.ts.map +1 -0
  338. package/dist/ui/ToolDisplay.js +99 -0
  339. package/dist/ui/ToolDisplay.js.map +1 -0
  340. package/dist/ui/components/Banner.d.ts +46 -0
  341. package/dist/ui/components/Banner.d.ts.map +1 -0
  342. package/dist/ui/components/Banner.js +121 -0
  343. package/dist/ui/components/Banner.js.map +1 -0
  344. package/dist/ui/components/Input.d.ts +51 -0
  345. package/dist/ui/components/Input.d.ts.map +1 -0
  346. package/dist/ui/components/Input.js +322 -0
  347. package/dist/ui/components/Input.js.map +1 -0
  348. package/dist/ui/components/Logo.d.ts +21 -0
  349. package/dist/ui/components/Logo.d.ts.map +1 -0
  350. package/dist/ui/components/Logo.js +31 -0
  351. package/dist/ui/components/Logo.js.map +1 -0
  352. package/dist/ui/components/Messages.d.ts +45 -0
  353. package/dist/ui/components/Messages.d.ts.map +1 -0
  354. package/dist/ui/components/Messages.js +76 -0
  355. package/dist/ui/components/Messages.js.map +1 -0
  356. package/dist/ui/components/Spinner.d.ts +29 -0
  357. package/dist/ui/components/Spinner.d.ts.map +1 -0
  358. package/dist/ui/components/Spinner.js +64 -0
  359. package/dist/ui/components/Spinner.js.map +1 -0
  360. package/dist/ui/components/ToolDisplay.d.ts +49 -0
  361. package/dist/ui/components/ToolDisplay.d.ts.map +1 -0
  362. package/dist/ui/components/ToolDisplay.js +99 -0
  363. package/dist/ui/components/ToolDisplay.js.map +1 -0
  364. package/dist/ui/index.d.ts +16 -0
  365. package/dist/ui/index.d.ts.map +1 -0
  366. package/dist/ui/index.js +17 -0
  367. package/dist/ui/index.js.map +1 -0
  368. package/dist/ui/theme.d.ts +34 -0
  369. package/dist/ui/theme.d.ts.map +1 -0
  370. package/dist/ui/theme.js +55 -0
  371. package/dist/ui/theme.js.map +1 -0
  372. package/dist/ui/utils.d.ts +28 -0
  373. package/dist/ui/utils.d.ts.map +1 -0
  374. package/dist/ui/utils.js +76 -0
  375. package/dist/ui/utils.js.map +1 -0
  376. package/dist/utils/fs/index.d.ts +24 -0
  377. package/dist/utils/fs/index.d.ts.map +1 -0
  378. package/dist/utils/fs/index.js +50 -0
  379. package/dist/utils/fs/index.js.map +1 -0
  380. package/dist/utils/index.d.ts +7 -0
  381. package/dist/utils/index.d.ts.map +1 -0
  382. package/dist/utils/index.js +10 -0
  383. package/dist/utils/index.js.map +1 -0
  384. package/dist/utils/security.d.ts +26 -0
  385. package/dist/utils/security.d.ts.map +1 -0
  386. package/dist/utils/security.js +123 -0
  387. package/dist/utils/security.js.map +1 -0
  388. package/dist/utils/text/index.d.ts +28 -0
  389. package/dist/utils/text/index.d.ts.map +1 -0
  390. package/dist/utils/text/index.js +51 -0
  391. package/dist/utils/text/index.js.map +1 -0
  392. package/package.json +84 -0
  393. 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,6 @@
1
+ /**
2
+ * 代理工具导出
3
+ */
4
+ export { runTask } from './task.js';
5
+ export { runEnterPlanMode, runExitPlanMode } from './planMode.js';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -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,6 @@
1
+ /**
2
+ * 代理工具导出
3
+ */
4
+ export { runTask } from './task.js';
5
+ export { runEnterPlanMode, runExitPlanMode } from './planMode.js';
6
+ //# sourceMappingURL=index.js.map
@@ -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":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * AI 工具导出
3
+ */
4
+ export { SkillLoader, getSkillLoader, runSkill } from './skill.js';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -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,5 @@
1
+ /**
2
+ * AI 工具导出
3
+ */
4
+ export { SkillLoader, getSkillLoader, runSkill } from './skill.js';
5
+ //# sourceMappingURL=index.js.map
@@ -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"}