@pixelzx/genesis 2026.5.9-1 → 2026.5.9-2

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 (1975) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-0CA8dLfb.js +201 -0
  4. package/dist/abort-cutoff.runtime-DLrSrIKj.js +20 -0
  5. package/dist/abort-cutoff.runtime.js +1 -1
  6. package/dist/abort.runtime-CZs24Rqo.js +2 -0
  7. package/dist/abort.runtime.js +1 -1
  8. package/dist/accounts-B4zJe0Yq.js +104 -0
  9. package/dist/accounts-BLjPr3cU.js +2 -0
  10. package/dist/accounts-CvvmJTMr.js +107 -0
  11. package/dist/acp-cli-CLEGmnZG.js +2193 -0
  12. package/dist/acp-spawn-3sot_ro5.js +1093 -0
  13. package/dist/acp-spawn-Ssi3CAga.js +2 -0
  14. package/dist/acp-stateful-target-driver-BLAHVVvA.js +89 -0
  15. package/dist/action-agents-Dq0xDTDy.js +67 -0
  16. package/dist/action-focus-BcCDHjpm.js +132 -0
  17. package/dist/action-help-Dv0F-uYd.js +7 -0
  18. package/dist/action-info-DrvJBtYv.js +101 -0
  19. package/dist/action-kill-C0ctDBN6.js +33 -0
  20. package/dist/action-list-ifQSDER2.js +21 -0
  21. package/dist/action-log-DigSwoBN.js +30 -0
  22. package/dist/action-send-Fgxgzr1G.js +39 -0
  23. package/dist/action-spawn-CQ9o7O-c.js +47 -0
  24. package/dist/action-unfocus-CTw5MONo.js +29 -0
  25. package/dist/actions.runtime-C48NraIV.js +5 -0
  26. package/dist/actions.runtime-vPuYQMEP.js +18 -0
  27. package/dist/actions.runtime.js +1 -1
  28. package/dist/agent-DcF3DIOY.js +2 -0
  29. package/dist/agent-command-DFciA5wB.js +874 -0
  30. package/dist/agent-harness-runtime-DYaAPdEV.js +144 -0
  31. package/dist/agent-runner-utils-Mk9b9UU9.js +239 -0
  32. package/dist/agent-runner.runtime-BjFjcCHV.js +3455 -0
  33. package/dist/agent-runner.runtime.js +1 -1
  34. package/dist/agent-runtime-BMldiM3Y.js +18 -0
  35. package/dist/agents-CWjPyPsv.js +5 -0
  36. package/dist/agents-DVeZakyc.js +954 -0
  37. package/dist/agents.bindings-DIEj_i2u.js +2 -0
  38. package/dist/agents.command-shared-Dnz5T0nf.js +40 -0
  39. package/dist/aliases-BurIDhAz.js +96 -0
  40. package/dist/aliases-DRf5QKLd.js +2 -0
  41. package/dist/api-1odKgvPw.js +3 -0
  42. package/dist/api-B4QoV66o.js +4 -0
  43. package/dist/api-BVv3GELU.js +5 -0
  44. package/dist/api-CLi_q8yx.js +48 -0
  45. package/dist/api-DpTBPGPX.js +139 -0
  46. package/dist/apply-BTVGkXcq.js +508 -0
  47. package/dist/apply.runtime-CGa1bc-F.js +166 -0
  48. package/dist/apply.runtime-CMLd-Aow.js +2 -0
  49. package/dist/apply.runtime.js +1 -1
  50. package/dist/approval-gateway-resolver-9vElgdEH.js +29 -0
  51. package/dist/approval-gateway-runtime-BcR8gXqU.js +2 -0
  52. package/dist/approval-handler-runtime-BI7BobM2.js +439 -0
  53. package/dist/approval-native-runtime-Bz8Vy_5G.js +729 -0
  54. package/dist/assistant-identity-BamJmF6s.js +74 -0
  55. package/dist/attempt-execution.runtime-CCpDCgeC.js +509 -0
  56. package/dist/attempt-execution.runtime.js +1 -1
  57. package/dist/attempt-execution.shared-tYK6f1sA.js +22 -0
  58. package/dist/attempt.prompt-helpers-BD2qLk94.js +221 -0
  59. package/dist/attempt.tool-run-context-CVbNUM9c.js +933 -0
  60. package/dist/audit-D_CSTjWR.js +939 -0
  61. package/dist/audit-channel.collect.runtime.js +1 -1
  62. package/dist/audit-extra.async-wruNJd57.js +971 -0
  63. package/dist/audit-tool-policy-B9AcZJql.js +3 -0
  64. package/dist/audit.deep.runtime-D4eXtoCF.js +2 -0
  65. package/dist/audit.deep.runtime.js +1 -1
  66. package/dist/audit.nondeep.runtime--FJmBA_w.js +880 -0
  67. package/dist/audit.nondeep.runtime.js +1 -1
  68. package/dist/audit.runtime-D2oypbTV.js +7 -0
  69. package/dist/audit.runtime.js +1 -1
  70. package/dist/auth-CAY7RIm5.js +2 -0
  71. package/dist/auth-CRl0U5WO.js +383 -0
  72. package/dist/auth-choice-BWpQV6PB.js +3 -0
  73. package/dist/auth-choice-C44XKsb9.js +354 -0
  74. package/dist/auth-choice-CgtXS0UY.js +85 -0
  75. package/dist/auth-choice-inference-HLapN0yl.js +30 -0
  76. package/dist/auth-choice-legacy--d5CxMYA.js +2 -0
  77. package/dist/auth-choice-legacy-BiaOGRSa.js +40 -0
  78. package/dist/auth-choice-options-CxxsZ9AS.js +99 -0
  79. package/dist/auth-choice-prompt-Bs5HdLZo.js +2 -0
  80. package/dist/auth-choice-prompt-CIbZkP3q.js +37 -0
  81. package/dist/auth-choice.apply.api-providers-DFs_Hb7e.js +2 -0
  82. package/dist/auth-choice.plugin-providers.runtime.js +1 -1
  83. package/dist/auth-install-policy-D2XRHYp_.js +195 -0
  84. package/dist/auth-lp2EMTMM.js +177 -0
  85. package/dist/auth-order-CkBahFe_.js +96 -0
  86. package/dist/auth-order-CseGI6QD.js +2 -0
  87. package/dist/auth-sU9QFM3_.js +56 -0
  88. package/dist/backup-verify-B-Uoj-15.js +2 -0
  89. package/dist/bash-tools-Br73otxW.js +2824 -0
  90. package/dist/bash-tools-D8b6lPnl.js +3 -0
  91. package/dist/bash-tools.exec-runtime-C4MO_tR3.js +829 -0
  92. package/dist/binding-routing-_1GxTJvW.js +85 -0
  93. package/dist/binding-targets-BZi7Eaky.js +121 -0
  94. package/dist/bonjour-discovery-bYgCDFiV.js +2 -0
  95. package/dist/bridge-server-Z8a6wG_a.js +113 -0
  96. package/dist/browser-control-auth-b0i_ogzs.js +2 -0
  97. package/dist/browser-node-runtime-DIn0vNQP.js +12 -0
  98. package/dist/browser-profiles-RRJksKtC.js +2 -0
  99. package/dist/browser-runtime-CRmjM_eN.js +387 -0
  100. package/dist/browser-setup-tools-DfljsIaS.js +13 -0
  101. package/dist/build-BTY-zmOn.js +550 -0
  102. package/dist/build-info.json +3 -3
  103. package/dist/bundled/boot-md/handler.js +3 -3
  104. package/dist/bundled/session-memory/handler.js +1 -1
  105. package/dist/bundled-plugin-load-paths-BhceQF7C.js +2 -0
  106. package/dist/bundled-plugin-load-paths-ZWKh-Qtt.js +110 -0
  107. package/dist/call-83wQ4RK2.js +3 -0
  108. package/dist/call-CNGUHA4E.js +331 -0
  109. package/dist/call.runtime-BoeU6HlD.js +2 -0
  110. package/dist/call.runtime.js +1 -1
  111. package/dist/capability-cli-CjXZtiAN.js +1401 -0
  112. package/dist/catalog-provider-hbPYCIHb.js +40 -0
  113. package/dist/catchup-fi0A0X6G.js +300 -0
  114. package/dist/channel-BCyBYEZw.js +491 -0
  115. package/dist/channel-BollE3fK.js +226 -0
  116. package/dist/channel-C4iJHasO.js +1174 -0
  117. package/dist/channel-CZj1GE6c.js +350 -0
  118. package/dist/channel-DSf_WWeM.js +453 -0
  119. package/dist/channel-DZ1WMqes.js +297 -0
  120. package/dist/channel-Djz_Jz-P.js +1320 -0
  121. package/dist/channel-Vl5tW4wj.js +840 -0
  122. package/dist/channel-aCMKD2EU.js +595 -0
  123. package/dist/channel-add-wizard-CyaqyoMI.js +125 -0
  124. package/dist/channel-add-wizard-DBnqJQ7p.js +2 -0
  125. package/dist/channel-core-o2ga4Mn-.js +5 -0
  126. package/dist/channel-doctor-Bm067ZZ3.js +2 -0
  127. package/dist/channel-inbound-6EfM36fi.js +31 -0
  128. package/dist/channel-oGSbONXx.js +1100 -0
  129. package/dist/channel-plugin-resolution-7SkSLEid.js +2 -0
  130. package/dist/channel-plugin-resolution-D4rtoY6H.js +153 -0
  131. package/dist/channel-plugin-runtime-DDWX5ddg.js +771 -0
  132. package/dist/channel-runtime-BtLIK1S8.js +425 -0
  133. package/dist/channel-selection.runtime.js +1 -1
  134. package/dist/channel-setup-zPxdbm4p.js +1297 -0
  135. package/dist/channel-v7Nf8_kK.js +1802 -0
  136. package/dist/channel.runtime-1NdLQuo5.js +576 -0
  137. package/dist/channel.runtime-BXuA38HL.js +430 -0
  138. package/dist/channel.runtime-BZznmhpw.js +89 -0
  139. package/dist/channel.runtime-BcbP0aUr.js +2364 -0
  140. package/dist/channel.runtime-Cn9YkO17.js +109 -0
  141. package/dist/channel.runtime-sHzdaLSR.js +34702 -0
  142. package/dist/channel.runtime-u6CglHXP.js +4 -0
  143. package/dist/channel.runtime.js +1 -1
  144. package/dist/channel.setup-CQPT27he.js +10 -0
  145. package/dist/channels-Ca_GeBCA.js +733 -0
  146. package/dist/channels-cli-CYiAFi2L.js +268 -0
  147. package/dist/chat-B0obqfrE.js +2830 -0
  148. package/dist/chrome-Dmg8rOOy.js +1430 -0
  149. package/dist/clawbot-cli-D-wsbybZ.js +9 -0
  150. package/dist/clawhub-Bw_oroJ9.js +400 -0
  151. package/dist/cli/daemon-cli.js +4 -4
  152. package/dist/cli-Cjg5FoK6.js +3726 -0
  153. package/dist/cli-D7FnZRhN.js +72 -0
  154. package/dist/cli-DTzACUJ5.js +2 -0
  155. package/dist/cli-DVF0lmSY.js +683 -0
  156. package/dist/cli-DdosPr5g.js +2 -0
  157. package/dist/cli-DgBnKpnx.js +219 -0
  158. package/dist/cli-DlpFMnDe.js +154 -0
  159. package/dist/cli-okIxAXmr.js +2 -0
  160. package/dist/cli-runner-BYpLWLGt.js +286 -0
  161. package/dist/cli-runner.runtime-B7YAJHpe.js +3 -0
  162. package/dist/cli-runner.runtime-CJYMKi2e.js +4 -0
  163. package/dist/cli-runner.runtime.js +1 -1
  164. package/dist/cli-startup-metadata.json +2 -2
  165. package/dist/cli.runtime-BiQiuGK8.js +1261 -0
  166. package/dist/cli.runtime.js +1 -1
  167. package/dist/client-BR4n6hNI.js +713 -0
  168. package/dist/client-Cf24VXFt.js +138 -0
  169. package/dist/command-auth-ZFNGVZ1l.js +76 -0
  170. package/dist/command-config-resolution-CCxM48fG.js +23 -0
  171. package/dist/command-config-resolution-DZ8NuYpb.js +2 -0
  172. package/dist/command-config-resolution.runtime-y20A7eoR.js +2 -0
  173. package/dist/command-config-resolution.runtime.js +1 -1
  174. package/dist/command-execution-startup-C1Ev3Qnf.js +324 -0
  175. package/dist/command-registry-Cp0-uBvD.js +4 -0
  176. package/dist/command-registry-CroYLrbJ.js +9 -0
  177. package/dist/command-registry-core-DztPKtJK.js +101 -0
  178. package/dist/command-secret-gateway-C0FsXiNU.js +528 -0
  179. package/dist/command-status.runtime-BpBrSGUJ.js +87 -0
  180. package/dist/command-status.runtime.js +1 -1
  181. package/dist/commands-acp-B61b7ved.js +77 -0
  182. package/dist/commands-compact.runtime-BAdDkvwj.js +10 -0
  183. package/dist/commands-compact.runtime.js +1 -1
  184. package/dist/commands-core.runtime-DiHWuAG7.js +2 -0
  185. package/dist/commands-core.runtime.js +1 -1
  186. package/dist/commands-handlers.runtime-ChdtbbaM.js +4597 -0
  187. package/dist/commands-handlers.runtime.js +1 -1
  188. package/dist/commands-reset-hooks-Bo9O3p_A.js +133 -0
  189. package/dist/commands-status-CeLNHPM0.js +16 -0
  190. package/dist/commands-status.runtime-D_Vp1X5_.js +3 -0
  191. package/dist/commands-status.runtime.js +1 -1
  192. package/dist/commands-subagents-control.runtime-C33ckfAv.js +2 -0
  193. package/dist/commands-subagents-control.runtime-D4DhHEiT.js +3 -0
  194. package/dist/commands-subagents-control.runtime.js +1 -1
  195. package/dist/commands-system-prompt-COv58JTi.js +158 -0
  196. package/dist/commands-system-prompt-HKOihaLK.js +2 -0
  197. package/dist/commands.runtime-h71EVKOi.js +166 -0
  198. package/dist/commands.runtime.js +1 -1
  199. package/dist/compact-BrCra5F3.js +1118 -0
  200. package/dist/compact.runtime-C6SrtJTz.js +12 -0
  201. package/dist/compact.runtime.js +1 -1
  202. package/dist/completion-cli-BX2HZrZU.js +328 -0
  203. package/dist/config-BFLj-fNN.js +252 -0
  204. package/dist/config-cli-ygapqOMa.js +1078 -0
  205. package/dist/config-guard-CoUcOZzd.js +96 -0
  206. package/dist/config-runtime-CLrwW_R_.js +32 -0
  207. package/dist/configure-Bl4YQ3CH.js +2 -0
  208. package/dist/configure-D16Few58.js +1252 -0
  209. package/dist/connect-options-BhC5UQTi.js +699 -0
  210. package/dist/control-auth-DNFuULZ1.js +125 -0
  211. package/dist/control-service-UtrnNZR4.js +156 -0
  212. package/dist/control-ui/assets/agents-DvMlgG1V.js +1052 -0
  213. package/dist/control-ui/assets/canvas-n9LriwKt.js +269 -0
  214. package/dist/control-ui/assets/channels-DiFCgzI2.js +463 -0
  215. package/dist/control-ui/assets/cron-BPgeIAkW.js +933 -0
  216. package/dist/control-ui/assets/debug-DW6L_hJj.js +94 -0
  217. package/dist/control-ui/assets/index-LsGgCPs6.js +6359 -0
  218. package/dist/control-ui/assets/instances-CvJ3A1Hk.js +57 -0
  219. package/dist/control-ui/assets/nodes-WvplPOYf.js +436 -0
  220. package/dist/control-ui/assets/plugins-Bu6UEyqM.js +273 -0
  221. package/dist/control-ui/assets/sessions-CMg95Rmr.js +306 -0
  222. package/dist/control-ui/assets/skills-XJc5GCFP.js +323 -0
  223. package/dist/control-ui/assets/wallet-Cw-Xn1wM.js +199 -0
  224. package/dist/control-ui/index.html +1 -1
  225. package/dist/control-ui-DfR_528y.js +1043 -0
  226. package/dist/conversation-id-C8dzBOdB.js +38 -0
  227. package/dist/conversation-id-CsqecVo_.js +235 -0
  228. package/dist/conversation-runtime-nAoayMyf.js +31 -0
  229. package/dist/core-CewPep95.js +275 -0
  230. package/dist/create-B052IquP.js +80 -0
  231. package/dist/cron-cli-zkpMAfTa.js +713 -0
  232. package/dist/daemon-cli-B3QX8ho4.js +12 -0
  233. package/dist/daemon-install-DqGQoyX8.js +64 -0
  234. package/dist/daemon-install-auth-profiles-source.runtime.js +1 -1
  235. package/dist/daemon-install-auth-profiles-store.runtime.js +1 -1
  236. package/dist/dashboard-BHjSY3mb.js +81 -0
  237. package/dist/dashboard-DPXhsRCR.js +2 -0
  238. package/dist/delegate-CCK4c0Zl.js +64 -0
  239. package/dist/deliver-B3LmnUEH.js +3 -0
  240. package/dist/deliver-BtMUmRpU.js +747 -0
  241. package/dist/deliver-runtime-kfTsrh0Z.js +2 -0
  242. package/dist/delivery-logger.runtime.js +1 -1
  243. package/dist/delivery-outbound.runtime-xnjEUWIK.js +6 -0
  244. package/dist/delivery-outbound.runtime.js +1 -1
  245. package/dist/delivery-subagent-registry.runtime.js +1 -1
  246. package/dist/delivery-target.runtime.js +1 -1
  247. package/dist/delivery.runtime-oNtWo0h9.js +253 -0
  248. package/dist/delivery.runtime.js +1 -1
  249. package/dist/detached-task-runtime-CS3nu1g5.js +73 -0
  250. package/dist/devices-cli-hnRL_EgB.js +498 -0
  251. package/dist/diagnostic-support-export-D6sq6qBF.js +533 -0
  252. package/dist/diagnostics-dGMDmEaj.js +154 -0
  253. package/dist/direct-dm-B7MAseXX.js +64 -0
  254. package/dist/directive-handling.fast-lane-BDZzb1c3.js +66 -0
  255. package/dist/directive-handling.impl-B0Q4GVor.js +703 -0
  256. package/dist/directive-handling.impl-KM-ESmbb.js +2 -0
  257. package/dist/directive-handling.model-selection-C0cUvkUH.js +114 -0
  258. package/dist/directive-handling.persist.runtime-D2vtbPoj.js +215 -0
  259. package/dist/directive-handling.persist.runtime.js +1 -1
  260. package/dist/directory-cli-XqCKO3DH.js +240 -0
  261. package/dist/discovery-nb8lOKiX.js +2 -0
  262. package/dist/dispatch-BOAQ60sx.js +1131 -0
  263. package/dist/dispatch-acp-CVrFiJ5o.js +981 -0
  264. package/dist/dispatch-acp-manager.runtime-olnQhwR-.js +3 -0
  265. package/dist/dispatch-acp-manager.runtime.js +1 -1
  266. package/dist/dispatch-acp-media.runtime-DX-wMzpn.js +4 -0
  267. package/dist/dispatch-acp-media.runtime.js +1 -1
  268. package/dist/dispatch-acp-session.runtime-Ua4EFiic.js +2 -0
  269. package/dist/dispatch-acp-session.runtime.js +1 -1
  270. package/dist/dispatch-acp.runtime-7SbVXQLP.js +19 -0
  271. package/dist/dispatch-acp.runtime.js +1 -1
  272. package/dist/doctor-auth-DY23Lbzo.js +172 -0
  273. package/dist/doctor-auth-legacy-oauth-FXycT3rW.js +2 -0
  274. package/dist/doctor-completion-opJf8E_C.js +2 -0
  275. package/dist/doctor-config-flow-2JYaVE0-.js +420 -0
  276. package/dist/doctor-config-preflight-4x2uv9Hb.js +63 -0
  277. package/dist/doctor-config-preflight-B07ImAVz.js +2 -0
  278. package/dist/doctor-cron-B5LdOuxR.js +678 -0
  279. package/dist/doctor-device-pairing-DpTPdaEl.js +307 -0
  280. package/dist/doctor-gateway-daemon-flow-Bu454-sh.js +250 -0
  281. package/dist/doctor-gateway-health-DLc2lC6v.js +63 -0
  282. package/dist/doctor-gateway-services-nfS_weBB.js +316 -0
  283. package/dist/doctor-health-DbSdggc-.js +59 -0
  284. package/dist/doctor-health-contributions-QsszyyOf.js +493 -0
  285. package/dist/doctor-memory-search-BJzkDQFO.js +372 -0
  286. package/dist/doctor-prompter-ItZHriXT.js +56 -0
  287. package/dist/doctor-sandbox-DlwDnh9l.js +194 -0
  288. package/dist/doctor-security-BcgUbdDE.js +210 -0
  289. package/dist/doctor-startup-channel-maintenance-CSm0kVp7.js +17 -0
  290. package/dist/doctor-state-migrations-CzuIt_kk.js +2 -0
  291. package/dist/doctor-ui-CqARev-u.js +96 -0
  292. package/dist/doctor-update-BEHmv8Xq.js +58 -0
  293. package/dist/doctor-workspace-WOSsr97h.js +2 -0
  294. package/dist/doctor-workspace-status-q0x2fhBz.js +75 -0
  295. package/dist/dreaming-BNUWuUDR.js +1574 -0
  296. package/dist/dreaming-narrative-Bj2DXV1n.js +595 -0
  297. package/dist/embedded-gateway-stub.runtime-BIiprD37.js +9 -0
  298. package/dist/embedded-gateway-stub.runtime.js +1 -1
  299. package/dist/embedding-provider-DDJVhG6s.js +118 -0
  300. package/dist/embeddings-BcBUDrld.js +215 -0
  301. package/dist/embeddings-http-CATnDu-1.js +205 -0
  302. package/dist/empty-allowlist-scan-6JAE1WAj.js +94 -0
  303. package/dist/empty-allowlist-scan-Cc7fIEP1.js +2 -0
  304. package/dist/entry.js +3 -3
  305. package/dist/exec-approval-forwarder.runtime-XneENX4R.js +3 -0
  306. package/dist/exec-approval-forwarder.runtime.js +1 -1
  307. package/dist/exec-approvals-cli-bVkpe5kn.js +498 -0
  308. package/dist/exec-defaults-C7MUEVh_.js +2 -0
  309. package/dist/exec-defaults-D1yvsTtz.js +67 -0
  310. package/dist/exec-safe-bins-CMXTNkuu.js +2 -0
  311. package/dist/exec-safe-bins-c1SitPNh.js +148 -0
  312. package/dist/execute.runtime-CHn6LmBk.js +1366 -0
  313. package/dist/execute.runtime.js +1 -1
  314. package/dist/extensionAPI.js +3 -3
  315. package/dist/extensions/active-memory/index.js +3 -3
  316. package/dist/extensions/alibaba/index.js +1 -1
  317. package/dist/extensions/alibaba/video-generation-provider.js +1 -1
  318. package/dist/extensions/arcee/index.js +2 -2
  319. package/dist/extensions/bluebubbles/api.js +3 -3
  320. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  321. package/dist/extensions/browser/browser-bridge.js +1 -1
  322. package/dist/extensions/browser/browser-config.js +4 -4
  323. package/dist/extensions/browser/browser-control-auth.js +2 -2
  324. package/dist/extensions/browser/browser-doctor.js +2 -2
  325. package/dist/extensions/browser/browser-maintenance.js +2 -2
  326. package/dist/extensions/browser/browser-profiles.js +2 -2
  327. package/dist/extensions/browser/browser-runtime-api.js +11 -11
  328. package/dist/extensions/browser/index.js +1 -1
  329. package/dist/extensions/browser/plugin-registration.js +1 -1
  330. package/dist/extensions/browser/register.runtime.js +3 -3
  331. package/dist/extensions/browser/runtime-api.js +12 -12
  332. package/dist/extensions/browser/test-support.js +1 -1
  333. package/dist/extensions/byteplus/index.js +3 -3
  334. package/dist/extensions/byteplus/video-generation-provider.js +1 -1
  335. package/dist/extensions/chutes/index.js +4 -4
  336. package/dist/extensions/cloudflare-ai-gateway/api.js +1 -1
  337. package/dist/extensions/cloudflare-ai-gateway/catalog-provider.js +1 -1
  338. package/dist/extensions/cloudflare-ai-gateway/index.js +2 -2
  339. package/dist/extensions/comfy/image-generation-provider.js +2 -2
  340. package/dist/extensions/comfy/index.js +5 -5
  341. package/dist/extensions/comfy/music-generation-provider.js +1 -1
  342. package/dist/extensions/comfy/video-generation-provider.js +2 -2
  343. package/dist/extensions/comfy/workflow-runtime.js +1 -1
  344. package/dist/extensions/deepseek/index.js +1 -1
  345. package/dist/extensions/device-pair/api.js +2 -2
  346. package/dist/extensions/device-pair/index.js +4 -4
  347. package/dist/extensions/device-pair/notify.js +1 -1
  348. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  349. package/dist/extensions/device-pair/qr-image.js +2 -2
  350. package/dist/extensions/fal/image-generation-provider.js +1 -1
  351. package/dist/extensions/fal/index.js +3 -3
  352. package/dist/extensions/fal/provider-registration.js +1 -1
  353. package/dist/extensions/fal/test-api.js +2 -2
  354. package/dist/extensions/fal/video-generation-provider.js +1 -1
  355. package/dist/extensions/fireworks/index.js +1 -1
  356. package/dist/extensions/github-copilot/api.js +1 -1
  357. package/dist/extensions/github-copilot/auth.js +1 -1
  358. package/dist/extensions/github-copilot/embeddings.js +1 -1
  359. package/dist/extensions/github-copilot/index.js +4 -4
  360. package/dist/extensions/github-copilot/login.js +1 -1
  361. package/dist/extensions/github-copilot/register.runtime.js +2 -2
  362. package/dist/extensions/google-meet/index.js +6 -6
  363. package/dist/extensions/groq/index.js +1 -1
  364. package/dist/extensions/groq/media-understanding-provider.js +1 -1
  365. package/dist/extensions/groq/test-api.js +1 -1
  366. package/dist/extensions/huggingface/index.js +1 -1
  367. package/dist/extensions/image-generation-core/api.js +2 -2
  368. package/dist/extensions/imessage/api.js +4 -4
  369. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  370. package/dist/extensions/imessage/runtime-api.js +5 -5
  371. package/dist/extensions/imessage/test-api.js +1 -1
  372. package/dist/extensions/irc/api.js +2 -2
  373. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  374. package/dist/extensions/kilocode/index.js +1 -1
  375. package/dist/extensions/kimi-coding/index.js +2 -2
  376. package/dist/extensions/line/api.js +2 -2
  377. package/dist/extensions/line/channel-plugin-api.js +1 -1
  378. package/dist/extensions/line/contract-api.js +1 -1
  379. package/dist/extensions/line/runtime-api.js +4 -4
  380. package/dist/extensions/line/setup-api.js +1 -1
  381. package/dist/extensions/litellm/index.js +1 -1
  382. package/dist/extensions/llm-task/index.js +2 -2
  383. package/dist/extensions/lmstudio/api.js +2 -2
  384. package/dist/extensions/lmstudio/index.js +3 -3
  385. package/dist/extensions/lmstudio/memory-embedding-adapter.js +1 -1
  386. package/dist/extensions/lmstudio/runtime-api.js +1 -1
  387. package/dist/extensions/lobster/index.js +3 -3
  388. package/dist/extensions/lobster/runtime-api.js +1 -1
  389. package/dist/extensions/mattermost/api.js +1 -1
  390. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  391. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  392. package/dist/extensions/mattermost/policy-api.js +1 -1
  393. package/dist/extensions/mattermost/runtime-api.js +7 -7
  394. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  395. package/dist/extensions/media-understanding-core/runtime-api.js +2 -2
  396. package/dist/extensions/memory-core/api.js +1 -1
  397. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  398. package/dist/extensions/memory-core/index.js +3 -3
  399. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  400. package/dist/extensions/memory-lancedb/index.js +1 -1
  401. package/dist/extensions/memory-wiki/cli-metadata.js +1 -1
  402. package/dist/extensions/memory-wiki/index.js +1 -1
  403. package/dist/extensions/microsoft/index.js +1 -1
  404. package/dist/extensions/microsoft/speech-provider.js +1 -1
  405. package/dist/extensions/microsoft/test-api.js +1 -1
  406. package/dist/extensions/microsoft-foundry/auth.js +1 -1
  407. package/dist/extensions/microsoft-foundry/cli.js +1 -1
  408. package/dist/extensions/microsoft-foundry/index.js +1 -1
  409. package/dist/extensions/microsoft-foundry/onboard.js +2 -2
  410. package/dist/extensions/microsoft-foundry/provider.js +1 -1
  411. package/dist/extensions/microsoft-foundry/runtime.js +1 -1
  412. package/dist/extensions/microsoft-foundry/shared-runtime.js +2 -2
  413. package/dist/extensions/microsoft-foundry/shared.js +1 -1
  414. package/dist/extensions/minimax/image-generation-provider.js +1 -1
  415. package/dist/extensions/minimax/index.js +6 -6
  416. package/dist/extensions/minimax/media-understanding-provider.js +1 -1
  417. package/dist/extensions/minimax/music-generation-provider.js +1 -1
  418. package/dist/extensions/minimax/oauth.js +1 -1
  419. package/dist/extensions/minimax/oauth.runtime.js +1 -1
  420. package/dist/extensions/minimax/provider-registration.js +1 -1
  421. package/dist/extensions/minimax/speech-provider.js +1 -1
  422. package/dist/extensions/minimax/test-api.js +4 -4
  423. package/dist/extensions/minimax/video-generation-provider.js +1 -1
  424. package/dist/extensions/mistral/index.js +2 -2
  425. package/dist/extensions/mistral/media-understanding-provider.js +1 -1
  426. package/dist/extensions/mistral/test-api.js +1 -1
  427. package/dist/extensions/moonshot/index.js +2 -2
  428. package/dist/extensions/moonshot/media-understanding-provider.js +1 -1
  429. package/dist/extensions/moonshot/test-api.js +1 -1
  430. package/dist/extensions/msteams/api.js +1 -1
  431. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  432. package/dist/extensions/msteams/runtime-api.js +4 -4
  433. package/dist/extensions/msteams/test-api.js +1 -1
  434. package/dist/extensions/nextcloud-talk/api.js +1 -1
  435. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  436. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  437. package/dist/extensions/nvidia/index.js +1 -1
  438. package/dist/extensions/ollama/api.js +3 -3
  439. package/dist/extensions/ollama/index.js +9 -9
  440. package/dist/extensions/ollama/runtime-api.js +2 -2
  441. package/dist/extensions/ollama/web-search-provider.js +1 -1
  442. package/dist/extensions/openai/api.js +2 -2
  443. package/dist/extensions/openai/image-generation-provider.js +1 -1
  444. package/dist/extensions/openai/index.js +6 -6
  445. package/dist/extensions/openai/media-understanding-provider.js +1 -1
  446. package/dist/extensions/openai/openai-codex-provider.js +1 -1
  447. package/dist/extensions/openai/openai-provider.js +1 -1
  448. package/dist/extensions/openai/register.runtime.js +4 -4
  449. package/dist/extensions/openai/test-api.js +3 -3
  450. package/dist/extensions/openai/video-generation-provider.js +1 -1
  451. package/dist/extensions/opencode/index.js +2 -2
  452. package/dist/extensions/opencode/media-understanding-provider.js +1 -1
  453. package/dist/extensions/opencode-go/index.js +2 -2
  454. package/dist/extensions/opencode-go/media-understanding-provider.js +1 -1
  455. package/dist/extensions/openrouter/api.js +1 -1
  456. package/dist/extensions/openrouter/image-generation-provider.js +1 -1
  457. package/dist/extensions/openrouter/index.js +4 -4
  458. package/dist/extensions/openrouter/media-understanding-provider.js +1 -1
  459. package/dist/extensions/openrouter/register.runtime.js +3 -3
  460. package/dist/extensions/openrouter/test-api.js +2 -2
  461. package/dist/extensions/openshell/index.js +3 -3
  462. package/dist/extensions/qianfan/index.js +1 -1
  463. package/dist/extensions/qwen/index.js +3 -3
  464. package/dist/extensions/qwen/media-understanding-provider.js +1 -1
  465. package/dist/extensions/qwen/test-api.js +2 -2
  466. package/dist/extensions/qwen/video-generation-provider.js +1 -1
  467. package/dist/extensions/runway/index.js +1 -1
  468. package/dist/extensions/runway/video-generation-provider.js +1 -1
  469. package/dist/extensions/signal/api.js +6 -6
  470. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  471. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  472. package/dist/extensions/signal/runtime-api.js +9 -9
  473. package/dist/extensions/skill-workshop/api.js +1 -1
  474. package/dist/extensions/skill-workshop/index.js +2 -2
  475. package/dist/extensions/speech-core/runtime-api.js +1 -1
  476. package/dist/extensions/stepfun/index.js +2 -2
  477. package/dist/extensions/synology-chat/api.js +1 -1
  478. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  479. package/dist/extensions/synthetic/index.js +1 -1
  480. package/dist/extensions/talk-voice/index.js +1 -1
  481. package/dist/extensions/tencent/index.js +2 -2
  482. package/dist/extensions/thread-ownership/index.js +1 -1
  483. package/dist/extensions/tlon/api.js +2 -2
  484. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  485. package/dist/extensions/tlon/runtime-api.js +1 -1
  486. package/dist/extensions/tlon/test-api.js +1 -1
  487. package/dist/extensions/together/index.js +2 -2
  488. package/dist/extensions/together/video-generation-provider.js +1 -1
  489. package/dist/extensions/twitch/api.js +1 -1
  490. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  491. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  492. package/dist/extensions/venice/index.js +1 -1
  493. package/dist/extensions/vercel-ai-gateway/index.js +1 -1
  494. package/dist/extensions/voice-call/index.js +1 -1
  495. package/dist/extensions/voice-call/runtime-entry.js +1 -1
  496. package/dist/extensions/volcengine/index.js +2 -2
  497. package/dist/extensions/vydra/image-generation-provider.js +1 -1
  498. package/dist/extensions/vydra/index.js +4 -4
  499. package/dist/extensions/vydra/video-generation-provider.js +1 -1
  500. package/dist/extensions/xai/api.js +2 -2
  501. package/dist/extensions/xai/code-execution.js +2 -2
  502. package/dist/extensions/xai/image-generation-provider.js +1 -1
  503. package/dist/extensions/xai/index.js +6 -6
  504. package/dist/extensions/xai/speech-provider.js +1 -1
  505. package/dist/extensions/xai/tts.js +1 -1
  506. package/dist/extensions/xai/video-generation-provider.js +1 -1
  507. package/dist/extensions/xai/x-search.js +2 -2
  508. package/dist/extensions/xiaomi/index.js +1 -1
  509. package/dist/extensions/zai/index.js +2 -2
  510. package/dist/extensions/zai/media-understanding-provider.js +1 -1
  511. package/dist/extensions/zai/test-api.js +1 -1
  512. package/dist/extensions/zalo/api.js +3 -3
  513. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  514. package/dist/extensions/zalo/runtime-api.js +2 -2
  515. package/dist/extensions/zalo/setup-api.js +2 -2
  516. package/dist/extensions/zalouser/api.js +3 -3
  517. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  518. package/dist/extensions/zalouser/runtime-api.js +7 -7
  519. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  520. package/dist/extensions/zalouser/test-api.js +1 -1
  521. package/dist/fallbacks-BWfTkiI4.js +31 -0
  522. package/dist/fallbacks-C9KDYKs_.js +2 -0
  523. package/dist/fallbacks-shared-DfTzBfq1.js +111 -0
  524. package/dist/format-CqMlnPqV.js +245 -0
  525. package/dist/gateway-CkxkzVZN.js +115 -0
  526. package/dist/gateway-cli-hF08SMoD.js +1283 -0
  527. package/dist/gateway-discovery-targets-BilYS9ha.js +42 -0
  528. package/dist/gateway-install-token-CZq3-WaX.js +141 -0
  529. package/dist/gateway-rpc-yH-iFPPG.js +14 -0
  530. package/dist/gateway-rpc.runtime-Bxb1dLu2.js +23 -0
  531. package/dist/gateway-rpc.runtime.js +1 -1
  532. package/dist/gateway-runtime-DSIAuM0M.js +15 -0
  533. package/dist/gateway-status-B3SqIStn.js +584 -0
  534. package/dist/genesis-tools-DzgSb3vd.js +9144 -0
  535. package/dist/genesis-tools.runtime-BkPuepHE.js +2 -0
  536. package/dist/genesis-tools.runtime.js +1 -1
  537. package/dist/get-reply-ChN4EIDm.js +3879 -0
  538. package/dist/get-reply-from-config.runtime-cgmM6iLA.js +2 -0
  539. package/dist/get-reply-from-config.runtime.js +1 -1
  540. package/dist/gmail-watcher-lifecycle-8oetrTVi.js +2 -0
  541. package/dist/gmail-watcher-lifecycle-CJJGDUP5.js +191 -0
  542. package/dist/graph-users-BjskkPXl.js +1337 -0
  543. package/dist/health-BcGQpWhR.js +3 -0
  544. package/dist/health-C_ieY9Kj.js +469 -0
  545. package/dist/health-route-CwpATAjq.js +41 -0
  546. package/dist/health-route-yxKlxzM8.js +2 -0
  547. package/dist/health-style-_j6EAcB7.js +2 -0
  548. package/dist/heartbeat-runner-BATl6sLG.js +5 -0
  549. package/dist/heartbeat-runner-LDUrUqCE.js +1292 -0
  550. package/dist/heartbeat-runner.runtime-DsuMWPNt.js +4 -0
  551. package/dist/heartbeat-runner.runtime.js +1 -1
  552. package/dist/hooks-cli-CEYDwXFE.js +433 -0
  553. package/dist/hooks-status-Cqby6WVW.js +86 -0
  554. package/dist/image-fallbacks-CqQR3jWU.js +31 -0
  555. package/dist/image-fallbacks-Nt-2QyCg.js +2 -0
  556. package/dist/image-generation-core-DEiEJhEK.js +18 -0
  557. package/dist/image-generation-core.auth.runtime.js +1 -1
  558. package/dist/image-generation-provider-BHKIJcjv.js +63 -0
  559. package/dist/image-generation-provider-BVsvNzI_.js +228 -0
  560. package/dist/image-generation-provider-CpH4lCyW.js +137 -0
  561. package/dist/image-generation-provider-Ct1lT0uf.js +157 -0
  562. package/dist/image-generation-provider-DPRew87B.js +95 -0
  563. package/dist/image-generation-provider-DgCga9KE.js +274 -0
  564. package/dist/image-generation-provider-DgFuHosU.js +529 -0
  565. package/dist/image-runtime-2qfUy_eg.js +9 -0
  566. package/dist/inbound-reply-dispatch-B798MCBn.js +73 -0
  567. package/dist/inbound.runtime-BzROcnJN.js +3 -0
  568. package/dist/inbound.runtime-DmyBUa6W.js +4 -0
  569. package/dist/inbound.runtime.js +1 -1
  570. package/dist/index.js +2 -2
  571. package/dist/infra-runtime-D3zS_Fs_.js +39 -0
  572. package/dist/init-Cgs_Y5r2.js +59 -0
  573. package/dist/install-CNyKkmoe.js +726 -0
  574. package/dist/install-Cr1XiFcK.js +190 -0
  575. package/dist/install-security-scan-DkBMNG01.js +26 -0
  576. package/dist/install-security-scan.runtime-RflYyKMz.js +671 -0
  577. package/dist/install-security-scan.runtime.js +1 -1
  578. package/dist/install.runtime-BxrmrGNn.js +27 -0
  579. package/dist/install.runtime-Cwxpe69l.js +2 -0
  580. package/dist/install.runtime-Czxp-yhT.js +12 -0
  581. package/dist/install.runtime.js +1 -1
  582. package/dist/jobs-Dd5apK1w.js +734 -0
  583. package/dist/legacy-tools-by-sender-BBxdN6rr.js +95 -0
  584. package/dist/legacy-tools-by-sender-jW8LxMcX.js +2 -0
  585. package/dist/library-CHfLQeCR.js +45 -0
  586. package/dist/lifecycle-lQvUNIhu.js +229 -0
  587. package/dist/lifecycle-zNuWSrCz.js +571 -0
  588. package/dist/lifecycle.runtime-ByIupJ19.js +2 -0
  589. package/dist/lifecycle.runtime.js +1 -1
  590. package/dist/list-C3XOJSpa.js +2 -0
  591. package/dist/list-Cc1XrqqF.js +1212 -0
  592. package/dist/list-D7rUonSE.js +131 -0
  593. package/dist/list-xlj8z1FQ.js +2 -0
  594. package/dist/list.probe-DxROY_f3.js +419 -0
  595. package/dist/live-model-switch-BKj-o0qi.js +336 -0
  596. package/dist/llm-slug-generator-Dgp800fh.js +79 -0
  597. package/dist/llm-slug-generator.js +1 -1
  598. package/dist/load-config-BLj62YjO.js +35 -0
  599. package/dist/loader-CbjGl9Hl.js +222 -0
  600. package/dist/local-dispatch.runtime-DRwpFW1C.js +8 -0
  601. package/dist/local-dispatch.runtime.js +1 -1
  602. package/dist/login-xTSVvkH1.js +108 -0
  603. package/dist/logs-cli-DxgJIioY.js +265 -0
  604. package/dist/logs-cli.runtime-Bokfw6xX.js +2 -0
  605. package/dist/logs-cli.runtime.js +1 -1
  606. package/dist/main-session-restart-recovery-BGtEwwC7.js +206 -0
  607. package/dist/managed-image-attachments-CdnUvv4i.js +635 -0
  608. package/dist/managed-image-attachments-DGoeEEK0.js +2 -0
  609. package/dist/manager-By98-8j7.js +2057 -0
  610. package/dist/manager-DoYtM2M_.js +2 -0
  611. package/dist/markdown-to-line-BAow3FG2.js +790 -0
  612. package/dist/mcp/plugin-tools-serve.js +1 -1
  613. package/dist/mcp-cli-CzbNPbAu.js +725 -0
  614. package/dist/mcp-http-3955tCu1.js +529 -0
  615. package/dist/media-runtime-DPuaOh-W.js +329 -0
  616. package/dist/media-understanding-DMGc6bUS.js +85 -0
  617. package/dist/media-understanding-provider-BFjdxO9-.js +21 -0
  618. package/dist/media-understanding-provider-BN0_ZWCk.js +13 -0
  619. package/dist/media-understanding-provider-Bc8inzhb.js +69 -0
  620. package/dist/media-understanding-provider-BjOG0qfv.js +85 -0
  621. package/dist/media-understanding-provider-BpUWx7YV.js +12 -0
  622. package/dist/media-understanding-provider-CDvqr0Ha.js +18 -0
  623. package/dist/media-understanding-provider-DOPCCOGb.js +37 -0
  624. package/dist/media-understanding-provider-DOVnR49K.js +18 -0
  625. package/dist/media-understanding-provider-Dyw_vjd1.js +28 -0
  626. package/dist/media-understanding-provider-t-_UaQgo.js +12 -0
  627. package/dist/media-understanding-runtime-CloZxX3k.js +2 -0
  628. package/dist/memory-core-host-runtime-cli-D7VcUd8Q.js +9 -0
  629. package/dist/memory-embedding-adapter-DryAyE08.js +123 -0
  630. package/dist/memory-host-search-BAD700R9.js +12 -0
  631. package/dist/memory-host-search.runtime.js +1 -1
  632. package/dist/message-action-runner-COx-ZvZd.js +1407 -0
  633. package/dist/message-action-runner-fdG6pGAZ.js +2 -0
  634. package/dist/message-actions-Dp5oy-Id.js +143 -0
  635. package/dist/message-format-C6vUBf1L.js +328 -0
  636. package/dist/message-o2dPGRzs.js +232 -0
  637. package/dist/message.config.runtime.js +1 -1
  638. package/dist/message.gateway.runtime-56NMl6zr.js +2 -0
  639. package/dist/message.gateway.runtime.js +1 -1
  640. package/dist/model-picker-CmKXNo9I.js +3 -0
  641. package/dist/model-picker-RwmF8BB2.js +559 -0
  642. package/dist/model-picker.runtime-C7NZbfGO.js +15 -0
  643. package/dist/model-picker.runtime.js +1 -1
  644. package/dist/model-selection-V3vSY372.js +213 -0
  645. package/dist/models-auth-status-CIvClfyB.js +201 -0
  646. package/dist/models-cli-BnImTHDJ.js +219 -0
  647. package/dist/models.fetch-CSjF93kV.js +518 -0
  648. package/dist/monitor-B6C1jpvZ.js +671 -0
  649. package/dist/monitor-CD_A25Rx.js +788 -0
  650. package/dist/monitor-DbpDtT91.js +1661 -0
  651. package/dist/monitor-DvkiboRC.js +1459 -0
  652. package/dist/monitor-auth-eDhrUf09.js +207 -0
  653. package/dist/monitor-processing-3UY_U9hP.js +1974 -0
  654. package/dist/monitor-v7YjMH5B.js +2 -0
  655. package/dist/monitor-yj-MViK6.js +1237 -0
  656. package/dist/monitor.runtime-K9_4KdMD.js +2 -0
  657. package/dist/monitor.runtime.js +1 -1
  658. package/dist/monitor.webhook-DIIuOtEd.js +180 -0
  659. package/dist/msteams-6tpdLYYt.js +35 -0
  660. package/dist/music-generation-provider-DLsuTyhN.js +63 -0
  661. package/dist/music-generation-provider-DURtvZ5B.js +170 -0
  662. package/dist/native-hook-relay-DVfxqsON.js +519 -0
  663. package/dist/nextcloud-talk-DyYXCJLV.js +17 -0
  664. package/dist/node-cli-XV5Mq4R5.js +2506 -0
  665. package/dist/nodes-cli-CkCLLSNL.js +1046 -0
  666. package/dist/nodes-utils-Cvyl5QAh.js +84 -0
  667. package/dist/nodes.helpers-DYk79sWL.js +34 -0
  668. package/dist/notify-CzYxngwD.js +315 -0
  669. package/dist/oauth-CDxZvq5B.js +152 -0
  670. package/dist/oauth-CemxANpL.js +75 -0
  671. package/dist/oauth-DfB1vcWQ.js +139 -0
  672. package/dist/oauth-fpxNVPrl.js +2 -0
  673. package/dist/oauth-tls-preflight-BcNy7dKB.js +2 -0
  674. package/dist/oauth.flow-DbJmBCPq.js +3 -0
  675. package/dist/oauth.flow-jarh1FJh.js +45 -0
  676. package/dist/onboard-4gvN93s8.js +316 -0
  677. package/dist/onboard-D0lkvRs5.js +632 -0
  678. package/dist/onboard-channels-B31xMIuZ.js +3 -0
  679. package/dist/onboard-channels-BEkUvYCF.js +2 -0
  680. package/dist/onboard-config-DvU9Ngti.js +2 -0
  681. package/dist/onboard-custom-BitaTI2J.js +271 -0
  682. package/dist/onboard-custom-a9DbHTUT.js +3 -0
  683. package/dist/onboard-helpers-BHi-aRMH.js +204 -0
  684. package/dist/onboard-helpers-elKh6zBN.js +6 -0
  685. package/dist/onboard-hooks-Cr15MeKN.js +52 -0
  686. package/dist/onboard-remote-Cng1yalR.js +2 -0
  687. package/dist/onboard-remote-DXV2D8eg.js +193 -0
  688. package/dist/onboard-search-B0OW2KL3.js +323 -0
  689. package/dist/onboard-skills-BdzrRAcj.js +134 -0
  690. package/dist/onboard-skills-CNwXUb0I.js +2 -0
  691. package/dist/onboarding-plugin-install-DRFjmslc.js +406 -0
  692. package/dist/open-policy-allowfrom-C084Puwf.js +2 -0
  693. package/dist/open-policy-allowfrom-Dg0zzuWw.js +101 -0
  694. package/dist/openai-codex-provider-DC5MRZgN.js +472 -0
  695. package/dist/openai-http-DPekQzlm.js +500 -0
  696. package/dist/openai-provider-BAc1xw8U.js +313 -0
  697. package/dist/opencode-rrH9GPhY.js +35 -0
  698. package/dist/openresponses-http-KuBtyTB9.js +1128 -0
  699. package/dist/operator-approvals-client-Ck6tSehQ.js +68 -0
  700. package/dist/outbound-runtime-Dquu18jb.js +5 -0
  701. package/dist/outbound.runtime-C4fvxQG0.js +2 -0
  702. package/dist/outbound.runtime.js +1 -1
  703. package/dist/pair-command-approve-DXxc-bF6.js +44 -0
  704. package/dist/persistent-bindings.lifecycle-DHLMOTbE.js +2 -0
  705. package/dist/persistent-bindings.lifecycle-FgyzapQO.js +85 -0
  706. package/dist/pi-embedded-DX9kTXHk.js +4 -0
  707. package/dist/pi-embedded-c1fYxGY_.js +2905 -0
  708. package/dist/pi-embedded-subscribe.handlers.compaction.runtime-EnaEhBV7.js +23 -0
  709. package/dist/pi-embedded-subscribe.handlers.compaction.runtime.js +1 -1
  710. package/dist/pi-embedded.runtime-BF21n0BD.js +4 -0
  711. package/dist/pi-embedded.runtime.js +1 -1
  712. package/dist/pi-tool-definition-adapter-IAoWm6mw.js +217 -0
  713. package/dist/pi-tools-C_f4UUql.js +1057 -0
  714. package/dist/pi-tools.before-tool-call-OMTQuo2Y.js +2 -0
  715. package/dist/pi-tools.before-tool-call-Yjb1AzLr.js +433 -0
  716. package/dist/plugin-Bqw6iIhd.js +12195 -0
  717. package/dist/plugin-enabled-Dws5rJhZ.js +140 -0
  718. package/dist/plugin-install-BQn7pUma.js +115 -0
  719. package/dist/plugin-install-config-policy-BM-_U7I2.js +137 -0
  720. package/dist/plugin-install-iU6yvmd2.js +2 -0
  721. package/dist/plugin-install-plan-D11M-SSH.js +50 -0
  722. package/dist/plugin-registration-BlawgUJq.js +23 -0
  723. package/dist/plugin-registry-BS1ql5am.js +3 -0
  724. package/dist/plugin-registry-DQYacxoR.js +2 -0
  725. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  726. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  727. package/dist/plugin-sdk/acp-runtime.js +3 -3
  728. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  729. package/dist/plugin-sdk/agent-harness.js +7 -7
  730. package/dist/plugin-sdk/agent-runtime.js +2 -2
  731. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  732. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  733. package/dist/plugin-sdk/approval-runtime.js +1 -1
  734. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  735. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  736. package/dist/plugin-sdk/browser-support.js +7 -7
  737. package/dist/plugin-sdk/channel-core.js +2 -2
  738. package/dist/plugin-sdk/channel-inbound.js +3 -3
  739. package/dist/plugin-sdk/command-auth.js +2 -2
  740. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  741. package/dist/plugin-sdk/compat.js +1 -1
  742. package/dist/plugin-sdk/config-runtime.js +3 -3
  743. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  744. package/dist/plugin-sdk/conversation-runtime.js +4 -4
  745. package/dist/plugin-sdk/core.js +2 -2
  746. package/dist/plugin-sdk/direct-dm.js +1 -1
  747. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  748. package/dist/plugin-sdk/image-generation-core.js +2 -2
  749. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  750. package/dist/plugin-sdk/index.js +1 -1
  751. package/dist/plugin-sdk/infra-runtime.js +2 -2
  752. package/dist/plugin-sdk/irc.js +2 -2
  753. package/dist/plugin-sdk/matrix.js +1 -1
  754. package/dist/plugin-sdk/mattermost.js +2 -2
  755. package/dist/plugin-sdk/media-runtime.js +5 -5
  756. package/dist/plugin-sdk/media-understanding-runtime.js +2 -2
  757. package/dist/plugin-sdk/media-understanding.js +2 -2
  758. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  759. package/dist/plugin-sdk/memory-core.js +2 -2
  760. package/dist/plugin-sdk/memory-host-search.js +1 -1
  761. package/dist/plugin-sdk/msteams.js +3 -3
  762. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  763. package/dist/plugin-sdk/nostr.js +1 -1
  764. package/dist/plugin-sdk/opencode.js +1 -1
  765. package/dist/plugin-sdk/outbound-runtime.js +2 -2
  766. package/dist/plugin-sdk/provider-auth-api-key.js +2 -2
  767. package/dist/plugin-sdk/provider-auth-login.js +1 -1
  768. package/dist/plugin-sdk/provider-auth.js +2 -2
  769. package/dist/plugin-sdk/provider-entry.js +1 -1
  770. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  771. package/dist/plugin-sdk/reply-runtime.js +4 -4
  772. package/dist/plugin-sdk/runtime-doctor.js +1 -1
  773. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  774. package/dist/plugin-sdk/runtime.js +3 -3
  775. package/dist/plugin-sdk/sandbox.js +1 -1
  776. package/dist/plugin-sdk/session-store-runtime.js +1 -1
  777. package/dist/plugin-sdk/session-visibility.js +1 -1
  778. package/dist/plugin-sdk/skill-commands-runtime.js +1 -1
  779. package/dist/plugin-sdk/src/config/types.browser.d.ts +1 -1
  780. package/dist/plugin-sdk/testing.js +4 -4
  781. package/dist/plugin-sdk/tlon.js +1 -1
  782. package/dist/plugin-sdk/zalo.js +1 -1
  783. package/dist/plugin-sdk/zalouser.js +1 -1
  784. package/dist/plugin-service-VZSLJ4oI.js +2892 -0
  785. package/dist/plugins/runtime/index.js +1 -1
  786. package/dist/plugins-cli-UR8WqrIq.js +584 -0
  787. package/dist/plugins-command-helpers-D799dbVj.js +107 -0
  788. package/dist/plugins-install-persist-D_HU3Frx.js +133 -0
  789. package/dist/plugins-update-command-BTBJuQMC.js +1057 -0
  790. package/dist/policy-9PlwCZVI.js +328 -0
  791. package/dist/postinstall-inventory.json +854 -850
  792. package/dist/prepare.runtime-BWs6JC5C.js +815 -0
  793. package/dist/prepare.runtime.js +1 -1
  794. package/dist/preview-warnings-Xd3ZVG_C.js +120 -0
  795. package/dist/probe-BvnxVXPF.js +2 -0
  796. package/dist/probe-CVdSkKEj.js +241 -0
  797. package/dist/probe-CdbOHCqk.js +45 -0
  798. package/dist/probe-CgIZN3nP.js +1443 -0
  799. package/dist/probe-Cj5gwplO.js +74 -0
  800. package/dist/probe-D4pJKTVi.js +2 -0
  801. package/dist/probe-DOpn9xW4.js +243 -0
  802. package/dist/probe-Dhgk7ek6.js +2205 -0
  803. package/dist/probe-auth-Nvl_FRXO.js +3 -0
  804. package/dist/program-BOie7Vt-.js +111 -0
  805. package/dist/program-context-ChxdxCOu.js +2 -0
  806. package/dist/prompt-select-styled-BoqQDWM7.js +20 -0
  807. package/dist/protocol-AGt54mci.js +2335 -0
  808. package/dist/provider-D_uxch_F.js +70 -0
  809. package/dist/provider-api-key-auth-DQcZiZii.js +114 -0
  810. package/dist/provider-api-key-auth.runtime.js +1 -1
  811. package/dist/provider-auth-C983Ir3i.js +46 -0
  812. package/dist/provider-auth-api-key-DTSUklSr.js +5 -0
  813. package/dist/provider-auth-choice-B5hkZbf_.js +228 -0
  814. package/dist/provider-auth-choice-preference-CJRv4tMl.js +27 -0
  815. package/dist/provider-auth-choices-BgUKYeKC.js +2 -0
  816. package/dist/provider-auth-guidance-CXc99WzE.js +2 -0
  817. package/dist/provider-auth-login-O3Sm0KwV.js +8 -0
  818. package/dist/provider-auth-login.runtime-CbaRtloJ.js +267 -0
  819. package/dist/provider-auth-login.runtime.js +1 -1
  820. package/dist/provider-dispatcher-DWf9-i4h.js +22 -0
  821. package/dist/provider-dispatcher-Difz51Qf.js +2 -0
  822. package/dist/provider-entry-D0S4gpr-.js +106 -0
  823. package/dist/provider-flow-f_IA_ktZ.js +148 -0
  824. package/dist/provider-install-catalog-Cg32-zFa.js +108 -0
  825. package/dist/provider-model-defaults-ChOCI1XD.js +6 -0
  826. package/dist/provider-registration-DReJwyYv.js +37 -0
  827. package/dist/provider-registration-DuuV27JS.js +218 -0
  828. package/dist/proxy-cli-CqFZNmxT.js +44 -0
  829. package/dist/proxy-cli.runtime-CAFc4tCs.js +372 -0
  830. package/dist/proxy-cli.runtime.js +1 -1
  831. package/dist/pw-ai-Dre6YylS.js +2511 -0
  832. package/dist/qr-cli-CKjl5y9P.js +349 -0
  833. package/dist/qr-cli-HA7KcboU.js +2 -0
  834. package/dist/qr-image-BEyM3usD.js +2 -0
  835. package/dist/queue-18j62oEc.js +409 -0
  836. package/dist/reaction-runtime-api-Byb7aNNv.js +116 -0
  837. package/dist/reactions-DKjkdDpt.js +998 -0
  838. package/dist/read-best-effort-config.runtime.js +1 -1
  839. package/dist/read-capability-L5JQpwus.js +412 -0
  840. package/dist/register-service-commands-DgcOFNfd.js +71 -0
  841. package/dist/register.agent-D8O3Pej1.js +248 -0
  842. package/dist/register.backup-B_r2LOYK.js +64 -0
  843. package/dist/register.configure-DnJuRHEh.js +15 -0
  844. package/dist/register.maintenance-3aZxhWJa.js +363 -0
  845. package/dist/register.message-BXlGRk2N.js +329 -0
  846. package/dist/register.onboard-CqjGOMl-.js +81 -0
  847. package/dist/register.runtime-BnKRhWSR.js +81 -0
  848. package/dist/register.runtime.js +1 -1
  849. package/dist/register.setup-CuhKuyzn.js +150 -0
  850. package/dist/register.status-health-sessions-C5DzZa1_.js +1215 -0
  851. package/dist/register.subclis-CR1fpSTT.js +3 -0
  852. package/dist/register.subclis-D_uws2t_.js +29 -0
  853. package/dist/register.subclis-core-AHoaC6VW.js +249 -0
  854. package/dist/register.wallet-BiFJeDsS.js +159 -0
  855. package/dist/repair-sequencing-BSAmIx7i.js +145 -0
  856. package/dist/reply-dispatch-runtime-Ceu-bJO-.js +13 -0
  857. package/dist/reply-media-paths.runtime-BQcpYv4W.js +2 -0
  858. package/dist/reply-media-paths.runtime-DpCr5Ul0.js +146 -0
  859. package/dist/reply-media-paths.runtime.js +1 -1
  860. package/dist/reply-runtime-BCvhbO0n.js +11 -0
  861. package/dist/reply.runtime-Dq49ajK8.js +2 -0
  862. package/dist/reply.runtime.js +1 -1
  863. package/dist/resolve-k9X8xwXZ.js +259 -0
  864. package/dist/response-generator-F0uPL6Wb.js +175 -0
  865. package/dist/restart-health-B3BG9cWC.js +2 -0
  866. package/dist/restart-health-Blxs74k_.js +202 -0
  867. package/dist/root-help-ChzMvc3A.js +44 -0
  868. package/dist/route-reply-C8iN0qJY.js +162 -0
  869. package/dist/route-reply.runtime-B2lAB1-b.js +2 -0
  870. package/dist/route-reply.runtime.js +1 -1
  871. package/dist/routes-CJ7e3-3_.js +3341 -0
  872. package/dist/routes-CSpmwUOo.js +2 -0
  873. package/dist/rpc-zrzVsr7U.js +61 -0
  874. package/dist/rpc.runtime-BoWSTfbK.js +21 -0
  875. package/dist/rpc.runtime.js +1 -1
  876. package/dist/run-auth-profile.runtime-CmWR2ACc.js +2 -0
  877. package/dist/run-auth-profile.runtime.js +1 -1
  878. package/dist/run-context.runtime.js +1 -1
  879. package/dist/run-delivery.runtime-gMcYNNDu.js +530 -0
  880. package/dist/run-delivery.runtime.js +1 -1
  881. package/dist/run-embedded.runtime-Y7BR9y48.js +4 -0
  882. package/dist/run-embedded.runtime.js +1 -1
  883. package/dist/run-execution-cli.runtime-gnM2Ql9w.js +4 -0
  884. package/dist/run-execution-cli.runtime.js +1 -1
  885. package/dist/run-executor.runtime-CrBblsnd.js +277 -0
  886. package/dist/run-executor.runtime.js +1 -1
  887. package/dist/run-external-content.runtime.js +1 -1
  888. package/dist/run-main-TmL9-_zs.js +567 -0
  889. package/dist/run-model-catalog.runtime.js +1 -1
  890. package/dist/run-subagent-registry.runtime-CWsqAYYP.js +2 -0
  891. package/dist/run-subagent-registry.runtime.js +1 -1
  892. package/dist/run-wait-D3KzpvQq.js +135 -0
  893. package/dist/runner-DUtC35j2.js +966 -0
  894. package/dist/runner.entries-0ZSu_nTv.js +604 -0
  895. package/dist/runtime-CxubLXjp.js +72 -0
  896. package/dist/runtime-DSuaai8P.js +263 -0
  897. package/dist/runtime-DnDt_3OQ.js +116 -0
  898. package/dist/runtime-DrHUjQ1Q.js +973 -0
  899. package/dist/runtime-_ZEfYaU0.js +9 -0
  900. package/dist/runtime-api-BO9T0HM6.js +9 -0
  901. package/dist/runtime-api-D05_vaS-.js +9 -0
  902. package/dist/runtime-api-DP5brVhK.js +4 -0
  903. package/dist/runtime-api-Y1Y0XFaX.js +14 -0
  904. package/dist/runtime-embedded-pi.runtime-zFbq7SGM.js +2 -0
  905. package/dist/runtime-embedded-pi.runtime.js +1 -1
  906. package/dist/runtime-entry-BxV0KsK8.js +2769 -0
  907. package/dist/runtime-internal-BhujhdGc.js +2 -0
  908. package/dist/runtime-manifest.runtime.js +1 -1
  909. package/dist/runtime-options-DPOGEX8m.js +275 -0
  910. package/dist/runtime-pB6_767d.js +2 -0
  911. package/dist/runtime-prepare.runtime-DCMh017y.js +80 -0
  912. package/dist/runtime-prepare.runtime.js +1 -1
  913. package/dist/runtime-registry-loader-BnT6zi1m.js +2 -0
  914. package/dist/runtime-schema-BkQ2RaAT.js +27796 -0
  915. package/dist/runtime-web-tools-BUdYGMsD.js +1477 -0
  916. package/dist/runtime-web-tools-fallback.runtime.js +1 -1
  917. package/dist/runtime-web-tools-manifest.runtime.js +1 -1
  918. package/dist/runtime-web-tools-public-artifacts.runtime.js +1 -1
  919. package/dist/sandbox-CHm2nn70.js +1156 -0
  920. package/dist/sandbox-E_kshBRj.js +3 -0
  921. package/dist/sandbox-cli-DQy0IvU6.js +450 -0
  922. package/dist/scan-BHrX6xlw.js +2 -0
  923. package/dist/scan-YCM3NZ4a.js +523 -0
  924. package/dist/secrets-cli-DiJDMvpu.js +2101 -0
  925. package/dist/security-cli-DKW-eR9G.js +486 -0
  926. package/dist/selection-CKyD2Dph.js +7736 -0
  927. package/dist/selection-Dg3WfJp4.js +2 -0
  928. package/dist/send-Cwx2NC_E.js +156 -0
  929. package/dist/send-DfVrE6Nj.js +102 -0
  930. package/dist/send.runtime-RHU8DLUa.js +2 -0
  931. package/dist/send.runtime.js +1 -1
  932. package/dist/server-CVac_8eO.js +77 -0
  933. package/dist/server-DK60xdj1.js +13 -0
  934. package/dist/server-context-DH1UPelC.js +847 -0
  935. package/dist/server-context-DSP_jNKo.js +2 -0
  936. package/dist/server-node-events-CQkjKwDW.js +481 -0
  937. package/dist/server-plugin-bootstrap-CWkKWsmU.js +11535 -0
  938. package/dist/server-plugin-bootstrap-DtuLv1Z0.js +2 -0
  939. package/dist/server-restart-sentinel-BqlD_fdp.js +697 -0
  940. package/dist/server.impl-y2ki-U8R.js +12822 -0
  941. package/dist/session-BmhZ0w1g.js +48 -0
  942. package/dist/session-archive.runtime.js +1 -1
  943. package/dist/session-envelope-CcfhPnpN.js +18 -0
  944. package/dist/session-key-B4usxD24.js +65 -0
  945. package/dist/session-kill-http-CBVZRf5-.js +110 -0
  946. package/dist/session-meta-BboKGMtd.js +109 -0
  947. package/dist/session-override-BOwEVLnz.js +106 -0
  948. package/dist/session-reset-model.runtime-ZTv_T7lt.js +133 -0
  949. package/dist/session-reset-model.runtime.js +1 -1
  950. package/dist/session-reset-service-EkGOtdE8.js +471 -0
  951. package/dist/session-route-BGqKLpT1.js +93 -0
  952. package/dist/session-status.runtime-8fW2zaxe.js +2 -0
  953. package/dist/session-status.runtime.js +1 -1
  954. package/dist/session-store-DgAh1suS.js +126 -0
  955. package/dist/session-store.runtime-JjCOtrjx.js +2 -0
  956. package/dist/session-store.runtime.js +1 -1
  957. package/dist/session-subagent-reactivation.runtime-Ds5c0djG.js +2 -0
  958. package/dist/session-subagent-reactivation.runtime.js +1 -1
  959. package/dist/session-tab-registry-DkVIf7hV.js +581 -0
  960. package/dist/session-updates-Cv75xqmY.js +236 -0
  961. package/dist/session-updates.runtime-B8c11iw1.js +2 -0
  962. package/dist/session-updates.runtime.js +1 -1
  963. package/dist/session-utils-CuzGvD11.js +1006 -0
  964. package/dist/session-visibility-C3JCU9JN.js +147 -0
  965. package/dist/sessions-CxqBNE-J.js +2 -0
  966. package/dist/sessions-DNlJETOX.js +48 -0
  967. package/dist/sessions-DaSeSXOJ.js +281 -0
  968. package/dist/sessions-Dm6k-udS.js +16 -0
  969. package/dist/sessions-helpers-DOb5IrRm.js +304 -0
  970. package/dist/sessions-history-http-CupOgqEu.js +383 -0
  971. package/dist/sessions-patch-CzbJpzmm.js +309 -0
  972. package/dist/sessions-resolve-jfzejD6e.js +174 -0
  973. package/dist/sessions.runtime-BVhaNHoj.js +2 -0
  974. package/dist/sessions.runtime.js +1 -1
  975. package/dist/setup-C_cEOif3.js +495 -0
  976. package/dist/setup-DafKIWc2.js +421 -0
  977. package/dist/setup-api-CaIoRGbW.js +29 -0
  978. package/dist/setup-core-DHSQ96hI.js +171 -0
  979. package/dist/setup-core-SSEJmQpZ.js +176 -0
  980. package/dist/setup-surface-C6FileLV.js +219 -0
  981. package/dist/setup-surface-GihBDZa6.js +403 -0
  982. package/dist/setup-surface-biZwah-0.js +286 -0
  983. package/dist/setup.finalize-ch5XUfVx.js +539 -0
  984. package/dist/setup.gateway-config-ueuag32X.js +250 -0
  985. package/dist/shared--9pW5Ce7.js +76 -0
  986. package/dist/shared-BHLRlMoM.js +217 -0
  987. package/dist/shared-BbFyx9G1.js +121 -0
  988. package/dist/shared-CiA5BTBf.js +198 -0
  989. package/dist/shared-runtime-9X8j5_KJ.js +7 -0
  990. package/dist/skill-commands-X1nUEOXX.js +83 -0
  991. package/dist/skill-commands.runtime-t_xMebUt.js +2 -0
  992. package/dist/skill-commands.runtime.js +1 -1
  993. package/dist/skills-clawhub-Qqd5npos.js +275 -0
  994. package/dist/skills-cli-D1XXa0XQ.js +370 -0
  995. package/dist/skills-install-Dub1fmyK.js +605 -0
  996. package/dist/skills-snapshot.runtime-jMF9Gla8.js +7 -0
  997. package/dist/skills-snapshot.runtime.js +1 -1
  998. package/dist/slash-state-C4SKy5al.js +1911 -0
  999. package/dist/speech-provider-DN4EL6mY.js +209 -0
  1000. package/dist/speech-provider-DiHqRzvg.js +216 -0
  1001. package/dist/speech-provider-I6DuR7ih.js +170 -0
  1002. package/dist/src-CvAKVqK5.js +3974 -0
  1003. package/dist/stage-sandbox-media.runtime-D3i8uZyP.js +232 -0
  1004. package/dist/stage-sandbox-media.runtime.js +1 -1
  1005. package/dist/stale-plugin-config-DjXhX5ro.js +103 -0
  1006. package/dist/stale-plugin-config-OQnSe4DX.js +2 -0
  1007. package/dist/startup-context-BCZp-nrD.js +312 -0
  1008. package/dist/state-migrations-w5G6NV2T.js +820 -0
  1009. package/dist/status-BHUXDOxB.js +190 -0
  1010. package/dist/status-Bj0PB_BB.js +209 -0
  1011. package/dist/status-CoR6bPDI.js +2 -0
  1012. package/dist/status-DF3nzErU.js +3 -0
  1013. package/dist/status-DYRFWBUr.js +2 -0
  1014. package/dist/status-QjQ5fLJG.js +397 -0
  1015. package/dist/status-RapY_a8v.js +62 -0
  1016. package/dist/status-all-C5dOpSTJ.js +498 -0
  1017. package/dist/status-json-Ch8iLhXc.js +14 -0
  1018. package/dist/status-json-command-j0_mDLvG.js +84 -0
  1019. package/dist/status-message-DZWQePYx.js +466 -0
  1020. package/dist/status-message.runtime-uc5V05rB.js +6 -0
  1021. package/dist/status-message.runtime.js +1 -1
  1022. package/dist/status-queue.runtime-DCiv2--4.js +2 -0
  1023. package/dist/status-queue.runtime.js +1 -1
  1024. package/dist/status-runtime-shared-ZMmwbQgo.js +257 -0
  1025. package/dist/status-subagents.runtime-BtzPnPQK.js +18 -0
  1026. package/dist/status-subagents.runtime.js +1 -1
  1027. package/dist/status-text-DWp3FqTV.js +237 -0
  1028. package/dist/status.agent-local-BOqQC7TE.js +58 -0
  1029. package/dist/status.command.text-runtime-BGajGa6I.js +15 -0
  1030. package/dist/status.gateway-connection.runtime-oVziBbXJ.js +2 -0
  1031. package/dist/status.gateway-connection.runtime.js +1 -1
  1032. package/dist/status.gateway-probe-uIu3L-Rn.js +16 -0
  1033. package/dist/status.gather-K0BR9xLt.js +2 -0
  1034. package/dist/status.gather-vx7VGIBO.js +292 -0
  1035. package/dist/status.link-channel-A9hhIWyV.js +35 -0
  1036. package/dist/status.node-mode-Be4WLZXV.js +32 -0
  1037. package/dist/status.node-mode-Blnsadww.js +2 -0
  1038. package/dist/status.runtime-B2ripBxv.js +2 -0
  1039. package/dist/status.runtime-Bo7TFvUE.js +2 -0
  1040. package/dist/status.runtime.js +1 -1
  1041. package/dist/status.scan-BiRMUkAL.js +65 -0
  1042. package/dist/status.scan-overview-CHPUBwXN.js +379 -0
  1043. package/dist/status.scan.deps.runtime.js +1 -1
  1044. package/dist/status.scan.fast-json-B17v4E7m.js +132 -0
  1045. package/dist/status.scan.fast-json-DnHV6-FY.js +2 -0
  1046. package/dist/status.scan.runtime-DkG5vIQz.js +409 -0
  1047. package/dist/status.scan.runtime.js +1 -1
  1048. package/dist/status.summary-B-dxNuw4.js +2 -0
  1049. package/dist/status.summary-BUa9nTjl.js +214 -0
  1050. package/dist/status.update-Dk3S_7Lg.js +79 -0
  1051. package/dist/status.update-XYGUXSP7.js +2 -0
  1052. package/dist/store-B0wUii0o.js +910 -0
  1053. package/dist/store-C6gzhrUl.js +4 -0
  1054. package/dist/store.runtime-zFzaCgaN.js +2 -0
  1055. package/dist/store.runtime.js +1 -1
  1056. package/dist/stream-BGF6sIIj.js +664 -0
  1057. package/dist/subagent-announce-cxSxcEpf.js +351 -0
  1058. package/dist/subagent-announce-delivery-DWWzFpRW.js +726 -0
  1059. package/dist/subagent-announce-output-BifyE5eI.js +364 -0
  1060. package/dist/subagent-capabilities-AF6T_57k.js +251 -0
  1061. package/dist/subagent-control-CdZhtCp9.js +506 -0
  1062. package/dist/subagent-control.runtime-DBV8B-6z.js +3 -0
  1063. package/dist/subagent-control.runtime.js +1 -1
  1064. package/dist/subagent-followup.runtime-BPnUQG2q.js +68 -0
  1065. package/dist/subagent-followup.runtime.js +1 -1
  1066. package/dist/subagent-orphan-recovery-BmhbSEPM.js +305 -0
  1067. package/dist/subagent-registry-BPOTEL9f.js +1753 -0
  1068. package/dist/subagent-registry-DksKb1R4.js +3 -0
  1069. package/dist/subagent-registry.runtime.js +1 -1
  1070. package/dist/subagent-spawn-CtYFn2NM.js +1005 -0
  1071. package/dist/supervisor-B-cWweJz.js +704 -0
  1072. package/dist/supervisor-log.runtime.js +1 -1
  1073. package/dist/system-cli-C_3trUzR.js +59 -0
  1074. package/dist/systemd-linger-Bp7RlUum.js +2 -0
  1075. package/dist/target-id-Ujv5hNZO.js +107 -0
  1076. package/dist/targets-Rv4LtIoh.js +67 -0
  1077. package/dist/targets.runtime.js +1 -1
  1078. package/dist/task-executor-DjPeHczG.js +360 -0
  1079. package/dist/task-owner-access-CMLLG2vh.js +74 -0
  1080. package/dist/task-registry-Q3Cl90mj.js +2366 -0
  1081. package/dist/task-registry-delivery-runtime-BSuaWdpl.js +2 -0
  1082. package/dist/task-registry-delivery-runtime-DWCwND9H.js +3 -0
  1083. package/dist/task-registry.maintenance-CvZuHZTV.js +416 -0
  1084. package/dist/task-registry.maintenance-IDjkL8Np.js +2 -0
  1085. package/dist/telegram/token.js +2 -2
  1086. package/dist/testing-CNkQ39ew.js +575 -0
  1087. package/dist/text-report-DVIG_L7b.js +587 -0
  1088. package/dist/tool-auth-shared-De65N_fJ.js +90 -0
  1089. package/dist/tool-policy-pipeline-Cwo7nErU.js +109 -0
  1090. package/dist/tool-resolution-s05uymkY.js +90 -0
  1091. package/dist/tools-effective-inventory--jk1GD1B.js +152 -0
  1092. package/dist/tools-invoke-http-Bkpw98PK.js +206 -0
  1093. package/dist/transcript-YAj-FvLG.js +312 -0
  1094. package/dist/transcript-resolve.runtime-4NCOnX42.js +2 -0
  1095. package/dist/transcript-resolve.runtime.js +1 -1
  1096. package/dist/transcript.runtime-CoUyn9fx.js +2 -0
  1097. package/dist/transcript.runtime.js +1 -1
  1098. package/dist/trash-Bj9oW0g5.js +24 -0
  1099. package/dist/tts-Cnj91x3B.js +64 -0
  1100. package/dist/tui-cli-63sm8eVE.js +4575 -0
  1101. package/dist/uninstall-9nOSf4s_.js +185 -0
  1102. package/dist/update-DlxQL9Iy.js +1282 -0
  1103. package/dist/update-cli-C_DkYNQx.js +1759 -0
  1104. package/dist/update-runner-xWl321w2.js +1892 -0
  1105. package/dist/update-startup-DDtqVzgO.js +331 -0
  1106. package/dist/update-startup-DN0IlVjY.js +2 -0
  1107. package/dist/upgrade-CROnI5RX.js +1226 -0
  1108. package/dist/video-generation-provider-B8mxQJBe.js +271 -0
  1109. package/dist/video-generation-provider-BmWUZDy3.js +78 -0
  1110. package/dist/video-generation-provider-BnHoRhgc.js +254 -0
  1111. package/dist/video-generation-provider-BzbQU0_O2.js +77 -0
  1112. package/dist/video-generation-provider-C4a6Fid4.js +64 -0
  1113. package/dist/video-generation-provider-CPKiG6d-.js +287 -0
  1114. package/dist/video-generation-provider-Cvb0pnUY.js +221 -0
  1115. package/dist/video-generation-provider-D40zcMSN.js +264 -0
  1116. package/dist/video-generation-provider-DahQjVLx.js +118 -0
  1117. package/dist/video-generation-provider-Ni3qeKHD.js +187 -0
  1118. package/dist/video-generation-provider-VpDrag9H.js +281 -0
  1119. package/dist/video-generation-task-status-D_6OimZH.js +163 -0
  1120. package/dist/wait-for-idle-before-flush-jjJHjLe9.js +5986 -0
  1121. package/dist/web-search-provider-CX_JSUqp.js +163 -0
  1122. package/dist/webhooks-cli-BgTQ_P6o.js +321 -0
  1123. package/dist/wizard-models-BXxRio-w.js +161 -0
  1124. package/dist/workflow-runtime-D62ZaRZf.js +485 -0
  1125. package/package.json +1 -1
  1126. package/dist/abort-OiNnhIeU.js +0 -201
  1127. package/dist/abort-cutoff.runtime-e5msXazz.js +0 -20
  1128. package/dist/abort.runtime-32L7to00.js +0 -2
  1129. package/dist/accounts-14lAXeAz.js +0 -107
  1130. package/dist/accounts-LZBr-w-R.js +0 -2
  1131. package/dist/accounts-Qds94ljJ.js +0 -104
  1132. package/dist/acp-cli-Dpw7BGfH.js +0 -2193
  1133. package/dist/acp-spawn-CY9aGxXS.js +0 -1093
  1134. package/dist/acp-spawn-_f_fT2de.js +0 -2
  1135. package/dist/acp-stateful-target-driver-CCR0BYbj.js +0 -89
  1136. package/dist/action-agents-EpYpAn3c.js +0 -67
  1137. package/dist/action-focus-B3Ps1mmc.js +0 -132
  1138. package/dist/action-help-BGFH_VTi.js +0 -7
  1139. package/dist/action-info-C8TaNUkA.js +0 -101
  1140. package/dist/action-kill-DGSI5rAr.js +0 -33
  1141. package/dist/action-list-mDthFZbQ.js +0 -21
  1142. package/dist/action-log-BP5nomP5.js +0 -30
  1143. package/dist/action-send-Bh2FybD3.js +0 -39
  1144. package/dist/action-spawn-Dn0I3O5l.js +0 -47
  1145. package/dist/action-unfocus-BC9BBJec.js +0 -29
  1146. package/dist/actions.runtime-DbK3OvjW.js +0 -5
  1147. package/dist/actions.runtime-ydCDe6F7.js +0 -18
  1148. package/dist/agent-2o2eoVoy.js +0 -2
  1149. package/dist/agent-command-DmyA9z8R.js +0 -874
  1150. package/dist/agent-harness-runtime-B5rFeVnf.js +0 -144
  1151. package/dist/agent-runner-utils-DZOonqcp.js +0 -239
  1152. package/dist/agent-runner.runtime-ByRVf3ri.js +0 -3455
  1153. package/dist/agent-runtime-CHO-MdDI.js +0 -18
  1154. package/dist/agents-9L9SuCcn.js +0 -5
  1155. package/dist/agents-WtBMKDwO.js +0 -954
  1156. package/dist/agents.bindings-DUCT7yry.js +0 -2
  1157. package/dist/agents.command-shared-BBhswYB6.js +0 -40
  1158. package/dist/aliases-BbVKhonh.js +0 -96
  1159. package/dist/aliases-CZ5oBftl.js +0 -2
  1160. package/dist/api-BWDQZArS.js +0 -48
  1161. package/dist/api-HqzZCzSZ.js +0 -5
  1162. package/dist/api-YyjQX3CK.js +0 -3
  1163. package/dist/api-aioOoaX8.js +0 -139
  1164. package/dist/api-mhcwEPke.js +0 -4
  1165. package/dist/apply-D-o-D5ae.js +0 -508
  1166. package/dist/apply.runtime-BkZiuui8.js +0 -166
  1167. package/dist/apply.runtime-BnL-LuiS.js +0 -2
  1168. package/dist/approval-gateway-resolver-ZfVZSqSY.js +0 -29
  1169. package/dist/approval-gateway-runtime-B3klmuhM.js +0 -2
  1170. package/dist/approval-handler-runtime-B9-1ZE2m.js +0 -439
  1171. package/dist/approval-native-runtime-Dc47eE28.js +0 -729
  1172. package/dist/assistant-identity-BJGlR731.js +0 -74
  1173. package/dist/attempt-execution.runtime-Dvb3Lr4C.js +0 -509
  1174. package/dist/attempt-execution.shared-CrrA0Anh.js +0 -22
  1175. package/dist/attempt.prompt-helpers-D42OSEcl.js +0 -221
  1176. package/dist/attempt.tool-run-context-fDOIg6kt.js +0 -933
  1177. package/dist/audit-B2pydz3g.js +0 -939
  1178. package/dist/audit-extra.async-nI09atn6.js +0 -971
  1179. package/dist/audit-tool-policy-BKWAS6yU.js +0 -3
  1180. package/dist/audit.deep.runtime-aPovRAts.js +0 -2
  1181. package/dist/audit.nondeep.runtime-BvrCJl4U.js +0 -880
  1182. package/dist/audit.runtime-b0S_gQ96.js +0 -7
  1183. package/dist/auth-BN2154e0.js +0 -383
  1184. package/dist/auth-CAbEo0kO.js +0 -56
  1185. package/dist/auth-D2nGJuio.js +0 -2
  1186. package/dist/auth-ZHjpnQ6q.js +0 -177
  1187. package/dist/auth-choice-BSXGTESF.js +0 -354
  1188. package/dist/auth-choice-C5CTX499.js +0 -85
  1189. package/dist/auth-choice-C9-7i28N.js +0 -3
  1190. package/dist/auth-choice-inference-s8zdsYr7.js +0 -30
  1191. package/dist/auth-choice-legacy-CCxoDHuP.js +0 -40
  1192. package/dist/auth-choice-legacy-DDkk2RCn.js +0 -2
  1193. package/dist/auth-choice-options-BIa3PkrG.js +0 -99
  1194. package/dist/auth-choice-prompt-3zAPptyB.js +0 -2
  1195. package/dist/auth-choice-prompt-CVXaEZMS.js +0 -37
  1196. package/dist/auth-choice.apply.api-providers-CWgqsayF.js +0 -2
  1197. package/dist/auth-install-policy-ISsAgDw3.js +0 -195
  1198. package/dist/auth-order-CAYi780T.js +0 -2
  1199. package/dist/auth-order-Db_WKPjd.js +0 -96
  1200. package/dist/backup-verify-CdOAmzAS.js +0 -2
  1201. package/dist/bash-tools-DBpdfhbT.js +0 -3
  1202. package/dist/bash-tools-qdz1BvUq.js +0 -2824
  1203. package/dist/bash-tools.exec-runtime-BxYRaGWr.js +0 -829
  1204. package/dist/binding-routing-C5KQ4aMB.js +0 -85
  1205. package/dist/binding-targets-B21rWX8y.js +0 -121
  1206. package/dist/bonjour-discovery-DdJwp8BR.js +0 -2
  1207. package/dist/bridge-server-Cd9HIyEM.js +0 -113
  1208. package/dist/browser-control-auth-CqUfrmnh.js +0 -2
  1209. package/dist/browser-node-runtime-C_gi-Hxh.js +0 -12
  1210. package/dist/browser-profiles-B3PNUxu6.js +0 -2
  1211. package/dist/browser-runtime-CKNoYQQT.js +0 -387
  1212. package/dist/browser-setup-tools-BS6MamG8.js +0 -13
  1213. package/dist/build-MUrq4SZe.js +0 -550
  1214. package/dist/bundled-plugin-load-paths-PGID9xSk.js +0 -2
  1215. package/dist/bundled-plugin-load-paths-gO3UWVBf.js +0 -110
  1216. package/dist/call-4ZLbcShk.js +0 -3
  1217. package/dist/call-CnVwqvc-.js +0 -331
  1218. package/dist/call.runtime-P3tmnPlm.js +0 -2
  1219. package/dist/capability-cli-Dsf3kVxU.js +0 -1401
  1220. package/dist/catalog-provider-BbeVG9BX.js +0 -40
  1221. package/dist/catchup-DIWi6bFP.js +0 -300
  1222. package/dist/channel-Bd4WBT1e.js +0 -491
  1223. package/dist/channel-BjZJYYzo.js +0 -297
  1224. package/dist/channel-BxGYV6Zd.js +0 -840
  1225. package/dist/channel-CLQBCnlI.js +0 -350
  1226. package/dist/channel-CSWAj5aC.js +0 -226
  1227. package/dist/channel-CbZZjPYz.js +0 -1100
  1228. package/dist/channel-Cd2ZsgQ2.js +0 -453
  1229. package/dist/channel-CfyL5j9F.js +0 -595
  1230. package/dist/channel-Dblz16CA.js +0 -1174
  1231. package/dist/channel-Dklq7HwR.js +0 -1802
  1232. package/dist/channel-JMpXfym9.js +0 -1320
  1233. package/dist/channel-add-wizard-BZxYZDO9.js +0 -125
  1234. package/dist/channel-add-wizard-CaHT24zz.js +0 -2
  1235. package/dist/channel-core-5nOGNjtf.js +0 -5
  1236. package/dist/channel-doctor-BJW7bTGQ.js +0 -2
  1237. package/dist/channel-inbound-BWxr-ADn.js +0 -31
  1238. package/dist/channel-plugin-resolution-BPeYeZA8.js +0 -2
  1239. package/dist/channel-plugin-resolution-BlBNIB2a.js +0 -153
  1240. package/dist/channel-plugin-runtime-DbNUeRTy.js +0 -771
  1241. package/dist/channel-runtime-B3OHY6mP.js +0 -425
  1242. package/dist/channel-setup-Ds6mtf4v.js +0 -1297
  1243. package/dist/channel.runtime-BJpm5f_F.js +0 -109
  1244. package/dist/channel.runtime-Bj_EgjGh.js +0 -430
  1245. package/dist/channel.runtime-CQlCIZX3.js +0 -2364
  1246. package/dist/channel.runtime-M9ynpc3S.js +0 -34702
  1247. package/dist/channel.runtime-SFS4pZM1.js +0 -576
  1248. package/dist/channel.runtime-ZW6QViZZ.js +0 -4
  1249. package/dist/channel.runtime-_XulV4EX.js +0 -89
  1250. package/dist/channel.setup-WsdWwhwp.js +0 -10
  1251. package/dist/channels-DGKW1oDr.js +0 -733
  1252. package/dist/channels-cli-BlDYocQE.js +0 -268
  1253. package/dist/chat-Dw8GHjpf.js +0 -2830
  1254. package/dist/chrome-CpgPgeb8.js +0 -1181
  1255. package/dist/clawbot-cli-0H08qQ39.js +0 -9
  1256. package/dist/clawhub-B8vQZp2O.js +0 -400
  1257. package/dist/cli-BqWXkeUs.js +0 -72
  1258. package/dist/cli-DHl3RmiM.js +0 -2
  1259. package/dist/cli-DvG2clNo.js +0 -219
  1260. package/dist/cli-GgpzGzY-.js +0 -683
  1261. package/dist/cli-H3X3Abhi.js +0 -2
  1262. package/dist/cli-I_U18Zj7.js +0 -3726
  1263. package/dist/cli-N7s4V_Ac.js +0 -154
  1264. package/dist/cli-Q34b38_6.js +0 -2
  1265. package/dist/cli-runner-D87jhfwM.js +0 -286
  1266. package/dist/cli-runner.runtime-B53dwXf1.js +0 -4
  1267. package/dist/cli-runner.runtime-CXPtmCqJ.js +0 -3
  1268. package/dist/cli.runtime-DmBLxGrW.js +0 -1261
  1269. package/dist/client-Bm9vKmhX.js +0 -138
  1270. package/dist/client-CDLetywx.js +0 -713
  1271. package/dist/command-auth-CvC6ZhtG.js +0 -76
  1272. package/dist/command-config-resolution-Do83X_Bp.js +0 -23
  1273. package/dist/command-config-resolution-pVG6FoqP.js +0 -2
  1274. package/dist/command-config-resolution.runtime-kEVcfMZm.js +0 -2
  1275. package/dist/command-execution-startup-IAvWVwb_.js +0 -305
  1276. package/dist/command-registry-BdK4qesS.js +0 -9
  1277. package/dist/command-registry-ClR7_y_z.js +0 -4
  1278. package/dist/command-registry-core-B60OtQ9I.js +0 -101
  1279. package/dist/command-secret-gateway-CvREjM9H.js +0 -528
  1280. package/dist/command-status.runtime-3XmhZqmG.js +0 -87
  1281. package/dist/commands-acp-BYABMzhY.js +0 -77
  1282. package/dist/commands-compact.runtime-C3J3UER-.js +0 -10
  1283. package/dist/commands-core.runtime-DFdJh60s.js +0 -2
  1284. package/dist/commands-handlers.runtime-DCdcViLH.js +0 -4597
  1285. package/dist/commands-reset-hooks-DLnWb1Va.js +0 -133
  1286. package/dist/commands-status-CEF7Mp6D.js +0 -16
  1287. package/dist/commands-status.runtime-zP6s0nfh.js +0 -3
  1288. package/dist/commands-subagents-control.runtime-BSWumf8c.js +0 -2
  1289. package/dist/commands-subagents-control.runtime-Dy4sppYu.js +0 -3
  1290. package/dist/commands-system-prompt-BYonuxzQ.js +0 -158
  1291. package/dist/commands-system-prompt-C6TjY3rz.js +0 -2
  1292. package/dist/commands.runtime-DTd3pO4m.js +0 -166
  1293. package/dist/compact-DeHVeOYR.js +0 -1118
  1294. package/dist/compact.runtime-DO9qQwQU.js +0 -12
  1295. package/dist/completion-cli-Deus3b8-.js +0 -328
  1296. package/dist/config-Bw5Kew-v.js +0 -252
  1297. package/dist/config-cli-DFB3iuKb.js +0 -1078
  1298. package/dist/config-guard-t7jywPR-.js +0 -96
  1299. package/dist/config-runtime-Bt88vmOj.js +0 -32
  1300. package/dist/configure-CQIKpSbu.js +0 -1252
  1301. package/dist/configure-DOc4NeXh.js +0 -2
  1302. package/dist/connect-options-COnDbzRx.js +0 -699
  1303. package/dist/control-auth-Cn5YR5wo.js +0 -125
  1304. package/dist/control-service-BN9tjmGf.js +0 -156
  1305. package/dist/control-ui/assets/agents-CZUIyxEM.js +0 -1052
  1306. package/dist/control-ui/assets/canvas-Dm7T865D.js +0 -269
  1307. package/dist/control-ui/assets/channels-CiPvudJA.js +0 -463
  1308. package/dist/control-ui/assets/cron-B14-kw5R.js +0 -933
  1309. package/dist/control-ui/assets/debug-CmDZanup.js +0 -94
  1310. package/dist/control-ui/assets/index-DhGuBeJ2.js +0 -6359
  1311. package/dist/control-ui/assets/instances-VaZKj4g5.js +0 -57
  1312. package/dist/control-ui/assets/nodes-OYjiryo2.js +0 -436
  1313. package/dist/control-ui/assets/plugins-PP89PB4Q.js +0 -273
  1314. package/dist/control-ui/assets/sessions-i9hJdgF0.js +0 -306
  1315. package/dist/control-ui/assets/skills-BbUBXFNS.js +0 -323
  1316. package/dist/control-ui/assets/wallet-Olr48I33.js +0 -199
  1317. package/dist/control-ui-BJSryFYU.js +0 -1043
  1318. package/dist/conversation-id-DUC83-Xa.js +0 -235
  1319. package/dist/conversation-id-G--VoHRy.js +0 -38
  1320. package/dist/conversation-runtime-BgY9C2BO.js +0 -31
  1321. package/dist/core-v4f7bXWW.js +0 -275
  1322. package/dist/create-C26klqm6.js +0 -80
  1323. package/dist/cron-cli-nedGNJU0.js +0 -713
  1324. package/dist/daemon-cli-COmc1YwZ.js +0 -12
  1325. package/dist/daemon-install-BOPAEUyR.js +0 -64
  1326. package/dist/delegate-DEFh3qEB.js +0 -64
  1327. package/dist/deliver-BFyI54_G.js +0 -747
  1328. package/dist/deliver-CbT0UmtQ.js +0 -3
  1329. package/dist/deliver-runtime-DOskrGHp.js +0 -2
  1330. package/dist/delivery-outbound.runtime-CYJH20qm.js +0 -6
  1331. package/dist/delivery.runtime-Bc8givN7.js +0 -253
  1332. package/dist/detached-task-runtime-qIh7q5y5.js +0 -73
  1333. package/dist/devices-cli-CVodCsvr.js +0 -498
  1334. package/dist/diagnostic-support-export-8ChBfjDE.js +0 -533
  1335. package/dist/diagnostics-Bk94MOXQ.js +0 -154
  1336. package/dist/direct-dm-CHkFU7It.js +0 -64
  1337. package/dist/directive-handling.fast-lane-BS0-sUhG.js +0 -66
  1338. package/dist/directive-handling.impl-B1lfwgo8.js +0 -2
  1339. package/dist/directive-handling.impl-E4GHiSw4.js +0 -703
  1340. package/dist/directive-handling.model-selection-CbeBlSGR.js +0 -114
  1341. package/dist/directive-handling.persist.runtime-BbOq7k7q.js +0 -215
  1342. package/dist/directory-cli-APPOcabH.js +0 -240
  1343. package/dist/discovery-CWThCB8j.js +0 -2
  1344. package/dist/dispatch-BUIn3xT5.js +0 -1131
  1345. package/dist/dispatch-acp-CauXB0Yh.js +0 -981
  1346. package/dist/dispatch-acp-manager.runtime-B8MJ8ECj.js +0 -3
  1347. package/dist/dispatch-acp-media.runtime-B1Y3Y1XZ.js +0 -4
  1348. package/dist/dispatch-acp-session.runtime-DyC5raRj.js +0 -2
  1349. package/dist/dispatch-acp.runtime-vchRvLDX.js +0 -19
  1350. package/dist/doctor-auth-2TMwkvdZ.js +0 -172
  1351. package/dist/doctor-auth-legacy-oauth-BrYdrsbD.js +0 -2
  1352. package/dist/doctor-completion-8OcoxUsx.js +0 -2
  1353. package/dist/doctor-config-flow-WxpaZx3C.js +0 -420
  1354. package/dist/doctor-config-preflight-BaF4urE-.js +0 -63
  1355. package/dist/doctor-config-preflight-DZtMnKmU.js +0 -2
  1356. package/dist/doctor-cron-B2u67rGg.js +0 -678
  1357. package/dist/doctor-device-pairing-ChWlWNdm.js +0 -307
  1358. package/dist/doctor-gateway-daemon-flow-CSmhkG4A.js +0 -250
  1359. package/dist/doctor-gateway-health-DYiucwjE.js +0 -63
  1360. package/dist/doctor-gateway-services-D_PD0loN.js +0 -316
  1361. package/dist/doctor-health-BInF5NOz.js +0 -59
  1362. package/dist/doctor-health-contributions-C6TfTHDb.js +0 -493
  1363. package/dist/doctor-memory-search-Cg2YmLfu.js +0 -372
  1364. package/dist/doctor-prompter-DqkSAPwY.js +0 -56
  1365. package/dist/doctor-sandbox-BjgX5g3i.js +0 -194
  1366. package/dist/doctor-security-T7us9uYd.js +0 -210
  1367. package/dist/doctor-startup-channel-maintenance-64W6Pwei.js +0 -17
  1368. package/dist/doctor-state-migrations-C9RkcS_g.js +0 -2
  1369. package/dist/doctor-ui-zOuoVLme.js +0 -96
  1370. package/dist/doctor-update-sAD6RCVl.js +0 -58
  1371. package/dist/doctor-workspace-k-oOpOeQ.js +0 -2
  1372. package/dist/doctor-workspace-status-BAyT2p1j.js +0 -75
  1373. package/dist/dreaming-0_evepvy.js +0 -1574
  1374. package/dist/dreaming-narrative-BAEykAPD.js +0 -595
  1375. package/dist/embedded-gateway-stub.runtime-CQXHNoef.js +0 -9
  1376. package/dist/embedding-provider-D77jg3jO.js +0 -118
  1377. package/dist/embeddings-D-kGtEij.js +0 -215
  1378. package/dist/embeddings-http-CAfo13K3.js +0 -205
  1379. package/dist/empty-allowlist-scan-1Cp5AShv.js +0 -94
  1380. package/dist/empty-allowlist-scan-BI-ys6De.js +0 -2
  1381. package/dist/exec-approval-forwarder.runtime-maLuSa-B.js +0 -3
  1382. package/dist/exec-approvals-cli-BzYJkBAZ.js +0 -498
  1383. package/dist/exec-defaults-BT1qVb9h.js +0 -67
  1384. package/dist/exec-defaults-dNWVx7dc.js +0 -2
  1385. package/dist/exec-safe-bins--gFVDDdV.js +0 -2
  1386. package/dist/exec-safe-bins-eiLrQcAD.js +0 -148
  1387. package/dist/execute.runtime-DJzB1HB8.js +0 -1366
  1388. package/dist/fallbacks-BH4cdaV7.js +0 -2
  1389. package/dist/fallbacks-BSBpnXa4.js +0 -31
  1390. package/dist/fallbacks-shared-Clt3TsQ_.js +0 -111
  1391. package/dist/format-4zWzhU8Q.js +0 -245
  1392. package/dist/gateway-BGXRwNec.js +0 -115
  1393. package/dist/gateway-cli-CzwyLwg1.js +0 -1325
  1394. package/dist/gateway-discovery-targets-4C__L2V_.js +0 -42
  1395. package/dist/gateway-install-token-CDZxlaDX.js +0 -141
  1396. package/dist/gateway-rpc-BY3Oto7p.js +0 -14
  1397. package/dist/gateway-rpc.runtime-BXWIEwJ2.js +0 -23
  1398. package/dist/gateway-runtime-DRwUkgHW.js +0 -15
  1399. package/dist/gateway-status-BpWDiRPo.js +0 -584
  1400. package/dist/genesis-tools-C_polEcn.js +0 -9144
  1401. package/dist/genesis-tools.runtime-wlLaYkmW.js +0 -2
  1402. package/dist/get-reply-Djbscb0p.js +0 -3879
  1403. package/dist/get-reply-from-config.runtime-c_yymFNc.js +0 -2
  1404. package/dist/gmail-watcher-lifecycle-Be-CadK5.js +0 -191
  1405. package/dist/gmail-watcher-lifecycle-ggzxPr2v.js +0 -2
  1406. package/dist/graph-users-DGzo2oi0.js +0 -1337
  1407. package/dist/health-BOIX5Hyd.js +0 -469
  1408. package/dist/health-DgxS2kKr.js +0 -3
  1409. package/dist/health-style-BpmhVr6t.js +0 -2
  1410. package/dist/heartbeat-runner-CwIewAFM.js +0 -5
  1411. package/dist/heartbeat-runner-DZWvlc6O.js +0 -1292
  1412. package/dist/heartbeat-runner.runtime-Bvwexwm3.js +0 -4
  1413. package/dist/hooks-cli-B__N8nFC.js +0 -433
  1414. package/dist/hooks-status-BZmM-4uk.js +0 -86
  1415. package/dist/image-fallbacks-ARdMNyk9.js +0 -2
  1416. package/dist/image-fallbacks-B5f-IPre.js +0 -31
  1417. package/dist/image-generation-core-DdJI4glx.js +0 -18
  1418. package/dist/image-generation-provider-CnjSM2cp.js +0 -63
  1419. package/dist/image-generation-provider-DMDKtyjs.js +0 -157
  1420. package/dist/image-generation-provider-DSGaFXvB.js +0 -95
  1421. package/dist/image-generation-provider-DWLTDUWA.js +0 -228
  1422. package/dist/image-generation-provider-Dpt9Cxhe.js +0 -529
  1423. package/dist/image-generation-provider-SOqiP_8D.js +0 -274
  1424. package/dist/image-generation-provider-hTILgvEs.js +0 -137
  1425. package/dist/image-runtime-Cw6KnPyI.js +0 -9
  1426. package/dist/inbound-reply-dispatch-B3FKSrdM.js +0 -73
  1427. package/dist/inbound.runtime-BEVTM-H0.js +0 -3
  1428. package/dist/inbound.runtime-bre1AEdv.js +0 -4
  1429. package/dist/infra-runtime-D40sSUCf.js +0 -39
  1430. package/dist/init-D--934lj.js +0 -59
  1431. package/dist/install-BPmIu7Fr.js +0 -726
  1432. package/dist/install-BPzQAw9w.js +0 -190
  1433. package/dist/install-security-scan-BI9eIS4d.js +0 -26
  1434. package/dist/install-security-scan.runtime-CZdmIMiU.js +0 -671
  1435. package/dist/install.runtime-CzO5O86f.js +0 -27
  1436. package/dist/install.runtime-DSFCCJsH.js +0 -12
  1437. package/dist/install.runtime-MU60vpuj.js +0 -2
  1438. package/dist/jobs-BfZ4AGS3.js +0 -734
  1439. package/dist/legacy-tools-by-sender-Cob0vuXU.js +0 -2
  1440. package/dist/legacy-tools-by-sender-sXGvvdwZ.js +0 -95
  1441. package/dist/library-DJ6vMjlq.js +0 -45
  1442. package/dist/lifecycle-C4_KEIsv.js +0 -571
  1443. package/dist/lifecycle-DvgTG8pk.js +0 -229
  1444. package/dist/lifecycle.runtime-D1DCL-wO.js +0 -2
  1445. package/dist/list-BXLV65Gc.js +0 -1212
  1446. package/dist/list-Bso59rT0.js +0 -2
  1447. package/dist/list-C27fOWdB.js +0 -2
  1448. package/dist/list-_dDCEcd-.js +0 -131
  1449. package/dist/list.probe-7PH4qvJj.js +0 -419
  1450. package/dist/live-model-switch-Dzwoi72R.js +0 -336
  1451. package/dist/llm-slug-generator-63kdm2OR.js +0 -79
  1452. package/dist/load-config-C_aH0rca.js +0 -35
  1453. package/dist/loader-PS-t7z4_.js +0 -222
  1454. package/dist/local-dispatch.runtime-DB4L69Z-.js +0 -8
  1455. package/dist/login-BYQtsezq.js +0 -108
  1456. package/dist/logs-cli-D7lfZhM7.js +0 -265
  1457. package/dist/logs-cli.runtime-CFyJZr7R.js +0 -2
  1458. package/dist/main-session-restart-recovery-CN8gSmXd.js +0 -206
  1459. package/dist/managed-image-attachments-BHpzxWpi.js +0 -635
  1460. package/dist/managed-image-attachments-ynrnuzaN.js +0 -2
  1461. package/dist/manager-BHdBsJ-4.js +0 -2057
  1462. package/dist/manager-BbEguv55.js +0 -2
  1463. package/dist/markdown-to-line-CvZX649M.js +0 -790
  1464. package/dist/mcp-cli-Bm36vIZ8.js +0 -725
  1465. package/dist/mcp-http-BAkamHPJ.js +0 -529
  1466. package/dist/media-runtime-xDvelqeF.js +0 -329
  1467. package/dist/media-understanding-D2f1Sw5u.js +0 -85
  1468. package/dist/media-understanding-provider-B5zBHITx.js +0 -13
  1469. package/dist/media-understanding-provider-BF9f8Kc2.js +0 -12
  1470. package/dist/media-understanding-provider-BO0XCNzy.js +0 -28
  1471. package/dist/media-understanding-provider-Cvz4Q6U8.js +0 -18
  1472. package/dist/media-understanding-provider-DDAuhJ_N.js +0 -12
  1473. package/dist/media-understanding-provider-DrmrHvoA.js +0 -85
  1474. package/dist/media-understanding-provider-DvNmD55z.js +0 -18
  1475. package/dist/media-understanding-provider-LIShWYb1.js +0 -21
  1476. package/dist/media-understanding-provider-bTDblFEB.js +0 -37
  1477. package/dist/media-understanding-provider-zMirTfGH.js +0 -69
  1478. package/dist/media-understanding-runtime-D4TZ-fjJ.js +0 -2
  1479. package/dist/memory-core-host-runtime-cli-Km35Eu66.js +0 -9
  1480. package/dist/memory-embedding-adapter-LQFGssCg.js +0 -123
  1481. package/dist/memory-host-search-D37_7MYw.js +0 -12
  1482. package/dist/message-Dw1Q1vDW.js +0 -232
  1483. package/dist/message-action-runner-5i2YKy26.js +0 -1407
  1484. package/dist/message-action-runner-rouTQpow.js +0 -2
  1485. package/dist/message-actions-CIGFQT75.js +0 -143
  1486. package/dist/message-format-CKLFXoR1.js +0 -328
  1487. package/dist/message.gateway.runtime-CsFUD3Xo.js +0 -2
  1488. package/dist/model-picker-B4VYxzEq.js +0 -559
  1489. package/dist/model-picker-CDUdNkfe.js +0 -3
  1490. package/dist/model-picker.runtime-Vbq_0Nyf.js +0 -15
  1491. package/dist/model-selection-DP4Zcp8n.js +0 -213
  1492. package/dist/models-auth-status-D1KCepQd.js +0 -201
  1493. package/dist/models-cli-Btj5FdA8.js +0 -219
  1494. package/dist/models.fetch-kJPiR3kv.js +0 -518
  1495. package/dist/monitor-BtGV4rhd.js +0 -1237
  1496. package/dist/monitor-C_AtnL_B.js +0 -1459
  1497. package/dist/monitor-CzrunYzr.js +0 -788
  1498. package/dist/monitor-DVyns958.js +0 -671
  1499. package/dist/monitor-Dl3Dgkhr.js +0 -1661
  1500. package/dist/monitor-Dlvc68h5.js +0 -2
  1501. package/dist/monitor-auth-tgR858Ie.js +0 -207
  1502. package/dist/monitor-processing-vrwGp4ey.js +0 -1974
  1503. package/dist/monitor.runtime-4gL93IXG.js +0 -2
  1504. package/dist/monitor.webhook-BY6fnY01.js +0 -180
  1505. package/dist/msteams-C_BTrDSD.js +0 -35
  1506. package/dist/music-generation-provider-DS5qzKbp.js +0 -63
  1507. package/dist/music-generation-provider-ETSXorR4.js +0 -170
  1508. package/dist/native-hook-relay-BV_VTu1a.js +0 -519
  1509. package/dist/nextcloud-talk-DAV3h79e.js +0 -17
  1510. package/dist/node-cli-BMyfOX1d.js +0 -2506
  1511. package/dist/nodes-cli-C7o6W-57.js +0 -1046
  1512. package/dist/nodes-utils-CkcInlXX.js +0 -84
  1513. package/dist/nodes.helpers-DlttpHIF.js +0 -34
  1514. package/dist/notify-BPswoXqd.js +0 -315
  1515. package/dist/oauth-BMW6Uu6d.js +0 -152
  1516. package/dist/oauth-C57IxcVb.js +0 -139
  1517. package/dist/oauth-Cos3_Tm8.js +0 -2
  1518. package/dist/oauth-DLhqzpsA.js +0 -75
  1519. package/dist/oauth-tls-preflight-7onGTMCp.js +0 -2
  1520. package/dist/oauth.flow-B5sXe4f9.js +0 -45
  1521. package/dist/oauth.flow-C4SGDpVk.js +0 -3
  1522. package/dist/onboard-D2DJ5gYK.js +0 -632
  1523. package/dist/onboard-azFxOPDQ.js +0 -316
  1524. package/dist/onboard-channels-B_8hae58.js +0 -3
  1525. package/dist/onboard-channels-CYYkzN3n.js +0 -2
  1526. package/dist/onboard-config-Dkx9PDJF.js +0 -2
  1527. package/dist/onboard-custom-DBWwn7bA.js +0 -3
  1528. package/dist/onboard-custom-DqPCa9g_.js +0 -271
  1529. package/dist/onboard-helpers-9F1luARe.js +0 -204
  1530. package/dist/onboard-helpers-B35AFfng.js +0 -6
  1531. package/dist/onboard-hooks-scqbQ_0u.js +0 -52
  1532. package/dist/onboard-remote-3Yoz22Ua.js +0 -2
  1533. package/dist/onboard-remote-DJNTDiWN.js +0 -193
  1534. package/dist/onboard-search-88CSSNZj.js +0 -323
  1535. package/dist/onboard-skills-4FG47R9v.js +0 -2
  1536. package/dist/onboard-skills-DszLde1e.js +0 -134
  1537. package/dist/onboarding-plugin-install-R2Wv8ogP.js +0 -406
  1538. package/dist/open-policy-allowfrom-Bb8cflPm.js +0 -101
  1539. package/dist/open-policy-allowfrom-D6Pt5lcH.js +0 -2
  1540. package/dist/openai-codex-provider-Sn6gnpPy.js +0 -472
  1541. package/dist/openai-http-RiSW6RCL.js +0 -500
  1542. package/dist/openai-provider-C5WiV_oK.js +0 -313
  1543. package/dist/opencode-BEf3DHS_.js +0 -35
  1544. package/dist/openresponses-http-uihsQrWI.js +0 -1128
  1545. package/dist/operator-approvals-client-CVnzkwJp.js +0 -68
  1546. package/dist/outbound-runtime-C8CZBjjK.js +0 -5
  1547. package/dist/outbound.runtime-Bu1pCn2b.js +0 -2
  1548. package/dist/pair-command-approve-VnlhalEu.js +0 -44
  1549. package/dist/persistent-bindings.lifecycle-CkZa5ZSw.js +0 -85
  1550. package/dist/persistent-bindings.lifecycle-JneetERl.js +0 -2
  1551. package/dist/pi-embedded-4mJWzgw8.js +0 -4
  1552. package/dist/pi-embedded-Cbd5cHT-.js +0 -2905
  1553. package/dist/pi-embedded-subscribe.handlers.compaction.runtime-Cc6L30ZZ.js +0 -23
  1554. package/dist/pi-embedded.runtime-hOBxsSX2.js +0 -4
  1555. package/dist/pi-tool-definition-adapter-BQ6J-gI3.js +0 -217
  1556. package/dist/pi-tools-mrYKf_w5.js +0 -1057
  1557. package/dist/pi-tools.before-tool-call-Bcu1s6dd.js +0 -2
  1558. package/dist/pi-tools.before-tool-call-Bp_y436W.js +0 -433
  1559. package/dist/plugin-C0AG4DfO.js +0 -12195
  1560. package/dist/plugin-enabled-6QWARqV2.js +0 -140
  1561. package/dist/plugin-install-CNvOZufr.js +0 -115
  1562. package/dist/plugin-install-DQ_puPBW.js +0 -2
  1563. package/dist/plugin-install-config-policy-CrdLAK6J.js +0 -137
  1564. package/dist/plugin-install-plan-BlGsFyaK.js +0 -50
  1565. package/dist/plugin-registration-BOWb2A5S.js +0 -23
  1566. package/dist/plugin-registry-Dvz3pMfk.js +0 -3
  1567. package/dist/plugin-registry-WynVAGXW.js +0 -2
  1568. package/dist/plugin-service-CoZBvaKW.js +0 -2892
  1569. package/dist/plugins-cli-DYqIZxn-.js +0 -584
  1570. package/dist/plugins-command-helpers-B9R6gAMK.js +0 -107
  1571. package/dist/plugins-install-persist-B9psaQNp.js +0 -133
  1572. package/dist/plugins-update-command-n-54MoUJ.js +0 -1057
  1573. package/dist/policy-CGIs0Whl.js +0 -328
  1574. package/dist/prepare.runtime-GJ3FP8zv.js +0 -815
  1575. package/dist/preview-warnings-C1sLJw-y.js +0 -120
  1576. package/dist/probe-B0uel_53.js +0 -2
  1577. package/dist/probe-BMLDcZ32.js +0 -241
  1578. package/dist/probe-Bav-QtgY.js +0 -243
  1579. package/dist/probe-BiwA57vj.js +0 -74
  1580. package/dist/probe-Ci_3ht33.js +0 -2205
  1581. package/dist/probe-D8pMlDSU.js +0 -1443
  1582. package/dist/probe-DezLtnJj.js +0 -2
  1583. package/dist/probe-Dt1gxKms.js +0 -45
  1584. package/dist/probe-auth-DlhTwb46.js +0 -3
  1585. package/dist/program-S6C78I73.js +0 -111
  1586. package/dist/program-context-Ds8uJ5_0.js +0 -2
  1587. package/dist/prompt-select-styled-bIPy-fsG.js +0 -20
  1588. package/dist/protocol-C83jsm03.js +0 -2335
  1589. package/dist/provider-CwjDoVuI.js +0 -70
  1590. package/dist/provider-api-key-auth-DJsXnAsJ.js +0 -114
  1591. package/dist/provider-auth-5weS24pb.js +0 -46
  1592. package/dist/provider-auth-api-key-xONPO54i.js +0 -5
  1593. package/dist/provider-auth-choice-BU6Uu-NM.js +0 -228
  1594. package/dist/provider-auth-choice-preference-CjLBlWwT.js +0 -27
  1595. package/dist/provider-auth-choices-Cae9lEV6.js +0 -2
  1596. package/dist/provider-auth-guidance-2WFCZas6.js +0 -2
  1597. package/dist/provider-auth-login-Dx6MBNVR.js +0 -8
  1598. package/dist/provider-auth-login.runtime-DPU3bX7X.js +0 -267
  1599. package/dist/provider-dispatcher-C5E193P9.js +0 -22
  1600. package/dist/provider-dispatcher-DRpaBVoI.js +0 -2
  1601. package/dist/provider-entry-CMWmgrzY.js +0 -106
  1602. package/dist/provider-flow-B_lCjxh6.js +0 -148
  1603. package/dist/provider-install-catalog-CHnjnVn4.js +0 -108
  1604. package/dist/provider-model-defaults-6YyFItrt.js +0 -6
  1605. package/dist/provider-registration-Cz_Sa6aj.js +0 -218
  1606. package/dist/provider-registration-oDE3wvPW.js +0 -37
  1607. package/dist/proxy-cli-5dsD8slb.js +0 -44
  1608. package/dist/proxy-cli.runtime-DtOAaJyi.js +0 -372
  1609. package/dist/pw-ai-CuxAxPAK.js +0 -2511
  1610. package/dist/qr-cli-BGy1EdFR.js +0 -2
  1611. package/dist/qr-cli-D1N1qj4a.js +0 -349
  1612. package/dist/qr-image-CfoAOgi7.js +0 -2
  1613. package/dist/queue-SeTgQ4v1.js +0 -409
  1614. package/dist/reaction-runtime-api-CCX6OLTi.js +0 -116
  1615. package/dist/reactions-HriS4Lzd.js +0 -998
  1616. package/dist/read-capability-CugyApjs.js +0 -412
  1617. package/dist/register-service-commands-Bm3YW4mf.js +0 -71
  1618. package/dist/register.agent-C_sWjcmM.js +0 -248
  1619. package/dist/register.backup-D2H0YOM2.js +0 -64
  1620. package/dist/register.configure-CDV38g-s.js +0 -15
  1621. package/dist/register.maintenance-HM6XlAmr.js +0 -438
  1622. package/dist/register.message-CppmF8Fq.js +0 -329
  1623. package/dist/register.onboard-DVw5tTxy.js +0 -81
  1624. package/dist/register.runtime-Bv_g58Z3.js +0 -81
  1625. package/dist/register.setup-DrYBirHr.js +0 -150
  1626. package/dist/register.status-health-sessions-D_BlsslT.js +0 -1215
  1627. package/dist/register.subclis-B_mIsoj1.js +0 -29
  1628. package/dist/register.subclis-cEgJqD-F.js +0 -3
  1629. package/dist/register.subclis-core-9Vbv6pXL.js +0 -249
  1630. package/dist/register.wallet-B8SZqXvK.js +0 -159
  1631. package/dist/repair-sequencing-CHE8lZBR.js +0 -145
  1632. package/dist/reply-dispatch-runtime-D2iW6oyM.js +0 -13
  1633. package/dist/reply-media-paths.runtime-Cbeuxf6S.js +0 -2
  1634. package/dist/reply-media-paths.runtime-Ce0sUqmz.js +0 -146
  1635. package/dist/reply-runtime-DbZbTyRR.js +0 -11
  1636. package/dist/reply.runtime-HZt78rs1.js +0 -2
  1637. package/dist/resolve-cTAHXgZf.js +0 -259
  1638. package/dist/response-generator-I1Txyrne.js +0 -175
  1639. package/dist/restart-health-COnZzsKp.js +0 -202
  1640. package/dist/restart-health-eI6OqLsK.js +0 -2
  1641. package/dist/root-help-JJCwZUWN.js +0 -44
  1642. package/dist/route-reply-Ceh8EGzd.js +0 -162
  1643. package/dist/route-reply.runtime-CnrZS4em.js +0 -2
  1644. package/dist/routes-8SM2K3mV.js +0 -3341
  1645. package/dist/routes-CdA2B5Ih.js +0 -2
  1646. package/dist/rpc-BjIUGNvJ.js +0 -61
  1647. package/dist/rpc.runtime-DrJSFwsT.js +0 -21
  1648. package/dist/run-auth-profile.runtime-DWQ2cTlZ.js +0 -2
  1649. package/dist/run-delivery.runtime-r8f_tOSs.js +0 -530
  1650. package/dist/run-embedded.runtime-cWFV7jeB.js +0 -4
  1651. package/dist/run-execution-cli.runtime-Cb_A5ZXZ.js +0 -4
  1652. package/dist/run-executor.runtime-cIKt7XT8.js +0 -277
  1653. package/dist/run-main-Dkeo211Q.js +0 -516
  1654. package/dist/run-subagent-registry.runtime-D3RJ_VVd.js +0 -2
  1655. package/dist/run-wait-BNHvcVAx.js +0 -135
  1656. package/dist/runner-BYC9AI6n.js +0 -966
  1657. package/dist/runner.entries-RQHPJQlO.js +0 -604
  1658. package/dist/runtime-7KFT5Wnl.js +0 -263
  1659. package/dist/runtime-CAnPdqA9.js +0 -973
  1660. package/dist/runtime-JujtR8I6.js +0 -72
  1661. package/dist/runtime-PfHASyBB.js +0 -9
  1662. package/dist/runtime-ZRlD3E9S.js +0 -2
  1663. package/dist/runtime-api-BH3mTSpX.js +0 -9
  1664. package/dist/runtime-api-DWMVXYzi.js +0 -9
  1665. package/dist/runtime-api-ejyh_z6Z.js +0 -14
  1666. package/dist/runtime-api-m8CybWFK.js +0 -4
  1667. package/dist/runtime-embedded-pi.runtime-C-IVwtTs.js +0 -2
  1668. package/dist/runtime-entry-C05y9IWz.js +0 -2769
  1669. package/dist/runtime-fpqEiCAz.js +0 -116
  1670. package/dist/runtime-internal-Dfyi8iby.js +0 -2
  1671. package/dist/runtime-options-CL-8UQhL.js +0 -275
  1672. package/dist/runtime-prepare.runtime-CP3YZRq0.js +0 -80
  1673. package/dist/runtime-registry-loader-C03Ol6U_.js +0 -2
  1674. package/dist/runtime-schema-CQHEAWIe.js +0 -27796
  1675. package/dist/runtime-web-tools-DX1a8FUK.js +0 -1477
  1676. package/dist/sandbox-DjctEHje.js +0 -1156
  1677. package/dist/sandbox-F3gPY6yS.js +0 -3
  1678. package/dist/sandbox-cli-BSvKQdGK.js +0 -450
  1679. package/dist/scan-CLP9mf6Q.js +0 -523
  1680. package/dist/scan-D_J6FOI2.js +0 -2
  1681. package/dist/secrets-cli-DSSo4ZAV.js +0 -2101
  1682. package/dist/security-cli-BrgxYyHT.js +0 -486
  1683. package/dist/selection-BLnL3CIA.js +0 -7736
  1684. package/dist/selection-Bopczn8T.js +0 -2
  1685. package/dist/send-BKyU3kY5.js +0 -156
  1686. package/dist/send-BtiJkfWW.js +0 -102
  1687. package/dist/send.runtime-DF-vTxbI.js +0 -2
  1688. package/dist/server-BLWOFAVH.js +0 -13
  1689. package/dist/server-CcSf1M9y.js +0 -77
  1690. package/dist/server-context-9-okJgp8.js +0 -2
  1691. package/dist/server-context-BFPsolSM.js +0 -847
  1692. package/dist/server-node-events-9U-zD3f7.js +0 -481
  1693. package/dist/server-plugin-bootstrap-Br17f8OG.js +0 -11535
  1694. package/dist/server-plugin-bootstrap-v7VjtrnR.js +0 -2
  1695. package/dist/server-restart-sentinel-CRSWqLu5.js +0 -697
  1696. package/dist/server.impl-CUbtVPLf.js +0 -12822
  1697. package/dist/session-DAybdZjw.js +0 -48
  1698. package/dist/session-envelope-CiS8YBeP.js +0 -18
  1699. package/dist/session-key-D68MvGwI.js +0 -65
  1700. package/dist/session-kill-http-AYORP5Al.js +0 -110
  1701. package/dist/session-meta-DiXSQVi7.js +0 -109
  1702. package/dist/session-override-BSDJ8_ze.js +0 -106
  1703. package/dist/session-reset-model.runtime-DY4_Jb5l.js +0 -133
  1704. package/dist/session-reset-service-B8-SYOa3.js +0 -471
  1705. package/dist/session-route-DCD8YOOS.js +0 -93
  1706. package/dist/session-status.runtime-DT5nKTVP.js +0 -2
  1707. package/dist/session-store-DKe1sTca.js +0 -126
  1708. package/dist/session-store.runtime-BT09hrcf.js +0 -2
  1709. package/dist/session-subagent-reactivation.runtime-moOExxRG.js +0 -2
  1710. package/dist/session-tab-registry-6CK-3LZT.js +0 -581
  1711. package/dist/session-updates-BthqeByC.js +0 -236
  1712. package/dist/session-updates.runtime-DVIwMwM2.js +0 -2
  1713. package/dist/session-utils-D3S2x7za.js +0 -1006
  1714. package/dist/session-visibility-BOaiW8-B.js +0 -147
  1715. package/dist/sessions-CPxZnP4C.js +0 -2
  1716. package/dist/sessions-CRZaJLRB.js +0 -281
  1717. package/dist/sessions-CenAwEJA.js +0 -48
  1718. package/dist/sessions-helpers-D54klZ0N.js +0 -304
  1719. package/dist/sessions-history-http-CSvtpCvi.js +0 -383
  1720. package/dist/sessions-patch-B19xMHkL.js +0 -309
  1721. package/dist/sessions-q9vEmfIg.js +0 -16
  1722. package/dist/sessions-resolve-DVmdzrE3.js +0 -174
  1723. package/dist/sessions.runtime-B7jlBz2G.js +0 -2
  1724. package/dist/setup-CUfiTgI2.js +0 -421
  1725. package/dist/setup-D6ihayO1.js +0 -495
  1726. package/dist/setup-api-9s67oXlp.js +0 -29
  1727. package/dist/setup-core-C99fpLlr.js +0 -176
  1728. package/dist/setup-core-DaClXvq0.js +0 -171
  1729. package/dist/setup-surface-D525KEVY.js +0 -403
  1730. package/dist/setup-surface-Dp8-7oqb.js +0 -219
  1731. package/dist/setup-surface-MTokVtpC.js +0 -286
  1732. package/dist/setup.finalize-C-itcXZh.js +0 -539
  1733. package/dist/setup.gateway-config-CtF_uR41.js +0 -250
  1734. package/dist/shared-0_Njvu-4.js +0 -76
  1735. package/dist/shared-CINoi8DP.js +0 -121
  1736. package/dist/shared-CU_QI-su.js +0 -198
  1737. package/dist/shared-runtime-9k_uwoVc.js +0 -7
  1738. package/dist/shared-zk2nFjiQ.js +0 -217
  1739. package/dist/skill-commands-Lr9mozPh.js +0 -83
  1740. package/dist/skill-commands.runtime-Ccrr5sDP.js +0 -2
  1741. package/dist/skills-clawhub-CoxSpq-t.js +0 -275
  1742. package/dist/skills-cli-B1nEXYxf.js +0 -370
  1743. package/dist/skills-install-CEyr4Q-0.js +0 -605
  1744. package/dist/skills-snapshot.runtime-sRNT0SD9.js +0 -7
  1745. package/dist/slash-state-BuwOIYbQ.js +0 -1911
  1746. package/dist/speech-provider-9X-lk7rt.js +0 -209
  1747. package/dist/speech-provider-C-hGxBbz.js +0 -170
  1748. package/dist/speech-provider-D7FCMXvu.js +0 -216
  1749. package/dist/src-gxqtPkSN.js +0 -3974
  1750. package/dist/stage-sandbox-media.runtime-xcawVs24.js +0 -232
  1751. package/dist/stale-plugin-config-B8toKRW8.js +0 -103
  1752. package/dist/stale-plugin-config-DVSwZdEN.js +0 -2
  1753. package/dist/startup-context-D63-imDC.js +0 -312
  1754. package/dist/state-migrations-DSr9JHsF.js +0 -820
  1755. package/dist/status-9obFamZT.js +0 -190
  1756. package/dist/status-BLqb-tK5.js +0 -2
  1757. package/dist/status-Cj4HleBk.js +0 -3
  1758. package/dist/status-CrgOhrg3.js +0 -2
  1759. package/dist/status-Cv1wtqRZ.js +0 -62
  1760. package/dist/status-DJ8qQBGJ.js +0 -209
  1761. package/dist/status-KZK7NRWz.js +0 -397
  1762. package/dist/status-all-DC3fCVvo.js +0 -498
  1763. package/dist/status-json-Bjfa0-_5.js +0 -14
  1764. package/dist/status-json-command-C1RdwAgR.js +0 -84
  1765. package/dist/status-message-D7mxoFt4.js +0 -466
  1766. package/dist/status-message.runtime-dzziJRO-.js +0 -6
  1767. package/dist/status-queue.runtime-C10WJezD.js +0 -2
  1768. package/dist/status-runtime-shared-CeOsrR35.js +0 -257
  1769. package/dist/status-subagents.runtime-BMBErdMe.js +0 -18
  1770. package/dist/status-text-ByBEK9so.js +0 -237
  1771. package/dist/status.agent-local-BTmtArDP.js +0 -58
  1772. package/dist/status.command.text-runtime-DJ8gaett.js +0 -15
  1773. package/dist/status.gateway-connection.runtime-DkseUSEe.js +0 -2
  1774. package/dist/status.gateway-probe-DMp_6M2v.js +0 -16
  1775. package/dist/status.gather-BTPHTrHG.js +0 -2
  1776. package/dist/status.gather-DSIUKAm8.js +0 -292
  1777. package/dist/status.link-channel-F-n80oQz.js +0 -35
  1778. package/dist/status.node-mode-DsEoChD0.js +0 -32
  1779. package/dist/status.node-mode-GE_T0IDV.js +0 -2
  1780. package/dist/status.runtime-ivZORZbF.js +0 -2
  1781. package/dist/status.runtime-jws8sBty.js +0 -2
  1782. package/dist/status.scan-DauR-WY5.js +0 -65
  1783. package/dist/status.scan-overview-Dpo0T83_.js +0 -379
  1784. package/dist/status.scan.fast-json-Bf4asO-s.js +0 -2
  1785. package/dist/status.scan.fast-json-CmZ53rDy.js +0 -132
  1786. package/dist/status.scan.runtime-CD7rhB8Y.js +0 -409
  1787. package/dist/status.summary-BVBb43IU.js +0 -214
  1788. package/dist/status.summary-BsoP31Ak.js +0 -2
  1789. package/dist/status.update-CHdoxDYF.js +0 -2
  1790. package/dist/status.update-FoMyXtJt.js +0 -79
  1791. package/dist/store-t_e6UeQl.js +0 -910
  1792. package/dist/store-z-qNX5aX.js +0 -4
  1793. package/dist/store.runtime-DP2Pprik.js +0 -2
  1794. package/dist/stream-kpMWhVzc.js +0 -664
  1795. package/dist/subagent-announce-DuNuyqJY.js +0 -351
  1796. package/dist/subagent-announce-delivery-B4UiR8AX.js +0 -726
  1797. package/dist/subagent-announce-output-X7dAFWpV.js +0 -364
  1798. package/dist/subagent-capabilities-Br1FQ2Ar.js +0 -251
  1799. package/dist/subagent-control-CwADDJMF.js +0 -506
  1800. package/dist/subagent-control.runtime-CJp0aK6O.js +0 -3
  1801. package/dist/subagent-followup.runtime-DgCRHo-P.js +0 -68
  1802. package/dist/subagent-orphan-recovery-DPaND0LA.js +0 -305
  1803. package/dist/subagent-registry-BIAzu8LD.js +0 -1753
  1804. package/dist/subagent-registry-Z8SdU9lH.js +0 -3
  1805. package/dist/subagent-spawn-DIKeFu9r.js +0 -1005
  1806. package/dist/supervisor-BwVXGbW1.js +0 -704
  1807. package/dist/system-cli-O5gzFbKg.js +0 -59
  1808. package/dist/systemd-linger-CH5Ywx8A.js +0 -2
  1809. package/dist/target-id-DEEWnLPz.js +0 -107
  1810. package/dist/targets-BqOfjrX_.js +0 -67
  1811. package/dist/task-executor-BGncFMoh.js +0 -360
  1812. package/dist/task-owner-access-DQYVI-In.js +0 -74
  1813. package/dist/task-registry-8GSAuUDF.js +0 -2366
  1814. package/dist/task-registry-delivery-runtime-661R5b9C.js +0 -3
  1815. package/dist/task-registry-delivery-runtime-BCICoM3b.js +0 -2
  1816. package/dist/task-registry.maintenance-CPSvCCES.js +0 -416
  1817. package/dist/task-registry.maintenance-CYEycEiH.js +0 -2
  1818. package/dist/testing-BALbxnoY.js +0 -575
  1819. package/dist/text-report-C31JmnxT.js +0 -587
  1820. package/dist/tool-auth-shared-lOvNDLXS.js +0 -90
  1821. package/dist/tool-policy-pipeline-CSh3Mr8c.js +0 -109
  1822. package/dist/tool-resolution-BxjrmKBb.js +0 -90
  1823. package/dist/tools-effective-inventory-DGNt7lW2.js +0 -152
  1824. package/dist/tools-invoke-http-Dj-ReJVx.js +0 -206
  1825. package/dist/transcript-DK8bLOGQ.js +0 -312
  1826. package/dist/transcript-resolve.runtime-CCOPZ5SW.js +0 -2
  1827. package/dist/transcript.runtime-nYO6HglP.js +0 -2
  1828. package/dist/trash-CdL58JhS.js +0 -24
  1829. package/dist/tts-CpqgN8Lc.js +0 -64
  1830. package/dist/tui-cli-drmGvmS6.js +0 -4575
  1831. package/dist/uninstall-CYlyPrRR.js +0 -185
  1832. package/dist/update-YjxOXm5D.js +0 -1282
  1833. package/dist/update-cli-BfhENNCG.js +0 -1759
  1834. package/dist/update-runner-Dnc4hBQd.js +0 -1892
  1835. package/dist/update-startup-DSnY9P3k.js +0 -331
  1836. package/dist/update-startup-DnApgs_7.js +0 -2
  1837. package/dist/upgrade-DGTmkfQr.js +0 -1226
  1838. package/dist/video-generation-provider-24yLqnSZ.js +0 -254
  1839. package/dist/video-generation-provider-8j4PNLKE.js +0 -118
  1840. package/dist/video-generation-provider-DDwLRLiR.js +0 -187
  1841. package/dist/video-generation-provider-DGJe4N-c.js +0 -271
  1842. package/dist/video-generation-provider-DLMLF7z-2.js +0 -77
  1843. package/dist/video-generation-provider-D_T2R-Mh.js +0 -287
  1844. package/dist/video-generation-provider-DcNUjls_.js +0 -78
  1845. package/dist/video-generation-provider-Dl6j6XIE.js +0 -281
  1846. package/dist/video-generation-provider-DnVDR0yx.js +0 -221
  1847. package/dist/video-generation-provider-oE8-W2xN.js +0 -64
  1848. package/dist/video-generation-provider-weeKqmY-.js +0 -264
  1849. package/dist/video-generation-task-status-CQ9vf0P1.js +0 -163
  1850. package/dist/wait-for-idle-before-flush-XCTsu7bq.js +0 -5986
  1851. package/dist/web-search-provider-Cm90v9So.js +0 -163
  1852. package/dist/webhooks-cli-DbinLpWK.js +0 -321
  1853. package/dist/wizard-models-CYnCrGUS.js +0 -161
  1854. package/dist/workflow-runtime-DmHRkMvf.js +0 -485
  1855. /package/dist/{agent-list-vf9Q1JYA.js → agent-list-BG1HT1uV.js} +0 -0
  1856. /package/dist/{agents.bindings-Bem54JDr.js → agents.bindings-BsKwP-M1.js} +0 -0
  1857. /package/dist/{agents.config-Bf4IE_jt.js → agents.config-BcQjdDjt.js} +0 -0
  1858. /package/dist/{audit-channel.collect.runtime-4SDS3d6l.js → audit-channel.collect.runtime-Da2LJFzJ.js} +0 -0
  1859. /package/dist/{audit-tool-policy-DfW-Bg35.js → audit-tool-policy-Bp9Sm0oc.js} +0 -0
  1860. /package/dist/{auth-choice.apply.api-providers-Dr-BX6uo.js → auth-choice.apply.api-providers-nfkY6hL9.js} +0 -0
  1861. /package/dist/{auth-choice.plugin-providers.runtime-DJ50fpMo.js → auth-choice.plugin-providers.runtime-CKKBgy5E.js} +0 -0
  1862. /package/dist/{auth-surface-resolution-CPavr6ne.js → auth-surface-resolution-C5xRC0i_.js} +0 -0
  1863. /package/dist/{backup-verify-BBzQn06f.js → backup-verify-DeZBme1Z.js} +0 -0
  1864. /package/dist/{bonjour-discovery-BCuBu3eC.js → bonjour-discovery-DVp0CY5y.js} +0 -0
  1865. /package/dist/{browser-open-DJ4t4o6e.js → browser-open-BmFZAtQZ.js} +0 -0
  1866. /package/dist/{channel-account-context-CxskCBia.js → channel-account-context-08pGSfVf.js} +0 -0
  1867. /package/dist/{channel-capabilities-CGqnrmrr.js → channel-capabilities-bO3yWqgu.js} +0 -0
  1868. /package/dist/{channel-doctor-C29LMDyi.js → channel-doctor-DROap4LU.js} +0 -0
  1869. /package/dist/{channel-plugin-blockers-Db1JoUT3.js → channel-plugin-blockers-DS3H1CnV.js} +0 -0
  1870. /package/dist/{channel-selection.runtime-CFTt0ATQ.js → channel-selection.runtime-C8I-oIhj.js} +0 -0
  1871. /package/dist/{channels-status-issues-BvyaX7fu.js → channels-status-issues-DhD0yasL.js} +0 -0
  1872. /package/dist/{channels-table-DGrWByle.js → channels-table-CdaaJWDE.js} +0 -0
  1873. /package/dist/{close-reason-DPozo0RR.js → close-reason-DCEn5ZLO.js} +0 -0
  1874. /package/dist/{config-2LFRVjdy.js → config-DGZhYDuc.js} +0 -0
  1875. /package/dist/{config-mutation-state-DvELg9U3.js → config-mutation-state-4dXmSxXo.js} +0 -0
  1876. /package/dist/{config-validation-Gz3XLWkk.js → config-validation-Bx_ufkz3.js} +0 -0
  1877. /package/dist/{configured-DHBUKT37.js → configured-LOSXYOON.js} +0 -0
  1878. /package/dist/{control-ui-assets-Bn4WlmDz.js → control-ui-assets-_5qLV7Of.js} +0 -0
  1879. /package/dist/{coverage-BgPvdovz.js → coverage-BW7REo8f.js} +0 -0
  1880. /package/dist/{daemon-install-auth-profiles-source.runtime-1VDwhrxW.js → daemon-install-auth-profiles-source.runtime-CT6HhS4a.js} +0 -0
  1881. /package/dist/{daemon-install-auth-profiles-store.runtime-DX6klKlD.js → daemon-install-auth-profiles-store.runtime-Bmt-S1Th.js} +0 -0
  1882. /package/dist/{delivery-logger.runtime-QED0YWeh.js → delivery-logger.runtime-aZc6eYH6.js} +0 -0
  1883. /package/dist/{delivery-subagent-registry.runtime-BzWcJLcF.js → delivery-subagent-registry.runtime-DbsJlOPs.js} +0 -0
  1884. /package/dist/{delivery-target.runtime-MCOBBchX.js → delivery-target.runtime-CJ2AFZQF.js} +0 -0
  1885. /package/dist/{discovery-DGW2-MLa.js → discovery-CrxVb47K.js} +0 -0
  1886. /package/dist/{doctor-auth-legacy-oauth-BV7C6Vfj.js → doctor-auth-legacy-oauth-CQ-450U8.js} +0 -0
  1887. /package/dist/{doctor-bootstrap-size-PW5cPiSq.js → doctor-bootstrap-size-DFMO-0_2.js} +0 -0
  1888. /package/dist/{doctor-browser-DcQUu327.js → doctor-browser-DAmWk-ym.js} +0 -0
  1889. /package/dist/{doctor-bundled-plugin-runtime-deps-D1esrgeQ.js → doctor-bundled-plugin-runtime-deps-DL8egd0z.js} +0 -0
  1890. /package/dist/{doctor-claude-cli-B4BZv-kG.js → doctor-claude-cli-D8n8fZH1.js} +0 -0
  1891. /package/dist/{doctor-completion-WKgtPjbK.js → doctor-completion-DlF2_ta4.js} +0 -0
  1892. /package/dist/{doctor-config-analysis-BQdKpP5K.js → doctor-config-analysis-G4qApgNB.js} +0 -0
  1893. /package/dist/{doctor-install-DmjLfve4.js → doctor-install-BMLurFXg.js} +0 -0
  1894. /package/dist/{doctor-platform-notes-R_SxZdMz.js → doctor-platform-notes-DclB4xTp.js} +0 -0
  1895. /package/dist/{doctor-plugin-manifests-CA7lPt_x.js → doctor-plugin-manifests-Df-R6NRK.js} +0 -0
  1896. /package/dist/{doctor-repair-mode-DUDOaIhC.js → doctor-repair-mode-DjA0yOsO.js} +0 -0
  1897. /package/dist/{doctor-session-locks-Dx6vj6mm.js → doctor-session-locks-nnNg0XQt.js} +0 -0
  1898. /package/dist/{doctor-state-integrity-BQo15whd.js → doctor-state-integrity-mZ-atajo.js} +0 -0
  1899. /package/dist/{doctor-workspace-BIyTt_M_.js → doctor-workspace-CC8n4W1s.js} +0 -0
  1900. /package/dist/{gateway-lock-BaykvnC-.js → gateway-lock-BJ54teSG.js} +0 -0
  1901. /package/dist/{gateway-presence-Dut8sl-J.js → gateway-presence-Ck83hwdf.js} +0 -0
  1902. /package/dist/{gmail-setup-utils-ZOTbsJFv.js → gmail-setup-utils-CJA4K3ai.js} +0 -0
  1903. /package/dist/{health-format-B2qc32Pr.js → health-format-lZouXkHr.js} +0 -0
  1904. /package/dist/{health-style-BbCs1Yab.js → health-style-L-8YpdOF.js} +0 -0
  1905. /package/dist/{help-CwxpeDY5.js → help-B0u4yzRF.js} +0 -0
  1906. /package/dist/{helpers-LcBHwWZc.js → helpers-_-TEHOc6.js} +0 -0
  1907. /package/dist/{http-endpoint-helpers-BNftqeoQ.js → http-endpoint-helpers-C9HFCAZ9.js} +0 -0
  1908. /package/dist/{image-CAZ8XAQL.js → image-B6bNXdin.js} +0 -0
  1909. /package/dist/{image-generation-core.auth.runtime-0Qo_H5K_.js → image-generation-core.auth.runtime-B9u67AkK.js} +0 -0
  1910. /package/dist/{includes-scan-DoynIeya.js → includes-scan-C2pgYVb9.js} +0 -0
  1911. /package/dist/{input-allowlist-c0bB2eKy.js → input-allowlist-BOaar9sV.js} +0 -0
  1912. /package/dist/{install-package-dir-DPpzkcTy.js → install-package-dir-DBuZueA5.js} +0 -0
  1913. /package/dist/{install-target-DVcgbidG.js → install-target-CIbvCu-L.js} +0 -0
  1914. /package/dist/{ipv4-DMxATcV1.js → ipv4-x_VPPHNE.js} +0 -0
  1915. /package/dist/{lifecycle-startup-gLhpfLB7.js → lifecycle-startup-irALz7cL.js} +0 -0
  1916. /package/dist/{log-tail-9Hz1lmAo.js → log-tail-X0OPkkt2.js} +0 -0
  1917. /package/dist/{memory-host-search.runtime-HNAskOxX.js → memory-host-search.runtime-DDlULx33.js} +0 -0
  1918. /package/dist/{message.config.runtime-Cso6MvT8.js → message.config.runtime-Cn6_nzb5.js} +0 -0
  1919. /package/dist/{models-http-x7qxTDsp.js → models-http-C485AWr-.js} +0 -0
  1920. /package/dist/{node-service-BJUuDPKK.js → node-service-DoJ8Y9pv.js} +0 -0
  1921. /package/dist/{object-PDLz41ub.js → object-Bx7kd36S.js} +0 -0
  1922. /package/dist/{onboard-config-izAl6gwz.js → onboard-config-CqQvgsYa.js} +0 -0
  1923. /package/dist/{onboard-core-auth-flags-BMxne6w7.js → onboard-core-auth-flags-__K0sJjJ.js} +0 -0
  1924. /package/dist/{onboard-custom-config-3QJEWGL0.js → onboard-custom-config-BWwqk5fe.js} +0 -0
  1925. /package/dist/{package-update-utils-DE_n1gKX.js → package-update-utils-CCxatoo6.js} +0 -0
  1926. /package/dist/{pairing-cli-d6AhyJBm.js → pairing-cli-D-FUyZEV.js} +0 -0
  1927. /package/dist/{parse-log-line-LslQCpUT.js → parse-log-line-DoA9bQrQ.js} +0 -0
  1928. /package/dist/{paths-Cg-jfcZN.js → paths-BJ5uczC1.js} +0 -0
  1929. /package/dist/{ports-Ce2qG4x8.js → ports-CC9fm-fy.js} +0 -0
  1930. /package/dist/{probe-auth-Bn7VL9ZR.js → probe-auth-DFrZGBYH.js} +0 -0
  1931. /package/dist/{probe-target-BSlPhDks.js → probe-target-Chki0Xkk.js} +0 -0
  1932. /package/dist/{program-context-Kgd1rM3u.js → program-context-zMhdBPNy.js} +0 -0
  1933. /package/dist/{provider-api-key-auth.runtime-VgQwNphE.js → provider-api-key-auth.runtime-BmxvYpks.js} +0 -0
  1934. /package/dist/{provider-auth-choices-BCbf2yRh.js → provider-auth-choices-BB5yTDNn.js} +0 -0
  1935. /package/dist/{provider-auth-guidance-BWdK-ykC.js → provider-auth-guidance-CP_5xA8Y.js} +0 -0
  1936. /package/dist/{provider-openai-codex-oauth-tls-DtZu90G7.js → provider-openai-codex-oauth-tls-DerZ1cTV.js} +0 -0
  1937. /package/dist/{push-apns-BciQnS_A.js → push-apns-BvvTQGNo.js} +0 -0
  1938. /package/dist/{read-best-effort-config.runtime-qVYHl7Xo.js → read-best-effort-config.runtime-C5T0K31f.js} +0 -0
  1939. /package/dist/{root-help-metadata-ekl-JjpR.js → root-help-metadata-DfEC0ws2.js} +0 -0
  1940. /package/dist/{run-context.runtime-4WGT7JBj.js → run-context.runtime-QbU7trk9.js} +0 -0
  1941. /package/dist/{run-external-content.runtime-D3JPvjLm.js → run-external-content.runtime-pkNsrLtO.js} +0 -0
  1942. /package/dist/{run-id-R6ObHP3v.js → run-id-DWJ95pBN.js} +0 -0
  1943. /package/dist/{run-model-catalog.runtime-BggglNcs.js → run-model-catalog.runtime-CAcKERDC.js} +0 -0
  1944. /package/dist/{run-session-state-BaNj_GaS.js → run-session-state-XlO-wc3A.js} +0 -0
  1945. /package/dist/{runtime-manifest.runtime-Ddvsb5G5.js → runtime-manifest.runtime-DHHRd6iG.js} +0 -0
  1946. /package/dist/{runtime-registry-loader-9HAwLW0h.js → runtime-registry-loader-Bzjy_HHi.js} +0 -0
  1947. /package/dist/{runtime-web-channel-plugin-DVDCKmzx.js → runtime-web-channel-plugin-Dl8enKc3.js} +0 -0
  1948. /package/dist/{runtime-web-tools-fallback.runtime-Brdq0-xZ.js → runtime-web-tools-fallback.runtime-BCaVKJOn.js} +0 -0
  1949. /package/dist/{runtime-web-tools-manifest.runtime-BRmjTDGh.js → runtime-web-tools-manifest.runtime-3ureBtOs.js} +0 -0
  1950. /package/dist/{runtime-web-tools-public-artifacts.runtime-DsVQgFR8.js → runtime-web-tools-public-artifacts.runtime-7kYkuMoy.js} +0 -0
  1951. /package/dist/{schedule-ZSZnEiFe.js → schedule-Beb3GOcH.js} +0 -0
  1952. /package/dist/{server-startup-log-Eplhdcpt.js → server-startup-log-VzrHGqrP.js} +0 -0
  1953. /package/dist/{server-startup-memory-DyQIirmI.js → server-startup-memory-C5BZZa9k.js} +0 -0
  1954. /package/dist/{server-tailscale-DgAyhovj.js → server-tailscale-DpU6qzPY.js} +0 -0
  1955. /package/dist/{service-CO5U35OJ.js → service-BTZwpGci.js} +0 -0
  1956. /package/dist/{services-DNIJn8xg.js → services-BeY15lKe.js} +0 -0
  1957. /package/dist/{session-archive.runtime-rUFw8vE3.js → session-archive.runtime-kZWDRugt.js} +0 -0
  1958. /package/dist/{setup-launch-env-DCjAfCDq.js → setup-launch-env-CgNfSFCy.js} +0 -0
  1959. /package/dist/{setup.plugin-config-DyOBe14m.js → setup.plugin-config-EEmTDTvp.js} +0 -0
  1960. /package/dist/{setup.secret-input-Drr2LKMe.js → setup.secret-input-DnGWpeX9.js} +0 -0
  1961. /package/dist/{skill-scanner-B4yjTBTL.js → skill-scanner-CTCiX7W7.js} +0 -0
  1962. /package/dist/{ssh-config-QI5SlOa1.js → ssh-config-dpF9FXUa.js} +0 -0
  1963. /package/dist/{status-D3Yk4ckb.js → status-BmXT7hzH.js} +0 -0
  1964. /package/dist/{status.format-bwV75oQh.js → status.format-D83pj6zB.js} +0 -0
  1965. /package/dist/{status.gateway-connection-B0HsKKf1.js → status.gateway-connection-Dni-CXUg.js} +0 -0
  1966. /package/dist/{status.scan.deps.runtime-inl0xzZH.js → status.scan.deps.runtime-DyhPcxBc.js} +0 -0
  1967. /package/dist/{subagent-followup-hints-rwiRTQ4_.js → subagent-followup-hints-DCvZ8pkz.js} +0 -0
  1968. /package/dist/{supervisor-log.runtime-gvNK9Wct.js → supervisor-log.runtime-B9_WwWul.js} +0 -0
  1969. /package/dist/{systemd-linger-BH3QL_N0.js → systemd-linger-D0Pquvmk.js} +0 -0
  1970. /package/dist/{targets.runtime-BWbu7FiA.js → targets.runtime-CfoMqGAv.js} +0 -0
  1971. /package/dist/{task-registry.audit.shared-B9InRDQ7.js → task-registry.audit.shared-WSawIHtV.js} +0 -0
  1972. /package/dist/{text-format-J_bO4oMX.js → text-format-Ck1rxlbh.js} +0 -0
  1973. /package/dist/{types-cKnUNBos.js → types-CFl4vCLB.js} +0 -0
  1974. /package/dist/{update-check-BOB550De.js → update-check-BErCzWUb.js} +0 -0
  1975. /package/dist/{workspace-D6DmbfYx.js → workspace-NJH7qx4x.js} +0 -0
