@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,1490 +0,0 @@
1
- import "./redact-fatrROh9.js";
2
- import "./errors-DOJWZqNo.js";
3
- import "./unhandled-rejections-CTvNvnT0.js";
4
- import "./logger-BFfIIIKH.js";
5
- import "./paths-D6AgsMTU.js";
6
- import "./tmp-moldclaw-dir-DWF-d8qD.js";
7
- import "./theme-BSXzMzAA.js";
8
- import "./globals-DESrFYmC.js";
9
- import "./subsystem-S4LNMNHd.js";
10
- import "./ansi-BPhP6LBZ.js";
11
- import "./boolean-D8Ha5nYV.js";
12
- import "./env-Dgex_t9p.js";
13
- import "./warning-filter-gJuwHM7C.js";
14
- import "./utils-rjVNXUns.js";
15
- import "./links-C5I443Xb.js";
16
- import "./setup-binary-Fw3cCSWL.js";
17
- import { $w as formatAllowlistMatchMeta, Ah as createScopedPairingAccess, Nd as resolveDmGroupAccessWithLists, Oh as issuePairingChallenge, Ug as logInboundDrop, Uw as resolveControlCommandGate, Wg as logTypingFailure, _s as toLocationContext, ag as createTypingCallbacks, gs as formatLocationText, hs as resolveInboundSessionEnvelopeContext, kd as readStoreAllowFromForDmPolicy, sT as mergeAllowlist, sg as createReplyPrefixOptions, uT as summarizeMapping } from "./auth-profiles-BJcHzwPy.js";
18
- import "./model-selection-DfA4esOK.js";
19
- import "./agent-scope-DA7O8MVG.js";
20
- import "./account-id-O4Og6DrK.js";
21
- import "./boundary-file-read-Y1cMjPlu.js";
22
- import "./logger-wrbK9-ju.js";
23
- import "./exec-CoBTyh8B.js";
24
- import "./workspace-CxNKYS0V.js";
25
- import "./io-DcoxdH6t.js";
26
- import "./host-env-security-xy11yVnm.js";
27
- import "./safe-text-BcUvBreN.js";
28
- import "./version-rW_3ob2o.js";
29
- import "./env-substitution-C9xZMTDL.js";
30
- import "./config-state-D1JkXt39.js";
31
- import "./network-mode-CE-ihBf6.js";
32
- import "./registry-DcDGl2X7.js";
33
- import "./manifest-registry-_0xclaVY.js";
34
- import "./ip-w605xvSx.js";
35
- import "./zod-schema.core-CWxzqcUs.js";
36
- import "./config-CkD8DJ7L.js";
37
- import "./audit-fs-SjcfoPO7.js";
38
- import "./resolve-3ErMOltL.js";
39
- import "./provider-web-search-BR7etTjJ.js";
40
- import "./text-runtime-CgEQ9Y9_.js";
41
- import "./workspace-dirs-L1_QQ9mB.js";
42
- import "./config-BbxrRaLf.js";
43
- import "./tailnet-KyAU6tj_.js";
44
- import "./net-B_Iq_SVP.js";
45
- import "./credentials-D5uBf_C5.js";
46
- import "./routes-BNDsNO_e.js";
47
- import "./frontmatter-BTDAgsA3.js";
48
- import "./env-overrides-BHxqjYZG.js";
49
- import "./path-alias-guards-B3ZKrId1.js";
50
- import "./skills-B4h1k-SP.js";
51
- import "./ports-BVwQuCIR.js";
52
- import "./ports-lsof-DiY6GaAf.js";
53
- import "./ssh-tunnel-BaHTFPzH.js";
54
- import "./image-ops-Uw4rEShL.js";
55
- import "./fs-safe-Da4H0IOU.js";
56
- import "./mime-_IkgFMS2.js";
57
- import "./server-middleware-BPq4bu3A.js";
58
- import "./message-channel-CKeDAoOT.js";
59
- import "./resolve-route-IkBfMjBz.js";
60
- import "./internal-hooks-0x1JiQ5f.js";
61
- import { a as resolveSenderScopedGroupPolicy, c as resolveAllowlistProviderRuntimeGroupPolicy, f as warnMissingProviderGroupPolicyFallbackOnce, l as resolveDefaultGroupPolicy, o as GROUP_POLICY_BLOCKED_LABEL, t as evaluateGroupRouteAccessForPolicy } from "./group-access-BWGTPTwF.js";
62
- import "./lazy-runtime-DdzFA4b9.js";
63
- import "./config-schema-GQ6uWjXe.js";
64
- import "./method-scopes-D-Q9dvbj.js";
65
- import "./session-cost-usage-B-57mlS8.js";
66
- import "./paths-CDWV-9nX.js";
67
- import "./routing-3o2D0ix4.js";
68
- import "./send-Cm9v3uhF.js";
69
- import "./node-resolve-DfOpQmxm.js";
70
- import "./provider-stream-gVymYPmd.js";
71
- import "./identity-file-DM4N5_7H.js";
72
- import "./provider-models-BA3hqqPq.js";
73
- import "./secret-file-Bjh19aoH.js";
74
- import "./logging-BdFqMomc.js";
75
- import "./runtime-env-CT-voxYE.js";
76
- import "./registry-xhgvU89y.js";
77
- import "./provider-onboard-CBC3kdk_.js";
78
- import "./model-definitions-DwehIMlw.js";
79
- import "./diagnostic-vMghIesG.js";
80
- import "./message-hook-mappers-DORrSLHM.js";
81
- import "./json-store-DlpyvQXN.js";
82
- import "./call-CoaQYq7c.js";
83
- import "./multimodal-BWF8MRkz.js";
84
- import "./memory-search-BBG2BKIh.js";
85
- import "./query-expansion-8R79qExs.js";
86
- import "./search-manager-CfizyEMk.js";
87
- import "./core-EKuk2FxR.js";
88
- import "./issue-format-i6sEuV4a.js";
89
- import "./logging-S-5LPdfQ.js";
90
- import "./note-z78_JyNp.js";
91
- import "./state-paths-C7dX__ql.js";
92
- import "./config-value-Dh8m-CFf.js";
93
- import "./command-secret-targets-CO_lZ_ZZ.js";
94
- import "./brave-BG5Yopn8.js";
95
- import "./provider-usage-DzuzbNBv.js";
96
- import "./perplexity-Brhpb45X.js";
97
- import "./restart-stale-pids-CN9ElYwR.js";
98
- import "./delivery-queue-DLjFP-0C.js";
99
- import "./pairing-token-ANLRyJSu.js";
100
- import "./accounts-BCaV8MsT.js";
101
- import "./process-runtime-CicRKAFe.js";
102
- import "./audit-BqRK9OSj.js";
103
- import "./cli-runtime-DtIDS2w7.js";
104
- import "./cli-utils-FHeUZLsT.js";
105
- import "./help-format-1yV2Xzq7.js";
106
- import "./progress-BQSTKUhd.js";
107
- import "./gateway-runtime-C76hUmUV.js";
108
- import "./run-command-DLrfpRdi.js";
109
- import { n as resolveRuntimeEnv } from "./runtime-CE5bcF01.js";
110
- import { n as dispatchReplyFromConfigWithSettledDispatcher } from "./inbound-reply-dispatch-DoIJLztA.js";
111
- import { _ as isBunRuntime, d as stopSharedClientForAccount, g as loadMatrixSdk, m as resolveMatrixAuth, o as resolveMatrixAccount, r as resolveMatrixTargets, u as resolveSharedMatrixClient } from "./matrix-Dfzcc5nV.js";
112
- import { s as getMatrixRuntime } from "./credentials-CgJiOMDt.js";
113
- import { a as sendTypingMatrix, d as isPollStartType, f as parsePollStartContent, i as sendReadReceiptMatrix, l as setActiveMatrixClient, n as sendMessageMatrix, t as reactMatrixMessage, u as formatPollAsText } from "./send-BTLVBf_E.js";
114
- import { a as resolveMatrixRoomConfig, i as resolveMatrixAllowListMatches, n as normalizeMatrixUserId, o as fetchEventSummary, r as resolveMatrixAllowListMatch, t as normalizeMatrixAllowList } from "./allowlist-B2eBBeMF.js";
115
- import "./probe-CJQlxgsl.js";
116
- //#region extensions/matrix/src/matrix/monitor/auto-join.ts
117
- function registerMatrixAutoJoin(params) {
118
- const { client, cfg, runtime } = params;
119
- const core = getMatrixRuntime();
120
- const logVerbose = (message) => {
121
- if (!core.logging.shouldLogVerbose()) return;
122
- runtime.log?.(message);
123
- };
124
- const autoJoin = cfg.channels?.matrix?.autoJoin ?? "always";
125
- const autoJoinAllowlist = cfg.channels?.matrix?.autoJoinAllowlist ?? [];
126
- if (autoJoin === "off") return;
127
- if (autoJoin === "always") {
128
- const { AutojoinRoomsMixin } = loadMatrixSdk();
129
- AutojoinRoomsMixin.setupOnClient(client);
130
- logVerbose("matrix: auto-join enabled for all invites");
131
- return;
132
- }
133
- client.on("room.invite", async (roomId, _inviteEvent) => {
134
- if (autoJoin !== "allowlist") return;
135
- let alias;
136
- let altAliases = [];
137
- try {
138
- const aliasState = await client.getRoomStateEvent(roomId, "m.room.canonical_alias", "").catch(() => null);
139
- alias = aliasState?.alias;
140
- altAliases = Array.isArray(aliasState?.alt_aliases) ? aliasState.alt_aliases : [];
141
- } catch {}
142
- if (!(autoJoinAllowlist.includes("*") || autoJoinAllowlist.includes(roomId) || (alias ? autoJoinAllowlist.includes(alias) : false) || altAliases.some((value) => autoJoinAllowlist.includes(value)))) {
143
- logVerbose(`matrix: invite ignored (not in allowlist) room=${roomId}`);
144
- return;
145
- }
146
- try {
147
- await client.joinRoom(roomId);
148
- logVerbose(`matrix: joined room ${roomId}`);
149
- } catch (err) {
150
- runtime.error?.(`matrix: failed to join room ${roomId}: ${String(err)}`);
151
- }
152
- });
153
- }
154
- //#endregion
155
- //#region extensions/matrix/src/matrix/monitor/direct.ts
156
- const DM_CACHE_TTL_MS = 3e4;
157
- /**
158
- * Check if an error is a Matrix M_NOT_FOUND response (missing state event).
159
- * The bot-sdk throws MatrixError with errcode/statusCode on the error object.
160
- */
161
- function isMatrixNotFoundError(err) {
162
- if (typeof err !== "object" || err === null) return false;
163
- const e = err;
164
- return e.errcode === "M_NOT_FOUND" || e.statusCode === 404;
165
- }
166
- function createDirectRoomTracker(client, opts = {}) {
167
- const log = opts.log ?? (() => {});
168
- const includeMemberCountInLogs = opts.includeMemberCountInLogs === true;
169
- let lastDmUpdateMs = 0;
170
- let cachedSelfUserId = null;
171
- const memberCountCache = /* @__PURE__ */ new Map();
172
- const ensureSelfUserId = async () => {
173
- if (cachedSelfUserId) return cachedSelfUserId;
174
- try {
175
- cachedSelfUserId = await client.getUserId();
176
- } catch {
177
- cachedSelfUserId = null;
178
- }
179
- return cachedSelfUserId;
180
- };
181
- const refreshDmCache = async () => {
182
- const now = Date.now();
183
- if (now - lastDmUpdateMs < DM_CACHE_TTL_MS) return;
184
- lastDmUpdateMs = now;
185
- try {
186
- await client.dms.update();
187
- } catch (err) {
188
- log(`matrix: dm cache refresh failed (${String(err)})`);
189
- }
190
- };
191
- const resolveMemberCount = async (roomId) => {
192
- const cached = memberCountCache.get(roomId);
193
- const now = Date.now();
194
- if (cached && now - cached.ts < DM_CACHE_TTL_MS) return cached.count;
195
- try {
196
- const count = (await client.getJoinedRoomMembers(roomId)).length;
197
- memberCountCache.set(roomId, {
198
- count,
199
- ts: now
200
- });
201
- return count;
202
- } catch (err) {
203
- log(`matrix: dm member count failed room=${roomId} (${String(err)})`);
204
- return null;
205
- }
206
- };
207
- const hasDirectFlag = async (roomId, userId) => {
208
- const target = userId?.trim();
209
- if (!target) return false;
210
- try {
211
- return (await client.getRoomStateEvent(roomId, "m.room.member", target))?.is_direct === true;
212
- } catch {
213
- return false;
214
- }
215
- };
216
- return { isDirectMessage: async (params) => {
217
- const { roomId, senderId } = params;
218
- await refreshDmCache();
219
- if (client.dms.isDm(roomId)) {
220
- log(`matrix: dm detected via m.direct room=${roomId}`);
221
- return true;
222
- }
223
- const selfUserId = params.selfUserId ?? await ensureSelfUserId();
224
- if (await hasDirectFlag(roomId, senderId) || await hasDirectFlag(roomId, selfUserId ?? "")) {
225
- log(`matrix: dm detected via member state room=${roomId}`);
226
- return true;
227
- }
228
- const memberCount = await resolveMemberCount(roomId);
229
- if (memberCount === 2) try {
230
- if (!(await client.getRoomStateEvent(roomId, "m.room.name", ""))?.name?.trim()) {
231
- log(`matrix: dm detected via fallback (2 members, no room name) room=${roomId}`);
232
- return true;
233
- }
234
- } catch (err) {
235
- if (isMatrixNotFoundError(err)) {
236
- log(`matrix: dm detected via fallback (2 members, no room name) room=${roomId}`);
237
- return true;
238
- }
239
- log(`matrix: dm fallback skipped (room name check failed: ${String(err)}) room=${roomId}`);
240
- }
241
- if (!includeMemberCountInLogs) {
242
- log(`matrix: dm check room=${roomId} result=group`);
243
- return false;
244
- }
245
- log(`matrix: dm check room=${roomId} result=group members=${memberCount ?? "unknown"}`);
246
- return false;
247
- } };
248
- }
249
- //#endregion
250
- //#region extensions/matrix/src/matrix/monitor/types.ts
251
- const EventType = {
252
- RoomMessage: "m.room.message",
253
- RoomMessageEncrypted: "m.room.encrypted",
254
- RoomMember: "m.room.member",
255
- Location: "m.location"
256
- };
257
- const RelationType$1 = {
258
- Replace: "m.replace",
259
- Thread: "m.thread"
260
- };
261
- //#endregion
262
- //#region extensions/matrix/src/matrix/monitor/events.ts
263
- const matrixMonitorListenerRegistry = (() => {
264
- const registeredClients = /* @__PURE__ */ new WeakSet();
265
- return { tryRegister(client) {
266
- if (registeredClients.has(client)) return false;
267
- registeredClients.add(client);
268
- return true;
269
- } };
270
- })();
271
- function createSelfUserIdResolver(client) {
272
- let selfUserId;
273
- let selfUserIdLookup;
274
- return async () => {
275
- if (selfUserId) return selfUserId;
276
- if (!selfUserIdLookup) selfUserIdLookup = client.getUserId().then((userId) => {
277
- selfUserId = userId;
278
- return userId;
279
- }).catch(() => void 0).finally(() => {
280
- if (!selfUserId) selfUserIdLookup = void 0;
281
- });
282
- return await selfUserIdLookup;
283
- };
284
- }
285
- function registerMatrixMonitorEvents(params) {
286
- if (!matrixMonitorListenerRegistry.tryRegister(params.client)) {
287
- params.logVerboseMessage("matrix: skipping duplicate listener registration for client");
288
- return;
289
- }
290
- const { client, auth, logVerboseMessage, warnedEncryptedRooms, warnedCryptoMissingRooms, logger, formatNativeDependencyHint, onRoomMessage } = params;
291
- const resolveSelfUserId = createSelfUserIdResolver(client);
292
- client.on("room.message", (roomId, event) => {
293
- const eventId = event?.event_id;
294
- const senderId = event?.sender;
295
- if (eventId && senderId) (async () => {
296
- const currentSelfUserId = await resolveSelfUserId();
297
- if (!currentSelfUserId || senderId === currentSelfUserId) return;
298
- await sendReadReceiptMatrix(roomId, eventId, client).catch((err) => {
299
- logVerboseMessage(`matrix: early read receipt failed room=${roomId} id=${eventId}: ${String(err)}`);
300
- });
301
- })();
302
- onRoomMessage(roomId, event);
303
- });
304
- client.on("room.encrypted_event", (roomId, event) => {
305
- const eventId = event?.event_id ?? "unknown";
306
- logVerboseMessage(`matrix: encrypted event room=${roomId} type=${event?.type ?? "unknown"} id=${eventId}`);
307
- });
308
- client.on("room.decrypted_event", (roomId, event) => {
309
- const eventId = event?.event_id ?? "unknown";
310
- logVerboseMessage(`matrix: decrypted event room=${roomId} type=${event?.type ?? "unknown"} id=${eventId}`);
311
- });
312
- client.on("room.failed_decryption", async (roomId, event, error) => {
313
- logger.warn("Failed to decrypt message", {
314
- roomId,
315
- eventId: event.event_id,
316
- error: error.message
317
- });
318
- logVerboseMessage(`matrix: failed decrypt room=${roomId} id=${event.event_id ?? "unknown"} error=${error.message}`);
319
- });
320
- client.on("room.invite", (roomId, event) => {
321
- const eventId = event?.event_id ?? "unknown";
322
- const sender = event?.sender ?? "unknown";
323
- const isDirect = (event?.content)?.is_direct === true;
324
- logVerboseMessage(`matrix: invite room=${roomId} sender=${sender} direct=${String(isDirect)} id=${eventId}`);
325
- });
326
- client.on("room.join", (roomId, event) => {
327
- logVerboseMessage(`matrix: join room=${roomId} id=${event?.event_id ?? "unknown"}`);
328
- });
329
- client.on("room.event", (roomId, event) => {
330
- const eventType = event?.type ?? "unknown";
331
- if (eventType === EventType.RoomMessageEncrypted) {
332
- logVerboseMessage(`matrix: encrypted raw event room=${roomId} id=${event?.event_id ?? "unknown"}`);
333
- if (auth.encryption !== true && !warnedEncryptedRooms.has(roomId)) {
334
- warnedEncryptedRooms.add(roomId);
335
- logger.warn("matrix: encrypted event received without encryption enabled; set channels.matrix.encryption=true and verify the device to decrypt", { roomId });
336
- }
337
- if (auth.encryption === true && !client.crypto && !warnedCryptoMissingRooms.has(roomId)) {
338
- warnedCryptoMissingRooms.add(roomId);
339
- const warning = `matrix: encryption enabled but crypto is unavailable; ${formatNativeDependencyHint({
340
- packageName: "@matrix-org/matrix-sdk-crypto-nodejs",
341
- manager: "pnpm",
342
- downloadCommand: "node node_modules/@matrix-org/matrix-sdk-crypto-nodejs/download-lib.js"
343
- })}`;
344
- logger.warn(warning, { roomId });
345
- }
346
- return;
347
- }
348
- if (eventType === EventType.RoomMember) {
349
- const membership = (event?.content)?.membership;
350
- logVerboseMessage(`matrix: member event room=${roomId} stateKey=${event.state_key ?? ""} membership=${membership ?? "unknown"}`);
351
- }
352
- });
353
- }
354
- //#endregion
355
- //#region extensions/matrix/src/matrix/monitor/access-policy.ts
356
- async function resolveMatrixAccessState(params) {
357
- const storeAllowFrom = params.isDirectMessage ? await readStoreAllowFromForDmPolicy({
358
- provider: "matrix",
359
- accountId: params.resolvedAccountId,
360
- dmPolicy: params.dmPolicy,
361
- readStore: params.readStoreForDmPolicy
362
- }) : [];
363
- const normalizedGroupAllowFrom = normalizeMatrixAllowList(params.groupAllowFrom);
364
- const senderGroupPolicy = resolveSenderScopedGroupPolicy({
365
- groupPolicy: params.groupPolicy,
366
- groupAllowFrom: normalizedGroupAllowFrom
367
- });
368
- const access = resolveDmGroupAccessWithLists({
369
- isGroup: !params.isDirectMessage,
370
- dmPolicy: params.dmPolicy,
371
- groupPolicy: senderGroupPolicy,
372
- allowFrom: params.allowFrom,
373
- groupAllowFrom: normalizedGroupAllowFrom,
374
- storeAllowFrom,
375
- groupAllowFromFallbackToAllowFrom: false,
376
- isSenderAllowed: (allowFrom) => resolveMatrixAllowListMatches({
377
- allowList: normalizeMatrixAllowList(allowFrom),
378
- userId: params.senderId
379
- })
380
- });
381
- const effectiveAllowFrom = normalizeMatrixAllowList(access.effectiveAllowFrom);
382
- const effectiveGroupAllowFrom = normalizeMatrixAllowList(access.effectiveGroupAllowFrom);
383
- return {
384
- access,
385
- effectiveAllowFrom,
386
- effectiveGroupAllowFrom,
387
- groupAllowConfigured: effectiveGroupAllowFrom.length > 0
388
- };
389
- }
390
- async function enforceMatrixDirectMessageAccess(params) {
391
- if (!params.dmEnabled) return false;
392
- if (params.accessDecision === "allow") return true;
393
- const allowMatchMeta = formatAllowlistMatchMeta(resolveMatrixAllowListMatch({
394
- allowList: params.effectiveAllowFrom,
395
- userId: params.senderId
396
- }));
397
- if (params.accessDecision === "pairing") {
398
- await issuePairingChallenge({
399
- channel: "matrix",
400
- senderId: params.senderId,
401
- senderIdLine: `Matrix user id: ${params.senderId}`,
402
- meta: { name: params.senderName },
403
- upsertPairingRequest: params.upsertPairingRequest,
404
- buildReplyText: ({ code }) => [
405
- "MoldClaw: access not configured.",
406
- "",
407
- `Pairing code: ${code}`,
408
- "",
409
- "Ask the bot owner to approve with:",
410
- "moldclaw pairing approve matrix <code>"
411
- ].join("\n"),
412
- sendPairingReply: params.sendPairingReply,
413
- onCreated: () => {
414
- params.logVerboseMessage(`matrix pairing request sender=${params.senderId} name=${params.senderName ?? "unknown"} (${allowMatchMeta})`);
415
- },
416
- onReplyError: (err) => {
417
- params.logVerboseMessage(`matrix pairing reply failed for ${params.senderId}: ${String(err)}`);
418
- }
419
- });
420
- return false;
421
- }
422
- params.logVerboseMessage(`matrix: blocked dm sender ${params.senderId} (dmPolicy=${params.dmPolicy}, ${allowMatchMeta})`);
423
- return false;
424
- }
425
- //#endregion
426
- //#region extensions/matrix/src/matrix/monitor/inbound-body.ts
427
- function resolveMatrixSenderUsername(senderId) {
428
- const username = senderId.split(":")[0]?.replace(/^@/, "").trim();
429
- return username ? username : void 0;
430
- }
431
- function resolveMatrixInboundSenderLabel(params) {
432
- const senderName = params.senderName.trim();
433
- const senderUsername = params.senderUsername ?? resolveMatrixSenderUsername(params.senderId);
434
- if (senderName && senderUsername && senderName !== senderUsername) return `${senderName} (${senderUsername})`;
435
- return senderName || senderUsername || params.senderId;
436
- }
437
- function resolveMatrixBodyForAgent(params) {
438
- if (params.isDirectMessage) return params.bodyText;
439
- return `${params.senderLabel}: ${params.bodyText}`;
440
- }
441
- //#endregion
442
- //#region extensions/matrix/src/matrix/monitor/location.ts
443
- function parseGeoUri(value) {
444
- const trimmed = value.trim();
445
- if (!trimmed) return null;
446
- if (!trimmed.toLowerCase().startsWith("geo:")) return null;
447
- const [coordsPart, ...paramParts] = trimmed.slice(4).split(";");
448
- const coords = coordsPart.split(",");
449
- if (coords.length < 2) return null;
450
- const latitude = Number.parseFloat(coords[0] ?? "");
451
- const longitude = Number.parseFloat(coords[1] ?? "");
452
- if (!Number.isFinite(latitude) || !Number.isFinite(longitude)) return null;
453
- const params = /* @__PURE__ */ new Map();
454
- for (const part of paramParts) {
455
- const segment = part.trim();
456
- if (!segment) continue;
457
- const eqIndex = segment.indexOf("=");
458
- const rawKey = eqIndex === -1 ? segment : segment.slice(0, eqIndex);
459
- const rawValue = eqIndex === -1 ? "" : segment.slice(eqIndex + 1);
460
- const key = rawKey.trim().toLowerCase();
461
- if (!key) continue;
462
- const valuePart = rawValue.trim();
463
- params.set(key, valuePart ? decodeURIComponent(valuePart) : "");
464
- }
465
- const accuracyRaw = params.get("u");
466
- const accuracy = accuracyRaw ? Number.parseFloat(accuracyRaw) : void 0;
467
- return {
468
- latitude,
469
- longitude,
470
- accuracy: Number.isFinite(accuracy) ? accuracy : void 0
471
- };
472
- }
473
- function resolveMatrixLocation(params) {
474
- const { eventType, content } = params;
475
- if (!(eventType === EventType.Location || eventType === EventType.RoomMessage && content.msgtype === EventType.Location)) return null;
476
- const geoUri = typeof content.geo_uri === "string" ? content.geo_uri.trim() : "";
477
- if (!geoUri) return null;
478
- const parsed = parseGeoUri(geoUri);
479
- if (!parsed) return null;
480
- const caption = typeof content.body === "string" ? content.body.trim() : "";
481
- const location = {
482
- latitude: parsed.latitude,
483
- longitude: parsed.longitude,
484
- accuracy: parsed.accuracy,
485
- caption: caption || void 0,
486
- source: "pin",
487
- isLive: false
488
- };
489
- return {
490
- text: formatLocationText(location),
491
- context: toLocationContext(location)
492
- };
493
- }
494
- //#endregion
495
- //#region extensions/matrix/src/matrix/monitor/media.ts
496
- async function fetchMatrixMediaBuffer(params) {
497
- if (!params.client.mxcToHttp(params.mxcUrl)) return null;
498
- try {
499
- const result = await params.client.downloadContent(params.mxcUrl);
500
- const raw = result.data ?? result;
501
- const buffer = Buffer.isBuffer(raw) ? raw : Buffer.from(raw);
502
- if (buffer.byteLength > params.maxBytes) throw new Error("Matrix media exceeds configured size limit");
503
- return {
504
- buffer,
505
- headerType: result.contentType
506
- };
507
- } catch (err) {
508
- throw new Error(`Matrix media download failed: ${String(err)}`, { cause: err });
509
- }
510
- }
511
- /**
512
- * Download and decrypt encrypted media from a Matrix room.
513
- * Uses @vector-im/matrix-bot-sdk's decryptMedia which handles both download and decryption.
514
- */
515
- async function fetchEncryptedMediaBuffer(params) {
516
- if (!params.client.crypto) throw new Error("Cannot decrypt media: crypto not enabled");
517
- const decrypted = await params.client.crypto.decryptMedia(params.file);
518
- if (decrypted.byteLength > params.maxBytes) throw new Error("Matrix media exceeds configured size limit");
519
- return { buffer: decrypted };
520
- }
521
- async function downloadMatrixMedia(params) {
522
- let fetched;
523
- if (typeof params.sizeBytes === "number" && params.sizeBytes > params.maxBytes) throw new Error("Matrix media exceeds configured size limit");
524
- if (params.file) fetched = await fetchEncryptedMediaBuffer({
525
- client: params.client,
526
- file: params.file,
527
- maxBytes: params.maxBytes
528
- });
529
- else fetched = await fetchMatrixMediaBuffer({
530
- client: params.client,
531
- mxcUrl: params.mxcUrl,
532
- maxBytes: params.maxBytes
533
- });
534
- if (!fetched) return null;
535
- const headerType = fetched.headerType ?? params.contentType ?? void 0;
536
- const saved = await getMatrixRuntime().channel.media.saveMediaBuffer(fetched.buffer, headerType, "inbound", params.maxBytes);
537
- return {
538
- path: saved.path,
539
- contentType: saved.contentType,
540
- placeholder: "[matrix media]"
541
- };
542
- }
543
- //#endregion
544
- //#region extensions/matrix/src/matrix/monitor/mentions.ts
545
- /**
546
- * Check if the formatted_body contains a matrix.to mention link for the given user ID.
547
- * Many Matrix clients (including Element) use HTML links in formatted_body instead of
548
- * or in addition to the m.mentions field.
549
- */
550
- function checkFormattedBodyMention(formattedBody, userId) {
551
- if (!formattedBody || !userId) return false;
552
- const escapedUserId = userId.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
553
- if (new RegExp(`href=["']https://matrix\\.to/#/${escapedUserId}["']`, "i").test(formattedBody)) return true;
554
- const encodedUserId = encodeURIComponent(userId).replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
555
- return new RegExp(`href=["']https://matrix\\.to/#/${encodedUserId}["']`, "i").test(formattedBody);
556
- }
557
- function resolveMentions(params) {
558
- const mentions = params.content["m.mentions"];
559
- const mentionedUsers = Array.isArray(mentions?.user_ids) ? new Set(mentions.user_ids) : /* @__PURE__ */ new Set();
560
- const mentionedInFormattedBody = params.userId ? checkFormattedBodyMention(params.content.formatted_body, params.userId) : false;
561
- return {
562
- wasMentioned: Boolean(mentions?.room) || (params.userId ? mentionedUsers.has(params.userId) : false) || mentionedInFormattedBody || getMatrixRuntime().channel.mentions.matchesMentionPatterns(params.text ?? "", params.mentionRegexes),
563
- hasExplicitMention: Boolean(mentions)
564
- };
565
- }
566
- //#endregion
567
- //#region extensions/matrix/src/matrix/monitor/replies.ts
568
- async function deliverMatrixReplies(params) {
569
- const core = getMatrixRuntime();
570
- const cfg = core.config.loadConfig();
571
- const tableMode = params.tableMode ?? core.channel.text.resolveMarkdownTableMode({
572
- cfg,
573
- channel: "matrix",
574
- accountId: params.accountId
575
- });
576
- const logVerbose = (message) => {
577
- if (core.logging.shouldLogVerbose()) params.runtime.log?.(message);
578
- };
579
- const chunkLimit = Math.min(params.textLimit, 4e3);
580
- const chunkMode = core.channel.text.resolveChunkMode(cfg, "matrix", params.accountId);
581
- let hasReplied = false;
582
- for (const reply of params.replies) {
583
- const hasMedia = Boolean(reply?.mediaUrl) || (reply?.mediaUrls?.length ?? 0) > 0;
584
- if (!reply?.text && !hasMedia) {
585
- if (reply?.audioAsVoice) {
586
- logVerbose("matrix reply has audioAsVoice without media/text; skipping");
587
- continue;
588
- }
589
- params.runtime.error?.("matrix reply missing text/media");
590
- continue;
591
- }
592
- if (reply.text && isReasoningOnlyMessage(reply.text)) {
593
- logVerbose("matrix reply is reasoning-only; skipping");
594
- continue;
595
- }
596
- const replyToIdRaw = reply.replyToId?.trim();
597
- const replyToId = params.threadId || params.replyToMode === "off" ? void 0 : replyToIdRaw;
598
- const rawText = reply.text ?? "";
599
- const text = core.channel.text.convertMarkdownTables(rawText, tableMode);
600
- const mediaList = reply.mediaUrls?.length ? reply.mediaUrls : reply.mediaUrl ? [reply.mediaUrl] : [];
601
- const shouldIncludeReply = (id) => Boolean(id) && (params.replyToMode === "all" || !hasReplied);
602
- const replyToIdForReply = shouldIncludeReply(replyToId) ? replyToId : void 0;
603
- if (mediaList.length === 0) {
604
- let sentTextChunk = false;
605
- for (const chunk of core.channel.text.chunkMarkdownTextWithMode(text, chunkLimit, chunkMode)) {
606
- const trimmed = chunk.trim();
607
- if (!trimmed) continue;
608
- await sendMessageMatrix(params.roomId, trimmed, {
609
- client: params.client,
610
- replyToId: replyToIdForReply,
611
- threadId: params.threadId,
612
- accountId: params.accountId
613
- });
614
- sentTextChunk = true;
615
- }
616
- if (replyToIdForReply && !hasReplied && sentTextChunk) hasReplied = true;
617
- continue;
618
- }
619
- let first = true;
620
- for (const mediaUrl of mediaList) {
621
- const caption = first ? text : "";
622
- await sendMessageMatrix(params.roomId, caption, {
623
- client: params.client,
624
- mediaUrl,
625
- replyToId: replyToIdForReply,
626
- threadId: params.threadId,
627
- audioAsVoice: reply.audioAsVoice,
628
- accountId: params.accountId
629
- });
630
- first = false;
631
- }
632
- if (replyToIdForReply && !hasReplied) hasReplied = true;
633
- }
634
- }
635
- const REASONING_PREFIX = "Reasoning:\n";
636
- const THINKING_TAG_RE = /^\s*<\s*(?:think(?:ing)?|thought|antthinking)\b/i;
637
- /**
638
- * Detect messages that contain only reasoning/thinking content and no user-facing answer.
639
- * These are emitted by the agent when `includeReasoning` is active but should not
640
- * be forwarded to channels that do not support a dedicated reasoning lane.
641
- */
642
- function isReasoningOnlyMessage(text) {
643
- const trimmed = text.trim();
644
- if (trimmed.startsWith(REASONING_PREFIX)) return true;
645
- if (THINKING_TAG_RE.test(trimmed)) return true;
646
- return false;
647
- }
648
- //#endregion
649
- //#region extensions/matrix/src/matrix/monitor/threads.ts
650
- const RelationType = { Thread: "m.thread" };
651
- function resolveMatrixThreadTarget(params) {
652
- const { threadReplies, messageId, threadRootId } = params;
653
- if (threadReplies === "off") return;
654
- const isThreadRoot = params.isThreadRoot === true;
655
- const hasInboundThread = Boolean(threadRootId && threadRootId !== messageId && !isThreadRoot);
656
- if (threadReplies === "inbound") return hasInboundThread ? threadRootId : void 0;
657
- if (threadReplies === "always") return threadRootId ?? messageId;
658
- }
659
- function resolveMatrixThreadRootId(params) {
660
- const relates = params.content["m.relates_to"];
661
- if (!relates || typeof relates !== "object") return;
662
- if ("rel_type" in relates && relates.rel_type === RelationType.Thread) {
663
- if ("event_id" in relates && typeof relates.event_id === "string") return relates.event_id;
664
- if ("m.in_reply_to" in relates && typeof relates["m.in_reply_to"] === "object" && relates["m.in_reply_to"] && "event_id" in relates["m.in_reply_to"] && typeof relates["m.in_reply_to"].event_id === "string") return relates["m.in_reply_to"].event_id;
665
- }
666
- }
667
- //#endregion
668
- //#region extensions/matrix/src/matrix/monitor/handler.ts
669
- function resolveMatrixBaseRouteSession(params) {
670
- const sessionKey = params.isDirectMessage && params.baseRoute.matchedBy === "binding.peer.parent" ? params.buildAgentSessionKey({
671
- agentId: params.baseRoute.agentId,
672
- channel: "matrix",
673
- accountId: params.accountId,
674
- peer: {
675
- kind: "channel",
676
- id: params.roomId
677
- }
678
- }) : params.baseRoute.sessionKey;
679
- return {
680
- sessionKey,
681
- lastRoutePolicy: sessionKey === params.baseRoute.mainSessionKey ? "main" : "session"
682
- };
683
- }
684
- function shouldOverrideMatrixDmToGroup(params) {
685
- return params.isDirectMessage === true && params.roomConfigInfo?.config !== void 0 && params.roomConfigInfo.allowed === true && params.roomConfigInfo.matchSource === "direct";
686
- }
687
- function createMatrixRoomMessageHandler(params) {
688
- const { client, core, cfg, runtime, logger, logVerboseMessage, allowFrom, roomsConfig, mentionRegexes, groupPolicy, replyToMode, threadReplies, dmEnabled, dmPolicy, textLimit, mediaMaxBytes, startupMs, startupGraceMs, directTracker, getRoomInfo, getMemberDisplayName, accountId } = params;
689
- const resolvedAccountId = accountId?.trim() || "default";
690
- const pairing = createScopedPairingAccess({
691
- core,
692
- channel: "matrix",
693
- accountId: resolvedAccountId
694
- });
695
- return async (roomId, event) => {
696
- try {
697
- const eventType = event.type;
698
- if (eventType === EventType.RoomMessageEncrypted) return;
699
- const isPollEvent = isPollStartType(eventType);
700
- const locationContent = event.content;
701
- const isLocationEvent = eventType === EventType.Location || eventType === EventType.RoomMessage && locationContent.msgtype === EventType.Location;
702
- if (eventType !== EventType.RoomMessage && !isPollEvent && !isLocationEvent) return;
703
- logVerboseMessage(`matrix: room.message recv room=${roomId} type=${eventType} id=${event.event_id ?? "unknown"}`);
704
- if (event.unsigned?.redacted_because) return;
705
- const senderId = event.sender;
706
- if (!senderId) return;
707
- const selfUserId = await client.getUserId();
708
- if (senderId === selfUserId) return;
709
- const eventTs = event.origin_server_ts;
710
- const eventAge = event.unsigned?.age;
711
- if (typeof eventTs === "number" && eventTs < startupMs - startupGraceMs) return;
712
- if (typeof eventTs !== "number" && typeof eventAge === "number" && eventAge > startupGraceMs) return;
713
- const roomInfo = await getRoomInfo(roomId);
714
- const roomName = roomInfo.name;
715
- const roomAliases = [roomInfo.canonicalAlias ?? "", ...roomInfo.altAliases].filter(Boolean);
716
- let content = event.content;
717
- if (isPollEvent) {
718
- const pollStartContent = event.content;
719
- const pollSummary = parsePollStartContent(pollStartContent);
720
- if (pollSummary) {
721
- pollSummary.eventId = event.event_id ?? "";
722
- pollSummary.roomId = roomId;
723
- pollSummary.sender = senderId;
724
- pollSummary.senderName = await getMemberDisplayName(roomId, senderId);
725
- content = {
726
- msgtype: "m.text",
727
- body: formatPollAsText(pollSummary)
728
- };
729
- } else return;
730
- }
731
- const locationPayload = resolveMatrixLocation({
732
- eventType,
733
- content
734
- });
735
- const relates = content["m.relates_to"];
736
- if (relates && "rel_type" in relates) {
737
- if (relates.rel_type === RelationType$1.Replace) return;
738
- }
739
- let isDirectMessage = await directTracker.isDirectMessage({
740
- roomId,
741
- senderId,
742
- selfUserId
743
- });
744
- const roomConfigInfo = resolveMatrixRoomConfig({
745
- rooms: roomsConfig,
746
- roomId,
747
- aliases: roomAliases,
748
- name: roomName
749
- });
750
- if (shouldOverrideMatrixDmToGroup({
751
- isDirectMessage,
752
- roomConfigInfo
753
- })) {
754
- logVerboseMessage(`matrix: overriding DM to group for configured room=${roomId} (${roomConfigInfo.matchKey})`);
755
- isDirectMessage = false;
756
- }
757
- const isRoom = !isDirectMessage;
758
- if (isRoom && groupPolicy === "disabled") return;
759
- const roomConfig = isRoom ? roomConfigInfo?.config : void 0;
760
- const roomMatchMeta = roomConfigInfo ? `matchKey=${roomConfigInfo.matchKey ?? "none"} matchSource=${roomConfigInfo.matchSource ?? "none"}` : "matchKey=none matchSource=none";
761
- if (isRoom) {
762
- const routeAccess = evaluateGroupRouteAccessForPolicy({
763
- groupPolicy,
764
- routeAllowlistConfigured: Boolean(roomConfigInfo?.allowlistConfigured),
765
- routeMatched: Boolean(roomConfig),
766
- routeEnabled: roomConfigInfo?.allowed ?? true
767
- });
768
- if (!routeAccess.allowed) {
769
- if (routeAccess.reason === "route_disabled") logVerboseMessage(`matrix: room disabled room=${roomId} (${roomMatchMeta})`);
770
- else if (routeAccess.reason === "empty_allowlist") logVerboseMessage(`matrix: drop room message (no allowlist, ${roomMatchMeta})`);
771
- else if (routeAccess.reason === "route_not_allowlisted") logVerboseMessage(`matrix: drop room message (not in allowlist, ${roomMatchMeta})`);
772
- return;
773
- }
774
- }
775
- const senderName = await getMemberDisplayName(roomId, senderId);
776
- const senderUsername = resolveMatrixSenderUsername(senderId);
777
- const senderLabel = resolveMatrixInboundSenderLabel({
778
- senderName,
779
- senderId,
780
- senderUsername
781
- });
782
- const groupAllowFrom = cfg.channels?.matrix?.groupAllowFrom ?? [];
783
- const { access, effectiveAllowFrom, effectiveGroupAllowFrom, groupAllowConfigured } = await resolveMatrixAccessState({
784
- isDirectMessage,
785
- resolvedAccountId,
786
- dmPolicy,
787
- groupPolicy,
788
- allowFrom,
789
- groupAllowFrom,
790
- senderId,
791
- readStoreForDmPolicy: pairing.readStoreForDmPolicy
792
- });
793
- if (isDirectMessage) {
794
- if (!await enforceMatrixDirectMessageAccess({
795
- dmEnabled,
796
- dmPolicy,
797
- accessDecision: access.decision,
798
- senderId,
799
- senderName,
800
- effectiveAllowFrom,
801
- upsertPairingRequest: pairing.upsertPairingRequest,
802
- sendPairingReply: async (text) => {
803
- await sendMessageMatrix(`room:${roomId}`, text, { client });
804
- },
805
- logVerboseMessage
806
- })) return;
807
- }
808
- const roomUsers = roomConfig?.users ?? [];
809
- if (isRoom && roomUsers.length > 0) {
810
- const userMatch = resolveMatrixAllowListMatch({
811
- allowList: normalizeMatrixAllowList(roomUsers),
812
- userId: senderId
813
- });
814
- if (!userMatch.allowed) {
815
- logVerboseMessage(`matrix: blocked sender ${senderId} (room users allowlist, ${roomMatchMeta}, ${formatAllowlistMatchMeta(userMatch)})`);
816
- return;
817
- }
818
- }
819
- if (isRoom && roomUsers.length === 0 && groupAllowConfigured && access.decision !== "allow") {
820
- const groupAllowMatch = resolveMatrixAllowListMatch({
821
- allowList: effectiveGroupAllowFrom,
822
- userId: senderId
823
- });
824
- if (!groupAllowMatch.allowed) {
825
- logVerboseMessage(`matrix: blocked sender ${senderId} (groupAllowFrom, ${roomMatchMeta}, ${formatAllowlistMatchMeta(groupAllowMatch)})`);
826
- return;
827
- }
828
- }
829
- if (isRoom) logVerboseMessage(`matrix: allow room ${roomId} (${roomMatchMeta})`);
830
- const rawBody = locationPayload?.text ?? (typeof content.body === "string" ? content.body.trim() : "");
831
- let media = null;
832
- const contentUrl = "url" in content && typeof content.url === "string" ? content.url : void 0;
833
- const contentFile = "file" in content && content.file && typeof content.file === "object" ? content.file : void 0;
834
- const mediaUrl = contentUrl ?? contentFile?.url;
835
- if (!rawBody && !mediaUrl) return;
836
- const contentInfo = "info" in content && content.info && typeof content.info === "object" ? content.info : void 0;
837
- const contentType = contentInfo?.mimetype;
838
- const contentSize = typeof contentInfo?.size === "number" ? contentInfo.size : void 0;
839
- if (mediaUrl?.startsWith("mxc://")) try {
840
- media = await downloadMatrixMedia({
841
- client,
842
- mxcUrl: mediaUrl,
843
- contentType,
844
- sizeBytes: contentSize,
845
- maxBytes: mediaMaxBytes,
846
- file: contentFile
847
- });
848
- } catch (err) {
849
- logVerboseMessage(`matrix: media download failed: ${String(err)}`);
850
- }
851
- const bodyText = rawBody || media?.placeholder || "";
852
- if (!bodyText) return;
853
- const { wasMentioned, hasExplicitMention } = resolveMentions({
854
- content,
855
- userId: selfUserId,
856
- text: bodyText,
857
- mentionRegexes
858
- });
859
- const allowTextCommands = core.channel.commands.shouldHandleTextCommands({
860
- cfg,
861
- surface: "matrix"
862
- });
863
- const useAccessGroups = cfg.commands?.useAccessGroups !== false;
864
- const senderAllowedForCommands = resolveMatrixAllowListMatches({
865
- allowList: effectiveAllowFrom,
866
- userId: senderId
867
- });
868
- const senderAllowedForGroup = groupAllowConfigured ? resolveMatrixAllowListMatches({
869
- allowList: effectiveGroupAllowFrom,
870
- userId: senderId
871
- }) : false;
872
- const senderAllowedForRoomUsers = isRoom && roomUsers.length > 0 ? resolveMatrixAllowListMatches({
873
- allowList: normalizeMatrixAllowList(roomUsers),
874
- userId: senderId
875
- }) : false;
876
- const hasControlCommandInMessage = core.channel.text.hasControlCommand(bodyText, cfg);
877
- const commandGate = resolveControlCommandGate({
878
- useAccessGroups,
879
- authorizers: [
880
- {
881
- configured: effectiveAllowFrom.length > 0,
882
- allowed: senderAllowedForCommands
883
- },
884
- {
885
- configured: roomUsers.length > 0,
886
- allowed: senderAllowedForRoomUsers
887
- },
888
- {
889
- configured: groupAllowConfigured,
890
- allowed: senderAllowedForGroup
891
- }
892
- ],
893
- allowTextCommands,
894
- hasControlCommand: hasControlCommandInMessage
895
- });
896
- const commandAuthorized = commandGate.commandAuthorized;
897
- if (isRoom && commandGate.shouldBlock) {
898
- logInboundDrop({
899
- log: logVerboseMessage,
900
- channel: "matrix",
901
- reason: "control command (unauthorized)",
902
- target: senderId
903
- });
904
- return;
905
- }
906
- const shouldRequireMention = isRoom ? roomConfig?.autoReply === true ? false : roomConfig?.autoReply === false ? true : typeof roomConfig?.requireMention === "boolean" ? roomConfig?.requireMention : true : false;
907
- const shouldBypassMention = allowTextCommands && isRoom && shouldRequireMention && !wasMentioned && !hasExplicitMention && commandAuthorized && hasControlCommandInMessage;
908
- const canDetectMention = mentionRegexes.length > 0 || hasExplicitMention;
909
- if (isRoom && shouldRequireMention && !wasMentioned && !shouldBypassMention) {
910
- logger.info("skipping room message", {
911
- roomId,
912
- reason: "no-mention"
913
- });
914
- return;
915
- }
916
- const messageId = event.event_id ?? "";
917
- const replyToEventId = content["m.relates_to"]?.["m.in_reply_to"]?.event_id;
918
- const threadRootId = resolveMatrixThreadRootId({
919
- event,
920
- content
921
- });
922
- const threadTarget = resolveMatrixThreadTarget({
923
- threadReplies,
924
- messageId,
925
- threadRootId,
926
- isThreadRoot: false
927
- });
928
- const baseRoute = core.channel.routing.resolveAgentRoute({
929
- cfg,
930
- channel: "matrix",
931
- accountId,
932
- peer: {
933
- kind: isDirectMessage ? "direct" : "channel",
934
- id: isDirectMessage ? senderId : roomId
935
- },
936
- parentPeer: isDirectMessage ? {
937
- kind: "channel",
938
- id: roomId
939
- } : void 0
940
- });
941
- const baseRouteSession = resolveMatrixBaseRouteSession({
942
- buildAgentSessionKey: core.channel.routing.buildAgentSessionKey,
943
- baseRoute,
944
- isDirectMessage,
945
- roomId,
946
- accountId
947
- });
948
- const route = {
949
- ...baseRoute,
950
- lastRoutePolicy: baseRouteSession.lastRoutePolicy,
951
- sessionKey: threadRootId ? `${baseRouteSession.sessionKey}:thread:${threadRootId}` : baseRouteSession.sessionKey
952
- };
953
- let threadStarterBody;
954
- let threadLabel;
955
- let parentSessionKey;
956
- if (threadRootId) {
957
- if (core.channel.session.readSessionUpdatedAt({
958
- storePath: core.channel.session.resolveStorePath(cfg.session?.store, { agentId: baseRoute.agentId }),
959
- sessionKey: route.sessionKey
960
- }) === void 0) try {
961
- const rootEvent = await fetchEventSummary(client, roomId, threadRootId);
962
- if (rootEvent?.body) {
963
- const rootSenderName = rootEvent.sender ? await getMemberDisplayName(roomId, rootEvent.sender) : void 0;
964
- threadStarterBody = core.channel.reply.formatAgentEnvelope({
965
- channel: "Matrix",
966
- from: rootSenderName ?? rootEvent.sender ?? "Unknown",
967
- timestamp: rootEvent.timestamp,
968
- envelope: core.channel.reply.resolveEnvelopeFormatOptions(cfg),
969
- body: rootEvent.body
970
- });
971
- threadLabel = `Matrix thread in ${roomName ?? roomId}`;
972
- parentSessionKey = baseRoute.sessionKey;
973
- }
974
- } catch (err) {
975
- logVerboseMessage(`matrix: failed to fetch thread root ${threadRootId}: ${String(err)}`);
976
- }
977
- }
978
- const envelopeFrom = isDirectMessage ? senderName : roomName ?? roomId;
979
- const textWithId = threadRootId ? `${bodyText}\n[matrix event id: ${messageId} room: ${roomId} thread: ${threadRootId}]` : `${bodyText}\n[matrix event id: ${messageId} room: ${roomId}]`;
980
- const { storePath, envelopeOptions, previousTimestamp } = resolveInboundSessionEnvelopeContext({
981
- cfg,
982
- agentId: route.agentId,
983
- sessionKey: route.sessionKey
984
- });
985
- const body = core.channel.reply.formatInboundEnvelope({
986
- channel: "Matrix",
987
- from: envelopeFrom,
988
- timestamp: eventTs ?? void 0,
989
- previousTimestamp,
990
- envelope: envelopeOptions,
991
- body: textWithId,
992
- chatType: isDirectMessage ? "direct" : "channel",
993
- senderLabel
994
- });
995
- const groupSystemPrompt = roomConfig?.systemPrompt?.trim() || void 0;
996
- const ctxPayload = core.channel.reply.finalizeInboundContext({
997
- Body: body,
998
- BodyForAgent: resolveMatrixBodyForAgent({
999
- isDirectMessage,
1000
- bodyText,
1001
- senderLabel
1002
- }),
1003
- RawBody: bodyText,
1004
- CommandBody: bodyText,
1005
- From: isDirectMessage ? `matrix:${senderId}` : `matrix:channel:${roomId}`,
1006
- To: `room:${roomId}`,
1007
- SessionKey: route.sessionKey,
1008
- AccountId: route.accountId,
1009
- ChatType: threadRootId ? "thread" : isDirectMessage ? "direct" : "channel",
1010
- ConversationLabel: envelopeFrom,
1011
- SenderName: senderName,
1012
- SenderId: senderId,
1013
- SenderUsername: senderUsername,
1014
- GroupSubject: isRoom ? roomName ?? roomId : void 0,
1015
- GroupChannel: isRoom ? roomInfo.canonicalAlias ?? roomId : void 0,
1016
- GroupSystemPrompt: isRoom ? groupSystemPrompt : void 0,
1017
- Provider: "matrix",
1018
- Surface: "matrix",
1019
- WasMentioned: isRoom ? wasMentioned : void 0,
1020
- MessageSid: messageId,
1021
- ReplyToId: threadTarget ? void 0 : replyToEventId ?? void 0,
1022
- MessageThreadId: threadTarget,
1023
- Timestamp: eventTs ?? void 0,
1024
- MediaPath: media?.path,
1025
- MediaType: media?.contentType,
1026
- MediaUrl: media?.path,
1027
- ...locationPayload?.context,
1028
- CommandAuthorized: commandAuthorized,
1029
- CommandSource: "text",
1030
- OriginatingChannel: "matrix",
1031
- OriginatingTo: `room:${roomId}`,
1032
- ThreadStarterBody: threadStarterBody,
1033
- ThreadLabel: threadLabel,
1034
- ParentSessionKey: parentSessionKey
1035
- });
1036
- await core.channel.session.recordInboundSession({
1037
- storePath,
1038
- sessionKey: ctxPayload.SessionKey ?? route.sessionKey,
1039
- ctx: ctxPayload,
1040
- updateLastRoute: isDirectMessage ? {
1041
- sessionKey: route.mainSessionKey,
1042
- channel: "matrix",
1043
- to: `room:${roomId}`,
1044
- accountId: route.accountId
1045
- } : void 0,
1046
- onRecordError: (err) => {
1047
- logger.warn("failed updating session meta", {
1048
- error: String(err),
1049
- storePath,
1050
- sessionKey: ctxPayload.SessionKey ?? route.sessionKey
1051
- });
1052
- }
1053
- });
1054
- logVerboseMessage(`matrix inbound: room=${roomId} from=${senderId} preview="${bodyText.slice(0, 200).replace(/\n/g, "\\n")}"`);
1055
- const ackReaction = (cfg.messages?.ackReaction ?? "").trim();
1056
- const ackScope = cfg.messages?.ackReactionScope ?? "group-mentions";
1057
- const shouldAckReaction = () => Boolean(ackReaction && core.channel.reactions.shouldAckReaction({
1058
- scope: ackScope,
1059
- isDirect: isDirectMessage,
1060
- isGroup: isRoom,
1061
- isMentionableGroup: isRoom,
1062
- requireMention: Boolean(shouldRequireMention),
1063
- canDetectMention,
1064
- effectiveWasMentioned: wasMentioned || shouldBypassMention,
1065
- shouldBypassMention
1066
- }));
1067
- if (shouldAckReaction() && messageId) reactMatrixMessage(roomId, messageId, ackReaction, client).catch((err) => {
1068
- logVerboseMessage(`matrix react failed for room ${roomId}: ${String(err)}`);
1069
- });
1070
- const replyTarget = ctxPayload.To;
1071
- if (!replyTarget) {
1072
- runtime.error?.("matrix: missing reply target");
1073
- return;
1074
- }
1075
- let didSendReply = false;
1076
- const tableMode = core.channel.text.resolveMarkdownTableMode({
1077
- cfg,
1078
- channel: "matrix",
1079
- accountId: route.accountId
1080
- });
1081
- const { onModelSelected, ...prefixOptions } = createReplyPrefixOptions({
1082
- cfg,
1083
- agentId: route.agentId,
1084
- channel: "matrix",
1085
- accountId: route.accountId
1086
- });
1087
- const humanDelay = core.channel.reply.resolveHumanDelayConfig(cfg, route.agentId);
1088
- const typingCallbacks = createTypingCallbacks({
1089
- start: () => sendTypingMatrix(roomId, true, void 0, client),
1090
- stop: () => sendTypingMatrix(roomId, false, void 0, client),
1091
- onStartError: (err) => {
1092
- logTypingFailure({
1093
- log: logVerboseMessage,
1094
- channel: "matrix",
1095
- action: "start",
1096
- target: roomId,
1097
- error: err
1098
- });
1099
- },
1100
- onStopError: (err) => {
1101
- logTypingFailure({
1102
- log: logVerboseMessage,
1103
- channel: "matrix",
1104
- action: "stop",
1105
- target: roomId,
1106
- error: err
1107
- });
1108
- }
1109
- });
1110
- const { dispatcher, replyOptions, markDispatchIdle } = core.channel.reply.createReplyDispatcherWithTyping({
1111
- ...prefixOptions,
1112
- humanDelay,
1113
- typingCallbacks,
1114
- deliver: async (payload) => {
1115
- await deliverMatrixReplies({
1116
- replies: [payload],
1117
- roomId,
1118
- client,
1119
- runtime,
1120
- textLimit,
1121
- replyToMode,
1122
- threadId: threadTarget,
1123
- accountId: route.accountId,
1124
- tableMode
1125
- });
1126
- didSendReply = true;
1127
- },
1128
- onError: (err, info) => {
1129
- runtime.error?.(`matrix ${info.kind} reply failed: ${String(err)}`);
1130
- }
1131
- });
1132
- const { queuedFinal, counts } = await dispatchReplyFromConfigWithSettledDispatcher({
1133
- cfg,
1134
- ctxPayload,
1135
- dispatcher,
1136
- onSettled: () => {
1137
- markDispatchIdle();
1138
- },
1139
- replyOptions: {
1140
- ...replyOptions,
1141
- skillFilter: roomConfig?.skills,
1142
- onModelSelected
1143
- }
1144
- });
1145
- if (!queuedFinal) return;
1146
- didSendReply = true;
1147
- const finalCount = counts.final;
1148
- logVerboseMessage(`matrix: delivered ${finalCount} reply${finalCount === 1 ? "" : "ies"} to ${replyTarget}`);
1149
- if (didSendReply) {
1150
- const previewText = bodyText.replace(/\s+/g, " ").slice(0, 160);
1151
- core.system.enqueueSystemEvent(`Matrix message from ${senderName}: ${previewText}`, {
1152
- sessionKey: route.sessionKey,
1153
- contextKey: `matrix:message:${roomId}:${messageId || "unknown"}`
1154
- });
1155
- }
1156
- } catch (err) {
1157
- runtime.error?.(`matrix handler failed: ${String(err)}`);
1158
- }
1159
- };
1160
- }
1161
- //#endregion
1162
- //#region extensions/matrix/src/matrix/monitor/room-info.ts
1163
- function createMatrixRoomInfoResolver(client) {
1164
- const roomInfoCache = /* @__PURE__ */ new Map();
1165
- const getRoomInfo = async (roomId) => {
1166
- const cached = roomInfoCache.get(roomId);
1167
- if (cached) return cached;
1168
- let name;
1169
- let canonicalAlias;
1170
- let altAliases = [];
1171
- try {
1172
- name = (await client.getRoomStateEvent(roomId, "m.room.name", "").catch(() => null))?.name;
1173
- } catch {}
1174
- try {
1175
- const aliasState = await client.getRoomStateEvent(roomId, "m.room.canonical_alias", "").catch(() => null);
1176
- canonicalAlias = aliasState?.alias;
1177
- altAliases = aliasState?.alt_aliases ?? [];
1178
- } catch {}
1179
- const info = {
1180
- name,
1181
- canonicalAlias,
1182
- altAliases
1183
- };
1184
- roomInfoCache.set(roomId, info);
1185
- return info;
1186
- };
1187
- const getMemberDisplayName = async (roomId, userId) => {
1188
- try {
1189
- return (await client.getRoomStateEvent(roomId, "m.room.member", userId).catch(() => null))?.displayname ?? userId;
1190
- } catch {
1191
- return userId;
1192
- }
1193
- };
1194
- return {
1195
- getRoomInfo,
1196
- getMemberDisplayName
1197
- };
1198
- }
1199
- //#endregion
1200
- //#region extensions/matrix/src/matrix/monitor/index.ts
1201
- const DEFAULT_MEDIA_MAX_MB = 20;
1202
- const DEFAULT_STARTUP_GRACE_MS = 5e3;
1203
- function isConfiguredMatrixRoomEntry(entry) {
1204
- return entry.startsWith("!") || entry.startsWith("#") && entry.includes(":");
1205
- }
1206
- function normalizeMatrixUserEntry(raw) {
1207
- return raw.replace(/^matrix:/i, "").replace(/^user:/i, "").trim();
1208
- }
1209
- function normalizeMatrixRoomEntry(raw) {
1210
- return raw.replace(/^matrix:/i, "").replace(/^(room|channel):/i, "").trim();
1211
- }
1212
- function isMatrixUserId(value) {
1213
- return value.startsWith("@") && value.includes(":");
1214
- }
1215
- async function resolveMatrixUserAllowlist(params) {
1216
- let allowList = params.list ?? [];
1217
- if (allowList.length === 0) return allowList.map(String);
1218
- const entries = allowList.map((entry) => normalizeMatrixUserEntry(String(entry))).filter((entry) => entry && entry !== "*");
1219
- if (entries.length === 0) return allowList.map(String);
1220
- const mapping = [];
1221
- const unresolved = [];
1222
- const additions = [];
1223
- const pending = [];
1224
- for (const entry of entries) {
1225
- if (isMatrixUserId(entry)) {
1226
- additions.push(normalizeMatrixUserId(entry));
1227
- continue;
1228
- }
1229
- pending.push(entry);
1230
- }
1231
- if (pending.length > 0) {
1232
- const resolved = await resolveMatrixTargets({
1233
- cfg: params.cfg,
1234
- inputs: pending,
1235
- kind: "user",
1236
- runtime: params.runtime
1237
- });
1238
- for (const entry of resolved) if (entry.resolved && entry.id) {
1239
- const normalizedId = normalizeMatrixUserId(entry.id);
1240
- additions.push(normalizedId);
1241
- mapping.push(`${entry.input}→${normalizedId}`);
1242
- } else unresolved.push(entry.input);
1243
- }
1244
- allowList = mergeAllowlist({
1245
- existing: allowList,
1246
- additions
1247
- });
1248
- summarizeMapping(params.label, mapping, unresolved, params.runtime);
1249
- if (unresolved.length > 0) params.runtime.log?.(`${params.label} entries must be full Matrix IDs (example: @user:server). Unresolved entries are ignored.`);
1250
- return allowList.map(String);
1251
- }
1252
- async function resolveMatrixRoomsConfig(params) {
1253
- let roomsConfig = params.roomsConfig;
1254
- if (!roomsConfig || Object.keys(roomsConfig).length === 0) return roomsConfig;
1255
- const mapping = [];
1256
- const unresolved = [];
1257
- const nextRooms = {};
1258
- if (roomsConfig["*"]) nextRooms["*"] = roomsConfig["*"];
1259
- const pending = [];
1260
- for (const [entry, roomConfig] of Object.entries(roomsConfig)) {
1261
- if (entry === "*") continue;
1262
- const trimmed = entry.trim();
1263
- if (!trimmed) continue;
1264
- const cleaned = normalizeMatrixRoomEntry(trimmed);
1265
- if (isConfiguredMatrixRoomEntry(cleaned)) {
1266
- if (!nextRooms[cleaned]) nextRooms[cleaned] = roomConfig;
1267
- if (cleaned !== entry) mapping.push(`${entry}→${cleaned}`);
1268
- continue;
1269
- }
1270
- pending.push({
1271
- input: entry,
1272
- query: trimmed,
1273
- config: roomConfig
1274
- });
1275
- }
1276
- if (pending.length > 0) (await resolveMatrixTargets({
1277
- cfg: params.cfg,
1278
- inputs: pending.map((entry) => entry.query),
1279
- kind: "group",
1280
- runtime: params.runtime
1281
- })).forEach((entry, index) => {
1282
- const source = pending[index];
1283
- if (!source) return;
1284
- if (entry.resolved && entry.id) {
1285
- if (!nextRooms[entry.id]) nextRooms[entry.id] = source.config;
1286
- mapping.push(`${source.input}→${entry.id}`);
1287
- } else unresolved.push(source.input);
1288
- });
1289
- roomsConfig = nextRooms;
1290
- summarizeMapping("matrix rooms", mapping, unresolved, params.runtime);
1291
- if (unresolved.length > 0) params.runtime.log?.("matrix rooms must be room IDs or aliases (example: !room:server or #alias:server). Unresolved entries are ignored.");
1292
- if (Object.keys(roomsConfig).length === 0) return roomsConfig;
1293
- const nextRoomsWithUsers = { ...roomsConfig };
1294
- for (const [roomKey, roomConfig] of Object.entries(roomsConfig)) {
1295
- const users = roomConfig?.users ?? [];
1296
- if (users.length === 0) continue;
1297
- const resolvedUsers = await resolveMatrixUserAllowlist({
1298
- cfg: params.cfg,
1299
- runtime: params.runtime,
1300
- label: `matrix room users (${roomKey})`,
1301
- list: users
1302
- });
1303
- if (resolvedUsers !== users) nextRoomsWithUsers[roomKey] = {
1304
- ...roomConfig,
1305
- users: resolvedUsers
1306
- };
1307
- }
1308
- return nextRoomsWithUsers;
1309
- }
1310
- async function resolveMatrixMonitorConfig(params) {
1311
- return {
1312
- allowFrom: await resolveMatrixUserAllowlist({
1313
- cfg: params.cfg,
1314
- runtime: params.runtime,
1315
- label: "matrix dm allowlist",
1316
- list: params.accountConfig.dm?.allowFrom ?? []
1317
- }),
1318
- groupAllowFrom: await resolveMatrixUserAllowlist({
1319
- cfg: params.cfg,
1320
- runtime: params.runtime,
1321
- label: "matrix group allowlist",
1322
- list: params.accountConfig.groupAllowFrom ?? []
1323
- }),
1324
- roomsConfig: await resolveMatrixRoomsConfig({
1325
- cfg: params.cfg,
1326
- runtime: params.runtime,
1327
- roomsConfig: params.accountConfig.groups ?? params.accountConfig.rooms
1328
- })
1329
- };
1330
- }
1331
- async function monitorMatrixProvider(opts = {}) {
1332
- if (isBunRuntime()) throw new Error("Matrix provider requires Node (bun runtime not supported)");
1333
- const core = getMatrixRuntime();
1334
- let cfg = core.config.loadConfig();
1335
- if (cfg.channels?.matrix?.enabled === false) return;
1336
- const logger = core.logging.getChildLogger({ module: "matrix-auto-reply" });
1337
- const runtime = resolveRuntimeEnv({
1338
- runtime: opts.runtime,
1339
- logger
1340
- });
1341
- const logVerboseMessage = (message) => {
1342
- if (!core.logging.shouldLogVerbose()) return;
1343
- logger.debug?.(message);
1344
- };
1345
- const account = resolveMatrixAccount({
1346
- cfg,
1347
- accountId: opts.accountId
1348
- });
1349
- const accountConfig = account.config;
1350
- const allowlistOnly = accountConfig.allowlistOnly === true;
1351
- const { allowFrom, groupAllowFrom, roomsConfig } = await resolveMatrixMonitorConfig({
1352
- cfg,
1353
- runtime,
1354
- accountConfig
1355
- });
1356
- cfg = {
1357
- ...cfg,
1358
- channels: {
1359
- ...cfg.channels,
1360
- matrix: {
1361
- ...cfg.channels?.matrix,
1362
- dm: {
1363
- ...cfg.channels?.matrix?.dm,
1364
- allowFrom
1365
- },
1366
- groupAllowFrom,
1367
- ...roomsConfig ? { groups: roomsConfig } : {}
1368
- }
1369
- }
1370
- };
1371
- const auth = await resolveMatrixAuth({
1372
- cfg,
1373
- accountId: opts.accountId
1374
- });
1375
- const resolvedInitialSyncLimit = typeof opts.initialSyncLimit === "number" ? Math.max(0, Math.floor(opts.initialSyncLimit)) : auth.initialSyncLimit;
1376
- const authWithLimit = resolvedInitialSyncLimit === auth.initialSyncLimit ? auth : {
1377
- ...auth,
1378
- initialSyncLimit: resolvedInitialSyncLimit
1379
- };
1380
- const client = await resolveSharedMatrixClient({
1381
- cfg,
1382
- auth: authWithLimit,
1383
- startClient: false,
1384
- accountId: opts.accountId
1385
- });
1386
- setActiveMatrixClient(client, opts.accountId);
1387
- const mentionRegexes = core.channel.mentions.buildMentionRegexes(cfg);
1388
- const defaultGroupPolicy = resolveDefaultGroupPolicy(cfg);
1389
- const { groupPolicy: groupPolicyRaw, providerMissingFallbackApplied } = resolveAllowlistProviderRuntimeGroupPolicy({
1390
- providerConfigPresent: cfg.channels?.matrix !== void 0,
1391
- groupPolicy: accountConfig.groupPolicy,
1392
- defaultGroupPolicy
1393
- });
1394
- warnMissingProviderGroupPolicyFallbackOnce({
1395
- providerMissingFallbackApplied,
1396
- providerKey: "matrix",
1397
- accountId: account.accountId,
1398
- blockedLabel: GROUP_POLICY_BLOCKED_LABEL.room,
1399
- log: (message) => logVerboseMessage(message)
1400
- });
1401
- const groupPolicy = allowlistOnly && groupPolicyRaw === "open" ? "allowlist" : groupPolicyRaw;
1402
- const replyToMode = opts.replyToMode ?? accountConfig.replyToMode ?? "off";
1403
- const threadReplies = accountConfig.threadReplies ?? "inbound";
1404
- const dmConfig = accountConfig.dm;
1405
- const dmEnabled = dmConfig?.enabled ?? true;
1406
- const dmPolicyRaw = dmConfig?.policy ?? "pairing";
1407
- const dmPolicy = allowlistOnly && dmPolicyRaw !== "disabled" ? "allowlist" : dmPolicyRaw;
1408
- const textLimit = core.channel.text.resolveTextChunkLimit(cfg, "matrix");
1409
- const mediaMaxMb = opts.mediaMaxMb ?? accountConfig.mediaMaxMb ?? DEFAULT_MEDIA_MAX_MB;
1410
- const mediaMaxBytes = Math.max(1, mediaMaxMb) * 1024 * 1024;
1411
- const startupMs = Date.now();
1412
- const startupGraceMs = DEFAULT_STARTUP_GRACE_MS;
1413
- const directTracker = createDirectRoomTracker(client, {
1414
- log: logVerboseMessage,
1415
- includeMemberCountInLogs: core.logging.shouldLogVerbose()
1416
- });
1417
- registerMatrixAutoJoin({
1418
- client,
1419
- cfg,
1420
- runtime
1421
- });
1422
- const warnedEncryptedRooms = /* @__PURE__ */ new Set();
1423
- const warnedCryptoMissingRooms = /* @__PURE__ */ new Set();
1424
- const { getRoomInfo, getMemberDisplayName } = createMatrixRoomInfoResolver(client);
1425
- const handleRoomMessage = createMatrixRoomMessageHandler({
1426
- client,
1427
- core,
1428
- cfg,
1429
- runtime,
1430
- logger,
1431
- logVerboseMessage,
1432
- allowFrom,
1433
- roomsConfig,
1434
- mentionRegexes,
1435
- groupPolicy,
1436
- replyToMode,
1437
- threadReplies,
1438
- dmEnabled,
1439
- dmPolicy,
1440
- textLimit,
1441
- mediaMaxBytes,
1442
- startupMs,
1443
- startupGraceMs,
1444
- directTracker,
1445
- getRoomInfo,
1446
- getMemberDisplayName,
1447
- accountId: opts.accountId
1448
- });
1449
- registerMatrixMonitorEvents({
1450
- client,
1451
- auth,
1452
- logVerboseMessage,
1453
- warnedEncryptedRooms,
1454
- warnedCryptoMissingRooms,
1455
- logger,
1456
- formatNativeDependencyHint: core.system.formatNativeDependencyHint,
1457
- onRoomMessage: handleRoomMessage
1458
- });
1459
- logVerboseMessage("matrix: starting client");
1460
- await resolveSharedMatrixClient({
1461
- cfg,
1462
- auth: authWithLimit,
1463
- accountId: opts.accountId
1464
- });
1465
- logVerboseMessage("matrix: client started");
1466
- logger.info(`matrix: logged in as ${auth.userId}`);
1467
- if (auth.encryption && client.crypto) try {
1468
- if (await client.crypto.requestOwnUserVerification?.()) logger.info("matrix: device verification requested - please verify in another client");
1469
- } catch (err) {
1470
- logger.debug?.("Device verification request failed (may already be verified)", { error: String(err) });
1471
- }
1472
- await new Promise((resolve) => {
1473
- const onAbort = () => {
1474
- try {
1475
- logVerboseMessage("matrix: stopping client");
1476
- stopSharedClientForAccount(auth, opts.accountId);
1477
- } finally {
1478
- setActiveMatrixClient(null, opts.accountId);
1479
- resolve();
1480
- }
1481
- };
1482
- if (opts.abortSignal?.aborted) {
1483
- onAbort();
1484
- return;
1485
- }
1486
- opts.abortSignal?.addEventListener("abort", onAbort, { once: true });
1487
- });
1488
- }
1489
- //#endregion
1490
- export { monitorMatrixProvider };