@xagent-ai/cli 1.2.2 → 1.3.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 (568) hide show
  1. package/.github/ISSUE_TEMPLATE/bug_report.md +38 -38
  2. package/.github/ISSUE_TEMPLATE/feature_request.md +20 -20
  3. package/.github/workflows/ci.yml +72 -0
  4. package/.github/workflows/release.yml +109 -0
  5. package/.gitmodules +3 -3
  6. package/README.md +326 -280
  7. package/README_CN.md +325 -279
  8. package/dist/ai-client/factory.d.ts +52 -0
  9. package/dist/ai-client/factory.d.ts.map +1 -0
  10. package/dist/ai-client/factory.js +132 -0
  11. package/dist/ai-client/factory.js.map +1 -0
  12. package/dist/ai-client/index.d.ts +20 -0
  13. package/dist/ai-client/index.d.ts.map +1 -0
  14. package/dist/ai-client/index.js +49 -0
  15. package/dist/ai-client/index.js.map +1 -0
  16. package/dist/ai-client/providers/anthropic.d.ts +57 -0
  17. package/dist/ai-client/providers/anthropic.d.ts.map +1 -0
  18. package/dist/ai-client/providers/anthropic.js +400 -0
  19. package/dist/ai-client/providers/anthropic.js.map +1 -0
  20. package/dist/ai-client/providers/openai.d.ts +57 -0
  21. package/dist/ai-client/providers/openai.d.ts.map +1 -0
  22. package/dist/ai-client/providers/openai.js +286 -0
  23. package/dist/ai-client/providers/openai.js.map +1 -0
  24. package/dist/ai-client/providers/remote.d.ts +111 -0
  25. package/dist/ai-client/providers/remote.d.ts.map +1 -0
  26. package/dist/ai-client/providers/remote.js +351 -0
  27. package/dist/ai-client/providers/remote.js.map +1 -0
  28. package/dist/ai-client/registry.d.ts +51 -0
  29. package/dist/ai-client/registry.d.ts.map +1 -0
  30. package/dist/ai-client/registry.js +81 -0
  31. package/dist/ai-client/registry.js.map +1 -0
  32. package/dist/ai-client/types.d.ts +260 -0
  33. package/dist/ai-client/types.d.ts.map +1 -0
  34. package/dist/ai-client/types.js +73 -0
  35. package/dist/ai-client/types.js.map +1 -0
  36. package/dist/ai-client-factory.d.ts +62 -0
  37. package/dist/ai-client-factory.d.ts.map +1 -0
  38. package/dist/ai-client-factory.js +157 -0
  39. package/dist/ai-client-factory.js.map +1 -0
  40. package/dist/auth.d.ts +23 -1
  41. package/dist/auth.d.ts.map +1 -1
  42. package/dist/auth.js +160 -168
  43. package/dist/auth.js.map +1 -1
  44. package/dist/cancellation.d.ts +5 -4
  45. package/dist/cancellation.d.ts.map +1 -1
  46. package/dist/cancellation.js +55 -32
  47. package/dist/cancellation.js.map +1 -1
  48. package/dist/checkpoint.d.ts +1 -1
  49. package/dist/checkpoint.d.ts.map +1 -1
  50. package/dist/checkpoint.js +2 -2
  51. package/dist/checkpoint.js.map +1 -1
  52. package/dist/cli.js +626 -13
  53. package/dist/cli.js.map +1 -1
  54. package/dist/config.d.ts +10 -4
  55. package/dist/config.d.ts.map +1 -1
  56. package/dist/config.js +62 -25
  57. package/dist/config.js.map +1 -1
  58. package/dist/context-compressor.d.ts +81 -16
  59. package/dist/context-compressor.d.ts.map +1 -1
  60. package/dist/context-compressor.js +712 -153
  61. package/dist/context-compressor.js.map +1 -1
  62. package/dist/gui-subagent/action-parser/actionParser.d.ts.map +1 -1
  63. package/dist/gui-subagent/action-parser/actionParser.js +4 -2
  64. package/dist/gui-subagent/action-parser/actionParser.js.map +1 -1
  65. package/dist/gui-subagent/agent/gui-agent.d.ts +29 -2
  66. package/dist/gui-subagent/agent/gui-agent.d.ts.map +1 -1
  67. package/dist/gui-subagent/agent/gui-agent.js +87 -45
  68. package/dist/gui-subagent/agent/gui-agent.js.map +1 -1
  69. package/dist/gui-subagent/index.d.ts +16 -1
  70. package/dist/gui-subagent/index.d.ts.map +1 -1
  71. package/dist/gui-subagent/index.js +4 -0
  72. package/dist/gui-subagent/index.js.map +1 -1
  73. package/dist/gui-subagent/operator/base-operator.d.ts.map +1 -1
  74. package/dist/gui-subagent/operator/base-operator.js +0 -1
  75. package/dist/gui-subagent/operator/base-operator.js.map +1 -1
  76. package/dist/gui-subagent/operator/computer-operator.d.ts.map +1 -1
  77. package/dist/gui-subagent/operator/computer-operator.js +29 -8
  78. package/dist/gui-subagent/operator/computer-operator.js.map +1 -1
  79. package/dist/gui-subagent/types/actions.d.ts +1 -1
  80. package/dist/gui-subagent/types/actions.d.ts.map +1 -1
  81. package/dist/gui-subagent/types/actions.js +0 -1
  82. package/dist/gui-subagent/types/actions.js.map +1 -1
  83. package/dist/gui-subagent/types/operator.d.ts +1 -1
  84. package/dist/gui-subagent/types/operator.d.ts.map +1 -1
  85. package/dist/index.d.ts +1 -2
  86. package/dist/index.d.ts.map +1 -1
  87. package/dist/index.js +1 -2
  88. package/dist/index.js.map +1 -1
  89. package/dist/input-processor.d.ts.map +1 -1
  90. package/dist/input-processor.js +6 -3
  91. package/dist/input-processor.js.map +1 -1
  92. package/dist/mcp.d.ts +5 -0
  93. package/dist/mcp.d.ts.map +1 -1
  94. package/dist/mcp.js +81 -35
  95. package/dist/mcp.js.map +1 -1
  96. package/dist/ripgrep.d.ts +29 -0
  97. package/dist/ripgrep.d.ts.map +1 -0
  98. package/dist/ripgrep.js +292 -0
  99. package/dist/ripgrep.js.map +1 -0
  100. package/dist/session.d.ts +23 -7
  101. package/dist/session.d.ts.map +1 -1
  102. package/dist/session.js +624 -243
  103. package/dist/session.js.map +1 -1
  104. package/dist/shell.d.ts +33 -0
  105. package/dist/shell.d.ts.map +1 -0
  106. package/dist/shell.js +125 -0
  107. package/dist/shell.js.map +1 -0
  108. package/dist/skill-installer.d.ts +38 -0
  109. package/dist/skill-installer.d.ts.map +1 -0
  110. package/dist/skill-installer.js +447 -0
  111. package/dist/skill-installer.js.map +1 -0
  112. package/dist/skill-invoker.d.ts +7 -1
  113. package/dist/skill-invoker.d.ts.map +1 -1
  114. package/dist/skill-invoker.js +34 -13
  115. package/dist/skill-invoker.js.map +1 -1
  116. package/dist/skill-loader.d.ts +8 -3
  117. package/dist/skill-loader.d.ts.map +1 -1
  118. package/dist/skill-loader.js +46 -44
  119. package/dist/skill-loader.js.map +1 -1
  120. package/dist/skill-manager.d.ts +85 -0
  121. package/dist/skill-manager.d.ts.map +1 -0
  122. package/dist/skill-manager.js +340 -0
  123. package/dist/skill-manager.js.map +1 -0
  124. package/dist/slash-commands.d.ts +38 -1
  125. package/dist/slash-commands.d.ts.map +1 -1
  126. package/dist/slash-commands.js +912 -296
  127. package/dist/slash-commands.js.map +1 -1
  128. package/dist/smart-approval.d.ts.map +1 -1
  129. package/dist/smart-approval.js +67 -55
  130. package/dist/smart-approval.js.map +1 -1
  131. package/dist/system-prompt-generator.d.ts +6 -0
  132. package/dist/system-prompt-generator.d.ts.map +1 -1
  133. package/dist/system-prompt-generator.js +84 -34
  134. package/dist/system-prompt-generator.js.map +1 -1
  135. package/dist/terminal.d.ts +28 -0
  136. package/dist/terminal.d.ts.map +1 -0
  137. package/dist/terminal.js +82 -0
  138. package/dist/terminal.js.map +1 -0
  139. package/dist/tools.d.ts +23 -7
  140. package/dist/tools.d.ts.map +1 -1
  141. package/dist/tools.js +797 -437
  142. package/dist/tools.js.map +1 -1
  143. package/dist/truncate.d.ts +55 -0
  144. package/dist/truncate.d.ts.map +1 -0
  145. package/dist/truncate.js +130 -0
  146. package/dist/truncate.js.map +1 -0
  147. package/dist/types.d.ts +27 -9
  148. package/dist/types.d.ts.map +1 -1
  149. package/dist/update.d.ts.map +1 -1
  150. package/dist/update.js +17 -28
  151. package/dist/update.js.map +1 -1
  152. package/dist/workflow.d.ts +5 -1
  153. package/dist/workflow.d.ts.map +1 -1
  154. package/dist/workflow.js +60 -47
  155. package/dist/workflow.js.map +1 -1
  156. package/docs/architecture/mcp-integration-guide.md +304 -194
  157. package/docs/architecture/overview.md +169 -169
  158. package/docs/architecture/tool-system-design.md +134 -134
  159. package/docs/cli/commands.md +349 -238
  160. package/docs/smart-mode.md +281 -281
  161. package/docs/third-party-models.md +439 -439
  162. package/find-skills/SKILL.md +133 -0
  163. package/package.json +89 -90
  164. package/scripts/install-ripgrep.js +241 -0
  165. package/src/ai-client/factory.ts +151 -0
  166. package/src/ai-client/index.ts +61 -0
  167. package/src/ai-client/providers/anthropic.ts +466 -0
  168. package/src/ai-client/providers/openai.ts +342 -0
  169. package/src/ai-client/providers/remote.ts +436 -0
  170. package/src/ai-client/registry.ts +97 -0
  171. package/src/ai-client/types.ts +345 -0
  172. package/src/ai-client-factory.ts +204 -0
  173. package/src/auth.ts +663 -614
  174. package/src/cancellation.ts +205 -176
  175. package/src/checkpoint.ts +219 -219
  176. package/src/cli.ts +1406 -743
  177. package/src/config.ts +341 -297
  178. package/src/context-compressor.ts +982 -290
  179. package/src/conversation.ts +288 -288
  180. package/src/gui-subagent/action-parser/actionParser.ts +318 -315
  181. package/src/gui-subagent/action-parser/constants.ts +14 -14
  182. package/src/gui-subagent/action-parser/index.ts +8 -8
  183. package/src/gui-subagent/action-parser/types.ts +31 -31
  184. package/src/gui-subagent/agent/gui-agent.ts +1151 -1089
  185. package/src/gui-subagent/agent/index.ts +5 -5
  186. package/src/gui-subagent/index.ts +177 -163
  187. package/src/gui-subagent/operator/base-operator.ts +244 -245
  188. package/src/gui-subagent/operator/computer-operator.ts +540 -520
  189. package/src/gui-subagent/operator/index.ts +6 -6
  190. package/src/gui-subagent/types/actions.ts +260 -262
  191. package/src/gui-subagent/types/index.ts +6 -6
  192. package/src/gui-subagent/types/operator.ts +106 -106
  193. package/src/gui-subagent/utils.ts +51 -51
  194. package/src/index.ts +17 -18
  195. package/src/input-processor.ts +6 -3
  196. package/src/logger.ts +438 -438
  197. package/src/mcp.ts +730 -682
  198. package/src/memory.ts +344 -344
  199. package/src/ripgrep.ts +368 -0
  200. package/src/session-manager.ts +308 -308
  201. package/src/session.ts +948 -386
  202. package/src/shell.ts +133 -0
  203. package/src/skill-installer.ts +518 -0
  204. package/src/skill-invoker.ts +960 -935
  205. package/src/skill-loader.ts +501 -496
  206. package/src/skill-manager.ts +384 -0
  207. package/src/slash-commands.ts +2181 -1389
  208. package/src/smart-approval.ts +117 -73
  209. package/src/system-prompt-generator.ts +89 -34
  210. package/src/terminal.ts +96 -0
  211. package/src/theme.ts +738 -738
  212. package/src/tools.ts +1336 -773
  213. package/src/truncate.ts +173 -0
  214. package/src/types.ts +219 -198
  215. package/src/update.ts +22 -32
  216. package/src/workflow.ts +523 -508
  217. package/tsconfig.json +22 -22
  218. package/vitest.config.ts +19 -19
  219. package/dist/ai-client.d.ts +0 -86
  220. package/dist/ai-client.d.ts.map +0 -1
  221. package/dist/ai-client.js +0 -1372
  222. package/dist/ai-client.js.map +0 -1
  223. package/dist/gui-subagent/operator/browser-operator.d.ts +0 -36
  224. package/dist/gui-subagent/operator/browser-operator.d.ts.map +0 -1
  225. package/dist/gui-subagent/operator/browser-operator.js +0 -306
  226. package/dist/gui-subagent/operator/browser-operator.js.map +0 -1
  227. package/dist/gui-subagent/operator/desktop-operator.d.ts +0 -55
  228. package/dist/gui-subagent/operator/desktop-operator.d.ts.map +0 -1
  229. package/dist/gui-subagent/operator/desktop-operator.js +0 -527
  230. package/dist/gui-subagent/operator/desktop-operator.js.map +0 -1
  231. package/dist/hook.d.ts +0 -73
  232. package/dist/hook.d.ts.map +0 -1
  233. package/dist/hook.js +0 -156
  234. package/dist/hook.js.map +0 -1
  235. package/dist/input-history.d.ts +0 -24
  236. package/dist/input-history.d.ts.map +0 -1
  237. package/dist/input-history.js +0 -94
  238. package/dist/input-history.js.map +0 -1
  239. package/dist/keyboard-manager.d.ts +0 -151
  240. package/dist/keyboard-manager.d.ts.map +0 -1
  241. package/dist/keyboard-manager.js +0 -396
  242. package/dist/keyboard-manager.js.map +0 -1
  243. package/dist/print-system-prompt.d.ts +0 -2
  244. package/dist/print-system-prompt.d.ts.map +0 -1
  245. package/dist/print-system-prompt.js +0 -40
  246. package/dist/print-system-prompt.js.map +0 -1
  247. package/dist/remote-ai-client.d.ts +0 -104
  248. package/dist/remote-ai-client.d.ts.map +0 -1
  249. package/dist/remote-ai-client.js +0 -552
  250. package/dist/remote-ai-client.js.map +0 -1
  251. package/dist/sdk-output-adapter.d.ts +0 -232
  252. package/dist/sdk-output-adapter.d.ts.map +0 -1
  253. package/dist/sdk-output-adapter.js +0 -636
  254. package/dist/sdk-output-adapter.js.map +0 -1
  255. package/dist/sdk-session-v2.d.ts +0 -13
  256. package/dist/sdk-session-v2.d.ts.map +0 -1
  257. package/dist/sdk-session-v2.js +0 -46
  258. package/dist/sdk-session-v2.js.map +0 -1
  259. package/dist/sdk-session.d.ts +0 -13
  260. package/dist/sdk-session.d.ts.map +0 -1
  261. package/dist/sdk-session.js +0 -48
  262. package/dist/sdk-session.js.map +0 -1
  263. package/dist/test-boundary-conditions.d.ts.map +0 -1
  264. package/dist/test-boundary-conditions.js.map +0 -1
  265. package/dist/test-cancellation-fix.d.ts.map +0 -1
  266. package/dist/test-cancellation-fix.js.map +0 -1
  267. package/dist/test-input-history.d.ts.map +0 -1
  268. package/dist/test-input-history.js.map +0 -1
  269. package/dist/test-interaction-flow.d.ts.map +0 -1
  270. package/dist/test-interaction-flow.js.map +0 -1
  271. package/dist/test-quick.d.ts.map +0 -1
  272. package/dist/test-quick.js.map +0 -1
  273. package/dist/test-user-interaction.d.ts.map +0 -1
  274. package/dist/test-user-interaction.js.map +0 -1
  275. package/dist/tools/edit-diff.d.ts +0 -32
  276. package/dist/tools/edit-diff.d.ts.map +0 -1
  277. package/dist/tools/edit-diff.js +0 -185
  278. package/dist/tools/edit-diff.js.map +0 -1
  279. package/dist/tools/edit.d.ts +0 -11
  280. package/dist/tools/edit.d.ts.map +0 -1
  281. package/dist/tools/edit.js +0 -129
  282. package/dist/tools/edit.js.map +0 -1
  283. package/dist/unified-session.d.ts +0 -42
  284. package/dist/unified-session.d.ts.map +0 -1
  285. package/dist/unified-session.js +0 -271
  286. package/dist/unified-session.js.map +0 -1
  287. package/skills/.claude-plugin/marketplace.json +0 -45
  288. package/skills/README.md +0 -94
  289. package/skills/THIRD_PARTY_NOTICES.md +0 -405
  290. package/skills/skills/algorithmic-art/LICENSE.txt +0 -202
  291. package/skills/skills/algorithmic-art/SKILL.md +0 -405
  292. package/skills/skills/algorithmic-art/templates/generator_template.js +0 -223
  293. package/skills/skills/algorithmic-art/templates/viewer.html +0 -599
  294. package/skills/skills/brand-guidelines/LICENSE.txt +0 -202
  295. package/skills/skills/brand-guidelines/SKILL.md +0 -73
  296. package/skills/skills/canvas-design/LICENSE.txt +0 -202
  297. package/skills/skills/canvas-design/SKILL.md +0 -130
  298. package/skills/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +0 -93
  299. package/skills/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  300. package/skills/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  301. package/skills/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +0 -93
  302. package/skills/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  303. package/skills/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +0 -93
  304. package/skills/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  305. package/skills/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  306. package/skills/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +0 -93
  307. package/skills/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  308. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  309. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  310. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +0 -93
  311. package/skills/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  312. package/skills/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +0 -93
  313. package/skills/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  314. package/skills/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +0 -94
  315. package/skills/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  316. package/skills/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  317. package/skills/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +0 -93
  318. package/skills/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  319. package/skills/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +0 -93
  320. package/skills/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  321. package/skills/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  322. package/skills/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +0 -93
  323. package/skills/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  324. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  325. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  326. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  327. package/skills/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  328. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  329. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  330. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  331. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +0 -93
  332. package/skills/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  333. package/skills/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  334. package/skills/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  335. package/skills/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +0 -93
  336. package/skills/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  337. package/skills/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  338. package/skills/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +0 -93
  339. package/skills/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  340. package/skills/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  341. package/skills/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  342. package/skills/skills/canvas-design/canvas-fonts/Jura-OFL.txt +0 -93
  343. package/skills/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +0 -93
  344. package/skills/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  345. package/skills/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  346. package/skills/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  347. package/skills/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  348. package/skills/skills/canvas-design/canvas-fonts/Lora-OFL.txt +0 -93
  349. package/skills/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  350. package/skills/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  351. package/skills/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +0 -93
  352. package/skills/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  353. package/skills/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +0 -93
  354. package/skills/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  355. package/skills/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  356. package/skills/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +0 -93
  357. package/skills/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  358. package/skills/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  359. package/skills/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +0 -93
  360. package/skills/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +0 -93
  361. package/skills/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  362. package/skills/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  363. package/skills/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +0 -93
  364. package/skills/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  365. package/skills/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +0 -93
  366. package/skills/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  367. package/skills/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  368. package/skills/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +0 -93
  369. package/skills/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  370. package/skills/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +0 -93
  371. package/skills/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  372. package/skills/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  373. package/skills/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  374. package/skills/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  375. package/skills/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +0 -93
  376. package/skills/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  377. package/skills/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +0 -93
  378. package/skills/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  379. package/skills/skills/doc-coauthoring/SKILL.md +0 -375
  380. package/skills/skills/docx/LICENSE.txt +0 -30
  381. package/skills/skills/docx/SKILL.md +0 -197
  382. package/skills/skills/docx/docx-js.md +0 -350
  383. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  384. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  385. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  386. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  387. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  388. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  389. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  390. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  391. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  392. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  393. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  394. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  395. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  396. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  397. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  398. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  399. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  400. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  401. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  402. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  403. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  404. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  405. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  406. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  407. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  408. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  409. package/skills/skills/docx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  410. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  411. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  412. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  413. package/skills/skills/docx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  414. package/skills/skills/docx/ooxml/schemas/mce/mc.xsd +0 -75
  415. package/skills/skills/docx/ooxml/schemas/microsoft/wml-2010.xsd +0 -560
  416. package/skills/skills/docx/ooxml/schemas/microsoft/wml-2012.xsd +0 -67
  417. package/skills/skills/docx/ooxml/schemas/microsoft/wml-2018.xsd +0 -14
  418. package/skills/skills/docx/ooxml/schemas/microsoft/wml-cex-2018.xsd +0 -20
  419. package/skills/skills/docx/ooxml/schemas/microsoft/wml-cid-2016.xsd +0 -13
  420. package/skills/skills/docx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  421. package/skills/skills/docx/ooxml/schemas/microsoft/wml-symex-2015.xsd +0 -8
  422. package/skills/skills/docx/ooxml/scripts/pack.py +0 -159
  423. package/skills/skills/docx/ooxml/scripts/unpack.py +0 -29
  424. package/skills/skills/docx/ooxml/scripts/validate.py +0 -69
  425. package/skills/skills/docx/ooxml/scripts/validation/__init__.py +0 -15
  426. package/skills/skills/docx/ooxml/scripts/validation/base.py +0 -951
  427. package/skills/skills/docx/ooxml/scripts/validation/docx.py +0 -274
  428. package/skills/skills/docx/ooxml/scripts/validation/pptx.py +0 -315
  429. package/skills/skills/docx/ooxml/scripts/validation/redlining.py +0 -279
  430. package/skills/skills/docx/ooxml.md +0 -610
  431. package/skills/skills/docx/scripts/__init__.py +0 -1
  432. package/skills/skills/docx/scripts/document.py +0 -1276
  433. package/skills/skills/docx/scripts/templates/comments.xml +0 -3
  434. package/skills/skills/docx/scripts/templates/commentsExtended.xml +0 -3
  435. package/skills/skills/docx/scripts/templates/commentsExtensible.xml +0 -3
  436. package/skills/skills/docx/scripts/templates/commentsIds.xml +0 -3
  437. package/skills/skills/docx/scripts/templates/people.xml +0 -3
  438. package/skills/skills/docx/scripts/utilities.py +0 -374
  439. package/skills/skills/frontend-design/LICENSE.txt +0 -177
  440. package/skills/skills/frontend-design/SKILL.md +0 -42
  441. package/skills/skills/internal-comms/LICENSE.txt +0 -202
  442. package/skills/skills/internal-comms/SKILL.md +0 -32
  443. package/skills/skills/internal-comms/examples/3p-updates.md +0 -47
  444. package/skills/skills/internal-comms/examples/company-newsletter.md +0 -65
  445. package/skills/skills/internal-comms/examples/faq-answers.md +0 -30
  446. package/skills/skills/internal-comms/examples/general-comms.md +0 -16
  447. package/skills/skills/mcp-builder/LICENSE.txt +0 -202
  448. package/skills/skills/mcp-builder/SKILL.md +0 -236
  449. package/skills/skills/mcp-builder/reference/evaluation.md +0 -602
  450. package/skills/skills/mcp-builder/reference/mcp_best_practices.md +0 -249
  451. package/skills/skills/mcp-builder/reference/node_mcp_server.md +0 -970
  452. package/skills/skills/mcp-builder/reference/python_mcp_server.md +0 -719
  453. package/skills/skills/mcp-builder/scripts/connections.py +0 -151
  454. package/skills/skills/mcp-builder/scripts/evaluation.py +0 -373
  455. package/skills/skills/mcp-builder/scripts/example_evaluation.xml +0 -22
  456. package/skills/skills/mcp-builder/scripts/requirements.txt +0 -2
  457. package/skills/skills/pdf/LICENSE.txt +0 -30
  458. package/skills/skills/pdf/SKILL.md +0 -294
  459. package/skills/skills/pdf/forms.md +0 -205
  460. package/skills/skills/pdf/reference.md +0 -612
  461. package/skills/skills/pdf/scripts/check_bounding_boxes.py +0 -70
  462. package/skills/skills/pdf/scripts/check_bounding_boxes_test.py +0 -226
  463. package/skills/skills/pdf/scripts/check_fillable_fields.py +0 -12
  464. package/skills/skills/pdf/scripts/convert_pdf_to_images.py +0 -35
  465. package/skills/skills/pdf/scripts/create_validation_image.py +0 -41
  466. package/skills/skills/pdf/scripts/extract_form_field_info.py +0 -152
  467. package/skills/skills/pdf/scripts/fill_fillable_fields.py +0 -114
  468. package/skills/skills/pdf/scripts/fill_pdf_form_with_annotations.py +0 -108
  469. package/skills/skills/pptx/LICENSE.txt +0 -30
  470. package/skills/skills/pptx/SKILL.md +0 -484
  471. package/skills/skills/pptx/html2pptx.md +0 -625
  472. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chart.xsd +0 -1499
  473. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-chartDrawing.xsd +0 -146
  474. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-diagram.xsd +0 -1085
  475. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-lockedCanvas.xsd +0 -11
  476. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-main.xsd +0 -3081
  477. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-picture.xsd +0 -23
  478. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-spreadsheetDrawing.xsd +0 -185
  479. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/dml-wordprocessingDrawing.xsd +0 -287
  480. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/pml.xsd +0 -1676
  481. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-additionalCharacteristics.xsd +0 -28
  482. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-bibliography.xsd +0 -144
  483. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-commonSimpleTypes.xsd +0 -174
  484. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlDataProperties.xsd +0 -25
  485. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-customXmlSchemaProperties.xsd +0 -18
  486. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesCustom.xsd +0 -59
  487. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesExtended.xsd +0 -56
  488. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-documentPropertiesVariantTypes.xsd +0 -195
  489. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-math.xsd +0 -582
  490. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/shared-relationshipReference.xsd +0 -25
  491. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/sml.xsd +0 -4439
  492. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-main.xsd +0 -570
  493. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-officeDrawing.xsd +0 -509
  494. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-presentationDrawing.xsd +0 -12
  495. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-spreadsheetDrawing.xsd +0 -108
  496. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/vml-wordprocessingDrawing.xsd +0 -96
  497. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/wml.xsd +0 -3646
  498. package/skills/skills/pptx/ooxml/schemas/ISO-IEC29500-4_2016/xml.xsd +0 -116
  499. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-contentTypes.xsd +0 -42
  500. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-coreProperties.xsd +0 -50
  501. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-digSig.xsd +0 -49
  502. package/skills/skills/pptx/ooxml/schemas/ecma/fouth-edition/opc-relationships.xsd +0 -33
  503. package/skills/skills/pptx/ooxml/schemas/mce/mc.xsd +0 -75
  504. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-2010.xsd +0 -560
  505. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-2012.xsd +0 -67
  506. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-2018.xsd +0 -14
  507. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-cex-2018.xsd +0 -20
  508. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-cid-2016.xsd +0 -13
  509. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-sdtdatahash-2020.xsd +0 -4
  510. package/skills/skills/pptx/ooxml/schemas/microsoft/wml-symex-2015.xsd +0 -8
  511. package/skills/skills/pptx/ooxml/scripts/pack.py +0 -159
  512. package/skills/skills/pptx/ooxml/scripts/unpack.py +0 -29
  513. package/skills/skills/pptx/ooxml/scripts/validate.py +0 -69
  514. package/skills/skills/pptx/ooxml/scripts/validation/__init__.py +0 -15
  515. package/skills/skills/pptx/ooxml/scripts/validation/base.py +0 -951
  516. package/skills/skills/pptx/ooxml/scripts/validation/docx.py +0 -274
  517. package/skills/skills/pptx/ooxml/scripts/validation/pptx.py +0 -315
  518. package/skills/skills/pptx/ooxml/scripts/validation/redlining.py +0 -279
  519. package/skills/skills/pptx/ooxml.md +0 -427
  520. package/skills/skills/pptx/scripts/html2pptx.js +0 -979
  521. package/skills/skills/pptx/scripts/inventory.py +0 -1020
  522. package/skills/skills/pptx/scripts/rearrange.py +0 -231
  523. package/skills/skills/pptx/scripts/replace.py +0 -385
  524. package/skills/skills/pptx/scripts/thumbnail.py +0 -450
  525. package/skills/skills/skill-creator/LICENSE.txt +0 -202
  526. package/skills/skills/skill-creator/SKILL.md +0 -356
  527. package/skills/skills/skill-creator/references/output-patterns.md +0 -82
  528. package/skills/skills/skill-creator/references/workflows.md +0 -28
  529. package/skills/skills/skill-creator/scripts/init_skill.py +0 -303
  530. package/skills/skills/skill-creator/scripts/package_skill.py +0 -110
  531. package/skills/skills/skill-creator/scripts/quick_validate.py +0 -95
  532. package/skills/skills/slack-gif-creator/LICENSE.txt +0 -202
  533. package/skills/skills/slack-gif-creator/SKILL.md +0 -254
  534. package/skills/skills/slack-gif-creator/core/easing.py +0 -234
  535. package/skills/skills/slack-gif-creator/core/frame_composer.py +0 -176
  536. package/skills/skills/slack-gif-creator/core/gif_builder.py +0 -269
  537. package/skills/skills/slack-gif-creator/core/validators.py +0 -136
  538. package/skills/skills/slack-gif-creator/requirements.txt +0 -4
  539. package/skills/skills/theme-factory/LICENSE.txt +0 -202
  540. package/skills/skills/theme-factory/SKILL.md +0 -59
  541. package/skills/skills/theme-factory/theme-showcase.pdf +0 -0
  542. package/skills/skills/theme-factory/themes/arctic-frost.md +0 -19
  543. package/skills/skills/theme-factory/themes/botanical-garden.md +0 -19
  544. package/skills/skills/theme-factory/themes/desert-rose.md +0 -19
  545. package/skills/skills/theme-factory/themes/forest-canopy.md +0 -19
  546. package/skills/skills/theme-factory/themes/golden-hour.md +0 -19
  547. package/skills/skills/theme-factory/themes/midnight-galaxy.md +0 -19
  548. package/skills/skills/theme-factory/themes/modern-minimalist.md +0 -19
  549. package/skills/skills/theme-factory/themes/ocean-depths.md +0 -19
  550. package/skills/skills/theme-factory/themes/sunset-boulevard.md +0 -19
  551. package/skills/skills/theme-factory/themes/tech-innovation.md +0 -19
  552. package/skills/skills/web-artifacts-builder/LICENSE.txt +0 -202
  553. package/skills/skills/web-artifacts-builder/SKILL.md +0 -74
  554. package/skills/skills/web-artifacts-builder/scripts/bundle-artifact.sh +0 -54
  555. package/skills/skills/web-artifacts-builder/scripts/init-artifact.sh +0 -322
  556. package/skills/skills/webapp-testing/LICENSE.txt +0 -202
  557. package/skills/skills/webapp-testing/SKILL.md +0 -96
  558. package/skills/skills/webapp-testing/examples/console_logging.py +0 -35
  559. package/skills/skills/webapp-testing/examples/element_discovery.py +0 -40
  560. package/skills/skills/webapp-testing/examples/static_html_automation.py +0 -33
  561. package/skills/skills/webapp-testing/scripts/with_server.py +0 -106
  562. package/skills/skills/xlsx/LICENSE.txt +0 -30
  563. package/skills/skills/xlsx/SKILL.md +0 -289
  564. package/skills/skills/xlsx/recalc.py +0 -178
  565. package/skills/spec/agent-skills-spec.md +0 -3
  566. package/skills/template/SKILL.md +0 -6
  567. package/src/ai-client.ts +0 -1560
  568. package/src/remote-ai-client.ts +0 -664
