@xagent-ai/cli 1.0.1

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 (537) hide show
  1. package/.eslintrc.js +25 -0
  2. package/.gitmodules +3 -0
  3. package/.prettierrc.json +8 -0
  4. package/CONTRIBUTING.md +167 -0
  5. package/LICENSE +21 -0
  6. package/README.md +280 -0
  7. package/README_CN.md +280 -0
  8. package/dist/agents.d.ts +21 -0
  9. package/dist/agents.d.ts.map +1 -0
  10. package/dist/agents.js +463 -0
  11. package/dist/agents.js.map +1 -0
  12. package/dist/ai-client.d.ts +83 -0
  13. package/dist/ai-client.d.ts.map +1 -0
  14. package/dist/ai-client.js +1280 -0
  15. package/dist/ai-client.js.map +1 -0
  16. package/dist/auth.d.ts +25 -0
  17. package/dist/auth.d.ts.map +1 -0
  18. package/dist/auth.js +573 -0
  19. package/dist/auth.js.map +1 -0
  20. package/dist/cancellation.d.ts +46 -0
  21. package/dist/cancellation.d.ts.map +1 -0
  22. package/dist/cancellation.js +154 -0
  23. package/dist/cancellation.js.map +1 -0
  24. package/dist/checkpoint.d.ts +28 -0
  25. package/dist/checkpoint.d.ts.map +1 -0
  26. package/dist/checkpoint.js +186 -0
  27. package/dist/checkpoint.js.map +1 -0
  28. package/dist/cli.d.ts +3 -0
  29. package/dist/cli.d.ts.map +1 -0
  30. package/dist/cli.js +364 -0
  31. package/dist/cli.js.map +1 -0
  32. package/dist/config.d.ts +49 -0
  33. package/dist/config.d.ts.map +1 -0
  34. package/dist/config.js +205 -0
  35. package/dist/config.js.map +1 -0
  36. package/dist/context-compressor.d.ts +51 -0
  37. package/dist/context-compressor.d.ts.map +1 -0
  38. package/dist/context-compressor.js +231 -0
  39. package/dist/context-compressor.js.map +1 -0
  40. package/dist/conversation.d.ts +34 -0
  41. package/dist/conversation.d.ts.map +1 -0
  42. package/dist/conversation.js +221 -0
  43. package/dist/conversation.js.map +1 -0
  44. package/dist/gui-subagent/action-parser/actionParser.d.ts +19 -0
  45. package/dist/gui-subagent/action-parser/actionParser.d.ts.map +1 -0
  46. package/dist/gui-subagent/action-parser/actionParser.js +203 -0
  47. package/dist/gui-subagent/action-parser/actionParser.js.map +1 -0
  48. package/dist/gui-subagent/action-parser/constants.d.ts +8 -0
  49. package/dist/gui-subagent/action-parser/constants.d.ts.map +1 -0
  50. package/dist/gui-subagent/action-parser/constants.js +12 -0
  51. package/dist/gui-subagent/action-parser/constants.js.map +1 -0
  52. package/dist/gui-subagent/action-parser/index.d.ts +3 -0
  53. package/dist/gui-subagent/action-parser/index.d.ts.map +1 -0
  54. package/dist/gui-subagent/action-parser/index.js +6 -0
  55. package/dist/gui-subagent/action-parser/index.js.map +1 -0
  56. package/dist/gui-subagent/action-parser/types.d.ts +24 -0
  57. package/dist/gui-subagent/action-parser/types.d.ts.map +1 -0
  58. package/dist/gui-subagent/action-parser/types.js +12 -0
  59. package/dist/gui-subagent/action-parser/types.js.map +1 -0
  60. package/dist/gui-subagent/agent/gui-agent.d.ts +126 -0
  61. package/dist/gui-subagent/agent/gui-agent.d.ts.map +1 -0
  62. package/dist/gui-subagent/agent/gui-agent.js +820 -0
  63. package/dist/gui-subagent/agent/gui-agent.js.map +1 -0
  64. package/dist/gui-subagent/agent/index.d.ts +5 -0
  65. package/dist/gui-subagent/agent/index.d.ts.map +1 -0
  66. package/dist/gui-subagent/agent/index.js +5 -0
  67. package/dist/gui-subagent/agent/index.js.map +1 -0
  68. package/dist/gui-subagent/index.d.ts +43 -0
  69. package/dist/gui-subagent/index.d.ts.map +1 -0
  70. package/dist/gui-subagent/index.js +96 -0
  71. package/dist/gui-subagent/index.js.map +1 -0
  72. package/dist/gui-subagent/operator/base-operator.d.ts +108 -0
  73. package/dist/gui-subagent/operator/base-operator.d.ts.map +1 -0
  74. package/dist/gui-subagent/operator/base-operator.js +172 -0
  75. package/dist/gui-subagent/operator/base-operator.js.map +1 -0
  76. package/dist/gui-subagent/operator/browser-operator.d.ts +36 -0
  77. package/dist/gui-subagent/operator/browser-operator.d.ts.map +1 -0
  78. package/dist/gui-subagent/operator/browser-operator.js +306 -0
  79. package/dist/gui-subagent/operator/browser-operator.js.map +1 -0
  80. package/dist/gui-subagent/operator/computer-operator.d.ts +31 -0
  81. package/dist/gui-subagent/operator/computer-operator.d.ts.map +1 -0
  82. package/dist/gui-subagent/operator/computer-operator.js +441 -0
  83. package/dist/gui-subagent/operator/computer-operator.js.map +1 -0
  84. package/dist/gui-subagent/operator/desktop-operator.d.ts +55 -0
  85. package/dist/gui-subagent/operator/desktop-operator.d.ts.map +1 -0
  86. package/dist/gui-subagent/operator/desktop-operator.js +527 -0
  87. package/dist/gui-subagent/operator/desktop-operator.js.map +1 -0
  88. package/dist/gui-subagent/operator/index.d.ts +7 -0
  89. package/dist/gui-subagent/operator/index.d.ts.map +1 -0
  90. package/dist/gui-subagent/operator/index.js +6 -0
  91. package/dist/gui-subagent/operator/index.js.map +1 -0
  92. package/dist/gui-subagent/types/actions.d.ts +108 -0
  93. package/dist/gui-subagent/types/actions.d.ts.map +1 -0
  94. package/dist/gui-subagent/types/actions.js +39 -0
  95. package/dist/gui-subagent/types/actions.js.map +1 -0
  96. package/dist/gui-subagent/types/index.d.ts +6 -0
  97. package/dist/gui-subagent/types/index.d.ts.map +1 -0
  98. package/dist/gui-subagent/types/index.js +6 -0
  99. package/dist/gui-subagent/types/index.js.map +1 -0
  100. package/dist/gui-subagent/types/operator.d.ts +95 -0
  101. package/dist/gui-subagent/types/operator.d.ts.map +1 -0
  102. package/dist/gui-subagent/types/operator.js +16 -0
  103. package/dist/gui-subagent/types/operator.js.map +1 -0
  104. package/dist/gui-subagent/utils.d.ts +19 -0
  105. package/dist/gui-subagent/utils.d.ts.map +1 -0
  106. package/dist/gui-subagent/utils.js +42 -0
  107. package/dist/gui-subagent/utils.js.map +1 -0
  108. package/dist/hook.d.ts +73 -0
  109. package/dist/hook.d.ts.map +1 -0
  110. package/dist/hook.js +156 -0
  111. package/dist/hook.js.map +1 -0
  112. package/dist/index.d.ts +19 -0
  113. package/dist/index.d.ts.map +1 -0
  114. package/dist/index.js +19 -0
  115. package/dist/index.js.map +1 -0
  116. package/dist/input-history.d.ts +24 -0
  117. package/dist/input-history.d.ts.map +1 -0
  118. package/dist/input-history.js +94 -0
  119. package/dist/input-history.js.map +1 -0
  120. package/dist/input-processor.d.ts +31 -0
  121. package/dist/input-processor.d.ts.map +1 -0
  122. package/dist/input-processor.js +233 -0
  123. package/dist/input-processor.js.map +1 -0
  124. package/dist/keyboard-manager.d.ts +151 -0
  125. package/dist/keyboard-manager.d.ts.map +1 -0
  126. package/dist/keyboard-manager.js +396 -0
  127. package/dist/keyboard-manager.js.map +1 -0
  128. package/dist/logger.d.ts +75 -0
  129. package/dist/logger.d.ts.map +1 -0
  130. package/dist/logger.js +339 -0
  131. package/dist/logger.js.map +1 -0
  132. package/dist/mcp.d.ts +57 -0
  133. package/dist/mcp.d.ts.map +1 -0
  134. package/dist/mcp.js +483 -0
  135. package/dist/mcp.js.map +1 -0
  136. package/dist/memory.d.ts +25 -0
  137. package/dist/memory.d.ts.map +1 -0
  138. package/dist/memory.js +250 -0
  139. package/dist/memory.js.map +1 -0
  140. package/dist/print-system-prompt.d.ts +2 -0
  141. package/dist/print-system-prompt.d.ts.map +1 -0
  142. package/dist/print-system-prompt.js +40 -0
  143. package/dist/print-system-prompt.js.map +1 -0
  144. package/dist/session-manager.d.ts +41 -0
  145. package/dist/session-manager.d.ts.map +1 -0
  146. package/dist/session-manager.js +234 -0
  147. package/dist/session-manager.js.map +1 -0
  148. package/dist/session.d.ts +77 -0
  149. package/dist/session.d.ts.map +1 -0
  150. package/dist/session.js +1081 -0
  151. package/dist/session.js.map +1 -0
  152. package/dist/skill-invoker.d.ts +177 -0
  153. package/dist/skill-invoker.d.ts.map +1 -0
  154. package/dist/skill-invoker.js +1643 -0
  155. package/dist/skill-invoker.js.map +1 -0
  156. package/dist/skill-loader.d.ts +76 -0
  157. package/dist/skill-loader.d.ts.map +1 -0
  158. package/dist/skill-loader.js +407 -0
  159. package/dist/skill-loader.js.map +1 -0
  160. package/dist/slash-commands.d.ts +60 -0
  161. package/dist/slash-commands.d.ts.map +1 -0
  162. package/dist/slash-commands.js +1021 -0
  163. package/dist/slash-commands.js.map +1 -0
  164. package/dist/smart-approval.d.ts +137 -0
  165. package/dist/smart-approval.d.ts.map +1 -0
  166. package/dist/smart-approval.js +512 -0
  167. package/dist/smart-approval.js.map +1 -0
  168. package/dist/system-prompt-generator.d.ts +35 -0
  169. package/dist/system-prompt-generator.d.ts.map +1 -0
  170. package/dist/system-prompt-generator.js +729 -0
  171. package/dist/system-prompt-generator.js.map +1 -0
  172. package/dist/test-boundary-conditions.d.ts.map +1 -0
  173. package/dist/test-boundary-conditions.js.map +1 -0
  174. package/dist/test-cancellation-fix.d.ts.map +1 -0
  175. package/dist/test-cancellation-fix.js.map +1 -0
  176. package/dist/test-input-history.d.ts.map +1 -0
  177. package/dist/test-input-history.js.map +1 -0
  178. package/dist/test-interaction-flow.d.ts.map +1 -0
  179. package/dist/test-interaction-flow.js.map +1 -0
  180. package/dist/test-quick.d.ts.map +1 -0
  181. package/dist/test-quick.js.map +1 -0
  182. package/dist/test-user-interaction.d.ts.map +1 -0
  183. package/dist/test-user-interaction.js.map +1 -0
  184. package/dist/theme.d.ts +353 -0
  185. package/dist/theme.d.ts.map +1 -0
  186. package/dist/theme.js +383 -0
  187. package/dist/theme.js.map +1 -0
  188. package/dist/tools.d.ts +373 -0
  189. package/dist/tools.d.ts.map +1 -0
  190. package/dist/tools.js +2906 -0
  191. package/dist/tools.js.map +1 -0
  192. package/dist/types.d.ts +180 -0
  193. package/dist/types.d.ts.map +1 -0
  194. package/dist/types.js +23 -0
  195. package/dist/types.js.map +1 -0
  196. package/dist/unified-session.d.ts +42 -0
  197. package/dist/unified-session.d.ts.map +1 -0
  198. package/dist/unified-session.js +271 -0
  199. package/dist/unified-session.js.map +1 -0
  200. package/dist/update.d.ts +30 -0
  201. package/dist/update.d.ts.map +1 -0
  202. package/dist/update.js +211 -0
  203. package/dist/update.js.map +1 -0
  204. package/dist/workflow.d.ts +53 -0
  205. package/dist/workflow.d.ts.map +1 -0
  206. package/dist/workflow.js +405 -0
  207. package/dist/workflow.js.map +1 -0
  208. package/docs/architecture/mcp-integration-guide.md +131 -0
  209. package/docs/architecture/overview.md +93 -0
  210. package/docs/architecture/tool-system-design.md +89 -0
  211. package/docs/cli/commands.md +189 -0
  212. package/docs/smart-mode.md +257 -0
  213. package/docs/third-party-models.md +449 -0
  214. package/package.json +85 -0
  215. package/scripts/init-skills-path.js +58 -0
  216. package/skills/.claude-plugin/marketplace.json +45 -0
  217. package/skills/README.md +94 -0
  218. package/skills/THIRD_PARTY_NOTICES.md +405 -0
  219. package/skills/skills/algorithmic-art/LICENSE.txt +202 -0
  220. package/skills/skills/algorithmic-art/SKILL.md +405 -0
  221. package/skills/skills/algorithmic-art/templates/generator_template.js +223 -0
  222. package/skills/skills/algorithmic-art/templates/viewer.html +599 -0
  223. package/skills/skills/brand-guidelines/LICENSE.txt +202 -0
  224. package/skills/skills/brand-guidelines/SKILL.md +73 -0
  225. package/skills/skills/canvas-design/LICENSE.txt +202 -0
  226. package/skills/skills/canvas-design/SKILL.md +130 -0
  227. package/skills/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  228. package/skills/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  229. package/skills/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  230. package/skills/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
  231. package/skills/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  232. package/skills/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
  233. package/skills/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  234. package/skills/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  235. package/skills/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  236. package/skills/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  237. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  238. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  239. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  240. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  241. package/skills/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
  242. package/skills/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  243. package/skills/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
  244. package/skills/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  245. package/skills/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  246. package/skills/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
  247. package/skills/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  248. package/skills/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
  249. package/skills/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  250. package/skills/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  251. package/skills/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  252. package/skills/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  253. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  254. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  255. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  256. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  257. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  258. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  259. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  260. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  261. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  262. package/skills/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  263. package/skills/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  264. package/skills/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
  265. package/skills/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  266. package/skills/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  267. package/skills/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  268. package/skills/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  269. package/skills/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  270. package/skills/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  271. package/skills/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
  272. package/skills/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  273. package/skills/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  274. package/skills/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  275. package/skills/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  276. package/skills/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  277. package/skills/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
  278. package/skills/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  279. package/skills/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  280. package/skills/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
  281. package/skills/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  282. package/skills/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  283. package/skills/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  284. package/skills/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  285. package/skills/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
  286. package/skills/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  287. package/skills/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  288. package/skills/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
  289. package/skills/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
  290. package/skills/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  291. package/skills/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  292. package/skills/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
  293. package/skills/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  294. package/skills/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
  295. package/skills/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  296. package/skills/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  297. package/skills/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
  298. package/skills/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  299. package/skills/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
  300. package/skills/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  301. package/skills/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  302. package/skills/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  303. package/skills/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  304. package/skills/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
  305. package/skills/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  306. package/skills/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
  307. package/skills/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  308. package/skills/skills/doc-coauthoring/SKILL.md +375 -0
  309. package/skills/skills/docx/LICENSE.txt +30 -0
  310. package/skills/skills/docx/SKILL.md +197 -0
  311. package/skills/skills/docx/docx-js.md +350 -0
  312. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  313. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  314. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  315. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  316. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  317. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  318. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  319. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  320. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  321. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  322. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  323. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  324. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  325. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  326. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  327. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  328. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  329. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  330. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  331. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  332. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  333. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  334. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  335. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  336. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  337. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  338. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  339. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  340. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  341. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  342. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  343. package/skills/skills/docx/ooxml/schemas/mce/mc.xsd +75 -0
  344. package/skills/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  345. package/skills/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  346. package/skills/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  347. package/skills/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  348. package/skills/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  349. package/skills/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  350. package/skills/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  351. package/skills/skills/docx/ooxml/scripts/pack.py +159 -0
  352. package/skills/skills/docx/ooxml/scripts/unpack.py +29 -0
  353. package/skills/skills/docx/ooxml/scripts/validate.py +69 -0
  354. package/skills/skills/docx/ooxml/scripts/validation/__init__.py +15 -0
  355. package/skills/skills/docx/ooxml/scripts/validation/base.py +951 -0
  356. package/skills/skills/docx/ooxml/scripts/validation/docx.py +274 -0
  357. package/skills/skills/docx/ooxml/scripts/validation/pptx.py +315 -0
  358. package/skills/skills/docx/ooxml/scripts/validation/redlining.py +279 -0
  359. package/skills/skills/docx/ooxml.md +610 -0
  360. package/skills/skills/docx/scripts/__init__.py +1 -0
  361. package/skills/skills/docx/scripts/document.py +1276 -0
  362. package/skills/skills/docx/scripts/templates/comments.xml +3 -0
  363. package/skills/skills/docx/scripts/templates/commentsExtended.xml +3 -0
  364. package/skills/skills/docx/scripts/templates/commentsExtensible.xml +3 -0
  365. package/skills/skills/docx/scripts/templates/commentsIds.xml +3 -0
  366. package/skills/skills/docx/scripts/templates/people.xml +3 -0
  367. package/skills/skills/docx/scripts/utilities.py +374 -0
  368. package/skills/skills/frontend-design/LICENSE.txt +177 -0
  369. package/skills/skills/frontend-design/SKILL.md +42 -0
  370. package/skills/skills/internal-comms/LICENSE.txt +202 -0
  371. package/skills/skills/internal-comms/SKILL.md +32 -0
  372. package/skills/skills/internal-comms/examples/3p-updates.md +47 -0
  373. package/skills/skills/internal-comms/examples/company-newsletter.md +65 -0
  374. package/skills/skills/internal-comms/examples/faq-answers.md +30 -0
  375. package/skills/skills/internal-comms/examples/general-comms.md +16 -0
  376. package/skills/skills/mcp-builder/LICENSE.txt +202 -0
  377. package/skills/skills/mcp-builder/SKILL.md +236 -0
  378. package/skills/skills/mcp-builder/reference/evaluation.md +602 -0
  379. package/skills/skills/mcp-builder/reference/mcp_best_practices.md +249 -0
  380. package/skills/skills/mcp-builder/reference/node_mcp_server.md +970 -0
  381. package/skills/skills/mcp-builder/reference/python_mcp_server.md +719 -0
  382. package/skills/skills/mcp-builder/scripts/connections.py +151 -0
  383. package/skills/skills/mcp-builder/scripts/evaluation.py +373 -0
  384. package/skills/skills/mcp-builder/scripts/example_evaluation.xml +22 -0
  385. package/skills/skills/mcp-builder/scripts/requirements.txt +2 -0
  386. package/skills/skills/pdf/LICENSE.txt +30 -0
  387. package/skills/skills/pdf/SKILL.md +294 -0
  388. package/skills/skills/pdf/forms.md +205 -0
  389. package/skills/skills/pdf/reference.md +612 -0
  390. package/skills/skills/pdf/scripts/check_bounding_boxes.py +70 -0
  391. package/skills/skills/pdf/scripts/check_bounding_boxes_test.py +226 -0
  392. package/skills/skills/pdf/scripts/check_fillable_fields.py +12 -0
  393. package/skills/skills/pdf/scripts/convert_pdf_to_images.py +35 -0
  394. package/skills/skills/pdf/scripts/create_validation_image.py +41 -0
  395. package/skills/skills/pdf/scripts/extract_form_field_info.py +152 -0
  396. package/skills/skills/pdf/scripts/fill_fillable_fields.py +114 -0
  397. package/skills/skills/pdf/scripts/fill_pdf_form_with_annotations.py +108 -0
  398. package/skills/skills/pptx/LICENSE.txt +30 -0
  399. package/skills/skills/pptx/SKILL.md +484 -0
  400. package/skills/skills/pptx/html2pptx.md +625 -0
  401. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +1499 -0
  402. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +146 -0
  403. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +1085 -0
  404. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +11 -0
  405. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +3081 -0
  406. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +23 -0
  407. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +185 -0
  408. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +287 -0
  409. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +1676 -0
  410. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +28 -0
  411. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +144 -0
  412. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +174 -0
  413. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +25 -0
  414. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +18 -0
  415. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +59 -0
  416. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +56 -0
  417. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +195 -0
  418. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +582 -0
  419. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +25 -0
  420. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +4439 -0
  421. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +570 -0
  422. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +509 -0
  423. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +12 -0
  424. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +108 -0
  425. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +96 -0
  426. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +3646 -0
  427. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +116 -0
  428. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +42 -0
  429. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +50 -0
  430. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +49 -0
  431. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +33 -0
  432. package/skills/skills/pptx/ooxml/schemas/mce/mc.xsd +75 -0
  433. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +560 -0
  434. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +67 -0
  435. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +14 -0
  436. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +20 -0
  437. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +13 -0
  438. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +4 -0
  439. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +8 -0
  440. package/skills/skills/pptx/ooxml/scripts/pack.py +159 -0
  441. package/skills/skills/pptx/ooxml/scripts/unpack.py +29 -0
  442. package/skills/skills/pptx/ooxml/scripts/validate.py +69 -0
  443. package/skills/skills/pptx/ooxml/scripts/validation/__init__.py +15 -0
  444. package/skills/skills/pptx/ooxml/scripts/validation/base.py +951 -0
  445. package/skills/skills/pptx/ooxml/scripts/validation/docx.py +274 -0
  446. package/skills/skills/pptx/ooxml/scripts/validation/pptx.py +315 -0
  447. package/skills/skills/pptx/ooxml/scripts/validation/redlining.py +279 -0
  448. package/skills/skills/pptx/ooxml.md +427 -0
  449. package/skills/skills/pptx/scripts/html2pptx.js +979 -0
  450. package/skills/skills/pptx/scripts/inventory.py +1020 -0
  451. package/skills/skills/pptx/scripts/rearrange.py +231 -0
  452. package/skills/skills/pptx/scripts/replace.py +385 -0
  453. package/skills/skills/pptx/scripts/thumbnail.py +450 -0
  454. package/skills/skills/skill-creator/LICENSE.txt +202 -0
  455. package/skills/skills/skill-creator/SKILL.md +356 -0
  456. package/skills/skills/skill-creator/references/output-patterns.md +82 -0
  457. package/skills/skills/skill-creator/references/workflows.md +28 -0
  458. package/skills/skills/skill-creator/scripts/init_skill.py +303 -0
  459. package/skills/skills/skill-creator/scripts/package_skill.py +110 -0
  460. package/skills/skills/skill-creator/scripts/quick_validate.py +95 -0
  461. package/skills/skills/slack-gif-creator/LICENSE.txt +202 -0
  462. package/skills/skills/slack-gif-creator/SKILL.md +254 -0
  463. package/skills/skills/slack-gif-creator/core/easing.py +234 -0
  464. package/skills/skills/slack-gif-creator/core/frame_composer.py +176 -0
  465. package/skills/skills/slack-gif-creator/core/gif_builder.py +269 -0
  466. package/skills/skills/slack-gif-creator/core/validators.py +136 -0
  467. package/skills/skills/slack-gif-creator/requirements.txt +4 -0
  468. package/skills/skills/theme-factory/LICENSE.txt +202 -0
  469. package/skills/skills/theme-factory/SKILL.md +59 -0
  470. package/skills/skills/theme-factory/theme-showcase.pdf +0 -0
  471. package/skills/skills/theme-factory/themes/arctic-frost.md +19 -0
  472. package/skills/skills/theme-factory/themes/botanical-garden.md +19 -0
  473. package/skills/skills/theme-factory/themes/desert-rose.md +19 -0
  474. package/skills/skills/theme-factory/themes/forest-canopy.md +19 -0
  475. package/skills/skills/theme-factory/themes/golden-hour.md +19 -0
  476. package/skills/skills/theme-factory/themes/midnight-galaxy.md +19 -0
  477. package/skills/skills/theme-factory/themes/modern-minimalist.md +19 -0
  478. package/skills/skills/theme-factory/themes/ocean-depths.md +19 -0
  479. package/skills/skills/theme-factory/themes/sunset-boulevard.md +19 -0
  480. package/skills/skills/theme-factory/themes/tech-innovation.md +19 -0
  481. package/skills/skills/web-artifacts-builder/LICENSE.txt +202 -0
  482. package/skills/skills/web-artifacts-builder/SKILL.md +74 -0
  483. package/skills/skills/web-artifacts-builder/scripts/bundle-artifact.sh +54 -0
  484. package/skills/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -0
  485. package/skills/skills/webapp-testing/LICENSE.txt +202 -0
  486. package/skills/skills/webapp-testing/SKILL.md +96 -0
  487. package/skills/skills/webapp-testing/examples/console_logging.py +35 -0
  488. package/skills/skills/webapp-testing/examples/element_discovery.py +40 -0
  489. package/skills/skills/webapp-testing/examples/static_html_automation.py +33 -0
  490. package/skills/skills/webapp-testing/scripts/with_server.py +106 -0
  491. package/skills/skills/xlsx/LICENSE.txt +30 -0
  492. package/skills/skills/xlsx/SKILL.md +289 -0
  493. package/skills/skills/xlsx/recalc.py +178 -0
  494. package/skills/spec/agent-skills-spec.md +3 -0
  495. package/skills/template/SKILL.md +6 -0
  496. package/src/agents.ts +504 -0
  497. package/src/ai-client.ts +1456 -0
  498. package/src/auth.ts +648 -0
  499. package/src/cancellation.ts +176 -0
  500. package/src/checkpoint.ts +219 -0
  501. package/src/cli.ts +384 -0
  502. package/src/config.ts +248 -0
  503. package/src/context-compressor.ts +290 -0
  504. package/src/conversation.ts +288 -0
  505. package/src/gui-subagent/action-parser/actionParser.ts +312 -0
  506. package/src/gui-subagent/action-parser/constants.ts +12 -0
  507. package/src/gui-subagent/action-parser/index.ts +6 -0
  508. package/src/gui-subagent/action-parser/types.ts +31 -0
  509. package/src/gui-subagent/agent/gui-agent.ts +982 -0
  510. package/src/gui-subagent/agent/index.ts +5 -0
  511. package/src/gui-subagent/index.ts +139 -0
  512. package/src/gui-subagent/operator/base-operator.ts +246 -0
  513. package/src/gui-subagent/operator/computer-operator.ts +520 -0
  514. package/src/gui-subagent/operator/index.ts +7 -0
  515. package/src/gui-subagent/types/actions.ts +263 -0
  516. package/src/gui-subagent/types/index.ts +6 -0
  517. package/src/gui-subagent/types/operator.ts +106 -0
  518. package/src/gui-subagent/utils.ts +51 -0
  519. package/src/index.ts +18 -0
  520. package/src/input-processor.ts +282 -0
  521. package/src/logger.ts +438 -0
  522. package/src/mcp.ts +563 -0
  523. package/src/memory.ts +303 -0
  524. package/src/session-manager.ts +308 -0
  525. package/src/session.ts +1280 -0
  526. package/src/skill-invoker.ts +1888 -0
  527. package/src/skill-loader.ts +476 -0
  528. package/src/slash-commands.ts +1150 -0
  529. package/src/smart-approval.ts +595 -0
  530. package/src/system-prompt-generator.ts +786 -0
  531. package/src/theme.ts +455 -0
  532. package/src/tools.ts +3398 -0
  533. package/src/types.ts +198 -0
  534. package/src/update.ts +270 -0
  535. package/src/workflow.ts +508 -0
  536. package/tsconfig.json +22 -0
  537. package/vitest.config.ts +19 -0
