@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,1599 +0,0 @@
1
- import { u as resolveGatewayPort } from "./paths-D6AgsMTU.js";
2
- import { n as isRich, r as theme } from "./theme-BSXzMzAA.js";
3
- import { n as info } from "./globals-DESrFYmC.js";
4
- import { Bu as readRestartSentinel, Vu as summarizeRestartSentinel, rC as loadSessionStore, rc as getRemoteSkillEligibility, yu as resolveCommandSecretRefsViaGateway } from "./auth-profiles-BJcHzwPy.js";
5
- import { p as resolveAgentWorkspaceDir } from "./agent-scope-DA7O8MVG.js";
6
- import { r as runExec } from "./exec-CoBTyh8B.js";
7
- import { t as resolvemoldClawPackageRoot } from "./moldclaw-root-vgfzPuAl.js";
8
- import { d as readConfigFileSnapshot, u as readBestEffortConfig } from "./io-DcoxdH6t.js";
9
- import { n as VERSION } from "./version-rW_3ob2o.js";
10
- import { E as readTailscaleStatusJson } from "./config-BbxrRaLf.js";
11
- import { t as formatCliCommand } from "./command-format-DIDjlImI.js";
12
- import { a as inspectPortUsage, c as formatPortDiagnostics } from "./ports-BVwQuCIR.js";
13
- import { L as hasPotentialConfiguredChannels, O as formatDurationPrecise, n as createLazyRuntimeSurface } from "./lazy-runtime-DdzFA4b9.js";
14
- import { l as resolveStorePath } from "./paths-CDWV-9nX.js";
15
- import { n as callGateway, t as buildGatewayConnectionDetails } from "./call-CoaQYq7c.js";
16
- import { t as resolveMemorySearchConfig } from "./memory-search-BBG2BKIh.js";
17
- import { t as formatConfigIssueLine } from "./issue-format-i6sEuV4a.js";
18
- import { c as getStatusCommandSecretTargetIds } from "./command-secret-targets-CO_lZ_ZZ.js";
19
- import { n as formatTimeAgo } from "./format-relative-B7AB_aDW.js";
20
- import { n as withProgress } from "./progress-BQSTKUhd.js";
21
- import { r as normalizeControlUiBasePath } from "./control-ui-shared-kLBp4YlS.js";
22
- import { g as resolveControlUiLinks } from "./onboard-helpers-D3wWfH8F.js";
23
- import { c as resolveGatewayLogPaths } from "./launchd-C1YgvbKp.js";
24
- import { n as resolveGatewayService } from "./service-DLhEn8sS.js";
25
- import { t as probeGateway } from "./probe-CfL4tnJ6.js";
26
- import { t as readLastGatewayErrorLine } from "./diagnostics-Ct6HBGrk.js";
27
- import { n as resolveGatewayProbeAuthSafe } from "./probe-auth-D_UKzu4m.js";
28
- import { t as buildWorkspaceSkillStatus } from "./skills-status-DGdxY3OI.js";
29
- import { n as renderTable, t as getTerminalTableWidth } from "./table-DUG58M8M.js";
30
- import { a as resolveSharedMemoryStatusSnapshot, c as getNodeDaemonStatusSummary, d as formatTokensCompact, f as readServiceStatusSummary, h as pickGatewaySelfPresence, i as resolveMemoryPluginStatus, l as formatDuration, m as resolveOsSummary, n as buildTailscaleHttpsUrl, o as getAgentLocalStatuses$1, p as listGatewayAgentsBasic, r as resolveGatewayProbeSnapshot, s as getDaemonStatusSummary, t as getStatusSummary, u as formatKTokens } from "./status.summary-AMek7qvI.js";
31
- import { t as formatHealthChannelLines } from "./health-DXZykGaX.js";
32
- import { h as resolveUpdateChannelDisplay, i as formatGitInstallLabel, p as normalizeUpdateChannel, t as checkUpdateStatus } from "./update-check-Me_VZCOt.js";
33
- import { t as resolveNodeService } from "./node-service-DnHU1_vE.js";
34
- import { t as collectChannelStatusIssues } from "./channels-status-issues-kDtsWzA-.js";
35
- import { n as redactSecrets, t as formatGatewayAuthUsed } from "./format-DSvqVxj1.js";
36
- import { t as buildChannelsTable } from "./channels-CTL8iR9J.js";
37
- import { i as resolveUpdateAvailability, n as formatUpdateOneLiner, r as getUpdateCheckResult, t as formatUpdateAvailableHint } from "./status.update-SccSfWO9.js";
38
- import { t as shortenText } from "./text-format-CwRO950L.js";
39
- import path from "node:path";
40
- import fs from "node:fs/promises";
41
- //#region src/memory/status-format.ts
42
- function resolveMemoryVectorState(vector) {
43
- if (!vector.enabled) return {
44
- tone: "muted",
45
- state: "disabled"
46
- };
47
- if (vector.available === true) return {
48
- tone: "ok",
49
- state: "ready"
50
- };
51
- if (vector.available === false) return {
52
- tone: "warn",
53
- state: "unavailable"
54
- };
55
- return {
56
- tone: "muted",
57
- state: "unknown"
58
- };
59
- }
60
- function resolveMemoryFtsState(fts) {
61
- if (!fts.enabled) return {
62
- tone: "muted",
63
- state: "disabled"
64
- };
65
- return fts.available ? {
66
- tone: "ok",
67
- state: "ready"
68
- } : {
69
- tone: "warn",
70
- state: "unavailable"
71
- };
72
- }
73
- function resolveMemoryCacheSummary(cache) {
74
- if (!cache.enabled) return {
75
- tone: "muted",
76
- text: "cache off"
77
- };
78
- return {
79
- tone: "ok",
80
- text: `cache on${typeof cache.entries === "number" ? ` (${cache.entries})` : ""}`
81
- };
82
- }
83
- //#endregion
84
- //#region src/commands/status-all/agents.ts
85
- async function fileExists(p) {
86
- try {
87
- await fs.access(p);
88
- return true;
89
- } catch {
90
- return false;
91
- }
92
- }
93
- async function getAgentLocalStatuses(cfg) {
94
- const agentList = listGatewayAgentsBasic(cfg);
95
- const now = Date.now();
96
- const agents = await Promise.all(agentList.agents.map(async (agent) => {
97
- const workspaceDir = (() => {
98
- try {
99
- return resolveAgentWorkspaceDir(cfg, agent.id);
100
- } catch {
101
- return null;
102
- }
103
- })();
104
- const bootstrapPending = workspaceDir != null ? await fileExists(path.join(workspaceDir, "BOOTSTRAP.md")) : null;
105
- const sessionsPath = resolveStorePath(cfg.session?.store, { agentId: agent.id });
106
- const store = (() => {
107
- try {
108
- return loadSessionStore(sessionsPath);
109
- } catch {
110
- return {};
111
- }
112
- })();
113
- const updatedAt = Object.values(store).reduce((max, entry) => Math.max(max, entry?.updatedAt ?? 0), 0);
114
- const lastUpdatedAt = updatedAt > 0 ? updatedAt : null;
115
- const lastActiveAgeMs = lastUpdatedAt ? now - lastUpdatedAt : null;
116
- const sessionsCount = Object.keys(store).filter((k) => k !== "global" && k !== "unknown").length;
117
- return {
118
- id: agent.id,
119
- name: agent.name,
120
- workspaceDir,
121
- bootstrapPending,
122
- sessionsPath,
123
- sessionsCount,
124
- lastUpdatedAt,
125
- lastActiveAgeMs
126
- };
127
- }));
128
- const totalSessions = agents.reduce((sum, a) => sum + a.sessionsCount, 0);
129
- const bootstrapPendingCount = agents.reduce((sum, a) => sum + (a.bootstrapPending ? 1 : 0), 0);
130
- return {
131
- defaultId: agentList.defaultId,
132
- agents,
133
- totalSessions,
134
- bootstrapPendingCount
135
- };
136
- }
137
- //#endregion
138
- //#region src/commands/status-all/gateway.ts
139
- async function readFileTailLines(filePath, maxLines) {
140
- const raw = await fs.readFile(filePath, "utf8").catch(() => "");
141
- if (!raw.trim()) return [];
142
- const lines = raw.replace(/\r/g, "").split("\n");
143
- return lines.slice(Math.max(0, lines.length - maxLines)).map((line) => line.trimEnd()).filter((line) => line.trim().length > 0);
144
- }
145
- function countMatches(haystack, needle) {
146
- if (!haystack || !needle) return 0;
147
- return haystack.split(needle).length - 1;
148
- }
149
- function shorten(message, maxLen) {
150
- const cleaned = message.replace(/\s+/g, " ").trim();
151
- if (cleaned.length <= maxLen) return cleaned;
152
- return `${cleaned.slice(0, Math.max(0, maxLen - 1))}…`;
153
- }
154
- function normalizeGwsLine(line) {
155
- return line.replace(/\s+runId=[^\s]+/g, "").replace(/\s+conn=[^\s]+/g, "").replace(/\s+id=[^\s]+/g, "").replace(/\s+error=Error:.*$/g, "").trim();
156
- }
157
- function consumeJsonBlock(lines, startIndex) {
158
- const startLine = lines[startIndex] ?? "";
159
- const braceAt = startLine.indexOf("{");
160
- if (braceAt < 0) return null;
161
- const parts = [startLine.slice(braceAt)];
162
- let depth = countMatches(parts[0] ?? "", "{") - countMatches(parts[0] ?? "", "}");
163
- let i = startIndex;
164
- while (depth > 0 && i + 1 < lines.length) {
165
- i += 1;
166
- const next = lines[i] ?? "";
167
- parts.push(next);
168
- depth += countMatches(next, "{") - countMatches(next, "}");
169
- }
170
- return {
171
- json: parts.join("\n"),
172
- endIndex: i
173
- };
174
- }
175
- function summarizeLogTail(rawLines, opts) {
176
- const maxLines = Math.max(6, opts?.maxLines ?? 26);
177
- const out = [];
178
- const groups = /* @__PURE__ */ new Map();
179
- const addGroup = (key, base) => {
180
- const existing = groups.get(key);
181
- if (existing) {
182
- existing.count += 1;
183
- return;
184
- }
185
- groups.set(key, {
186
- count: 1,
187
- index: out.length,
188
- base
189
- });
190
- out.push(base);
191
- };
192
- const addLine = (line) => {
193
- const trimmed = line.trimEnd();
194
- if (!trimmed) return;
195
- out.push(trimmed);
196
- };
197
- const lines = rawLines.map((line) => line.trimEnd()).filter(Boolean);
198
- for (let i = 0; i < lines.length; i += 1) {
199
- const line = lines[i] ?? "";
200
- const trimmedStart = line.trimStart();
201
- if ((trimmedStart.startsWith("\"") || trimmedStart === "}" || trimmedStart === "{" || trimmedStart.startsWith("}") || trimmedStart.startsWith("{")) && !trimmedStart.startsWith("[") && !trimmedStart.startsWith("#")) continue;
202
- const tokenRefresh = line.match(/^\[([^\]]+)\]\s+Token refresh failed:\s*(\d+)\s*(\{)?\s*$/);
203
- if (tokenRefresh) {
204
- const tag = tokenRefresh[1] ?? "unknown";
205
- const status = tokenRefresh[2] ?? "unknown";
206
- const block = consumeJsonBlock(lines, i);
207
- if (block) {
208
- i = block.endIndex;
209
- const parsed = (() => {
210
- try {
211
- return JSON.parse(block.json);
212
- } catch {
213
- return null;
214
- }
215
- })();
216
- const code = parsed?.error?.code?.trim() || null;
217
- const msg = parsed?.error?.message?.trim() || null;
218
- const msgShort = msg ? msg.toLowerCase().includes("signing in again") ? "re-auth required" : shorten(msg, 52) : null;
219
- const base = `[${tag}] token refresh ${status}${code ? ` ${code}` : ""}${msgShort ? ` · ${msgShort}` : ""}`;
220
- addGroup(`token:${tag}:${status}:${code ?? ""}:${msgShort ?? ""}`, base);
221
- continue;
222
- }
223
- }
224
- const embedded = line.match(/^Embedded agent failed before reply:\s+OAuth token refresh failed for ([^:]+):/);
225
- if (embedded) {
226
- const provider = embedded[1]?.trim() || "unknown";
227
- addGroup(`embedded:${provider}`, `Embedded agent: OAuth token refresh failed (${provider})`);
228
- continue;
229
- }
230
- if (line.startsWith("[gws]") && line.includes("errorCode=UNAVAILABLE") && line.includes("OAuth token refresh failed")) {
231
- const normalized = normalizeGwsLine(line);
232
- addGroup(`gws:${normalized}`, normalized);
233
- continue;
234
- }
235
- addLine(line);
236
- }
237
- for (const g of groups.values()) {
238
- if (g.count <= 1) continue;
239
- out[g.index] = `${g.base} ×${g.count}`;
240
- }
241
- const deduped = [];
242
- for (const line of out) {
243
- if (deduped[deduped.length - 1] === line) continue;
244
- deduped.push(line);
245
- }
246
- if (deduped.length <= maxLines) return deduped;
247
- const head = Math.min(6, Math.floor(maxLines / 3));
248
- const tail = Math.max(1, maxLines - head - 1);
249
- return [
250
- ...deduped.slice(0, head),
251
- `… ${deduped.length - head - tail} lines omitted …`,
252
- ...deduped.slice(-tail)
253
- ];
254
- }
255
- //#endregion
256
- //#region src/commands/status-all/channel-issues.ts
257
- function groupChannelIssuesByChannel(issues) {
258
- const byChannel = /* @__PURE__ */ new Map();
259
- for (const issue of issues) {
260
- const key = issue.channel;
261
- const list = byChannel.get(key);
262
- if (list) list.push(issue);
263
- else byChannel.set(key, [issue]);
264
- }
265
- return byChannel;
266
- }
267
- //#endregion
268
- //#region src/commands/status-all/diagnosis.ts
269
- async function appendStatusAllDiagnosis(params) {
270
- const { lines, muted, ok, warn, fail } = params;
271
- const emitCheck = (label, status) => {
272
- const icon = status === "ok" ? ok("✓") : status === "warn" ? warn("!") : fail("✗");
273
- const colored = status === "ok" ? ok(label) : status === "warn" ? warn(label) : fail(label);
274
- lines.push(`${icon} ${colored}`);
275
- };
276
- lines.push("");
277
- lines.push(muted("Gateway connection details:"));
278
- for (const line of redactSecrets(params.connectionDetailsForReport).split("\n").map((l) => l.trimEnd())) lines.push(` ${muted(line)}`);
279
- lines.push("");
280
- if (params.snap) {
281
- const status = !params.snap.exists ? "fail" : params.snap.valid ? "ok" : "warn";
282
- emitCheck(`Config: ${params.snap.path ?? "(unknown)"}`, status);
283
- const issues = [...params.snap.legacyIssues ?? [], ...params.snap.issues ?? []];
284
- const uniqueIssues = issues.filter((issue, index) => issues.findIndex((x) => x.path === issue.path && x.message === issue.message) === index);
285
- for (const issue of uniqueIssues.slice(0, 12)) lines.push(` ${formatConfigIssueLine(issue, "-")}`);
286
- if (uniqueIssues.length > 12) lines.push(` ${muted(`… +${uniqueIssues.length - 12} more`)}`);
287
- } else emitCheck("Config: read failed", "warn");
288
- if (params.remoteUrlMissing) {
289
- lines.push("");
290
- emitCheck("Gateway remote mode misconfigured (gateway.remote.url missing)", "warn");
291
- lines.push(` ${muted("Fix: set gateway.remote.url, or set gateway.mode=local.")}`);
292
- }
293
- emitCheck(`Secret diagnostics (${params.secretDiagnostics.length})`, params.secretDiagnostics.length === 0 ? "ok" : "warn");
294
- for (const diagnostic of params.secretDiagnostics.slice(0, 10)) lines.push(` - ${muted(redactSecrets(diagnostic))}`);
295
- if (params.secretDiagnostics.length > 10) lines.push(` ${muted(`… +${params.secretDiagnostics.length - 10} more`)}`);
296
- if (params.sentinel?.payload) {
297
- emitCheck("Restart sentinel present", "warn");
298
- lines.push(` ${muted(`${summarizeRestartSentinel(params.sentinel.payload)} · ${formatTimeAgo(Date.now() - params.sentinel.payload.ts)}`)}`);
299
- } else emitCheck("Restart sentinel: none", "ok");
300
- const lastErrClean = params.lastErr?.trim() ?? "";
301
- const isTrivialLastErr = lastErrClean.length < 8 || lastErrClean === "}" || lastErrClean === "{";
302
- if (lastErrClean && !isTrivialLastErr) {
303
- lines.push("");
304
- lines.push(muted("Gateway last log line:"));
305
- lines.push(` ${muted(redactSecrets(lastErrClean))}`);
306
- }
307
- if (params.portUsage) {
308
- const portOk = params.portUsage.listeners.length === 0;
309
- emitCheck(`Port ${params.port}`, portOk ? "ok" : "warn");
310
- if (!portOk) for (const line of formatPortDiagnostics(params.portUsage)) lines.push(` ${muted(line)}`);
311
- }
312
- {
313
- const backend = params.tailscale.backendState ?? "unknown";
314
- const okBackend = backend === "Running";
315
- const hasDns = Boolean(params.tailscale.dnsName);
316
- emitCheck(params.tailscaleMode === "off" ? `Tailscale: off · ${backend}${params.tailscale.dnsName ? ` · ${params.tailscale.dnsName}` : ""}` : `Tailscale: ${params.tailscaleMode} · ${backend}${params.tailscale.dnsName ? ` · ${params.tailscale.dnsName}` : ""}`, okBackend && (params.tailscaleMode === "off" || hasDns) ? "ok" : "warn");
317
- if (params.tailscale.error) lines.push(` ${muted(`error: ${params.tailscale.error}`)}`);
318
- if (params.tailscale.ips.length > 0) lines.push(` ${muted(`ips: ${params.tailscale.ips.slice(0, 3).join(", ")}${params.tailscale.ips.length > 3 ? "…" : ""}`)}`);
319
- if (params.tailscaleHttpsUrl) lines.push(` ${muted(`https: ${params.tailscaleHttpsUrl}`)}`);
320
- }
321
- if (params.skillStatus) {
322
- const eligible = params.skillStatus.skills.filter((s) => s.eligible).length;
323
- const missing = params.skillStatus.skills.filter((s) => s.eligible && Object.values(s.missing).some((arr) => arr.length)).length;
324
- emitCheck(`Skills: ${eligible} eligible · ${missing} missing · ${params.skillStatus.workspaceDir}`, missing === 0 ? "ok" : "warn");
325
- }
326
- params.progress.setLabel("Reading logs…");
327
- const logPaths = (() => {
328
- try {
329
- return resolveGatewayLogPaths(process.env);
330
- } catch {
331
- return null;
332
- }
333
- })();
334
- if (logPaths) {
335
- params.progress.setLabel("Reading logs…");
336
- const [stderrTail, stdoutTail] = await Promise.all([readFileTailLines(logPaths.stderrPath, 40).catch(() => []), readFileTailLines(logPaths.stdoutPath, 40).catch(() => [])]);
337
- if (stderrTail.length > 0 || stdoutTail.length > 0) {
338
- lines.push("");
339
- lines.push(muted(`Gateway logs (tail, summarized): ${logPaths.logDir}`));
340
- lines.push(` ${muted(`# stderr: ${logPaths.stderrPath}`)}`);
341
- for (const line of summarizeLogTail(stderrTail, { maxLines: 22 }).map(redactSecrets)) lines.push(` ${muted(line)}`);
342
- lines.push(` ${muted(`# stdout: ${logPaths.stdoutPath}`)}`);
343
- for (const line of summarizeLogTail(stdoutTail, { maxLines: 22 }).map(redactSecrets)) lines.push(` ${muted(line)}`);
344
- }
345
- }
346
- params.progress.tick();
347
- if (params.channelsStatus) {
348
- emitCheck(`Channel issues (${params.channelIssues.length || "none"})`, params.channelIssues.length === 0 ? "ok" : "warn");
349
- for (const issue of params.channelIssues.slice(0, 12)) {
350
- const fixText = issue.fix ? ` · fix: ${issue.fix}` : "";
351
- lines.push(` - ${issue.channel}[${issue.accountId}] ${issue.kind}: ${issue.message}${fixText}`);
352
- }
353
- if (params.channelIssues.length > 12) lines.push(` ${muted(`… +${params.channelIssues.length - 12} more`)}`);
354
- } else emitCheck(`Channel issues skipped (gateway ${params.gatewayReachable ? "query failed" : "unreachable"})`, "warn");
355
- const healthErr = (() => {
356
- if (!params.health || typeof params.health !== "object") return "";
357
- const record = params.health;
358
- if (!("error" in record)) return "";
359
- const value = record.error;
360
- if (!value) return "";
361
- if (typeof value === "string") return value;
362
- try {
363
- return JSON.stringify(value, null, 2);
364
- } catch {
365
- return "[unserializable error]";
366
- }
367
- })();
368
- if (healthErr) {
369
- lines.push("");
370
- lines.push(muted("Gateway health:"));
371
- lines.push(` ${muted(redactSecrets(healthErr))}`);
372
- }
373
- lines.push("");
374
- lines.push(muted("Pasteable debug report. Auth tokens redacted."));
375
- lines.push("Troubleshooting: https://docs.moldclaw.ai/troubleshooting");
376
- lines.push("");
377
- }
378
- //#endregion
379
- //#region src/commands/status-all/report-lines.ts
380
- async function buildStatusAllReportLines(params) {
381
- const rich = isRich();
382
- const heading = (text) => rich ? theme.heading(text) : text;
383
- const ok = (text) => rich ? theme.success(text) : text;
384
- const warn = (text) => rich ? theme.warn(text) : text;
385
- const fail = (text) => rich ? theme.error(text) : text;
386
- const muted = (text) => rich ? theme.muted(text) : text;
387
- const tableWidth = getTerminalTableWidth();
388
- const overview = renderTable({
389
- width: tableWidth,
390
- columns: [{
391
- key: "Item",
392
- header: "Item",
393
- minWidth: 10
394
- }, {
395
- key: "Value",
396
- header: "Value",
397
- flex: true,
398
- minWidth: 24
399
- }],
400
- rows: params.overviewRows
401
- });
402
- const channelRows = params.channels.rows.map((row) => ({
403
- channelId: row.id,
404
- Channel: row.label,
405
- Enabled: row.enabled ? ok("ON") : muted("OFF"),
406
- State: row.state === "ok" ? ok("OK") : row.state === "warn" ? warn("WARN") : row.state === "off" ? muted("OFF") : theme.accentDim("SETUP"),
407
- Detail: row.detail
408
- }));
409
- const channelIssuesByChannel = groupChannelIssuesByChannel(params.channelIssues);
410
- const channelsTable = renderTable({
411
- width: tableWidth,
412
- columns: [
413
- {
414
- key: "Channel",
415
- header: "Channel",
416
- minWidth: 10
417
- },
418
- {
419
- key: "Enabled",
420
- header: "Enabled",
421
- minWidth: 7
422
- },
423
- {
424
- key: "State",
425
- header: "State",
426
- minWidth: 8
427
- },
428
- {
429
- key: "Detail",
430
- header: "Detail",
431
- flex: true,
432
- minWidth: 28
433
- }
434
- ],
435
- rows: channelRows.map((row) => {
436
- const issues = channelIssuesByChannel.get(row.channelId) ?? [];
437
- if (issues.length === 0) return row;
438
- const issue = issues[0];
439
- const suffix = ` · ${warn(`gateway: ${String(issue.message).slice(0, 90)}`)}`;
440
- return {
441
- ...row,
442
- State: warn("WARN"),
443
- Detail: `${row.Detail}${suffix}`
444
- };
445
- })
446
- });
447
- const agentsTable = renderTable({
448
- width: tableWidth,
449
- columns: [
450
- {
451
- key: "Agent",
452
- header: "Agent",
453
- minWidth: 12
454
- },
455
- {
456
- key: "BootstrapFile",
457
- header: "Bootstrap file",
458
- minWidth: 14
459
- },
460
- {
461
- key: "Sessions",
462
- header: "Sessions",
463
- align: "right",
464
- minWidth: 8
465
- },
466
- {
467
- key: "Active",
468
- header: "Active",
469
- minWidth: 10
470
- },
471
- {
472
- key: "Store",
473
- header: "Store",
474
- flex: true,
475
- minWidth: 34
476
- }
477
- ],
478
- rows: params.agentStatus.agents.map((a) => ({
479
- Agent: a.name?.trim() ? `${a.id} (${a.name.trim()})` : a.id,
480
- BootstrapFile: a.bootstrapPending === true ? warn("PRESENT") : a.bootstrapPending === false ? ok("ABSENT") : "unknown",
481
- Sessions: String(a.sessionsCount),
482
- Active: a.lastActiveAgeMs != null ? formatTimeAgo(a.lastActiveAgeMs) : "unknown",
483
- Store: a.sessionsPath
484
- }))
485
- });
486
- const lines = [];
487
- lines.push(heading("moldClaw status --all"));
488
- lines.push("");
489
- lines.push(heading("Overview"));
490
- lines.push(overview.trimEnd());
491
- lines.push("");
492
- lines.push(heading("Channels"));
493
- lines.push(channelsTable.trimEnd());
494
- for (const detail of params.channels.details) {
495
- lines.push("");
496
- lines.push(heading(detail.title));
497
- lines.push(renderTable({
498
- width: tableWidth,
499
- columns: detail.columns.map((c) => ({
500
- key: c,
501
- header: c,
502
- flex: c === "Notes",
503
- minWidth: c === "Notes" ? 28 : 10
504
- })),
505
- rows: detail.rows.map((r) => ({
506
- ...r,
507
- ...r.Status === "OK" ? { Status: ok("OK") } : r.Status === "WARN" ? { Status: warn("WARN") } : {}
508
- }))
509
- }).trimEnd());
510
- }
511
- lines.push("");
512
- lines.push(heading("Agents"));
513
- lines.push(agentsTable.trimEnd());
514
- lines.push("");
515
- lines.push(heading("Diagnosis (read-only)"));
516
- await appendStatusAllDiagnosis({
517
- lines,
518
- progress: params.progress,
519
- muted,
520
- ok,
521
- warn,
522
- fail,
523
- connectionDetailsForReport: params.connectionDetailsForReport,
524
- ...params.diagnosis
525
- });
526
- return lines;
527
- }
528
- //#endregion
529
- //#region src/commands/status-all.ts
530
- async function statusAllCommand(runtime, opts) {
531
- await withProgress({
532
- label: "Scanning status --all…",
533
- total: 11
534
- }, async (progress) => {
535
- progress.setLabel("Loading config…");
536
- const loadedRaw = await readBestEffortConfig();
537
- const { resolvedConfig: cfg, diagnostics: secretDiagnostics } = await resolveCommandSecretRefsViaGateway({
538
- config: loadedRaw,
539
- commandName: "status --all",
540
- targetIds: getStatusCommandSecretTargetIds(),
541
- mode: "read_only_status"
542
- });
543
- const osSummary = resolveOsSummary();
544
- const snap = await readConfigFileSnapshot().catch(() => null);
545
- progress.tick();
546
- progress.setLabel("Checking Tailscale…");
547
- const tailscaleMode = cfg.gateway?.tailscale?.mode ?? "off";
548
- const tailscale = await (async () => {
549
- try {
550
- const parsed = await readTailscaleStatusJson(runExec, { timeoutMs: 1200 });
551
- const backendState = typeof parsed.BackendState === "string" ? parsed.BackendState : null;
552
- const self = typeof parsed.Self === "object" && parsed.Self !== null ? parsed.Self : null;
553
- const dnsNameRaw = self && typeof self.DNSName === "string" ? self.DNSName : null;
554
- return {
555
- ok: true,
556
- backendState,
557
- dnsName: dnsNameRaw ? dnsNameRaw.replace(/\.$/, "") : null,
558
- ips: self && Array.isArray(self.TailscaleIPs) ? self.TailscaleIPs.filter((v) => typeof v === "string" && v.trim().length > 0).map((v) => v.trim()) : [],
559
- error: null
560
- };
561
- } catch (err) {
562
- return {
563
- ok: false,
564
- backendState: null,
565
- dnsName: null,
566
- ips: [],
567
- error: String(err)
568
- };
569
- }
570
- })();
571
- const tailscaleHttpsUrl = tailscaleMode !== "off" && tailscale.dnsName ? `https://${tailscale.dnsName}${normalizeControlUiBasePath(cfg.gateway?.controlUi?.basePath)}` : null;
572
- progress.tick();
573
- progress.setLabel("Checking for updates…");
574
- const update = await checkUpdateStatus({
575
- root: await resolvemoldClawPackageRoot({
576
- moduleUrl: import.meta.url,
577
- argv1: process.argv[1],
578
- cwd: process.cwd()
579
- }),
580
- timeoutMs: 6500,
581
- fetchGit: true,
582
- includeRegistry: true
583
- });
584
- const channelLabel = resolveUpdateChannelDisplay({
585
- configChannel: normalizeUpdateChannel(cfg.update?.channel),
586
- installKind: update.installKind,
587
- gitTag: update.git?.tag ?? null,
588
- gitBranch: update.git?.branch ?? null
589
- }).label;
590
- const gitLabel = formatGitInstallLabel(update);
591
- progress.tick();
592
- progress.setLabel("Probing gateway…");
593
- const connection = buildGatewayConnectionDetails({ config: cfg });
594
- const isRemoteMode = cfg.gateway?.mode === "remote";
595
- const remoteUrlRaw = typeof cfg.gateway?.remote?.url === "string" ? cfg.gateway.remote.url.trim() : "";
596
- const remoteUrlMissing = isRemoteMode && !remoteUrlRaw;
597
- const gatewayMode = isRemoteMode ? "remote" : "local";
598
- const localProbeAuthResolution = resolveGatewayProbeAuthSafe({
599
- cfg,
600
- mode: "local"
601
- });
602
- const remoteProbeAuthResolution = resolveGatewayProbeAuthSafe({
603
- cfg,
604
- mode: "remote"
605
- });
606
- const probeAuthResolution = isRemoteMode && !remoteUrlMissing ? remoteProbeAuthResolution : localProbeAuthResolution;
607
- const probeAuth = probeAuthResolution.auth;
608
- const gatewayProbe = await probeGateway({
609
- url: connection.url,
610
- auth: probeAuth,
611
- timeoutMs: Math.min(5e3, opts?.timeoutMs ?? 1e4)
612
- }).catch(() => null);
613
- const gatewayReachable = gatewayProbe?.ok === true;
614
- const gatewaySelf = pickGatewaySelfPresence(gatewayProbe?.presence ?? null);
615
- progress.tick();
616
- progress.setLabel("Checking services…");
617
- const readServiceSummary = async (service) => {
618
- try {
619
- const summary = await readServiceStatusSummary(service, service.label);
620
- return {
621
- label: summary.label,
622
- installed: summary.installed,
623
- managedBymoldClaw: summary.managedBymoldClaw,
624
- loaded: summary.loaded,
625
- loadedText: summary.loadedText,
626
- runtime: summary.runtime
627
- };
628
- } catch {
629
- return null;
630
- }
631
- };
632
- const daemon = await readServiceSummary(resolveGatewayService());
633
- const nodeService = await readServiceSummary(resolveNodeService());
634
- progress.tick();
635
- progress.setLabel("Scanning agents…");
636
- const agentStatus = await getAgentLocalStatuses(cfg);
637
- progress.tick();
638
- progress.setLabel("Summarizing channels…");
639
- const channels = await buildChannelsTable(cfg, {
640
- showSecrets: false,
641
- sourceConfig: loadedRaw
642
- });
643
- progress.tick();
644
- const connectionDetailsForReport = (() => {
645
- if (!remoteUrlMissing) return connection.message;
646
- const bindMode = cfg.gateway?.bind ?? "loopback";
647
- return [
648
- "Gateway mode: remote",
649
- "Gateway target: (missing gateway.remote.url)",
650
- `Config: ${snap?.path?.trim() ? snap.path.trim() : "(unknown config path)"}`,
651
- `Bind: ${bindMode}`,
652
- `Local fallback (used for probes): ${connection.url}`,
653
- "Fix: set gateway.remote.url, or set gateway.mode=local."
654
- ].join("\n");
655
- })();
656
- const callOverrides = remoteUrlMissing ? {
657
- url: connection.url,
658
- token: localProbeAuthResolution.auth.token,
659
- password: localProbeAuthResolution.auth.password
660
- } : {};
661
- progress.setLabel("Querying gateway…");
662
- const health = gatewayReachable ? await callGateway({
663
- config: cfg,
664
- method: "health",
665
- timeoutMs: Math.min(8e3, opts?.timeoutMs ?? 1e4),
666
- ...callOverrides
667
- }).catch((err) => ({ error: String(err) })) : { error: gatewayProbe?.error ?? "gateway unreachable" };
668
- const channelsStatus = gatewayReachable ? await callGateway({
669
- config: cfg,
670
- method: "channels.status",
671
- params: {
672
- probe: false,
673
- timeoutMs: opts?.timeoutMs ?? 1e4
674
- },
675
- timeoutMs: Math.min(8e3, opts?.timeoutMs ?? 1e4),
676
- ...callOverrides
677
- }).catch(() => null) : null;
678
- const channelIssues = channelsStatus ? collectChannelStatusIssues(channelsStatus) : [];
679
- progress.tick();
680
- progress.setLabel("Checking local state…");
681
- const sentinel = await readRestartSentinel().catch(() => null);
682
- const lastErr = await readLastGatewayErrorLine(process.env).catch(() => null);
683
- const port = resolveGatewayPort(cfg);
684
- const portUsage = await inspectPortUsage(port).catch(() => null);
685
- progress.tick();
686
- const defaultWorkspace = agentStatus.agents.find((a) => a.id === agentStatus.defaultId)?.workspaceDir ?? agentStatus.agents[0]?.workspaceDir ?? null;
687
- const skillStatus = defaultWorkspace != null ? (() => {
688
- try {
689
- return buildWorkspaceSkillStatus(defaultWorkspace, {
690
- config: cfg,
691
- eligibility: { remote: getRemoteSkillEligibility() }
692
- });
693
- } catch {
694
- return null;
695
- }
696
- })() : null;
697
- const dashboard = cfg.gateway?.controlUi?.enabled ?? true ? resolveControlUiLinks({
698
- port,
699
- bind: cfg.gateway?.bind,
700
- customBindHost: cfg.gateway?.customBindHost,
701
- basePath: cfg.gateway?.controlUi?.basePath
702
- }).httpUrl : null;
703
- const updateLine = formatUpdateOneLiner(update).replace(/^Update:\s*/i, "");
704
- const gatewayTarget = remoteUrlMissing ? `fallback ${connection.url}` : connection.url;
705
- const gatewayStatus = gatewayReachable ? `reachable ${formatDurationPrecise(gatewayProbe?.connectLatencyMs ?? 0)}` : gatewayProbe?.error ? `unreachable (${gatewayProbe.error})` : "unreachable";
706
- const gatewayAuth = gatewayReachable ? ` · auth ${formatGatewayAuthUsed(probeAuth)}` : "";
707
- const gatewaySelfLine = gatewaySelf?.host || gatewaySelf?.ip || gatewaySelf?.version || gatewaySelf?.platform ? [
708
- gatewaySelf.host ? gatewaySelf.host : null,
709
- gatewaySelf.ip ? `(${gatewaySelf.ip})` : null,
710
- gatewaySelf.version ? `app ${gatewaySelf.version}` : null,
711
- gatewaySelf.platform ? gatewaySelf.platform : null
712
- ].filter(Boolean).join(" ") : null;
713
- const aliveThresholdMs = 10 * 6e4;
714
- const aliveAgents = agentStatus.agents.filter((a) => a.lastActiveAgeMs != null && a.lastActiveAgeMs <= aliveThresholdMs).length;
715
- const lines = await buildStatusAllReportLines({
716
- progress,
717
- overviewRows: [
718
- {
719
- Item: "Version",
720
- Value: VERSION
721
- },
722
- {
723
- Item: "OS",
724
- Value: osSummary.label
725
- },
726
- {
727
- Item: "Node",
728
- Value: process.versions.node
729
- },
730
- {
731
- Item: "Config",
732
- Value: snap?.path?.trim() ? snap.path.trim() : "(unknown config path)"
733
- },
734
- dashboard ? {
735
- Item: "Dashboard",
736
- Value: dashboard
737
- } : {
738
- Item: "Dashboard",
739
- Value: "disabled"
740
- },
741
- {
742
- Item: "Tailscale",
743
- Value: tailscaleMode === "off" ? `off${tailscale.backendState ? ` · ${tailscale.backendState}` : ""}${tailscale.dnsName ? ` · ${tailscale.dnsName}` : ""}` : tailscale.dnsName && tailscaleHttpsUrl ? `${tailscaleMode} · ${tailscale.backendState ?? "unknown"} · ${tailscale.dnsName} · ${tailscaleHttpsUrl}` : `${tailscaleMode} · ${tailscale.backendState ?? "unknown"} · magicdns unknown`
744
- },
745
- {
746
- Item: "Channel",
747
- Value: channelLabel
748
- },
749
- ...gitLabel ? [{
750
- Item: "Git",
751
- Value: gitLabel
752
- }] : [],
753
- {
754
- Item: "Update",
755
- Value: updateLine
756
- },
757
- {
758
- Item: "Gateway",
759
- Value: `${gatewayMode}${remoteUrlMissing ? " (remote.url missing)" : ""} · ${gatewayTarget} (${connection.urlSource}) · ${gatewayStatus}${gatewayAuth}`
760
- },
761
- ...probeAuthResolution.warning ? [{
762
- Item: "Gateway auth warning",
763
- Value: probeAuthResolution.warning
764
- }] : [],
765
- {
766
- Item: "Security",
767
- Value: `Run: ${formatCliCommand("moldclaw security audit --deep")}`
768
- },
769
- gatewaySelfLine ? {
770
- Item: "Gateway self",
771
- Value: gatewaySelfLine
772
- } : {
773
- Item: "Gateway self",
774
- Value: "unknown"
775
- },
776
- daemon ? {
777
- Item: "Gateway service",
778
- Value: !daemon.installed ? `${daemon.label} not installed` : `${daemon.label} ${daemon.managedBymoldClaw ? "installed · " : ""}${daemon.loadedText}${daemon.runtime?.status ? ` · ${daemon.runtime.status}` : ""}${daemon.runtime?.pid ? ` (pid ${daemon.runtime.pid})` : ""}`
779
- } : {
780
- Item: "Gateway service",
781
- Value: "unknown"
782
- },
783
- nodeService ? {
784
- Item: "Node service",
785
- Value: !nodeService.installed ? `${nodeService.label} not installed` : `${nodeService.label} ${nodeService.managedBymoldClaw ? "installed · " : ""}${nodeService.loadedText}${nodeService.runtime?.status ? ` · ${nodeService.runtime.status}` : ""}${nodeService.runtime?.pid ? ` (pid ${nodeService.runtime.pid})` : ""}`
786
- } : {
787
- Item: "Node service",
788
- Value: "unknown"
789
- },
790
- {
791
- Item: "Agents",
792
- Value: `${agentStatus.agents.length} total · ${agentStatus.bootstrapPendingCount} bootstrapping · ${aliveAgents} active · ${agentStatus.totalSessions} sessions`
793
- },
794
- {
795
- Item: "Secrets",
796
- Value: secretDiagnostics.length > 0 ? `${secretDiagnostics.length} diagnostic${secretDiagnostics.length === 1 ? "" : "s"}` : "none"
797
- }
798
- ],
799
- channels,
800
- channelIssues: channelIssues.map((issue) => ({
801
- channel: issue.channel,
802
- message: issue.message
803
- })),
804
- agentStatus,
805
- connectionDetailsForReport,
806
- diagnosis: {
807
- snap,
808
- remoteUrlMissing,
809
- secretDiagnostics,
810
- sentinel,
811
- lastErr,
812
- port,
813
- portUsage,
814
- tailscaleMode,
815
- tailscale,
816
- tailscaleHttpsUrl,
817
- skillStatus,
818
- channelsStatus,
819
- channelIssues,
820
- gatewayReachable,
821
- health
822
- }
823
- });
824
- progress.setLabel("Rendering…");
825
- runtime.log(lines.join("\n"));
826
- progress.tick();
827
- });
828
- }
829
- //#endregion
830
- //#region src/commands/status.scan.ts
831
- let pluginRegistryModulePromise;
832
- let statusScanDepsRuntimeModulePromise;
833
- function loadPluginRegistryModule() {
834
- pluginRegistryModulePromise ??= import("./plugin-registry-DxAXQUlZ.js");
835
- return pluginRegistryModulePromise;
836
- }
837
- const loadStatusScanRuntimeModule = createLazyRuntimeSurface(() => import("./status.scan.runtime-CqScDt-p.js"), ({ statusScanRuntime }) => statusScanRuntime);
838
- function loadStatusScanDepsRuntimeModule() {
839
- statusScanDepsRuntimeModulePromise ??= import("./status.scan.deps.runtime-BcoKEzQD.js");
840
- return statusScanDepsRuntimeModulePromise;
841
- }
842
- function deferResult(promise) {
843
- return promise.then((value) => ({
844
- ok: true,
845
- value
846
- }), (error) => ({
847
- ok: false,
848
- error
849
- }));
850
- }
851
- function unwrapDeferredResult(result) {
852
- if (!result.ok) throw result.error;
853
- return result.value;
854
- }
855
- async function resolveChannelsStatus(params) {
856
- if (!params.gatewayReachable) return null;
857
- return await callGateway({
858
- config: params.cfg,
859
- method: "channels.status",
860
- params: {
861
- probe: false,
862
- timeoutMs: Math.min(8e3, params.opts.timeoutMs ?? 1e4)
863
- },
864
- timeoutMs: Math.min(params.opts.all ? 5e3 : 2500, params.opts.timeoutMs ?? 1e4)
865
- }).catch(() => null);
866
- }
867
- async function resolveMemoryStatusSnapshot(params) {
868
- const { getMemorySearchManager } = await loadStatusScanDepsRuntimeModule();
869
- return await resolveSharedMemoryStatusSnapshot({
870
- cfg: params.cfg,
871
- agentStatus: params.agentStatus,
872
- memoryPlugin: params.memoryPlugin,
873
- resolveMemoryConfig: resolveMemorySearchConfig,
874
- getMemorySearchManager
875
- });
876
- }
877
- async function scanStatusJsonFast(opts) {
878
- const loadedRaw = await readBestEffortConfig();
879
- const { resolvedConfig: cfg, diagnostics: secretDiagnostics } = await resolveCommandSecretRefsViaGateway({
880
- config: loadedRaw,
881
- commandName: "status --json",
882
- targetIds: getStatusCommandSecretTargetIds(),
883
- mode: "read_only_status"
884
- });
885
- if (hasPotentialConfiguredChannels(cfg)) {
886
- const { ensurePluginRegistryLoaded } = await loadPluginRegistryModule();
887
- ensurePluginRegistryLoaded({ scope: "configured-channels" });
888
- }
889
- const osSummary = resolveOsSummary();
890
- const tailscaleMode = cfg.gateway?.tailscale?.mode ?? "off";
891
- const updatePromise = getUpdateCheckResult({
892
- timeoutMs: opts.all ? 6500 : 2500,
893
- fetchGit: true,
894
- includeRegistry: true
895
- });
896
- const agentStatusPromise = getAgentLocalStatuses$1(cfg);
897
- const summaryPromise = getStatusSummary({
898
- config: cfg,
899
- sourceConfig: loadedRaw
900
- });
901
- const tailscaleDnsPromise = tailscaleMode === "off" ? Promise.resolve(null) : loadStatusScanDepsRuntimeModule().then(({ getTailnetHostname }) => getTailnetHostname((cmd, args) => runExec(cmd, args, {
902
- timeoutMs: 1200,
903
- maxBuffer: 2e5
904
- }))).catch(() => null);
905
- const gatewayProbePromise = resolveGatewayProbeSnapshot({
906
- cfg,
907
- opts
908
- });
909
- const [tailscaleDns, update, agentStatus, gatewaySnapshot, summary] = await Promise.all([
910
- tailscaleDnsPromise,
911
- updatePromise,
912
- agentStatusPromise,
913
- gatewayProbePromise,
914
- summaryPromise
915
- ]);
916
- const tailscaleHttpsUrl = buildTailscaleHttpsUrl({
917
- tailscaleMode,
918
- tailscaleDns,
919
- controlUiBasePath: cfg.gateway?.controlUi?.basePath
920
- });
921
- const { gatewayConnection, remoteUrlMissing, gatewayMode, gatewayProbeAuth, gatewayProbeAuthWarning, gatewayProbe } = gatewaySnapshot;
922
- const gatewayReachable = gatewayProbe?.ok === true;
923
- const gatewaySelf = gatewayProbe?.presence ? pickGatewaySelfPresence(gatewayProbe.presence) : null;
924
- const memoryPlugin = resolveMemoryPluginStatus(cfg);
925
- return {
926
- cfg,
927
- sourceConfig: loadedRaw,
928
- secretDiagnostics,
929
- osSummary,
930
- tailscaleMode,
931
- tailscaleDns,
932
- tailscaleHttpsUrl,
933
- update,
934
- gatewayConnection,
935
- remoteUrlMissing,
936
- gatewayMode,
937
- gatewayProbeAuth,
938
- gatewayProbeAuthWarning,
939
- gatewayProbe,
940
- gatewayReachable,
941
- gatewaySelf,
942
- channelIssues: [],
943
- agentStatus,
944
- channels: {
945
- rows: [],
946
- details: []
947
- },
948
- summary,
949
- memory: await resolveMemoryStatusSnapshot({
950
- cfg,
951
- agentStatus,
952
- memoryPlugin
953
- }),
954
- memoryPlugin
955
- };
956
- }
957
- async function scanStatus(opts, _runtime) {
958
- if (opts.json) return await scanStatusJsonFast({
959
- timeoutMs: opts.timeoutMs,
960
- all: opts.all
961
- });
962
- return await withProgress({
963
- label: "Scanning status…",
964
- total: 10,
965
- enabled: true
966
- }, async (progress) => {
967
- progress.setLabel("Loading config…");
968
- const loadedRaw = await readBestEffortConfig();
969
- const { resolvedConfig: cfg, diagnostics: secretDiagnostics } = await resolveCommandSecretRefsViaGateway({
970
- config: loadedRaw,
971
- commandName: "status",
972
- targetIds: getStatusCommandSecretTargetIds(),
973
- mode: "read_only_status"
974
- });
975
- const osSummary = resolveOsSummary();
976
- const tailscaleMode = cfg.gateway?.tailscale?.mode ?? "off";
977
- const tailscaleDnsPromise = tailscaleMode === "off" ? Promise.resolve(null) : loadStatusScanDepsRuntimeModule().then(({ getTailnetHostname }) => getTailnetHostname((cmd, args) => runExec(cmd, args, {
978
- timeoutMs: 1200,
979
- maxBuffer: 2e5
980
- }))).catch(() => null);
981
- const updatePromise = deferResult(getUpdateCheckResult({
982
- timeoutMs: opts.all ? 6500 : 2500,
983
- fetchGit: true,
984
- includeRegistry: true
985
- }));
986
- const agentStatusPromise = deferResult(getAgentLocalStatuses$1(cfg));
987
- const summaryPromise = deferResult(getStatusSummary({
988
- config: cfg,
989
- sourceConfig: loadedRaw
990
- }));
991
- progress.tick();
992
- progress.setLabel("Checking Tailscale…");
993
- const tailscaleDns = await tailscaleDnsPromise;
994
- const tailscaleHttpsUrl = buildTailscaleHttpsUrl({
995
- tailscaleMode,
996
- tailscaleDns,
997
- controlUiBasePath: cfg.gateway?.controlUi?.basePath
998
- });
999
- progress.tick();
1000
- progress.setLabel("Checking for updates…");
1001
- const update = unwrapDeferredResult(await updatePromise);
1002
- progress.tick();
1003
- progress.setLabel("Resolving agents…");
1004
- const agentStatus = unwrapDeferredResult(await agentStatusPromise);
1005
- progress.tick();
1006
- progress.setLabel("Probing gateway…");
1007
- const { gatewayConnection, remoteUrlMissing, gatewayMode, gatewayProbeAuth, gatewayProbeAuthWarning, gatewayProbe } = await resolveGatewayProbeSnapshot({
1008
- cfg,
1009
- opts
1010
- });
1011
- const gatewayReachable = gatewayProbe?.ok === true;
1012
- const gatewaySelf = gatewayProbe?.presence ? pickGatewaySelfPresence(gatewayProbe.presence) : null;
1013
- progress.tick();
1014
- progress.setLabel("Querying channel status…");
1015
- const channelsStatus = await resolveChannelsStatus({
1016
- cfg,
1017
- gatewayReachable,
1018
- opts
1019
- });
1020
- const { collectChannelStatusIssues, buildChannelsTable } = await loadStatusScanRuntimeModule();
1021
- const channelIssues = channelsStatus ? collectChannelStatusIssues(channelsStatus) : [];
1022
- progress.tick();
1023
- progress.setLabel("Summarizing channels…");
1024
- const channels = await buildChannelsTable(cfg, {
1025
- showSecrets: process.env.MOLDCLAW_SHOW_SECRETS?.trim() !== "0",
1026
- sourceConfig: loadedRaw
1027
- });
1028
- progress.tick();
1029
- progress.setLabel("Checking memory…");
1030
- const memoryPlugin = resolveMemoryPluginStatus(cfg);
1031
- const memory = await resolveMemoryStatusSnapshot({
1032
- cfg,
1033
- agentStatus,
1034
- memoryPlugin
1035
- });
1036
- progress.tick();
1037
- progress.setLabel("Reading sessions…");
1038
- const summary = unwrapDeferredResult(await summaryPromise);
1039
- progress.tick();
1040
- progress.setLabel("Rendering…");
1041
- progress.tick();
1042
- return {
1043
- cfg,
1044
- sourceConfig: loadedRaw,
1045
- secretDiagnostics,
1046
- osSummary,
1047
- tailscaleMode,
1048
- tailscaleDns,
1049
- tailscaleHttpsUrl,
1050
- update,
1051
- gatewayConnection,
1052
- remoteUrlMissing,
1053
- gatewayMode,
1054
- gatewayProbeAuth,
1055
- gatewayProbeAuthWarning,
1056
- gatewayProbe,
1057
- gatewayReachable,
1058
- gatewaySelf,
1059
- channelIssues,
1060
- agentStatus,
1061
- channels,
1062
- summary,
1063
- memory,
1064
- memoryPlugin
1065
- };
1066
- });
1067
- }
1068
- //#endregion
1069
- //#region src/commands/status.command.ts
1070
- let providerUsagePromise;
1071
- let securityAuditModulePromise;
1072
- function loadProviderUsage() {
1073
- providerUsagePromise ??= import("./provider-usage-CaDE0mqq.js");
1074
- return providerUsagePromise;
1075
- }
1076
- function loadSecurityAuditModule() {
1077
- securityAuditModulePromise ??= import("./audit.runtime-Y8C9W7s9.js");
1078
- return securityAuditModulePromise;
1079
- }
1080
- function resolvePairingRecoveryContext(params) {
1081
- const sanitizeRequestId = (value) => {
1082
- const trimmed = value.trim();
1083
- if (!trimmed) return null;
1084
- if (!/^[A-Za-z0-9][A-Za-z0-9._:-]{0,127}$/.test(trimmed)) return null;
1085
- return trimmed;
1086
- };
1087
- const source = [params.error, params.closeReason].filter((part) => typeof part === "string" && part.trim().length > 0).join(" ");
1088
- if (!source || !/pairing required/i.test(source)) return null;
1089
- const requestIdMatch = source.match(/requestId:\s*([^\s)]+)/i);
1090
- return { requestId: (requestIdMatch && requestIdMatch[1] ? sanitizeRequestId(requestIdMatch[1]) : null) || null };
1091
- }
1092
- async function statusCommand(opts, runtime) {
1093
- if (opts.all && !opts.json) {
1094
- await statusAllCommand(runtime, { timeoutMs: opts.timeoutMs });
1095
- return;
1096
- }
1097
- const scan = await scanStatus({
1098
- json: opts.json,
1099
- timeoutMs: opts.timeoutMs,
1100
- all: opts.all
1101
- }, runtime);
1102
- const runSecurityAudit = async () => await loadSecurityAuditModule().then(({ runSecurityAudit }) => runSecurityAudit({
1103
- config: scan.cfg,
1104
- sourceConfig: scan.sourceConfig,
1105
- deep: false,
1106
- includeFilesystem: true,
1107
- includeChannelSecurity: true
1108
- }));
1109
- const securityAudit = opts.json ? await runSecurityAudit() : await withProgress({
1110
- label: "Running security audit…",
1111
- indeterminate: true,
1112
- enabled: true
1113
- }, async () => await runSecurityAudit());
1114
- const { cfg, osSummary, tailscaleMode, tailscaleDns, tailscaleHttpsUrl, update, gatewayConnection, remoteUrlMissing, gatewayMode, gatewayProbeAuth, gatewayProbeAuthWarning, gatewayProbe, gatewayReachable, gatewaySelf, channelIssues, agentStatus, channels, summary, secretDiagnostics, memory, memoryPlugin } = scan;
1115
- const usage = opts.usage ? await withProgress({
1116
- label: "Fetching usage snapshot…",
1117
- indeterminate: true,
1118
- enabled: opts.json !== true
1119
- }, async () => {
1120
- const { loadProviderUsageSummary } = await loadProviderUsage();
1121
- return await loadProviderUsageSummary({ timeoutMs: opts.timeoutMs });
1122
- }) : void 0;
1123
- const health = opts.deep ? await withProgress({
1124
- label: "Checking gateway health…",
1125
- indeterminate: true,
1126
- enabled: opts.json !== true
1127
- }, async () => await callGateway({
1128
- method: "health",
1129
- params: { probe: true },
1130
- timeoutMs: opts.timeoutMs,
1131
- config: scan.cfg
1132
- })) : void 0;
1133
- const lastHeartbeat = opts.deep && gatewayReachable ? await callGateway({
1134
- method: "last-heartbeat",
1135
- params: {},
1136
- timeoutMs: opts.timeoutMs,
1137
- config: scan.cfg
1138
- }).catch(() => null) : null;
1139
- const channelInfo = resolveUpdateChannelDisplay({
1140
- configChannel: normalizeUpdateChannel(cfg.update?.channel),
1141
- installKind: update.installKind,
1142
- gitTag: update.git?.tag ?? null,
1143
- gitBranch: update.git?.branch ?? null
1144
- });
1145
- if (opts.json) {
1146
- const [daemon, nodeDaemon] = await Promise.all([getDaemonStatusSummary(), getNodeDaemonStatusSummary()]);
1147
- runtime.log(JSON.stringify({
1148
- ...summary,
1149
- os: osSummary,
1150
- update,
1151
- updateChannel: channelInfo.channel,
1152
- updateChannelSource: channelInfo.source,
1153
- memory,
1154
- memoryPlugin,
1155
- gateway: {
1156
- mode: gatewayMode,
1157
- url: gatewayConnection.url,
1158
- urlSource: gatewayConnection.urlSource,
1159
- misconfigured: remoteUrlMissing,
1160
- reachable: gatewayReachable,
1161
- connectLatencyMs: gatewayProbe?.connectLatencyMs ?? null,
1162
- self: gatewaySelf,
1163
- error: gatewayProbe?.error ?? null,
1164
- authWarning: gatewayProbeAuthWarning ?? null
1165
- },
1166
- gatewayService: daemon,
1167
- nodeService: nodeDaemon,
1168
- agents: agentStatus,
1169
- securityAudit,
1170
- secretDiagnostics,
1171
- ...health || usage || lastHeartbeat ? {
1172
- health,
1173
- usage,
1174
- lastHeartbeat
1175
- } : {}
1176
- }, null, 2));
1177
- return;
1178
- }
1179
- const muted = (value) => theme.muted(value);
1180
- const ok = (value) => theme.success(value);
1181
- const warn = (value) => theme.warn(value);
1182
- if (opts.verbose) {
1183
- const details = buildGatewayConnectionDetails({ config: scan.cfg });
1184
- runtime.log(info("Gateway connection:"));
1185
- for (const line of details.message.split("\n")) runtime.log(` ${line}`);
1186
- runtime.log("");
1187
- }
1188
- const tableWidth = getTerminalTableWidth();
1189
- if (secretDiagnostics.length > 0) {
1190
- runtime.log(theme.warn("Secret diagnostics:"));
1191
- for (const entry of secretDiagnostics) runtime.log(`- ${entry}`);
1192
- runtime.log("");
1193
- }
1194
- const dashboard = (() => {
1195
- if (!(cfg.gateway?.controlUi?.enabled ?? true)) return "disabled";
1196
- return resolveControlUiLinks({
1197
- port: resolveGatewayPort(cfg),
1198
- bind: cfg.gateway?.bind,
1199
- customBindHost: cfg.gateway?.customBindHost,
1200
- basePath: cfg.gateway?.controlUi?.basePath
1201
- }).httpUrl;
1202
- })();
1203
- const gatewayValue = (() => {
1204
- const target = remoteUrlMissing ? `fallback ${gatewayConnection.url}` : `${gatewayConnection.url}${gatewayConnection.urlSource ? ` (${gatewayConnection.urlSource})` : ""}`;
1205
- const reach = remoteUrlMissing ? warn("misconfigured (remote.url missing)") : gatewayReachable ? ok(`reachable ${formatDuration(gatewayProbe?.connectLatencyMs)}`) : warn(gatewayProbe?.error ? `unreachable (${gatewayProbe.error})` : "unreachable");
1206
- const auth = gatewayReachable && !remoteUrlMissing ? ` · auth ${formatGatewayAuthUsed(gatewayProbeAuth)}` : "";
1207
- const self = gatewaySelf?.host || gatewaySelf?.version || gatewaySelf?.platform ? [
1208
- gatewaySelf?.host ? gatewaySelf.host : null,
1209
- gatewaySelf?.ip ? `(${gatewaySelf.ip})` : null,
1210
- gatewaySelf?.version ? `app ${gatewaySelf.version}` : null,
1211
- gatewaySelf?.platform ? gatewaySelf.platform : null
1212
- ].filter(Boolean).join(" ") : null;
1213
- return `${gatewayMode} · ${target} · ${reach}${auth}${self ? ` · ${self}` : ""}`;
1214
- })();
1215
- const pairingRecovery = resolvePairingRecoveryContext({
1216
- error: gatewayProbe?.error ?? null,
1217
- closeReason: gatewayProbe?.close?.reason ?? null
1218
- });
1219
- const agentsValue = (() => {
1220
- const pending = agentStatus.bootstrapPendingCount > 0 ? `${agentStatus.bootstrapPendingCount} bootstrap file${agentStatus.bootstrapPendingCount === 1 ? "" : "s"} present` : "no bootstrap files";
1221
- const def = agentStatus.agents.find((a) => a.id === agentStatus.defaultId);
1222
- const defActive = def?.lastActiveAgeMs != null ? formatTimeAgo(def.lastActiveAgeMs) : "unknown";
1223
- const defSuffix = def ? ` · default ${def.id} active ${defActive}` : "";
1224
- return `${agentStatus.agents.length} · ${pending} · sessions ${agentStatus.totalSessions}${defSuffix}`;
1225
- })();
1226
- const [daemon, nodeDaemon] = await Promise.all([getDaemonStatusSummary(), getNodeDaemonStatusSummary()]);
1227
- const daemonValue = (() => {
1228
- if (daemon.installed === false) return `${daemon.label} not installed`;
1229
- const installedPrefix = daemon.managedBymoldClaw ? "installed · " : "";
1230
- return `${daemon.label} ${installedPrefix}${daemon.loadedText}${daemon.runtimeShort ? ` · ${daemon.runtimeShort}` : ""}`;
1231
- })();
1232
- const nodeDaemonValue = (() => {
1233
- if (nodeDaemon.installed === false) return `${nodeDaemon.label} not installed`;
1234
- const installedPrefix = nodeDaemon.managedBymoldClaw ? "installed · " : "";
1235
- return `${nodeDaemon.label} ${installedPrefix}${nodeDaemon.loadedText}${nodeDaemon.runtimeShort ? ` · ${nodeDaemon.runtimeShort}` : ""}`;
1236
- })();
1237
- const defaults = summary.sessions.defaults;
1238
- const defaultCtx = defaults.contextTokens ? ` (${formatKTokens(defaults.contextTokens)} ctx)` : "";
1239
- const eventsValue = summary.queuedSystemEvents.length > 0 ? `${summary.queuedSystemEvents.length} queued` : "none";
1240
- const probesValue = health ? ok("enabled") : muted("skipped (use --deep)");
1241
- const heartbeatValue = (() => {
1242
- const parts = summary.heartbeat.agents.map((agent) => {
1243
- if (!agent.enabled || !agent.everyMs) return `disabled (${agent.agentId})`;
1244
- return `${agent.every} (${agent.agentId})`;
1245
- }).filter(Boolean);
1246
- return parts.length > 0 ? parts.join(", ") : "disabled";
1247
- })();
1248
- const lastHeartbeatValue = (() => {
1249
- if (!opts.deep) return null;
1250
- if (!gatewayReachable) return warn("unavailable");
1251
- if (!lastHeartbeat) return muted("none");
1252
- const age = formatTimeAgo(Date.now() - lastHeartbeat.ts);
1253
- const channel = lastHeartbeat.channel ?? "unknown";
1254
- const accountLabel = lastHeartbeat.accountId ? `account ${lastHeartbeat.accountId}` : null;
1255
- return [
1256
- lastHeartbeat.status,
1257
- `${age} ago`,
1258
- channel,
1259
- accountLabel
1260
- ].filter(Boolean).join(" · ");
1261
- })();
1262
- const storeLabel = summary.sessions.paths.length > 1 ? `${summary.sessions.paths.length} stores` : summary.sessions.paths[0] ?? "unknown";
1263
- const memoryValue = (() => {
1264
- if (!memoryPlugin.enabled) return muted(`disabled${memoryPlugin.reason ? ` (${memoryPlugin.reason})` : ""}`);
1265
- if (!memory) {
1266
- const slot = memoryPlugin.slot ? `plugin ${memoryPlugin.slot}` : "plugin";
1267
- if (memoryPlugin.slot && memoryPlugin.slot !== "memory-core") return `enabled (${slot})`;
1268
- return muted(`enabled (${slot}) · unavailable`);
1269
- }
1270
- const parts = [];
1271
- const dirtySuffix = memory.dirty ? ` · ${warn("dirty")}` : "";
1272
- parts.push(`${memory.files} files · ${memory.chunks} chunks${dirtySuffix}`);
1273
- if (memory.sources?.length) parts.push(`sources ${memory.sources.join(", ")}`);
1274
- if (memoryPlugin.slot) parts.push(`plugin ${memoryPlugin.slot}`);
1275
- const colorByTone = (tone, text) => tone === "ok" ? ok(text) : tone === "warn" ? warn(text) : muted(text);
1276
- const vector = memory.vector;
1277
- if (vector) {
1278
- const state = resolveMemoryVectorState(vector);
1279
- const label = state.state === "disabled" ? "vector off" : `vector ${state.state}`;
1280
- parts.push(colorByTone(state.tone, label));
1281
- }
1282
- const fts = memory.fts;
1283
- if (fts) {
1284
- const state = resolveMemoryFtsState(fts);
1285
- const label = state.state === "disabled" ? "fts off" : `fts ${state.state}`;
1286
- parts.push(colorByTone(state.tone, label));
1287
- }
1288
- const cache = memory.cache;
1289
- if (cache) {
1290
- const summary = resolveMemoryCacheSummary(cache);
1291
- parts.push(colorByTone(summary.tone, summary.text));
1292
- }
1293
- return parts.join(" · ");
1294
- })();
1295
- const updateAvailability = resolveUpdateAvailability(update);
1296
- const updateLine = formatUpdateOneLiner(update).replace(/^Update:\s*/i, "");
1297
- const channelLabel = channelInfo.label;
1298
- const gitLabel = formatGitInstallLabel(update);
1299
- const overviewRows = [
1300
- {
1301
- Item: "Dashboard",
1302
- Value: dashboard
1303
- },
1304
- {
1305
- Item: "OS",
1306
- Value: `${osSummary.label} · node ${process.versions.node}`
1307
- },
1308
- {
1309
- Item: "Tailscale",
1310
- Value: tailscaleMode === "off" ? muted("off") : tailscaleDns && tailscaleHttpsUrl ? `${tailscaleMode} · ${tailscaleDns} · ${tailscaleHttpsUrl}` : warn(`${tailscaleMode} · magicdns unknown`)
1311
- },
1312
- {
1313
- Item: "Channel",
1314
- Value: channelLabel
1315
- },
1316
- ...gitLabel ? [{
1317
- Item: "Git",
1318
- Value: gitLabel
1319
- }] : [],
1320
- {
1321
- Item: "Update",
1322
- Value: updateAvailability.available ? warn(`available · ${updateLine}`) : updateLine
1323
- },
1324
- {
1325
- Item: "Gateway",
1326
- Value: gatewayValue
1327
- },
1328
- ...gatewayProbeAuthWarning ? [{
1329
- Item: "Gateway auth warning",
1330
- Value: warn(gatewayProbeAuthWarning)
1331
- }] : [],
1332
- {
1333
- Item: "Gateway service",
1334
- Value: daemonValue
1335
- },
1336
- {
1337
- Item: "Node service",
1338
- Value: nodeDaemonValue
1339
- },
1340
- {
1341
- Item: "Agents",
1342
- Value: agentsValue
1343
- },
1344
- {
1345
- Item: "Memory",
1346
- Value: memoryValue
1347
- },
1348
- {
1349
- Item: "Probes",
1350
- Value: probesValue
1351
- },
1352
- {
1353
- Item: "Events",
1354
- Value: eventsValue
1355
- },
1356
- {
1357
- Item: "Heartbeat",
1358
- Value: heartbeatValue
1359
- },
1360
- ...lastHeartbeatValue ? [{
1361
- Item: "Last heartbeat",
1362
- Value: lastHeartbeatValue
1363
- }] : [],
1364
- {
1365
- Item: "Sessions",
1366
- Value: `${summary.sessions.count} active · default ${defaults.model ?? "unknown"}${defaultCtx} · ${storeLabel}`
1367
- }
1368
- ];
1369
- runtime.log(theme.heading("moldClaw status"));
1370
- runtime.log("");
1371
- runtime.log(theme.heading("Overview"));
1372
- runtime.log(renderTable({
1373
- width: tableWidth,
1374
- columns: [{
1375
- key: "Item",
1376
- header: "Item",
1377
- minWidth: 12
1378
- }, {
1379
- key: "Value",
1380
- header: "Value",
1381
- flex: true,
1382
- minWidth: 32
1383
- }],
1384
- rows: overviewRows
1385
- }).trimEnd());
1386
- if (pairingRecovery) {
1387
- runtime.log("");
1388
- runtime.log(theme.warn("Gateway pairing approval required."));
1389
- if (pairingRecovery.requestId) runtime.log(theme.muted(`Recovery: ${formatCliCommand(`moldclaw devices approve ${pairingRecovery.requestId}`)}`));
1390
- runtime.log(theme.muted(`Fallback: ${formatCliCommand("moldclaw devices approve --latest")}`));
1391
- runtime.log(theme.muted(`Inspect: ${formatCliCommand("moldclaw devices list")}`));
1392
- }
1393
- runtime.log("");
1394
- runtime.log(theme.heading("Security audit"));
1395
- const fmtSummary = (value) => {
1396
- return [
1397
- theme.error(`${value.critical} critical`),
1398
- theme.warn(`${value.warn} warn`),
1399
- theme.muted(`${value.info} info`)
1400
- ].join(" · ");
1401
- };
1402
- runtime.log(theme.muted(`Summary: ${fmtSummary(securityAudit.summary)}`));
1403
- const importantFindings = securityAudit.findings.filter((f) => f.severity === "critical" || f.severity === "warn");
1404
- if (importantFindings.length === 0) runtime.log(theme.muted("No critical or warn findings detected."));
1405
- else {
1406
- const severityLabel = (sev) => {
1407
- if (sev === "critical") return theme.error("CRITICAL");
1408
- if (sev === "warn") return theme.warn("WARN");
1409
- return theme.muted("INFO");
1410
- };
1411
- const sevRank = (sev) => sev === "critical" ? 0 : sev === "warn" ? 1 : 2;
1412
- const sorted = [...importantFindings].toSorted((a, b) => sevRank(a.severity) - sevRank(b.severity));
1413
- const shown = sorted.slice(0, 6);
1414
- for (const f of shown) {
1415
- runtime.log(` ${severityLabel(f.severity)} ${f.title}`);
1416
- runtime.log(` ${shortenText(f.detail.replaceAll("\n", " "), 160)}`);
1417
- if (f.remediation?.trim()) runtime.log(` ${theme.muted(`Fix: ${f.remediation.trim()}`)}`);
1418
- }
1419
- if (sorted.length > shown.length) runtime.log(theme.muted(`… +${sorted.length - shown.length} more`));
1420
- }
1421
- runtime.log(theme.muted(`Full report: ${formatCliCommand("moldclaw security audit")}`));
1422
- runtime.log(theme.muted(`Deep probe: ${formatCliCommand("moldclaw security audit --deep")}`));
1423
- runtime.log("");
1424
- runtime.log(theme.heading("Channels"));
1425
- const channelIssuesByChannel = groupChannelIssuesByChannel(channelIssues);
1426
- runtime.log(renderTable({
1427
- width: tableWidth,
1428
- columns: [
1429
- {
1430
- key: "Channel",
1431
- header: "Channel",
1432
- minWidth: 10
1433
- },
1434
- {
1435
- key: "Enabled",
1436
- header: "Enabled",
1437
- minWidth: 7
1438
- },
1439
- {
1440
- key: "State",
1441
- header: "State",
1442
- minWidth: 8
1443
- },
1444
- {
1445
- key: "Detail",
1446
- header: "Detail",
1447
- flex: true,
1448
- minWidth: 24
1449
- }
1450
- ],
1451
- rows: channels.rows.map((row) => {
1452
- const issues = channelIssuesByChannel.get(row.id) ?? [];
1453
- const effectiveState = row.state === "off" ? "off" : issues.length > 0 ? "warn" : row.state;
1454
- const issueSuffix = issues.length > 0 ? ` · ${warn(`gateway: ${shortenText(issues[0]?.message ?? "issue", 84)}`)}` : "";
1455
- return {
1456
- Channel: row.label,
1457
- Enabled: row.enabled ? ok("ON") : muted("OFF"),
1458
- State: effectiveState === "ok" ? ok("OK") : effectiveState === "warn" ? warn("WARN") : effectiveState === "off" ? muted("OFF") : theme.accentDim("SETUP"),
1459
- Detail: `${row.detail}${issueSuffix}`
1460
- };
1461
- })
1462
- }).trimEnd());
1463
- runtime.log("");
1464
- runtime.log(theme.heading("Sessions"));
1465
- runtime.log(renderTable({
1466
- width: tableWidth,
1467
- columns: [
1468
- {
1469
- key: "Key",
1470
- header: "Key",
1471
- minWidth: 20,
1472
- flex: true
1473
- },
1474
- {
1475
- key: "Kind",
1476
- header: "Kind",
1477
- minWidth: 6
1478
- },
1479
- {
1480
- key: "Age",
1481
- header: "Age",
1482
- minWidth: 9
1483
- },
1484
- {
1485
- key: "Model",
1486
- header: "Model",
1487
- minWidth: 14
1488
- },
1489
- {
1490
- key: "Tokens",
1491
- header: "Tokens",
1492
- minWidth: 16
1493
- }
1494
- ],
1495
- rows: summary.sessions.recent.length > 0 ? summary.sessions.recent.map((sess) => ({
1496
- Key: shortenText(sess.key, 32),
1497
- Kind: sess.kind,
1498
- Age: sess.updatedAt ? formatTimeAgo(sess.age) : "no activity",
1499
- Model: sess.model ?? "unknown",
1500
- Tokens: formatTokensCompact(sess)
1501
- })) : [{
1502
- Key: muted("no sessions yet"),
1503
- Kind: "",
1504
- Age: "",
1505
- Model: "",
1506
- Tokens: ""
1507
- }]
1508
- }).trimEnd());
1509
- if (summary.queuedSystemEvents.length > 0) {
1510
- runtime.log("");
1511
- runtime.log(theme.heading("System events"));
1512
- runtime.log(renderTable({
1513
- width: tableWidth,
1514
- columns: [{
1515
- key: "Event",
1516
- header: "Event",
1517
- flex: true,
1518
- minWidth: 24
1519
- }],
1520
- rows: summary.queuedSystemEvents.slice(0, 5).map((event) => ({ Event: event }))
1521
- }).trimEnd());
1522
- if (summary.queuedSystemEvents.length > 5) runtime.log(muted(`… +${summary.queuedSystemEvents.length - 5} more`));
1523
- }
1524
- if (health) {
1525
- runtime.log("");
1526
- runtime.log(theme.heading("Health"));
1527
- const rows = [];
1528
- rows.push({
1529
- Item: "Gateway",
1530
- Status: ok("reachable"),
1531
- Detail: `${health.durationMs}ms`
1532
- });
1533
- for (const line of formatHealthChannelLines(health, { accountMode: "all" })) {
1534
- const colon = line.indexOf(":");
1535
- if (colon === -1) continue;
1536
- const item = line.slice(0, colon).trim();
1537
- const detail = line.slice(colon + 1).trim();
1538
- const normalized = detail.toLowerCase();
1539
- const status = (() => {
1540
- if (normalized.startsWith("ok")) return ok("OK");
1541
- if (normalized.startsWith("failed")) return warn("WARN");
1542
- if (normalized.startsWith("not configured")) return muted("OFF");
1543
- if (normalized.startsWith("configured")) return ok("OK");
1544
- if (normalized.startsWith("linked")) return ok("LINKED");
1545
- if (normalized.startsWith("not linked")) return warn("UNLINKED");
1546
- return warn("WARN");
1547
- })();
1548
- rows.push({
1549
- Item: item,
1550
- Status: status,
1551
- Detail: detail
1552
- });
1553
- }
1554
- runtime.log(renderTable({
1555
- width: tableWidth,
1556
- columns: [
1557
- {
1558
- key: "Item",
1559
- header: "Item",
1560
- minWidth: 10
1561
- },
1562
- {
1563
- key: "Status",
1564
- header: "Status",
1565
- minWidth: 8
1566
- },
1567
- {
1568
- key: "Detail",
1569
- header: "Detail",
1570
- flex: true,
1571
- minWidth: 28
1572
- }
1573
- ],
1574
- rows
1575
- }).trimEnd());
1576
- }
1577
- if (usage) {
1578
- const { formatUsageReportLines } = await loadProviderUsage();
1579
- runtime.log("");
1580
- runtime.log(theme.heading("Usage"));
1581
- for (const line of formatUsageReportLines(usage)) runtime.log(line);
1582
- }
1583
- runtime.log("");
1584
- runtime.log("FAQ: https://docs.moldclaw.ai/faq");
1585
- runtime.log("Troubleshooting: https://docs.moldclaw.ai/troubleshooting");
1586
- runtime.log("");
1587
- const updateHint = formatUpdateAvailableHint(update);
1588
- if (updateHint) {
1589
- runtime.log(theme.warn(updateHint));
1590
- runtime.log("");
1591
- }
1592
- runtime.log("Next steps:");
1593
- runtime.log(` Need to share? ${formatCliCommand("moldclaw status --all")}`);
1594
- runtime.log(` Need to debug live? ${formatCliCommand("moldclaw logs --follow")}`);
1595
- if (gatewayReachable) runtime.log(` Need to test channels? ${formatCliCommand("moldclaw status --deep")}`);
1596
- else runtime.log(` Fix reachability first: ${formatCliCommand("moldclaw gateway probe")}`);
1597
- }
1598
- //#endregion
1599
- export { statusCommand as t };