@spacebar_ai/moldclaw-core 2026.3.14 → 2026.3.16

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 (1074) hide show
  1. package/README.md +108 -3
  2. package/dist/account-id-plS5L20e.d.ts +1 -0
  3. package/dist/accounts-BAYVGC2k.js +109 -0
  4. package/dist/accounts-DrjRgReV.d.ts +103 -0
  5. package/dist/acp-cli-at_UYEOS.js +2088 -0
  6. package/dist/acpx-Chy1GQ_k.d.ts +5 -0
  7. package/dist/actions.runtime-C0F7dMfO.js +114 -0
  8. package/dist/actions.runtime-caI2LG9o.js +128 -0
  9. package/dist/agent-media-payload-CkpAqaOh.d.ts +16 -0
  10. package/dist/agents-B98yPGc5.js +853 -0
  11. package/dist/agents-BrLr08L3.js +217 -0
  12. package/dist/allow-from-BIwT4dl7.d.ts +42 -0
  13. package/dist/allow-list-CHt7yvAf.js +81 -0
  14. package/dist/allowlist-CxQo2wQc.js +142 -0
  15. package/dist/allowlist-resolution-B7ib7gye.d.ts +17 -0
  16. package/dist/api-Co7TNHbL.js +6953 -0
  17. package/dist/api-cEQ_ql_8.js +112 -0
  18. package/dist/audit-AnKnnlaZ.js +787 -0
  19. package/dist/audit-channel.collect.runtime-CAk1DFQ3.js +600 -0
  20. package/dist/audit-channel.runtime-5phdZp_m.js +116 -0
  21. package/dist/audit-extra.async-B8ZXFxic.js +813 -0
  22. package/dist/audit-hdKa3D-u.js +54 -0
  23. package/dist/audit-membership-runtime-CJV5XvGU.js +157 -0
  24. package/dist/audit.deep.runtime-DNMcRQrp.js +24 -0
  25. package/dist/audit.nondeep.runtime-DhNDL6yM.js +831 -0
  26. package/dist/audit.runtime-Bx7uWEh8.js +113 -0
  27. package/dist/auth-choice-C37W9MA7.js +268 -0
  28. package/dist/auth-choice-CNppOY_V.js +117 -0
  29. package/dist/auth-choice-XYFnp6fI.js +502 -0
  30. package/dist/auth-choice-options-D6oZY4Xo.js +123 -0
  31. package/dist/auth-choice-prompt-BhRqchJx.js +110 -0
  32. package/dist/auth-choice-prompt-C1xv0N08.js +36 -0
  33. package/dist/auth-choice.plugin-providers.runtime-DhLEtbmR.js +114 -0
  34. package/dist/auth-profiles-9zZdaXJK.js +127756 -0
  35. package/dist/auth-profiles.runtime-HONFDgiu.js +111 -0
  36. package/dist/bluebubbles-BY8JhO4y.js +64 -0
  37. package/dist/bluebubbles-CQjEnzK_.d.ts +6 -0
  38. package/dist/bluebubbles-RmcKgkBa.d.ts +45 -0
  39. package/dist/boolean-param-F1sMwnPu.d.ts +5 -0
  40. package/dist/bot-BGh-ATV7.d.ts +478 -0
  41. package/dist/brave-CljenznH.js +24 -0
  42. package/dist/browser-cli-CX8i0wf0.js +1492 -0
  43. package/dist/build-info.json +3 -3
  44. package/dist/bundled/boot-md/handler.d.ts +6 -0
  45. package/dist/bundled/boot-md/handler.js +26 -26
  46. package/dist/bundled/bootstrap-extra-files/handler.d.ts +6 -0
  47. package/dist/bundled/command-logger/handler.d.ts +9 -0
  48. package/dist/bundled/session-memory/handler.d.ts +9 -0
  49. package/dist/bundled/session-memory/handler.js +27 -27
  50. package/dist/call-Bc257L16.js +37 -0
  51. package/dist/call-DYFR7oGy.js +639 -0
  52. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  53. package/dist/channel-Bd-igGEW.js +803 -0
  54. package/dist/channel-BgRMb6bZ.js +575 -0
  55. package/dist/channel-BtcLrU6J.js +1598 -0
  56. package/dist/channel-Bwf6m_hD.js +538 -0
  57. package/dist/channel-C7-kgDBd.js +562 -0
  58. package/dist/channel-CEXOAxIc.js +949 -0
  59. package/dist/channel-CpZ3p9MJ.js +226 -0
  60. package/dist/channel-CqBlN6A2.js +619 -0
  61. package/dist/channel-DKhfHW4U.js +352 -0
  62. package/dist/channel-DS3t_KdJ2.js +316 -0
  63. package/dist/channel-DY24FA1v.js +4681 -0
  64. package/dist/channel-DYFGmImJ.js +542 -0
  65. package/dist/channel-DcyIqX5p.js +207 -0
  66. package/dist/channel-J-2XcAli.js +214 -0
  67. package/dist/channel-N616f4gZ.js +306 -0
  68. package/dist/channel-NY7aU2Gj.js +397 -0
  69. package/dist/channel-PNI8BOmm.js +1321 -0
  70. package/dist/channel-UcXepDJs.js +943 -0
  71. package/dist/channel-account-context-CL3hEq1j.js +103 -0
  72. package/dist/channel-config-schema-Q2nzcCCR.d.ts +1 -0
  73. package/dist/channel-jA_jodJo.js +920 -0
  74. package/dist/channel-options-CtgU5qkG.js +50 -0
  75. package/dist/channel-policy-7wXDp6d3.d.ts +1 -0
  76. package/dist/channel-rGI8uig4.js +497 -0
  77. package/dist/channel-summary-DGJZXo0r.js +106 -0
  78. package/dist/channel.runtime--WZvlNJM.js +413 -0
  79. package/dist/channel.runtime-B0ct42DL.js +122 -0
  80. package/dist/channel.runtime-BEZUZrYB.js +177 -0
  81. package/dist/channel.runtime-BMuWmsIC.js +166 -0
  82. package/dist/channel.runtime-BtvHP0po.js +4006 -0
  83. package/dist/channel.runtime-Cwf993pX.js +194 -0
  84. package/dist/channel.runtime-Cy4lEpTX.js +174 -0
  85. package/dist/channel.runtime-DAz6axda.js +865 -0
  86. package/dist/channel.runtime-DdQ2mOVh.js +236 -0
  87. package/dist/channel.runtime-Dy3HPgOU.js +399 -0
  88. package/dist/channel.runtime-iqfC25k7.js +213 -0
  89. package/dist/channel.setup-B4VYMZlQ.js +9 -0
  90. package/dist/channel.setup-BohGbCbI.js +57 -0
  91. package/dist/channel.setup-Bq2AQqqc.js +6 -0
  92. package/dist/channel.setup-BxiSfLp1.js +8 -0
  93. package/dist/channel.setup-DOUS6fjO.js +8 -0
  94. package/dist/channel.setup-DXhdYU3g.js +9 -0
  95. package/dist/channel.setup-N51CgfNy.js +11 -0
  96. package/dist/channels/plugins/actions/discord.d.ts +3 -0
  97. package/dist/channels/plugins/actions/discord.js +26 -26
  98. package/dist/channels/plugins/actions/signal.d.ts +2 -0
  99. package/dist/channels/plugins/actions/signal.js +26 -26
  100. package/dist/channels/plugins/actions/telegram.d.ts +3 -0
  101. package/dist/channels/plugins/actions/telegram.js +26 -26
  102. package/dist/channels/plugins/agent-tools/whatsapp-login.d.ts +4 -0
  103. package/dist/channels/plugins/agent-tools/whatsapp-login.js +26 -26
  104. package/dist/channels-CueeFf0q.js +404 -0
  105. package/dist/channels-PheAd73E.js +1113 -0
  106. package/dist/channels-cli-CXzVF84v.js +286 -0
  107. package/dist/channels-status-issues-BjWBQHhU.js +16 -0
  108. package/dist/chat-type-BlSN0vo4.d.ts +5 -0
  109. package/dist/clawbot-cli-BBehDXW1.js +113 -0
  110. package/dist/cli/daemon-cli.d.ts +58 -0
  111. package/dist/cli/daemon-cli.js +1 -1
  112. package/dist/cli-CIm7d5Id.js +149 -0
  113. package/dist/command-format-pq3tS8t2.d.ts +4 -0
  114. package/dist/command-registry-CDkp__KH.js +13 -0
  115. package/dist/command-registry-DSEkUBW1.js +212 -0
  116. package/dist/command-secret-gateway-CqP_o0n8.js +106 -0
  117. package/dist/compact.runtime-Qm_csEtG.js +111 -0
  118. package/dist/completion-cli-Ch1sgSLQ.js +445 -0
  119. package/dist/completion-cli-vF067Tso.js +16 -0
  120. package/dist/config-B2W1zTP1.js +44 -0
  121. package/dist/config-CMhKplgO.js +938 -0
  122. package/dist/config-DchtRsvs.js +30 -0
  123. package/dist/config-cli-C41d88_c.js +428 -0
  124. package/dist/config-guard-B_vjkXCQ.js +117 -0
  125. package/dist/config-schema-pPBCF4hz.js +31 -0
  126. package/dist/config-validation-6om9cBUx.js +262 -0
  127. package/dist/config-value-Dl3XEpA6.js +132 -0
  128. package/dist/configure-BxzvDSzu.js +1100 -0
  129. package/dist/configure-CLMLoWAn.js +238 -0
  130. package/dist/control-ui-shared-E8Nz6uKZ.js +29 -0
  131. package/dist/core-Cd3fMFKq.d.ts +87 -0
  132. package/dist/credentials-yYt6VWCq.js +268 -0
  133. package/dist/cron-cli-CA3lV3kh.js +634 -0
  134. package/dist/daemon-cli-BtQuIXEk.js +339 -0
  135. package/dist/daemon-install-BWKGzgMm.js +175 -0
  136. package/dist/deliver-CgMNmfTy.js +106 -0
  137. package/dist/deliver-runtime-Bn1KWoiQ.js +106 -0
  138. package/dist/devices-cli-D601npiL.js +340 -0
  139. package/dist/diagnostic-CkiYEGqt.js +310 -0
  140. package/dist/diffs-B5tZ8Coj.d.ts +1 -0
  141. package/dist/directory-cli-skEV8MT7.js +306 -0
  142. package/dist/directory-config-helpers-B-tiBKIv.d.ts +38 -0
  143. package/dist/directory-runtime-BEJ2fCIR.d.ts +1 -0
  144. package/dist/directory.static-CnyzoWbV.js +44 -0
  145. package/dist/discord-B_gbzPti.js +109 -0
  146. package/dist/discovery-CqI-e_Mv.js +48 -0
  147. package/dist/dm-policy-shared-nybkS1uP.d.ts +95 -0
  148. package/dist/dns-cli-Cjes3Ruw.js +216 -0
  149. package/dist/docs-cli-C3g3Gi_d.js +173 -0
  150. package/dist/doctor-completion-TvgV4SZH.js +90 -0
  151. package/dist/doctor-config-flow-0w9Ux7V8.js +107 -0
  152. package/dist/doctor-config-flow-DLzr8W7Y.js +2437 -0
  153. package/dist/enable-VYzv8b2z.js +24 -0
  154. package/dist/entry.d.ts +7 -0
  155. package/dist/entry.js +1 -1
  156. package/dist/env-overrides-DYVIkuvN.js +434 -0
  157. package/dist/env-overrides.runtime-6kijpIuu.js +17 -0
  158. package/dist/exec-approvals-cli-D_lkTG-l.js +419 -0
  159. package/dist/exec-sVmouhA9.d.ts +39 -0
  160. package/dist/extensions/acpx/index.d.ts +11 -0
  161. package/dist/extensions/acpx/index.js +1 -1
  162. package/dist/extensions/amazon-bedrock/index.d.ts +11 -0
  163. package/dist/extensions/anthropic/index.d.ts +11 -0
  164. package/dist/extensions/anthropic/index.js +26 -26
  165. package/dist/extensions/bluebubbles/index.d.ts +11 -0
  166. package/dist/extensions/bluebubbles/index.js +30 -30
  167. package/dist/extensions/bluebubbles/setup-entry.d.ts +59 -0
  168. package/dist/extensions/bluebubbles/setup-entry.js +30 -30
  169. package/dist/extensions/brave/index.d.ts +11 -0
  170. package/dist/extensions/brave/index.js +2 -2
  171. package/dist/extensions/byteplus/index.d.ts +11 -0
  172. package/dist/extensions/byteplus/index.js +26 -26
  173. package/dist/extensions/cloudflare-ai-gateway/index.d.ts +11 -0
  174. package/dist/extensions/cloudflare-ai-gateway/index.js +27 -27
  175. package/dist/extensions/copilot-proxy/index.d.ts +11 -0
  176. package/dist/extensions/device-pair/index.d.ts +12 -0
  177. package/dist/extensions/diagnostics-otel/index.d.ts +11 -0
  178. package/dist/extensions/diffs/index.d.ts +11 -0
  179. package/dist/extensions/discord/index.d.ts +11 -0
  180. package/dist/extensions/discord/index.js +31 -31
  181. package/dist/extensions/discord/setup-entry.d.ts +7 -0
  182. package/dist/extensions/discord/setup-entry.js +29 -29
  183. package/dist/extensions/elevenlabs/index.d.ts +11 -0
  184. package/dist/extensions/elevenlabs/index.js +26 -26
  185. package/dist/extensions/feishu/index.d.ts +229 -0
  186. package/dist/extensions/feishu/index.js +31 -31
  187. package/dist/extensions/feishu/setup-entry.d.ts +9 -0
  188. package/dist/extensions/feishu/setup-entry.js +28 -28
  189. package/dist/extensions/firecrawl/index.d.ts +11 -0
  190. package/dist/extensions/firecrawl/index.js +26 -26
  191. package/dist/extensions/github-copilot/index.d.ts +11 -0
  192. package/dist/extensions/github-copilot/index.js +27 -27
  193. package/dist/extensions/google/index.d.ts +11 -0
  194. package/dist/extensions/google/index.js +26 -26
  195. package/dist/extensions/googlechat/index.d.ts +11 -0
  196. package/dist/extensions/googlechat/index.js +30 -30
  197. package/dist/extensions/googlechat/setup-entry.d.ts +19 -0
  198. package/dist/extensions/googlechat/setup-entry.js +30 -30
  199. package/dist/extensions/huggingface/index.d.ts +11 -0
  200. package/dist/extensions/huggingface/index.js +26 -26
  201. package/dist/extensions/imessage/index.d.ts +11 -0
  202. package/dist/extensions/imessage/index.js +30 -30
  203. package/dist/extensions/imessage/setup-entry.d.ts +7 -0
  204. package/dist/extensions/imessage/setup-entry.js +30 -30
  205. package/dist/extensions/irc/index.d.ts +11 -0
  206. package/dist/extensions/irc/index.js +29 -29
  207. package/dist/extensions/irc/setup-entry.d.ts +8 -0
  208. package/dist/extensions/irc/setup-entry.js +29 -29
  209. package/dist/extensions/kakao-talkchannel/index.d.ts +19 -0
  210. package/dist/extensions/kakao-talkchannel/index.js +1762 -0
  211. package/dist/extensions/kakao-talkchannel/moldclaw.plugin.json +111 -0
  212. package/dist/extensions/kakao-talkchannel/package.json +12 -0
  213. package/dist/extensions/kilocode/index.d.ts +11 -0
  214. package/dist/extensions/kilocode/index.js +26 -26
  215. package/dist/extensions/kimi-coding/index.d.ts +11 -0
  216. package/dist/extensions/kimi-coding/index.js +26 -26
  217. package/dist/extensions/line/index.d.ts +11 -0
  218. package/dist/extensions/line/index.js +28 -28
  219. package/dist/extensions/line/setup-entry.d.ts +7 -0
  220. package/dist/extensions/line/setup-entry.js +28 -28
  221. package/dist/extensions/llm-task/index.d.ts +11 -0
  222. package/dist/extensions/llm-task/index.js +28 -28
  223. package/dist/extensions/lobster/index.d.ts +11 -0
  224. package/dist/extensions/matrix/index.d.ts +11 -0
  225. package/dist/extensions/matrix/index.js +31 -31
  226. package/dist/extensions/matrix/setup-entry.d.ts +20 -0
  227. package/dist/extensions/matrix/setup-entry.js +31 -31
  228. package/dist/extensions/mattermost/index.d.ts +11 -0
  229. package/dist/extensions/mattermost/index.js +28 -28
  230. package/dist/extensions/mattermost/setup-entry.d.ts +88 -0
  231. package/dist/extensions/mattermost/setup-entry.js +28 -28
  232. package/dist/extensions/memory-core/index.d.ts +11 -0
  233. package/dist/extensions/memory-lancedb/index.d.ts +25 -0
  234. package/dist/extensions/microsoft/index.d.ts +11 -0
  235. package/dist/extensions/microsoft/index.js +26 -26
  236. package/dist/extensions/minimax/index.d.ts +11 -0
  237. package/dist/extensions/minimax/index.js +26 -26
  238. package/dist/extensions/mistral/index.d.ts +11 -0
  239. package/dist/extensions/mistral/index.js +26 -26
  240. package/dist/extensions/modelstudio/index.d.ts +11 -0
  241. package/dist/extensions/modelstudio/index.js +26 -26
  242. package/dist/extensions/moonshot/index.d.ts +11 -0
  243. package/dist/extensions/moonshot/index.js +26 -26
  244. package/dist/extensions/msteams/index.d.ts +11 -0
  245. package/dist/extensions/msteams/index.js +31 -31
  246. package/dist/extensions/msteams/setup-entry.d.ts +11 -0
  247. package/dist/extensions/msteams/setup-entry.js +31 -31
  248. package/dist/extensions/nextcloud-talk/index.d.ts +11 -0
  249. package/dist/extensions/nextcloud-talk/index.js +28 -28
  250. package/dist/extensions/nextcloud-talk/setup-entry.d.ts +60 -0
  251. package/dist/extensions/nextcloud-talk/setup-entry.js +28 -28
  252. package/dist/extensions/nostr/index.d.ts +11 -0
  253. package/dist/extensions/nostr/index.js +28 -28
  254. package/dist/extensions/nostr/setup-entry.d.ts +49 -0
  255. package/dist/extensions/nostr/setup-entry.js +28 -28
  256. package/dist/extensions/nvidia/index.d.ts +11 -0
  257. package/dist/extensions/ollama/index.d.ts +11 -0
  258. package/dist/extensions/open-prose/index.d.ts +11 -0
  259. package/dist/extensions/openai/index.d.ts +11 -0
  260. package/dist/extensions/openai/index.js +26 -26
  261. package/dist/extensions/opencode/index.d.ts +11 -0
  262. package/dist/extensions/opencode/index.js +26 -26
  263. package/dist/extensions/opencode-go/index.d.ts +11 -0
  264. package/dist/extensions/opencode-go/index.js +26 -26
  265. package/dist/extensions/openrouter/index.d.ts +11 -0
  266. package/dist/extensions/openrouter/index.js +26 -26
  267. package/dist/extensions/openshell/index.d.ts +11 -0
  268. package/dist/extensions/openshell/index.js +26 -26
  269. package/dist/extensions/perplexity/index.d.ts +11 -0
  270. package/dist/extensions/perplexity/index.js +2 -2
  271. package/dist/extensions/phone-control/index.d.ts +12 -0
  272. package/dist/extensions/qianfan/index.d.ts +11 -0
  273. package/dist/extensions/qianfan/index.js +26 -26
  274. package/dist/extensions/qwen-portal-auth/index.d.ts +12 -0
  275. package/dist/extensions/qwen-portal-auth/index.js +26 -26
  276. package/dist/extensions/sglang/index.d.ts +11 -0
  277. package/dist/extensions/sglang/index.js +26 -26
  278. package/dist/extensions/signal/index.d.ts +11 -0
  279. package/dist/extensions/signal/index.js +29 -29
  280. package/dist/extensions/signal/setup-entry.d.ts +7 -0
  281. package/dist/extensions/signal/setup-entry.js +29 -29
  282. package/dist/extensions/slack/index.d.ts +11 -0
  283. package/dist/extensions/slack/index.js +30 -30
  284. package/dist/extensions/slack/setup-entry.d.ts +7 -0
  285. package/dist/extensions/slack/setup-entry.js +29 -29
  286. package/dist/extensions/synology-chat/index.d.ts +11 -0
  287. package/dist/extensions/synology-chat/index.js +28 -28
  288. package/dist/extensions/synology-chat/setup-entry.d.ts +138 -0
  289. package/dist/extensions/synology-chat/setup-entry.js +28 -28
  290. package/dist/extensions/synthetic/index.d.ts +11 -0
  291. package/dist/extensions/synthetic/index.js +26 -26
  292. package/dist/extensions/talk-voice/index.d.ts +12 -0
  293. package/dist/extensions/talk-voice/index.js +26 -26
  294. package/dist/extensions/telegram/index.d.ts +11 -0
  295. package/dist/extensions/telegram/index.js +29 -29
  296. package/dist/extensions/telegram/setup-entry.d.ts +7 -0
  297. package/dist/extensions/telegram/setup-entry.js +28 -28
  298. package/dist/extensions/thread-ownership/index.d.ts +12 -0
  299. package/dist/extensions/tlon/index.d.ts +11 -0
  300. package/dist/extensions/tlon/index.js +28 -28
  301. package/dist/extensions/tlon/setup-entry.d.ts +7 -0
  302. package/dist/extensions/tlon/setup-entry.js +28 -28
  303. package/dist/extensions/together/index.d.ts +11 -0
  304. package/dist/extensions/together/index.js +26 -26
  305. package/dist/extensions/twitch/index.d.ts +39 -0
  306. package/dist/extensions/twitch/index.js +28 -28
  307. package/dist/extensions/venice/index.d.ts +11 -0
  308. package/dist/extensions/venice/index.js +26 -26
  309. package/dist/extensions/vercel-ai-gateway/index.d.ts +11 -0
  310. package/dist/extensions/vercel-ai-gateway/index.js +26 -26
  311. package/dist/extensions/vllm/index.d.ts +11 -0
  312. package/dist/extensions/vllm/index.js +26 -26
  313. package/dist/extensions/voice-call/index.d.ts +11 -0
  314. package/dist/extensions/voice-call/index.js +26 -26
  315. package/dist/extensions/volcengine/index.d.ts +11 -0
  316. package/dist/extensions/volcengine/index.js +26 -26
  317. package/dist/extensions/whatsapp/index.d.ts +11 -0
  318. package/dist/extensions/whatsapp/index.js +29 -29
  319. package/dist/extensions/whatsapp/setup-entry.d.ts +7 -0
  320. package/dist/extensions/whatsapp/setup-entry.js +29 -29
  321. package/dist/extensions/xai/index.d.ts +11 -0
  322. package/dist/extensions/xai/index.js +26 -26
  323. package/dist/extensions/xiaomi/index.d.ts +11 -0
  324. package/dist/extensions/xiaomi/index.js +26 -26
  325. package/dist/extensions/zai/index.d.ts +11 -0
  326. package/dist/extensions/zai/index.js +26 -26
  327. package/dist/extensions/zalo/index.d.ts +11 -0
  328. package/dist/extensions/zalo/index.js +30 -30
  329. package/dist/extensions/zalo/setup-entry.d.ts +34 -0
  330. package/dist/extensions/zalo/setup-entry.js +30 -30
  331. package/dist/extensions/zalouser/index.d.ts +11 -0
  332. package/dist/extensions/zalouser/index.js +31 -31
  333. package/dist/extensions/zalouser/setup-entry.d.ts +42 -0
  334. package/dist/extensions/zalouser/setup-entry.js +31 -31
  335. package/dist/feishu-DCKEC3ao.d.ts +36 -0
  336. package/dist/gateway-cli-DN1Ii6J-.js +26432 -0
  337. package/dist/gateway-install-token-CJYFJBaC.js +163 -0
  338. package/dist/gateway-rpc-CroQg9MB.js +26 -0
  339. package/dist/gateway-runtime-D9FRZqKP.js +69 -0
  340. package/dist/googlechat-CBCkerAy.js +307 -0
  341. package/dist/googlechat-CSUNieHX.d.ts +12 -0
  342. package/dist/group-access-rSvkIglb.d.ts +61 -0
  343. package/dist/health-B6WwLJp4.js +570 -0
  344. package/dist/health-CAlJydXv.js +108 -0
  345. package/dist/history-BwNxb0sJ.d.ts +75 -0
  346. package/dist/hooks-BYlfU3Nf.d.ts +6 -0
  347. package/dist/hooks-cli-DuKmdo_H.js +995 -0
  348. package/dist/http-registry-DX_LVtuK.d.ts +20 -0
  349. package/dist/image-generation-DKkdRpve.d.ts +9 -0
  350. package/dist/imessage-7abjbe2Q.js +31 -0
  351. package/dist/imessage-DOH1yaDE.js +110 -0
  352. package/dist/inbound-envelope-CmvweL6U.d.ts +78 -0
  353. package/dist/inbound-reply-dispatch-BvnKTOec.js +71 -0
  354. package/dist/inbound-reply-dispatch-C7LjHRZN.d.ts +72 -0
  355. package/dist/index-DTQqfqj9.d.ts +1 -0
  356. package/dist/index.d.ts +27 -0
  357. package/dist/index.js +2 -2
  358. package/dist/infra/warning-filter.d.ts +10 -0
  359. package/dist/install-target-tXRD7VkM.js +574 -0
  360. package/dist/installs-C8fz8sm3.js +532 -0
  361. package/dist/io-C6XifaT4.js +9737 -0
  362. package/dist/io-C8awRnSW.js +28 -0
  363. package/dist/ipv4-d88_Jn2p.js +82 -0
  364. package/dist/irc-DpR6FXjN.js +672 -0
  365. package/dist/json-store-Sr_kk-II.d.ts +14 -0
  366. package/dist/keyed-async-queue-BA3BKukE.d.ts +19 -0
  367. package/dist/library-DOwowAGN.js +107 -0
  368. package/dist/lifecycle-core-BHHBoRTY.js +382 -0
  369. package/dist/line/accounts.d.ts +3 -0
  370. package/dist/line/send.d.ts +2 -0
  371. package/dist/line/send.js +4 -4
  372. package/dist/line/template-messages.d.ts +2 -0
  373. package/dist/line-8rsNbJCP.js +530 -0
  374. package/dist/line-D_cvIf6B.d.ts +75 -0
  375. package/dist/links-BOnvOj1z.d.ts +7 -0
  376. package/dist/llm-slug-generator-D9HjWtJT.js +67 -0
  377. package/dist/llm-slug-generator.d.ts +12 -0
  378. package/dist/llm-slug-generator.js +27 -27
  379. package/dist/logging-BhqLWxTD.js +13 -0
  380. package/dist/logging-DfaiL4OX.js +29 -0
  381. package/dist/login-qr-COBYR52w.js +233 -0
  382. package/dist/login-qr-xK4QIpPc.js +107 -0
  383. package/dist/logs-cli-RSSTw8L_.js +254 -0
  384. package/dist/manager-runtime-DL6JoSj9.js +106 -0
  385. package/dist/manager.runtime-Cbyhg1vB.js +710 -0
  386. package/dist/markdown-to-line-BTlEkOls.d.ts +91 -0
  387. package/dist/matrix-DX-jaB88.js +1490 -0
  388. package/dist/matrix-H6Yyj1QZ.d.ts +68 -0
  389. package/dist/matrix-J8s45tRw.js +1269 -0
  390. package/dist/mattermost-D75n6bRI.d.ts +6 -0
  391. package/dist/mcp-cli-CLc3_yCO.js +86 -0
  392. package/dist/media-understanding.runtime-BI0Lljbl.js +111 -0
  393. package/dist/memory-cli-CTp2cYrf.js +106 -0
  394. package/dist/method-scopes-Du8ODGFW.js +2586 -0
  395. package/dist/model-auth-markers-DEDakSUW.d.ts +20 -0
  396. package/dist/model-picker-CDBs7LJF.js +390 -0
  397. package/dist/model-picker-CRix4Wwv.js +107 -0
  398. package/dist/model-picker.runtime-CITyy3Rn.js +120 -0
  399. package/dist/model-suppression.runtime-Ce7D6QUT.js +111 -0
  400. package/dist/models-BK1eanuP.js +113 -0
  401. package/dist/models-X4Czy3uE.js +2514 -0
  402. package/dist/models-cli-C79Ulviy.js +304 -0
  403. package/dist/models-config-DALlu3S9.js +106 -0
  404. package/dist/models-config.providers.discovery-CSJ1STM1.d.ts +18 -0
  405. package/dist/monitor-B45a_RpX.js +3468 -0
  406. package/dist/monitor-C8KbJ-i0.js +767 -0
  407. package/dist/monitor-CIhrvegZ.js +3076 -0
  408. package/dist/monitor-CQut7klP.js +6823 -0
  409. package/dist/monitor-DZb5IJle.js +777 -0
  410. package/dist/monitor-DaFkdD27.js +108 -0
  411. package/dist/monitor-Do9Tp2Ii.js +110 -0
  412. package/dist/monitor-shared-CMK9cDOb.js +444 -0
  413. package/dist/msteams-A6H_wv5F.js +852 -0
  414. package/dist/net-DpMJgN-o.d.ts +19 -0
  415. package/dist/nextcloud-talk-f1pZ5Bge.d.ts +1 -0
  416. package/dist/node-cli-BXnmsjzL.js +2498 -0
  417. package/dist/node-resolve-CupmrA0Y.js +835 -0
  418. package/dist/nodes-cli-DZVrah_8.js +1375 -0
  419. package/dist/nostr-DMV534Ks.d.ts +7 -0
  420. package/dist/nostr-SAk3tjtR.js +8744 -0
  421. package/dist/npm-resolution-Dr9wssCY.js +60 -0
  422. package/dist/oauth-utils-DnyXdWU9.d.ts +10 -0
  423. package/dist/onboard-BE5pmb1g.js +589 -0
  424. package/dist/onboard-channels-3hNVY0E7.js +1241 -0
  425. package/dist/onboard-channels-vaO3nWLL.js +200 -0
  426. package/dist/onboard-custom-CI5uFyWH.js +571 -0
  427. package/dist/onboard-custom-eIvRswgv.js +109 -0
  428. package/dist/onboard-helpers-ChMWfUnl.js +335 -0
  429. package/dist/onboard-helpers-DRFi9oaD.js +108 -0
  430. package/dist/onboard-remote-BTspTgA4.js +112 -0
  431. package/dist/onboard-remote-so38yXlX.js +181 -0
  432. package/dist/onboard-search-DS0tZS24.js +297 -0
  433. package/dist/onboard-skills-B9DxCCiU.js +133 -0
  434. package/dist/onboard-skills-so0a_BJV.js +112 -0
  435. package/dist/outbound-media-BiJscGlR.js +11 -0
  436. package/dist/outbound-media-DJF-TuJu.d.ts +11 -0
  437. package/dist/pairing-access-CuiJP9xN.d.ts +21 -0
  438. package/dist/pairing-cli-DN0u1Cez.js +212 -0
  439. package/dist/parse-finite-number-B3FJTjyQ.d.ts +5 -0
  440. package/dist/perplexity-Bw1u3CAF.js +24 -0
  441. package/dist/persistent-dedupe-DR5Ka6BX.d.ts +26 -0
  442. package/dist/pi-model-discovery-runtime-iwKNCaYu.js +106 -0
  443. package/dist/pi-tools.before-tool-call.runtime-BM_N-JZe.js +380 -0
  444. package/dist/plugin-install--KVul05Z.js +184 -0
  445. package/dist/plugin-install-DVpPsLkS.js +112 -0
  446. package/dist/plugin-install-plan-Dwc6-coz.js +49 -0
  447. package/dist/plugin-registry-XRswugE9.js +108 -0
  448. package/dist/plugin-registry-jozQafRo.js +49 -0
  449. package/dist/plugin-sdk/account-resolution.js +26 -26
  450. package/dist/plugin-sdk/acp-runtime.js +26 -26
  451. package/dist/plugin-sdk/acpx.js +1 -1
  452. package/dist/plugin-sdk/agent-runtime.js +26 -26
  453. package/dist/plugin-sdk/bluebubbles.js +29 -29
  454. package/dist/plugin-sdk/channel-config-helpers.js +26 -26
  455. package/dist/plugin-sdk/channel-config-schema.js +2 -2
  456. package/dist/plugin-sdk/channel-policy.js +26 -26
  457. package/dist/plugin-sdk/channel-runtime.js +26 -26
  458. package/dist/plugin-sdk/compat.js +27 -27
  459. package/dist/plugin-sdk/config-runtime.js +28 -28
  460. package/dist/plugin-sdk/conversation-runtime.js +26 -26
  461. package/dist/plugin-sdk/discord.js +26 -26
  462. package/dist/plugin-sdk/feishu.js +27 -27
  463. package/dist/plugin-sdk/gateway-runtime.js +8 -8
  464. package/dist/plugin-sdk/googlechat.js +29 -29
  465. package/dist/plugin-sdk/image-generation-runtime.js +26 -26
  466. package/dist/plugin-sdk/image-generation.js +26 -26
  467. package/dist/plugin-sdk/imessage.js +27 -27
  468. package/dist/plugin-sdk/index.js +26 -26
  469. package/dist/plugin-sdk/infra-runtime.js +26 -26
  470. package/dist/plugin-sdk/irc.js +29 -29
  471. package/dist/plugin-sdk/line.js +27 -27
  472. package/dist/plugin-sdk/llm-task.js +26 -26
  473. package/dist/plugin-sdk/matrix.js +29 -29
  474. package/dist/plugin-sdk/mattermost.js +28 -28
  475. package/dist/plugin-sdk/media-runtime.js +26 -26
  476. package/dist/plugin-sdk/media-understanding-runtime.js +26 -26
  477. package/dist/plugin-sdk/media-understanding.js +26 -26
  478. package/dist/plugin-sdk/msteams.js +30 -30
  479. package/dist/plugin-sdk/nextcloud-talk.js +28 -28
  480. package/dist/plugin-sdk/nostr.js +27 -27
  481. package/dist/plugin-sdk/plugin-runtime.js +26 -26
  482. package/dist/plugin-sdk/provider-auth.js +28 -28
  483. package/dist/plugin-sdk/provider-setup.js +27 -27
  484. package/dist/plugin-sdk/provider-web-search.js +1 -1
  485. package/dist/plugin-sdk/qwen-portal-auth.js +26 -26
  486. package/dist/plugin-sdk/reply-history.js +26 -26
  487. package/dist/plugin-sdk/reply-runtime.js +26 -26
  488. package/dist/plugin-sdk/sandbox.js +26 -26
  489. package/dist/plugin-sdk/security-runtime.js +26 -26
  490. package/dist/plugin-sdk/self-hosted-provider-setup.js +27 -27
  491. package/dist/plugin-sdk/setup.js +27 -27
  492. package/dist/plugin-sdk/signal.js +26 -26
  493. package/dist/plugin-sdk/slack.js +26 -26
  494. package/dist/plugin-sdk/speech-runtime.js +26 -26
  495. package/dist/plugin-sdk/speech.js +26 -26
  496. package/dist/plugin-sdk/src/channels/plugins/setup-wizard-helpers.d.ts +3 -0
  497. package/dist/plugin-sdk/src/config/config-lock.d.ts +38 -0
  498. package/dist/plugin-sdk/src/config/config.d.ts +1 -1
  499. package/dist/plugin-sdk/src/config/io.d.ts +39 -0
  500. package/dist/plugin-sdk/src/config/types.gateway.d.ts +12 -0
  501. package/dist/plugin-sdk/src/config/types.secrets.d.ts +10 -0
  502. package/dist/plugin-sdk/src/config/zod-schema.d.ts +2 -0
  503. package/dist/plugin-sdk/src/gateway/credential-planner.d.ts +3 -1
  504. package/dist/plugin-sdk/src/secrets/provider-env-vars.d.ts +61 -0
  505. package/dist/plugin-sdk/src/secrets/sec1-placeholder.d.ts +181 -0
  506. package/dist/plugin-sdk/src/secrets/sec1-utils.d.ts +57 -0
  507. package/dist/plugin-sdk/synology-chat.js +27 -27
  508. package/dist/plugin-sdk/telegram.js +26 -26
  509. package/dist/plugin-sdk/text-runtime.js +4 -4
  510. package/dist/plugin-sdk/tlon.js +27 -27
  511. package/dist/plugin-sdk/twitch.js +26 -26
  512. package/dist/plugin-sdk/voice-call.js +26 -26
  513. package/dist/plugin-sdk/whatsapp.js +26 -26
  514. package/dist/plugin-sdk/zalo.js +30 -30
  515. package/dist/plugin-sdk/zalouser.js +29 -29
  516. package/dist/plugins/runtime/index.d.ts +22 -0
  517. package/dist/plugins/runtime/index.js +26 -26
  518. package/dist/plugins-C4PiDdjc.js +106 -0
  519. package/dist/plugins-cli-zhmliYNU.js +912 -0
  520. package/dist/policy-CcSolumc.js +143 -0
  521. package/dist/preflight-audio.runtime-BAbfqqzW.js +111 -0
  522. package/dist/probe-Bgt5c-cr.js +129 -0
  523. package/dist/probe-CPk5iGcg.js +47 -0
  524. package/dist/probe-DR4KRKXz.js +19 -0
  525. package/dist/probe-DnoCyJ_m.js +1793 -0
  526. package/dist/probe-VsLtK3vQ.js +6328 -0
  527. package/dist/probe-auth-BnsKrQt7.js +38 -0
  528. package/dist/probe-auth-DYdUG8l1.js +48 -0
  529. package/dist/program-8enYYBsc.js +247 -0
  530. package/dist/prompt-select-styled-DxBcUasv.js +2673 -0
  531. package/dist/provider-api-key-auth.runtime-DsLZyt6h.js +116 -0
  532. package/dist/provider-auth-choice-30EvRxqc.js +126 -0
  533. package/dist/provider-auth-choice-preference-DMr1WmRg.js +189 -0
  534. package/dist/provider-auth-choice.runtime-CI98BgQF.js +118 -0
  535. package/dist/provider-auth-guidance-WKDIi_wk.js +34 -0
  536. package/dist/provider-auth-result-Cs8wguSI.d.ts +18 -0
  537. package/dist/provider-models-EOys_Nvi.d.ts +867 -0
  538. package/dist/provider-ollama-setup-D89zlm9C.d.ts +32 -0
  539. package/dist/provider-onboard-BzOpgCLu.d.ts +40 -0
  540. package/dist/provider-runtime.runtime-Cm4as2KG.js +106 -0
  541. package/dist/provider-self-hosted-setup-Bmv_AQmw.d.ts +61 -0
  542. package/dist/provider-self-hosted-setup-CJwFVVB4.js +182 -0
  543. package/dist/provider-usage-CVNyLLDb.js +106 -0
  544. package/dist/provider-usage.types-CdTymHNu.d.ts +16 -0
  545. package/dist/provider-web-search-BJhXD5dH.js +2392 -0
  546. package/dist/provider-wizard-DMMYXjlW.js +152 -0
  547. package/dist/push-apns-BnWTdTEk.js +1038 -0
  548. package/dist/pw-ai-CtK_7Cy2.js +1866 -0
  549. package/dist/qr-cli-CA-BF0--.js +108 -0
  550. package/dist/qr-cli-D18HiUkh.js +369 -0
  551. package/dist/reactions-Df7XG8Uh.js +281 -0
  552. package/dist/read-only-account-inspect.discord.runtime-B-FP0mwb.js +111 -0
  553. package/dist/read-only-account-inspect.slack.runtime-DkWZ2ccW.js +111 -0
  554. package/dist/read-only-account-inspect.telegram.runtime-BnlTkn_e.js +111 -0
  555. package/dist/redact-snapshot-DVdstBvO.js +2661 -0
  556. package/dist/ref-contract-RPkB754Q.js +53 -0
  557. package/dist/register.agent-DVAxXQKW.js +434 -0
  558. package/dist/register.backup-CUuL5KUZ.js +624 -0
  559. package/dist/register.configure-bC0UEwfU.js +247 -0
  560. package/dist/register.maintenance-iIqvl_eT.js +569 -0
  561. package/dist/register.message-CEDd4z07.js +704 -0
  562. package/dist/register.onboard-Cejfnysy.js +187 -0
  563. package/dist/register.setup-DU7uHdYt.js +207 -0
  564. package/dist/register.status-health-sessions-BWphMXNR.js +493 -0
  565. package/dist/register.subclis-DnIweTEG.js +315 -0
  566. package/dist/register.subclis-gJX_Pbub.js +12 -0
  567. package/dist/registry-Dgwc-7eS.js +1183 -0
  568. package/dist/replies-D9PEZ8yn.js +110 -0
  569. package/dist/reply-history-lHgoC4l3.d.ts +1 -0
  570. package/dist/reply-payload-Bd2HuR4g.d.ts +46 -0
  571. package/dist/request-url-BcSJaiiu.d.ts +5 -0
  572. package/dist/resolve-BbsCHGLY.js +660 -0
  573. package/dist/resolve-channels-BtrGC95o.js +262 -0
  574. package/dist/resolve-channels-C1SthO1N.js +226 -0
  575. package/dist/resolve-users-CgSxHrU0.js +143 -0
  576. package/dist/routes-BZtqNrBf.js +7097 -0
  577. package/dist/rpc-D3KMxG4J.js +67 -0
  578. package/dist/run-command-C8b3dCZV.d.ts +16 -0
  579. package/dist/run-main-BlWJVotF.js +423 -0
  580. package/dist/runtime-RWGbO5Qy.d.ts +26 -0
  581. package/dist/runtime-discord-ops.runtime-DUXIYvQr.js +9073 -0
  582. package/dist/runtime-slack-ops.runtime-n1yFfyp1.js +4551 -0
  583. package/dist/runtime-telegram-ops.runtime-PZUWchjT.js +128 -0
  584. package/dist/runtime-whatsapp-login.runtime-xsuNyvGz.js +109 -0
  585. package/dist/runtime-whatsapp-outbound.runtime-5EfEyCsO.js +112 -0
  586. package/dist/sandbox-cli-Dw1nWNmQ.js +530 -0
  587. package/dist/search-manager-BJoRxOaf.js +15 -0
  588. package/dist/search-manager-DxkQvUrW.js +386 -0
  589. package/dist/secret-input-schema-Cp_La9qv.d.ts +19 -0
  590. package/dist/secrets-cli-BPyV2gSq.js +2065 -0
  591. package/dist/security-cli-EK4sSRfG.js +570 -0
  592. package/dist/send-B01Gvh9m.js +629 -0
  593. package/dist/send-B4L4wRJO.js +100 -0
  594. package/dist/send-BDcGrXt0.js +1025 -0
  595. package/dist/send-BRRtHxyR.js +283 -0
  596. package/dist/send-DU6dmMXW.js +631 -0
  597. package/dist/server-CWw5GFEg.js +106 -0
  598. package/dist/server-node-events-92cDVswC.js +501 -0
  599. package/dist/session-key-DbkfhOjM.d.ts +46 -0
  600. package/dist/sessions-B052uHA3.js +218 -0
  601. package/dist/sessions-Cef4dZNP.js +107 -0
  602. package/dist/setup-BlQPyDPy.js +387 -0
  603. package/dist/setup-DcSZ_pTn.d.ts +37 -0
  604. package/dist/setup-core-B9mdZYnU.js +166 -0
  605. package/dist/setup-core-Cj0sLkpP.js +47 -0
  606. package/dist/setup-core-CkZbebOv.js +143 -0
  607. package/dist/setup-core-MRNjnrJl.js +205 -0
  608. package/dist/setup-surface-3ZY0JtWE.js +490 -0
  609. package/dist/setup-wizard-helpers-Dwzb9Dcz.d.ts +203 -0
  610. package/dist/setup.finalize-B5ETm3Ui.js +517 -0
  611. package/dist/setup.gateway-config-C8hdtlbw.js +338 -0
  612. package/dist/setup.secret-input-BZSIeiqy.js +25 -0
  613. package/dist/shared--9_eQ_lc.js +75 -0
  614. package/dist/shared-CxkH3H0U.js +102 -0
  615. package/dist/shared-DTNL0hA9.js +298 -0
  616. package/dist/shared-HSP1OV-Q.js +96 -0
  617. package/dist/shared-UIjWb_3B.js +182 -0
  618. package/dist/signal-CTI6bSmB.js +109 -0
  619. package/dist/skills-4-r1mfJM.js +853 -0
  620. package/dist/skills-RNm54CBO.js +19 -0
  621. package/dist/skills-cli-te7dSs5p.js +291 -0
  622. package/dist/skills-install-Del-Ogv8.js +763 -0
  623. package/dist/skills-status-BZpoMXrR.js +169 -0
  624. package/dist/skills-status-Dq61Sz8U.js +20 -0
  625. package/dist/slack-oc-viUtl.js +109 -0
  626. package/dist/slash-commands.runtime-NdkD2LZV.js +123 -0
  627. package/dist/slash-dispatch.runtime-DQgeaF3J.js +136 -0
  628. package/dist/slash-skill-commands.runtime-DmOl2DnL.js +111 -0
  629. package/dist/src-0wtt7seR.js +1696 -0
  630. package/dist/status-5oR_gqv_.js +121 -0
  631. package/dist/status-BO8LY0hC.js +1599 -0
  632. package/dist/status-D_oHA9yO.js +126 -0
  633. package/dist/status-IrMacJRj.js +606 -0
  634. package/dist/status-Prdeg53E.js +43 -0
  635. package/dist/status-json-Da0hR-1Z.js +286 -0
  636. package/dist/status.link-channel-BgUJEZAz.js +138 -0
  637. package/dist/status.scan.deps.runtime-D9vHTxOW.js +121 -0
  638. package/dist/status.scan.runtime-D-EdD5CW.js +114 -0
  639. package/dist/status.summary--i6xduWH.js +592 -0
  640. package/dist/status.summary.runtime-BqMXjaBc.js +113 -0
  641. package/dist/subagent-orphan-recovery-DiRJcFQc.js +302 -0
  642. package/dist/subagent-registry-runtime-B66EYEYm.js +106 -0
  643. package/dist/synology-chat-BemXqdzG.js +297 -0
  644. package/dist/system-cli-CSuiia4-.js +92 -0
  645. package/dist/telegram/audit.d.ts +2 -0
  646. package/dist/telegram/audit.js +1 -1
  647. package/dist/telegram/token.d.ts +2 -0
  648. package/dist/telegram/token.js +26 -26
  649. package/dist/telegram-DLFcRv5a.js +109 -0
  650. package/dist/testing-DZrulv-n.d.ts +1755 -0
  651. package/dist/text-chunking-BaYBIUoR.d.ts +79 -0
  652. package/dist/text-chunking-C8kmbNfa.js +84 -0
  653. package/dist/thinking-D8aqmr3o.d.ts +13 -0
  654. package/dist/tlon-Bpr4f3yF.js +433 -0
  655. package/dist/tool-send-BHKm5ztm.d.ts +9 -0
  656. package/dist/tui-BY3QRgC1.js +3834 -0
  657. package/dist/tui-cli-CCfZOlV0.js +132 -0
  658. package/dist/types-CKx5nDZB.d.ts +45 -0
  659. package/dist/types-DBhDdMQd.d.ts +22670 -0
  660. package/dist/types.base-B_TkkSS8.d.ts +188 -0
  661. package/dist/types.secrets-Bojc4omL.js +92 -0
  662. package/dist/ui-1UpZZyI3.js +31 -0
  663. package/dist/update-BR4JvFpV.js +1036 -0
  664. package/dist/update-cli-BZv44lFq.js +1498 -0
  665. package/dist/update-offset-store-DGdBotIW.js +107 -0
  666. package/dist/update-runner-D34sooPe.js +1496 -0
  667. package/dist/vllm-defaults-BCGSJ7K0.d.ts +13 -0
  668. package/dist/wait-BU9vJv22.d.ts +4 -0
  669. package/dist/web-CXpU2D41.js +107 -0
  670. package/dist/web-shared-B4sL45ah.d.ts +45 -0
  671. package/dist/webhook-memory-guards-B7oLVseG.d.ts +43 -0
  672. package/dist/webhook-request-guards-CqIH7equ.d.ts +76 -0
  673. package/dist/webhook-targets-CAAGATtk.js +181 -0
  674. package/dist/webhook-targets-oQ0jd4r0.d.ts +106 -0
  675. package/dist/webhooks-cli-B46t2VT5.js +349 -0
  676. package/dist/whatsapp-Dniwd4Rv.js +109 -0
  677. package/dist/whatsapp-actions-fL46PsNs.js +162 -0
  678. package/dist/windows-spawn-DGeE98SH.d.ts +43 -0
  679. package/dist/workspace-dirs-d3Ms_ryk.js +2002 -0
  680. package/dist/zalo-Csulx0XK.d.ts +9 -0
  681. package/dist/zalo-gh0yAWmS.js +415 -0
  682. package/dist/zalouser-CuxRvztM.js +30911 -0
  683. package/dist/zod-schema.agent-runtime-B4MkB-_3.d.ts +10 -0
  684. package/dist/zod-schema.core-D5reNip6.js +541 -0
  685. package/dist/zod-schema.core-DN3RhEUG.d.ts +173 -0
  686. package/docs/SEC1.md +523 -0
  687. package/docs/SEC1_IMPLEMENTATION/CHANNELS_REPORT.md +173 -0
  688. package/docs/SEC1_IMPLEMENTATION/CORE_UTIL_REPORT.md +139 -0
  689. package/docs/SEC1_IMPLEMENTATION/DOCS_REPORT.md +134 -0
  690. package/docs/SEC1_IMPLEMENTATION/ENV_MAP_DRAFT.md +148 -0
  691. package/docs/SEC1_IMPLEMENTATION/INTEGRATION_REPORT.md +170 -0
  692. package/docs/SEC1_IMPLEMENTATION/PROVIDERS_REPORT.md +291 -0
  693. package/docs/SEC1_IMPLEMENTATION/QA_REPORT.md +249 -0
  694. package/docs/SEC1_IMPLEMENTATION/RECURSIVE_QA/wave1-channels.md +317 -0
  695. package/docs/SEC1_IMPLEMENTATION/RECURSIVE_QA/wave1-docs.md +212 -0
  696. package/docs/SEC1_IMPLEMENTATION/RECURSIVE_QA/wave1-security.md +368 -0
  697. package/docs/SEC1_IMPLEMENTATION/RECURSIVE_QA/wave2-critic-consolidated.md +195 -0
  698. package/docs/SEC1_IMPLEMENTATION/RECURSIVE_QA/wave3-fix-report.md +105 -0
  699. package/docs/SEC1_IMPLEMENTATION/STRATEGY.md +451 -0
  700. package/docs/SEC1_IMPLEMENTATION/TEST_REPORT.md +156 -0
  701. package/docs/pipeline-sdk/CLI_SPEC.md +609 -0
  702. package/docs/pipeline-sdk/PIPELINE_SDK_DESIGN.md +1372 -0
  703. package/extensions/kakao-talkchannel/MIGRATION_ARCH_ANALYSIS.md +455 -0
  704. package/extensions/kakao-talkchannel/MIGRATION_CODE_ANALYSIS.md +383 -0
  705. package/extensions/kakao-talkchannel/MIGRATION_STRATEGY.md +115 -0
  706. package/extensions/kakao-talkchannel/README.md +50 -0
  707. package/extensions/kakao-talkchannel/index.ts +20 -0
  708. package/extensions/kakao-talkchannel/moldclaw.plugin.json +98 -0
  709. package/extensions/kakao-talkchannel/package.json +12 -0
  710. package/extensions/kakao-talkchannel/src/adapters/config.ts +132 -0
  711. package/extensions/kakao-talkchannel/src/adapters/gateway.ts +974 -0
  712. package/extensions/kakao-talkchannel/src/adapters/outbound.ts +52 -0
  713. package/extensions/kakao-talkchannel/src/adapters/pairing.ts +35 -0
  714. package/extensions/kakao-talkchannel/src/adapters/security.ts +57 -0
  715. package/extensions/kakao-talkchannel/src/adapters/setup.ts +105 -0
  716. package/extensions/kakao-talkchannel/src/adapters/status.ts +117 -0
  717. package/extensions/kakao-talkchannel/src/channel.ts +58 -0
  718. package/extensions/kakao-talkchannel/src/commands/card.ts +413 -0
  719. package/extensions/kakao-talkchannel/src/config/schema.ts +129 -0
  720. package/extensions/kakao-talkchannel/src/kakao/callback.ts +133 -0
  721. package/extensions/kakao-talkchannel/src/kakao/limits.ts +129 -0
  722. package/extensions/kakao-talkchannel/src/kakao/payload.ts +138 -0
  723. package/extensions/kakao-talkchannel/src/kakao/response.ts +373 -0
  724. package/extensions/kakao-talkchannel/src/relay/client.ts +146 -0
  725. package/extensions/kakao-talkchannel/src/relay/session.ts +137 -0
  726. package/extensions/kakao-talkchannel/src/relay/sse.ts +258 -0
  727. package/extensions/kakao-talkchannel/src/relay/stream.ts +149 -0
  728. package/extensions/kakao-talkchannel/src/runtime.ts +21 -0
  729. package/extensions/kakao-talkchannel/src/types.ts +447 -0
  730. package/extensions/kakao-talkchannel/src/version.ts +3 -0
  731. package/extensions/kakao-talkchannel/tsconfig.json +19 -0
  732. package/package.json +23 -8
  733. package/skills/meshy/SKILL.md +69 -0
  734. package/skills/meshy/scripts/__pycache__/check_status.cpython-312.pyc +0 -0
  735. package/skills/meshy/scripts/__pycache__/image_to_3d.cpython-312.pyc +0 -0
  736. package/skills/meshy/scripts/__pycache__/text_to_3d.cpython-312.pyc +0 -0
  737. package/skills/meshy/scripts/check_status.py +147 -0
  738. package/skills/meshy/scripts/image_to_3d.py +229 -0
  739. package/skills/meshy/scripts/text_to_3d.py +214 -0
  740. package/skills/nano-banana-pro/scripts/generate_image.py +1 -1
  741. package/skills/openai-whisper-api/scripts/transcribe.sh +0 -0
  742. package/skills/tavily-search/SKILL.md +61 -0
  743. package/skills/tavily-search/scripts/__pycache__/search.cpython-312.pyc +0 -0
  744. package/skills/tavily-search/scripts/search.py +238 -0
  745. package/skills/video-frames/scripts/frame.sh +0 -0
  746. package/LICENSE +0 -21
  747. package/dist/accounts-UcSvD34O.js +0 -109
  748. package/dist/acp-cli-BPb8PgHP.js +0 -2088
  749. package/dist/actions.runtime-BL5QRooG.js +0 -114
  750. package/dist/actions.runtime-DSdfSo40.js +0 -128
  751. package/dist/agents-CHeX_5-H.js +0 -217
  752. package/dist/agents-DQRL9XKP.js +0 -853
  753. package/dist/allow-list-Boi79v-U.js +0 -81
  754. package/dist/allowlist-B2eBBeMF.js +0 -142
  755. package/dist/api-CFAtRSYL.js +0 -6953
  756. package/dist/api-D5JNJj8n.js +0 -112
  757. package/dist/audit-BM0GsdzV.js +0 -787
  758. package/dist/audit-BqRK9OSj.js +0 -54
  759. package/dist/audit-channel.collect.runtime-BPvDB8aq.js +0 -600
  760. package/dist/audit-channel.runtime-D3fzHiAo.js +0 -116
  761. package/dist/audit-extra.async-NveNIzX0.js +0 -813
  762. package/dist/audit-membership-runtime-mu470WFO.js +0 -157
  763. package/dist/audit.deep.runtime-RdxvW8Tj.js +0 -24
  764. package/dist/audit.nondeep.runtime-DDu8vA9Z.js +0 -831
  765. package/dist/audit.runtime-Y8C9W7s9.js +0 -113
  766. package/dist/auth-choice-C1CIxRsi.js +0 -268
  767. package/dist/auth-choice-CTvqWiDI.js +0 -117
  768. package/dist/auth-choice-Ddzko1B8.js +0 -502
  769. package/dist/auth-choice-options-BIAmAiCe.js +0 -123
  770. package/dist/auth-choice-prompt-B815kArz.js +0 -110
  771. package/dist/auth-choice-prompt-CGhTNCJx.js +0 -36
  772. package/dist/auth-choice.plugin-providers.runtime-AvAZ6S5W.js +0 -114
  773. package/dist/auth-profiles-BJcHzwPy.js +0 -127650
  774. package/dist/auth-profiles.runtime-CieFilK5.js +0 -111
  775. package/dist/bluebubbles-F8FGE9cH.js +0 -64
  776. package/dist/brave-BG5Yopn8.js +0 -24
  777. package/dist/browser-cli-Co7PJGZF.js +0 -1492
  778. package/dist/call-CoaQYq7c.js +0 -639
  779. package/dist/call-D3eu5Jjh.js +0 -37
  780. package/dist/channel-BftWD6yu.js +0 -1321
  781. package/dist/channel-Bub9U5Xg.js +0 -214
  782. package/dist/channel-C0oDs7TO.js +0 -4681
  783. package/dist/channel-C8CnEdkZ.js +0 -352
  784. package/dist/channel-CI-RC-xf.js +0 -497
  785. package/dist/channel-CY-hZCOJ.js +0 -397
  786. package/dist/channel-CbtGJB2x.js +0 -943
  787. package/dist/channel-CcfK3wP8.js +0 -803
  788. package/dist/channel-DBoDIeVj.js +0 -619
  789. package/dist/channel-DEq6Ecs-.js +0 -920
  790. package/dist/channel-DH4dhW1n.js +0 -226
  791. package/dist/channel-DQ_wdKg_.js +0 -575
  792. package/dist/channel-DT6qD1Ic.js +0 -207
  793. package/dist/channel-DZNAyxwr.js +0 -542
  794. package/dist/channel-DtakwAEe.js +0 -538
  795. package/dist/channel-DuYgH6p1.js +0 -562
  796. package/dist/channel-Hn-AN-d52.js +0 -316
  797. package/dist/channel-_R4hbD5h.js +0 -1598
  798. package/dist/channel-account-context-DXq8dlvI.js +0 -103
  799. package/dist/channel-kQmEVn3I.js +0 -306
  800. package/dist/channel-options-DHfxaklg.js +0 -50
  801. package/dist/channel-summary-DUpnoYhI.js +0 -106
  802. package/dist/channel-t-JxCWk6.js +0 -949
  803. package/dist/channel.runtime--GYriaXU.js +0 -213
  804. package/dist/channel.runtime-BJtn3GOH.js +0 -174
  805. package/dist/channel.runtime-BV7t_oNz.js +0 -166
  806. package/dist/channel.runtime-Bi8a3n9S.js +0 -865
  807. package/dist/channel.runtime-BjsYF0NN.js +0 -122
  808. package/dist/channel.runtime-BnI6YtmI.js +0 -413
  809. package/dist/channel.runtime-CQOftcCd.js +0 -194
  810. package/dist/channel.runtime-CuIAcPjZ.js +0 -4006
  811. package/dist/channel.runtime-DH1Q1G4k.js +0 -399
  812. package/dist/channel.runtime-DYYUPKxr.js +0 -236
  813. package/dist/channel.runtime-U5Gszsr5.js +0 -177
  814. package/dist/channel.setup-BQFHmgki.js +0 -9
  815. package/dist/channel.setup-BVoDwklu.js +0 -8
  816. package/dist/channel.setup-Bf73HsXr.js +0 -57
  817. package/dist/channel.setup-CblD4flM.js +0 -11
  818. package/dist/channel.setup-DgxlrPgz.js +0 -6
  819. package/dist/channel.setup-GLIAEVKL.js +0 -8
  820. package/dist/channel.setup-YTy5R1sz.js +0 -9
  821. package/dist/channels-CTL8iR9J.js +0 -404
  822. package/dist/channels-DBGvnjHY.js +0 -1113
  823. package/dist/channels-cli-BmVO5-sq.js +0 -286
  824. package/dist/channels-status-issues-kDtsWzA-.js +0 -16
  825. package/dist/clawbot-cli-DtcMJHqX.js +0 -113
  826. package/dist/cli-BNGECGVY.js +0 -149
  827. package/dist/command-registry-1SDrWgER.js +0 -13
  828. package/dist/command-registry-DNorYU4w.js +0 -212
  829. package/dist/command-secret-gateway-DqDZparO.js +0 -106
  830. package/dist/compact.runtime-C1ZN8UGb.js +0 -111
  831. package/dist/completion-cli-Q_Jt5Foc.js +0 -16
  832. package/dist/completion-cli-QkTXhuJh.js +0 -445
  833. package/dist/config-BbxrRaLf.js +0 -938
  834. package/dist/config-CkD8DJ7L.js +0 -44
  835. package/dist/config-cli-BoPrlYTp.js +0 -428
  836. package/dist/config-guard-CEhCvr_u.js +0 -117
  837. package/dist/config-schema-GQ6uWjXe.js +0 -31
  838. package/dist/config-validation-woE2_LpC.js +0 -262
  839. package/dist/config-value-Dh8m-CFf.js +0 -132
  840. package/dist/config-y4i5g7s4.js +0 -30
  841. package/dist/configure-DGRzwdFN.js +0 -1100
  842. package/dist/configure-S4AHE3k_.js +0 -238
  843. package/dist/control-ui-shared-kLBp4YlS.js +0 -29
  844. package/dist/credentials-D5uBf_C5.js +0 -265
  845. package/dist/cron-cli-lGupeVCW.js +0 -634
  846. package/dist/daemon-cli-Cs_edi0I.js +0 -339
  847. package/dist/daemon-install-DIFpP_qv.js +0 -175
  848. package/dist/deliver-DYa_DFZU.js +0 -106
  849. package/dist/deliver-runtime-DCW_o2Ot.js +0 -106
  850. package/dist/devices-cli-YsGOW2-w.js +0 -340
  851. package/dist/diagnostic-vMghIesG.js +0 -310
  852. package/dist/directory-cli-DtjMQjU5.js +0 -306
  853. package/dist/directory.static-DBZGvsdF.js +0 -44
  854. package/dist/discord-DYCu19HT.js +0 -109
  855. package/dist/discovery-DZYAoDF_.js +0 -48
  856. package/dist/dns-cli-DqW4pNgW.js +0 -216
  857. package/dist/docs-cli-Bu9TBlDU.js +0 -173
  858. package/dist/doctor-completion-B5hcQD5c.js +0 -90
  859. package/dist/doctor-config-flow-BBB2ZKfT.js +0 -107
  860. package/dist/doctor-config-flow-DDBYUS9f.js +0 -2437
  861. package/dist/enable-Tmsp8QuB.js +0 -24
  862. package/dist/env-overrides-BHxqjYZG.js +0 -434
  863. package/dist/env-overrides.runtime-Cz98bf-l.js +0 -17
  864. package/dist/exec-approvals-cli-wO5cYfMa.js +0 -419
  865. package/dist/gateway-cli-CFvDGhB9.js +0 -26429
  866. package/dist/gateway-install-token-CskJfo_N.js +0 -163
  867. package/dist/gateway-rpc-srYfBID9.js +0 -26
  868. package/dist/gateway-runtime-C76hUmUV.js +0 -69
  869. package/dist/googlechat-Cha5utST.js +0 -307
  870. package/dist/health-DDQYYsJy.js +0 -108
  871. package/dist/health-DXZykGaX.js +0 -570
  872. package/dist/hooks-cli-DfkurPYP.js +0 -995
  873. package/dist/imessage-B26k39pl.js +0 -110
  874. package/dist/imessage-Bp1_6cws.js +0 -31
  875. package/dist/inbound-reply-dispatch-DoIJLztA.js +0 -71
  876. package/dist/install-target-BjOuS4I8.js +0 -574
  877. package/dist/installs-Cz4k0W1Y.js +0 -532
  878. package/dist/io-B0OKifLZ.js +0 -28
  879. package/dist/io-DcoxdH6t.js +0 -9570
  880. package/dist/ipv4-CTQQ4_IW.js +0 -82
  881. package/dist/irc-B8vBDigm.js +0 -672
  882. package/dist/library-VCM_cQY4.js +0 -107
  883. package/dist/lifecycle-core-Ctz36PdQ.js +0 -382
  884. package/dist/line-B_uTLrdI.js +0 -530
  885. package/dist/llm-slug-generator-YWg0g2pj.js +0 -67
  886. package/dist/logging-S-5LPdfQ.js +0 -13
  887. package/dist/logging-ueBMCGMR.js +0 -29
  888. package/dist/login-qr-pcACm2Ng.js +0 -107
  889. package/dist/login-qr-pv-kxMfF.js +0 -233
  890. package/dist/logs-cli-RgADgSMO.js +0 -254
  891. package/dist/manager-runtime-BhTkoKmb.js +0 -106
  892. package/dist/manager.runtime-BjHzikoK.js +0 -710
  893. package/dist/matrix-C4EEu2Qp.js +0 -1490
  894. package/dist/matrix-Dfzcc5nV.js +0 -1269
  895. package/dist/mcp-cli-CJmOm9Oj.js +0 -86
  896. package/dist/media-understanding.runtime-DCETFCw_.js +0 -111
  897. package/dist/memory-cli-DFqd6tYx.js +0 -106
  898. package/dist/method-scopes-D-Q9dvbj.js +0 -2586
  899. package/dist/model-picker-Z-CUcuMr.js +0 -390
  900. package/dist/model-picker-v5mUsZ4J.js +0 -107
  901. package/dist/model-picker.runtime-A_z0dHfS.js +0 -120
  902. package/dist/model-suppression.runtime-QVWVJRr-.js +0 -111
  903. package/dist/models-Bbj0xV4F.js +0 -2514
  904. package/dist/models-D-OIjZqU.js +0 -113
  905. package/dist/models-cli-Bpn-5i4h.js +0 -304
  906. package/dist/models-config-Cwa5cJbC.js +0 -106
  907. package/dist/monitor-BchfCAaU.js +0 -6823
  908. package/dist/monitor-BydV44SP.js +0 -3076
  909. package/dist/monitor-CT8axwfm.js +0 -767
  910. package/dist/monitor-CZGWNOvn.js +0 -777
  911. package/dist/monitor-DN62r69g.js +0 -3468
  912. package/dist/monitor-DZ0fzJku.js +0 -110
  913. package/dist/monitor-DvNjzWFu.js +0 -108
  914. package/dist/monitor-shared-B-DBSlkQ.js +0 -444
  915. package/dist/msteams-Bf-wk2Rp.js +0 -852
  916. package/dist/node-cli-kH16TQI7.js +0 -2498
  917. package/dist/node-resolve-DfOpQmxm.js +0 -835
  918. package/dist/nodes-cli-CkAMXW5u.js +0 -1375
  919. package/dist/nostr-B8UGHclZ.js +0 -8744
  920. package/dist/npm-resolution-DmjlifII.js +0 -60
  921. package/dist/onboard-C883nfyw.js +0 -589
  922. package/dist/onboard-channels-Dc-BxN7p.js +0 -200
  923. package/dist/onboard-channels-j5EENtum.js +0 -1241
  924. package/dist/onboard-custom-0atne0C5.js +0 -571
  925. package/dist/onboard-custom-CWMqwjJx.js +0 -109
  926. package/dist/onboard-helpers-D3wWfH8F.js +0 -335
  927. package/dist/onboard-helpers-DZmRCe8l.js +0 -108
  928. package/dist/onboard-remote-Cn6kW-p0.js +0 -112
  929. package/dist/onboard-remote-Cx4w5VAk.js +0 -181
  930. package/dist/onboard-search-Ck9HRh2M.js +0 -297
  931. package/dist/onboard-skills-BtqrGioT.js +0 -133
  932. package/dist/onboard-skills-Dnw19Os8.js +0 -112
  933. package/dist/outbound-media-C5Nv4o18.js +0 -11
  934. package/dist/pairing-cli-Cwy9QZ_4.js +0 -212
  935. package/dist/perplexity-Brhpb45X.js +0 -24
  936. package/dist/pi-model-discovery-runtime-DIOdo6D8.js +0 -106
  937. package/dist/pi-tools.before-tool-call.runtime-CFM4gsDF.js +0 -380
  938. package/dist/plugin-install-BOV00hia.js +0 -112
  939. package/dist/plugin-install-Bak8fUBv.js +0 -184
  940. package/dist/plugin-install-plan-bKkEefRf.js +0 -49
  941. package/dist/plugin-registry-DxAXQUlZ.js +0 -108
  942. package/dist/plugin-registry-n0p3phem.js +0 -49
  943. package/dist/plugins-Ca3RK8Fi.js +0 -106
  944. package/dist/plugins-cli-BnC51H2R.js +0 -912
  945. package/dist/policy-BJv97w9e.js +0 -143
  946. package/dist/preflight-audio.runtime-BrFcf-6_.js +0 -111
  947. package/dist/probe-063xvvZc.js +0 -19
  948. package/dist/probe-BJEb2wGv.js +0 -1793
  949. package/dist/probe-CJQlxgsl.js +0 -47
  950. package/dist/probe-Caa2HznF.js +0 -6328
  951. package/dist/probe-CfL4tnJ6.js +0 -129
  952. package/dist/probe-auth-DN2Ec83-.js +0 -38
  953. package/dist/probe-auth-D_UKzu4m.js +0 -48
  954. package/dist/program-BOMdC7MC.js +0 -247
  955. package/dist/prompt-select-styled-DDnCfM3j.js +0 -2673
  956. package/dist/provider-api-key-auth.runtime-DUns3fwX.js +0 -116
  957. package/dist/provider-auth-choice-B_j1ctT2.js +0 -126
  958. package/dist/provider-auth-choice-preference-BaOBZ_Xn.js +0 -189
  959. package/dist/provider-auth-choice.runtime-DOako_zV.js +0 -118
  960. package/dist/provider-auth-guidance-CrjxnoNZ.js +0 -34
  961. package/dist/provider-runtime.runtime-BkOkgmTw.js +0 -106
  962. package/dist/provider-self-hosted-setup-BFDU6dRa.js +0 -182
  963. package/dist/provider-usage-CaDE0mqq.js +0 -106
  964. package/dist/provider-web-search-BR7etTjJ.js +0 -2392
  965. package/dist/provider-wizard-DCPdKUvb.js +0 -152
  966. package/dist/push-apns-B_OZjm4v.js +0 -1038
  967. package/dist/pw-ai-dG60P0hQ.js +0 -1866
  968. package/dist/qr-cli-DWfiw79I.js +0 -369
  969. package/dist/qr-cli-DwuKtyZQ.js +0 -108
  970. package/dist/reactions-CIGAPBn8.js +0 -281
  971. package/dist/read-only-account-inspect.discord.runtime-D54mnq8l.js +0 -111
  972. package/dist/read-only-account-inspect.slack.runtime-Bxs9ObMC.js +0 -111
  973. package/dist/read-only-account-inspect.telegram.runtime-UoVuf_Yo.js +0 -111
  974. package/dist/redact-snapshot-DZ3Vq-SC.js +0 -2657
  975. package/dist/ref-contract-D96lSYLs.js +0 -53
  976. package/dist/register.agent-2KmeahEL.js +0 -434
  977. package/dist/register.backup-ECBnWVR7.js +0 -624
  978. package/dist/register.configure-Doz1daCp.js +0 -247
  979. package/dist/register.maintenance-C33cV-WM.js +0 -569
  980. package/dist/register.message-CnL0NiF6.js +0 -704
  981. package/dist/register.onboard-BrYGZeQA.js +0 -187
  982. package/dist/register.setup-Bx6gEg6X.js +0 -207
  983. package/dist/register.status-health-sessions-FLb0CUOO.js +0 -493
  984. package/dist/register.subclis-BuqgaeIf.js +0 -12
  985. package/dist/register.subclis-DwdgfdnT.js +0 -315
  986. package/dist/registry-xhgvU89y.js +0 -1107
  987. package/dist/replies-hB2aipLu.js +0 -110
  988. package/dist/resolve-3ErMOltL.js +0 -660
  989. package/dist/resolve-channels-BV8GXuPe.js +0 -226
  990. package/dist/resolve-channels-CTY_XRIP.js +0 -262
  991. package/dist/resolve-users-DQ4Ne4Zc.js +0 -143
  992. package/dist/routes-BNDsNO_e.js +0 -7097
  993. package/dist/rpc-BLGTBWXq.js +0 -67
  994. package/dist/run-main-COAE4GlI.js +0 -423
  995. package/dist/runtime-discord-ops.runtime-Dxg-nlgd.js +0 -9073
  996. package/dist/runtime-slack-ops.runtime-Di474LJr.js +0 -4551
  997. package/dist/runtime-telegram-ops.runtime-Da8vgf3O.js +0 -128
  998. package/dist/runtime-whatsapp-login.runtime-DcouP4iF.js +0 -109
  999. package/dist/runtime-whatsapp-outbound.runtime-CYamaEJX.js +0 -112
  1000. package/dist/sandbox-cli-U5ZTxhxL.js +0 -530
  1001. package/dist/search-manager-CfizyEMk.js +0 -386
  1002. package/dist/search-manager-DaF2QP4s.js +0 -15
  1003. package/dist/secrets-cli-C0gytFip.js +0 -2065
  1004. package/dist/security-cli-C74EuLUO.js +0 -570
  1005. package/dist/send-BTLVBf_E.js +0 -631
  1006. package/dist/send-BlWWCEZE.js +0 -1025
  1007. package/dist/send-CfypD1B_.js +0 -100
  1008. package/dist/send-Cm9v3uhF.js +0 -283
  1009. package/dist/send-g2odQuYI.js +0 -629
  1010. package/dist/server-C8b5QJ2s.js +0 -106
  1011. package/dist/server-node-events-xqQe5xiu.js +0 -501
  1012. package/dist/sessions-CSSzvgPQ.js +0 -107
  1013. package/dist/sessions-z0GIvdKa.js +0 -218
  1014. package/dist/setup-D9XTmlF8.js +0 -387
  1015. package/dist/setup-core-BDrLOwYO.js +0 -143
  1016. package/dist/setup-core-CM7cY7_i.js +0 -166
  1017. package/dist/setup-core-CnmgANY-.js +0 -205
  1018. package/dist/setup-core-DgcjCKmG.js +0 -47
  1019. package/dist/setup-surface-DzRrVKYj.js +0 -490
  1020. package/dist/setup.finalize-UaPu_adv.js +0 -517
  1021. package/dist/setup.gateway-config-Djc1ceEh.js +0 -338
  1022. package/dist/setup.secret-input-BkczghbR.js +0 -25
  1023. package/dist/shared-BHizGoNk.js +0 -298
  1024. package/dist/shared-CUfYhQkP.js +0 -96
  1025. package/dist/shared-DYYqr9EC.js +0 -75
  1026. package/dist/shared-DthOxMRQ.js +0 -182
  1027. package/dist/shared-On_A5_hW.js +0 -102
  1028. package/dist/signal-D6px9PGZ.js +0 -109
  1029. package/dist/skills-B4h1k-SP.js +0 -853
  1030. package/dist/skills-Bto10BGB.js +0 -19
  1031. package/dist/skills-cli-CXGR3Y5j.js +0 -291
  1032. package/dist/skills-install-B1AlkK8C.js +0 -763
  1033. package/dist/skills-status-BsmJ_iSg.js +0 -20
  1034. package/dist/skills-status-DGdxY3OI.js +0 -169
  1035. package/dist/slack-B7vWFmxP.js +0 -109
  1036. package/dist/slash-commands.runtime-DXdAT84n.js +0 -123
  1037. package/dist/slash-dispatch.runtime-CNf2-9Aj.js +0 -136
  1038. package/dist/slash-skill-commands.runtime-CBjffHRX.js +0 -111
  1039. package/dist/src-Cp7P7T08.js +0 -1696
  1040. package/dist/status-158fWh4A.js +0 -43
  1041. package/dist/status-BJIVLJnb.js +0 -1599
  1042. package/dist/status-BQiBI6N9.js +0 -126
  1043. package/dist/status-CZipXGUu.js +0 -121
  1044. package/dist/status-ZZIVFLI-.js +0 -606
  1045. package/dist/status-json-BNUy5Mem.js +0 -286
  1046. package/dist/status.link-channel-B694y1Xu.js +0 -138
  1047. package/dist/status.scan.deps.runtime-BcoKEzQD.js +0 -121
  1048. package/dist/status.scan.runtime-CqScDt-p.js +0 -114
  1049. package/dist/status.summary-AMek7qvI.js +0 -592
  1050. package/dist/status.summary.runtime-XgkcQ_kr.js +0 -113
  1051. package/dist/subagent-orphan-recovery-CrCYTmFC.js +0 -302
  1052. package/dist/subagent-registry-runtime-Cg-YvLx3.js +0 -106
  1053. package/dist/synology-chat-0G85jIqQ.js +0 -297
  1054. package/dist/system-cli-kZtSxKNm.js +0 -92
  1055. package/dist/telegram-DV0Wy89w.js +0 -109
  1056. package/dist/text-chunking-C2J2Oeul.js +0 -84
  1057. package/dist/tlon-DmK1NUVP.js +0 -433
  1058. package/dist/tui-D3bNPLG7.js +0 -3834
  1059. package/dist/tui-cli-DtMp9k_s.js +0 -132
  1060. package/dist/types.secrets-DuSPmmWB.js +0 -80
  1061. package/dist/ui-CeGztSEL.js +0 -31
  1062. package/dist/update-De7VudzP.js +0 -1036
  1063. package/dist/update-cli-BH8Pb-So.js +0 -1498
  1064. package/dist/update-offset-store-syELkdEW.js +0 -107
  1065. package/dist/update-runner-Cq-Q40T9.js +0 -1496
  1066. package/dist/web-CjMtvfSq.js +0 -107
  1067. package/dist/webhook-targets-_jTR0Bb_.js +0 -181
  1068. package/dist/webhooks-cli-DQ6u2Qau.js +0 -349
  1069. package/dist/whatsapp-CyLk16SZ.js +0 -109
  1070. package/dist/whatsapp-actions-Dzr2Wzqw.js +0 -162
  1071. package/dist/workspace-dirs-L1_QQ9mB.js +0 -2002
  1072. package/dist/zalo-CrehfXvK.js +0 -415
  1073. package/dist/zalouser-D1QD-O-I.js +0 -30911
  1074. package/dist/zod-schema.core-CWxzqcUs.js +0 -541