@@ -0,0 +1,512 @@
1
+ import inquirer from 'inquirer';
2
+ import { AIClient } from './ai-client.js';
3
+ import { getConfigManager } from './config.js';
4
+ import { getLogger } from './logger.js';
5
+ import { colors, icons } from './theme.js';
6
+ const logger = getLogger();
7
+ /**
8
+ * Approval result type
9
+ */
10
+ export var ApprovalDecision;
11
+ (function (ApprovalDecision) {
12
+ ApprovalDecision["APPROVED"] = "approved";
13
+ ApprovalDecision["REJECTED"] = "rejected";
14
+ ApprovalDecision["REQUIRES_CONFIRMATION"] = "requires_confirmation";
15
+ ApprovalDecision["AI_REVIEW"] = "ai_review";
16
+ })(ApprovalDecision || (ApprovalDecision = {}));
17
+ /**
18
+ * Risk level
19
+ */
20
+ export var RiskLevel;
21
+ (function (RiskLevel) {
22
+ RiskLevel["LOW"] = "LOW";
23
+ RiskLevel["MEDIUM"] = "MEDIUM";
24
+ RiskLevel["HIGH"] = "HIGH";
25
+ RiskLevel["CRITICAL"] = "CRITICAL";
26
+ })(RiskLevel || (RiskLevel = {}));
27
+ /**
28
+ * Whitelist checker
29
+ */
30
+ export class WhitelistChecker {
31
+ static WHITELISTED_TOOLS = new Set([
32
+ // Information reading tools
33
+ 'Read',
34
+ 'ListDirectory',
35
+ 'SearchCodebase',
36
+ 'Grep',
37
+ 'image_read',
38
+ // Task management tools
39
+ 'todo_write',
40
+ 'todo_read',
41
+ 'task',
42
+ 'exit_plan_mode',
43
+ 'web_search',
44
+ // File editing tools
45
+ 'replace',
46
+ 'Write',
47
+ // Other safe tools
48
+ 'web_fetch',
49
+ 'ask_user_question',
50
+ 'save_memory',
51
+ 'xml_escape',
52
+ 'Skill'
53
+ ]);
54
+ /**
55
+ * Check if tool is in whitelist
56
+ */
57
+ check(toolName) {
58
+ return WhitelistChecker.WHITELISTED_TOOLS.has(toolName);
59
+ }
60
+ /**
61
+ * Get list of whitelisted tools
62
+ */
63
+ getWhitelistedTools() {
64
+ return Array.from(WhitelistChecker.WHITELISTED_TOOLS);
65
+ }
66
+ }
67
+ /**
68
+ * Blacklist checker
69
+ */
70
+ export class BlacklistChecker {
71
+ static RULES = [
72
+ // System destruction
73
+ {
74
+ pattern: /rm\s+-rf\s+\/$/,
75
+ category: 'System destruction',
76
+ riskLevel: RiskLevel.CRITICAL,
77
+ description: 'Delete root directory'
78
+ },
79
+ {
80
+ pattern: /rm\s+-rf\s+(\/etc|\/usr|\/bin|\/sbin|\/lib|\/lib64)/,
81
+ category: 'System destruction',
82
+ riskLevel: RiskLevel.CRITICAL,
83
+ description: 'Delete system directories'
84
+ },
85
+ {
86
+ pattern: /rm\s+-rf\s+.*\*/,
87
+ category: 'System destruction',
88
+ riskLevel: RiskLevel.HIGH,
89
+ description: 'Batch delete files'
90
+ },
91
+ {
92
+ pattern: /(mkfs|format)\s+/,
93
+ category: 'System destruction',
94
+ riskLevel: RiskLevel.CRITICAL,
95
+ description: 'Format disk'
96
+ },
97
+ {
98
+ pattern: /dd\s+.*of=\/dev\/(sd[a-z]|nvme[0-9]n[0-9])/,
99
+ category: 'System destruction',
100
+ riskLevel: RiskLevel.CRITICAL,
101
+ description: 'Overwrite disk data'
102
+ },
103
+ // Privilege escalation
104
+ {
105
+ pattern: /chmod\s+777\s+/,
106
+ category: 'Privilege escalation',
107
+ riskLevel: RiskLevel.HIGH,
108
+ description: 'Set file permissions to 777'
109
+ },
110
+ {
111
+ pattern: /chmod\s+[45][0-9]{3}\s+/,
112
+ category: 'Privilege escalation',
113
+ riskLevel: RiskLevel.HIGH,
114
+ description: 'Set SUID/SGID permissions'
115
+ },
116
+ {
117
+ pattern: /vi\s+\/etc\/sudoers/,
118
+ category: 'Privilege escalation',
119
+ riskLevel: RiskLevel.CRITICAL,
120
+ description: 'Modify sudo permissions'
121
+ },
122
+ {
123
+ pattern: /echo.*>>.*\/etc\/sudoers/,
124
+ category: 'Privilege escalation',
125
+ riskLevel: RiskLevel.CRITICAL,
126
+ description: 'Modify sudo permissions'
127
+ },
128
+ // Data theft
129
+ {
130
+ pattern: /cat\s+\/etc\/passwd/,
131
+ category: 'Data theft',
132
+ riskLevel: RiskLevel.HIGH,
133
+ description: 'Read password file'
134
+ },
135
+ {
136
+ pattern: /cat\s+\/etc\/shadow/,
137
+ category: 'Data theft',
138
+ riskLevel: RiskLevel.CRITICAL,
139
+ description: 'Read shadow file'
140
+ },
141
+ {
142
+ pattern: /cat\s+.*\/\.ssh\/id_rsa/,
143
+ category: 'Data theft',
144
+ riskLevel: RiskLevel.CRITICAL,
145
+ description: 'Read SSH private key'
146
+ },
147
+ {
148
+ pattern: /grep\s+-[rRi].*password/,
149
+ category: 'Data theft',
150
+ riskLevel: RiskLevel.HIGH,
151
+ description: 'Search for password information'
152
+ },
153
+ {
154
+ pattern: /(curl|wget).*\|(sh|bash|python|perl)/,
155
+ category: 'Data theft',
156
+ riskLevel: RiskLevel.CRITICAL,
157
+ description: 'Remote code execution'
158
+ },
159
+ // Network attacks
160
+ {
161
+ pattern: /nmap\s+-[sS].*/,
162
+ category: 'Network attacks',
163
+ riskLevel: RiskLevel.MEDIUM,
164
+ description: 'Network scanning'
165
+ },
166
+ {
167
+ pattern: /nc\s+.*-l/,
168
+ category: 'Network attacks',
169
+ riskLevel: RiskLevel.HIGH,
170
+ description: 'Create network listener'
171
+ },
172
+ {
173
+ pattern: /iptables\s+-F/,
174
+ category: 'Network attacks',
175
+ riskLevel: RiskLevel.HIGH,
176
+ description: 'Clear firewall rules'
177
+ },
178
+ // Resource exhaustion
179
+ {
180
+ pattern: /:\)\s*{\s*:\s*\|\s*:&\s*};/,
181
+ category: 'Resource exhaustion',
182
+ riskLevel: RiskLevel.CRITICAL,
183
+ description: 'Fork bomb'
184
+ },
185
+ {
186
+ pattern: /while\s+true\s*;\s*do\s+.*done/,
187
+ category: 'Resource exhaustion',
188
+ riskLevel: RiskLevel.HIGH,
189
+ description: 'Infinite loop'
190
+ }
191
+ ];
192
+ /**
193
+ * Check if tool call matches blacklist rules
194
+ */
195
+ check(context) {
196
+ const { toolName, params } = context;
197
+ // For Bash tool, check command content
198
+ if (toolName === 'Bash' && params.command) {
199
+ const command = params.command;
200
+ for (const rule of BlacklistChecker.RULES) {
201
+ if (rule.pattern.test(command)) {
202
+ return { matched: true, rule };
203
+ }
204
+ }
205
+ }
206
+ // For file operation tools, check path
207
+ if (['Write', 'DeleteFile', 'replace'].includes(toolName)) {
208
+ const filePath = params.filePath || params.file_path || '';
209
+ if (this.isSystemPath(filePath)) {
210
+ return {
211
+ matched: true,
212
+ rule: {
213
+ pattern: /system-path/,
214
+ category: 'System destruction',
215
+ riskLevel: RiskLevel.HIGH,
216
+ description: 'Modify system files'
217
+ }
218
+ };
219
+ }
220
+ }
221
+ return { matched: false };
222
+ }
223
+ /**
224
+ * Check if it's a system path
225
+ */
226
+ isSystemPath(filePath) {
227
+ const systemPaths = [
228
+ '/etc',
229
+ '/usr',
230
+ '/bin',
231
+ '/sbin',
232
+ '/lib',
233
+ '/lib64',
234
+ '/boot',
235
+ '/sys',
236
+ '/proc',
237
+ '/dev'
238
+ ];
239
+ const normalizedPath = filePath.toLowerCase().replace(/\\/g, '/');
240
+ return systemPaths.some(sysPath => normalizedPath.startsWith(sysPath));
241
+ }
242
+ /**
243
+ * Get all blacklist rules
244
+ */
245
+ getRules() {
246
+ return [...BlacklistChecker.RULES];
247
+ }
248
+ }
249
+ /**
250
+ * AI approval checker
251
+ */
252
+ export class AIApprovalChecker {
253
+ aiClient = null;
254
+ constructor() {
255
+ this.initializeAIClient();
256
+ }
257
+ /**
258
+ * Initialize AI client
259
+ */
260
+ async initializeAIClient() {
261
+ try {
262
+ const configManager = getConfigManager();
263
+ const authConfig = configManager.getAuthConfig();
264
+ if (authConfig.apiKey) {
265
+ this.aiClient = new AIClient(authConfig);
266
+ }
267
+ }
268
+ catch (error) {
269
+ logger.error('Failed to initialize AI approval checker', error instanceof Error ? error.message : String(error));
270
+ }
271
+ }
272
+ /**
273
+ * Use AI for intelligent review
274
+ */
275
+ async check(context) {
276
+ if (!this.aiClient) {
277
+ // If AI client is not initialized, default to medium risk, requires user confirmation
278
+ return {
279
+ approved: false,
280
+ analysis: 'AI review not available, requires manual user confirmation',
281
+ riskLevel: RiskLevel.MEDIUM
282
+ };
283
+ }
284
+ const prompt = this.buildApprovalPrompt(context);
285
+ try {
286
+ const messages = [
287
+ {
288
+ role: 'system',
289
+ content: `You are a security review expert. Your task is to evaluate the security of tool calls.
290
+
291
+ Please analyze from the following dimensions:
292
+ 1. Whether the operation has malicious intent
293
+ 2. Whether it may cause data leakage
294
+ 3. Whether it may compromise system integrity
295
+ 4. Whether it follows best practices
296
+
297
+ Please return results in JSON format:
298
+ {
299
+ "approved": boolean,
300
+ "riskLevel": "LOW" | "MEDIUM" | "HIGH" | "CRITICAL",
301
+ "analysis": "Detailed analysis description"
302
+ }`
303
+ },
304
+ {
305
+ role: 'user',
306
+ content: prompt
307
+ }
308
+ ];
309
+ const response = await this.aiClient.chatCompletion(messages, {
310
+ temperature: 0.3,
311
+ // maxTokens: 500
312
+ });
313
+ const content = typeof response.choices[0].message.content === 'string'
314
+ ? response.choices[0].message.content
315
+ : '{}';
316
+ // Parse AI response
317
+ const jsonMatch = content.match(/\{[\s\S]*\}/);
318
+ if (jsonMatch) {
319
+ const result = JSON.parse(jsonMatch[0]);
320
+ return {
321
+ approved: result.approved || false,
322
+ analysis: result.analysis || 'No detailed analysis',
323
+ riskLevel: result.riskLevel || RiskLevel.MEDIUM
324
+ };
325
+ }
326
+ // If unable to parse, return medium risk
327
+ return {
328
+ approved: false,
329
+ analysis: 'Unable to parse AI response, requires manual confirmation',
330
+ riskLevel: RiskLevel.MEDIUM
331
+ };
332
+ }
333
+ catch (error) {
334
+ logger.error('AI approval check failed', error instanceof Error ? error.message : String(error));
335
+ return {
336
+ approved: false,
337
+ analysis: `AI review failed: ${error.message}, requires manual confirmation`,
338
+ riskLevel: RiskLevel.MEDIUM
339
+ };
340
+ }
341
+ }
342
+ /**
343
+ * Build review prompt
344
+ */
345
+ buildApprovalPrompt(context) {
346
+ const { toolName, params } = context;
347
+ let prompt = `Tool name: ${toolName}\n`;
348
+ prompt += `Parameters: ${JSON.stringify(params, null, 2)}\n\n`;
349
+ // Add specific analysis guidance based on tool type
350
+ if (toolName === 'Bash') {
351
+ prompt += `This is a Shell command execution request. Please check if the command contains:\n- Dangerous system operations (such as deletion, formatting)\n- Privilege escalation operations\n- Data theft operations\n- Remote code execution\n- Resource exhaustion attacks`;
352
+ }
353
+ else if (['Write', 'replace', 'DeleteFile'].includes(toolName)) {
354
+ prompt += `This is a file operation request. Please check:\n- Whether the target path is a system path\n- Whether the operation may damage system files\n- Whether it involves sensitive configuration files`;
355
+ }
356
+ else if (toolName === 'web_fetch' || toolName === 'web_search') {
357
+ prompt += `This is a network request. Please check:\n- Whether the URL is a malicious website\n- Whether it may leak sensitive information\n- Whether it may execute remote code`;
358
+ }
359
+ return prompt;
360
+ }
361
+ }
362
+ /**
363
+ * Smart approval engine
364
+ */
365
+ export class SmartApprovalEngine {
366
+ whitelistChecker;
367
+ blacklistChecker;
368
+ aiChecker;
369
+ debugMode;
370
+ constructor(debugMode = false) {
371
+ this.whitelistChecker = new WhitelistChecker();
372
+ this.blacklistChecker = new BlacklistChecker();
373
+ this.aiChecker = new AIApprovalChecker();
374
+ this.debugMode = debugMode;
375
+ }
376
+ /**
377
+ * Evaluate tool call
378
+ */
379
+ async evaluate(context) {
380
+ const startTime = Date.now();
381
+ if (this.debugMode) {
382
+ logger.debug(`[SmartApprovalEngine] Evaluating tool call: ${context.toolName}`);
383
+ }
384
+ // First layer: Whitelist check
385
+ const whitelistCheck = this.whitelistChecker.check(context.toolName);
386
+ if (whitelistCheck) {
387
+ const latency = Date.now() - startTime;
388
+ if (this.debugMode) {
389
+ logger.debug(`[WhitelistChecker] Tool '${context.toolName}' in whitelist, latency: ${latency}ms`);
390
+ }
391
+ return {
392
+ decision: ApprovalDecision.APPROVED,
393
+ riskLevel: RiskLevel.LOW,
394
+ detectionMethod: 'whitelist',
395
+ description: `Tool '${context.toolName}' is in the whitelist, executing directly`,
396
+ latency
397
+ };
398
+ }
399
+ if (this.debugMode) {
400
+ logger.debug(`[WhitelistChecker] Tool '${context.toolName}' not in whitelist`);
401
+ }
402
+ // Second layer: Blacklist check
403
+ const blacklistCheck = this.blacklistChecker.check(context);
404
+ if (blacklistCheck.matched && blacklistCheck.rule) {
405
+ const latency = Date.now() - startTime;
406
+ if (this.debugMode) {
407
+ logger.debug(`[BlacklistChecker] Matched rule: ${blacklistCheck.rule.description}, Risk: ${blacklistCheck.rule.riskLevel}, latency: ${latency}ms`);
408
+ }
409
+ return {
410
+ decision: ApprovalDecision.REQUIRES_CONFIRMATION,
411
+ riskLevel: blacklistCheck.rule.riskLevel,
412
+ detectionMethod: 'blacklist',
413
+ description: `Detected potentially risky operation: ${blacklistCheck.rule.description}`,
414
+ latency
415
+ };
416
+ }
417
+ if (this.debugMode) {
418
+ logger.debug(`[BlacklistChecker] No blacklist rule matched`);
419
+ }
420
+ // Third layer: AI intelligent review
421
+ const aiCheck = await this.aiChecker.check(context);
422
+ const latency = Date.now() - startTime;
423
+ if (this.debugMode) {
424
+ logger.debug(`[AIApprovalChecker] AI review result: approved=${aiCheck.approved}, risk=${aiCheck.riskLevel}, latency: ${latency}ms`);
425
+ }
426
+ return {
427
+ decision: aiCheck.approved ? ApprovalDecision.APPROVED : ApprovalDecision.REQUIRES_CONFIRMATION,
428
+ riskLevel: aiCheck.riskLevel,
429
+ detectionMethod: 'ai_review',
430
+ description: aiCheck.analysis,
431
+ latency,
432
+ aiAnalysis: aiCheck.analysis
433
+ };
434
+ }
435
+ /**
436
+ * Request user confirmation
437
+ */
438
+ async requestConfirmation(result) {
439
+ const separator = icons.separator.repeat(40);
440
+ console.log('');
441
+ console.log(colors.warning(`${icons.warning} [Smart Mode] Detected potentially risky operation`));
442
+ console.log(colors.border(separator));
443
+ console.log('');
444
+ console.log(colors.textMuted(`📊 Risk Level: ${this.getRiskLevelDisplay(result.riskLevel)}`));
445
+ console.log(colors.textMuted(`🔍 Detection Method: ${this.getDetectionMethodDisplay(result.detectionMethod)}`));
446
+ console.log('');
447
+ if (result.aiAnalysis) {
448
+ console.log(colors.textMuted(`🤖 AI Analysis:`));
449
+ console.log(colors.textDim(` ${result.aiAnalysis}`));
450
+ console.log('');
451
+ }
452
+ console.log(colors.textMuted(`⚠️ Risk Description: ${result.description}`));
453
+ console.log('');
454
+ console.log(colors.warning('Potentially risky operation detected, continue execution?'));
455
+ try {
456
+ const { confirmed } = await inquirer.prompt([
457
+ {
458
+ type: 'confirm',
459
+ name: 'confirmed',
460
+ message: 'Continue execution?',
461
+ default: false
462
+ }
463
+ ]);
464
+ return confirmed;
465
+ }
466
+ catch (error) {
467
+ logger.error('Failed to get user confirmation', error instanceof Error ? error.message : String(error));
468
+ return false;
469
+ }
470
+ }
471
+ /**
472
+ * Get risk level display
473
+ */
474
+ getRiskLevelDisplay(riskLevel) {
475
+ const displays = {
476
+ [RiskLevel.LOW]: colors.success('LOW'),
477
+ [RiskLevel.MEDIUM]: colors.warning('MEDIUM'),
478
+ [RiskLevel.HIGH]: colors.error('HIGH'),
479
+ [RiskLevel.CRITICAL]: colors.error('CRITICAL')
480
+ };
481
+ return displays[riskLevel];
482
+ }
483
+ /**
484
+ * Get detection method display
485
+ */
486
+ getDetectionMethodDisplay(method) {
487
+ const displays = {
488
+ whitelist: 'Whitelist rules',
489
+ blacklist: 'Blacklist rules',
490
+ ai_review: 'AI intelligent review',
491
+ manual: 'Manual review'
492
+ };
493
+ return displays[method] || method;
494
+ }
495
+ /**
496
+ * Set debug mode
497
+ */
498
+ setDebugMode(enabled) {
499
+ this.debugMode = enabled;
500
+ }
501
+ }
502
+ /**
503
+ * Get smart approval engine instance
504
+ */
505
+ let smartApprovalEngineInstance = null;
506
+ export function getSmartApprovalEngine(debugMode = false) {
507
+ if (!smartApprovalEngineInstance) {
508
+ smartApprovalEngineInstance = new SmartApprovalEngine(debugMode);
509
+ }
510
+ return smartApprovalEngineInstance;
511
+ }
512
+ //# sourceMappingURL=smart-approval.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"smart-approval.js","sourceRoot":"","sources":["../src/smart-approval.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ import { ToolRegistry } from './tools.js';
2
+ import { ExecutionMode, AgentConfig } from './types.js';
3
+ export interface ToolParameter {
4
+ type: string;
5
+ description: string;
6
+ required?: boolean;
7
+ enum?: string[];
8
+ default?: any;
9
+ }
10
+ export interface ToolSchema {
11
+ name: string;
12
+ description: string;
13
+ parameters: Record<string, ToolParameter>;
14
+ usage: string;
15
+ examples: string[];
16
+ bestPractices: string[];
17
+ }
18
+ export declare class SystemPromptGenerator {
19
+ private toolRegistry;
20
+ private executionMode;
21
+ private agentConfig?;
22
+ constructor(toolRegistry: ToolRegistry, executionMode: ExecutionMode, agentConfig?: AgentConfig);
23
+ generateEnhancedSystemPrompt(baseSystemPrompt: string): Promise<string>;
24
+ private getToolSchemas;
25
+ private createToolSchema;
26
+ private generateToolUsageGuide;
27
+ private generateDecisionMakingGuide;
28
+ private generateExecutionStrategy;
29
+ /**
30
+ * Dynamically generate skill instructions from loaded skills
31
+ */
32
+ private generateSkillInstructions;
33
+ getToolDefinitions(): any[];
34
+ }
35
+ //# sourceMappingURL=system-prompt-generator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"system-prompt-generator.d.ts","sourceRoot":"","sources":["../src/system-prompt-generator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAIxD,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,OAAO,CAAC,EAAE,GAAG,CAAC;CACf;AAED,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAC;IAC1C,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,aAAa,EAAE,MAAM,EAAE,CAAC;CACzB;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,YAAY,CAAe;IACnC,OAAO,CAAC,aAAa,CAAgB;IACrC,OAAO,CAAC,WAAW,CAAC,CAAc;gBAEtB,YAAY,EAAE,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,WAAW,CAAC,EAAE,WAAW;IAMzF,4BAA4B,CAAC,gBAAgB,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAuE7E,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,gBAAgB;IAsbxB,OAAO,CAAC,sBAAsB;IAoC9B,OAAO,CAAC,2BAA2B;IA2FnC,OAAO,CAAC,yBAAyB;IA6BjC;;OAEG;YACW,yBAAyB;IAqCvC,kBAAkB,IAAI,GAAG,EAAE;CA2C5B"}