@@ -0,0 +1,2364 @@
1
+ import { i as formatErrorMessage } from "./errors-Jbvi20TW.js";
2
+ import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString } from "./string-coerce-C1IzJjqi.js";
3
+ import { d as resolveThreadSessionKeys$1 } from "./session-key-EpIbK3Oz.js";
4
+ import { i as parseStrictPositiveInteger } from "./parse-finite-number-De8ORAh1.js";
5
+ import { n as safeParseWithSchema, t as safeParseJsonWithSchema } from "./zod-parse-DQfbYHdH.js";
6
+ import { t as rawDataToString } from "./ws-VGsesElb.js";
7
+ import { d as resolveDebugProxySettings, n as captureWsEvent, u as createDebugProxyWebSocketAgent } from "./runtime-DstRtL8d.js";
8
+ import { n as fetchWithSsrFGuard } from "./fetch-guard-DKzLBD09.js";
9
+ import { u as isReasoningReplyPayload } from "./reply-payload-ChFsXpe2.js";
10
+ import "./text-runtime-_RVT_Gf-.js";
11
+ import "./core-CewPep95.js";
12
+ import "./routing-DQjoINBR.js";
13
+ import "./error-runtime-BFUKL2SO.js";
14
+ import { i as formatInboundFromLabel$1 } from "./envelope-BEJocK3D.js";
15
+ import { n as resolveControlCommandGate } from "./command-gating-DK3daq-x.js";
16
+ import { a as warnMissingProviderGroupPolicyFallbackOnce, n as resolveAllowlistProviderRuntimeGroupPolicy, r as resolveDefaultGroupPolicy } from "./runtime-group-policy-xUD2PMwD.js";
17
+ import { n as isDangerousNameMatchingEnabled } from "./dangerous-name-matching-DuglfWYZ.js";
18
+ import { n as readStoreAllowFromForDmPolicy, o as resolveDmGroupAccessWithLists, t as DM_GROUP_ACCESS_REASON } from "./dm-policy-shared-DbEcnLNK.js";
19
+ import { a as buildPendingHistoryContextFromMap, s as clearHistoryEntriesIfEnabled, u as recordPendingHistoryEntryIfEnabled } from "./history-Bq3OQ5PP.js";
20
+ import { n as logInboundDrop, r as logTypingFailure } from "./logging-BxvkluBF.js";
21
+ import { t as resolveChannelMediaMaxBytes } from "./media-limits-q5Hb_t71.js";
22
+ import { t as createChannelReplyPipeline } from "./channel-reply-pipeline-DSzkaJZ6.js";
23
+ import { n as createChannelPairingController } from "./channel-pairing-BYxDuhqX.js";
24
+ import { t as registerPluginHttpRoute } from "./http-registry-CwrsuvhF.js";
25
+ import "./proxy-capture-Dburkius.js";
26
+ import { t as buildAgentMediaPayload } from "./agent-media-payload-DyKKu0nf.js";
27
+ import { f as ssrfPolicyFromPrivateNetworkOptIn, o as isPrivateNetworkOptInEnabled } from "./ssrf-policy-BEXYawGN.js";
28
+ import "./ssrf-runtime-D5AIIK7K.js";
29
+ import "./browser-node-runtime-DIn0vNQP.js";
30
+ import { t as listSkillCommandsForAgents } from "./skill-commands-X1nUEOXX.js";
31
+ import { t as buildModelsProviderData } from "./commands-models-D_SvBnRz.js";
32
+ import "./extension-shared-aYdE8X8M.js";
33
+ import "./channel-inbound-6EfM36fi.js";
34
+ import { i as createFinalizableDraftLifecycle, l as deliverFinalizableDraftPreview } from "./channel-lifecycle-DdkKfO4h.js";
35
+ import { t as createClaimableDedupe } from "./persistent-dedupe-DHyhSBC8.js";
36
+ import { t as zod_exports } from "./zod-wD6cuybd.js";
37
+ import { n as isMattermostSenderAllowed, r as normalizeMattermostAllowList, t as authorizeMattermostCommandInvocation } from "./monitor-auth-eDhrUf09.js";
38
+ import { _ as readMattermostError, a as MattermostPostSchema, c as createMattermostPost, f as fetchMattermostMe, g as normalizeMattermostBaseUrl, h as fetchMattermostUserTeams, i as resolveMattermostReplyToMode, l as deleteMattermostPost, o as createMattermostClient, p as fetchMattermostUser, r as resolveMattermostAccount, t as listMattermostAccountIds, u as fetchMattermostChannel, v as sendMattermostTyping, y as updateMattermostPost } from "./accounts-DPKnV5R1.js";
39
+ import { t as getMattermostRuntime } from "./runtime-DiVYCyXK.js";
40
+ import { C as resolveCallbackUrl, S as registerSlashCommands, _ as renderMattermostProviderPickerView, a as sendMessageMattermost, b as cleanupSlashCommands, c as computeInteractionCallbackUrl, d as setInteractionCallbackUrl, f as setInteractionSecret, g as renderMattermostModelsPickerView, h as parseMattermostModelPickerContext, l as createMattermostInteractionHandler, m as buildMattermostAllowedModelRefs, n as deactivateSlashCommands, o as resolveMattermostOpaqueTarget, p as deliverMattermostReplyPayload, r as getSlashCommandState, s as buildButtonProps, t as activateSlashCommands, u as resolveInteractionCallbackPath, v as resolveMattermostModelPickerCurrentModel, w as resolveSlashCommandConfig, x as isSlashCommandsEnabled, y as DEFAULT_COMMAND_SPECS } from "./slash-state-C4SKy5al.js";
41
+ import { randomUUID } from "node:crypto";
42
+ import WebSocket from "ws";
43
+ //#region extensions/mattermost/src/mattermost/directory.ts
44
+ function buildClient(params) {
45
+ const account = resolveMattermostAccount({
46
+ cfg: params.cfg,
47
+ accountId: params.accountId
48
+ });
49
+ if (!account.enabled || !account.botToken || !account.baseUrl) return null;
50
+ return createMattermostClient({
51
+ baseUrl: account.baseUrl,
52
+ botToken: account.botToken,
53
+ allowPrivateNetwork: isPrivateNetworkOptInEnabled(account.config)
54
+ });
55
+ }
56
+ /**
57
+ * Build clients from ALL enabled accounts (deduplicated by token).
58
+ *
59
+ * We always scan every account because:
60
+ * - Private channels are only visible to bots that are members
61
+ * - The requesting agent's account may have an expired/invalid token
62
+ *
63
+ * This means a single healthy bot token is enough for directory discovery.
64
+ */
65
+ function buildClients(params) {
66
+ const accountIds = listMattermostAccountIds(params.cfg);
67
+ const seen = /* @__PURE__ */ new Set();
68
+ const clients = [];
69
+ for (const id of accountIds) {
70
+ const client = buildClient({
71
+ cfg: params.cfg,
72
+ accountId: id
73
+ });
74
+ if (client && !seen.has(client.token)) {
75
+ seen.add(client.token);
76
+ clients.push(client);
77
+ }
78
+ }
79
+ return clients;
80
+ }
81
+ /**
82
+ * List channels (public + private) visible to any configured bot account.
83
+ *
84
+ * NOTE: Uses per_page=200 which covers most instances. Mattermost does not
85
+ * return a "has more" indicator, so very large instances (200+ channels per bot)
86
+ * may see incomplete results. Pagination can be added if needed.
87
+ */
88
+ async function listMattermostDirectoryGroups(params) {
89
+ const clients = buildClients(params);
90
+ if (!clients.length) return [];
91
+ const q = normalizeLowercaseStringOrEmpty(params.query);
92
+ const seenIds = /* @__PURE__ */ new Set();
93
+ const entries = [];
94
+ for (const client of clients) try {
95
+ const me = await fetchMattermostMe(client);
96
+ const channels = await client.request(`/users/${me.id}/channels?per_page=200`);
97
+ for (const ch of channels) {
98
+ if (ch.type !== "O" && ch.type !== "P") continue;
99
+ if (seenIds.has(ch.id)) continue;
100
+ if (q) {
101
+ const name = normalizeLowercaseStringOrEmpty(ch.name);
102
+ const display = normalizeLowercaseStringOrEmpty(ch.display_name);
103
+ if (!name.includes(q) && !display.includes(q)) continue;
104
+ }
105
+ seenIds.add(ch.id);
106
+ entries.push({
107
+ kind: "group",
108
+ id: `channel:${ch.id}`,
109
+ name: ch.name ?? void 0,
110
+ handle: ch.display_name ?? void 0
111
+ });
112
+ }
113
+ } catch (err) {
114
+ console.debug?.("[mattermost-directory] listGroups: skipping account:", err?.message);
115
+ continue;
116
+ }
117
+ return params.limit && params.limit > 0 ? entries.slice(0, params.limit) : entries;
118
+ }
119
+ /**
120
+ * List team members as peer directory entries.
121
+ *
122
+ * Uses only the first available client since all bots in a team see the same
123
+ * user list (unlike channels where membership varies). Uses the first team
124
+ * returned — multi-team setups will only see members from that team.
125
+ *
126
+ * NOTE: per_page=200 for member listing; same pagination caveat as groups.
127
+ */
128
+ async function listMattermostDirectoryPeers(params) {
129
+ const clients = buildClients(params);
130
+ if (!clients.length) return [];
131
+ const client = clients[0];
132
+ try {
133
+ const me = await fetchMattermostMe(client);
134
+ const teams = await client.request("/users/me/teams");
135
+ if (!teams.length) return [];
136
+ const teamId = teams[0].id;
137
+ const q = normalizeLowercaseStringOrEmpty(params.query);
138
+ let users;
139
+ if (q) users = await client.request("/users/search", {
140
+ method: "POST",
141
+ body: JSON.stringify({
142
+ term: q,
143
+ team_id: teamId
144
+ })
145
+ });
146
+ else {
147
+ const userIds = (await client.request(`/teams/${teamId}/members?per_page=200`)).map((m) => m.user_id).filter((id) => id !== me.id);
148
+ if (!userIds.length) return [];
149
+ users = await client.request("/users/ids", {
150
+ method: "POST",
151
+ body: JSON.stringify(userIds)
152
+ });
153
+ }
154
+ const entries = users.filter((u) => u.id !== me.id).map((u) => ({
155
+ kind: "user",
156
+ id: `user:${u.id}`,
157
+ name: u.username ?? void 0,
158
+ handle: [u.first_name, u.last_name].filter(Boolean).join(" ").trim() || u.nickname || void 0
159
+ }));
160
+ return params.limit && params.limit > 0 ? entries.slice(0, params.limit) : entries;
161
+ } catch (err) {
162
+ console.debug?.("[mattermost-directory] listPeers failed:", err?.message);
163
+ return [];
164
+ }
165
+ }
166
+ //#endregion
167
+ //#region extensions/mattermost/src/mattermost/draft-stream.ts
168
+ const MATTERMOST_STREAM_MAX_CHARS = 4e3;
169
+ const DEFAULT_THROTTLE_MS = 1e3;
170
+ function normalizeMattermostDraftText(text, maxChars) {
171
+ const trimmed = text.trim();
172
+ if (!trimmed) return "";
173
+ if (trimmed.length <= maxChars) return trimmed;
174
+ return `${trimmed.slice(0, Math.max(0, maxChars - 3)).trimEnd()}...`;
175
+ }
176
+ function buildMattermostToolStatusText(params) {
177
+ return `Running${params.name?.trim() ? ` \`${params.name.trim()}\`` : " tool"}…`;
178
+ }
179
+ function createMattermostDraftStream(params) {
180
+ const maxChars = Math.min(params.maxChars ?? MATTERMOST_STREAM_MAX_CHARS, MATTERMOST_STREAM_MAX_CHARS);
181
+ const throttleMs = Math.max(250, params.throttleMs ?? DEFAULT_THROTTLE_MS);
182
+ const streamState = {
183
+ stopped: false,
184
+ final: false
185
+ };
186
+ let streamPostId;
187
+ let lastSentText = "";
188
+ const sendOrEditStreamMessage = async (text) => {
189
+ if (streamState.stopped && !streamState.final) return false;
190
+ const normalized = normalizeMattermostDraftText(params.renderText?.(text) ?? text, maxChars);
191
+ if (!normalized) return false;
192
+ if (normalized === lastSentText) return true;
193
+ try {
194
+ if (streamPostId) await updateMattermostPost(params.client, streamPostId, { message: normalized });
195
+ else {
196
+ const postId = (await createMattermostPost(params.client, {
197
+ channelId: params.channelId,
198
+ message: normalized,
199
+ rootId: params.rootId
200
+ })).id?.trim();
201
+ if (!postId) {
202
+ streamState.stopped = true;
203
+ params.warn?.("mattermost stream preview stopped (missing post id from create)");
204
+ return false;
205
+ }
206
+ streamPostId = postId;
207
+ }
208
+ lastSentText = normalized;
209
+ return true;
210
+ } catch (err) {
211
+ streamState.stopped = true;
212
+ params.warn?.(`mattermost stream preview failed: ${err instanceof Error ? err.message : String(err)}`);
213
+ return false;
214
+ }
215
+ };
216
+ const { loop, update, stop, clear, discardPending, seal } = createFinalizableDraftLifecycle({
217
+ throttleMs,
218
+ state: streamState,
219
+ sendOrEditStreamMessage,
220
+ readMessageId: () => streamPostId,
221
+ clearMessageId: () => {
222
+ streamPostId = void 0;
223
+ },
224
+ isValidMessageId: (value) => typeof value === "string" && value.length > 0,
225
+ deleteMessage: async (postId) => {
226
+ await deleteMattermostPost(params.client, postId);
227
+ },
228
+ warn: params.warn,
229
+ warnPrefix: "mattermost stream preview cleanup failed"
230
+ });
231
+ const forceNewMessage = () => {
232
+ streamPostId = void 0;
233
+ lastSentText = "";
234
+ loop.resetPending();
235
+ loop.resetThrottleWindow();
236
+ };
237
+ params.log?.(`mattermost stream preview ready (maxChars=${maxChars}, throttleMs=${throttleMs})`);
238
+ return {
239
+ update,
240
+ flush: loop.flush,
241
+ postId: () => streamPostId,
242
+ clear,
243
+ discardPending,
244
+ seal,
245
+ stop,
246
+ forceNewMessage
247
+ };
248
+ }
249
+ //#endregion
250
+ //#region extensions/mattermost/src/mattermost/monitor-gating.ts
251
+ function mapMattermostChannelTypeToChatType(channelType) {
252
+ if (!channelType) return "channel";
253
+ const normalized = channelType.trim().toUpperCase();
254
+ if (normalized === "D") return "direct";
255
+ if (normalized === "G" || normalized === "P") return "group";
256
+ return "channel";
257
+ }
258
+ function evaluateMattermostMentionGate(params) {
259
+ const shouldRequireMention = params.kind !== "direct" && params.resolveRequireMention({
260
+ cfg: params.cfg,
261
+ channel: "mattermost",
262
+ accountId: params.accountId,
263
+ groupId: params.channelId,
264
+ requireMentionOverride: params.requireMentionOverride
265
+ });
266
+ const shouldBypassMention = params.isControlCommand && shouldRequireMention && !params.wasMentioned && params.commandAuthorized;
267
+ const effectiveWasMentioned = params.wasMentioned || shouldBypassMention || params.oncharTriggered;
268
+ if (params.oncharEnabled && !params.oncharTriggered && !params.wasMentioned && !params.isControlCommand) return {
269
+ shouldRequireMention,
270
+ shouldBypassMention,
271
+ effectiveWasMentioned,
272
+ dropReason: "onchar-not-triggered"
273
+ };
274
+ if (params.kind !== "direct" && shouldRequireMention && params.canDetectMention && !effectiveWasMentioned) return {
275
+ shouldRequireMention,
276
+ shouldBypassMention,
277
+ effectiveWasMentioned,
278
+ dropReason: "missing-mention"
279
+ };
280
+ return {
281
+ shouldRequireMention,
282
+ shouldBypassMention,
283
+ effectiveWasMentioned,
284
+ dropReason: null
285
+ };
286
+ }
287
+ //#endregion
288
+ //#region extensions/mattermost/src/mattermost/monitor-helpers.ts
289
+ const formatInboundFromLabel = formatInboundFromLabel$1;
290
+ function resolveThreadSessionKeys(params) {
291
+ return resolveThreadSessionKeys$1({
292
+ ...params,
293
+ normalizeThreadId: (threadId) => threadId
294
+ });
295
+ }
296
+ /**
297
+ * Strip bot mention from message text while preserving newlines and
298
+ * block-level Markdown formatting (headings, lists, blockquotes).
299
+ */
300
+ function normalizeMention(text, mention) {
301
+ if (!mention) return text.trim();
302
+ const escaped = mention.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
303
+ const hasMentionRe = new RegExp(`@${escaped}\\b`, "i");
304
+ const leadingMentionRe = new RegExp(`^([\\t ]*)@${escaped}\\b[\\t ]*`, "i");
305
+ const trailingMentionRe = new RegExp(`[\\t ]*@${escaped}\\b[\\t ]*$`, "i");
306
+ const normalizedLines = text.split("\n").map((line) => {
307
+ const hadMention = hasMentionRe.test(line);
308
+ const normalizedLine = line.replace(leadingMentionRe, "$1").replace(trailingMentionRe, "").replace(new RegExp(`@${escaped}\\b`, "gi"), "").replace(/(\S)[ \t]{2,}/g, "$1 ");
309
+ return {
310
+ text: normalizedLine,
311
+ mentionOnlyBlank: hadMention && normalizedLine.trim() === ""
312
+ };
313
+ });
314
+ while (normalizedLines[0]?.mentionOnlyBlank) normalizedLines.shift();
315
+ while (normalizedLines.at(-1)?.text.trim() === "") normalizedLines.pop();
316
+ return normalizedLines.map((line) => line.text).join("\n");
317
+ }
318
+ //#endregion
319
+ //#region extensions/mattermost/src/mattermost/monitor-onchar.ts
320
+ const DEFAULT_ONCHAR_PREFIXES = [">", "!"];
321
+ function resolveOncharPrefixes(prefixes) {
322
+ const cleaned = prefixes?.map((entry) => entry.trim()).filter(Boolean) ?? DEFAULT_ONCHAR_PREFIXES;
323
+ return cleaned.length > 0 ? cleaned : DEFAULT_ONCHAR_PREFIXES;
324
+ }
325
+ function stripOncharPrefix(text, prefixes) {
326
+ const trimmed = text.trimStart();
327
+ for (const prefix of prefixes) {
328
+ if (!prefix) continue;
329
+ if (trimmed.startsWith(prefix)) return {
330
+ triggered: true,
331
+ stripped: trimmed.slice(prefix.length).trimStart()
332
+ };
333
+ }
334
+ return {
335
+ triggered: false,
336
+ stripped: text
337
+ };
338
+ }
339
+ //#endregion
340
+ //#region extensions/mattermost/src/mattermost/monitor-resources.ts
341
+ const CHANNEL_CACHE_TTL_MS = 5 * 6e4;
342
+ const USER_CACHE_TTL_MS = 10 * 6e4;
343
+ function createMattermostMonitorResources(params) {
344
+ const { accountId, callbackUrl, client, logger, mediaMaxBytes, fetchRemoteMedia, saveMediaBuffer, mediaKindFromMime } = params;
345
+ const channelCache = /* @__PURE__ */ new Map();
346
+ const userCache = /* @__PURE__ */ new Map();
347
+ const resolveMattermostMedia = async (fileIds) => {
348
+ const ids = (fileIds ?? []).map((id) => id?.trim()).filter(Boolean);
349
+ if (ids.length === 0) return [];
350
+ const out = [];
351
+ for (const fileId of ids) try {
352
+ const fetched = await fetchRemoteMedia({
353
+ url: `${client.apiBaseUrl}/files/${fileId}`,
354
+ requestInit: { headers: { Authorization: `Bearer ${client.token}` } },
355
+ filePathHint: fileId,
356
+ maxBytes: mediaMaxBytes,
357
+ ssrfPolicy: { allowedHostnames: [new URL(client.baseUrl).hostname] }
358
+ });
359
+ const saved = await saveMediaBuffer(Buffer.from(fetched.buffer), fetched.contentType ?? void 0, "inbound", mediaMaxBytes);
360
+ const contentType = saved.contentType ?? fetched.contentType ?? void 0;
361
+ out.push({
362
+ path: saved.path,
363
+ contentType,
364
+ kind: mediaKindFromMime(contentType) ?? "unknown"
365
+ });
366
+ } catch (err) {
367
+ logger.debug?.(`mattermost: failed to download file ${fileId}: ${String(err)}`);
368
+ }
369
+ return out;
370
+ };
371
+ const sendTypingIndicator = async (channelId, parentId) => {
372
+ await sendMattermostTyping(client, {
373
+ channelId,
374
+ parentId
375
+ });
376
+ };
377
+ const resolveChannelInfo = async (channelId) => {
378
+ const cached = channelCache.get(channelId);
379
+ if (cached && cached.expiresAt > Date.now()) return cached.value;
380
+ try {
381
+ const info = await fetchMattermostChannel(client, channelId);
382
+ channelCache.set(channelId, {
383
+ value: info,
384
+ expiresAt: Date.now() + CHANNEL_CACHE_TTL_MS
385
+ });
386
+ return info;
387
+ } catch (err) {
388
+ logger.debug?.(`mattermost: channel lookup failed: ${String(err)}`);
389
+ channelCache.set(channelId, {
390
+ value: null,
391
+ expiresAt: Date.now() + CHANNEL_CACHE_TTL_MS
392
+ });
393
+ return null;
394
+ }
395
+ };
396
+ const resolveUserInfo = async (userId) => {
397
+ const cached = userCache.get(userId);
398
+ if (cached && cached.expiresAt > Date.now()) return cached.value;
399
+ try {
400
+ const info = await fetchMattermostUser(client, userId);
401
+ userCache.set(userId, {
402
+ value: info,
403
+ expiresAt: Date.now() + USER_CACHE_TTL_MS
404
+ });
405
+ return info;
406
+ } catch (err) {
407
+ logger.debug?.(`mattermost: user lookup failed: ${String(err)}`);
408
+ userCache.set(userId, {
409
+ value: null,
410
+ expiresAt: Date.now() + USER_CACHE_TTL_MS
411
+ });
412
+ return null;
413
+ }
414
+ };
415
+ const buildModelPickerProps = (channelId, buttons) => buildButtonProps({
416
+ callbackUrl,
417
+ accountId,
418
+ channelId,
419
+ buttons
420
+ });
421
+ const updateModelPickerPost = async (params) => {
422
+ const props = buildModelPickerProps(params.channelId, params.buttons ?? []) ?? { attachments: [] };
423
+ await updateMattermostPost(client, params.postId, {
424
+ message: params.message,
425
+ props
426
+ });
427
+ return {};
428
+ };
429
+ return {
430
+ resolveMattermostMedia,
431
+ sendTypingIndicator,
432
+ resolveChannelInfo,
433
+ resolveUserInfo,
434
+ updateModelPickerPost
435
+ };
436
+ }
437
+ //#endregion
438
+ //#region extensions/mattermost/src/mattermost/monitor-slash.ts
439
+ function isLoopbackHost$1(hostname) {
440
+ return hostname === "localhost" || hostname === "127.0.0.1" || hostname === "::1";
441
+ }
442
+ function buildSlashCommands(params) {
443
+ const commandsToRegister = [...DEFAULT_COMMAND_SPECS];
444
+ if (!params.nativeSkills) return commandsToRegister;
445
+ try {
446
+ const skillCommands = listSkillCommandsForAgents({ cfg: params.cfg });
447
+ for (const spec of skillCommands) {
448
+ const name = typeof spec.name === "string" ? spec.name.trim() : "";
449
+ if (!name) continue;
450
+ const trigger = name.startsWith("oc_") ? name : `oc_${name}`;
451
+ commandsToRegister.push({
452
+ trigger,
453
+ description: spec.description || `Run skill ${name}`,
454
+ autoComplete: true,
455
+ autoCompleteHint: "[args]",
456
+ originalName: name
457
+ });
458
+ }
459
+ } catch (err) {
460
+ params.runtime.error?.(`mattermost: failed to list skill commands: ${String(err)}`);
461
+ }
462
+ return commandsToRegister;
463
+ }
464
+ function dedupeSlashCommands(commands) {
465
+ const seen = /* @__PURE__ */ new Set();
466
+ return commands.filter((cmd) => {
467
+ const key = cmd.trigger.trim();
468
+ if (!key || seen.has(key)) return false;
469
+ seen.add(key);
470
+ return true;
471
+ });
472
+ }
473
+ function buildTriggerMap(commands) {
474
+ const triggerMap = /* @__PURE__ */ new Map();
475
+ for (const cmd of commands) if (cmd.originalName) triggerMap.set(cmd.trigger, cmd.originalName);
476
+ return triggerMap;
477
+ }
478
+ function warnOnSuspiciousCallbackUrl(params) {
479
+ try {
480
+ const mmHost = new URL(normalizeMattermostBaseUrl(params.baseUrl) ?? params.baseUrl).hostname;
481
+ const callbackHost = new URL(params.callbackUrl).hostname;
482
+ if (isLoopbackHost$1(callbackHost) && !isLoopbackHost$1(mmHost)) params.runtime.error?.(`mattermost: slash commands callbackUrl resolved to ${params.callbackUrl} (loopback) while baseUrl is ${params.baseUrl}. This MAY be unreachable depending on your deployment. If native slash commands don't work, set channels.mattermost.commands.callbackUrl to a URL reachable from the Mattermost server (e.g. your public reverse proxy URL).`);
483
+ } catch {}
484
+ }
485
+ async function registerSlashCommandsAcrossTeams(params) {
486
+ const registered = [];
487
+ let teamRegistrationFailures = 0;
488
+ for (const team of params.teams) try {
489
+ const created = await registerSlashCommands({
490
+ client: params.client,
491
+ teamId: team.id,
492
+ creatorUserId: params.botUserId,
493
+ callbackUrl: params.callbackUrl,
494
+ commands: params.commands,
495
+ log: (msg) => params.runtime.log?.(msg)
496
+ });
497
+ registered.push(...created);
498
+ } catch (err) {
499
+ teamRegistrationFailures += 1;
500
+ params.runtime.error?.(`mattermost: failed to register slash commands for team ${team.id}: ${String(err)}`);
501
+ }
502
+ return {
503
+ registered,
504
+ teamRegistrationFailures
505
+ };
506
+ }
507
+ async function registerMattermostMonitorSlashCommands(params) {
508
+ const commandsRaw = params.account.config.commands;
509
+ const slashConfig = resolveSlashCommandConfig(commandsRaw);
510
+ if (!isSlashCommandsEnabled(slashConfig)) return;
511
+ try {
512
+ const teams = await fetchMattermostUserTeams(params.client, params.botUserId);
513
+ const slashCallbackUrl = resolveCallbackUrl({
514
+ config: slashConfig,
515
+ gatewayPort: parseStrictPositiveInteger(process.env.GENESIS_GATEWAY_PORT?.trim()) ?? params.cfg.gateway?.port ?? 18789,
516
+ gatewayHost: params.cfg.gateway?.customBindHost ?? void 0
517
+ });
518
+ warnOnSuspiciousCallbackUrl({
519
+ runtime: params.runtime,
520
+ baseUrl: params.baseUrl,
521
+ callbackUrl: slashCallbackUrl
522
+ });
523
+ const dedupedCommands = dedupeSlashCommands(buildSlashCommands({
524
+ cfg: params.cfg,
525
+ runtime: params.runtime,
526
+ nativeSkills: slashConfig.nativeSkills === true
527
+ }));
528
+ const { registered, teamRegistrationFailures } = await registerSlashCommandsAcrossTeams({
529
+ client: params.client,
530
+ teams,
531
+ botUserId: params.botUserId,
532
+ callbackUrl: slashCallbackUrl,
533
+ commands: dedupedCommands,
534
+ runtime: params.runtime
535
+ });
536
+ if (registered.length === 0) {
537
+ params.runtime.error?.("mattermost: native slash commands enabled but no commands could be registered; keeping slash callbacks inactive");
538
+ return;
539
+ }
540
+ if (teamRegistrationFailures > 0) params.runtime.error?.(`mattermost: slash command registration completed with ${teamRegistrationFailures} team error(s)`);
541
+ activateSlashCommands({
542
+ account: params.account,
543
+ commandTokens: registered.map((cmd) => cmd.token).filter(Boolean),
544
+ registeredCommands: registered,
545
+ triggerMap: buildTriggerMap(dedupedCommands),
546
+ api: {
547
+ cfg: params.cfg,
548
+ runtime: params.runtime
549
+ },
550
+ log: (msg) => params.runtime.log?.(msg)
551
+ });
552
+ params.runtime.log?.(`mattermost: slash commands registered (${registered.length} commands across ${teams.length} teams, callback=${slashCallbackUrl})`);
553
+ } catch (err) {
554
+ params.runtime.error?.(`mattermost: failed to register slash commands: ${String(err)}`);
555
+ }
556
+ }
557
+ //#endregion
558
+ //#region extensions/mattermost/src/mattermost/monitor-websocket.ts
559
+ const MattermostEventPayloadSchema = zod_exports.z.object({
560
+ event: zod_exports.z.string().optional(),
561
+ data: zod_exports.z.object({
562
+ post: zod_exports.z.union([zod_exports.z.string(), MattermostPostSchema]).optional(),
563
+ reaction: zod_exports.z.union([zod_exports.z.string(), zod_exports.z.record(zod_exports.z.string(), zod_exports.z.unknown())]).optional(),
564
+ channel_id: zod_exports.z.string().optional(),
565
+ channel_name: zod_exports.z.string().optional(),
566
+ channel_display_name: zod_exports.z.string().optional(),
567
+ channel_type: zod_exports.z.string().optional(),
568
+ sender_name: zod_exports.z.string().optional(),
569
+ team_id: zod_exports.z.string().optional()
570
+ }).optional(),
571
+ broadcast: zod_exports.z.object({
572
+ channel_id: zod_exports.z.string().optional(),
573
+ team_id: zod_exports.z.string().optional(),
574
+ user_id: zod_exports.z.string().optional()
575
+ }).optional()
576
+ });
577
+ function parseMattermostEventPayload(raw) {
578
+ return safeParseJsonWithSchema(MattermostEventPayloadSchema, raw);
579
+ }
580
+ function parseMattermostPost(value) {
581
+ if (typeof value === "string") return safeParseJsonWithSchema(MattermostPostSchema, value);
582
+ return safeParseWithSchema(MattermostPostSchema, value);
583
+ }
584
+ var WebSocketClosedBeforeOpenError = class extends Error {
585
+ constructor(code, reason) {
586
+ super(`websocket closed before open (code ${code})`);
587
+ this.code = code;
588
+ this.reason = reason;
589
+ this.name = "WebSocketClosedBeforeOpenError";
590
+ }
591
+ };
592
+ const defaultMattermostWebSocketFactory = (url) => {
593
+ const agent = createDebugProxyWebSocketAgent(resolveDebugProxySettings());
594
+ return new WebSocket(url, agent ? { agent } : void 0);
595
+ };
596
+ function parsePostedPayload(payload) {
597
+ if (payload.event !== "posted") return null;
598
+ const postData = payload.data?.post;
599
+ if (!postData) return null;
600
+ const post = parseMattermostPost(postData);
601
+ if (!post) return null;
602
+ return {
603
+ payload,
604
+ post
605
+ };
606
+ }
607
+ function createMattermostConnectOnce(opts) {
608
+ const webSocketFactory = opts.webSocketFactory ?? defaultMattermostWebSocketFactory;
609
+ const healthCheckIntervalMs = opts.healthCheckIntervalMs ?? 3e4;
610
+ return async () => {
611
+ const flowId = randomUUID();
612
+ const ws = webSocketFactory(opts.wsUrl);
613
+ const onAbort = () => ws.terminate();
614
+ opts.abortSignal?.addEventListener("abort", onAbort, { once: true });
615
+ const getBotUpdateAt = opts.getBotUpdateAt;
616
+ try {
617
+ return await new Promise((resolve, reject) => {
618
+ let opened = false;
619
+ let settled = false;
620
+ let healthCheckEnabled = getBotUpdateAt != null;
621
+ let healthCheckInFlight = false;
622
+ let healthCheckTimer;
623
+ let initialUpdateAt;
624
+ const clearTimers = () => {
625
+ if (healthCheckTimer !== void 0) {
626
+ clearTimeout(healthCheckTimer);
627
+ healthCheckTimer = void 0;
628
+ }
629
+ };
630
+ const stopHealthChecks = () => {
631
+ healthCheckEnabled = false;
632
+ clearTimers();
633
+ };
634
+ const scheduleHealthCheck = () => {
635
+ if (!getBotUpdateAt || !healthCheckEnabled || settled || healthCheckInFlight) return;
636
+ healthCheckTimer = setTimeout(() => {
637
+ healthCheckTimer = void 0;
638
+ runHealthCheck();
639
+ }, healthCheckIntervalMs);
640
+ };
641
+ const runHealthCheck = async () => {
642
+ if (!getBotUpdateAt || !healthCheckEnabled || settled || healthCheckInFlight) return;
643
+ healthCheckInFlight = true;
644
+ try {
645
+ const current = await getBotUpdateAt();
646
+ if (!healthCheckEnabled || settled) return;
647
+ if (initialUpdateAt === void 0) {
648
+ initialUpdateAt = current;
649
+ return;
650
+ }
651
+ if (current !== initialUpdateAt) {
652
+ opts.runtime.log?.(`mattermost: bot account updated (update_at changed: ${initialUpdateAt} → ${current}) — reconnecting`);
653
+ stopHealthChecks();
654
+ ws.terminate();
655
+ }
656
+ } catch (err) {
657
+ if (!healthCheckEnabled || settled) return;
658
+ const label = initialUpdateAt === void 0 ? "mattermost: failed to get initial update_at" : "mattermost: health check error";
659
+ opts.runtime.error?.(`${label}: ${String(err)}`);
660
+ } finally {
661
+ healthCheckInFlight = false;
662
+ scheduleHealthCheck();
663
+ }
664
+ };
665
+ const resolveOnce = () => {
666
+ if (settled) return;
667
+ settled = true;
668
+ stopHealthChecks();
669
+ resolve();
670
+ };
671
+ const rejectOnce = (error) => {
672
+ if (settled) return;
673
+ settled = true;
674
+ stopHealthChecks();
675
+ reject(error);
676
+ };
677
+ ws.on("open", () => {
678
+ opened = true;
679
+ captureWsEvent({
680
+ url: opts.wsUrl,
681
+ direction: "local",
682
+ kind: "ws-open",
683
+ flowId,
684
+ meta: { subsystem: "mattermost-websocket" }
685
+ });
686
+ opts.statusSink?.({
687
+ connected: true,
688
+ lastConnectedAt: Date.now(),
689
+ lastError: null
690
+ });
691
+ const authPayload = JSON.stringify({
692
+ seq: opts.nextSeq(),
693
+ action: "authentication_challenge",
694
+ data: { token: opts.botToken }
695
+ });
696
+ captureWsEvent({
697
+ url: opts.wsUrl,
698
+ direction: "outbound",
699
+ kind: "ws-frame",
700
+ flowId,
701
+ payload: authPayload,
702
+ meta: {
703
+ subsystem: "mattermost-websocket",
704
+ eventType: "authentication_challenge"
705
+ }
706
+ });
707
+ ws.send(authPayload);
708
+ if (getBotUpdateAt) runHealthCheck();
709
+ });
710
+ ws.on("message", async (data) => {
711
+ captureWsEvent({
712
+ url: opts.wsUrl,
713
+ direction: "inbound",
714
+ kind: "ws-frame",
715
+ flowId,
716
+ payload: Buffer.from(rawDataToString(data)),
717
+ meta: { subsystem: "mattermost-websocket" }
718
+ });
719
+ const payload = parseMattermostEventPayload(rawDataToString(data));
720
+ if (!payload) return;
721
+ if (payload.event === "reaction_added" || payload.event === "reaction_removed") {
722
+ if (!opts.onReaction) return;
723
+ try {
724
+ await opts.onReaction(payload);
725
+ } catch (err) {
726
+ opts.runtime.error?.(`mattermost reaction handler failed: ${String(err)}`);
727
+ }
728
+ return;
729
+ }
730
+ if (payload.event !== "posted") return;
731
+ const parsed = parsePostedPayload(payload);
732
+ if (!parsed) return;
733
+ try {
734
+ await opts.onPosted(parsed.post, parsed.payload);
735
+ } catch (err) {
736
+ opts.runtime.error?.(`mattermost handler failed: ${String(err)}`);
737
+ }
738
+ });
739
+ ws.on("close", (code, reason) => {
740
+ captureWsEvent({
741
+ url: opts.wsUrl,
742
+ direction: "local",
743
+ kind: "ws-close",
744
+ flowId,
745
+ closeCode: code,
746
+ payload: reason,
747
+ meta: { subsystem: "mattermost-websocket" }
748
+ });
749
+ stopHealthChecks();
750
+ const message = reasonToString(reason);
751
+ opts.statusSink?.({
752
+ connected: false,
753
+ lastDisconnect: {
754
+ at: Date.now(),
755
+ status: code,
756
+ error: message || void 0
757
+ }
758
+ });
759
+ if (opened) {
760
+ resolveOnce();
761
+ return;
762
+ }
763
+ rejectOnce(new WebSocketClosedBeforeOpenError(code, message || void 0));
764
+ });
765
+ ws.on("error", (err) => {
766
+ captureWsEvent({
767
+ url: opts.wsUrl,
768
+ direction: "local",
769
+ kind: "error",
770
+ flowId,
771
+ errorText: String(err),
772
+ meta: { subsystem: "mattermost-websocket" }
773
+ });
774
+ opts.runtime.error?.(`mattermost websocket error: ${String(err)}`);
775
+ opts.statusSink?.({ lastError: String(err) });
776
+ try {
777
+ ws.close();
778
+ } catch {}
779
+ });
780
+ });
781
+ } finally {
782
+ opts.abortSignal?.removeEventListener("abort", onAbort);
783
+ }
784
+ };
785
+ }
786
+ function reasonToString(reason) {
787
+ if (!reason) return "";
788
+ if (typeof reason === "string") return reason;
789
+ return reason.length > 0 ? reason.toString("utf8") : "";
790
+ }
791
+ //#endregion
792
+ //#region extensions/mattermost/src/mattermost/reconnect.ts
793
+ /**
794
+ * Reconnection loop with exponential backoff.
795
+ *
796
+ * Calls `connectFn` in a while loop. On normal resolve (connection closed),
797
+ * the backoff resets. On thrown error (connection failed), the current delay is
798
+ * used, then doubled for the next retry.
799
+ * The loop exits when `abortSignal` fires.
800
+ */
801
+ async function runWithReconnect(connectFn, opts = {}) {
802
+ const { initialDelayMs = 2e3, maxDelayMs = 6e4 } = opts;
803
+ const jitterRatio = Math.max(0, opts.jitterRatio ?? 0);
804
+ const random = opts.random ?? Math.random;
805
+ let retryDelay = initialDelayMs;
806
+ let attempt = 0;
807
+ while (!opts.abortSignal?.aborted) {
808
+ let shouldIncreaseDelay = false;
809
+ let outcome = "resolved";
810
+ let error;
811
+ try {
812
+ await connectFn();
813
+ retryDelay = initialDelayMs;
814
+ } catch (err) {
815
+ if (opts.abortSignal?.aborted) return;
816
+ outcome = "rejected";
817
+ error = err;
818
+ opts.onError?.(err);
819
+ shouldIncreaseDelay = true;
820
+ }
821
+ if (opts.abortSignal?.aborted) return;
822
+ const delayMs = withJitter(retryDelay, jitterRatio, random);
823
+ if (!(opts.shouldReconnect?.({
824
+ attempt,
825
+ delayMs,
826
+ outcome,
827
+ error
828
+ }) ?? true)) return;
829
+ opts.onReconnect?.(delayMs);
830
+ await sleepAbortable(delayMs, opts.abortSignal);
831
+ if (shouldIncreaseDelay) retryDelay = Math.min(retryDelay * 2, maxDelayMs);
832
+ attempt++;
833
+ }
834
+ }
835
+ function withJitter(baseMs, jitterRatio, random) {
836
+ if (jitterRatio <= 0) return baseMs;
837
+ const normalized = Math.max(0, Math.min(1, random()));
838
+ const spread = baseMs * jitterRatio;
839
+ return Math.max(1, Math.round(baseMs - spread + normalized * spread * 2));
840
+ }
841
+ function sleepAbortable(ms, signal) {
842
+ return new Promise((resolve) => {
843
+ if (signal?.aborted) {
844
+ resolve();
845
+ return;
846
+ }
847
+ const onAbort = () => {
848
+ clearTimeout(timer);
849
+ resolve();
850
+ };
851
+ const timer = setTimeout(() => {
852
+ signal?.removeEventListener("abort", onAbort);
853
+ resolve();
854
+ }, ms);
855
+ signal?.addEventListener("abort", onAbort, { once: true });
856
+ });
857
+ }
858
+ //#endregion
859
+ //#region extensions/mattermost/src/mattermost/monitor.ts
860
+ const RECENT_MATTERMOST_MESSAGE_TTL_MS = 5 * 6e4;
861
+ const RECENT_MATTERMOST_MESSAGE_MAX = 2e3;
862
+ function isLoopbackHost(hostname) {
863
+ return hostname === "localhost" || hostname === "127.0.0.1" || hostname === "::1";
864
+ }
865
+ function normalizeInteractionSourceIps(values) {
866
+ return (values ?? []).map((value) => normalizeOptionalString(value)).filter((value) => Boolean(value));
867
+ }
868
+ const recentInboundMessages = createClaimableDedupe({
869
+ ttlMs: RECENT_MATTERMOST_MESSAGE_TTL_MS,
870
+ memoryMaxSize: RECENT_MATTERMOST_MESSAGE_MAX
871
+ });
872
+ var MattermostRetryableInboundError = class extends Error {
873
+ constructor(message, options) {
874
+ super(message, options);
875
+ this.name = "MattermostRetryableInboundError";
876
+ }
877
+ };
878
+ function buildMattermostModelPickerSelectMessageSid(params) {
879
+ const provider = normalizeLowercaseStringOrEmpty(params.provider);
880
+ const model = normalizeLowercaseStringOrEmpty(params.model);
881
+ return `interaction:${params.postId}:select:${provider}/${model}`;
882
+ }
883
+ function buildMattermostInboundReplayKeys(params) {
884
+ return [...new Set(params.messageIds.map((id) => `${params.accountId}:${id.trim()}`))].filter((key) => !key.endsWith(":"));
885
+ }
886
+ async function processMattermostReplayGuardedPost(params) {
887
+ const replayGuard = params.replayGuard ?? recentInboundMessages;
888
+ const replayKeys = buildMattermostInboundReplayKeys({
889
+ accountId: params.accountId,
890
+ messageIds: params.messageIds
891
+ });
892
+ if (replayKeys.length === 0) {
893
+ await params.handlePost();
894
+ return "processed";
895
+ }
896
+ const claimedKeys = [];
897
+ for (const replayKey of replayKeys) if ((await replayGuard.claim(replayKey)).kind === "claimed") claimedKeys.push(replayKey);
898
+ if (claimedKeys.length === 0) return "duplicate";
899
+ try {
900
+ await params.handlePost();
901
+ await Promise.all(claimedKeys.map((replayKey) => replayGuard.commit(replayKey)));
902
+ return "processed";
903
+ } catch (error) {
904
+ if (error instanceof MattermostRetryableInboundError) claimedKeys.forEach((replayKey) => replayGuard.release(replayKey, { error }));
905
+ else await Promise.all(claimedKeys.map((replayKey) => replayGuard.commit(replayKey)));
906
+ throw error;
907
+ }
908
+ }
909
+ function resolveRuntime(opts) {
910
+ return opts.runtime ?? {
911
+ log: console.log,
912
+ error: console.error,
913
+ exit: (code) => {
914
+ throw new Error(`exit ${code}`);
915
+ }
916
+ };
917
+ }
918
+ function isSystemPost(post) {
919
+ return normalizeOptionalString(post.type) !== void 0;
920
+ }
921
+ function channelChatType(kind) {
922
+ if (kind === "direct") return "direct";
923
+ if (kind === "group") return "group";
924
+ return "channel";
925
+ }
926
+ function resolveMattermostReplyRootId(params) {
927
+ const threadRootId = normalizeOptionalString(params.threadRootId);
928
+ if (threadRootId) return threadRootId;
929
+ return normalizeOptionalString(params.replyToId);
930
+ }
931
+ function canFinalizeMattermostPreviewInPlace(params) {
932
+ return resolveMattermostReplyRootId({
933
+ threadRootId: params.threadRootId,
934
+ replyToId: params.replyToId
935
+ }) === params.previewRootId?.trim();
936
+ }
937
+ async function deliverMattermostReplyWithDraftPreview(params) {
938
+ if (isReasoningReplyPayload(params.payload)) return;
939
+ await deliverFinalizableDraftPreview({
940
+ kind: params.info.kind,
941
+ payload: params.payload,
942
+ draft: {
943
+ flush: params.draftStream.flush,
944
+ clear: params.draftStream.clear,
945
+ discardPending: params.draftStream.discardPending,
946
+ seal: params.draftStream.seal,
947
+ id: params.draftStream.postId
948
+ },
949
+ buildFinalEdit: (payload) => {
950
+ const hasMedia = Boolean(payload.mediaUrl) || (payload.mediaUrls?.length ?? 0) > 0;
951
+ const previewFinalText = params.resolvePreviewFinalText(payload.text);
952
+ if (hasMedia || typeof previewFinalText !== "string" || payload.isError || !canFinalizeMattermostPreviewInPlace({
953
+ previewRootId: params.effectiveReplyToId,
954
+ threadRootId: params.effectiveReplyToId,
955
+ replyToId: payload.replyToId
956
+ })) return;
957
+ return { message: previewFinalText };
958
+ },
959
+ editFinal: async (previewPostId, edit) => {
960
+ await updateMattermostPost(params.client, previewPostId, edit);
961
+ },
962
+ deliverNormally: async () => {
963
+ await params.deliverFinal();
964
+ },
965
+ onPreviewFinalized: () => {
966
+ params.previewState.finalizedViaPreviewPost = true;
967
+ },
968
+ logPreviewEditFailure: (err) => {
969
+ params.logVerboseMessage(`mattermost preview final edit failed; falling back to normal send (${String(err)})`);
970
+ }
971
+ });
972
+ }
973
+ function resolveMattermostEffectiveReplyToId(params) {
974
+ const threadRootId = normalizeOptionalString(params.threadRootId);
975
+ if (threadRootId && params.replyToMode !== "off") return threadRootId;
976
+ if (params.kind === "direct") return;
977
+ const postId = normalizeOptionalString(params.postId);
978
+ if (!postId) return;
979
+ return params.replyToMode === "all" || params.replyToMode === "first" || params.replyToMode === "batched" ? postId : void 0;
980
+ }
981
+ function resolveMattermostThreadSessionContext(params) {
982
+ const effectiveReplyToId = resolveMattermostEffectiveReplyToId({
983
+ kind: params.kind,
984
+ postId: params.postId,
985
+ replyToMode: params.replyToMode,
986
+ threadRootId: params.threadRootId
987
+ });
988
+ const threadKeys = resolveThreadSessionKeys({
989
+ baseSessionKey: params.baseSessionKey,
990
+ threadId: effectiveReplyToId,
991
+ parentSessionKey: effectiveReplyToId ? params.baseSessionKey : void 0
992
+ });
993
+ return {
994
+ effectiveReplyToId,
995
+ sessionKey: threadKeys.sessionKey,
996
+ parentSessionKey: threadKeys.parentSessionKey
997
+ };
998
+ }
999
+ function resolveMattermostReactionChannelId(payload) {
1000
+ return normalizeOptionalString(payload.broadcast?.channel_id) ?? normalizeOptionalString(payload.data?.channel_id);
1001
+ }
1002
+ function buildMattermostAttachmentPlaceholder(mediaList) {
1003
+ if (mediaList.length === 0) return "";
1004
+ if (mediaList.length === 1) return `<media:${mediaList[0].kind === "unknown" ? "document" : mediaList[0].kind}>`;
1005
+ const allImages = mediaList.every((media) => media.kind === "image");
1006
+ const label = allImages ? "image" : "file";
1007
+ const suffix = mediaList.length === 1 ? label : `${label}s`;
1008
+ return `${allImages ? "<media:image>" : "<media:document>"} (${mediaList.length} ${suffix})`;
1009
+ }
1010
+ function buildMattermostWsUrl(baseUrl) {
1011
+ const normalized = normalizeMattermostBaseUrl(baseUrl);
1012
+ if (!normalized) throw new Error("Mattermost baseUrl is required");
1013
+ return `${normalized.replace(/^http/i, "ws")}/api/v4/websocket`;
1014
+ }
1015
+ async function monitorMattermostProvider(opts = {}) {
1016
+ const core = getMattermostRuntime();
1017
+ const runtime = resolveRuntime(opts);
1018
+ const cfg = opts.config ?? core.config.loadConfig();
1019
+ const account = resolveMattermostAccount({
1020
+ cfg,
1021
+ accountId: opts.accountId
1022
+ });
1023
+ const pairing = createChannelPairingController({
1024
+ core,
1025
+ channel: "mattermost",
1026
+ accountId: account.accountId
1027
+ });
1028
+ const allowNameMatching = isDangerousNameMatchingEnabled(account.config);
1029
+ const botToken = normalizeOptionalString(opts.botToken) ?? normalizeOptionalString(account.botToken);
1030
+ if (!botToken) throw new Error(`Mattermost bot token missing for account "${account.accountId}" (set channels.mattermost.accounts.${account.accountId}.botToken or MATTERMOST_BOT_TOKEN for default).`);
1031
+ const baseUrl = normalizeMattermostBaseUrl(opts.baseUrl ?? account.baseUrl);
1032
+ if (!baseUrl) throw new Error(`Mattermost baseUrl missing for account "${account.accountId}" (set channels.mattermost.accounts.${account.accountId}.baseUrl or MATTERMOST_URL for default).`);
1033
+ const client = createMattermostClient({
1034
+ baseUrl,
1035
+ botToken,
1036
+ allowPrivateNetwork: isPrivateNetworkOptInEnabled(account.config)
1037
+ });
1038
+ let botUser;
1039
+ await runWithReconnect(async () => {
1040
+ botUser = await fetchMattermostMe(client);
1041
+ }, {
1042
+ abortSignal: opts.abortSignal,
1043
+ jitterRatio: .2,
1044
+ shouldReconnect: ({ outcome }) => outcome === "rejected",
1045
+ onError: (err) => {
1046
+ runtime.error?.(`mattermost: API auth failed: ${String(err)}`);
1047
+ opts.statusSink?.({
1048
+ lastError: String(err),
1049
+ connected: false
1050
+ });
1051
+ },
1052
+ onReconnect: (delayMs) => {
1053
+ runtime.log?.(`mattermost: API not accessible, retrying in ${Math.round(delayMs / 1e3)}s`);
1054
+ }
1055
+ });
1056
+ if (opts.abortSignal?.aborted) return;
1057
+ const botUserId = botUser.id;
1058
+ const botUsername = normalizeOptionalString(botUser.username);
1059
+ runtime.log?.(`mattermost connected as ${botUsername ? `@${botUsername}` : botUserId}`);
1060
+ await registerMattermostMonitorSlashCommands({
1061
+ client,
1062
+ cfg,
1063
+ runtime,
1064
+ account,
1065
+ baseUrl,
1066
+ botUserId
1067
+ });
1068
+ const slashEnabled = getSlashCommandState(account.accountId) != null;
1069
+ setInteractionSecret(account.accountId, botToken);
1070
+ const interactionPath = resolveInteractionCallbackPath(account.accountId);
1071
+ const callbackUrl = computeInteractionCallbackUrl(account.accountId, {
1072
+ gateway: cfg.gateway,
1073
+ interactions: account.config.interactions
1074
+ });
1075
+ setInteractionCallbackUrl(account.accountId, callbackUrl);
1076
+ const allowedInteractionSourceIps = normalizeInteractionSourceIps(account.config.interactions?.allowedSourceIps);
1077
+ try {
1078
+ const mmHost = new URL(baseUrl).hostname;
1079
+ const callbackHost = new URL(callbackUrl).hostname;
1080
+ if (isLoopbackHost(callbackHost) && !isLoopbackHost(mmHost)) runtime.error?.(`mattermost: interactions callbackUrl resolved to ${callbackUrl} (loopback) while baseUrl is ${baseUrl}. This MAY be unreachable depending on your deployment. If button clicks don't work, set channels.mattermost.interactions.callbackBaseUrl to a URL reachable from the Mattermost server (e.g. your public reverse proxy URL).`);
1081
+ if (!isLoopbackHost(callbackHost) && allowedInteractionSourceIps.length === 0) runtime.error?.(`mattermost: interactions callbackUrl resolved to ${callbackUrl} without channels.mattermost.interactions.allowedSourceIps. For safety, non-loopback callback sources will be rejected until you allowlist the Mattermost server or trusted ingress IPs.`);
1082
+ } catch {}
1083
+ const effectiveInteractionSourceIps = allowedInteractionSourceIps.length > 0 ? allowedInteractionSourceIps : ["127.0.0.1", "::1"];
1084
+ const unregisterInteractions = registerPluginHttpRoute({
1085
+ path: interactionPath,
1086
+ fallbackPath: "/mattermost/interactions/default",
1087
+ auth: "plugin",
1088
+ handler: createMattermostInteractionHandler({
1089
+ client,
1090
+ botUserId,
1091
+ accountId: account.accountId,
1092
+ allowedSourceIps: effectiveInteractionSourceIps,
1093
+ trustedProxies: cfg.gateway?.trustedProxies,
1094
+ allowRealIpFallback: cfg.gateway?.allowRealIpFallback === true,
1095
+ handleInteraction: handleModelPickerInteraction,
1096
+ authorizeButtonClick: async ({ payload, post }) => {
1097
+ const channelInfo = await resolveChannelInfo(payload.channel_id);
1098
+ const isDirect = channelInfo?.type?.trim().toUpperCase() === "D";
1099
+ const allowTextCommands = core.channel.commands.shouldHandleTextCommands({
1100
+ cfg,
1101
+ surface: "mattermost"
1102
+ });
1103
+ const decision = authorizeMattermostCommandInvocation({
1104
+ account,
1105
+ cfg,
1106
+ senderId: payload.user_id,
1107
+ senderName: payload.user_name ?? "",
1108
+ channelId: payload.channel_id,
1109
+ channelInfo,
1110
+ storeAllowFrom: isDirect ? await readStoreAllowFromForDmPolicy({
1111
+ provider: "mattermost",
1112
+ accountId: account.accountId,
1113
+ dmPolicy: account.config.dmPolicy ?? "pairing",
1114
+ readStore: pairing.readStoreForDmPolicy
1115
+ }) : void 0,
1116
+ allowTextCommands,
1117
+ hasControlCommand: false
1118
+ });
1119
+ if (decision.ok) return { ok: true };
1120
+ return {
1121
+ ok: false,
1122
+ response: {
1123
+ update: {
1124
+ message: post.message ?? "",
1125
+ props: post.props ?? void 0
1126
+ },
1127
+ ephemeral_text: `Genesis ignored this action for ${decision.roomLabel}.`
1128
+ }
1129
+ };
1130
+ },
1131
+ resolveSessionKey: async ({ channelId, userId, post }) => {
1132
+ const channelInfo = await resolveChannelInfo(channelId);
1133
+ const kind = mapMattermostChannelTypeToChatType(channelInfo?.type);
1134
+ const teamId = channelInfo?.team_id ?? void 0;
1135
+ const route = core.channel.routing.resolveAgentRoute({
1136
+ cfg,
1137
+ channel: "mattermost",
1138
+ accountId: account.accountId,
1139
+ teamId,
1140
+ peer: {
1141
+ kind,
1142
+ id: kind === "direct" ? userId : channelId
1143
+ }
1144
+ });
1145
+ const replyToMode = resolveMattermostReplyToMode(account, kind);
1146
+ return resolveMattermostThreadSessionContext({
1147
+ baseSessionKey: route.sessionKey,
1148
+ kind,
1149
+ postId: post.id || void 0,
1150
+ replyToMode,
1151
+ threadRootId: post.root_id
1152
+ }).sessionKey;
1153
+ },
1154
+ dispatchButtonClick: async (opts) => {
1155
+ const channelInfo = await resolveChannelInfo(opts.channelId);
1156
+ const kind = mapMattermostChannelTypeToChatType(channelInfo?.type);
1157
+ const chatType = channelChatType(kind);
1158
+ const teamId = channelInfo?.team_id ?? void 0;
1159
+ const channelName = channelInfo?.name ?? void 0;
1160
+ const channelDisplay = channelInfo?.display_name ?? channelName ?? opts.channelId;
1161
+ const route = core.channel.routing.resolveAgentRoute({
1162
+ cfg,
1163
+ channel: "mattermost",
1164
+ accountId: account.accountId,
1165
+ teamId,
1166
+ peer: {
1167
+ kind,
1168
+ id: kind === "direct" ? opts.userId : opts.channelId
1169
+ }
1170
+ });
1171
+ const replyToMode = resolveMattermostReplyToMode(account, kind);
1172
+ const threadContext = resolveMattermostThreadSessionContext({
1173
+ baseSessionKey: route.sessionKey,
1174
+ kind,
1175
+ postId: opts.post.id || opts.postId,
1176
+ replyToMode,
1177
+ threadRootId: opts.post.root_id
1178
+ });
1179
+ const to = kind === "direct" ? `user:${opts.userId}` : `channel:${opts.channelId}`;
1180
+ const bodyText = `[Button click: user @${opts.userName} selected "${opts.actionName}"]`;
1181
+ const ctxPayload = core.channel.reply.finalizeInboundContext({
1182
+ Body: bodyText,
1183
+ BodyForAgent: bodyText,
1184
+ RawBody: bodyText,
1185
+ CommandBody: bodyText,
1186
+ From: kind === "direct" ? `mattermost:${opts.userId}` : kind === "group" ? `mattermost:group:${opts.channelId}` : `mattermost:channel:${opts.channelId}`,
1187
+ To: to,
1188
+ SessionKey: threadContext.sessionKey,
1189
+ ParentSessionKey: threadContext.parentSessionKey,
1190
+ AccountId: route.accountId,
1191
+ ChatType: chatType,
1192
+ ConversationLabel: `mattermost:${opts.userName}`,
1193
+ GroupSubject: kind !== "direct" ? channelDisplay : void 0,
1194
+ GroupChannel: channelName ? `#${channelName}` : void 0,
1195
+ GroupSpace: teamId,
1196
+ SenderName: opts.userName,
1197
+ SenderId: opts.userId,
1198
+ Provider: "mattermost",
1199
+ Surface: "mattermost",
1200
+ MessageSid: `interaction:${opts.postId}:${opts.actionId}`,
1201
+ ReplyToId: threadContext.effectiveReplyToId,
1202
+ MessageThreadId: threadContext.effectiveReplyToId,
1203
+ WasMentioned: true,
1204
+ CommandAuthorized: false,
1205
+ OriginatingChannel: "mattermost",
1206
+ OriginatingTo: to
1207
+ });
1208
+ const textLimit = core.channel.text.resolveTextChunkLimit(cfg, "mattermost", account.accountId, { fallbackLimit: account.textChunkLimit ?? 4e3 });
1209
+ const tableMode = core.channel.text.resolveMarkdownTableMode({
1210
+ cfg,
1211
+ channel: "mattermost",
1212
+ accountId: account.accountId
1213
+ });
1214
+ const { onModelSelected, typingCallbacks, ...replyPipeline } = createChannelReplyPipeline({
1215
+ cfg,
1216
+ agentId: route.agentId,
1217
+ channel: "mattermost",
1218
+ accountId: account.accountId,
1219
+ typing: {
1220
+ start: () => sendTypingIndicator(opts.channelId, threadContext.effectiveReplyToId),
1221
+ onStartError: (err) => {
1222
+ logTypingFailure({
1223
+ log: (message) => logger.debug?.(message),
1224
+ channel: "mattermost",
1225
+ target: opts.channelId,
1226
+ error: err
1227
+ });
1228
+ }
1229
+ }
1230
+ });
1231
+ const { dispatcher, replyOptions, markDispatchIdle } = core.channel.reply.createReplyDispatcherWithTyping({
1232
+ ...replyPipeline,
1233
+ humanDelay: core.channel.reply.resolveHumanDelayConfig(cfg, route.agentId),
1234
+ deliver: async (payload) => {
1235
+ await deliverMattermostReplyPayload({
1236
+ core,
1237
+ cfg,
1238
+ payload,
1239
+ to,
1240
+ accountId: account.accountId,
1241
+ agentId: route.agentId,
1242
+ replyToId: resolveMattermostReplyRootId({
1243
+ threadRootId: threadContext.effectiveReplyToId,
1244
+ replyToId: payload.replyToId
1245
+ }),
1246
+ textLimit,
1247
+ tableMode,
1248
+ sendMessage: sendMessageMattermost
1249
+ });
1250
+ runtime.log?.(`delivered button-click reply to ${to}`);
1251
+ },
1252
+ onError: (err, info) => {
1253
+ runtime.error?.(`mattermost button-click ${info.kind} reply failed: ${String(err)}`);
1254
+ },
1255
+ onReplyStart: typingCallbacks?.onReplyStart
1256
+ });
1257
+ await core.channel.reply.dispatchReplyFromConfig({
1258
+ ctx: ctxPayload,
1259
+ cfg,
1260
+ dispatcher,
1261
+ replyOptions: {
1262
+ ...replyOptions,
1263
+ disableBlockStreaming: typeof account.blockStreaming === "boolean" ? !account.blockStreaming : void 0,
1264
+ onModelSelected
1265
+ }
1266
+ });
1267
+ markDispatchIdle();
1268
+ },
1269
+ log: (msg) => runtime.log?.(msg)
1270
+ }),
1271
+ pluginId: "mattermost",
1272
+ source: "mattermost-interactions",
1273
+ accountId: account.accountId,
1274
+ log: (msg) => runtime.log?.(msg)
1275
+ });
1276
+ const logger = core.logging.getChildLogger({ module: "mattermost" });
1277
+ const logVerboseMessage = (message) => {
1278
+ if (!core.logging.shouldLogVerbose()) return;
1279
+ logger.debug?.(message);
1280
+ };
1281
+ const mediaMaxBytes = resolveChannelMediaMaxBytes({
1282
+ cfg,
1283
+ resolveChannelLimitMb: () => void 0,
1284
+ accountId: account.accountId
1285
+ }) ?? 8 * 1024 * 1024;
1286
+ const historyLimit = Math.max(0, cfg.messages?.groupChat?.historyLimit ?? 50);
1287
+ const channelHistories = /* @__PURE__ */ new Map();
1288
+ const defaultGroupPolicy = resolveDefaultGroupPolicy(cfg);
1289
+ const { groupPolicy, providerMissingFallbackApplied } = resolveAllowlistProviderRuntimeGroupPolicy({
1290
+ providerConfigPresent: cfg.channels?.mattermost !== void 0,
1291
+ groupPolicy: account.config.groupPolicy,
1292
+ defaultGroupPolicy
1293
+ });
1294
+ warnMissingProviderGroupPolicyFallbackOnce({
1295
+ providerMissingFallbackApplied,
1296
+ providerKey: "mattermost",
1297
+ accountId: account.accountId,
1298
+ log: (message) => logVerboseMessage(message)
1299
+ });
1300
+ const { resolveMattermostMedia, sendTypingIndicator, resolveChannelInfo, resolveUserInfo, updateModelPickerPost } = createMattermostMonitorResources({
1301
+ accountId: account.accountId,
1302
+ callbackUrl,
1303
+ client,
1304
+ logger: { debug: (message) => logger.debug?.(String(message)) },
1305
+ mediaMaxBytes,
1306
+ fetchRemoteMedia: (params) => core.channel.media.fetchRemoteMedia(params),
1307
+ saveMediaBuffer: (buffer, contentType, direction, maxBytes) => core.channel.media.saveMediaBuffer(Buffer.from(buffer), contentType, direction, maxBytes),
1308
+ mediaKindFromMime: (contentType) => core.media.mediaKindFromMime(contentType)
1309
+ });
1310
+ const runModelPickerCommand = async (params) => {
1311
+ const to = params.kind === "direct" ? `user:${params.senderId}` : `channel:${params.channelId}`;
1312
+ const fromLabel = params.kind === "direct" ? `Mattermost DM from ${params.senderName}` : `Mattermost message in ${params.roomLabel} from ${params.senderName}`;
1313
+ const ctxPayload = core.channel.reply.finalizeInboundContext({
1314
+ Body: params.commandText,
1315
+ BodyForAgent: params.commandText,
1316
+ RawBody: params.commandText,
1317
+ CommandBody: params.commandText,
1318
+ From: params.kind === "direct" ? `mattermost:${params.senderId}` : params.kind === "group" ? `mattermost:group:${params.channelId}` : `mattermost:channel:${params.channelId}`,
1319
+ To: to,
1320
+ SessionKey: params.sessionKey,
1321
+ ParentSessionKey: params.parentSessionKey,
1322
+ AccountId: params.route.accountId,
1323
+ ChatType: params.chatType,
1324
+ ConversationLabel: fromLabel,
1325
+ GroupSubject: params.kind !== "direct" ? params.channelDisplay || params.roomLabel : void 0,
1326
+ GroupChannel: params.channelName ? `#${params.channelName}` : void 0,
1327
+ GroupSpace: params.teamId,
1328
+ SenderName: params.senderName,
1329
+ SenderId: params.senderId,
1330
+ Provider: "mattermost",
1331
+ Surface: "mattermost",
1332
+ MessageSid: params.messageSid ?? `interaction:${params.postId}:${Date.now()}`,
1333
+ ReplyToId: params.effectiveReplyToId,
1334
+ MessageThreadId: params.effectiveReplyToId,
1335
+ Timestamp: Date.now(),
1336
+ WasMentioned: true,
1337
+ CommandAuthorized: params.commandAuthorized,
1338
+ CommandSource: "native",
1339
+ OriginatingChannel: "mattermost",
1340
+ OriginatingTo: to
1341
+ });
1342
+ const tableMode = core.channel.text.resolveMarkdownTableMode({
1343
+ cfg,
1344
+ channel: "mattermost",
1345
+ accountId: account.accountId
1346
+ });
1347
+ const textLimit = core.channel.text.resolveTextChunkLimit(cfg, "mattermost", account.accountId, { fallbackLimit: account.textChunkLimit ?? 4e3 });
1348
+ const shouldDeliverReplies = params.deliverReplies === true;
1349
+ const { onModelSelected, typingCallbacks, ...replyPipeline } = createChannelReplyPipeline({
1350
+ cfg,
1351
+ agentId: params.route.agentId,
1352
+ channel: "mattermost",
1353
+ accountId: account.accountId,
1354
+ typing: shouldDeliverReplies ? {
1355
+ start: () => sendTypingIndicator(params.channelId, params.effectiveReplyToId),
1356
+ onStartError: (err) => {
1357
+ logTypingFailure({
1358
+ log: (message) => logger.debug?.(message),
1359
+ channel: "mattermost",
1360
+ target: params.channelId,
1361
+ error: err
1362
+ });
1363
+ }
1364
+ } : void 0
1365
+ });
1366
+ const capturedTexts = [];
1367
+ const { dispatcher, replyOptions, markDispatchIdle } = core.channel.reply.createReplyDispatcherWithTyping({
1368
+ ...replyPipeline,
1369
+ deliver: async (payload) => {
1370
+ const trimmedPayload = {
1371
+ ...payload,
1372
+ text: core.channel.text.convertMarkdownTables(payload.text ?? "", tableMode).trim()
1373
+ };
1374
+ if (!shouldDeliverReplies) {
1375
+ if (trimmedPayload.text) capturedTexts.push(trimmedPayload.text);
1376
+ return;
1377
+ }
1378
+ await deliverMattermostReplyPayload({
1379
+ core,
1380
+ cfg,
1381
+ payload: trimmedPayload,
1382
+ to,
1383
+ accountId: account.accountId,
1384
+ agentId: params.route.agentId,
1385
+ replyToId: resolveMattermostReplyRootId({
1386
+ threadRootId: params.effectiveReplyToId,
1387
+ replyToId: trimmedPayload.replyToId
1388
+ }),
1389
+ textLimit,
1390
+ tableMode: "off",
1391
+ sendMessage: sendMessageMattermost
1392
+ });
1393
+ },
1394
+ onError: (err, info) => {
1395
+ runtime.error?.(`mattermost model picker ${info.kind} reply failed: ${String(err)}`);
1396
+ },
1397
+ onReplyStart: typingCallbacks?.onReplyStart
1398
+ });
1399
+ await core.channel.reply.withReplyDispatcher({
1400
+ dispatcher,
1401
+ onSettled: () => {
1402
+ markDispatchIdle();
1403
+ },
1404
+ run: () => core.channel.reply.dispatchReplyFromConfig({
1405
+ ctx: ctxPayload,
1406
+ cfg,
1407
+ dispatcher,
1408
+ replyOptions: {
1409
+ ...replyOptions,
1410
+ disableBlockStreaming: typeof account.blockStreaming === "boolean" ? !account.blockStreaming : void 0,
1411
+ onModelSelected
1412
+ }
1413
+ })
1414
+ });
1415
+ return capturedTexts.join("\n\n").trim();
1416
+ };
1417
+ async function handleModelPickerInteraction(params) {
1418
+ const pickerState = parseMattermostModelPickerContext(params.context);
1419
+ if (!pickerState) return null;
1420
+ if (pickerState.ownerUserId !== params.payload.user_id) return { ephemeral_text: "Only the person who opened this picker can use it." };
1421
+ const channelInfo = await resolveChannelInfo(params.payload.channel_id);
1422
+ const pickerCommandText = pickerState.action === "select" ? `/model ${pickerState.provider}/${pickerState.model}` : pickerState.action === "list" ? `/models ${pickerState.provider}` : "/models";
1423
+ const allowTextCommands = core.channel.commands.shouldHandleTextCommands({
1424
+ cfg,
1425
+ surface: "mattermost"
1426
+ });
1427
+ const hasControlCommand = core.channel.text.hasControlCommand(pickerCommandText, cfg);
1428
+ const dmPolicy = account.config.dmPolicy ?? "pairing";
1429
+ const storeAllowFrom = normalizeMattermostAllowList(await readStoreAllowFromForDmPolicy({
1430
+ provider: "mattermost",
1431
+ accountId: account.accountId,
1432
+ dmPolicy,
1433
+ readStore: pairing.readStoreForDmPolicy
1434
+ }));
1435
+ const auth = authorizeMattermostCommandInvocation({
1436
+ account,
1437
+ cfg,
1438
+ senderId: params.payload.user_id,
1439
+ senderName: params.userName,
1440
+ channelId: params.payload.channel_id,
1441
+ channelInfo,
1442
+ storeAllowFrom,
1443
+ allowTextCommands,
1444
+ hasControlCommand
1445
+ });
1446
+ if (!auth.ok) {
1447
+ if (auth.denyReason === "dm-pairing") {
1448
+ const { code } = await pairing.upsertPairingRequest({
1449
+ id: params.payload.user_id,
1450
+ meta: { name: params.userName }
1451
+ });
1452
+ return { ephemeral_text: core.channel.pairing.buildPairingReply({
1453
+ channel: "mattermost",
1454
+ idLine: `Your Mattermost user id: ${params.payload.user_id}`,
1455
+ code
1456
+ }) };
1457
+ }
1458
+ return { ephemeral_text: auth.denyReason === "unknown-channel" ? "Temporary error: unable to determine channel type. Please try again." : auth.denyReason === "dm-disabled" ? "This bot is not accepting direct messages." : auth.denyReason === "channels-disabled" ? "Model picker actions are disabled in channels." : auth.denyReason === "channel-no-allowlist" ? "Model picker actions are not configured for this channel." : "Unauthorized." };
1459
+ }
1460
+ const kind = auth.kind;
1461
+ const chatType = auth.chatType;
1462
+ const teamId = auth.channelInfo.team_id ?? params.payload.team_id ?? void 0;
1463
+ const channelName = auth.channelName || void 0;
1464
+ const channelDisplay = auth.channelDisplay || auth.channelName || params.payload.channel_id;
1465
+ const roomLabel = auth.roomLabel;
1466
+ const route = core.channel.routing.resolveAgentRoute({
1467
+ cfg,
1468
+ channel: "mattermost",
1469
+ accountId: account.accountId,
1470
+ teamId,
1471
+ peer: {
1472
+ kind,
1473
+ id: kind === "direct" ? params.payload.user_id : params.payload.channel_id
1474
+ }
1475
+ });
1476
+ const replyToMode = resolveMattermostReplyToMode(account, kind);
1477
+ const threadContext = resolveMattermostThreadSessionContext({
1478
+ baseSessionKey: route.sessionKey,
1479
+ kind,
1480
+ postId: params.post.id || params.payload.post_id,
1481
+ replyToMode,
1482
+ threadRootId: params.post.root_id
1483
+ });
1484
+ const modelSessionRoute = {
1485
+ agentId: route.agentId,
1486
+ sessionKey: threadContext.sessionKey
1487
+ };
1488
+ const data = await buildModelsProviderData(cfg, route.agentId);
1489
+ if (data.providers.length === 0) return await updateModelPickerPost({
1490
+ channelId: params.payload.channel_id,
1491
+ postId: params.payload.post_id,
1492
+ message: "No models available."
1493
+ });
1494
+ if (pickerState.action === "providers" || pickerState.action === "back") {
1495
+ const currentModel = resolveMattermostModelPickerCurrentModel({
1496
+ cfg,
1497
+ route: modelSessionRoute,
1498
+ data
1499
+ });
1500
+ const view = renderMattermostProviderPickerView({
1501
+ ownerUserId: pickerState.ownerUserId,
1502
+ data,
1503
+ currentModel
1504
+ });
1505
+ return await updateModelPickerPost({
1506
+ channelId: params.payload.channel_id,
1507
+ postId: params.payload.post_id,
1508
+ message: view.text,
1509
+ buttons: view.buttons
1510
+ });
1511
+ }
1512
+ if (pickerState.action === "list") {
1513
+ const currentModel = resolveMattermostModelPickerCurrentModel({
1514
+ cfg,
1515
+ route: modelSessionRoute,
1516
+ data
1517
+ });
1518
+ const view = renderMattermostModelsPickerView({
1519
+ ownerUserId: pickerState.ownerUserId,
1520
+ data,
1521
+ provider: pickerState.provider,
1522
+ page: pickerState.page,
1523
+ currentModel
1524
+ });
1525
+ return await updateModelPickerPost({
1526
+ channelId: params.payload.channel_id,
1527
+ postId: params.payload.post_id,
1528
+ message: view.text,
1529
+ buttons: view.buttons
1530
+ });
1531
+ }
1532
+ const targetModelRef = `${pickerState.provider}/${pickerState.model}`;
1533
+ if (!buildMattermostAllowedModelRefs(data).has(targetModelRef)) return { ephemeral_text: `That model is no longer available: ${targetModelRef}` };
1534
+ (async () => {
1535
+ try {
1536
+ await runModelPickerCommand({
1537
+ commandText: `/model ${targetModelRef}`,
1538
+ commandAuthorized: auth.commandAuthorized,
1539
+ route,
1540
+ sessionKey: threadContext.sessionKey,
1541
+ parentSessionKey: threadContext.parentSessionKey,
1542
+ channelId: params.payload.channel_id,
1543
+ senderId: params.payload.user_id,
1544
+ senderName: params.userName,
1545
+ kind,
1546
+ chatType,
1547
+ channelName,
1548
+ channelDisplay,
1549
+ roomLabel,
1550
+ teamId,
1551
+ postId: params.payload.post_id,
1552
+ messageSid: buildMattermostModelPickerSelectMessageSid({
1553
+ postId: params.payload.post_id,
1554
+ provider: pickerState.provider,
1555
+ model: pickerState.model
1556
+ }),
1557
+ effectiveReplyToId: threadContext.effectiveReplyToId,
1558
+ deliverReplies: true
1559
+ });
1560
+ const updatedModel = resolveMattermostModelPickerCurrentModel({
1561
+ cfg,
1562
+ route: modelSessionRoute,
1563
+ data,
1564
+ skipCache: true
1565
+ });
1566
+ const view = renderMattermostModelsPickerView({
1567
+ ownerUserId: pickerState.ownerUserId,
1568
+ data,
1569
+ provider: pickerState.provider,
1570
+ page: pickerState.page,
1571
+ currentModel: updatedModel
1572
+ });
1573
+ await updateModelPickerPost({
1574
+ channelId: params.payload.channel_id,
1575
+ postId: params.payload.post_id,
1576
+ message: view.text,
1577
+ buttons: view.buttons
1578
+ });
1579
+ } catch (err) {
1580
+ runtime.error?.(`mattermost model picker select failed: ${String(err)}`);
1581
+ }
1582
+ })();
1583
+ return {};
1584
+ }
1585
+ const handlePost = async (post, payload, messageIds) => {
1586
+ const channelId = post.channel_id ?? payload.data?.channel_id ?? payload.broadcast?.channel_id;
1587
+ if (!channelId) {
1588
+ logVerboseMessage("mattermost: drop post (missing channel id)");
1589
+ return;
1590
+ }
1591
+ const allMessageIds = messageIds?.length ? messageIds : post.id ? [post.id] : [];
1592
+ if (allMessageIds.length === 0) {
1593
+ logVerboseMessage("mattermost: drop post (missing message id)");
1594
+ return;
1595
+ }
1596
+ if (await processMattermostReplayGuardedPost({
1597
+ accountId: account.accountId,
1598
+ messageIds: allMessageIds,
1599
+ handlePost: async () => {
1600
+ const senderId = post.user_id ?? payload.broadcast?.user_id;
1601
+ if (!senderId) {
1602
+ logVerboseMessage("mattermost: drop post (missing sender id)");
1603
+ return;
1604
+ }
1605
+ if (senderId === botUserId) {
1606
+ logVerboseMessage(`mattermost: drop post (self sender=${senderId})`);
1607
+ return;
1608
+ }
1609
+ if (isSystemPost(post)) {
1610
+ logVerboseMessage(`mattermost: drop post (system post type=${post.type ?? "unknown"})`);
1611
+ return;
1612
+ }
1613
+ const channelInfo = await resolveChannelInfo(channelId);
1614
+ const kind = mapMattermostChannelTypeToChatType(payload.data?.channel_type ?? channelInfo?.type ?? void 0);
1615
+ const chatType = channelChatType(kind);
1616
+ const senderName = normalizeOptionalString(payload.data?.sender_name) ?? normalizeOptionalString((await resolveUserInfo(senderId))?.username) ?? senderId;
1617
+ const rawText = normalizeOptionalString(post.message) ?? "";
1618
+ const dmPolicy = account.config.dmPolicy ?? "pairing";
1619
+ const normalizedAllowFrom = normalizeMattermostAllowList(account.config.allowFrom ?? []);
1620
+ const normalizedGroupAllowFrom = normalizeMattermostAllowList(account.config.groupAllowFrom ?? []);
1621
+ const storeAllowFrom = normalizeMattermostAllowList(await readStoreAllowFromForDmPolicy({
1622
+ provider: "mattermost",
1623
+ accountId: account.accountId,
1624
+ dmPolicy,
1625
+ readStore: pairing.readStoreForDmPolicy
1626
+ }));
1627
+ const accessDecision = resolveDmGroupAccessWithLists({
1628
+ isGroup: kind !== "direct",
1629
+ dmPolicy,
1630
+ groupPolicy,
1631
+ allowFrom: normalizedAllowFrom,
1632
+ groupAllowFrom: normalizedGroupAllowFrom,
1633
+ storeAllowFrom,
1634
+ isSenderAllowed: (allowFrom) => isMattermostSenderAllowed({
1635
+ senderId,
1636
+ senderName,
1637
+ allowFrom,
1638
+ allowNameMatching
1639
+ })
1640
+ });
1641
+ const effectiveAllowFrom = accessDecision.effectiveAllowFrom;
1642
+ const effectiveGroupAllowFrom = accessDecision.effectiveGroupAllowFrom;
1643
+ const allowTextCommands = core.channel.commands.shouldHandleTextCommands({
1644
+ cfg,
1645
+ surface: "mattermost"
1646
+ });
1647
+ const hasControlCommand = core.channel.text.hasControlCommand(rawText, cfg);
1648
+ const isControlCommand = allowTextCommands && hasControlCommand;
1649
+ const useAccessGroups = cfg.commands?.useAccessGroups !== false;
1650
+ const commandDmAllowFrom = kind === "direct" ? effectiveAllowFrom : normalizedAllowFrom;
1651
+ const senderAllowedForCommands = isMattermostSenderAllowed({
1652
+ senderId,
1653
+ senderName,
1654
+ allowFrom: commandDmAllowFrom,
1655
+ allowNameMatching
1656
+ });
1657
+ const groupAllowedForCommands = isMattermostSenderAllowed({
1658
+ senderId,
1659
+ senderName,
1660
+ allowFrom: effectiveGroupAllowFrom,
1661
+ allowNameMatching
1662
+ });
1663
+ const commandGate = resolveControlCommandGate({
1664
+ useAccessGroups,
1665
+ authorizers: [{
1666
+ configured: commandDmAllowFrom.length > 0,
1667
+ allowed: senderAllowedForCommands
1668
+ }, {
1669
+ configured: effectiveGroupAllowFrom.length > 0,
1670
+ allowed: groupAllowedForCommands
1671
+ }],
1672
+ allowTextCommands,
1673
+ hasControlCommand
1674
+ });
1675
+ const commandAuthorized = commandGate.commandAuthorized;
1676
+ if (accessDecision.decision !== "allow") {
1677
+ if (kind === "direct") {
1678
+ if (accessDecision.reasonCode === DM_GROUP_ACCESS_REASON.DM_POLICY_DISABLED) {
1679
+ logVerboseMessage(`mattermost: drop dm (dmPolicy=disabled sender=${senderId})`);
1680
+ return;
1681
+ }
1682
+ if (accessDecision.decision === "pairing") {
1683
+ const { code, created } = await pairing.upsertPairingRequest({
1684
+ id: senderId,
1685
+ meta: { name: senderName }
1686
+ });
1687
+ logVerboseMessage(`mattermost: pairing request sender=${senderId} created=${created}`);
1688
+ if (created) try {
1689
+ await sendMessageMattermost(`user:${senderId}`, core.channel.pairing.buildPairingReply({
1690
+ channel: "mattermost",
1691
+ idLine: `Your Mattermost user id: ${senderId}`,
1692
+ code
1693
+ }), {
1694
+ cfg,
1695
+ accountId: account.accountId
1696
+ });
1697
+ opts.statusSink?.({ lastOutboundAt: Date.now() });
1698
+ } catch (err) {
1699
+ logVerboseMessage(`mattermost: pairing reply failed for ${senderId}: ${String(err)}`);
1700
+ }
1701
+ return;
1702
+ }
1703
+ logVerboseMessage(`mattermost: drop dm sender=${senderId} (dmPolicy=${dmPolicy})`);
1704
+ return;
1705
+ }
1706
+ if (accessDecision.reasonCode === DM_GROUP_ACCESS_REASON.GROUP_POLICY_DISABLED) {
1707
+ logVerboseMessage("mattermost: drop group message (groupPolicy=disabled)");
1708
+ return;
1709
+ }
1710
+ if (accessDecision.reasonCode === DM_GROUP_ACCESS_REASON.GROUP_POLICY_EMPTY_ALLOWLIST) {
1711
+ logVerboseMessage("mattermost: drop group message (no group allowlist)");
1712
+ return;
1713
+ }
1714
+ if (accessDecision.reasonCode === DM_GROUP_ACCESS_REASON.GROUP_POLICY_NOT_ALLOWLISTED) {
1715
+ logVerboseMessage(`mattermost: drop group sender=${senderId} (not in groupAllowFrom)`);
1716
+ return;
1717
+ }
1718
+ logVerboseMessage(`mattermost: drop group message (groupPolicy=${groupPolicy} reason=${accessDecision.reason})`);
1719
+ return;
1720
+ }
1721
+ if (kind !== "direct" && commandGate.shouldBlock) {
1722
+ logInboundDrop({
1723
+ log: logVerboseMessage,
1724
+ channel: "mattermost",
1725
+ reason: "control command (unauthorized)",
1726
+ target: senderId
1727
+ });
1728
+ return;
1729
+ }
1730
+ const teamId = payload.data?.team_id ?? channelInfo?.team_id ?? void 0;
1731
+ const channelName = payload.data?.channel_name ?? channelInfo?.name ?? "";
1732
+ const channelDisplay = payload.data?.channel_display_name ?? channelInfo?.display_name ?? channelName;
1733
+ const roomLabel = channelName ? `#${channelName}` : channelDisplay || `#${channelId}`;
1734
+ const route = core.channel.routing.resolveAgentRoute({
1735
+ cfg,
1736
+ channel: "mattermost",
1737
+ accountId: account.accountId,
1738
+ teamId,
1739
+ peer: {
1740
+ kind,
1741
+ id: kind === "direct" ? senderId : channelId
1742
+ }
1743
+ });
1744
+ const baseSessionKey = route.sessionKey;
1745
+ const threadRootId = normalizeOptionalString(post.root_id);
1746
+ const replyToMode = resolveMattermostReplyToMode(account, kind);
1747
+ const { effectiveReplyToId, sessionKey, parentSessionKey } = resolveMattermostThreadSessionContext({
1748
+ baseSessionKey,
1749
+ kind,
1750
+ postId: post.id,
1751
+ replyToMode,
1752
+ threadRootId
1753
+ });
1754
+ const historyKey = kind === "direct" ? null : sessionKey;
1755
+ const mentionRegexes = core.channel.mentions.buildMentionRegexes(cfg, route.agentId);
1756
+ const wasMentioned = kind !== "direct" && ((botUsername ? normalizeLowercaseStringOrEmpty(rawText).includes(`@${normalizeLowercaseStringOrEmpty(botUsername)}`) : false) || core.channel.mentions.matchesMentionPatterns(rawText, mentionRegexes));
1757
+ const pendingBody = rawText || (post.file_ids?.length ? `[Mattermost ${post.file_ids.length === 1 ? "file" : "files"}]` : "");
1758
+ const pendingSender = senderName;
1759
+ const recordPendingHistory = () => {
1760
+ const trimmed = pendingBody.trim();
1761
+ recordPendingHistoryEntryIfEnabled({
1762
+ historyMap: channelHistories,
1763
+ limit: historyLimit,
1764
+ historyKey: historyKey ?? "",
1765
+ entry: historyKey && trimmed ? {
1766
+ sender: pendingSender,
1767
+ body: trimmed,
1768
+ timestamp: typeof post.create_at === "number" ? post.create_at : void 0,
1769
+ messageId: post.id ?? void 0
1770
+ } : null
1771
+ });
1772
+ };
1773
+ const oncharEnabled = account.chatmode === "onchar" && kind !== "direct";
1774
+ const oncharPrefixes = oncharEnabled ? resolveOncharPrefixes(account.oncharPrefixes) : [];
1775
+ const oncharResult = oncharEnabled ? stripOncharPrefix(rawText, oncharPrefixes) : {
1776
+ triggered: false,
1777
+ stripped: rawText
1778
+ };
1779
+ const oncharTriggered = oncharResult.triggered;
1780
+ const canDetectMention = Boolean(botUsername) || mentionRegexes.length > 0;
1781
+ const mentionDecision = evaluateMattermostMentionGate({
1782
+ kind,
1783
+ cfg,
1784
+ accountId: account.accountId,
1785
+ channelId,
1786
+ threadRootId,
1787
+ requireMentionOverride: account.requireMention,
1788
+ resolveRequireMention: core.channel.groups.resolveRequireMention,
1789
+ wasMentioned,
1790
+ isControlCommand,
1791
+ commandAuthorized,
1792
+ oncharEnabled,
1793
+ oncharTriggered,
1794
+ canDetectMention
1795
+ });
1796
+ const { shouldRequireMention, shouldBypassMention } = mentionDecision;
1797
+ if (mentionDecision.dropReason === "onchar-not-triggered") {
1798
+ logVerboseMessage(`mattermost: drop group message (onchar not triggered channel=${channelId} sender=${senderId})`);
1799
+ recordPendingHistory();
1800
+ return;
1801
+ }
1802
+ if (mentionDecision.dropReason === "missing-mention") {
1803
+ logVerboseMessage(`mattermost: drop group message (missing mention channel=${channelId} sender=${senderId} requireMention=${shouldRequireMention} bypass=${shouldBypassMention} canDetectMention=${canDetectMention})`);
1804
+ recordPendingHistory();
1805
+ return;
1806
+ }
1807
+ const mediaList = await resolveMattermostMedia(post.file_ids);
1808
+ const mediaPlaceholder = buildMattermostAttachmentPlaceholder(mediaList);
1809
+ const bodyText = normalizeMention([oncharTriggered ? oncharResult.stripped : rawText, mediaPlaceholder].filter(Boolean).join("\n").trim(), botUsername);
1810
+ if (!bodyText) {
1811
+ logVerboseMessage(`mattermost: drop group message (empty body after normalization channel=${channelId} sender=${senderId})`);
1812
+ return;
1813
+ }
1814
+ core.channel.activity.record({
1815
+ channel: "mattermost",
1816
+ accountId: account.accountId,
1817
+ direction: "inbound"
1818
+ });
1819
+ const fromLabel = formatInboundFromLabel({
1820
+ isGroup: kind !== "direct",
1821
+ groupLabel: channelDisplay || roomLabel,
1822
+ groupId: channelId,
1823
+ groupFallback: roomLabel || "Channel",
1824
+ directLabel: senderName,
1825
+ directId: senderId
1826
+ });
1827
+ const preview = bodyText.replace(/\s+/g, " ").slice(0, 160);
1828
+ const inboundLabel = kind === "direct" ? `Mattermost DM from ${senderName}` : `Mattermost message in ${roomLabel} from ${senderName}`;
1829
+ core.system.enqueueSystemEvent(`${inboundLabel}: ${preview}`, {
1830
+ sessionKey,
1831
+ contextKey: `mattermost:message:${channelId}:${post.id ?? "unknown"}`
1832
+ });
1833
+ const textWithId = `${bodyText}\n[mattermost message id: ${post.id ?? "unknown"} channel: ${channelId}]`;
1834
+ let combinedBody = core.channel.reply.formatInboundEnvelope({
1835
+ channel: "Mattermost",
1836
+ from: fromLabel,
1837
+ timestamp: typeof post.create_at === "number" ? post.create_at : void 0,
1838
+ body: textWithId,
1839
+ chatType,
1840
+ sender: {
1841
+ name: senderName,
1842
+ id: senderId
1843
+ }
1844
+ });
1845
+ if (historyKey) combinedBody = buildPendingHistoryContextFromMap({
1846
+ historyMap: channelHistories,
1847
+ historyKey,
1848
+ limit: historyLimit,
1849
+ currentMessage: combinedBody,
1850
+ formatEntry: (entry) => core.channel.reply.formatInboundEnvelope({
1851
+ channel: "Mattermost",
1852
+ from: fromLabel,
1853
+ timestamp: entry.timestamp,
1854
+ body: `${entry.body}${entry.messageId ? ` [id:${entry.messageId} channel:${channelId}]` : ""}`,
1855
+ chatType,
1856
+ senderLabel: entry.sender
1857
+ })
1858
+ });
1859
+ const to = kind === "direct" ? `user:${senderId}` : `channel:${channelId}`;
1860
+ const mediaPayload = buildAgentMediaPayload(mediaList);
1861
+ const commandBody = rawText.trim();
1862
+ const inboundHistory = historyKey && historyLimit > 0 ? (channelHistories.get(historyKey) ?? []).map((entry) => ({
1863
+ sender: entry.sender,
1864
+ body: entry.body,
1865
+ timestamp: entry.timestamp
1866
+ })) : void 0;
1867
+ const ctxPayload = core.channel.reply.finalizeInboundContext({
1868
+ Body: combinedBody,
1869
+ BodyForAgent: bodyText,
1870
+ InboundHistory: inboundHistory,
1871
+ RawBody: bodyText,
1872
+ CommandBody: commandBody,
1873
+ BodyForCommands: commandBody,
1874
+ From: kind === "direct" ? `mattermost:${senderId}` : kind === "group" ? `mattermost:group:${channelId}` : `mattermost:channel:${channelId}`,
1875
+ To: to,
1876
+ SessionKey: sessionKey,
1877
+ ParentSessionKey: parentSessionKey,
1878
+ AccountId: route.accountId,
1879
+ ChatType: chatType,
1880
+ ConversationLabel: fromLabel,
1881
+ GroupSubject: kind !== "direct" ? channelDisplay || roomLabel : void 0,
1882
+ GroupChannel: channelName ? `#${channelName}` : void 0,
1883
+ GroupSpace: teamId,
1884
+ SenderName: senderName,
1885
+ SenderId: senderId,
1886
+ Provider: "mattermost",
1887
+ Surface: "mattermost",
1888
+ MessageSid: post.id ?? void 0,
1889
+ MessageSids: allMessageIds.length > 1 ? allMessageIds : void 0,
1890
+ MessageSidFirst: allMessageIds.length > 1 ? allMessageIds[0] : void 0,
1891
+ MessageSidLast: allMessageIds.length > 1 ? allMessageIds[allMessageIds.length - 1] : void 0,
1892
+ ReplyToId: effectiveReplyToId,
1893
+ MessageThreadId: effectiveReplyToId,
1894
+ Timestamp: typeof post.create_at === "number" ? post.create_at : void 0,
1895
+ WasMentioned: kind !== "direct" ? mentionDecision.effectiveWasMentioned : void 0,
1896
+ CommandAuthorized: commandAuthorized,
1897
+ OriginatingChannel: "mattermost",
1898
+ OriginatingTo: to,
1899
+ ...mediaPayload
1900
+ });
1901
+ if (kind === "direct") {
1902
+ const sessionCfg = cfg.session;
1903
+ const storePath = core.channel.session.resolveStorePath(sessionCfg?.store, { agentId: route.agentId });
1904
+ await core.channel.session.updateLastRoute({
1905
+ storePath,
1906
+ sessionKey: route.mainSessionKey,
1907
+ deliveryContext: {
1908
+ channel: "mattermost",
1909
+ to,
1910
+ accountId: route.accountId
1911
+ }
1912
+ });
1913
+ }
1914
+ const previewLine = bodyText.slice(0, 200).replace(/\n/g, "\\n");
1915
+ logVerboseMessage(`mattermost inbound: from=${ctxPayload.From} len=${bodyText.length} preview="${previewLine}"`);
1916
+ const textLimit = core.channel.text.resolveTextChunkLimit(cfg, "mattermost", account.accountId, { fallbackLimit: account.textChunkLimit ?? 4e3 });
1917
+ const tableMode = core.channel.text.resolveMarkdownTableMode({
1918
+ cfg,
1919
+ channel: "mattermost",
1920
+ accountId: account.accountId
1921
+ });
1922
+ const { onModelSelected, typingCallbacks, ...replyPipeline } = createChannelReplyPipeline({
1923
+ cfg,
1924
+ agentId: route.agentId,
1925
+ channel: "mattermost",
1926
+ accountId: account.accountId,
1927
+ typing: {
1928
+ start: () => sendTypingIndicator(channelId, effectiveReplyToId),
1929
+ onStartError: (err) => {
1930
+ logTypingFailure({
1931
+ log: (message) => logger.debug?.(message),
1932
+ channel: "mattermost",
1933
+ target: channelId,
1934
+ error: err
1935
+ });
1936
+ }
1937
+ }
1938
+ });
1939
+ const draftStream = createMattermostDraftStream({
1940
+ client,
1941
+ channelId,
1942
+ rootId: effectiveReplyToId,
1943
+ throttleMs: 1200,
1944
+ log: logVerboseMessage,
1945
+ warn: logVerboseMessage
1946
+ });
1947
+ let lastPartialText = "";
1948
+ const previewState = { finalizedViaPreviewPost: false };
1949
+ const resolvePreviewFinalText = (text) => {
1950
+ if (typeof text !== "string") return;
1951
+ const formatted = core.channel.text.convertMarkdownTables(text, tableMode);
1952
+ const chunkMode = core.channel.text.resolveChunkMode(cfg, "mattermost", account.accountId);
1953
+ const chunks = core.channel.text.chunkMarkdownTextWithMode(formatted, textLimit, chunkMode);
1954
+ if (!chunks.length && formatted) chunks.push(formatted);
1955
+ if (chunks.length != 1) return;
1956
+ const trimmed = chunks[0]?.trim();
1957
+ if (!trimmed) return;
1958
+ if (lastPartialText && lastPartialText.startsWith(trimmed) && trimmed.length < lastPartialText.length) return;
1959
+ return trimmed;
1960
+ };
1961
+ const updateDraftFromPartial = (text) => {
1962
+ const cleaned = text?.trim();
1963
+ if (!cleaned) return;
1964
+ if (cleaned === lastPartialText) return;
1965
+ if (lastPartialText && lastPartialText.startsWith(cleaned) && cleaned.length < lastPartialText.length) return;
1966
+ lastPartialText = cleaned;
1967
+ draftStream.update(cleaned);
1968
+ };
1969
+ const { dispatcher, replyOptions, markDispatchIdle, markRunComplete } = core.channel.reply.createReplyDispatcherWithTyping({
1970
+ ...replyPipeline,
1971
+ humanDelay: core.channel.reply.resolveHumanDelayConfig(cfg, route.agentId),
1972
+ typingCallbacks,
1973
+ deliver: async (payload, info) => {
1974
+ await deliverMattermostReplyWithDraftPreview({
1975
+ payload,
1976
+ info,
1977
+ client,
1978
+ draftStream,
1979
+ effectiveReplyToId,
1980
+ resolvePreviewFinalText,
1981
+ previewState,
1982
+ logVerboseMessage,
1983
+ deliverFinal: async () => {
1984
+ await deliverMattermostReplyPayload({
1985
+ core,
1986
+ cfg,
1987
+ payload,
1988
+ to,
1989
+ accountId: account.accountId,
1990
+ agentId: route.agentId,
1991
+ replyToId: resolveMattermostReplyRootId({
1992
+ threadRootId: effectiveReplyToId,
1993
+ replyToId: payload.replyToId
1994
+ }),
1995
+ textLimit,
1996
+ tableMode,
1997
+ sendMessage: sendMessageMattermost
1998
+ });
1999
+ runtime.log?.(`delivered reply to ${to}`);
2000
+ }
2001
+ });
2002
+ },
2003
+ onError: (err, info) => {
2004
+ runtime.error?.(`mattermost ${info.kind} reply failed: ${String(err)}`);
2005
+ }
2006
+ });
2007
+ try {
2008
+ await core.channel.reply.withReplyDispatcher({
2009
+ dispatcher,
2010
+ onSettled: () => {
2011
+ markDispatchIdle();
2012
+ },
2013
+ run: () => core.channel.reply.dispatchReplyFromConfig({
2014
+ ctx: ctxPayload,
2015
+ cfg,
2016
+ dispatcher,
2017
+ replyOptions: {
2018
+ ...replyOptions,
2019
+ disableBlockStreaming: true,
2020
+ onModelSelected,
2021
+ onPartialReply: (payload) => {
2022
+ updateDraftFromPartial(payload.text);
2023
+ },
2024
+ onAssistantMessageStart: () => {
2025
+ lastPartialText = "";
2026
+ },
2027
+ onReasoningEnd: () => {
2028
+ lastPartialText = "";
2029
+ },
2030
+ onReasoningStream: async () => {
2031
+ if (!lastPartialText) draftStream.update("Thinking…");
2032
+ },
2033
+ onToolStart: async (payload) => {
2034
+ draftStream.update(buildMattermostToolStatusText(payload));
2035
+ }
2036
+ }
2037
+ })
2038
+ });
2039
+ } finally {
2040
+ try {
2041
+ await draftStream.stop();
2042
+ } catch (err) {
2043
+ logVerboseMessage(`mattermost draft preview cleanup failed: ${String(err)}`);
2044
+ }
2045
+ markRunComplete();
2046
+ }
2047
+ if (historyKey) clearHistoryEntriesIfEnabled({
2048
+ historyMap: channelHistories,
2049
+ historyKey,
2050
+ limit: historyLimit
2051
+ });
2052
+ }
2053
+ }) === "duplicate") {
2054
+ logVerboseMessage(`mattermost: drop post (dedupe account=${account.accountId} ids=${allMessageIds.length})`);
2055
+ return;
2056
+ }
2057
+ };
2058
+ const handleReactionEvent = async (payload) => {
2059
+ const reactionData = payload.data?.reaction;
2060
+ if (!reactionData) return;
2061
+ let reaction = null;
2062
+ if (typeof reactionData === "string") try {
2063
+ reaction = JSON.parse(reactionData);
2064
+ } catch {
2065
+ return;
2066
+ }
2067
+ else if (typeof reactionData === "object") reaction = reactionData;
2068
+ if (!reaction) return;
2069
+ const userId = reaction.user_id?.trim();
2070
+ const postId = reaction.post_id?.trim();
2071
+ const emojiName = reaction.emoji_name?.trim();
2072
+ if (!userId || !postId || !emojiName) return;
2073
+ if (userId === botUserId) return;
2074
+ const action = payload.event === "reaction_removed" ? "removed" : "added";
2075
+ const senderName = normalizeOptionalString((await resolveUserInfo(userId))?.username) ?? userId;
2076
+ const channelId = resolveMattermostReactionChannelId(payload);
2077
+ if (!channelId) {
2078
+ logVerboseMessage(`mattermost: drop reaction (no channel_id in broadcast, cannot enforce policy)`);
2079
+ return;
2080
+ }
2081
+ const channelInfo = await resolveChannelInfo(channelId);
2082
+ if (!channelInfo?.type) {
2083
+ logVerboseMessage(`mattermost: drop reaction (cannot resolve channel type for ${channelId})`);
2084
+ return;
2085
+ }
2086
+ const kind = mapMattermostChannelTypeToChatType(channelInfo.type);
2087
+ const dmPolicy = account.config.dmPolicy ?? "pairing";
2088
+ const storeAllowFrom = normalizeMattermostAllowList(await readStoreAllowFromForDmPolicy({
2089
+ provider: "mattermost",
2090
+ accountId: account.accountId,
2091
+ dmPolicy,
2092
+ readStore: pairing.readStoreForDmPolicy
2093
+ }));
2094
+ const reactionAccess = resolveDmGroupAccessWithLists({
2095
+ isGroup: kind !== "direct",
2096
+ dmPolicy,
2097
+ groupPolicy,
2098
+ allowFrom: normalizeMattermostAllowList(account.config.allowFrom ?? []),
2099
+ groupAllowFrom: normalizeMattermostAllowList(account.config.groupAllowFrom ?? []),
2100
+ storeAllowFrom,
2101
+ isSenderAllowed: (allowFrom) => isMattermostSenderAllowed({
2102
+ senderId: userId,
2103
+ senderName,
2104
+ allowFrom,
2105
+ allowNameMatching
2106
+ })
2107
+ });
2108
+ if (reactionAccess.decision !== "allow") {
2109
+ if (kind === "direct") logVerboseMessage(`mattermost: drop reaction (dmPolicy=${dmPolicy} sender=${userId} reason=${reactionAccess.reason})`);
2110
+ else logVerboseMessage(`mattermost: drop reaction (groupPolicy=${groupPolicy} sender=${userId} reason=${reactionAccess.reason} channel=${channelId})`);
2111
+ return;
2112
+ }
2113
+ const teamId = channelInfo?.team_id ?? void 0;
2114
+ const sessionKey = core.channel.routing.resolveAgentRoute({
2115
+ cfg,
2116
+ channel: "mattermost",
2117
+ accountId: account.accountId,
2118
+ teamId,
2119
+ peer: {
2120
+ kind,
2121
+ id: kind === "direct" ? userId : channelId
2122
+ }
2123
+ }).sessionKey;
2124
+ const eventText = `Mattermost reaction ${action}: :${emojiName}: by @${senderName} on post ${postId} in channel ${channelId}`;
2125
+ core.system.enqueueSystemEvent(eventText, {
2126
+ sessionKey,
2127
+ contextKey: `mattermost:reaction:${postId}:${emojiName}:${userId}:${action}`
2128
+ });
2129
+ logVerboseMessage(`mattermost reaction: ${action} :${emojiName}: by ${senderName} on ${postId}`);
2130
+ };
2131
+ const inboundDebounceMs = core.channel.debounce.resolveInboundDebounceMs({
2132
+ cfg,
2133
+ channel: "mattermost"
2134
+ });
2135
+ const debouncer = core.channel.debounce.createInboundDebouncer({
2136
+ debounceMs: inboundDebounceMs,
2137
+ buildKey: (entry) => {
2138
+ const channelId = entry.post.channel_id ?? entry.payload.data?.channel_id ?? entry.payload.broadcast?.channel_id;
2139
+ if (!channelId) return null;
2140
+ const threadId = normalizeOptionalString(entry.post.root_id);
2141
+ const threadKey = threadId ? `thread:${threadId}` : "channel";
2142
+ return `mattermost:${account.accountId}:${channelId}:${threadKey}`;
2143
+ },
2144
+ shouldDebounce: (entry) => {
2145
+ if (entry.post.file_ids && entry.post.file_ids.length > 0) return false;
2146
+ const text = normalizeOptionalString(entry.post.message) ?? "";
2147
+ if (!text) return false;
2148
+ return !core.channel.text.hasControlCommand(text, cfg);
2149
+ },
2150
+ onFlush: async (entries) => {
2151
+ const last = entries.at(-1);
2152
+ if (!last) return;
2153
+ if (entries.length === 1) {
2154
+ await handlePost(last.post, last.payload);
2155
+ return;
2156
+ }
2157
+ const combinedText = entries.map((entry) => normalizeOptionalString(entry.post.message) ?? "").filter(Boolean).join("\n");
2158
+ const mergedPost = {
2159
+ ...last.post,
2160
+ message: combinedText,
2161
+ file_ids: []
2162
+ };
2163
+ const ids = entries.map((entry) => entry.post.id).filter(Boolean);
2164
+ await handlePost(mergedPost, last.payload, ids.length > 0 ? ids : void 0);
2165
+ },
2166
+ onError: (err) => {
2167
+ runtime.error?.(`mattermost debounce flush failed: ${String(err)}`);
2168
+ }
2169
+ });
2170
+ const wsUrl = buildMattermostWsUrl(baseUrl);
2171
+ let seq = 1;
2172
+ const connectOnce = createMattermostConnectOnce({
2173
+ wsUrl,
2174
+ botToken,
2175
+ abortSignal: opts.abortSignal,
2176
+ statusSink: opts.statusSink,
2177
+ runtime,
2178
+ webSocketFactory: opts.webSocketFactory,
2179
+ nextSeq: () => seq++,
2180
+ getBotUpdateAt: async () => {
2181
+ return (await fetchMattermostMe(client)).update_at ?? 0;
2182
+ },
2183
+ onPosted: async (post, payload) => {
2184
+ await debouncer.enqueue({
2185
+ post,
2186
+ payload
2187
+ });
2188
+ },
2189
+ onReaction: async (payload) => {
2190
+ await handleReactionEvent(payload);
2191
+ }
2192
+ });
2193
+ let slashShutdownCleanup = null;
2194
+ if (slashEnabled) {
2195
+ const runAbortCleanup = () => {
2196
+ if (slashShutdownCleanup) return;
2197
+ const commands = getSlashCommandState(account.accountId)?.registeredCommands ?? [];
2198
+ deactivateSlashCommands(account.accountId);
2199
+ slashShutdownCleanup = cleanupSlashCommands({
2200
+ client,
2201
+ commands,
2202
+ log: (msg) => runtime.log?.(msg)
2203
+ }).catch((err) => {
2204
+ runtime.error?.(`mattermost: slash cleanup failed: ${String(err)}`);
2205
+ });
2206
+ };
2207
+ if (opts.abortSignal?.aborted) runAbortCleanup();
2208
+ else opts.abortSignal?.addEventListener("abort", runAbortCleanup, { once: true });
2209
+ }
2210
+ try {
2211
+ await runWithReconnect(connectOnce, {
2212
+ abortSignal: opts.abortSignal,
2213
+ jitterRatio: .2,
2214
+ onError: (err) => {
2215
+ runtime.error?.(`mattermost connection failed: ${String(err)}`);
2216
+ opts.statusSink?.({
2217
+ lastError: String(err),
2218
+ connected: false
2219
+ });
2220
+ },
2221
+ onReconnect: (delayMs) => {
2222
+ runtime.log?.(`mattermost reconnecting in ${Math.round(delayMs / 1e3)}s`);
2223
+ }
2224
+ });
2225
+ } finally {
2226
+ unregisterInteractions?.();
2227
+ }
2228
+ const slashShutdownCleanupPromise = slashShutdownCleanup;
2229
+ if (slashShutdownCleanupPromise) await Promise.resolve(slashShutdownCleanupPromise);
2230
+ }
2231
+ //#endregion
2232
+ //#region extensions/mattermost/src/mattermost/probe.ts
2233
+ async function probeMattermost(baseUrl, botToken, timeoutMs = 2500, allowPrivateNetwork = false) {
2234
+ const normalized = normalizeMattermostBaseUrl(baseUrl);
2235
+ if (!normalized) return {
2236
+ ok: false,
2237
+ error: "baseUrl missing"
2238
+ };
2239
+ const url = `${normalized}/api/v4/users/me`;
2240
+ const start = Date.now();
2241
+ const controller = timeoutMs > 0 ? new AbortController() : void 0;
2242
+ let timer = null;
2243
+ if (controller) timer = setTimeout(() => controller.abort(), timeoutMs);
2244
+ try {
2245
+ const { response: res, release } = await fetchWithSsrFGuard({
2246
+ url,
2247
+ init: {
2248
+ headers: { Authorization: `Bearer ${botToken}` },
2249
+ signal: controller?.signal
2250
+ },
2251
+ auditContext: "mattermost-probe",
2252
+ policy: ssrfPolicyFromPrivateNetworkOptIn(allowPrivateNetwork)
2253
+ });
2254
+ try {
2255
+ const elapsedMs = Date.now() - start;
2256
+ if (!res.ok) {
2257
+ const detail = await readMattermostError(res);
2258
+ return {
2259
+ ok: false,
2260
+ status: res.status,
2261
+ error: detail || res.statusText,
2262
+ elapsedMs
2263
+ };
2264
+ }
2265
+ const bot = await res.json();
2266
+ return {
2267
+ ok: true,
2268
+ status: res.status,
2269
+ elapsedMs,
2270
+ bot
2271
+ };
2272
+ } finally {
2273
+ await release();
2274
+ }
2275
+ } catch (err) {
2276
+ return {
2277
+ ok: false,
2278
+ status: null,
2279
+ error: formatErrorMessage(err),
2280
+ elapsedMs: Date.now() - start
2281
+ };
2282
+ } finally {
2283
+ if (timer) clearTimeout(timer);
2284
+ }
2285
+ }
2286
+ //#endregion
2287
+ //#region extensions/mattermost/src/mattermost/reactions.ts
2288
+ const BOT_USER_CACHE_TTL_MS = 10 * 6e4;
2289
+ const botUserIdCache = /* @__PURE__ */ new Map();
2290
+ async function resolveBotUserId(client, cacheKey) {
2291
+ const cached = botUserIdCache.get(cacheKey);
2292
+ if (cached && cached.expiresAt > Date.now()) return cached.userId;
2293
+ const userId = (await fetchMattermostMe(client))?.id?.trim();
2294
+ if (!userId) return null;
2295
+ botUserIdCache.set(cacheKey, {
2296
+ userId,
2297
+ expiresAt: Date.now() + BOT_USER_CACHE_TTL_MS
2298
+ });
2299
+ return userId;
2300
+ }
2301
+ async function addMattermostReaction(params) {
2302
+ return runMattermostReaction(params, {
2303
+ action: "add",
2304
+ mutation: createReaction
2305
+ });
2306
+ }
2307
+ async function removeMattermostReaction(params) {
2308
+ return runMattermostReaction(params, {
2309
+ action: "remove",
2310
+ mutation: deleteReaction
2311
+ });
2312
+ }
2313
+ async function runMattermostReaction(params, options) {
2314
+ const resolved = resolveMattermostAccount({
2315
+ cfg: params.cfg,
2316
+ accountId: params.accountId
2317
+ });
2318
+ const baseUrl = resolved.baseUrl?.trim();
2319
+ const botToken = resolved.botToken?.trim();
2320
+ if (!baseUrl || !botToken) return {
2321
+ ok: false,
2322
+ error: "Mattermost botToken/baseUrl missing."
2323
+ };
2324
+ const client = createMattermostClient({
2325
+ baseUrl,
2326
+ botToken,
2327
+ fetchImpl: params.fetchImpl,
2328
+ allowPrivateNetwork: isPrivateNetworkOptInEnabled(resolved.config)
2329
+ });
2330
+ const userId = await resolveBotUserId(client, `${baseUrl}:${botToken}`);
2331
+ if (!userId) return {
2332
+ ok: false,
2333
+ error: "Mattermost reactions failed: could not resolve bot user id."
2334
+ };
2335
+ try {
2336
+ await options.mutation(client, {
2337
+ userId,
2338
+ postId: params.postId,
2339
+ emojiName: params.emojiName
2340
+ });
2341
+ } catch (err) {
2342
+ return {
2343
+ ok: false,
2344
+ error: `Mattermost ${options.action} reaction failed: ${String(err)}`
2345
+ };
2346
+ }
2347
+ return { ok: true };
2348
+ }
2349
+ async function createReaction(client, params) {
2350
+ await client.request("/reactions", {
2351
+ method: "POST",
2352
+ body: JSON.stringify({
2353
+ user_id: params.userId,
2354
+ post_id: params.postId,
2355
+ emoji_name: params.emojiName
2356
+ })
2357
+ });
2358
+ }
2359
+ async function deleteReaction(client, params) {
2360
+ const emoji = encodeURIComponent(params.emojiName);
2361
+ await client.request(`/users/${params.userId}/posts/${params.postId}/reactions/${emoji}`, { method: "DELETE" });
2362
+ }
2363
+ //#endregion
2364
+ export { addMattermostReaction, listMattermostDirectoryGroups, listMattermostDirectoryPeers, monitorMattermostProvider, probeMattermost, removeMattermostReaction, resolveMattermostOpaqueTarget, sendMessageMattermost };