package/src/shell.ts ADDED
@@ -0,0 +1,133 @@
1
+ import { existsSync } from 'fs';
2
+ import { spawn, spawnSync } from 'child_process';
3
+
4
+ /**
5
+ * Find bash executable on PATH (Windows).
6
+ */
7
+ function findBashOnPath(): string | null {
8
+ try {
9
+ const result = spawnSync('where', ['bash.exe'], { encoding: 'utf-8', timeout: 5000 });
10
+ if (result.status === 0 && result.stdout) {
11
+ const firstMatch = result.stdout.trim().split(/\r?\n/)[0];
12
+ if (firstMatch && existsSync(firstMatch)) {
13
+ return firstMatch;
14
+ }
15
+ }
16
+ } catch {
17
+ // Ignore errors
18
+ }
19
+ return null;
20
+ }
21
+
22
+ /**
23
+ * Get PowerShell version on Windows.
24
+ * @returns Version string (e.g., "5.1.22621") or "Unknown" if detection fails
25
+ */
26
+ export function getPowerShellVersion(): string {
27
+ if (process.platform !== 'win32') {
28
+ return 'N/A';
29
+ }
30
+
31
+ try {
32
+ const result = spawnSync('powershell', ['-NoProfile', '-Command', '($PSVersionTable.PSVersion | Select-Object -ExpandProperty Major), ($PSVersionTable.PSVersion | Select-Object -ExpandProperty Minor), ($PSVersionTable.PSVersion | Select-Object -ExpandProperty Build) -join "."'], {
33
+ encoding: 'utf-8',
34
+ timeout: 5000
35
+ });
36
+
37
+ if (result.status === 0 && result.stdout.trim()) {
38
+ return result.stdout.trim();
39
+ }
40
+ } catch {
41
+ // Ignore errors
42
+ }
43
+ return 'Unknown';
44
+ }
45
+
46
+ interface ShellConfig {
47
+ /** Path to the shell executable */
48
+ shell: string;
49
+ /** Arguments to pass to the shell */
50
+ args: string[];
51
+ }
52
+
53
+ let cachedShellConfig: ShellConfig | null = null;
54
+
55
+ /**
56
+ * Get shell configuration based on platform.
57
+ * Resolution order:
58
+ * 1. On Windows: PowerShell (preferred), then Git Bash as fallback
59
+ * 2. On Unix: /bin/bash
60
+ *
61
+ * @returns ShellConfig with shell path and args
62
+ */
63
+ export function getShellConfig(): ShellConfig {
64
+ if (cachedShellConfig) {
65
+ return cachedShellConfig;
66
+ }
67
+
68
+ if (process.platform === 'win32') {
69
+ // On Windows, prefer PowerShell for better compatibility and output handling
70
+ // Use -NoProfile to avoid profile script interference
71
+ // -Command executes the command string as PowerShell script
72
+ cachedShellConfig = {
73
+ shell: 'powershell',
74
+ args: ['-NoProfile', '-ExecutionPolicy', 'Bypass', '-Command']
75
+ };
76
+ return cachedShellConfig;
77
+ }
78
+
79
+ // Unix: prefer bash over sh
80
+ if (existsSync('/bin/bash')) {
81
+ cachedShellConfig = { shell: '/bin/bash', args: ['-c'] };
82
+ } else {
83
+ cachedShellConfig = { shell: 'sh', args: ['-c'] };
84
+ }
85
+ return cachedShellConfig;
86
+ }
87
+
88
+ /**
89
+ * Get a shell command string with proper quoting for the platform.
90
+ * @param command The command to execute
91
+ * @returns A properly quoted command string
92
+ */
93
+ export function quoteShellCommand(command: string): string {
94
+ if (process.platform === 'win32') {
95
+ // For PowerShell -Command, the command string is passed directly
96
+ // PowerShell will parse and execute it as a script
97
+ // No additional quoting needed - just return the command as-is
98
+ return command;
99
+ } else {
100
+ // For bash/sh, use single quotes
101
+ return `'${command.replace(/'/g, "'\\''")}'`;
102
+ }
103
+ }
104
+
105
+ /**
106
+ * Kill a process and all its children (cross-platform).
107
+ * @param pid Process ID to kill
108
+ */
109
+ export function killProcessTree(pid: number): void {
110
+ if (process.platform === 'win32') {
111
+ // Use taskkill on Windows to kill process tree
112
+ try {
113
+ spawn('taskkill', ['/F', '/T', '/PID', String(pid)], {
114
+ stdio: 'ignore',
115
+ detached: true,
116
+ });
117
+ } catch (error) {
118
+ console.warn(`[shell] Failed to kill process tree (PID ${pid}): ${error instanceof Error ? error.message : String(error)}`);
119
+ }
120
+ } else {
121
+ // Use SIGKILL on Unix/Linux/Mac
122
+ try {
123
+ process.kill(-pid, 'SIGKILL');
124
+ } catch (error) {
125
+ // Fallback to killing just the child if process group kill fails
126
+ try {
127
+ process.kill(pid, 'SIGKILL');
128
+ } catch (fallbackError) {
129
+ console.warn(`[shell] Failed to kill process (PID ${pid}): ${fallbackError instanceof Error ? fallbackError.message : String(fallbackError)}`);
130
+ }
131
+ }
132
+ }
133
+ }
@@ -0,0 +1,518 @@
1
+ /**
2
+ * Skill Installer - Handles remote skill installation
3
+ * Supports: GitHub shorthand, GitHub URLs, direct SKILL.md URLs
4
+ */
5
+
6
+ import fs from 'fs/promises';
7
+ import path from 'path';
8
+ import os from 'os';
9
+ import { mkdtemp, rm } from 'fs/promises';
10
+ import { tmpdir } from 'os';
11
+ import simpleGit from 'simple-git';
12
+ import { getConfigManager } from './config.js';
13
+ import { getLogger } from './logger.js';
14
+
15
+ const logger = getLogger();
16
+ const CLONE_TIMEOUT_MS = 60000; // 60 seconds
17
+
18
+ export interface RemoteSource {
19
+ type: 'github' | 'direct-url' | 'local';
20
+ url: string;
21
+ ref?: string; // Branch/tag
22
+ subpath?: string; // Path to skill within repo
23
+ skillName?: string; // For @owner/repo@syntax
24
+ }
25
+
26
+ export interface InstallResult {
27
+ success: boolean;
28
+ skillName?: string;
29
+ skillPath?: string;
30
+ error?: string;
31
+ }
32
+
33
+ /**
34
+ * Parse a source string into structured format
35
+ */
36
+ export function parseSource(input: string): RemoteSource {
37
+ const trimmed = input.trim();
38
+
39
+ // Check if local path
40
+ if (isLocalPath(trimmed)) {
41
+ return { type: 'local', url: trimmed };
42
+ }
43
+
44
+ // Direct SKILL.md URL (non-GitHub)
45
+ if (isDirectSkillUrl(trimmed)) {
46
+ return { type: 'direct-url', url: trimmed };
47
+ }
48
+
49
+ // GitHub URL with path: https://github.com/owner/repo/tree/branch/path/to/skill
50
+ const githubTreeWithPathMatch = trimmed.match(/github\.com\/([^/]+)\/([^/]+)\/tree\/([^/]+)\/(.+)/);
51
+ if (githubTreeWithPathMatch) {
52
+ const [, owner, repo, ref, subpath] = githubTreeWithPathMatch;
53
+ return {
54
+ type: 'github',
55
+ url: `https://github.com/${owner}/${repo}.git`,
56
+ ref,
57
+ subpath
58
+ };
59
+ }
60
+
61
+ // GitHub URL with branch only: https://github.com/owner/repo/tree/branch
62
+ const githubTreeMatch = trimmed.match(/github\.com\/([^/]+)\/([^/]+)\/tree\/([^/]+)$/);
63
+ if (githubTreeMatch) {
64
+ const [, owner, repo, ref] = githubTreeMatch;
65
+ return {
66
+ type: 'github',
67
+ url: `https://github.com/${owner}/${repo}.git`,
68
+ ref
69
+ };
70
+ }
71
+
72
+ // GitHub URL: https://github.com/owner/repo
73
+ const githubRepoMatch = trimmed.match(/github\.com\/([^/]+)\/([^/]+)/);
74
+ if (githubRepoMatch) {
75
+ const [, owner, repo] = githubRepoMatch;
76
+ const cleanRepo = repo.replace(/\.git$/, '');
77
+ return {
78
+ type: 'github',
79
+ url: `https://github.com/${owner}/${cleanRepo}.git`
80
+ };
81
+ }
82
+
83
+ // GitHub shorthand: owner/repo, owner/repo@skill-name
84
+ const atSkillMatch = trimmed.match(/^([^/]+)\/([^/@]+)@(.+)$/);
85
+ if (atSkillMatch && !trimmed.includes(':') && !trimmed.startsWith('.') && !trimmed.startsWith('/')) {
86
+ const [, owner, repo, skillName] = atSkillMatch;
87
+ return {
88
+ type: 'github',
89
+ url: `https://github.com/${owner}/${repo}.git`,
90
+ skillName
91
+ };
92
+ }
93
+
94
+ const shorthandMatch = trimmed.match(/^([^/]+)\/([^/]+)(?:\/(.+))?$/);
95
+ if (shorthandMatch && !trimmed.includes(':') && !trimmed.startsWith('.') && !trimmed.startsWith('/')) {
96
+ const [, owner, repo, subpath] = shorthandMatch;
97
+ return {
98
+ type: 'github',
99
+ url: `https://github.com/${owner}/${repo}.git`,
100
+ subpath
101
+ };
102
+ }
103
+
104
+ // Fallback: treat as direct URL
105
+ return { type: 'direct-url', url: trimmed };
106
+ }
107
+
108
+ /**
109
+ * Check if input is a local path
110
+ */
111
+ function isLocalPath(input: string): boolean {
112
+ return (
113
+ path.isAbsolute(input) ||
114
+ input.startsWith('./') ||
115
+ input.startsWith('../') ||
116
+ input === '.' ||
117
+ input === '..' ||
118
+ /^[a-zA-Z]:[/\\]/.test(input)
119
+ );
120
+ }
121
+
122
+ /**
123
+ * Check if URL is a direct link to SKILL.md file
124
+ */
125
+ function isDirectSkillUrl(input: string): boolean {
126
+ if (!input.startsWith('http://') && !input.startsWith('https://')) {
127
+ return false;
128
+ }
129
+
130
+ if (!input.toLowerCase().endsWith('/skill.md') && !input.toLowerCase().endsWith('/skill')) {
131
+ return false;
132
+ }
133
+
134
+ // Exclude GitHub/GitLab URLs (they have their own handling)
135
+ if (input.includes('github.com/') && !input.includes('raw.githubusercontent.com')) {
136
+ return false;
137
+ }
138
+ if (input.includes('gitlab.com/') && !input.includes('/-/raw/')) {
139
+ return false;
140
+ }
141
+
142
+ return true;
143
+ }
144
+
145
+ /**
146
+ * Extract skill name from SKILL.md content
147
+ */
148
+ function extractSkillName(content: string): string | null {
149
+ const nameMatch = content.match(/^name:\s*(.+)$/m);
150
+ return nameMatch ? nameMatch[1].trim() : null;
151
+ }
152
+
153
+ /**
154
+ * Ensure directory exists
155
+ */
156
+ async function ensureDir(dirPath: string): Promise<void> {
157
+ await fs.mkdir(dirPath, { recursive: true });
158
+ }
159
+
160
+ /**
161
+ * Remove directory recursively
162
+ */
163
+ async function removeDir(dirPath: string): Promise<void> {
164
+ try {
165
+ await fs.rm(dirPath, { recursive: true, force: true });
166
+ } catch {
167
+ // Ignore if doesn't exist
168
+ }
169
+ }
170
+
171
+ /**
172
+ * Copy directory contents
173
+ */
174
+ async function copyDir(src: string, dest: string): Promise<void> {
175
+ await ensureDir(dest);
176
+ const entries = await fs.readdir(src, { withFileTypes: true });
177
+
178
+ for (const entry of entries) {
179
+ const srcPath = path.join(src, entry.name);
180
+ const destPath = path.join(dest, entry.name);
181
+
182
+ if (entry.isDirectory()) {
183
+ await copyDir(srcPath, destPath);
184
+ } else if (entry.isFile()) {
185
+ await fs.copyFile(srcPath, destPath);
186
+ }
187
+ }
188
+ }
189
+
190
+ /**
191
+ * Find SKILL.md in a directory
192
+ */
193
+ async function findSkillMd(dirPath: string): Promise<string | null> {
194
+ try {
195
+ const entries = await fs.readdir(dirPath, { withFileTypes: true });
196
+
197
+ for (const entry of entries) {
198
+ const fullPath = path.join(dirPath, entry.name);
199
+
200
+ if (entry.isDirectory()) {
201
+ // Skip hidden directories (except .)
202
+ if (entry.name.startsWith('.') && entry.name !== '.') continue;
203
+
204
+ // Check subdirectory for SKILL.md
205
+ const result = await findSkillMd(fullPath);
206
+ if (result) return result;
207
+ } else if (entry.isFile() && entry.name.toUpperCase() === 'SKILL.MD') {
208
+ return fullPath;
209
+ }
210
+ }
211
+ } catch {
212
+ // Ignore errors
213
+ }
214
+ return null;
215
+ }
216
+
217
+ /**
218
+ * Fetch remote file content via HTTP with timeout
219
+ */
220
+ async function fetchRemoteFile(url: string, timeoutMs: number = 30000): Promise<string> {
221
+ const controller = new AbortController();
222
+ const timeoutId = setTimeout(() => controller.abort(), timeoutMs);
223
+
224
+ try {
225
+ const response = await fetch(url, { signal: controller.signal });
226
+ clearTimeout(timeoutId);
227
+
228
+ if (!response.ok) {
229
+ throw new Error(`Failed to fetch ${url}: ${response.status} ${response.statusText}`);
230
+ }
231
+ return response.text();
232
+ } catch (error) {
233
+ clearTimeout(timeoutId);
234
+ if (error instanceof Error && error.name === 'AbortError') {
235
+ throw new Error(`Request timed out after ${timeoutMs}ms: ${url}`);
236
+ }
237
+ throw error;
238
+ }
239
+ }
240
+
241
+ /**
242
+ * Clone a GitHub repository to a temporary directory
243
+ */
244
+ async function cloneRepo(url: string, ref?: string): Promise<string> {
245
+ const tempDir = await mkdtemp(path.join(tmpdir(), 'xagent-skills-'));
246
+ const git = simpleGit({ timeout: { block: CLONE_TIMEOUT_MS } });
247
+ const cloneOptions = ref ? ['--depth', '1', '--branch', ref] : ['--depth', '1'];
248
+
249
+ try {
250
+ await git.clone(url, tempDir, cloneOptions);
251
+ return tempDir;
252
+ } catch (error) {
253
+ // Clean up temp dir on failure
254
+ await rm(tempDir, { recursive: true, force: true }).catch(() => {});
255
+
256
+ const errorMessage = error instanceof Error ? error.message : String(error);
257
+ const isTimeout = errorMessage.includes('block timeout') || errorMessage.includes('timed out');
258
+
259
+ if (isTimeout) {
260
+ throw new Error(
261
+ `Clone timed out after 60s. This often happens with private repos that require authentication.\n` +
262
+ ` Ensure you have access and your SSH keys or credentials are configured.`
263
+ );
264
+ }
265
+
266
+ throw new Error(`Failed to clone ${url}: ${errorMessage}`);
267
+ }
268
+ }
269
+
270
+ /**
271
+ * Install skill from direct URL (single SKILL.md file)
272
+ */
273
+ async function installFromDirectUrl(source: RemoteSource): Promise<InstallResult> {
274
+ const configManager = getConfigManager();
275
+ const userSkillsPath = configManager.getUserSkillsPath() || path.join(os.homedir(), '.xagent', 'skills');
276
+
277
+ try {
278
+ const content = await fetchRemoteFile(source.url);
279
+ const skillName = extractSkillName(content);
280
+
281
+ if (!skillName) {
282
+ return { success: false, error: 'Could not extract skill name from SKILL.md' };
283
+ }
284
+
285
+ const skillPath = path.join(userSkillsPath, skillName);
286
+
287
+ // Check if skill already exists
288
+ try {
289
+ await fs.access(skillPath);
290
+ return { success: false, error: `Skill "${skillName}" already installed` };
291
+ } catch {
292
+ // Doesn't exist, proceed
293
+ }
294
+
295
+ // Create skill directory
296
+ await ensureDir(skillPath);
297
+
298
+ // Write SKILL.md
299
+ await fs.writeFile(path.join(skillPath, 'SKILL.md'), content, 'utf-8');
300
+
301
+ return { success: true, skillName, skillPath };
302
+ } catch (error) {
303
+ return { success: false, error: error instanceof Error ? error.message : String(error) };
304
+ }
305
+ }
306
+
307
+ /**
308
+ * Install skill from GitHub repository using git clone
309
+ */
310
+ async function installFromGitHub(source: RemoteSource): Promise<InstallResult> {
311
+ const configManager = getConfigManager();
312
+ const userSkillsPath = configManager.getUserSkillsPath() || path.join(os.homedir(), '.xagent', 'skills');
313
+
314
+ // Parse owner/repo from URL
315
+ const urlMatch = source.url.match(/github\.com\/([^/]+)\/([^/]+?)(?:\.git)?$/);
316
+ if (!urlMatch) {
317
+ return { success: false, error: 'Invalid GitHub URL' };
318
+ }
319
+
320
+ const [, owner, repo] = urlMatch;
321
+ const cleanRepo = repo.replace(/\.git$/, '');
322
+ const ref = source.ref || 'main';
323
+
324
+ let tempDir: string | null = null;
325
+
326
+ try {
327
+ // Clone the repository to a temporary directory
328
+ tempDir = await cloneRepo(source.url, ref);
329
+
330
+ // Find the skill directory in the cloned repo
331
+ let skillDir: string;
332
+
333
+ if (source.subpath) {
334
+ // Specific path to skill provided
335
+ skillDir = path.join(tempDir, source.subpath);
336
+ try {
337
+ await fs.access(skillDir);
338
+ } catch {
339
+ return { success: false, error: `Path "${source.subpath}" not found in repository` };
340
+ }
341
+ } else if (source.skillName) {
342
+ // @owner/repo@syntax - skill is in skills/<skill-name>/
343
+ skillDir = path.join(tempDir, 'skills', source.skillName);
344
+ try {
345
+ await fs.access(skillDir);
346
+ } catch {
347
+ return { success: false, error: `Skill "${source.skillName}" not found in skills/` };
348
+ }
349
+ } else {
350
+ // No specific path - find SKILL.md in the repo
351
+ const skillMdPath = await findSkillMd(tempDir);
352
+ if (!skillMdPath) {
353
+ return { success: false, error: 'No SKILL.md found in repository' };
354
+ }
355
+ skillDir = path.dirname(skillMdPath);
356
+ }
357
+
358
+ // Read SKILL.md to get skill name
359
+ const skillMdPath = path.join(skillDir, 'SKILL.md');
360
+ let skillContent: string;
361
+ try {
362
+ skillContent = await fs.readFile(skillMdPath, 'utf-8');
363
+ } catch {
364
+ return { success: false, error: 'SKILL.md not found in skill directory' };
365
+ }
366
+
367
+ const skillName = extractSkillName(skillContent);
368
+ if (!skillName) {
369
+ return { success: false, error: 'Could not extract skill name from SKILL.md' };
370
+ }
371
+
372
+ const skillPath = path.join(userSkillsPath, skillName);
373
+
374
+ // Check if skill already exists
375
+ try {
376
+ await fs.access(skillPath);
377
+ return { success: false, error: `Skill "${skillName}" already installed` };
378
+ } catch {
379
+ // Doesn't exist, proceed
380
+ }
381
+
382
+ // Copy skill files to user skills directory
383
+ await copyDir(skillDir, skillPath);
384
+
385
+ return { success: true, skillName, skillPath };
386
+ } catch (error) {
387
+ return { success: false, error: error instanceof Error ? error.message : String(error) };
388
+ } finally {
389
+ // Clean up temporary directory
390
+ if (tempDir) {
391
+ await rm(tempDir, { recursive: true, force: true }).catch(() => {});
392
+ }
393
+ }
394
+ }
395
+
396
+ /**
397
+ * Install skill from local path
398
+ */
399
+ async function installFromLocal(source: RemoteSource): Promise<InstallResult> {
400
+ const configManager = getConfigManager();
401
+ const userSkillsPath = configManager.getUserSkillsPath() || path.join(os.homedir(), '.xagent', 'skills');
402
+
403
+ try {
404
+ const resolvedPath = path.resolve(source.url);
405
+
406
+ // Check if source exists
407
+ await fs.access(resolvedPath);
408
+
409
+ // Find SKILL.md
410
+ const skillMdPath = await findSkillMd(resolvedPath);
411
+ if (!skillMdPath) {
412
+ return { success: false, error: 'SKILL.md not found in source directory' };
413
+ }
414
+
415
+ const content = await fs.readFile(skillMdPath, 'utf-8');
416
+ const skillName = extractSkillName(content);
417
+
418
+ if (!skillName) {
419
+ return { success: false, error: 'Could not extract skill name from SKILL.md' };
420
+ }
421
+
422
+ const skillPath = path.join(userSkillsPath, skillName);
423
+
424
+ // Check if skill already exists
425
+ try {
426
+ await fs.access(skillPath);
427
+ return { success: false, error: `Skill "${skillName}" already installed` };
428
+ } catch {
429
+ // Doesn't exist, proceed
430
+ }
431
+
432
+ // Copy the skill directory
433
+ const sourceDir = path.dirname(skillMdPath);
434
+ await copyDir(sourceDir, skillPath);
435
+
436
+ return { success: true, skillName, skillPath };
437
+ } catch (error) {
438
+ return { success: false, error: error instanceof Error ? error.message : String(error) };
439
+ }
440
+ }
441
+
442
+ /**
443
+ * Main function to install a skill from source
444
+ */
445
+ export async function installSkill(source: string): Promise<InstallResult> {
446
+ const parsed = parseSource(source);
447
+
448
+ switch (parsed.type) {
449
+ case 'direct-url':
450
+ return installFromDirectUrl(parsed);
451
+ case 'github':
452
+ return installFromGitHub(parsed);
453
+ case 'local':
454
+ return installFromLocal(parsed);
455
+ default:
456
+ return { success: false, error: 'Unknown source type' };
457
+ }
458
+ }
459
+
460
+ /**
461
+ * Remove an installed skill
462
+ */
463
+ export async function removeSkill(skillName: string): Promise<InstallResult> {
464
+ const configManager = getConfigManager();
465
+ const userSkillsPath = configManager.getUserSkillsPath() || path.join(os.homedir(), '.xagent', 'skills');
466
+ const skillPath = path.join(userSkillsPath, skillName);
467
+
468
+ try {
469
+ await fs.access(skillPath);
470
+ await removeDir(skillPath);
471
+ return { success: true, skillName, skillPath };
472
+ } catch {
473
+ return { success: false, error: `Skill "${skillName}" not found` };
474
+ }
475
+ }
476
+
477
+ /**
478
+ * List installed user skills
479
+ */
480
+ export async function listUserSkills(): Promise<Array<{ name: string; description: string; path: string }>> {
481
+ const configManager = getConfigManager();
482
+ const userSkillsPath = configManager.getUserSkillsPath() || path.join(os.homedir(), '.xagent', 'skills');
483
+
484
+ const skills: Array<{ name: string; description: string; path: string }> = [];
485
+
486
+ try {
487
+ const entries = await fs.readdir(userSkillsPath, { withFileTypes: true });
488
+
489
+ for (const entry of entries) {
490
+ if (entry.isDirectory()) {
491
+ const skillPath = path.join(userSkillsPath, entry.name);
492
+ const skillMdPath = path.join(skillPath, 'SKILL.md');
493
+
494
+ try {
495
+ const content = await fs.readFile(skillMdPath, 'utf-8');
496
+ const nameMatch = content.match(/^name:\s*(.+)$/m);
497
+ const descMatch = content.match(/^description:\s*(.+)$/m);
498
+
499
+ skills.push({
500
+ name: nameMatch ? nameMatch[1].trim() : entry.name,
501
+ description: descMatch ? descMatch[1].trim() : 'No description',
502
+ path: skillPath
503
+ });
504
+ } catch {
505
+ skills.push({
506
+ name: entry.name,
507
+ description: '(Missing SKILL.md)',
508
+ path: skillPath
509
+ });
510
+ }
511
+ }
512
+ }
513
+ } catch {
514
+ // Directory doesn't exist or is empty
515
+ }
516
+
517
+ return skills;
518
+ }