@@ -1,1492 +0,0 @@
1
- import "./redact-fatrROh9.js";
2
- import "./errors-DOJWZqNo.js";
3
- import "./logger-BFfIIIKH.js";
4
- import "./paths-D6AgsMTU.js";
5
- import "./tmp-moldclaw-dir-DWF-d8qD.js";
6
- import { r as theme } from "./theme-BSXzMzAA.js";
7
- import { n as info, t as danger } from "./globals-DESrFYmC.js";
8
- import { m as defaultRuntime } from "./subsystem-S4LNMNHd.js";
9
- import "./ansi-BPhP6LBZ.js";
10
- import { t as parseBooleanValue } from "./boolean-D8Ha5nYV.js";
11
- import "./env-Dgex_t9p.js";
12
- import { S as shortenHomePath } from "./utils-rjVNXUns.js";
13
- import { t as formatDocsLink } from "./links-C5I443Xb.js";
14
- import { n as inheritOptionFromParent } from "./command-options-CYhpCq_H.js";
15
- import "./model-selection-DfA4esOK.js";
16
- import "./agent-scope-DA7O8MVG.js";
17
- import "./boundary-file-read-Y1cMjPlu.js";
18
- import "./logger-wrbK9-ju.js";
19
- import "./exec-CoBTyh8B.js";
20
- import "./workspace-CxNKYS0V.js";
21
- import { s as loadConfig } from "./io-DcoxdH6t.js";
22
- import "./host-env-security-xy11yVnm.js";
23
- import "./safe-text-BcUvBreN.js";
24
- import "./version-rW_3ob2o.js";
25
- import "./env-substitution-C9xZMTDL.js";
26
- import "./config-state-D1JkXt39.js";
27
- import "./network-mode-CE-ihBf6.js";
28
- import "./registry-DcDGl2X7.js";
29
- import "./manifest-registry-_0xclaVY.js";
30
- import "./ip-w605xvSx.js";
31
- import "./zod-schema.core-CWxzqcUs.js";
32
- import "./config-CkD8DJ7L.js";
33
- import "./audit-fs-SjcfoPO7.js";
34
- import "./resolve-3ErMOltL.js";
35
- import "./config-BbxrRaLf.js";
36
- import { t as formatCliCommand } from "./command-format-DIDjlImI.js";
37
- import "./tailnet-KyAU6tj_.js";
38
- import "./net-B_Iq_SVP.js";
39
- import "./credentials-D5uBf_C5.js";
40
- import { G as normalizeBrowserFormFieldValue, R as DEFAULT_UPLOAD_DIR, W as normalizeBrowserFormField, f as redactCdpUrl, z as resolveExistingPathsWithinRoot } from "./routes-BNDsNO_e.js";
41
- import "./path-alias-guards-B3ZKrId1.js";
42
- import "./ports-BVwQuCIR.js";
43
- import "./ports-lsof-DiY6GaAf.js";
44
- import "./image-ops-Uw4rEShL.js";
45
- import "./fs-safe-Da4H0IOU.js";
46
- import "./mime-_IkgFMS2.js";
47
- import "./message-channel-CKeDAoOT.js";
48
- import "./method-scopes-D-Q9dvbj.js";
49
- import "./call-CoaQYq7c.js";
50
- import { n as runCommandWithRuntime } from "./cli-utils-FHeUZLsT.js";
51
- import { t as formatHelpExamples } from "./help-format-1yV2Xzq7.js";
52
- import "./progress-BQSTKUhd.js";
53
- import { n as callGatewayFromCli, t as addGatewayClientOptions } from "./gateway-rpc-srYfBID9.js";
54
- //#region src/cli/browser-cli-shared.ts
55
- function normalizeQuery(query) {
56
- if (!query) return;
57
- const out = {};
58
- for (const [key, value] of Object.entries(query)) {
59
- if (value === void 0) continue;
60
- out[key] = String(value);
61
- }
62
- return Object.keys(out).length ? out : void 0;
63
- }
64
- async function callBrowserRequest(opts, params, extra) {
65
- const resolvedTimeoutMs = typeof extra?.timeoutMs === "number" && Number.isFinite(extra.timeoutMs) ? Math.max(1, Math.floor(extra.timeoutMs)) : typeof opts.timeout === "string" ? Number.parseInt(opts.timeout, 10) : void 0;
66
- const resolvedTimeout = typeof resolvedTimeoutMs === "number" && Number.isFinite(resolvedTimeoutMs) ? resolvedTimeoutMs : void 0;
67
- const timeout = typeof resolvedTimeout === "number" ? String(resolvedTimeout) : opts.timeout;
68
- const payload = await callGatewayFromCli("browser.request", {
69
- ...opts,
70
- timeout
71
- }, {
72
- method: params.method,
73
- path: params.path,
74
- query: normalizeQuery(params.query),
75
- body: params.body,
76
- timeoutMs: resolvedTimeout
77
- }, { progress: extra?.progress });
78
- if (payload === void 0) throw new Error("Unexpected browser.request response");
79
- return payload;
80
- }
81
- async function callBrowserResize(opts, params, extra) {
82
- return callBrowserRequest(opts, {
83
- method: "POST",
84
- path: "/act",
85
- query: params.profile ? { profile: params.profile } : void 0,
86
- body: {
87
- kind: "resize",
88
- width: params.width,
89
- height: params.height,
90
- targetId: params.targetId?.trim() || void 0
91
- }
92
- }, extra);
93
- }
94
- //#endregion
95
- //#region src/cli/browser-cli-actions-input/shared.ts
96
- function resolveBrowserActionContext(cmd, parentOpts) {
97
- const parent = parentOpts(cmd);
98
- return {
99
- parent,
100
- profile: parent?.browserProfile
101
- };
102
- }
103
- async function callBrowserAct(params) {
104
- return await callBrowserRequest(params.parent, {
105
- method: "POST",
106
- path: "/act",
107
- query: params.profile ? { profile: params.profile } : void 0,
108
- body: params.body
109
- }, { timeoutMs: params.timeoutMs ?? 2e4 });
110
- }
111
- function logBrowserActionResult(parent, result, successMessage) {
112
- if (parent?.json) {
113
- defaultRuntime.log(JSON.stringify(result, null, 2));
114
- return;
115
- }
116
- defaultRuntime.log(successMessage);
117
- }
118
- function requireRef(ref) {
119
- const refValue = typeof ref === "string" ? ref.trim() : "";
120
- if (!refValue) {
121
- defaultRuntime.error(danger("ref is required"));
122
- defaultRuntime.exit(1);
123
- return null;
124
- }
125
- return refValue;
126
- }
127
- async function readFile(path) {
128
- return await (await import("node:fs/promises")).readFile(path, "utf8");
129
- }
130
- async function readFields(opts) {
131
- const payload = opts.fieldsFile ? await readFile(opts.fieldsFile) : opts.fields ?? "";
132
- if (!payload.trim()) throw new Error("fields are required");
133
- const parsed = JSON.parse(payload);
134
- if (!Array.isArray(parsed)) throw new Error("fields must be an array");
135
- return parsed.map((entry, index) => {
136
- if (!entry || typeof entry !== "object") throw new Error(`fields[${index}] must be an object`);
137
- const rec = entry;
138
- const parsedField = normalizeBrowserFormField(rec);
139
- if (!parsedField) throw new Error(`fields[${index}] must include ref`);
140
- if (rec.value === void 0 || rec.value === null || normalizeBrowserFormFieldValue(rec.value) !== void 0) return parsedField;
141
- throw new Error(`fields[${index}].value must be string, number, boolean, or null`);
142
- });
143
- }
144
- //#endregion
145
- //#region src/cli/browser-cli-actions-input/register.element.ts
146
- function registerBrowserElementCommands(browser, parentOpts) {
147
- const runElementAction = async (params) => {
148
- const { parent, profile } = resolveBrowserActionContext(params.cmd, parentOpts);
149
- try {
150
- const result = await callBrowserAct({
151
- parent,
152
- profile,
153
- body: params.body,
154
- timeoutMs: params.timeoutMs
155
- });
156
- logBrowserActionResult(parent, result, typeof params.successMessage === "function" ? params.successMessage(result) : params.successMessage);
157
- } catch (err) {
158
- defaultRuntime.error(danger(String(err)));
159
- defaultRuntime.exit(1);
160
- }
161
- };
162
- browser.command("click").description("Click an element by ref from snapshot").argument("<ref>", "Ref id from snapshot").option("--target-id <id>", "CDP target id (or unique prefix)").option("--double", "Double click", false).option("--button <left|right|middle>", "Mouse button to use").option("--modifiers <list>", "Comma-separated modifiers (Shift,Alt,Meta)").action(async (ref, opts, cmd) => {
163
- const refValue = requireRef(ref);
164
- if (!refValue) return;
165
- const modifiers = opts.modifiers ? String(opts.modifiers).split(",").map((v) => v.trim()).filter(Boolean) : void 0;
166
- await runElementAction({
167
- cmd,
168
- body: {
169
- kind: "click",
170
- ref: refValue,
171
- targetId: opts.targetId?.trim() || void 0,
172
- doubleClick: Boolean(opts.double),
173
- button: opts.button?.trim() || void 0,
174
- modifiers
175
- },
176
- successMessage: (result) => {
177
- const url = result.url;
178
- return `clicked ref ${refValue}${typeof url === "string" && url ? ` on ${url}` : ""}`;
179
- }
180
- });
181
- });
182
- browser.command("type").description("Type into an element by ref from snapshot").argument("<ref>", "Ref id from snapshot").argument("<text>", "Text to type").option("--submit", "Press Enter after typing", false).option("--slowly", "Type slowly (human-like)", false).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (ref, text, opts, cmd) => {
183
- const refValue = requireRef(ref);
184
- if (!refValue) return;
185
- await runElementAction({
186
- cmd,
187
- body: {
188
- kind: "type",
189
- ref: refValue,
190
- text,
191
- submit: Boolean(opts.submit),
192
- slowly: Boolean(opts.slowly),
193
- targetId: opts.targetId?.trim() || void 0
194
- },
195
- successMessage: `typed into ref ${refValue}`
196
- });
197
- });
198
- browser.command("press").description("Press a key").argument("<key>", "Key to press (e.g. Enter)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (key, opts, cmd) => {
199
- await runElementAction({
200
- cmd,
201
- body: {
202
- kind: "press",
203
- key,
204
- targetId: opts.targetId?.trim() || void 0
205
- },
206
- successMessage: `pressed ${key}`
207
- });
208
- });
209
- browser.command("hover").description("Hover an element by ai ref").argument("<ref>", "Ref id from snapshot").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (ref, opts, cmd) => {
210
- await runElementAction({
211
- cmd,
212
- body: {
213
- kind: "hover",
214
- ref,
215
- targetId: opts.targetId?.trim() || void 0
216
- },
217
- successMessage: `hovered ref ${ref}`
218
- });
219
- });
220
- browser.command("scrollintoview").description("Scroll an element into view by ref from snapshot").argument("<ref>", "Ref id from snapshot").option("--target-id <id>", "CDP target id (or unique prefix)").option("--timeout-ms <ms>", "How long to wait for scroll (default: 20000)", (v) => Number(v)).action(async (ref, opts, cmd) => {
221
- const refValue = requireRef(ref);
222
- if (!refValue) return;
223
- const timeoutMs = Number.isFinite(opts.timeoutMs) ? opts.timeoutMs : void 0;
224
- await runElementAction({
225
- cmd,
226
- body: {
227
- kind: "scrollIntoView",
228
- ref: refValue,
229
- targetId: opts.targetId?.trim() || void 0,
230
- timeoutMs
231
- },
232
- timeoutMs,
233
- successMessage: `scrolled into view: ${refValue}`
234
- });
235
- });
236
- browser.command("drag").description("Drag from one ref to another").argument("<startRef>", "Start ref id").argument("<endRef>", "End ref id").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (startRef, endRef, opts, cmd) => {
237
- await runElementAction({
238
- cmd,
239
- body: {
240
- kind: "drag",
241
- startRef,
242
- endRef,
243
- targetId: opts.targetId?.trim() || void 0
244
- },
245
- successMessage: `dragged ${startRef} → ${endRef}`
246
- });
247
- });
248
- browser.command("select").description("Select option(s) in a select element").argument("<ref>", "Ref id from snapshot").argument("<values...>", "Option values to select").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (ref, values, opts, cmd) => {
249
- await runElementAction({
250
- cmd,
251
- body: {
252
- kind: "select",
253
- ref,
254
- values,
255
- targetId: opts.targetId?.trim() || void 0
256
- },
257
- successMessage: `selected ${values.join(", ")}`
258
- });
259
- });
260
- }
261
- //#endregion
262
- //#region src/cli/browser-cli-actions-input/register.files-downloads.ts
263
- async function normalizeUploadPaths(paths) {
264
- const result = await resolveExistingPathsWithinRoot({
265
- rootDir: DEFAULT_UPLOAD_DIR,
266
- requestedPaths: paths,
267
- scopeLabel: `uploads directory (${DEFAULT_UPLOAD_DIR})`
268
- });
269
- if (!result.ok) throw new Error(result.error);
270
- return result.paths;
271
- }
272
- async function runBrowserPostAction(params) {
273
- try {
274
- const result = await callBrowserRequest(params.parent, {
275
- method: "POST",
276
- path: params.path,
277
- query: params.profile ? { profile: params.profile } : void 0,
278
- body: params.body
279
- }, { timeoutMs: params.timeoutMs });
280
- if (params.parent?.json) {
281
- defaultRuntime.log(JSON.stringify(result, null, 2));
282
- return;
283
- }
284
- defaultRuntime.log(params.describeSuccess(result));
285
- } catch (err) {
286
- defaultRuntime.error(danger(String(err)));
287
- defaultRuntime.exit(1);
288
- }
289
- }
290
- function registerBrowserFilesAndDownloadsCommands(browser, parentOpts) {
291
- const resolveTimeoutAndTarget = (opts) => {
292
- return {
293
- timeoutMs: Number.isFinite(opts.timeoutMs) ? Number(opts.timeoutMs) : void 0,
294
- targetId: typeof opts.targetId === "string" ? opts.targetId.trim() || void 0 : void 0
295
- };
296
- };
297
- const runDownloadCommand = async (cmd, opts, request) => {
298
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
299
- const { timeoutMs, targetId } = resolveTimeoutAndTarget(opts);
300
- await runBrowserPostAction({
301
- parent,
302
- profile,
303
- path: request.path,
304
- body: {
305
- ...request.body,
306
- targetId,
307
- timeoutMs
308
- },
309
- timeoutMs: timeoutMs ?? 2e4,
310
- describeSuccess: (result) => `downloaded: ${shortenHomePath(result.download.path)}`
311
- });
312
- };
313
- browser.command("upload").description("Arm file upload for the next file chooser").argument("<paths...>", "File paths to upload (must be within moldClaw temp uploads dir, e.g. /tmp/moldclaw/uploads/file.pdf)").option("--ref <ref>", "Ref id from snapshot to click after arming").option("--input-ref <ref>", "Ref id for <input type=file> to set directly").option("--element <selector>", "CSS selector for <input type=file>").option("--target-id <id>", "CDP target id (or unique prefix)").option("--timeout-ms <ms>", "How long to wait for the next file chooser (default: 120000)", (v) => Number(v)).action(async (paths, opts, cmd) => {
314
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
315
- const normalizedPaths = await normalizeUploadPaths(paths);
316
- const { timeoutMs, targetId } = resolveTimeoutAndTarget(opts);
317
- await runBrowserPostAction({
318
- parent,
319
- profile,
320
- path: "/hooks/file-chooser",
321
- body: {
322
- paths: normalizedPaths,
323
- ref: opts.ref?.trim() || void 0,
324
- inputRef: opts.inputRef?.trim() || void 0,
325
- element: opts.element?.trim() || void 0,
326
- targetId,
327
- timeoutMs
328
- },
329
- timeoutMs: timeoutMs ?? 2e4,
330
- describeSuccess: () => `upload armed for ${paths.length} file(s)`
331
- });
332
- });
333
- browser.command("waitfordownload").description("Wait for the next download (and save it)").argument("[path]", "Save path within moldclaw temp downloads dir (default: /tmp/moldclaw/downloads/...; fallback: os.tmpdir()/moldclaw/downloads/...)").option("--target-id <id>", "CDP target id (or unique prefix)").option("--timeout-ms <ms>", "How long to wait for the next download (default: 120000)", (v) => Number(v)).action(async (outPath, opts, cmd) => {
334
- await runDownloadCommand(cmd, opts, {
335
- path: "/wait/download",
336
- body: { path: outPath?.trim() || void 0 }
337
- });
338
- });
339
- browser.command("download").description("Click a ref and save the resulting download").argument("<ref>", "Ref id from snapshot to click").argument("<path>", "Save path within moldclaw temp downloads dir (e.g. report.pdf or /tmp/moldclaw/downloads/report.pdf)").option("--target-id <id>", "CDP target id (or unique prefix)").option("--timeout-ms <ms>", "How long to wait for the download to start (default: 120000)", (v) => Number(v)).action(async (ref, outPath, opts, cmd) => {
340
- await runDownloadCommand(cmd, opts, {
341
- path: "/download",
342
- body: {
343
- ref,
344
- path: outPath
345
- }
346
- });
347
- });
348
- browser.command("dialog").description("Arm the next modal dialog (alert/confirm/prompt)").option("--accept", "Accept the dialog", false).option("--dismiss", "Dismiss the dialog", false).option("--prompt <text>", "Prompt response text").option("--target-id <id>", "CDP target id (or unique prefix)").option("--timeout-ms <ms>", "How long to wait for the next dialog (default: 120000)", (v) => Number(v)).action(async (opts, cmd) => {
349
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
350
- const accept = opts.accept ? true : opts.dismiss ? false : void 0;
351
- if (accept === void 0) {
352
- defaultRuntime.error(danger("Specify --accept or --dismiss"));
353
- defaultRuntime.exit(1);
354
- return;
355
- }
356
- const { timeoutMs, targetId } = resolveTimeoutAndTarget(opts);
357
- await runBrowserPostAction({
358
- parent,
359
- profile,
360
- path: "/hooks/dialog",
361
- body: {
362
- accept,
363
- promptText: opts.prompt?.trim() || void 0,
364
- targetId,
365
- timeoutMs
366
- },
367
- timeoutMs: timeoutMs ?? 2e4,
368
- describeSuccess: () => "dialog armed"
369
- });
370
- });
371
- }
372
- //#endregion
373
- //#region src/cli/browser-cli-actions-input/register.form-wait-eval.ts
374
- function registerBrowserFormWaitEvalCommands(browser, parentOpts) {
375
- browser.command("fill").description("Fill a form with JSON field descriptors").option("--fields <json>", "JSON array of field objects").option("--fields-file <path>", "Read JSON array from a file").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
376
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
377
- try {
378
- const fields = await readFields({
379
- fields: opts.fields,
380
- fieldsFile: opts.fieldsFile
381
- });
382
- logBrowserActionResult(parent, await callBrowserAct({
383
- parent,
384
- profile,
385
- body: {
386
- kind: "fill",
387
- fields,
388
- targetId: opts.targetId?.trim() || void 0
389
- }
390
- }), `filled ${fields.length} field(s)`);
391
- } catch (err) {
392
- defaultRuntime.error(danger(String(err)));
393
- defaultRuntime.exit(1);
394
- }
395
- });
396
- browser.command("wait").description("Wait for time, selector, URL, load state, or JS conditions").argument("[selector]", "CSS selector to wait for (visible)").option("--time <ms>", "Wait for N milliseconds", (v) => Number(v)).option("--text <value>", "Wait for text to appear").option("--text-gone <value>", "Wait for text to disappear").option("--url <pattern>", "Wait for URL (supports globs like **/dash)").option("--load <load|domcontentloaded|networkidle>", "Wait for load state").option("--fn <js>", "Wait for JS condition (passed to waitForFunction)").option("--timeout-ms <ms>", "How long to wait for each condition (default: 20000)", (v) => Number(v)).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (selector, opts, cmd) => {
397
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
398
- try {
399
- const sel = selector?.trim() || void 0;
400
- const load = opts.load === "load" || opts.load === "domcontentloaded" || opts.load === "networkidle" ? opts.load : void 0;
401
- const timeoutMs = Number.isFinite(opts.timeoutMs) ? opts.timeoutMs : void 0;
402
- logBrowserActionResult(parent, await callBrowserAct({
403
- parent,
404
- profile,
405
- body: {
406
- kind: "wait",
407
- timeMs: Number.isFinite(opts.time) ? opts.time : void 0,
408
- text: opts.text?.trim() || void 0,
409
- textGone: opts.textGone?.trim() || void 0,
410
- selector: sel,
411
- url: opts.url?.trim() || void 0,
412
- loadState: load,
413
- fn: opts.fn?.trim() || void 0,
414
- targetId: opts.targetId?.trim() || void 0,
415
- timeoutMs
416
- },
417
- timeoutMs
418
- }), "wait complete");
419
- } catch (err) {
420
- defaultRuntime.error(danger(String(err)));
421
- defaultRuntime.exit(1);
422
- }
423
- });
424
- browser.command("evaluate").description("Evaluate a function against the page or a ref").option("--fn <code>", "Function source, e.g. (el) => el.textContent").option("--ref <id>", "Ref from snapshot").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
425
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
426
- if (!opts.fn) {
427
- defaultRuntime.error(danger("Missing --fn"));
428
- defaultRuntime.exit(1);
429
- return;
430
- }
431
- try {
432
- const result = await callBrowserAct({
433
- parent,
434
- profile,
435
- body: {
436
- kind: "evaluate",
437
- fn: opts.fn,
438
- ref: opts.ref?.trim() || void 0,
439
- targetId: opts.targetId?.trim() || void 0
440
- }
441
- });
442
- if (parent?.json) {
443
- defaultRuntime.log(JSON.stringify(result, null, 2));
444
- return;
445
- }
446
- defaultRuntime.log(JSON.stringify(result.result ?? null, null, 2));
447
- } catch (err) {
448
- defaultRuntime.error(danger(String(err)));
449
- defaultRuntime.exit(1);
450
- }
451
- });
452
- }
453
- //#endregion
454
- //#region src/cli/browser-cli-resize.ts
455
- async function runBrowserResizeWithOutput(params) {
456
- const { width, height } = params;
457
- if (!Number.isFinite(width) || !Number.isFinite(height)) {
458
- defaultRuntime.error(danger("width and height must be numbers"));
459
- defaultRuntime.exit(1);
460
- return;
461
- }
462
- const result = await callBrowserResize(params.parent, {
463
- profile: params.profile,
464
- width,
465
- height,
466
- targetId: params.targetId
467
- }, { timeoutMs: params.timeoutMs ?? 2e4 });
468
- if (params.parent?.json) {
469
- defaultRuntime.log(JSON.stringify(result, null, 2));
470
- return;
471
- }
472
- defaultRuntime.log(params.successMessage);
473
- }
474
- //#endregion
475
- //#region src/cli/browser-cli-actions-input/register.navigation.ts
476
- function registerBrowserNavigationCommands(browser, parentOpts) {
477
- browser.command("navigate").description("Navigate the current tab to a URL").argument("<url>", "URL to navigate to").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (url, opts, cmd) => {
478
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
479
- try {
480
- const result = await callBrowserRequest(parent, {
481
- method: "POST",
482
- path: "/navigate",
483
- query: profile ? { profile } : void 0,
484
- body: {
485
- url,
486
- targetId: opts.targetId?.trim() || void 0
487
- }
488
- }, { timeoutMs: 2e4 });
489
- if (parent?.json) {
490
- defaultRuntime.log(JSON.stringify(result, null, 2));
491
- return;
492
- }
493
- defaultRuntime.log(`navigated to ${result.url ?? url}`);
494
- } catch (err) {
495
- defaultRuntime.error(danger(String(err)));
496
- defaultRuntime.exit(1);
497
- }
498
- });
499
- browser.command("resize").description("Resize the viewport").argument("<width>", "Viewport width", (v) => Number(v)).argument("<height>", "Viewport height", (v) => Number(v)).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (width, height, opts, cmd) => {
500
- const { parent, profile } = resolveBrowserActionContext(cmd, parentOpts);
501
- try {
502
- await runBrowserResizeWithOutput({
503
- parent,
504
- profile,
505
- width,
506
- height,
507
- targetId: opts.targetId,
508
- timeoutMs: 2e4,
509
- successMessage: `resized to ${width}x${height}`
510
- });
511
- } catch (err) {
512
- defaultRuntime.error(danger(String(err)));
513
- defaultRuntime.exit(1);
514
- }
515
- });
516
- }
517
- //#endregion
518
- //#region src/cli/browser-cli-actions-input/register.ts
519
- function registerBrowserActionInputCommands(browser, parentOpts) {
520
- registerBrowserNavigationCommands(browser, parentOpts);
521
- registerBrowserElementCommands(browser, parentOpts);
522
- registerBrowserFilesAndDownloadsCommands(browser, parentOpts);
523
- registerBrowserFormWaitEvalCommands(browser, parentOpts);
524
- }
525
- //#endregion
526
- //#region src/cli/browser-cli-actions-observe.ts
527
- function runBrowserObserve(action) {
528
- return runCommandWithRuntime(defaultRuntime, action, (err) => {
529
- defaultRuntime.error(danger(String(err)));
530
- defaultRuntime.exit(1);
531
- });
532
- }
533
- function registerBrowserActionObserveCommands(browser, parentOpts) {
534
- browser.command("console").description("Get recent console messages").option("--level <level>", "Filter by level (error, warn, info)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
535
- const parent = parentOpts(cmd);
536
- const profile = parent?.browserProfile;
537
- await runBrowserObserve(async () => {
538
- const result = await callBrowserRequest(parent, {
539
- method: "GET",
540
- path: "/console",
541
- query: {
542
- level: opts.level?.trim() || void 0,
543
- targetId: opts.targetId?.trim() || void 0,
544
- profile
545
- }
546
- }, { timeoutMs: 2e4 });
547
- if (parent?.json) {
548
- defaultRuntime.log(JSON.stringify(result, null, 2));
549
- return;
550
- }
551
- defaultRuntime.log(JSON.stringify(result.messages, null, 2));
552
- });
553
- });
554
- browser.command("pdf").description("Save page as PDF").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
555
- const parent = parentOpts(cmd);
556
- const profile = parent?.browserProfile;
557
- await runBrowserObserve(async () => {
558
- const result = await callBrowserRequest(parent, {
559
- method: "POST",
560
- path: "/pdf",
561
- query: profile ? { profile } : void 0,
562
- body: { targetId: opts.targetId?.trim() || void 0 }
563
- }, { timeoutMs: 2e4 });
564
- if (parent?.json) {
565
- defaultRuntime.log(JSON.stringify(result, null, 2));
566
- return;
567
- }
568
- defaultRuntime.log(`PDF: ${shortenHomePath(result.path)}`);
569
- });
570
- });
571
- browser.command("responsebody").description("Wait for a network response and return its body").argument("<url>", "URL (exact, substring, or glob like **/api)").option("--target-id <id>", "CDP target id (or unique prefix)").option("--timeout-ms <ms>", "How long to wait for the response (default: 20000)", (v) => Number(v)).option("--max-chars <n>", "Max body chars to return (default: 200000)", (v) => Number(v)).action(async (url, opts, cmd) => {
572
- const parent = parentOpts(cmd);
573
- const profile = parent?.browserProfile;
574
- await runBrowserObserve(async () => {
575
- const timeoutMs = Number.isFinite(opts.timeoutMs) ? opts.timeoutMs : void 0;
576
- const maxChars = Number.isFinite(opts.maxChars) ? opts.maxChars : void 0;
577
- const result = await callBrowserRequest(parent, {
578
- method: "POST",
579
- path: "/response/body",
580
- query: profile ? { profile } : void 0,
581
- body: {
582
- url,
583
- targetId: opts.targetId?.trim() || void 0,
584
- timeoutMs,
585
- maxChars
586
- }
587
- }, { timeoutMs: timeoutMs ?? 2e4 });
588
- if (parent?.json) {
589
- defaultRuntime.log(JSON.stringify(result, null, 2));
590
- return;
591
- }
592
- defaultRuntime.log(result.response.body);
593
- });
594
- });
595
- }
596
- //#endregion
597
- //#region src/cli/browser-cli-debug.ts
598
- const BROWSER_DEBUG_TIMEOUT_MS = 2e4;
599
- function runBrowserDebug(action) {
600
- return runCommandWithRuntime(defaultRuntime, action, (err) => {
601
- defaultRuntime.error(danger(String(err)));
602
- defaultRuntime.exit(1);
603
- });
604
- }
605
- async function withDebugContext(cmd, parentOpts, action) {
606
- const parent = parentOpts(cmd);
607
- await runBrowserDebug(() => action({
608
- parent,
609
- profile: parent.browserProfile
610
- }));
611
- }
612
- function printJsonResult$1(parent, result) {
613
- if (!parent.json) return false;
614
- defaultRuntime.log(JSON.stringify(result, null, 2));
615
- return true;
616
- }
617
- async function callDebugRequest(parent, params) {
618
- return callBrowserRequest(parent, params, { timeoutMs: BROWSER_DEBUG_TIMEOUT_MS });
619
- }
620
- function resolveProfileQuery$1(profile) {
621
- return profile ? { profile } : void 0;
622
- }
623
- function resolveDebugQuery(params) {
624
- return {
625
- targetId: typeof params.targetId === "string" ? params.targetId.trim() || void 0 : void 0,
626
- filter: typeof params.filter === "string" ? params.filter.trim() || void 0 : void 0,
627
- clear: Boolean(params.clear),
628
- profile: params.profile
629
- };
630
- }
631
- function registerBrowserDebugCommands(browser, parentOpts) {
632
- browser.command("highlight").description("Highlight an element by ref").argument("<ref>", "Ref id from snapshot").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (ref, opts, cmd) => {
633
- await withDebugContext(cmd, parentOpts, async ({ parent, profile }) => {
634
- if (printJsonResult$1(parent, await callDebugRequest(parent, {
635
- method: "POST",
636
- path: "/highlight",
637
- query: resolveProfileQuery$1(profile),
638
- body: {
639
- ref: ref.trim(),
640
- targetId: opts.targetId?.trim() || void 0
641
- }
642
- }))) return;
643
- defaultRuntime.log(`highlighted ${ref.trim()}`);
644
- });
645
- });
646
- browser.command("errors").description("Get recent page errors").option("--clear", "Clear stored errors after reading", false).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
647
- await withDebugContext(cmd, parentOpts, async ({ parent, profile }) => {
648
- const result = await callDebugRequest(parent, {
649
- method: "GET",
650
- path: "/errors",
651
- query: resolveDebugQuery({
652
- targetId: opts.targetId,
653
- clear: opts.clear,
654
- profile
655
- })
656
- });
657
- if (printJsonResult$1(parent, result)) return;
658
- if (!result.errors.length) {
659
- defaultRuntime.log("No page errors.");
660
- return;
661
- }
662
- defaultRuntime.log(result.errors.map((e) => `${e.timestamp} ${e.name ? `${e.name}: ` : ""}${e.message}`).join("\n"));
663
- });
664
- });
665
- browser.command("requests").description("Get recent network requests (best-effort)").option("--filter <text>", "Only show URLs that contain this substring").option("--clear", "Clear stored requests after reading", false).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
666
- await withDebugContext(cmd, parentOpts, async ({ parent, profile }) => {
667
- const result = await callDebugRequest(parent, {
668
- method: "GET",
669
- path: "/requests",
670
- query: resolveDebugQuery({
671
- targetId: opts.targetId,
672
- filter: opts.filter,
673
- clear: opts.clear,
674
- profile
675
- })
676
- });
677
- if (printJsonResult$1(parent, result)) return;
678
- if (!result.requests.length) {
679
- defaultRuntime.log("No requests recorded.");
680
- return;
681
- }
682
- defaultRuntime.log(result.requests.map((r) => {
683
- const status = typeof r.status === "number" ? ` ${r.status}` : "";
684
- const ok = r.ok === true ? " ok" : r.ok === false ? " fail" : "";
685
- const fail = r.failureText ? ` (${r.failureText})` : "";
686
- return `${r.timestamp} ${r.method}${status}${ok} ${r.url}${fail}`;
687
- }).join("\n"));
688
- });
689
- });
690
- const trace = browser.command("trace").description("Record a Playwright trace");
691
- trace.command("start").description("Start trace recording").option("--target-id <id>", "CDP target id (or unique prefix)").option("--no-screenshots", "Disable screenshots").option("--no-snapshots", "Disable snapshots").option("--sources", "Include sources (bigger traces)", false).action(async (opts, cmd) => {
692
- await withDebugContext(cmd, parentOpts, async ({ parent, profile }) => {
693
- if (printJsonResult$1(parent, await callDebugRequest(parent, {
694
- method: "POST",
695
- path: "/trace/start",
696
- query: resolveProfileQuery$1(profile),
697
- body: {
698
- targetId: opts.targetId?.trim() || void 0,
699
- screenshots: Boolean(opts.screenshots),
700
- snapshots: Boolean(opts.snapshots),
701
- sources: Boolean(opts.sources)
702
- }
703
- }))) return;
704
- defaultRuntime.log("trace started");
705
- });
706
- });
707
- trace.command("stop").description("Stop trace recording and write a .zip").option("--out <path>", "Output path within moldclaw temp dir (e.g. trace.zip or /tmp/moldclaw/trace.zip)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
708
- await withDebugContext(cmd, parentOpts, async ({ parent, profile }) => {
709
- const result = await callDebugRequest(parent, {
710
- method: "POST",
711
- path: "/trace/stop",
712
- query: resolveProfileQuery$1(profile),
713
- body: {
714
- targetId: opts.targetId?.trim() || void 0,
715
- path: opts.out?.trim() || void 0
716
- }
717
- });
718
- if (printJsonResult$1(parent, result)) return;
719
- defaultRuntime.log(`TRACE:${shortenHomePath(result.path)}`);
720
- });
721
- });
722
- }
723
- //#endregion
724
- //#region src/cli/browser-cli-examples.ts
725
- const browserCoreExamples = [
726
- "moldclaw browser status",
727
- "moldclaw browser start",
728
- "moldclaw browser stop",
729
- "moldclaw browser tabs",
730
- "moldclaw browser open https://example.com",
731
- "moldclaw browser focus abcd1234",
732
- "moldclaw browser close abcd1234",
733
- "moldclaw browser screenshot",
734
- "moldclaw browser screenshot --full-page",
735
- "moldclaw browser screenshot --ref 12",
736
- "moldclaw browser snapshot",
737
- "moldclaw browser snapshot --format aria --limit 200",
738
- "moldclaw browser snapshot --efficient",
739
- "moldclaw browser snapshot --labels"
740
- ];
741
- const browserActionExamples = [
742
- "moldclaw browser navigate https://example.com",
743
- "moldclaw browser resize 1280 720",
744
- "moldclaw browser click 12 --double",
745
- "moldclaw browser type 23 \"hello\" --submit",
746
- "moldclaw browser press Enter",
747
- "moldclaw browser hover 44",
748
- "moldclaw browser drag 10 11",
749
- "moldclaw browser select 9 OptionA OptionB",
750
- "moldclaw browser upload /tmp/moldclaw/uploads/file.pdf",
751
- "moldclaw browser fill --fields '[{\"ref\":\"1\",\"value\":\"Ada\"}]'",
752
- "moldclaw browser dialog --accept",
753
- "moldclaw browser wait --text \"Done\"",
754
- "moldclaw browser evaluate --fn '(el) => el.textContent' --ref 7",
755
- "moldclaw browser console --level error",
756
- "moldclaw browser pdf"
757
- ];
758
- //#endregion
759
- //#region src/cli/browser-cli-inspect.ts
760
- function registerBrowserInspectCommands(browser, parentOpts) {
761
- browser.command("screenshot").description("Capture a screenshot (MEDIA:<path>)").argument("[targetId]", "CDP target id (or unique prefix)").option("--full-page", "Capture full scrollable page", false).option("--ref <ref>", "ARIA ref from ai snapshot").option("--element <selector>", "CSS selector for element screenshot").option("--type <png|jpeg>", "Output type (default: png)", "png").action(async (targetId, opts, cmd) => {
762
- const parent = parentOpts(cmd);
763
- const profile = parent?.browserProfile;
764
- try {
765
- const result = await callBrowserRequest(parent, {
766
- method: "POST",
767
- path: "/screenshot",
768
- query: profile ? { profile } : void 0,
769
- body: {
770
- targetId: targetId?.trim() || void 0,
771
- fullPage: Boolean(opts.fullPage),
772
- ref: opts.ref?.trim() || void 0,
773
- element: opts.element?.trim() || void 0,
774
- type: opts.type === "jpeg" ? "jpeg" : "png"
775
- }
776
- }, { timeoutMs: 2e4 });
777
- if (parent?.json) {
778
- defaultRuntime.log(JSON.stringify(result, null, 2));
779
- return;
780
- }
781
- defaultRuntime.log(`MEDIA:${shortenHomePath(result.path)}`);
782
- } catch (err) {
783
- defaultRuntime.error(danger(String(err)));
784
- defaultRuntime.exit(1);
785
- }
786
- });
787
- browser.command("snapshot").description("Capture a snapshot (default: ai; aria is the accessibility tree)").option("--format <aria|ai>", "Snapshot format (default: ai)", "ai").option("--target-id <id>", "CDP target id (or unique prefix)").option("--limit <n>", "Max nodes (default: 500/800)", (v) => Number(v)).option("--mode <efficient>", "Snapshot preset (efficient)").option("--efficient", "Use the efficient snapshot preset", false).option("--interactive", "Role snapshot: interactive elements only", false).option("--compact", "Role snapshot: compact output", false).option("--depth <n>", "Role snapshot: max depth", (v) => Number(v)).option("--selector <sel>", "Role snapshot: scope to CSS selector").option("--frame <sel>", "Role snapshot: scope to an iframe selector").option("--labels", "Include viewport label overlay screenshot", false).option("--out <path>", "Write snapshot to a file").action(async (opts, cmd) => {
788
- const parent = parentOpts(cmd);
789
- const profile = parent?.browserProfile;
790
- const format = opts.format === "aria" ? "aria" : "ai";
791
- const configMode = format === "ai" && loadConfig().browser?.snapshotDefaults?.mode === "efficient" ? "efficient" : void 0;
792
- const mode = opts.efficient === true || opts.mode === "efficient" ? "efficient" : configMode;
793
- try {
794
- const result = await callBrowserRequest(parent, {
795
- method: "GET",
796
- path: "/snapshot",
797
- query: {
798
- format,
799
- targetId: opts.targetId?.trim() || void 0,
800
- limit: Number.isFinite(opts.limit) ? opts.limit : void 0,
801
- interactive: opts.interactive ? true : void 0,
802
- compact: opts.compact ? true : void 0,
803
- depth: Number.isFinite(opts.depth) ? opts.depth : void 0,
804
- selector: opts.selector?.trim() || void 0,
805
- frame: opts.frame?.trim() || void 0,
806
- labels: opts.labels ? true : void 0,
807
- mode,
808
- profile
809
- }
810
- }, { timeoutMs: 2e4 });
811
- if (opts.out) {
812
- const fs = await import("node:fs/promises");
813
- if (result.format === "ai") await fs.writeFile(opts.out, result.snapshot, "utf8");
814
- else {
815
- const payload = JSON.stringify(result, null, 2);
816
- await fs.writeFile(opts.out, payload, "utf8");
817
- }
818
- if (parent?.json) defaultRuntime.log(JSON.stringify({
819
- ok: true,
820
- out: opts.out,
821
- ...result.format === "ai" && result.imagePath ? { imagePath: result.imagePath } : {}
822
- }, null, 2));
823
- else {
824
- defaultRuntime.log(shortenHomePath(opts.out));
825
- if (result.format === "ai" && result.imagePath) defaultRuntime.log(`MEDIA:${shortenHomePath(result.imagePath)}`);
826
- }
827
- return;
828
- }
829
- if (parent?.json) {
830
- defaultRuntime.log(JSON.stringify(result, null, 2));
831
- return;
832
- }
833
- if (result.format === "ai") {
834
- defaultRuntime.log(result.snapshot);
835
- if (result.imagePath) defaultRuntime.log(`MEDIA:${shortenHomePath(result.imagePath)}`);
836
- return;
837
- }
838
- const nodes = "nodes" in result ? result.nodes : [];
839
- defaultRuntime.log(nodes.map((n) => {
840
- const indent = " ".repeat(Math.min(20, n.depth));
841
- const name = n.name ? ` "${n.name}"` : "";
842
- const value = n.value ? ` = "${n.value}"` : "";
843
- return `${indent}- ${n.role}${name}${value}`;
844
- }).join("\n"));
845
- } catch (err) {
846
- defaultRuntime.error(danger(String(err)));
847
- defaultRuntime.exit(1);
848
- }
849
- });
850
- }
851
- //#endregion
852
- //#region src/cli/browser-cli-manage.ts
853
- const BROWSER_MANAGE_REQUEST_TIMEOUT_MS = 45e3;
854
- function resolveProfileQuery(profile) {
855
- return profile ? { profile } : void 0;
856
- }
857
- function printJsonResult(parent, payload) {
858
- if (!parent?.json) return false;
859
- defaultRuntime.log(JSON.stringify(payload, null, 2));
860
- return true;
861
- }
862
- async function callTabAction(parent, profile, body) {
863
- return callBrowserRequest(parent, {
864
- method: "POST",
865
- path: "/tabs/action",
866
- query: resolveProfileQuery(profile),
867
- body
868
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS });
869
- }
870
- async function fetchBrowserStatus(parent, profile) {
871
- return await callBrowserRequest(parent, {
872
- method: "GET",
873
- path: "/",
874
- query: resolveProfileQuery(profile)
875
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS });
876
- }
877
- async function runBrowserToggle(parent, params) {
878
- await callBrowserRequest(parent, {
879
- method: "POST",
880
- path: params.path,
881
- query: resolveProfileQuery(params.profile)
882
- });
883
- const status = await fetchBrowserStatus(parent, params.profile);
884
- if (printJsonResult(parent, status)) return;
885
- const name = status.profile ?? "moldclaw";
886
- defaultRuntime.log(info(`🪢 browser [${name}] running: ${status.running}`));
887
- }
888
- function runBrowserCommand$1(action) {
889
- return runCommandWithRuntime(defaultRuntime, action, (err) => {
890
- defaultRuntime.error(danger(String(err)));
891
- defaultRuntime.exit(1);
892
- });
893
- }
894
- function logBrowserTabs(tabs, json) {
895
- if (json) {
896
- defaultRuntime.log(JSON.stringify({ tabs }, null, 2));
897
- return;
898
- }
899
- if (tabs.length === 0) {
900
- defaultRuntime.log("No tabs (browser closed or no targets).");
901
- return;
902
- }
903
- defaultRuntime.log(tabs.map((t, i) => `${i + 1}. ${t.title || "(untitled)"}\n ${t.url}\n id: ${t.targetId}`).join("\n"));
904
- }
905
- function usesChromeMcpTransport(params) {
906
- return params.transport === "chrome-mcp" || params.driver === "existing-session";
907
- }
908
- function formatBrowserConnectionSummary(params) {
909
- if (usesChromeMcpTransport(params)) {
910
- const userDataDir = params.userDataDir ? shortenHomePath(params.userDataDir) : null;
911
- return userDataDir ? `transport: chrome-mcp, userDataDir: ${userDataDir}` : "transport: chrome-mcp";
912
- }
913
- if (params.isRemote) return `cdpUrl: ${params.cdpUrl ?? "(unset)"}`;
914
- return `port: ${params.cdpPort ?? "(unset)"}`;
915
- }
916
- function registerBrowserManageCommands(browser, parentOpts) {
917
- browser.command("status").description("Show browser status").action(async (_opts, cmd) => {
918
- const parent = parentOpts(cmd);
919
- await runBrowserCommand$1(async () => {
920
- const status = await fetchBrowserStatus(parent, parent?.browserProfile);
921
- if (printJsonResult(parent, status)) return;
922
- const detectedPath = status.detectedExecutablePath ?? status.executablePath;
923
- const detectedDisplay = detectedPath ? shortenHomePath(detectedPath) : "auto";
924
- defaultRuntime.log([
925
- `profile: ${status.profile ?? "moldclaw"}`,
926
- `enabled: ${status.enabled}`,
927
- `running: ${status.running}`,
928
- `transport: ${usesChromeMcpTransport(status) ? "chrome-mcp" : status.transport ?? "cdp"}`,
929
- ...!usesChromeMcpTransport(status) ? [`cdpPort: ${status.cdpPort ?? "(unset)"}`, `cdpUrl: ${redactCdpUrl(status.cdpUrl ?? `http://127.0.0.1:${status.cdpPort}`)}`] : status.userDataDir ? [`userDataDir: ${shortenHomePath(status.userDataDir)}`] : [],
930
- `browser: ${status.chosenBrowser ?? "unknown"}`,
931
- `detectedBrowser: ${status.detectedBrowser ?? "unknown"}`,
932
- `detectedPath: ${detectedDisplay}`,
933
- `profileColor: ${status.color}`,
934
- ...status.detectError ? [`detectError: ${status.detectError}`] : []
935
- ].join("\n"));
936
- });
937
- });
938
- browser.command("start").description("Start the browser (no-op if already running)").action(async (_opts, cmd) => {
939
- const parent = parentOpts(cmd);
940
- const profile = parent?.browserProfile;
941
- await runBrowserCommand$1(async () => {
942
- await runBrowserToggle(parent, {
943
- profile,
944
- path: "/start"
945
- });
946
- });
947
- });
948
- browser.command("stop").description("Stop the browser (best-effort)").action(async (_opts, cmd) => {
949
- const parent = parentOpts(cmd);
950
- const profile = parent?.browserProfile;
951
- await runBrowserCommand$1(async () => {
952
- await runBrowserToggle(parent, {
953
- profile,
954
- path: "/stop"
955
- });
956
- });
957
- });
958
- browser.command("reset-profile").description("Reset browser profile (moves it to Trash)").action(async (_opts, cmd) => {
959
- const parent = parentOpts(cmd);
960
- const profile = parent?.browserProfile;
961
- await runBrowserCommand$1(async () => {
962
- const result = await callBrowserRequest(parent, {
963
- method: "POST",
964
- path: "/reset-profile",
965
- query: resolveProfileQuery(profile)
966
- }, { timeoutMs: 2e4 });
967
- if (printJsonResult(parent, result)) return;
968
- if (!result.moved) {
969
- defaultRuntime.log(info(`🪢 browser profile already missing.`));
970
- return;
971
- }
972
- const dest = result.to ?? result.from;
973
- defaultRuntime.log(info(`🪢 browser profile moved to Trash (${dest})`));
974
- });
975
- });
976
- browser.command("tabs").description("List open tabs").action(async (_opts, cmd) => {
977
- const parent = parentOpts(cmd);
978
- const profile = parent?.browserProfile;
979
- await runBrowserCommand$1(async () => {
980
- logBrowserTabs((await callBrowserRequest(parent, {
981
- method: "GET",
982
- path: "/tabs",
983
- query: resolveProfileQuery(profile)
984
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS })).tabs ?? [], parent?.json);
985
- });
986
- });
987
- const tab = browser.command("tab").description("Tab shortcuts (index-based)").action(async (_opts, cmd) => {
988
- const parent = parentOpts(cmd);
989
- const profile = parent?.browserProfile;
990
- await runBrowserCommand$1(async () => {
991
- logBrowserTabs((await callBrowserRequest(parent, {
992
- method: "POST",
993
- path: "/tabs/action",
994
- query: resolveProfileQuery(profile),
995
- body: { action: "list" }
996
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS })).tabs ?? [], parent?.json);
997
- });
998
- });
999
- tab.command("new").description("Open a new tab (about:blank)").action(async (_opts, cmd) => {
1000
- const parent = parentOpts(cmd);
1001
- const profile = parent?.browserProfile;
1002
- await runBrowserCommand$1(async () => {
1003
- if (printJsonResult(parent, await callTabAction(parent, profile, { action: "new" }))) return;
1004
- defaultRuntime.log("opened new tab");
1005
- });
1006
- });
1007
- tab.command("select").description("Focus tab by index (1-based)").argument("<index>", "Tab index (1-based)", (v) => Number(v)).action(async (index, _opts, cmd) => {
1008
- const parent = parentOpts(cmd);
1009
- const profile = parent?.browserProfile;
1010
- if (!Number.isFinite(index) || index < 1) {
1011
- defaultRuntime.error(danger("index must be a positive number"));
1012
- defaultRuntime.exit(1);
1013
- return;
1014
- }
1015
- await runBrowserCommand$1(async () => {
1016
- if (printJsonResult(parent, await callTabAction(parent, profile, {
1017
- action: "select",
1018
- index: Math.floor(index) - 1
1019
- }))) return;
1020
- defaultRuntime.log(`selected tab ${Math.floor(index)}`);
1021
- });
1022
- });
1023
- tab.command("close").description("Close tab by index (1-based); default: first tab").argument("[index]", "Tab index (1-based)", (v) => Number(v)).action(async (index, _opts, cmd) => {
1024
- const parent = parentOpts(cmd);
1025
- const profile = parent?.browserProfile;
1026
- const idx = typeof index === "number" && Number.isFinite(index) ? Math.floor(index) - 1 : void 0;
1027
- if (typeof idx === "number" && idx < 0) {
1028
- defaultRuntime.error(danger("index must be >= 1"));
1029
- defaultRuntime.exit(1);
1030
- return;
1031
- }
1032
- await runBrowserCommand$1(async () => {
1033
- if (printJsonResult(parent, await callTabAction(parent, profile, {
1034
- action: "close",
1035
- index: idx
1036
- }))) return;
1037
- defaultRuntime.log("closed tab");
1038
- });
1039
- });
1040
- browser.command("open").description("Open a URL in a new tab").argument("<url>", "URL to open").action(async (url, _opts, cmd) => {
1041
- const parent = parentOpts(cmd);
1042
- const profile = parent?.browserProfile;
1043
- await runBrowserCommand$1(async () => {
1044
- const tab = await callBrowserRequest(parent, {
1045
- method: "POST",
1046
- path: "/tabs/open",
1047
- query: resolveProfileQuery(profile),
1048
- body: { url }
1049
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS });
1050
- if (printJsonResult(parent, tab)) return;
1051
- defaultRuntime.log(`opened: ${tab.url}\nid: ${tab.targetId}`);
1052
- });
1053
- });
1054
- browser.command("focus").description("Focus a tab by target id (or unique prefix)").argument("<targetId>", "Target id or unique prefix").action(async (targetId, _opts, cmd) => {
1055
- const parent = parentOpts(cmd);
1056
- const profile = parent?.browserProfile;
1057
- await runBrowserCommand$1(async () => {
1058
- await callBrowserRequest(parent, {
1059
- method: "POST",
1060
- path: "/tabs/focus",
1061
- query: resolveProfileQuery(profile),
1062
- body: { targetId }
1063
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS });
1064
- if (printJsonResult(parent, { ok: true })) return;
1065
- defaultRuntime.log(`focused tab ${targetId}`);
1066
- });
1067
- });
1068
- browser.command("close").description("Close a tab (target id optional)").argument("[targetId]", "Target id or unique prefix (optional)").action(async (targetId, _opts, cmd) => {
1069
- const parent = parentOpts(cmd);
1070
- const profile = parent?.browserProfile;
1071
- await runBrowserCommand$1(async () => {
1072
- if (targetId?.trim()) await callBrowserRequest(parent, {
1073
- method: "DELETE",
1074
- path: `/tabs/${encodeURIComponent(targetId.trim())}`,
1075
- query: resolveProfileQuery(profile)
1076
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS });
1077
- else await callBrowserRequest(parent, {
1078
- method: "POST",
1079
- path: "/act",
1080
- query: resolveProfileQuery(profile),
1081
- body: { kind: "close" }
1082
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS });
1083
- if (printJsonResult(parent, { ok: true })) return;
1084
- defaultRuntime.log("closed tab");
1085
- });
1086
- });
1087
- browser.command("profiles").description("List all browser profiles").action(async (_opts, cmd) => {
1088
- const parent = parentOpts(cmd);
1089
- await runBrowserCommand$1(async () => {
1090
- const profiles = (await callBrowserRequest(parent, {
1091
- method: "GET",
1092
- path: "/profiles"
1093
- }, { timeoutMs: BROWSER_MANAGE_REQUEST_TIMEOUT_MS })).profiles ?? [];
1094
- if (printJsonResult(parent, { profiles })) return;
1095
- if (profiles.length === 0) {
1096
- defaultRuntime.log("No profiles configured.");
1097
- return;
1098
- }
1099
- defaultRuntime.log(profiles.map((p) => {
1100
- const status = p.running ? "running" : "stopped";
1101
- const tabs = p.running ? ` (${p.tabCount} tabs)` : "";
1102
- const def = p.isDefault ? " [default]" : "";
1103
- const loc = formatBrowserConnectionSummary(p);
1104
- const remote = p.isRemote ? " [remote]" : "";
1105
- const driver = p.driver !== "moldclaw" ? ` [${p.driver}]` : "";
1106
- return `${p.name}: ${status}${tabs}${def}${remote}${driver}\n ${loc}, color: ${p.color}`;
1107
- }).join("\n"));
1108
- });
1109
- });
1110
- browser.command("create-profile").description("Create a new browser profile").requiredOption("--name <name>", "Profile name (lowercase, numbers, hyphens)").option("--color <hex>", "Profile color (hex format, e.g. #0066CC)").option("--cdp-url <url>", "CDP URL for remote Chrome (http/https)").option("--user-data-dir <path>", "User data dir for existing-session Chromium attach").option("--driver <driver>", "Profile driver (moldclaw|existing-session). Default: moldclaw").action(async (opts, cmd) => {
1111
- const parent = parentOpts(cmd);
1112
- await runBrowserCommand$1(async () => {
1113
- const result = await callBrowserRequest(parent, {
1114
- method: "POST",
1115
- path: "/profiles/create",
1116
- body: {
1117
- name: opts.name,
1118
- color: opts.color,
1119
- cdpUrl: opts.cdpUrl,
1120
- userDataDir: opts.userDataDir,
1121
- driver: opts.driver === "existing-session" ? "existing-session" : void 0
1122
- }
1123
- }, { timeoutMs: 1e4 });
1124
- if (printJsonResult(parent, result)) return;
1125
- const loc = ` ${formatBrowserConnectionSummary(result)}`;
1126
- defaultRuntime.log(info(`🪢 Created profile "${result.profile}"\n${loc}\n color: ${result.color}${result.userDataDir ? `\n userDataDir: ${shortenHomePath(result.userDataDir)}` : ""}${opts.driver === "existing-session" ? "\n driver: existing-session" : ""}`));
1127
- });
1128
- });
1129
- browser.command("delete-profile").description("Delete a browser profile").requiredOption("--name <name>", "Profile name to delete").action(async (opts, cmd) => {
1130
- const parent = parentOpts(cmd);
1131
- await runBrowserCommand$1(async () => {
1132
- const result = await callBrowserRequest(parent, {
1133
- method: "DELETE",
1134
- path: `/profiles/${encodeURIComponent(opts.name)}`
1135
- }, { timeoutMs: 2e4 });
1136
- if (printJsonResult(parent, result)) return;
1137
- const msg = result.deleted ? `🪢 Deleted profile "${result.profile}" (user data removed)` : `🪢 Deleted profile "${result.profile}" (no user data found)`;
1138
- defaultRuntime.log(info(msg));
1139
- });
1140
- });
1141
- }
1142
- //#endregion
1143
- //#region src/cli/browser-cli-state.cookies-storage.ts
1144
- function resolveUrl(opts, command) {
1145
- if (typeof opts.url === "string" && opts.url.trim()) return opts.url.trim();
1146
- const inherited = inheritOptionFromParent(command, "url");
1147
- if (typeof inherited === "string" && inherited.trim()) return inherited.trim();
1148
- }
1149
- function resolveTargetId(rawTargetId, command) {
1150
- const local = typeof rawTargetId === "string" ? rawTargetId.trim() : "";
1151
- if (local) return local;
1152
- const inherited = inheritOptionFromParent(command, "targetId");
1153
- if (typeof inherited !== "string") return;
1154
- const trimmed = inherited.trim();
1155
- return trimmed ? trimmed : void 0;
1156
- }
1157
- async function runMutationRequest(params) {
1158
- try {
1159
- const result = await callBrowserRequest(params.parent, params.request, { timeoutMs: 2e4 });
1160
- if (params.parent?.json) {
1161
- defaultRuntime.log(JSON.stringify(result, null, 2));
1162
- return;
1163
- }
1164
- defaultRuntime.log(params.successMessage);
1165
- } catch (err) {
1166
- defaultRuntime.error(danger(String(err)));
1167
- defaultRuntime.exit(1);
1168
- }
1169
- }
1170
- function registerBrowserCookiesAndStorageCommands(browser, parentOpts) {
1171
- const cookies = browser.command("cookies").description("Read/write cookies");
1172
- cookies.option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
1173
- const parent = parentOpts(cmd);
1174
- const profile = parent?.browserProfile;
1175
- const targetId = resolveTargetId(opts.targetId, cmd);
1176
- try {
1177
- const result = await callBrowserRequest(parent, {
1178
- method: "GET",
1179
- path: "/cookies",
1180
- query: {
1181
- targetId,
1182
- profile
1183
- }
1184
- }, { timeoutMs: 2e4 });
1185
- if (parent?.json) {
1186
- defaultRuntime.log(JSON.stringify(result, null, 2));
1187
- return;
1188
- }
1189
- defaultRuntime.log(JSON.stringify(result.cookies ?? [], null, 2));
1190
- } catch (err) {
1191
- defaultRuntime.error(danger(String(err)));
1192
- defaultRuntime.exit(1);
1193
- }
1194
- });
1195
- cookies.command("set").description("Set a cookie (requires --url or domain+path)").argument("<name>", "Cookie name").argument("<value>", "Cookie value").option("--url <url>", "Cookie URL scope (recommended)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (name, value, opts, cmd) => {
1196
- const parent = parentOpts(cmd);
1197
- const profile = parent?.browserProfile;
1198
- const targetId = resolveTargetId(opts.targetId, cmd);
1199
- const url = resolveUrl(opts, cmd);
1200
- if (!url) {
1201
- defaultRuntime.error(danger("Missing required --url option for cookies set"));
1202
- defaultRuntime.exit(1);
1203
- return;
1204
- }
1205
- await runMutationRequest({
1206
- parent,
1207
- request: {
1208
- method: "POST",
1209
- path: "/cookies/set",
1210
- query: profile ? { profile } : void 0,
1211
- body: {
1212
- targetId,
1213
- cookie: {
1214
- name,
1215
- value,
1216
- url
1217
- }
1218
- }
1219
- },
1220
- successMessage: `cookie set: ${name}`
1221
- });
1222
- });
1223
- cookies.command("clear").description("Clear all cookies").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd) => {
1224
- const parent = parentOpts(cmd);
1225
- const profile = parent?.browserProfile;
1226
- const targetId = resolveTargetId(opts.targetId, cmd);
1227
- await runMutationRequest({
1228
- parent,
1229
- request: {
1230
- method: "POST",
1231
- path: "/cookies/clear",
1232
- query: profile ? { profile } : void 0,
1233
- body: { targetId }
1234
- },
1235
- successMessage: "cookies cleared"
1236
- });
1237
- });
1238
- const storage = browser.command("storage").description("Read/write localStorage/sessionStorage");
1239
- function registerStorageKind(kind) {
1240
- const cmd = storage.command(kind).description(`${kind}Storage commands`);
1241
- cmd.command("get").description(`Get ${kind}Storage (all keys or one key)`).argument("[key]", "Key (optional)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (key, opts, cmd2) => {
1242
- const parent = parentOpts(cmd2);
1243
- const profile = parent?.browserProfile;
1244
- const targetId = resolveTargetId(opts.targetId, cmd2);
1245
- try {
1246
- const result = await callBrowserRequest(parent, {
1247
- method: "GET",
1248
- path: `/storage/${kind}`,
1249
- query: {
1250
- key: key?.trim() || void 0,
1251
- targetId,
1252
- profile
1253
- }
1254
- }, { timeoutMs: 2e4 });
1255
- if (parent?.json) {
1256
- defaultRuntime.log(JSON.stringify(result, null, 2));
1257
- return;
1258
- }
1259
- defaultRuntime.log(JSON.stringify(result.values ?? {}, null, 2));
1260
- } catch (err) {
1261
- defaultRuntime.error(danger(String(err)));
1262
- defaultRuntime.exit(1);
1263
- }
1264
- });
1265
- cmd.command("set").description(`Set a ${kind}Storage key`).argument("<key>", "Key").argument("<value>", "Value").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (key, value, opts, cmd2) => {
1266
- const parent = parentOpts(cmd2);
1267
- const profile = parent?.browserProfile;
1268
- const targetId = resolveTargetId(opts.targetId, cmd2);
1269
- await runMutationRequest({
1270
- parent,
1271
- request: {
1272
- method: "POST",
1273
- path: `/storage/${kind}/set`,
1274
- query: profile ? { profile } : void 0,
1275
- body: {
1276
- key,
1277
- value,
1278
- targetId
1279
- }
1280
- },
1281
- successMessage: `${kind}Storage set: ${key}`
1282
- });
1283
- });
1284
- cmd.command("clear").description(`Clear all ${kind}Storage keys`).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (opts, cmd2) => {
1285
- const parent = parentOpts(cmd2);
1286
- const profile = parent?.browserProfile;
1287
- const targetId = resolveTargetId(opts.targetId, cmd2);
1288
- await runMutationRequest({
1289
- parent,
1290
- request: {
1291
- method: "POST",
1292
- path: `/storage/${kind}/clear`,
1293
- query: profile ? { profile } : void 0,
1294
- body: { targetId }
1295
- },
1296
- successMessage: `${kind}Storage cleared`
1297
- });
1298
- });
1299
- }
1300
- registerStorageKind("local");
1301
- registerStorageKind("session");
1302
- }
1303
- //#endregion
1304
- //#region src/cli/browser-cli-state.ts
1305
- function parseOnOff(raw) {
1306
- const parsed = parseBooleanValue(raw);
1307
- return parsed === void 0 ? null : parsed;
1308
- }
1309
- function runBrowserCommand(action) {
1310
- return runCommandWithRuntime(defaultRuntime, action, (err) => {
1311
- defaultRuntime.error(danger(String(err)));
1312
- defaultRuntime.exit(1);
1313
- });
1314
- }
1315
- async function runBrowserSetRequest(params) {
1316
- await runBrowserCommand(async () => {
1317
- const profile = params.parent?.browserProfile;
1318
- const result = await callBrowserRequest(params.parent, {
1319
- method: "POST",
1320
- path: params.path,
1321
- query: profile ? { profile } : void 0,
1322
- body: params.body
1323
- }, { timeoutMs: 2e4 });
1324
- if (params.parent?.json) {
1325
- defaultRuntime.log(JSON.stringify(result, null, 2));
1326
- return;
1327
- }
1328
- defaultRuntime.log(params.successMessage);
1329
- });
1330
- }
1331
- function registerBrowserStateCommands(browser, parentOpts) {
1332
- registerBrowserCookiesAndStorageCommands(browser, parentOpts);
1333
- const set = browser.command("set").description("Browser environment settings");
1334
- set.command("viewport").description("Set viewport size (alias for resize)").argument("<width>", "Viewport width", (v) => Number(v)).argument("<height>", "Viewport height", (v) => Number(v)).option("--target-id <id>", "CDP target id (or unique prefix)").action(async (width, height, opts, cmd) => {
1335
- const parent = parentOpts(cmd);
1336
- const profile = parent?.browserProfile;
1337
- await runBrowserCommand(async () => {
1338
- await runBrowserResizeWithOutput({
1339
- parent,
1340
- profile,
1341
- width,
1342
- height,
1343
- targetId: opts.targetId,
1344
- timeoutMs: 2e4,
1345
- successMessage: `viewport set: ${width}x${height}`
1346
- });
1347
- });
1348
- });
1349
- set.command("offline").description("Toggle offline mode").argument("<on|off>", "on/off").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (value, opts, cmd) => {
1350
- const parent = parentOpts(cmd);
1351
- const offline = parseOnOff(value);
1352
- if (offline === null) {
1353
- defaultRuntime.error(danger("Expected on|off"));
1354
- defaultRuntime.exit(1);
1355
- return;
1356
- }
1357
- await runBrowserSetRequest({
1358
- parent,
1359
- path: "/set/offline",
1360
- body: {
1361
- offline,
1362
- targetId: opts.targetId?.trim() || void 0
1363
- },
1364
- successMessage: `offline: ${offline}`
1365
- });
1366
- });
1367
- set.command("headers").description("Set extra HTTP headers (JSON object)").argument("[headersJson]", "JSON object of headers (alternative to --headers-json)").option("--headers-json <json>", "JSON object of headers").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (headersJson, opts, cmd) => {
1368
- const parent = parentOpts(cmd);
1369
- await runBrowserCommand(async () => {
1370
- const headersJsonValue = typeof opts.headersJson === "string" && opts.headersJson.trim() || (headersJson?.trim() ? headersJson.trim() : void 0);
1371
- if (!headersJsonValue) throw new Error("Missing headers JSON (pass --headers-json or positional JSON argument)");
1372
- const parsed = JSON.parse(String(headersJsonValue));
1373
- if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) throw new Error("Headers JSON must be a JSON object");
1374
- const headers = {};
1375
- for (const [k, v] of Object.entries(parsed)) if (typeof v === "string") headers[k] = v;
1376
- const profile = parent?.browserProfile;
1377
- const result = await callBrowserRequest(parent, {
1378
- method: "POST",
1379
- path: "/set/headers",
1380
- query: profile ? { profile } : void 0,
1381
- body: {
1382
- headers,
1383
- targetId: opts.targetId?.trim() || void 0
1384
- }
1385
- }, { timeoutMs: 2e4 });
1386
- if (parent?.json) {
1387
- defaultRuntime.log(JSON.stringify(result, null, 2));
1388
- return;
1389
- }
1390
- defaultRuntime.log("headers set");
1391
- });
1392
- });
1393
- set.command("credentials").description("Set HTTP basic auth credentials").option("--clear", "Clear credentials", false).argument("[username]", "Username").argument("[password]", "Password").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (username, password, opts, cmd) => {
1394
- await runBrowserSetRequest({
1395
- parent: parentOpts(cmd),
1396
- path: "/set/credentials",
1397
- body: {
1398
- username: username?.trim() || void 0,
1399
- password,
1400
- clear: Boolean(opts.clear),
1401
- targetId: opts.targetId?.trim() || void 0
1402
- },
1403
- successMessage: opts.clear ? "credentials cleared" : "credentials set"
1404
- });
1405
- });
1406
- set.command("geo").description("Set geolocation (and grant permission)").option("--clear", "Clear geolocation + permissions", false).argument("[latitude]", "Latitude", (v) => Number(v)).argument("[longitude]", "Longitude", (v) => Number(v)).option("--accuracy <m>", "Accuracy in meters", (v) => Number(v)).option("--origin <origin>", "Origin to grant permissions for").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (latitude, longitude, opts, cmd) => {
1407
- await runBrowserSetRequest({
1408
- parent: parentOpts(cmd),
1409
- path: "/set/geolocation",
1410
- body: {
1411
- latitude: Number.isFinite(latitude) ? latitude : void 0,
1412
- longitude: Number.isFinite(longitude) ? longitude : void 0,
1413
- accuracy: Number.isFinite(opts.accuracy) ? opts.accuracy : void 0,
1414
- origin: opts.origin?.trim() || void 0,
1415
- clear: Boolean(opts.clear),
1416
- targetId: opts.targetId?.trim() || void 0
1417
- },
1418
- successMessage: opts.clear ? "geolocation cleared" : "geolocation set"
1419
- });
1420
- });
1421
- set.command("media").description("Emulate prefers-color-scheme").argument("<dark|light|none>", "dark/light/none").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (value, opts, cmd) => {
1422
- const parent = parentOpts(cmd);
1423
- const v = value.trim().toLowerCase();
1424
- const colorScheme = v === "dark" ? "dark" : v === "light" ? "light" : v === "none" ? "none" : null;
1425
- if (!colorScheme) {
1426
- defaultRuntime.error(danger("Expected dark|light|none"));
1427
- defaultRuntime.exit(1);
1428
- return;
1429
- }
1430
- await runBrowserSetRequest({
1431
- parent,
1432
- path: "/set/media",
1433
- body: {
1434
- colorScheme,
1435
- targetId: opts.targetId?.trim() || void 0
1436
- },
1437
- successMessage: `media colorScheme: ${colorScheme}`
1438
- });
1439
- });
1440
- set.command("timezone").description("Override timezone (CDP)").argument("<timezoneId>", "Timezone ID (e.g. America/New_York)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (timezoneId, opts, cmd) => {
1441
- await runBrowserSetRequest({
1442
- parent: parentOpts(cmd),
1443
- path: "/set/timezone",
1444
- body: {
1445
- timezoneId,
1446
- targetId: opts.targetId?.trim() || void 0
1447
- },
1448
- successMessage: `timezone: ${timezoneId}`
1449
- });
1450
- });
1451
- set.command("locale").description("Override locale (CDP)").argument("<locale>", "Locale (e.g. en-US)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (locale, opts, cmd) => {
1452
- await runBrowserSetRequest({
1453
- parent: parentOpts(cmd),
1454
- path: "/set/locale",
1455
- body: {
1456
- locale,
1457
- targetId: opts.targetId?.trim() || void 0
1458
- },
1459
- successMessage: `locale: ${locale}`
1460
- });
1461
- });
1462
- set.command("device").description("Apply a Playwright device descriptor (e.g. \"iPhone 14\")").argument("<name>", "Device name (Playwright devices)").option("--target-id <id>", "CDP target id (or unique prefix)").action(async (name, opts, cmd) => {
1463
- await runBrowserSetRequest({
1464
- parent: parentOpts(cmd),
1465
- path: "/set/device",
1466
- body: {
1467
- name,
1468
- targetId: opts.targetId?.trim() || void 0
1469
- },
1470
- successMessage: `device: ${name}`
1471
- });
1472
- });
1473
- }
1474
- //#endregion
1475
- //#region src/cli/browser-cli.ts
1476
- function registerBrowserCli(program) {
1477
- const browser = program.command("browser").description("Manage moldClaw's dedicated browser (Chrome/Chromium)").option("--browser-profile <name>", "Browser profile name (default from config)").option("--json", "Output machine-readable JSON", false).addHelpText("after", () => `\n${theme.heading("Examples:")}\n${formatHelpExamples([...browserCoreExamples, ...browserActionExamples].map((cmd) => [cmd, ""]), true)}\n\n${theme.muted("Docs:")} ${formatDocsLink("/cli/browser", "docs.moldclaw.ai/cli/browser")}\n`).action(() => {
1478
- browser.outputHelp();
1479
- defaultRuntime.error(danger(`Missing subcommand. Try: "${formatCliCommand("moldclaw browser status")}"`));
1480
- defaultRuntime.exit(1);
1481
- });
1482
- addGatewayClientOptions(browser);
1483
- const parentOpts = (cmd) => cmd.parent?.opts?.();
1484
- registerBrowserManageCommands(browser, parentOpts);
1485
- registerBrowserInspectCommands(browser, parentOpts);
1486
- registerBrowserActionInputCommands(browser, parentOpts);
1487
- registerBrowserActionObserveCommands(browser, parentOpts);
1488
- registerBrowserDebugCommands(browser, parentOpts);
1489
- registerBrowserStateCommands(browser, parentOpts);
1490
- }
1491
- //#endregion
1492
- export { registerBrowserCli };