@pixelzx/genesis 2026.5.3-5 → 2026.5.5

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 (996) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/.buildstamp +1 -1
  3. package/dist/abort-t5XiT6Yl.js +201 -0
  4. package/dist/abort.runtime-C_xk0DkL.js +2 -0
  5. package/dist/abort.runtime.js +1 -1
  6. package/dist/accounts-B7yDKwxi.js +104 -0
  7. package/dist/accounts-CS7VL356.js +107 -0
  8. package/dist/accounts-XvHcAtMf.js +2 -0
  9. package/dist/acp-cli-B5H0nvID.js +2193 -0
  10. package/dist/acp-spawn-BRTMqPlq.js +2 -0
  11. package/dist/acp-spawn-Dsw3dzWY.js +1093 -0
  12. package/dist/acp-stateful-target-driver-BYhkJnyh.js +89 -0
  13. package/dist/action-agents-Ca9kTFvv.js +67 -0
  14. package/dist/action-focus-D4pT0hra.js +132 -0
  15. package/dist/action-help-DMzMxFEQ.js +7 -0
  16. package/dist/action-info-Dzn_fn6G.js +101 -0
  17. package/dist/action-kill-2AQuhnLy.js +33 -0
  18. package/dist/action-list-DI1M2pKU.js +21 -0
  19. package/dist/action-log-BVKGgOki.js +30 -0
  20. package/dist/action-send-CZ2wciMW.js +39 -0
  21. package/dist/action-spawn-BdclQLrK.js +47 -0
  22. package/dist/action-unfocus-DfQuRf8d.js +29 -0
  23. package/dist/actions.runtime-B2-oz_B6.js +5 -0
  24. package/dist/actions.runtime-BoUxrcw3.js +18 -0
  25. package/dist/actions.runtime.js +1 -1
  26. package/dist/agent-CnQ3yCIw.js +2 -0
  27. package/dist/agent-command-C4H_9c2N.js +874 -0
  28. package/dist/agent-harness-runtime-D2oXzgyL.js +144 -0
  29. package/dist/agent-runner-utils-CWgPcOYn.js +239 -0
  30. package/dist/agent-runner.runtime-DvK-HQhq.js +3455 -0
  31. package/dist/agent-runner.runtime.js +1 -1
  32. package/dist/agent-runtime-BDslXtCf.js +18 -0
  33. package/dist/agents-4T7YaeKy.js +953 -0
  34. package/dist/agents-C_Gty_RK.js +5 -0
  35. package/dist/aliases-BkVpehd-.js +96 -0
  36. package/dist/aliases-DWkJWJ5A.js +2 -0
  37. package/dist/api-CgW6fcU2.js +3 -0
  38. package/dist/api-DYPaGKUj.js +5 -0
  39. package/dist/api-DdoV90Cn.js +139 -0
  40. package/dist/approval-gateway-resolver-Ba_2kb3B.js +29 -0
  41. package/dist/approval-gateway-runtime-7VMivk0A.js +2 -0
  42. package/dist/approval-handler-runtime-DUDpOwG7.js +439 -0
  43. package/dist/approval-native-runtime-KkmX9gwQ.js +729 -0
  44. package/dist/attempt-execution.runtime-CQkeVpDx.js +509 -0
  45. package/dist/attempt-execution.runtime.js +1 -1
  46. package/dist/attempt.prompt-helpers-MoT6VaD0.js +221 -0
  47. package/dist/attempt.tool-run-context-B53GhX-d.js +933 -0
  48. package/dist/audit-CvHcVVb-.js +939 -0
  49. package/dist/audit.runtime-C7n442Rc.js +7 -0
  50. package/dist/audit.runtime.js +1 -1
  51. package/dist/auth-CAnSldtM.js +2 -0
  52. package/dist/auth-Czf_o5iE.js +383 -0
  53. package/dist/auth-order-Cu9Vj7lA.js +96 -0
  54. package/dist/auth-order-q1IFw7L3.js +2 -0
  55. package/dist/bash-tools-BS4TrA4X.js +2824 -0
  56. package/dist/bash-tools-DbHYuk8O.js +3 -0
  57. package/dist/binding-routing-CnNQE65Q.js +85 -0
  58. package/dist/binding-targets-DW0ScIRI.js +121 -0
  59. package/dist/bridge-server-BGS08n2f.js +113 -0
  60. package/dist/browser-control-auth-DMlQOsyN.js +2 -0
  61. package/dist/browser-node-runtime-CF32scUO.js +12 -0
  62. package/dist/browser-profiles-CmER65eh.js +2 -0
  63. package/dist/browser-runtime-D73M9fg3.js +387 -0
  64. package/dist/browser-setup-tools-Cr0UI1rf.js +13 -0
  65. package/dist/build-BL7WirDF.js +550 -0
  66. package/dist/build-info.json +3 -3
  67. package/dist/bundled/boot-md/handler.js +2 -2
  68. package/dist/bundled/session-memory/handler.js +1 -1
  69. package/dist/call-Ckws4Nlw.js +3 -0
  70. package/dist/call-DkGNVvLy.js +331 -0
  71. package/dist/call.runtime-DfLBtAIr.js +2 -0
  72. package/dist/call.runtime.js +1 -1
  73. package/dist/capability-cli-tSqSJf2o.js +1401 -0
  74. package/dist/catchup-Dp2L1RcY.js +300 -0
  75. package/dist/channel-BIFp1GJd.js +1320 -0
  76. package/dist/channel-BZMzoXhw.js +840 -0
  77. package/dist/channel-BtPZ0i4g.js +297 -0
  78. package/dist/channel-DDd7xwLG.js +226 -0
  79. package/dist/channel-DLezQPqR.js +350 -0
  80. package/dist/channel-DcYHXn_7.js +1100 -0
  81. package/dist/channel-DzKtLfJj.js +1802 -0
  82. package/dist/channel-LlY18tI5.js +595 -0
  83. package/dist/channel-NjZviHcJ.js +1174 -0
  84. package/dist/channel-core-Cg1mFpva.js +5 -0
  85. package/dist/channel-inbound-CZpi-vp5.js +31 -0
  86. package/dist/channel-pDXIWFS4.js +453 -0
  87. package/dist/channel-plugin-runtime-DHl81Ror.js +771 -0
  88. package/dist/channel-runtime-CtYrrwow.js +425 -0
  89. package/dist/channel-wMkGGyIY.js +491 -0
  90. package/dist/channel.runtime-B1n0hvUI.js +430 -0
  91. package/dist/channel.runtime-B9iR26l_.js +576 -0
  92. package/dist/channel.runtime-C8eBQk67.js +4 -0
  93. package/dist/channel.runtime-Db8g8JCg.js +89 -0
  94. package/dist/channel.runtime-DfRfisV2.js +34702 -0
  95. package/dist/channel.runtime-gPdBMu3V.js +109 -0
  96. package/dist/channel.runtime-rG9pJ5NO.js +2364 -0
  97. package/dist/channel.runtime.js +1 -1
  98. package/dist/channel.setup-CWblUOhD.js +10 -0
  99. package/dist/channels-B4dYRKsI.js +733 -0
  100. package/dist/channels-cli-GMAOUYU3.js +268 -0
  101. package/dist/chat-D2XaZNiP.js +2758 -0
  102. package/dist/clawbot-cli-CSmdcIMT.js +9 -0
  103. package/dist/cli/daemon-cli.js +3 -3
  104. package/dist/cli-2u5IZTMS.js +219 -0
  105. package/dist/cli-Bk8uXnyc.js +72 -0
  106. package/dist/cli-DBfw9jCz.js +2 -0
  107. package/dist/cli-runner-BEqvX1ky.js +286 -0
  108. package/dist/cli-runner.runtime-BIUcUGDa.js +4 -0
  109. package/dist/cli-runner.runtime-D2u3Yw0W.js +3 -0
  110. package/dist/cli-runner.runtime.js +1 -1
  111. package/dist/cli-startup-metadata.json +2 -2
  112. package/dist/cli-waH8839u.js +2 -0
  113. package/dist/cli.runtime-mKvJpLwI.js +1261 -0
  114. package/dist/cli.runtime.js +1 -1
  115. package/dist/client-CKizOsGp.js +138 -0
  116. package/dist/client-CrPccv7a.js +713 -0
  117. package/dist/command-auth-DPkjKHdv.js +76 -0
  118. package/dist/command-config-resolution-BTjtnAp2.js +2 -0
  119. package/dist/command-config-resolution-Be3KZA_l.js +23 -0
  120. package/dist/command-config-resolution.runtime-DXgL8cm7.js +2 -0
  121. package/dist/command-config-resolution.runtime.js +1 -1
  122. package/dist/command-registry-BL1Z4Cen.js +4 -0
  123. package/dist/command-registry-BMePAw9w.js +9 -0
  124. package/dist/command-registry-core-CAay55-n.js +104 -0
  125. package/dist/command-secret-gateway-jj1Qmk9L.js +528 -0
  126. package/dist/command-status.runtime-BVcCm9_0.js +87 -0
  127. package/dist/command-status.runtime.js +1 -1
  128. package/dist/commands-acp-COdUW69f.js +77 -0
  129. package/dist/commands-compact.runtime-C0Fedews.js +10 -0
  130. package/dist/commands-compact.runtime.js +1 -1
  131. package/dist/commands-handlers.runtime-BXVM3PWG.js +4597 -0
  132. package/dist/commands-handlers.runtime.js +1 -1
  133. package/dist/commands-status-DaApOLoQ.js +16 -0
  134. package/dist/commands-status.runtime-CxSjrKne.js +3 -0
  135. package/dist/commands-status.runtime.js +1 -1
  136. package/dist/commands-subagents-control.runtime-BEfW44br.js +2 -0
  137. package/dist/commands-subagents-control.runtime-DB3AROHI.js +3 -0
  138. package/dist/commands-subagents-control.runtime.js +1 -1
  139. package/dist/commands-system-prompt-CCrUy7xq.js +158 -0
  140. package/dist/commands-system-prompt-CN56TtaC.js +2 -0
  141. package/dist/commands.runtime-Bee6dM3V.js +166 -0
  142. package/dist/commands.runtime.js +1 -1
  143. package/dist/compact-7YtEe1kG.js +1118 -0
  144. package/dist/compact.runtime-4gW_cs7D.js +12 -0
  145. package/dist/compact.runtime.js +1 -1
  146. package/dist/completion-cli-COv-r8_h.js +313 -0
  147. package/dist/config-DSsLlg8J.js +251 -0
  148. package/dist/config-cli-C9oGe9gl.js +1078 -0
  149. package/dist/configure-Bfy9tVmS.js +2 -0
  150. package/dist/configure-DpIFRaAD.js +1245 -0
  151. package/dist/connect-options-CPixzqP_.js +699 -0
  152. package/dist/control-auth-L7U2ivRJ.js +125 -0
  153. package/dist/control-service-CbUz8qU5.js +156 -0
  154. package/dist/conversation-id-BroDIGeT.js +38 -0
  155. package/dist/conversation-id-CuVi0tWe.js +235 -0
  156. package/dist/conversation-runtime-weaahZQN.js +31 -0
  157. package/dist/core-PXv1nsc-.js +275 -0
  158. package/dist/cron-cli-DZNSQBuA.js +713 -0
  159. package/dist/daemon-cli-C_9CNoZA.js +12 -0
  160. package/dist/delegate-B8wh-jjf.js +64 -0
  161. package/dist/detached-task-runtime-BTq-jIGw.js +73 -0
  162. package/dist/devices-cli-C_amY-AS.js +496 -0
  163. package/dist/diagnostics-Bw-fd0ug.js +154 -0
  164. package/dist/direct-dm-Dvqjch3O.js +64 -0
  165. package/dist/dispatch-DHPQS49Q.js +1131 -0
  166. package/dist/dispatch-acp-manager.runtime-y-oykPUz.js +3 -0
  167. package/dist/dispatch-acp-manager.runtime.js +1 -1
  168. package/dist/dispatch-acp-taSuJD5W.js +981 -0
  169. package/dist/dispatch-acp.runtime-DgyaFFNX.js +19 -0
  170. package/dist/dispatch-acp.runtime.js +1 -1
  171. package/dist/doctor-device-pairing-rxwogzYF.js +307 -0
  172. package/dist/doctor-gateway-daemon-flow-Dm4wxnTt.js +250 -0
  173. package/dist/doctor-gateway-health-wJVW5xUW.js +60 -0
  174. package/dist/doctor-health-DaodspKU.js +59 -0
  175. package/dist/doctor-health-contributions-CBVyN6ju.js +486 -0
  176. package/dist/doctor-prompter-vO6LPeXZ.js +56 -0
  177. package/dist/doctor-workspace-status-BnXA04-6.js +75 -0
  178. package/dist/dreaming-1RLie1iF.js +1574 -0
  179. package/dist/dreaming-narrative-BRtTdpbt.js +595 -0
  180. package/dist/embedded-gateway-stub.runtime-GMix51Tf.js +9 -0
  181. package/dist/embedded-gateway-stub.runtime.js +1 -1
  182. package/dist/entry.js +2 -2
  183. package/dist/exec-approvals-cli-R6jgupQH.js +498 -0
  184. package/dist/extensionAPI.js +1 -1
  185. package/dist/extensions/active-memory/index.js +1 -1
  186. package/dist/extensions/bluebubbles/api.js +3 -3
  187. package/dist/extensions/bluebubbles/channel-plugin-api.js +1 -1
  188. package/dist/extensions/browser/browser-bridge.js +1 -1
  189. package/dist/extensions/browser/browser-config.js +4 -4
  190. package/dist/extensions/browser/browser-control-auth.js +2 -2
  191. package/dist/extensions/browser/browser-doctor.js +2 -2
  192. package/dist/extensions/browser/browser-maintenance.js +2 -2
  193. package/dist/extensions/browser/browser-profiles.js +2 -2
  194. package/dist/extensions/browser/browser-runtime-api.js +10 -10
  195. package/dist/extensions/browser/index.js +1 -1
  196. package/dist/extensions/browser/plugin-registration.js +1 -1
  197. package/dist/extensions/browser/register.runtime.js +3 -3
  198. package/dist/extensions/browser/runtime-api.js +11 -11
  199. package/dist/extensions/browser/test-support.js +1 -1
  200. package/dist/extensions/device-pair/api.js +1 -1
  201. package/dist/extensions/device-pair/index.js +3 -3
  202. package/dist/extensions/device-pair/notify.js +1 -1
  203. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  204. package/dist/extensions/google-meet/index.js +2 -2
  205. package/dist/extensions/imessage/api.js +3 -3
  206. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  207. package/dist/extensions/imessage/runtime-api.js +3 -3
  208. package/dist/extensions/irc/api.js +2 -2
  209. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  210. package/dist/extensions/line/api.js +2 -2
  211. package/dist/extensions/line/channel-plugin-api.js +1 -1
  212. package/dist/extensions/line/contract-api.js +1 -1
  213. package/dist/extensions/line/runtime-api.js +4 -4
  214. package/dist/extensions/line/setup-api.js +1 -1
  215. package/dist/extensions/llm-task/index.js +2 -2
  216. package/dist/extensions/lobster/index.js +3 -3
  217. package/dist/extensions/lobster/runtime-api.js +1 -1
  218. package/dist/extensions/mattermost/api.js +1 -1
  219. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  220. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  221. package/dist/extensions/mattermost/policy-api.js +1 -1
  222. package/dist/extensions/mattermost/runtime-api.js +4 -4
  223. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  224. package/dist/extensions/memory-core/api.js +1 -1
  225. package/dist/extensions/memory-core/cli-metadata.js +2 -2
  226. package/dist/extensions/memory-core/index.js +3 -3
  227. package/dist/extensions/memory-lancedb/cli-metadata.js +1 -1
  228. package/dist/extensions/msteams/api.js +1 -1
  229. package/dist/extensions/msteams/channel-plugin-api.js +1 -1
  230. package/dist/extensions/msteams/runtime-api.js +3 -3
  231. package/dist/extensions/msteams/test-api.js +1 -1
  232. package/dist/extensions/nextcloud-talk/api.js +1 -1
  233. package/dist/extensions/nextcloud-talk/channel-plugin-api.js +1 -1
  234. package/dist/extensions/nextcloud-talk/runtime-api.js +2 -2
  235. package/dist/extensions/openshell/index.js +2 -2
  236. package/dist/extensions/signal/api.js +6 -6
  237. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  238. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  239. package/dist/extensions/signal/runtime-api.js +7 -7
  240. package/dist/extensions/skill-workshop/api.js +1 -1
  241. package/dist/extensions/skill-workshop/index.js +1 -1
  242. package/dist/extensions/synology-chat/api.js +1 -1
  243. package/dist/extensions/synology-chat/channel-plugin-api.js +1 -1
  244. package/dist/extensions/tlon/api.js +2 -2
  245. package/dist/extensions/tlon/channel-plugin-api.js +1 -1
  246. package/dist/extensions/tlon/runtime-api.js +1 -1
  247. package/dist/extensions/tlon/test-api.js +1 -1
  248. package/dist/extensions/twitch/api.js +1 -1
  249. package/dist/extensions/twitch/channel-plugin-api.js +1 -1
  250. package/dist/extensions/twitch/setup-plugin-api.js +1 -1
  251. package/dist/extensions/zalo/api.js +3 -3
  252. package/dist/extensions/zalo/channel-plugin-api.js +1 -1
  253. package/dist/extensions/zalo/runtime-api.js +2 -2
  254. package/dist/extensions/zalo/setup-api.js +2 -2
  255. package/dist/extensions/zalouser/api.js +3 -3
  256. package/dist/extensions/zalouser/channel-plugin-api.js +1 -1
  257. package/dist/extensions/zalouser/runtime-api.js +6 -6
  258. package/dist/extensions/zalouser/setup-plugin-api.js +1 -1
  259. package/dist/extensions/zalouser/test-api.js +1 -1
  260. package/dist/fallbacks-Cckv3nng.js +2 -0
  261. package/dist/fallbacks-Y_nNY8_a.js +31 -0
  262. package/dist/fallbacks-shared-DZiG1Gr_.js +111 -0
  263. package/dist/gateway-CDfn0J87.js +115 -0
  264. package/dist/gateway-cli-D197U6l0.js +1325 -0
  265. package/dist/gateway-rpc-Bomz8HKq.js +14 -0
  266. package/dist/gateway-rpc.runtime-597tksmo.js +23 -0
  267. package/dist/gateway-rpc.runtime.js +1 -1
  268. package/dist/gateway-runtime-Bm2_MhFn.js +15 -0
  269. package/dist/gateway-status-Cr4UJKUx.js +584 -0
  270. package/dist/genesis-tools-DCRaVVjY.js +8999 -0
  271. package/dist/genesis-tools.runtime-idgd5fjy.js +2 -0
  272. package/dist/genesis-tools.runtime.js +1 -1
  273. package/dist/get-reply-BF_7bR5f.js +3879 -0
  274. package/dist/get-reply-from-config.runtime-DEq5XM_s.js +2 -0
  275. package/dist/get-reply-from-config.runtime.js +1 -1
  276. package/dist/graph-users-Bhlw-_4i.js +1337 -0
  277. package/dist/health-9ifMvGZN.js +3 -0
  278. package/dist/health-CzOJa6SX.js +469 -0
  279. package/dist/heartbeat-runner-B2Tkbj5e.js +5 -0
  280. package/dist/heartbeat-runner-B63G8dbO.js +1292 -0
  281. package/dist/heartbeat-runner.runtime-QJ_2AMjN.js +4 -0
  282. package/dist/heartbeat-runner.runtime.js +1 -1
  283. package/dist/hooks-cli-ZWI1iJnh.js +433 -0
  284. package/dist/image-fallbacks-BpTfBvbi.js +2 -0
  285. package/dist/image-fallbacks-DpVwnB41.js +31 -0
  286. package/dist/inbound-reply-dispatch-mKybIcNA.js +73 -0
  287. package/dist/index.js +2 -2
  288. package/dist/infra-runtime-CvwvzUfM.js +39 -0
  289. package/dist/init-CWeM0DfJ.js +59 -0
  290. package/dist/library-ClQalZ3x.js +45 -0
  291. package/dist/lifecycle-CgV7Cgt-.js +571 -0
  292. package/dist/lifecycle-DVWaxj-A.js +229 -0
  293. package/dist/lifecycle.runtime-DErLwVJ_.js +2 -0
  294. package/dist/lifecycle.runtime.js +1 -1
  295. package/dist/list-5RIS3LMG.js +2 -0
  296. package/dist/list-BNesYDN2.js +2 -0
  297. package/dist/list-Dk1hCKis.js +1201 -0
  298. package/dist/list-eUjt_6__.js +131 -0
  299. package/dist/list.probe-C51ceJSY.js +419 -0
  300. package/dist/llm-slug-generator-D64IMUoy.js +79 -0
  301. package/dist/llm-slug-generator.js +1 -1
  302. package/dist/load-config-Ccss2uTi.js +35 -0
  303. package/dist/local-dispatch.runtime-u7Ir1N07.js +8 -0
  304. package/dist/local-dispatch.runtime.js +1 -1
  305. package/dist/logs-cli-BYHTboPa.js +265 -0
  306. package/dist/logs-cli.runtime-CQwNptr-.js +2 -0
  307. package/dist/logs-cli.runtime.js +1 -1
  308. package/dist/main-session-restart-recovery-CA9bvC1W.js +206 -0
  309. package/dist/managed-image-attachments-B_gpkI1u.js +635 -0
  310. package/dist/managed-image-attachments-C0Y6nAP2.js +2 -0
  311. package/dist/manager-DZGFArgz.js +2 -0
  312. package/dist/manager-Df8TC4rX.js +2057 -0
  313. package/dist/markdown-to-line-xXLdnzcE.js +790 -0
  314. package/dist/mcp/plugin-tools-serve.js +1 -1
  315. package/dist/mcp-cli-B50W9Pkc.js +725 -0
  316. package/dist/mcp-http-BiUGVpJ4.js +529 -0
  317. package/dist/memory-core-host-runtime-cli-UgLo6ezC.js +9 -0
  318. package/dist/message-C95gttLd.js +232 -0
  319. package/dist/message-action-runner-0KAp6ccG.js +1407 -0
  320. package/dist/message-action-runner-BSUDvECO.js +2 -0
  321. package/dist/message-actions-Be4Ob151.js +143 -0
  322. package/dist/message.gateway.runtime-DMMRMIln.js +2 -0
  323. package/dist/message.gateway.runtime.js +1 -1
  324. package/dist/models-auth-status-DhYxBz7G.js +201 -0
  325. package/dist/models-cli-C2prinXb.js +219 -0
  326. package/dist/monitor-BEI21vNQ.js +1661 -0
  327. package/dist/monitor-BUgTAJvZ.js +1237 -0
  328. package/dist/monitor-BdJRIhi1.js +2 -0
  329. package/dist/monitor-C7wuttQJ.js +1459 -0
  330. package/dist/monitor-DMumiWnt.js +788 -0
  331. package/dist/monitor-IQo2ExmV.js +671 -0
  332. package/dist/monitor-auth-DW0lvfm3.js +207 -0
  333. package/dist/monitor-processing-DTrsRdyz.js +1974 -0
  334. package/dist/monitor.runtime-DwqyCQcb.js +2 -0
  335. package/dist/monitor.runtime.js +1 -1
  336. package/dist/monitor.webhook-D11nrUh9.js +180 -0
  337. package/dist/msteams-DO-PW98M.js +35 -0
  338. package/dist/native-hook-relay-CNZrcPIw.js +519 -0
  339. package/dist/nextcloud-talk-BeYFnATY.js +17 -0
  340. package/dist/node-cli-BFrdTPdH.js +2506 -0
  341. package/dist/nodes-cli-B3Wj_MvP.js +1046 -0
  342. package/dist/nodes-utils-AsgrCa7K.js +84 -0
  343. package/dist/nodes.helpers-CMXxavTs.js +34 -0
  344. package/dist/notify-CNS0kRWM.js +315 -0
  345. package/dist/onboard-D4ehf66t.js +632 -0
  346. package/dist/onboard-helpers-DWxdMyCs.js +6 -0
  347. package/dist/onboard-helpers-o78s0lR1.js +204 -0
  348. package/dist/onboard-remote-Cc1XlRzr.js +193 -0
  349. package/dist/onboard-remote-D8THwo3P.js +2 -0
  350. package/dist/onboard-skills-B2VoCq7v.js +134 -0
  351. package/dist/onboard-skills-DtOgSJZo.js +2 -0
  352. package/dist/openai-http-DKQZWsqY.js +500 -0
  353. package/dist/openresponses-http-C4kol41X.js +1128 -0
  354. package/dist/operator-approvals-client-BoN_VmkB.js +68 -0
  355. package/dist/outbound.runtime-D-L8FN8E.js +2 -0
  356. package/dist/outbound.runtime.js +1 -1
  357. package/dist/pair-command-approve-DMeQ6uD4.js +44 -0
  358. package/dist/persistent-bindings.lifecycle-O-RnoTW4.js +2 -0
  359. package/dist/persistent-bindings.lifecycle-bptWQEFT.js +85 -0
  360. package/dist/pi-embedded-BM79sXqb.js +2905 -0
  361. package/dist/pi-embedded-BUDWcDt8.js +4 -0
  362. package/dist/pi-embedded.runtime-D53bCPOr.js +4 -0
  363. package/dist/pi-embedded.runtime.js +1 -1
  364. package/dist/pi-tool-definition-adapter-DdYQtumi.js +217 -0
  365. package/dist/pi-tools-ihbjTP0K.js +1057 -0
  366. package/dist/pi-tools.before-tool-call-DrEqr96j.js +433 -0
  367. package/dist/pi-tools.before-tool-call-VB9YEPOv.js +2 -0
  368. package/dist/plugin-DwNULpmw.js +12195 -0
  369. package/dist/plugin-enabled-DbO9GyRJ.js +140 -0
  370. package/dist/plugin-registration-Du6hgUkp.js +23 -0
  371. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  372. package/dist/plugin-sdk/acp-binding-runtime.js +1 -1
  373. package/dist/plugin-sdk/acp-runtime.js +2 -2
  374. package/dist/plugin-sdk/agent-harness-runtime.js +5 -5
  375. package/dist/plugin-sdk/agent-harness.js +6 -6
  376. package/dist/plugin-sdk/agent-runtime.js +2 -2
  377. package/dist/plugin-sdk/approval-gateway-runtime.js +2 -2
  378. package/dist/plugin-sdk/approval-handler-runtime.js +3 -3
  379. package/dist/plugin-sdk/approval-runtime.js +1 -1
  380. package/dist/plugin-sdk/browser-node-runtime.js +4 -4
  381. package/dist/plugin-sdk/browser-setup-tools.js +3 -3
  382. package/dist/plugin-sdk/browser-support.js +7 -7
  383. package/dist/plugin-sdk/channel-core.js +2 -2
  384. package/dist/plugin-sdk/channel-inbound.js +2 -2
  385. package/dist/plugin-sdk/command-auth.js +1 -1
  386. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  387. package/dist/plugin-sdk/compat.js +1 -1
  388. package/dist/plugin-sdk/conversation-binding-runtime.js +1 -1
  389. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  390. package/dist/plugin-sdk/core.js +2 -2
  391. package/dist/plugin-sdk/direct-dm.js +1 -1
  392. package/dist/plugin-sdk/gateway-runtime.js +3 -3
  393. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  394. package/dist/plugin-sdk/index.js +1 -1
  395. package/dist/plugin-sdk/infra-runtime.js +2 -2
  396. package/dist/plugin-sdk/irc.js +2 -2
  397. package/dist/plugin-sdk/matrix.js +1 -1
  398. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +2 -2
  399. package/dist/plugin-sdk/memory-core.js +2 -2
  400. package/dist/plugin-sdk/msteams.js +2 -2
  401. package/dist/plugin-sdk/nextcloud-talk.js +2 -2
  402. package/dist/plugin-sdk/nostr.js +1 -1
  403. package/dist/plugin-sdk/reply-dispatch-runtime.js +1 -1
  404. package/dist/plugin-sdk/reply-runtime.js +4 -4
  405. package/dist/plugin-sdk/runtime-secret-resolution.js +1 -1
  406. package/dist/plugin-sdk/runtime.js +2 -2
  407. package/dist/plugin-sdk/session-visibility.js +1 -1
  408. package/dist/plugin-sdk/testing.js +4 -4
  409. package/dist/plugin-sdk/tlon.js +1 -1
  410. package/dist/plugin-sdk/zalo.js +1 -1
  411. package/dist/plugin-sdk/zalouser.js +1 -1
  412. package/dist/plugin-service-DcSnRF5x.js +2890 -0
  413. package/dist/plugins/runtime/index.js +1 -1
  414. package/dist/policy-uc224usV.js +328 -0
  415. package/dist/postinstall-inventory.json +407 -407
  416. package/dist/prepare.runtime-BPA6jMiM.js +815 -0
  417. package/dist/prepare.runtime.js +1 -1
  418. package/dist/probe-5ToseFjd.js +1443 -0
  419. package/dist/probe-BdCXAH_u.js +2 -0
  420. package/dist/probe-ByVoZEdq.js +45 -0
  421. package/dist/probe-D-D_1oc4.js +241 -0
  422. package/dist/probe-D6s_1Z5k.js +2 -0
  423. package/dist/probe-DIMAmSsO.js +74 -0
  424. package/dist/probe-DYuL-s4A.js +2205 -0
  425. package/dist/program-DDTWTh6g.js +111 -0
  426. package/dist/prompt-select-styled-kf1dPqNa.js +20 -0
  427. package/dist/protocol-Batc2DmY.js +2234 -0
  428. package/dist/provider-dispatcher-DdUqCa6H.js +2 -0
  429. package/dist/provider-dispatcher-uioW38XW.js +22 -0
  430. package/dist/qr-cli-B1WUe8Eb.js +2 -0
  431. package/dist/qr-cli-DmPti3xe.js +349 -0
  432. package/dist/reaction-runtime-api-5G3e9J0C.js +116 -0
  433. package/dist/reactions-x7VH-B95.js +998 -0
  434. package/dist/register-service-commands-DcW5qPTu.js +71 -0
  435. package/dist/register.agent-Dtj4HC7R.js +248 -0
  436. package/dist/register.configure-CJHb84Ce.js +15 -0
  437. package/dist/register.maintenance-BUkPfMcX.js +438 -0
  438. package/dist/register.message-DGFpyYBl.js +329 -0
  439. package/dist/register.onboard-D3v3xIfF.js +81 -0
  440. package/dist/register.runtime-DI4QxYdj.js +81 -0
  441. package/dist/register.runtime.js +1 -1
  442. package/dist/register.setup-CXTyuIFM.js +150 -0
  443. package/dist/register.status-health-sessions-CYUnRi97.js +1215 -0
  444. package/dist/register.subclis-DKMVrwRc.js +3 -0
  445. package/dist/register.subclis-NWRi2XKp.js +29 -0
  446. package/dist/register.subclis-core-De6qmQkr.js +243 -0
  447. package/dist/reply-dispatch-runtime-B8_j6pJi.js +13 -0
  448. package/dist/reply-runtime-DGHQDC9d.js +11 -0
  449. package/dist/reply.runtime-BCfqw2Co.js +2 -0
  450. package/dist/reply.runtime.js +1 -1
  451. package/dist/restart-health-6cjrRBpF.js +202 -0
  452. package/dist/restart-health-b6Qw43Tj.js +2 -0
  453. package/dist/root-help-BTIH_eUe.js +44 -0
  454. package/dist/routes-C3J2GfHR.js +3341 -0
  455. package/dist/routes-SMmfW6k8.js +2 -0
  456. package/dist/rpc-DQbAcIKu.js +61 -0
  457. package/dist/rpc.runtime-Q3qyofLf.js +21 -0
  458. package/dist/rpc.runtime.js +1 -1
  459. package/dist/run-delivery.runtime-BsLouK3f.js +530 -0
  460. package/dist/run-delivery.runtime.js +1 -1
  461. package/dist/run-embedded.runtime-CXd0oZQP.js +4 -0
  462. package/dist/run-embedded.runtime.js +1 -1
  463. package/dist/run-execution-cli.runtime-D-MKbq8r.js +4 -0
  464. package/dist/run-execution-cli.runtime.js +1 -1
  465. package/dist/run-executor.runtime-Cz0I8mDt.js +277 -0
  466. package/dist/run-executor.runtime.js +1 -1
  467. package/dist/run-main-CkXBTQut.js +516 -0
  468. package/dist/run-subagent-registry.runtime-Cyb8amrH.js +2 -0
  469. package/dist/run-subagent-registry.runtime.js +1 -1
  470. package/dist/run-wait-KlS0pdIK.js +135 -0
  471. package/dist/runtime-3niXLiFY.js +9 -0
  472. package/dist/runtime-api-B79e2jL2.js +4 -0
  473. package/dist/runtime-api-CM2c2bSC.js +9 -0
  474. package/dist/runtime-api-CnOFFN5q.js +14 -0
  475. package/dist/runtime-api-TnwM-EZH.js +9 -0
  476. package/dist/runtime-embedded-pi.runtime-9csGjukF.js +2 -0
  477. package/dist/runtime-embedded-pi.runtime.js +1 -1
  478. package/dist/runtime-internal-CQX4Zehn.js +2 -0
  479. package/dist/runtime-options-C0qP2VlT.js +275 -0
  480. package/dist/runtime-schema-DanWbDoL.js +27780 -0
  481. package/dist/runtime-vycfMfew.js +973 -0
  482. package/dist/scan-Bs5zROOQ.js +2 -0
  483. package/dist/scan-CP2zJb_w.js +523 -0
  484. package/dist/secrets-cli-YFTlIMmq.js +2101 -0
  485. package/dist/security-cli-B2WBRU9C.js +486 -0
  486. package/dist/selection-DSZGsU6m.js +2 -0
  487. package/dist/selection-hUGDnCgX.js +7736 -0
  488. package/dist/send-B3Ygb3r3.js +156 -0
  489. package/dist/send-DMwqnu6K.js +102 -0
  490. package/dist/send.runtime-D86atcfW.js +2 -0
  491. package/dist/send.runtime.js +1 -1
  492. package/dist/server-4gQCBM3M.js +77 -0
  493. package/dist/server-CK9eCPCG.js +13 -0
  494. package/dist/server-context-ih3GaGaI.js +847 -0
  495. package/dist/server-context-kZ_QADic.js +2 -0
  496. package/dist/server-node-events-CMlHOIKa.js +481 -0
  497. package/dist/server-plugin-bootstrap-B0XitldT.js +11333 -0
  498. package/dist/server-plugin-bootstrap-CHlVF8XB.js +2 -0
  499. package/dist/server-restart-sentinel-TpXCoiYX.js +697 -0
  500. package/dist/server.impl-B6at3Orl.js +12734 -0
  501. package/dist/session-kill-http-DvYp5h-j.js +110 -0
  502. package/dist/session-reset-service-C9rIVqF7.js +471 -0
  503. package/dist/session-route-FaMcEc7I.js +93 -0
  504. package/dist/session-status.runtime-BfPn8qA8.js +2 -0
  505. package/dist/session-status.runtime.js +1 -1
  506. package/dist/session-subagent-reactivation.runtime-C1fGNaiM.js +2 -0
  507. package/dist/session-subagent-reactivation.runtime.js +1 -1
  508. package/dist/session-tab-registry-BDK2AlxL.js +491 -0
  509. package/dist/session-visibility-BkrL2kFF.js +147 -0
  510. package/dist/sessions-helpers-YOu_5tl0.js +304 -0
  511. package/dist/sessions-history-http-DxNaoDfb.js +383 -0
  512. package/dist/sessions-patch-BPtlF0Lu.js +309 -0
  513. package/dist/sessions-resolve-B2rpvSka.js +174 -0
  514. package/dist/sessions.runtime-DEk_x65_.js +2 -0
  515. package/dist/sessions.runtime.js +1 -1
  516. package/dist/setup-DZJZF2R6.js +495 -0
  517. package/dist/setup-api-BkYWhB-B.js +29 -0
  518. package/dist/setup-core-BXBabSEx.js +171 -0
  519. package/dist/setup-core-eahC1DXh.js +176 -0
  520. package/dist/setup-surface-BEf8reey.js +286 -0
  521. package/dist/setup-surface-DAOKJ-ai.js +219 -0
  522. package/dist/setup-surface-b6gu0S8l.js +403 -0
  523. package/dist/setup.finalize-DXUCLT5O.js +539 -0
  524. package/dist/setup.gateway-config-BH4xbjcX.js +250 -0
  525. package/dist/shared-BhHdyXun.js +198 -0
  526. package/dist/shared-CKv38qsN.js +121 -0
  527. package/dist/shared-DUw9Q4Lf.js +76 -0
  528. package/dist/slash-state-BQgmhum1.js +1911 -0
  529. package/dist/src-C1B3uJMu.js +3974 -0
  530. package/dist/startup-context-DTpThe3H.js +312 -0
  531. package/dist/status-63GZxfe4.js +2 -0
  532. package/dist/status-C6qTe-QQ.js +397 -0
  533. package/dist/status-CSIGAUly.js +190 -0
  534. package/dist/status-DOW91Kcx.js +2 -0
  535. package/dist/status-all-7hqTcvxr.js +498 -0
  536. package/dist/status-json-CUzzv8An.js +14 -0
  537. package/dist/status-json-command-DwWlqvoV.js +84 -0
  538. package/dist/status-p4yx6E3C.js +209 -0
  539. package/dist/status-runtime-shared-yrzbsOR8.js +257 -0
  540. package/dist/status-subagents.runtime-CuRGoNNn.js +18 -0
  541. package/dist/status-subagents.runtime.js +1 -1
  542. package/dist/status-text-BrcRsCFE.js +237 -0
  543. package/dist/status-zV1BflCE.js +3 -0
  544. package/dist/status.gateway-connection.runtime-BKd4Zivg.js +2 -0
  545. package/dist/status.gateway-connection.runtime.js +1 -1
  546. package/dist/status.gather-B7WlHpIR.js +292 -0
  547. package/dist/status.gather-Ccewg4ce.js +2 -0
  548. package/dist/status.runtime-BFru2C4v.js +2 -0
  549. package/dist/status.runtime.js +1 -1
  550. package/dist/status.scan-mEKnAmP3.js +65 -0
  551. package/dist/status.scan-overview-B0qQVJd0.js +379 -0
  552. package/dist/status.scan.fast-json-CsU-fWhj.js +132 -0
  553. package/dist/status.scan.fast-json-tEc36TAC.js +2 -0
  554. package/dist/status.summary-Bvgry977.js +214 -0
  555. package/dist/status.summary-DRolowE_.js +2 -0
  556. package/dist/subagent-announce-Bhe55Ktf.js +351 -0
  557. package/dist/subagent-announce-delivery-NDBIRwuZ.js +726 -0
  558. package/dist/subagent-announce-output-DsmGO7Oi.js +364 -0
  559. package/dist/subagent-control-Bn8n-535.js +506 -0
  560. package/dist/subagent-followup.runtime-C7s-lOGN.js +68 -0
  561. package/dist/subagent-followup.runtime.js +1 -1
  562. package/dist/subagent-orphan-recovery-CJEhSvFZ.js +305 -0
  563. package/dist/subagent-registry-BgQA8eP1.js +1753 -0
  564. package/dist/subagent-registry-DAm-N9-O.js +3 -0
  565. package/dist/subagent-registry.runtime.js +1 -1
  566. package/dist/subagent-spawn-EXtecXVT.js +1005 -0
  567. package/dist/system-cli-CFS_PN8R.js +59 -0
  568. package/dist/targets-BXWH2MfM.js +67 -0
  569. package/dist/task-executor-DfugjJEq.js +360 -0
  570. package/dist/task-owner-access-CSwIy-v-.js +74 -0
  571. package/dist/task-registry-B-kQGKt_.js +2366 -0
  572. package/dist/task-registry-delivery-runtime-DD1_7xUF.js +3 -0
  573. package/dist/task-registry-delivery-runtime-DIsasFa1.js +2 -0
  574. package/dist/task-registry.maintenance-CxAx195T.js +2 -0
  575. package/dist/task-registry.maintenance-DIFuNnzy.js +416 -0
  576. package/dist/telegram/token.js +1 -1
  577. package/dist/testing-C7oUBiZL.js +575 -0
  578. package/dist/text-report-hYiQ_Kcv.js +587 -0
  579. package/dist/tool-resolution-CnnOHyxg.js +90 -0
  580. package/dist/tools-effective-inventory-DqYXIS6R.js +152 -0
  581. package/dist/tools-invoke-http-zop5qWa_.js +206 -0
  582. package/dist/trash-DZRlsk_R.js +24 -0
  583. package/dist/tui-cli-2cKXF0J8.js +4575 -0
  584. package/dist/update-cli-DP1KXasM.js +1759 -0
  585. package/dist/upgrade-DPFxH2YB.js +1226 -0
  586. package/dist/video-generation-task-status-BEgeadFu.js +163 -0
  587. package/dist/wait-for-idle-before-flush-CmSNfAco.js +5986 -0
  588. package/dist/wizard-models-BJGn0RnU.js +161 -0
  589. package/package.json +1 -1
  590. package/dist/abort-ca8hDmJr.js +0 -201
  591. package/dist/abort.runtime-BrChEuUS.js +0 -2
  592. package/dist/accounts-C1ECKXaw.js +0 -107
  593. package/dist/accounts-DH8HU_Fu.js +0 -104
  594. package/dist/accounts-DWQpG06j.js +0 -2
  595. package/dist/acp-cli-BLpWVnc7.js +0 -2193
  596. package/dist/acp-spawn-D1p6b1gk.js +0 -2
  597. package/dist/acp-spawn-qoyl9NiU.js +0 -1093
  598. package/dist/acp-stateful-target-driver-NL9txhIM.js +0 -89
  599. package/dist/action-agents-C729fJ_P.js +0 -67
  600. package/dist/action-focus-53k9XP4K.js +0 -132
  601. package/dist/action-help-bIJZBYLz.js +0 -7
  602. package/dist/action-info-BBzvYFX_.js +0 -101
  603. package/dist/action-kill-C4fa3E9I.js +0 -33
  604. package/dist/action-list-BEiIbwP1.js +0 -21
  605. package/dist/action-log-Cq7RLW2T.js +0 -30
  606. package/dist/action-send-DyiHgRwh.js +0 -39
  607. package/dist/action-spawn-CEZfDvXU.js +0 -47
  608. package/dist/action-unfocus-CpAw3JOi.js +0 -29
  609. package/dist/actions.runtime-BKEwPyo7.js +0 -18
  610. package/dist/actions.runtime-Bp0UusIf.js +0 -5
  611. package/dist/agent-C2hwJefQ.js +0 -2
  612. package/dist/agent-command-BAAeGRql.js +0 -874
  613. package/dist/agent-harness-runtime-Czrx53YL.js +0 -144
  614. package/dist/agent-runner-utils-DzShckNa.js +0 -239
  615. package/dist/agent-runner.runtime-d_EtNxBK.js +0 -3455
  616. package/dist/agent-runtime-DNgz7AOP.js +0 -18
  617. package/dist/agents-CZmpon7q.js +0 -5
  618. package/dist/agents-Cs9je_gQ.js +0 -953
  619. package/dist/aliases-CZemdpTj.js +0 -2
  620. package/dist/aliases-KefnmoaT.js +0 -96
  621. package/dist/api-CO05iXNH.js +0 -139
  622. package/dist/api-CyjlApHT.js +0 -3
  623. package/dist/api-DArm1ECd.js +0 -5
  624. package/dist/approval-gateway-resolver-URpDQMld.js +0 -29
  625. package/dist/approval-gateway-runtime-B087BMms.js +0 -2
  626. package/dist/approval-handler-runtime-BgRQnG4g.js +0 -439
  627. package/dist/approval-native-runtime-DAsraihr.js +0 -729
  628. package/dist/attempt-execution.runtime-D_FGkDQz.js +0 -509
  629. package/dist/attempt.prompt-helpers-CDzDUi1C.js +0 -221
  630. package/dist/attempt.tool-run-context-DitxaTPJ.js +0 -933
  631. package/dist/audit-Bq8vlxok.js +0 -939
  632. package/dist/audit.runtime-CU42yh1v.js +0 -7
  633. package/dist/auth-CQfwC-AH.js +0 -383
  634. package/dist/auth-DyWcaG4X.js +0 -2
  635. package/dist/auth-order-C3zGI0s9.js +0 -96
  636. package/dist/auth-order-XQ9ZGPd9.js +0 -2
  637. package/dist/bash-tools-BBRtIa6j.js +0 -2824
  638. package/dist/bash-tools-BI0d1TdC.js +0 -3
  639. package/dist/binding-routing-Cvm5c1IV.js +0 -85
  640. package/dist/binding-targets-DSs4NXbd.js +0 -121
  641. package/dist/bridge-server-CwWzSgv8.js +0 -113
  642. package/dist/browser-control-auth-y1f-9HRI.js +0 -2
  643. package/dist/browser-node-runtime-3UAeP8a6.js +0 -12
  644. package/dist/browser-profiles-BzzxphNW.js +0 -2
  645. package/dist/browser-runtime-jj11LR-E.js +0 -387
  646. package/dist/browser-setup-tools-CFB52yQc.js +0 -13
  647. package/dist/build-TlobwpQW.js +0 -550
  648. package/dist/call-Bx8lENb2.js +0 -3
  649. package/dist/call-jYRpeAWm.js +0 -331
  650. package/dist/call.runtime-BRluUZbD.js +0 -2
  651. package/dist/capability-cli-Iyj9Zi3g.js +0 -1401
  652. package/dist/catchup-CtxTwzY8.js +0 -300
  653. package/dist/channel-BJKHBfnq.js +0 -491
  654. package/dist/channel-BNNnYzwK.js +0 -1100
  655. package/dist/channel-BXS-Hd8p.js +0 -226
  656. package/dist/channel-C4XWpowe.js +0 -1174
  657. package/dist/channel-CJQdQgPr.js +0 -840
  658. package/dist/channel-C_zWAu4D.js +0 -595
  659. package/dist/channel-CtGzrF-K.js +0 -1802
  660. package/dist/channel-O9DE4IIq.js +0 -350
  661. package/dist/channel-WHUOtJme.js +0 -297
  662. package/dist/channel-WoDWDxqx.js +0 -1320
  663. package/dist/channel-core-BJjq9SOq.js +0 -5
  664. package/dist/channel-inbound-DLs-YfUs.js +0 -31
  665. package/dist/channel-plugin-runtime-CMG8ac2K.js +0 -771
  666. package/dist/channel-runtime-4UjeDmDI.js +0 -425
  667. package/dist/channel-ys2FFqi1.js +0 -453
  668. package/dist/channel.runtime-B38Ky3R9.js +0 -109
  669. package/dist/channel.runtime-Bl8WYZvF.js +0 -576
  670. package/dist/channel.runtime-D3kAsCsR.js +0 -89
  671. package/dist/channel.runtime-DEQ-anMf.js +0 -2364
  672. package/dist/channel.runtime-DG-EUnSC.js +0 -4
  673. package/dist/channel.runtime-IfV1Md6p.js +0 -430
  674. package/dist/channel.runtime-w1tHjTOa.js +0 -34702
  675. package/dist/channel.setup-dXwiMlyi.js +0 -10
  676. package/dist/channels-B2G1Y-iD.js +0 -733
  677. package/dist/channels-cli-YintLKAt.js +0 -268
  678. package/dist/chat-DdKbu8CA.js +0 -2758
  679. package/dist/clawbot-cli-CnHERFYk.js +0 -9
  680. package/dist/cli-CSNAd6Sz.js +0 -72
  681. package/dist/cli-CdRioBfN.js +0 -2
  682. package/dist/cli-DMPwqYqc.js +0 -219
  683. package/dist/cli-ctyAqh0j.js +0 -2
  684. package/dist/cli-runner-CNlk7xmx.js +0 -286
  685. package/dist/cli-runner.runtime-BK4sQk1m.js +0 -3
  686. package/dist/cli-runner.runtime-BT8ZZn-R.js +0 -4
  687. package/dist/cli.runtime-DU7swpBI.js +0 -1261
  688. package/dist/client-CQdcTPUf.js +0 -138
  689. package/dist/client-Vx7pseEY.js +0 -713
  690. package/dist/command-auth-DkJWb2HE.js +0 -76
  691. package/dist/command-config-resolution-CIRWRfR8.js +0 -23
  692. package/dist/command-config-resolution-DYZWj6Zm.js +0 -2
  693. package/dist/command-config-resolution.runtime-CUtVJOf0.js +0 -2
  694. package/dist/command-registry-CHy5EH0v.js +0 -4
  695. package/dist/command-registry-CyKgELQP.js +0 -9
  696. package/dist/command-registry-core-DQeRIuot.js +0 -104
  697. package/dist/command-secret-gateway-BNnWdAlq.js +0 -528
  698. package/dist/command-status.runtime-CKgimR6Y.js +0 -87
  699. package/dist/commands-acp-DSm97O5v.js +0 -77
  700. package/dist/commands-compact.runtime-BXhP6WJ6.js +0 -10
  701. package/dist/commands-handlers.runtime-FzK-n0L8.js +0 -4597
  702. package/dist/commands-status-BQnB5OSX.js +0 -16
  703. package/dist/commands-status.runtime-B6GcfEDm.js +0 -3
  704. package/dist/commands-subagents-control.runtime-CByd528A.js +0 -2
  705. package/dist/commands-subagents-control.runtime-CqI4LMYa.js +0 -3
  706. package/dist/commands-system-prompt-BD_LeeZk.js +0 -2
  707. package/dist/commands-system-prompt-C2Md_Ia1.js +0 -158
  708. package/dist/commands.runtime-CwiPf7Cc.js +0 -166
  709. package/dist/compact-B_4bMVpw.js +0 -1118
  710. package/dist/compact.runtime-BhRqiBXG.js +0 -12
  711. package/dist/completion-cli-D07hGGMI.js +0 -313
  712. package/dist/config-B1lvYOd7.js +0 -251
  713. package/dist/config-cli-BgepNwob.js +0 -1078
  714. package/dist/configure-CEfl0ORM.js +0 -2
  715. package/dist/configure-TsykzQqM.js +0 -1245
  716. package/dist/connect-options-zqTIEl6K.js +0 -699
  717. package/dist/control-auth-CNa_KHpo.js +0 -125
  718. package/dist/control-service-CZl5wFdZ.js +0 -156
  719. package/dist/conversation-id-BLY9ffjm.js +0 -38
  720. package/dist/conversation-id-DVeOM5Jh.js +0 -235
  721. package/dist/conversation-runtime-gJt7AAg2.js +0 -31
  722. package/dist/core-BtmNtOpS.js +0 -275
  723. package/dist/cron-cli-s9SF4__G.js +0 -713
  724. package/dist/daemon-cli-TCubZfI_.js +0 -12
  725. package/dist/delegate-DyITI93V.js +0 -64
  726. package/dist/detached-task-runtime-CTUQj84i.js +0 -73
  727. package/dist/devices-cli-SXcLjGmh.js +0 -496
  728. package/dist/diagnostics-waSemGnZ.js +0 -154
  729. package/dist/direct-dm-CiSjkmkL.js +0 -64
  730. package/dist/dispatch-BnQSIx2G.js +0 -1131
  731. package/dist/dispatch-acp-CaNQyl2L.js +0 -981
  732. package/dist/dispatch-acp-manager.runtime-DJK1eHYX.js +0 -3
  733. package/dist/dispatch-acp.runtime-Bl5cvtX4.js +0 -19
  734. package/dist/doctor-device-pairing-DBhEA-8G.js +0 -307
  735. package/dist/doctor-gateway-daemon-flow-Ds47Er3Y.js +0 -250
  736. package/dist/doctor-gateway-health-EWwTw5JR.js +0 -60
  737. package/dist/doctor-health-C6muRn7t.js +0 -59
  738. package/dist/doctor-health-contributions-B984415a.js +0 -486
  739. package/dist/doctor-prompter-BpOi4ndi.js +0 -56
  740. package/dist/doctor-workspace-status-CiEWZXrx.js +0 -75
  741. package/dist/dreaming-DFPenC85.js +0 -1574
  742. package/dist/dreaming-narrative-6A27_Gft.js +0 -595
  743. package/dist/embedded-gateway-stub.runtime-UVgfXZzk.js +0 -9
  744. package/dist/exec-approvals-cli-Cc_GG9ZT.js +0 -498
  745. package/dist/fallbacks-DX4YcmAx.js +0 -2
  746. package/dist/fallbacks-inTaaG-m.js +0 -31
  747. package/dist/fallbacks-shared-ow1la-U2.js +0 -111
  748. package/dist/gateway-D4iWwu3_.js +0 -115
  749. package/dist/gateway-cli-D6j0Aj3R.js +0 -1325
  750. package/dist/gateway-rpc-Dd_x2GX5.js +0 -14
  751. package/dist/gateway-rpc.runtime-Btnvsv-7.js +0 -23
  752. package/dist/gateway-runtime-DctMRv_p.js +0 -15
  753. package/dist/gateway-status-DJCtvUVn.js +0 -584
  754. package/dist/genesis-tools-CvMcpUvH.js +0 -8999
  755. package/dist/genesis-tools.runtime-Ch3NDEDq.js +0 -2
  756. package/dist/get-reply-Cm39MCyU.js +0 -3879
  757. package/dist/get-reply-from-config.runtime-CSqCYatb.js +0 -2
  758. package/dist/graph-users-BJxYqA3A.js +0 -1337
  759. package/dist/health-C14jIilQ.js +0 -469
  760. package/dist/health-C6yJSCMc.js +0 -3
  761. package/dist/heartbeat-runner-C6-gFnyC.js +0 -5
  762. package/dist/heartbeat-runner-yUYjgzIM.js +0 -1292
  763. package/dist/heartbeat-runner.runtime-DZzyrUNB.js +0 -4
  764. package/dist/hooks-cli-CCRaHheu.js +0 -433
  765. package/dist/image-fallbacks-BH9qLbBG.js +0 -31
  766. package/dist/image-fallbacks-DUOPO1ic.js +0 -2
  767. package/dist/inbound-reply-dispatch-DPf_IrbV.js +0 -73
  768. package/dist/infra-runtime-CLND6LJ0.js +0 -39
  769. package/dist/init-CzWob-9v.js +0 -59
  770. package/dist/library-C0a9Bz2M.js +0 -45
  771. package/dist/lifecycle-B_B_jt3r.js +0 -571
  772. package/dist/lifecycle-DuqKKZop.js +0 -229
  773. package/dist/lifecycle.runtime-DoosWTnK.js +0 -2
  774. package/dist/list-Bly8XeOF.js +0 -2
  775. package/dist/list-C5HvtbwZ.js +0 -2
  776. package/dist/list-CHIiamt1.js +0 -131
  777. package/dist/list-CMmJiacX.js +0 -1201
  778. package/dist/list.probe-kmHRFlrP.js +0 -419
  779. package/dist/llm-slug-generator-C3u6Ptgq.js +0 -79
  780. package/dist/load-config-CXvIGI7N.js +0 -35
  781. package/dist/local-dispatch.runtime-BNQF4rqW.js +0 -8
  782. package/dist/logs-cli-DEy1GPk2.js +0 -265
  783. package/dist/logs-cli.runtime-jWShKzQC.js +0 -2
  784. package/dist/main-session-restart-recovery-CzfY6Cd8.js +0 -206
  785. package/dist/managed-image-attachments-BGPKA7Mn.js +0 -2
  786. package/dist/managed-image-attachments-CTrq9ym-.js +0 -635
  787. package/dist/manager-C_ZGa9x8.js +0 -2057
  788. package/dist/manager-DIHLRzYF.js +0 -2
  789. package/dist/markdown-to-line-CRbbXtJK.js +0 -790
  790. package/dist/mcp-cli-FMJb3T4k.js +0 -725
  791. package/dist/mcp-http-b6UMoE_J.js +0 -529
  792. package/dist/memory-core-host-runtime-cli-CquxELNj.js +0 -9
  793. package/dist/message-CmjuvIFf.js +0 -232
  794. package/dist/message-action-runner-CiY3rhqt.js +0 -1407
  795. package/dist/message-action-runner-Do4P0h5i.js +0 -2
  796. package/dist/message-actions-BYREqFJA.js +0 -143
  797. package/dist/message.gateway.runtime-gkoWzaYV.js +0 -2
  798. package/dist/models-auth-status-B_Pcr0tl.js +0 -201
  799. package/dist/models-cli-BZSuW2gw.js +0 -219
  800. package/dist/monitor-22LY8y6z.js +0 -788
  801. package/dist/monitor-BZdf_CEm.js +0 -1237
  802. package/dist/monitor-CTVDlTs2.js +0 -671
  803. package/dist/monitor-Cfv-KGAl.js +0 -1661
  804. package/dist/monitor-DuA69-8E.js +0 -2
  805. package/dist/monitor-auth-BNDlfcw7.js +0 -207
  806. package/dist/monitor-cmWeDVxf.js +0 -1459
  807. package/dist/monitor-processing-D9Xcsagt.js +0 -1974
  808. package/dist/monitor.runtime-zWvcbNim.js +0 -2
  809. package/dist/monitor.webhook-BYWQa5lY.js +0 -180
  810. package/dist/msteams-n9HDT4O-.js +0 -35
  811. package/dist/native-hook-relay-CKyIfLOm.js +0 -519
  812. package/dist/nextcloud-talk-BuJVVP0J.js +0 -17
  813. package/dist/node-cli-DBK2TIEH.js +0 -2506
  814. package/dist/nodes-cli-D5Y1_ZVD.js +0 -1046
  815. package/dist/nodes-utils-C6IKaTjm.js +0 -84
  816. package/dist/nodes.helpers-CkJO5i0d.js +0 -34
  817. package/dist/notify-v0zoiI-O.js +0 -315
  818. package/dist/onboard-BCaLBJor.js +0 -632
  819. package/dist/onboard-helpers-Ba7ES7kB.js +0 -204
  820. package/dist/onboard-helpers-D5qdyBIj.js +0 -6
  821. package/dist/onboard-remote-BaHm_VrY.js +0 -2
  822. package/dist/onboard-remote-DbGAo_Ad.js +0 -193
  823. package/dist/onboard-skills-BA7c4li1.js +0 -2
  824. package/dist/onboard-skills-upyHp6T9.js +0 -134
  825. package/dist/openai-http-DwCqhEcX.js +0 -500
  826. package/dist/openresponses-http-tJr67vC1.js +0 -1128
  827. package/dist/operator-approvals-client-C0t_-2xC.js +0 -68
  828. package/dist/outbound.runtime-nXA4k1xA.js +0 -2
  829. package/dist/pair-command-approve-G5y-rKn9.js +0 -44
  830. package/dist/persistent-bindings.lifecycle-C56aKBVc.js +0 -2
  831. package/dist/persistent-bindings.lifecycle-CfBqvz9L.js +0 -85
  832. package/dist/pi-embedded-B1wvxHXL.js +0 -2905
  833. package/dist/pi-embedded-DmDb-oUB.js +0 -4
  834. package/dist/pi-embedded.runtime-D5xqw9Ko.js +0 -4
  835. package/dist/pi-tool-definition-adapter-CAxlo-Va.js +0 -217
  836. package/dist/pi-tools-C69yvznf.js +0 -1057
  837. package/dist/pi-tools.before-tool-call-BDeCmoAy.js +0 -2
  838. package/dist/pi-tools.before-tool-call-DG7VVNBn.js +0 -433
  839. package/dist/plugin-B9Ld0CUs.js +0 -12195
  840. package/dist/plugin-enabled-BguUplCN.js +0 -140
  841. package/dist/plugin-registration-DPBnSoak.js +0 -23
  842. package/dist/plugin-service-CdNFnRyN.js +0 -2890
  843. package/dist/policy-DgfegT_Y.js +0 -328
  844. package/dist/prepare.runtime-C_sRmuFC.js +0 -815
  845. package/dist/probe-8vb_Ssot.js +0 -45
  846. package/dist/probe-BjmKFiz1.js +0 -2205
  847. package/dist/probe-CVlOo8Hr.js +0 -74
  848. package/dist/probe-CakOsrSu.js +0 -241
  849. package/dist/probe-CbOoVumf.js +0 -2
  850. package/dist/probe-D6yFcZpK.js +0 -1443
  851. package/dist/probe-OcOYm1bj.js +0 -2
  852. package/dist/program-BJnTb7UE.js +0 -111
  853. package/dist/prompt-select-styled-C8kGHNpY.js +0 -20
  854. package/dist/protocol-C40iRm9c.js +0 -2234
  855. package/dist/provider-dispatcher-BIOPYzb9.js +0 -2
  856. package/dist/provider-dispatcher-CpwviX0O.js +0 -22
  857. package/dist/qr-cli-CJXKCj0L.js +0 -2
  858. package/dist/qr-cli-kSU9X-N0.js +0 -349
  859. package/dist/reaction-runtime-api-3XFmruJA.js +0 -116
  860. package/dist/reactions-By-nqZC6.js +0 -998
  861. package/dist/register-service-commands-fwB-T6mW.js +0 -71
  862. package/dist/register.agent-CpScU3CV.js +0 -248
  863. package/dist/register.configure-DpD3_BCK.js +0 -15
  864. package/dist/register.maintenance-ByoQXpk9.js +0 -438
  865. package/dist/register.message-BTXNOZMD.js +0 -329
  866. package/dist/register.onboard-B83CAOYy.js +0 -81
  867. package/dist/register.runtime-Doz01zcH.js +0 -81
  868. package/dist/register.setup-BKI5rwWy.js +0 -150
  869. package/dist/register.status-health-sessions-DRPszDQ-.js +0 -1215
  870. package/dist/register.subclis-DeXklyQL.js +0 -3
  871. package/dist/register.subclis-YkmoZoxl.js +0 -29
  872. package/dist/register.subclis-core-BPo4hV1Q.js +0 -243
  873. package/dist/reply-dispatch-runtime-DjIuN_dr.js +0 -13
  874. package/dist/reply-runtime-5TFidLR3.js +0 -11
  875. package/dist/reply.runtime-6d1e0INl.js +0 -2
  876. package/dist/restart-health-BWUPc4R-.js +0 -202
  877. package/dist/restart-health-CWvsjHVN.js +0 -2
  878. package/dist/root-help-D2YiFpS6.js +0 -44
  879. package/dist/routes-BdYdVpe7.js +0 -3341
  880. package/dist/routes-jYoN_qOU.js +0 -2
  881. package/dist/rpc-5tMjebZH.js +0 -61
  882. package/dist/rpc.runtime-BzAHjcm4.js +0 -21
  883. package/dist/run-delivery.runtime-qZIB76oE.js +0 -530
  884. package/dist/run-embedded.runtime-nHunVmCv.js +0 -4
  885. package/dist/run-execution-cli.runtime-CMT7La6D.js +0 -4
  886. package/dist/run-executor.runtime-BG6SDi3f.js +0 -277
  887. package/dist/run-main-CNf_LLX7.js +0 -516
  888. package/dist/run-subagent-registry.runtime-D0RcqcJr.js +0 -2
  889. package/dist/run-wait--kou3jZ7.js +0 -135
  890. package/dist/runtime-BvxkGJm2.js +0 -9
  891. package/dist/runtime-DgQ5oUKq.js +0 -973
  892. package/dist/runtime-api-6SzMK-FZ.js +0 -4
  893. package/dist/runtime-api-BAMrcB-5.js +0 -9
  894. package/dist/runtime-api-DLSrxS5O.js +0 -9
  895. package/dist/runtime-api-DsPleWQg.js +0 -14
  896. package/dist/runtime-embedded-pi.runtime-eyjaJfAz.js +0 -2
  897. package/dist/runtime-internal-BTfGDlHi.js +0 -2
  898. package/dist/runtime-options-B5_eZxMV.js +0 -275
  899. package/dist/runtime-schema-BB3QzGXJ.js +0 -27780
  900. package/dist/scan-D0fsxqed.js +0 -2
  901. package/dist/scan-DrjjN66Z.js +0 -523
  902. package/dist/secrets-cli-B7-qbfn-.js +0 -2101
  903. package/dist/security-cli-CYTPgL67.js +0 -486
  904. package/dist/selection-DEAdLh1Q.js +0 -2
  905. package/dist/selection-zPPyzfBX.js +0 -7736
  906. package/dist/send-CYKfZTCJ.js +0 -156
  907. package/dist/send-Di1tRwJD.js +0 -102
  908. package/dist/send.runtime-Bw22DBkL.js +0 -2
  909. package/dist/server-BIF5dPI_.js +0 -13
  910. package/dist/server-BJK0Q4xw.js +0 -77
  911. package/dist/server-context-CiVVCQNp.js +0 -847
  912. package/dist/server-context-DXvk5Tdy.js +0 -2
  913. package/dist/server-node-events-CdZP3Kok.js +0 -481
  914. package/dist/server-plugin-bootstrap-Di15EOt4.js +0 -11333
  915. package/dist/server-plugin-bootstrap-dboO44LL.js +0 -2
  916. package/dist/server-restart-sentinel-BWiOzljY.js +0 -697
  917. package/dist/server.impl-Ph8YCQpT.js +0 -12734
  918. package/dist/session-kill-http-B_J1fJ4-.js +0 -110
  919. package/dist/session-reset-service-DPgw70iw.js +0 -471
  920. package/dist/session-route-B0h6MEyB.js +0 -93
  921. package/dist/session-status.runtime-DCvgI1pG.js +0 -2
  922. package/dist/session-subagent-reactivation.runtime-BgsCnI-h.js +0 -2
  923. package/dist/session-tab-registry-FyN6CWh5.js +0 -491
  924. package/dist/session-visibility-CZjMA1SL.js +0 -147
  925. package/dist/sessions-helpers-B3W7MdIb.js +0 -304
  926. package/dist/sessions-history-http-Bw5J6HQ-.js +0 -383
  927. package/dist/sessions-patch-2sBcHc9a.js +0 -309
  928. package/dist/sessions-resolve-C-VZh_56.js +0 -174
  929. package/dist/sessions.runtime-cLuc67tJ.js +0 -2
  930. package/dist/setup-FW8xH-S-.js +0 -495
  931. package/dist/setup-api-Culp0Usf.js +0 -29
  932. package/dist/setup-core-CaTBS6Tz.js +0 -171
  933. package/dist/setup-core-youmXvW_.js +0 -176
  934. package/dist/setup-surface-BeMn-9hU.js +0 -403
  935. package/dist/setup-surface-CUd-s0wh.js +0 -286
  936. package/dist/setup-surface-DtscjAY3.js +0 -219
  937. package/dist/setup.finalize-BWyA4f4q.js +0 -539
  938. package/dist/setup.gateway-config-CvzMdftA.js +0 -250
  939. package/dist/shared-B3Pz1Xcr.js +0 -121
  940. package/dist/shared-Bc3x3THS.js +0 -76
  941. package/dist/shared-CxbLx0Ww.js +0 -198
  942. package/dist/slash-state-XfeMEeuI.js +0 -1911
  943. package/dist/src-BiDxQvtV.js +0 -3974
  944. package/dist/startup-context-CXQi-7YB.js +0 -312
  945. package/dist/status-Ch3bm70K.js +0 -2
  946. package/dist/status-CiQSxvY-.js +0 -3
  947. package/dist/status-DY0DlWlw.js +0 -190
  948. package/dist/status-DjdByQv-.js +0 -209
  949. package/dist/status-MT62_Jgw.js +0 -2
  950. package/dist/status-all-BD2viQD9.js +0 -498
  951. package/dist/status-json-CWS2oYON.js +0 -14
  952. package/dist/status-json-command-B6lZefoe.js +0 -84
  953. package/dist/status-pujDHwRb.js +0 -397
  954. package/dist/status-runtime-shared-Bu9Zhd7x.js +0 -257
  955. package/dist/status-subagents.runtime-B4UXD0lL.js +0 -18
  956. package/dist/status-text-myqmk4OL.js +0 -237
  957. package/dist/status.gateway-connection.runtime-B0Iwl2iZ.js +0 -2
  958. package/dist/status.gather-C51Ja0wP.js +0 -292
  959. package/dist/status.gather-DQ7WZp3H.js +0 -2
  960. package/dist/status.runtime-Cxyb3wHZ.js +0 -2
  961. package/dist/status.scan-C1aqDsy2.js +0 -65
  962. package/dist/status.scan-overview-BerlJz2l.js +0 -379
  963. package/dist/status.scan.fast-json-BXY82vu2.js +0 -2
  964. package/dist/status.scan.fast-json-DJqgEbzZ.js +0 -132
  965. package/dist/status.summary-CCdLUph8.js +0 -214
  966. package/dist/status.summary-CHAn0_FS.js +0 -2
  967. package/dist/subagent-announce-D4jG75Ub.js +0 -351
  968. package/dist/subagent-announce-delivery-BkQYzDcy.js +0 -726
  969. package/dist/subagent-announce-output-C3pkuu-t.js +0 -364
  970. package/dist/subagent-control-DVVK8du2.js +0 -506
  971. package/dist/subagent-followup.runtime-CdeweG-S.js +0 -68
  972. package/dist/subagent-orphan-recovery-ZQanOHb4.js +0 -305
  973. package/dist/subagent-registry-BcPa3ho0.js +0 -3
  974. package/dist/subagent-registry-hJUso5eL.js +0 -1753
  975. package/dist/subagent-spawn-DTaeQc9q.js +0 -1005
  976. package/dist/system-cli-CT8VaSDY.js +0 -59
  977. package/dist/targets-BPdSjnQH.js +0 -67
  978. package/dist/task-executor-B62Qzfi-.js +0 -360
  979. package/dist/task-owner-access-BBMrMOlN.js +0 -74
  980. package/dist/task-registry-BD-ew2bT.js +0 -2366
  981. package/dist/task-registry-delivery-runtime-B2WyGY0d.js +0 -3
  982. package/dist/task-registry-delivery-runtime-MFJszOHI.js +0 -2
  983. package/dist/task-registry.maintenance-0D2Yxl49.js +0 -416
  984. package/dist/task-registry.maintenance-OPlfB5W9.js +0 -2
  985. package/dist/testing-DmxZ16UC.js +0 -575
  986. package/dist/text-report-BwIpU54R.js +0 -587
  987. package/dist/tool-resolution-vn72hwMo.js +0 -90
  988. package/dist/tools-effective-inventory-DII_pOSr.js +0 -152
  989. package/dist/tools-invoke-http-DdthGR52.js +0 -206
  990. package/dist/trash-BVZu6rU7.js +0 -24
  991. package/dist/tui-cli-Bz51WCAi.js +0 -4575
  992. package/dist/update-cli-DkH8vHQP.js +0 -1759
  993. package/dist/upgrade-Dvj8K4WB.js +0 -1226
  994. package/dist/video-generation-task-status-CHYB_IeZ.js +0 -163
  995. package/dist/wait-for-idle-before-flush-DJMxeE2X.js +0 -5986
  996. package/dist/wizard-models-BNQQ7fvr.js +0 -161
@@ -0,0 +1,1131 @@
1
+ import { i as formatErrorMessage } from "./errors-Jbvi20TW.js";
2
+ import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString, s as normalizeOptionalLowercaseString } from "./string-coerce-C1IzJjqi.js";
3
+ import { v as sleep } from "./utils-DaGfogP-.js";
4
+ import { r as isDiagnosticsEnabled } from "./diagnostic-events-CD7YG9TK.js";
5
+ import { t as createSubsystemLogger } from "./subsystem-DTMy5YmO.js";
6
+ import { r as logVerbose } from "./globals-C5IxqXPj.js";
7
+ import { i as normalizeChannelId, t as getChannelPlugin } from "./registry-DXDC8Wqv.js";
8
+ import { _ as resolveAgentConfig, b as resolveAgentWorkspaceDir, p as resolveSessionAgentId } from "./agent-scope-CDjZLqNk.js";
9
+ import "./message-channel-core-CtbksRwN.js";
10
+ import { u as normalizeMessageChannel } from "./message-channel-BbI8d0sw.js";
11
+ import { n as fireAndForgetHook } from "./fire-and-forget-BxC2VE71.js";
12
+ import { n as getGlobalPluginRegistry, t as getGlobalHookRunner } from "./hook-runner-global-DA2gGjRr.js";
13
+ import { m as triggerInternalHook, n as createInternalHookEvent } from "./internal-hooks-aB3cCCPc.js";
14
+ import { h as normalizeVerboseLevel } from "./thinking-CM0wvLlr.js";
15
+ import { u as resolveStorePath } from "./paths-DD6L4IvS.js";
16
+ import { t as loadSessionStore } from "./store-load-DevCJoMp.js";
17
+ import { l as resolveSessionStoreEntry } from "./store-DsNJP7a2.js";
18
+ import { t as normalizeChatType } from "./chat-type-Dx2By8Y2.js";
19
+ import { n as parseSessionThreadInfoFast } from "./thread-info-Dz98fald.js";
20
+ import { a as isSilentReplyText, n as SILENT_REPLY_TOKEN } from "./tokens-Bq9TB3gs.js";
21
+ import { t as getReplyPayloadMetadata } from "./reply-payload-CSsG6Yzp.js";
22
+ import { m as resolveSendableOutboundReplyParts } from "./reply-payload-ChFsXpe2.js";
23
+ import { c as toPluginInboundClaimEvent, i as toInternalMessageReceivedContext, l as toPluginMessageContext, n as deriveInboundMessageHookContext, s as toPluginInboundClaimContext, u as toPluginMessageReceivedEvent } from "./message-hook-mappers-Q-EudlF-.js";
24
+ import { r as generateSecureInt } from "./secure-random-YxMYnv0t.js";
25
+ import { n as resolveSilentReplySettings, r as resolveSilentReplyRewriteText } from "./silent-reply-DpWtgUJf.js";
26
+ import { t as normalizeReplyPayload } from "./normalize-reply-BW-jdUE6.js";
27
+ import { i as logMessageQueued, o as logSessionStateChange, r as logMessageProcessed } from "./diagnostic-Ca7xQ_sl.js";
28
+ import { t as isParentOwnedBackgroundAcpSession } from "./session-interaction-mode-BPjkC62c.js";
29
+ import { a as buildPluginBindingUnavailableText, b as touchConversationBindingRecord, c as hasShownPluginBindingFallbackNotice, d as markPluginBindingFallbackNoticeShown, h as toPluginConversationBinding, n as buildPluginBindingDeclinedText, r as buildPluginBindingErrorText, u as isPluginOwnedSessionBindingRecord, y as resolveConversationBindingRecord } from "./conversation-binding-BK-7Flw4.js";
30
+ import { n as resolveSendPolicy } from "./send-policy-Cn5rDKug.js";
31
+ import { n as normalizeTtsAutoMode } from "./tts-auto-mode-B9FHKLDL.js";
32
+ import { n as shouldAttemptTtsPayload, t as resolveConfiguredTtsMode } from "./tts-config-DlRAvlv6.js";
33
+ import { n as commitInboundDedupe, r as releaseInboundDedupe, t as claimInboundDedupe } from "./inbound-dedupe-CGuVucqF.js";
34
+ import { t as resolveRunTypingPolicy } from "./typing-policy-BJnWzw-o.js";
35
+ import { t as finalizeInboundContext } from "./inbound-context-DcpIc6mh.js";
36
+ //#region src/auto-reply/dispatch-dispatcher.ts
37
+ async function withReplyDispatcher(params) {
38
+ try {
39
+ return await params.run();
40
+ } finally {
41
+ params.dispatcher.markComplete();
42
+ try {
43
+ await params.dispatcher.waitForIdle();
44
+ } finally {
45
+ await params.onSettled?.();
46
+ }
47
+ }
48
+ }
49
+ //#endregion
50
+ //#region src/channels/plugins/exec-approval-local.ts
51
+ function shouldSuppressLocalExecApprovalPrompt(params) {
52
+ const channel = params.channel ? normalizeChannelId(params.channel) : null;
53
+ if (!channel) return false;
54
+ return getChannelPlugin(channel)?.outbound?.shouldSuppressLocalPayloadPrompt?.({
55
+ cfg: params.cfg,
56
+ accountId: params.accountId,
57
+ payload: params.payload,
58
+ hint: {
59
+ kind: "approval-pending",
60
+ approvalKind: "exec"
61
+ }
62
+ }) ?? false;
63
+ }
64
+ //#endregion
65
+ //#region src/auto-reply/reply/effective-reply-route.ts
66
+ function isSystemEventProvider(provider) {
67
+ return provider === "heartbeat" || provider === "cron-event" || provider === "exec-event";
68
+ }
69
+ function resolveEffectiveReplyRoute(params) {
70
+ if (!isSystemEventProvider(params.ctx.Provider)) return {
71
+ channel: params.ctx.OriginatingChannel,
72
+ to: params.ctx.OriginatingTo,
73
+ accountId: params.ctx.AccountId
74
+ };
75
+ const persistedDeliveryContext = params.entry?.deliveryContext;
76
+ return {
77
+ channel: params.ctx.OriginatingChannel ?? persistedDeliveryContext?.channel ?? params.entry?.lastChannel,
78
+ to: params.ctx.OriginatingTo ?? persistedDeliveryContext?.to ?? params.entry?.lastTo,
79
+ accountId: params.ctx.AccountId ?? persistedDeliveryContext?.accountId ?? params.entry?.lastAccountId
80
+ };
81
+ }
82
+ //#endregion
83
+ //#region src/auto-reply/reply/routing-policy.ts
84
+ function resolveReplyRoutingDecision(params) {
85
+ const originatingChannel = normalizeMessageChannel(params.originatingChannel);
86
+ const providerChannel = normalizeMessageChannel(params.provider);
87
+ const surfaceChannel = normalizeMessageChannel(params.surface);
88
+ const currentSurface = providerChannel ?? surfaceChannel;
89
+ const isInternalWebchatTurn = currentSurface === "webchat" && (surfaceChannel === "webchat" || !surfaceChannel) && params.explicitDeliverRoute !== true;
90
+ const shouldRouteToOriginating = Boolean(!params.suppressDirectUserDelivery && !isInternalWebchatTurn && params.isRoutableChannel(originatingChannel) && params.originatingTo && originatingChannel !== currentSurface);
91
+ return {
92
+ originatingChannel,
93
+ currentSurface,
94
+ isInternalWebchatTurn,
95
+ shouldRouteToOriginating,
96
+ shouldSuppressTyping: params.suppressDirectUserDelivery === true || shouldRouteToOriginating || originatingChannel === "webchat"
97
+ };
98
+ }
99
+ //#endregion
100
+ //#region src/auto-reply/reply/dispatch-from-config.ts
101
+ let routeReplyRuntimePromise = null;
102
+ let getReplyFromConfigRuntimePromise = null;
103
+ let abortRuntimePromise = null;
104
+ let ttsRuntimePromise = null;
105
+ let runtimePluginsPromise = null;
106
+ let replyMediaPathsRuntimePromise = null;
107
+ function loadRouteReplyRuntime() {
108
+ routeReplyRuntimePromise ??= import("./route-reply.runtime-CkHKAVic.js");
109
+ return routeReplyRuntimePromise;
110
+ }
111
+ function loadGetReplyFromConfigRuntime() {
112
+ getReplyFromConfigRuntimePromise ??= import("./get-reply-from-config.runtime-DEq5XM_s.js");
113
+ return getReplyFromConfigRuntimePromise;
114
+ }
115
+ function loadAbortRuntime() {
116
+ abortRuntimePromise ??= import("./abort.runtime-C_xk0DkL.js");
117
+ return abortRuntimePromise;
118
+ }
119
+ function loadTtsRuntime() {
120
+ ttsRuntimePromise ??= import("./tts.runtime-DiRgX28x.js");
121
+ return ttsRuntimePromise;
122
+ }
123
+ function loadRuntimePlugins() {
124
+ runtimePluginsPromise ??= import("./runtime-plugins-mRkF9Io7.js");
125
+ return runtimePluginsPromise;
126
+ }
127
+ function loadReplyMediaPathsRuntime() {
128
+ replyMediaPathsRuntimePromise ??= import("./reply-media-paths.runtime-BzHN3Oug.js");
129
+ return replyMediaPathsRuntimePromise;
130
+ }
131
+ async function maybeApplyTtsToReplyPayload(params) {
132
+ if (!shouldAttemptTtsPayload({
133
+ cfg: params.cfg,
134
+ ttsAuto: params.ttsAuto
135
+ })) return params.payload;
136
+ const { maybeApplyTtsToPayload } = await loadTtsRuntime();
137
+ return maybeApplyTtsToPayload(params);
138
+ }
139
+ const AUDIO_PLACEHOLDER_RE = /^<media:audio>(\s*\([^)]*\))?$/i;
140
+ const AUDIO_HEADER_RE = /^\[Audio\b/i;
141
+ const normalizeMediaType = (value) => normalizeOptionalLowercaseString(value.split(";")[0]) ?? "";
142
+ const isInboundAudioContext = (ctx) => {
143
+ if ([typeof ctx.MediaType === "string" ? ctx.MediaType : void 0, ...Array.isArray(ctx.MediaTypes) ? ctx.MediaTypes : []].filter(Boolean).map((type) => normalizeMediaType(type)).some((type) => type === "audio" || type.startsWith("audio/"))) return true;
144
+ const trimmed = (typeof ctx.BodyForCommands === "string" ? ctx.BodyForCommands : typeof ctx.CommandBody === "string" ? ctx.CommandBody : typeof ctx.RawBody === "string" ? ctx.RawBody : typeof ctx.Body === "string" ? ctx.Body : "").trim();
145
+ if (!trimmed) return false;
146
+ if (AUDIO_PLACEHOLDER_RE.test(trimmed)) return true;
147
+ return AUDIO_HEADER_RE.test(trimmed);
148
+ };
149
+ const resolveRoutedPolicyConversationType = (ctx) => {
150
+ if (ctx.CommandSource === "native" && ctx.CommandTargetSessionKey && ctx.CommandTargetSessionKey !== ctx.SessionKey) return;
151
+ const chatType = normalizeChatType(ctx.ChatType);
152
+ if (chatType === "direct") return "direct";
153
+ if (chatType === "group" || chatType === "channel") return "group";
154
+ };
155
+ const resolveSessionStoreLookup = (ctx, cfg) => {
156
+ const sessionKey = normalizeOptionalString((ctx.CommandSource === "native" ? normalizeOptionalString(ctx.CommandTargetSessionKey) : void 0) ?? ctx.SessionKey);
157
+ if (!sessionKey) return {};
158
+ const agentId = resolveSessionAgentId({
159
+ sessionKey,
160
+ config: cfg
161
+ });
162
+ const storePath = resolveStorePath(cfg.session?.store, { agentId });
163
+ try {
164
+ return {
165
+ sessionKey,
166
+ storePath,
167
+ entry: resolveSessionStoreEntry({
168
+ store: loadSessionStore(storePath),
169
+ sessionKey
170
+ }).existing
171
+ };
172
+ } catch {
173
+ return {
174
+ sessionKey,
175
+ storePath
176
+ };
177
+ }
178
+ };
179
+ const createShouldEmitVerboseProgress = (params) => {
180
+ return () => {
181
+ if (params.sessionKey && params.storePath) try {
182
+ const entry = resolveSessionStoreEntry({
183
+ store: loadSessionStore(params.storePath),
184
+ sessionKey: params.sessionKey
185
+ }).existing;
186
+ const currentLevel = normalizeVerboseLevel(entry?.verboseLevel ?? "");
187
+ if (currentLevel) return currentLevel !== "off";
188
+ } catch {}
189
+ return params.fallbackLevel !== "off";
190
+ };
191
+ };
192
+ async function dispatchReplyFromConfig(params) {
193
+ const { ctx, cfg, dispatcher } = params;
194
+ const diagnosticsEnabled = isDiagnosticsEnabled(cfg);
195
+ const channel = normalizeLowercaseStringOrEmpty(ctx.Surface ?? ctx.Provider ?? "unknown");
196
+ const chatId = ctx.To ?? ctx.From;
197
+ const messageId = ctx.MessageSid ?? ctx.MessageSidFirst ?? ctx.MessageSidLast;
198
+ const sessionKey = ctx.SessionKey;
199
+ const startTime = diagnosticsEnabled ? Date.now() : 0;
200
+ const canTrackSession = diagnosticsEnabled && Boolean(sessionKey);
201
+ const recordProcessed = (outcome, opts) => {
202
+ if (!diagnosticsEnabled) return;
203
+ logMessageProcessed({
204
+ channel,
205
+ chatId,
206
+ messageId,
207
+ sessionKey,
208
+ durationMs: Date.now() - startTime,
209
+ outcome,
210
+ reason: opts?.reason,
211
+ error: opts?.error
212
+ });
213
+ };
214
+ const markProcessing = () => {
215
+ if (!canTrackSession || !sessionKey) return;
216
+ logMessageQueued({
217
+ sessionKey,
218
+ channel,
219
+ source: "dispatch"
220
+ });
221
+ logSessionStateChange({
222
+ sessionKey,
223
+ state: "processing",
224
+ reason: "message_start"
225
+ });
226
+ };
227
+ const markIdle = (reason) => {
228
+ if (!canTrackSession || !sessionKey) return;
229
+ logSessionStateChange({
230
+ sessionKey,
231
+ state: "idle",
232
+ reason
233
+ });
234
+ };
235
+ const inboundDedupeClaim = claimInboundDedupe(ctx);
236
+ if (inboundDedupeClaim.status === "duplicate" || inboundDedupeClaim.status === "inflight") {
237
+ recordProcessed("skipped", { reason: "duplicate" });
238
+ return {
239
+ queuedFinal: false,
240
+ counts: dispatcher.getQueuedCounts()
241
+ };
242
+ }
243
+ const sessionStoreEntry = resolveSessionStoreLookup(ctx, cfg);
244
+ const acpDispatchSessionKey = sessionStoreEntry.sessionKey ?? sessionKey;
245
+ const sessionAgentId = resolveSessionAgentId({
246
+ sessionKey: acpDispatchSessionKey,
247
+ config: cfg
248
+ });
249
+ const sessionAgentCfg = resolveAgentConfig(cfg, sessionAgentId);
250
+ const shouldEmitVerboseProgress = createShouldEmitVerboseProgress({
251
+ sessionKey: acpDispatchSessionKey,
252
+ storePath: sessionStoreEntry.storePath,
253
+ fallbackLevel: normalizeVerboseLevel(sessionStoreEntry.entry?.verboseLevel ?? sessionAgentCfg?.verboseDefault ?? cfg.agents?.defaults?.verboseDefault ?? "") ?? "off"
254
+ });
255
+ const replyRoute = resolveEffectiveReplyRoute({
256
+ ctx,
257
+ entry: sessionStoreEntry.entry
258
+ });
259
+ const routeThreadId = ctx.MessageThreadId ?? parseSessionThreadInfoFast(acpDispatchSessionKey).threadId;
260
+ const inboundAudio = isInboundAudioContext(ctx);
261
+ const sessionTtsAuto = normalizeTtsAutoMode(sessionStoreEntry.entry?.ttsAuto);
262
+ const workspaceDir = resolveAgentWorkspaceDir(cfg, sessionAgentId);
263
+ const { ensureRuntimePluginsLoaded } = await loadRuntimePlugins();
264
+ ensureRuntimePluginsLoaded({
265
+ config: cfg,
266
+ workspaceDir
267
+ });
268
+ const hookRunner = getGlobalHookRunner();
269
+ const timestamp = typeof ctx.Timestamp === "number" && Number.isFinite(ctx.Timestamp) ? ctx.Timestamp : void 0;
270
+ const hookContext = deriveInboundMessageHookContext(ctx, { messageId: ctx.MessageSidFull ?? ctx.MessageSid ?? ctx.MessageSidFirst ?? ctx.MessageSidLast });
271
+ const { isGroup, groupId } = hookContext;
272
+ const inboundClaimContext = toPluginInboundClaimContext(hookContext);
273
+ const inboundClaimEvent = toPluginInboundClaimEvent(hookContext, {
274
+ commandAuthorized: typeof ctx.CommandAuthorized === "boolean" ? ctx.CommandAuthorized : void 0,
275
+ wasMentioned: typeof ctx.WasMentioned === "boolean" ? ctx.WasMentioned : void 0
276
+ });
277
+ const suppressAcpChildUserDelivery = isParentOwnedBackgroundAcpSession(sessionStoreEntry.entry);
278
+ const normalizedRouteReplyChannel = normalizeMessageChannel(replyRoute.channel);
279
+ const normalizedProviderChannel = normalizeMessageChannel(ctx.Provider);
280
+ const normalizedSurfaceChannel = normalizeMessageChannel(ctx.Surface);
281
+ const normalizedCurrentSurface = normalizedProviderChannel ?? normalizedSurfaceChannel;
282
+ const isInternalWebchatTurn = normalizedCurrentSurface === "webchat" && (normalizedSurfaceChannel === "webchat" || !normalizedSurfaceChannel) && ctx.ExplicitDeliverRoute !== true;
283
+ const routeReplyRuntime = Boolean(!suppressAcpChildUserDelivery && !isInternalWebchatTurn && normalizedRouteReplyChannel && replyRoute.to && normalizedRouteReplyChannel !== normalizedCurrentSurface) ? await loadRouteReplyRuntime() : void 0;
284
+ const { originatingChannel: routeReplyChannel, currentSurface, shouldRouteToOriginating, shouldSuppressTyping } = resolveReplyRoutingDecision({
285
+ provider: ctx.Provider,
286
+ surface: ctx.Surface,
287
+ explicitDeliverRoute: ctx.ExplicitDeliverRoute,
288
+ originatingChannel: replyRoute.channel,
289
+ originatingTo: replyRoute.to,
290
+ suppressDirectUserDelivery: suppressAcpChildUserDelivery,
291
+ isRoutableChannel: routeReplyRuntime?.isRoutableChannel ?? (() => false)
292
+ });
293
+ const routeReplyTo = replyRoute.to;
294
+ const deliveryChannel = shouldRouteToOriginating ? routeReplyChannel : currentSurface;
295
+ const { createReplyMediaPathNormalizer } = await loadReplyMediaPathsRuntime();
296
+ const normalizeReplyMediaPaths = createReplyMediaPathNormalizer({
297
+ cfg,
298
+ sessionKey: acpDispatchSessionKey,
299
+ workspaceDir,
300
+ messageProvider: deliveryChannel,
301
+ accountId: replyRoute.accountId,
302
+ groupId,
303
+ groupChannel: ctx.GroupChannel,
304
+ groupSpace: ctx.GroupSpace,
305
+ requesterSenderId: ctx.SenderId,
306
+ requesterSenderName: ctx.SenderName,
307
+ requesterSenderUsername: ctx.SenderUsername,
308
+ requesterSenderE164: ctx.SenderE164
309
+ });
310
+ const normalizeReplyMediaPayload = async (payload) => {
311
+ if (!resolveSendableOutboundReplyParts(payload).hasMedia) return payload;
312
+ return await normalizeReplyMediaPaths(payload);
313
+ };
314
+ const routeReplyToOriginating = async (payload, options) => {
315
+ if (!shouldRouteToOriginating || !routeReplyChannel || !routeReplyTo || !routeReplyRuntime) return null;
316
+ return await routeReplyRuntime.routeReply({
317
+ payload,
318
+ channel: routeReplyChannel,
319
+ to: routeReplyTo,
320
+ sessionKey: ctx.SessionKey,
321
+ policySessionKey: ctx.CommandSource === "native" ? ctx.CommandTargetSessionKey ?? ctx.SessionKey : ctx.SessionKey,
322
+ policyConversationType: resolveRoutedPolicyConversationType(ctx),
323
+ accountId: replyRoute.accountId,
324
+ requesterSenderId: ctx.SenderId,
325
+ requesterSenderName: ctx.SenderName,
326
+ requesterSenderUsername: ctx.SenderUsername,
327
+ requesterSenderE164: ctx.SenderE164,
328
+ threadId: routeThreadId,
329
+ cfg,
330
+ abortSignal: options?.abortSignal,
331
+ mirror: options?.mirror,
332
+ isGroup,
333
+ groupId
334
+ });
335
+ };
336
+ /**
337
+ * Helper to send a payload via route-reply (async).
338
+ * Only used when actually routing to a different provider.
339
+ * Note: Only called when shouldRouteToOriginating is true, so
340
+ * routeReplyChannel and routeReplyTo are guaranteed to be defined.
341
+ */
342
+ const sendPayloadAsync = async (payload, abortSignal, mirror) => {
343
+ if (!routeReplyRuntime || !routeReplyChannel || !routeReplyTo) return;
344
+ if (abortSignal?.aborted) return;
345
+ const result = await routeReplyToOriginating(payload, {
346
+ abortSignal,
347
+ mirror
348
+ });
349
+ if (result && !result.ok) logVerbose(`dispatch-from-config: route-reply failed: ${result.error ?? "unknown error"}`);
350
+ };
351
+ const sendBindingNotice = async (payload, mode) => {
352
+ const result = await routeReplyToOriginating(payload);
353
+ if (result) {
354
+ if (!result.ok) logVerbose(`dispatch-from-config: route-reply (plugin binding notice) failed: ${result.error ?? "unknown error"}`);
355
+ return result.ok;
356
+ }
357
+ return mode === "additive" ? dispatcher.sendToolResult(payload) : dispatcher.sendFinalReply(payload);
358
+ };
359
+ const pluginOwnedBindingRecord = inboundClaimContext.conversationId && inboundClaimContext.channelId ? resolveConversationBindingRecord({
360
+ channel: inboundClaimContext.channelId,
361
+ accountId: inboundClaimContext.accountId ?? cfg.channels?.[inboundClaimContext.channelId]?.defaultAccount ?? "default",
362
+ conversationId: inboundClaimContext.conversationId,
363
+ parentConversationId: inboundClaimContext.parentConversationId
364
+ }) : null;
365
+ const pluginOwnedBinding = isPluginOwnedSessionBindingRecord(pluginOwnedBindingRecord) ? toPluginConversationBinding(pluginOwnedBindingRecord) : null;
366
+ const sendPolicy = resolveSendPolicy({
367
+ cfg,
368
+ entry: sessionStoreEntry.entry,
369
+ sessionKey: sessionStoreEntry.sessionKey ?? sessionKey,
370
+ channel: (shouldRouteToOriginating ? routeReplyChannel : void 0) ?? sessionStoreEntry.entry?.channel ?? replyRoute.channel ?? ctx.Surface ?? ctx.Provider ?? void 0,
371
+ chatType: sessionStoreEntry.entry?.chatType
372
+ });
373
+ const suppressDelivery = sendPolicy === "deny";
374
+ const suppressHookUserDelivery = suppressAcpChildUserDelivery || suppressDelivery;
375
+ let pluginFallbackReason;
376
+ if (pluginOwnedBinding) {
377
+ touchConversationBindingRecord(pluginOwnedBinding.bindingId);
378
+ if (suppressDelivery) logVerbose(`plugin-bound inbound skipped under sendPolicy: deny (plugin=${pluginOwnedBinding.pluginId} session=${sessionKey ?? "unknown"}); falling through to suppressed agent processing`);
379
+ else {
380
+ logVerbose(`plugin-bound inbound routed to ${pluginOwnedBinding.pluginId} conversation=${pluginOwnedBinding.conversationId}`);
381
+ const targetedClaimOutcome = hookRunner?.runInboundClaimForPluginOutcome ? await hookRunner.runInboundClaimForPluginOutcome(pluginOwnedBinding.pluginId, inboundClaimEvent, {
382
+ ...inboundClaimContext,
383
+ pluginBinding: pluginOwnedBinding
384
+ }) : getGlobalPluginRegistry()?.plugins.some((plugin) => plugin.id === pluginOwnedBinding.pluginId && plugin.status === "loaded") ?? false ? { status: "no_handler" } : { status: "missing_plugin" };
385
+ switch (targetedClaimOutcome.status) {
386
+ case "handled":
387
+ if (targetedClaimOutcome.result.reply) await sendBindingNotice(targetedClaimOutcome.result.reply, "terminal");
388
+ markIdle("plugin_binding_dispatch");
389
+ recordProcessed("completed", { reason: "plugin-bound-handled" });
390
+ return {
391
+ queuedFinal: false,
392
+ counts: dispatcher.getQueuedCounts()
393
+ };
394
+ case "missing_plugin":
395
+ case "no_handler":
396
+ pluginFallbackReason = targetedClaimOutcome.status === "missing_plugin" ? "plugin-bound-fallback-missing-plugin" : "plugin-bound-fallback-no-handler";
397
+ if (!hasShownPluginBindingFallbackNotice(pluginOwnedBinding.bindingId)) {
398
+ if (await sendBindingNotice({ text: buildPluginBindingUnavailableText(pluginOwnedBinding) }, "additive")) markPluginBindingFallbackNoticeShown(pluginOwnedBinding.bindingId);
399
+ }
400
+ break;
401
+ case "declined":
402
+ await sendBindingNotice({ text: buildPluginBindingDeclinedText(pluginOwnedBinding) }, "terminal");
403
+ markIdle("plugin_binding_declined");
404
+ recordProcessed("completed", { reason: "plugin-bound-declined" });
405
+ return {
406
+ queuedFinal: false,
407
+ counts: dispatcher.getQueuedCounts()
408
+ };
409
+ case "error":
410
+ logVerbose(`plugin-bound inbound claim failed for ${pluginOwnedBinding.pluginId}: ${targetedClaimOutcome.error}`);
411
+ await sendBindingNotice({ text: buildPluginBindingErrorText(pluginOwnedBinding) }, "terminal");
412
+ markIdle("plugin_binding_error");
413
+ recordProcessed("completed", { reason: "plugin-bound-error" });
414
+ return {
415
+ queuedFinal: false,
416
+ counts: dispatcher.getQueuedCounts()
417
+ };
418
+ }
419
+ }
420
+ }
421
+ if (hookRunner?.hasHooks("message_received")) fireAndForgetHook(hookRunner.runMessageReceived(toPluginMessageReceivedEvent(hookContext), toPluginMessageContext(hookContext)), "dispatch-from-config: message_received plugin hook failed");
422
+ if (sessionKey) fireAndForgetHook(triggerInternalHook(createInternalHookEvent("message", "received", sessionKey, {
423
+ ...toInternalMessageReceivedContext(hookContext),
424
+ timestamp
425
+ })), "dispatch-from-config: message_received internal hook failed");
426
+ markProcessing();
427
+ try {
428
+ const abortRuntime = params.fastAbortResolver ? null : await loadAbortRuntime();
429
+ const fastAbortResolver = params.fastAbortResolver ?? abortRuntime?.tryFastAbortFromMessage;
430
+ const formatAbortReplyTextResolver = params.formatAbortReplyTextResolver ?? abortRuntime?.formatAbortReplyText;
431
+ if (!fastAbortResolver || !formatAbortReplyTextResolver) throw new Error("abort runtime unavailable");
432
+ const fastAbort = await fastAbortResolver({
433
+ ctx,
434
+ cfg
435
+ });
436
+ if (fastAbort.handled) {
437
+ let queuedFinal = false;
438
+ let routedFinalCount = 0;
439
+ if (!suppressDelivery) {
440
+ const payload = { text: formatAbortReplyTextResolver(fastAbort.stoppedSubagents) };
441
+ const result = await routeReplyToOriginating(payload);
442
+ if (result) {
443
+ queuedFinal = result.ok;
444
+ if (result.ok) routedFinalCount += 1;
445
+ if (!result.ok) logVerbose(`dispatch-from-config: route-reply (abort) failed: ${result.error ?? "unknown error"}`);
446
+ } else queuedFinal = dispatcher.sendFinalReply(payload);
447
+ } else logVerbose(`dispatch-from-config: fast_abort reply suppressed by sendPolicy: deny (session=${sessionKey ?? "unknown"})`);
448
+ const counts = dispatcher.getQueuedCounts();
449
+ counts.final += routedFinalCount;
450
+ recordProcessed("completed", { reason: "fast_abort" });
451
+ markIdle("message_completed");
452
+ return {
453
+ queuedFinal,
454
+ counts
455
+ };
456
+ }
457
+ const shouldSendVerboseProgressMessages = !((ctx.Surface === "slack" || ctx.Provider === "slack") && ctx.ChatType !== "direct") && (ctx.ChatType !== "group" || ctx.IsForum === true);
458
+ const shouldSendToolSummaries = shouldSendVerboseProgressMessages;
459
+ const shouldSendToolStartStatuses = shouldSendVerboseProgressMessages;
460
+ const sendFinalPayload = async (payload) => {
461
+ const normalizedPayload = await normalizeReplyMediaPayload(await maybeApplyTtsToReplyPayload({
462
+ payload,
463
+ cfg,
464
+ channel: deliveryChannel,
465
+ kind: "final",
466
+ inboundAudio,
467
+ ttsAuto: sessionTtsAuto
468
+ }));
469
+ const result = await routeReplyToOriginating(normalizedPayload);
470
+ if (result) {
471
+ if (!result.ok) logVerbose(`dispatch-from-config: route-reply (final) failed: ${result.error ?? "unknown error"}`);
472
+ return {
473
+ queuedFinal: result.ok,
474
+ routedFinalCount: result.ok ? 1 : 0
475
+ };
476
+ }
477
+ return {
478
+ queuedFinal: dispatcher.sendFinalReply(normalizedPayload),
479
+ routedFinalCount: 0
480
+ };
481
+ };
482
+ if (hookRunner?.hasHooks("before_dispatch")) {
483
+ const beforeDispatchResult = await hookRunner.runBeforeDispatch({
484
+ content: hookContext.content,
485
+ body: hookContext.bodyForAgent ?? hookContext.body,
486
+ channel: hookContext.channelId,
487
+ sessionKey: sessionStoreEntry.sessionKey ?? sessionKey,
488
+ senderId: hookContext.senderId,
489
+ isGroup: hookContext.isGroup,
490
+ timestamp: hookContext.timestamp
491
+ }, {
492
+ channelId: hookContext.channelId,
493
+ accountId: hookContext.accountId,
494
+ conversationId: inboundClaimContext.conversationId,
495
+ sessionKey: sessionStoreEntry.sessionKey ?? sessionKey,
496
+ senderId: hookContext.senderId
497
+ });
498
+ if (beforeDispatchResult?.handled) {
499
+ const text = beforeDispatchResult.text;
500
+ let queuedFinal = false;
501
+ let routedFinalCount = 0;
502
+ if (text && !suppressDelivery) {
503
+ const handledReply = await sendFinalPayload({ text });
504
+ queuedFinal = handledReply.queuedFinal;
505
+ routedFinalCount += handledReply.routedFinalCount;
506
+ }
507
+ const counts = dispatcher.getQueuedCounts();
508
+ counts.final += routedFinalCount;
509
+ recordProcessed("completed", { reason: "before_dispatch_handled" });
510
+ markIdle("message_completed");
511
+ return {
512
+ queuedFinal,
513
+ counts
514
+ };
515
+ }
516
+ }
517
+ if (hookRunner?.hasHooks("reply_dispatch")) {
518
+ const replyDispatchResult = await hookRunner.runReplyDispatch({
519
+ ctx,
520
+ runId: params.replyOptions?.runId,
521
+ sessionKey: acpDispatchSessionKey,
522
+ images: params.replyOptions?.images,
523
+ inboundAudio,
524
+ sessionTtsAuto,
525
+ ttsChannel: deliveryChannel,
526
+ suppressUserDelivery: suppressHookUserDelivery,
527
+ shouldRouteToOriginating,
528
+ originatingChannel: routeReplyChannel,
529
+ originatingTo: routeReplyTo,
530
+ shouldSendToolSummaries,
531
+ sendPolicy
532
+ }, {
533
+ cfg,
534
+ dispatcher,
535
+ abortSignal: params.replyOptions?.abortSignal,
536
+ onReplyStart: params.replyOptions?.onReplyStart,
537
+ recordProcessed,
538
+ markIdle
539
+ });
540
+ if (replyDispatchResult?.handled) return {
541
+ queuedFinal: replyDispatchResult.queuedFinal,
542
+ counts: replyDispatchResult.counts
543
+ };
544
+ }
545
+ if (suppressDelivery) logVerbose(`Delivery suppressed by send policy for session ${sessionStoreEntry.sessionKey ?? sessionKey ?? "unknown"} — agent will still process the message`);
546
+ const toolStartStatusesSent = /* @__PURE__ */ new Set();
547
+ let toolStartStatusCount = 0;
548
+ const normalizeWorkingLabel = (label) => {
549
+ const collapsed = label.replace(/\s+/g, " ").trim();
550
+ if (collapsed.length <= 80) return collapsed;
551
+ return `${collapsed.slice(0, 77).trimEnd()}...`;
552
+ };
553
+ const formatPlanUpdateText = (payload) => {
554
+ const explanation = payload.explanation?.replace(/\s+/g, " ").trim();
555
+ const steps = (payload.steps ?? []).map((step) => step.replace(/\s+/g, " ").trim()).filter(Boolean);
556
+ const parts = [];
557
+ if (explanation) parts.push(explanation);
558
+ if (steps.length > 0) parts.push(steps.map((step, index) => `${index + 1}. ${step}`).join("\n"));
559
+ return parts.join("\n\n").trim() || "Planning next steps.";
560
+ };
561
+ const maybeSendWorkingStatus = async (label) => {
562
+ if (suppressDelivery) return;
563
+ const normalizedLabel = normalizeWorkingLabel(label);
564
+ if (!shouldEmitVerboseProgress() || !shouldSendToolStartStatuses || !normalizedLabel || toolStartStatusCount >= 2 || toolStartStatusesSent.has(normalizedLabel)) return;
565
+ toolStartStatusesSent.add(normalizedLabel);
566
+ toolStartStatusCount += 1;
567
+ const payload = { text: `Working: ${normalizedLabel}` };
568
+ if (shouldRouteToOriginating) {
569
+ await sendPayloadAsync(payload, void 0, false);
570
+ return;
571
+ }
572
+ dispatcher.sendToolResult(payload);
573
+ };
574
+ const sendPlanUpdate = async (payload) => {
575
+ if (suppressDelivery || !shouldEmitVerboseProgress() || !shouldSendVerboseProgressMessages) return;
576
+ const replyPayload = { text: formatPlanUpdateText(payload) };
577
+ if (shouldRouteToOriginating) {
578
+ await sendPayloadAsync(replyPayload, void 0, false);
579
+ return;
580
+ }
581
+ dispatcher.sendToolResult(replyPayload);
582
+ };
583
+ const summarizeApprovalLabel = (payload) => {
584
+ if (payload.status === "pending") {
585
+ const command = normalizeOptionalString(payload.command);
586
+ if (command) return normalizeWorkingLabel(`awaiting approval: ${command}`);
587
+ return "awaiting approval";
588
+ }
589
+ if (payload.status === "unavailable") {
590
+ const message = normalizeOptionalString(payload.message);
591
+ if (message) return normalizeWorkingLabel(message);
592
+ return "approval unavailable";
593
+ }
594
+ return "";
595
+ };
596
+ const summarizePatchLabel = (payload) => {
597
+ const summary = normalizeOptionalString(payload.summary);
598
+ if (summary) return normalizeWorkingLabel(summary);
599
+ const title = normalizeOptionalString(payload.title);
600
+ if (title) return normalizeWorkingLabel(title);
601
+ return "";
602
+ };
603
+ let accumulatedBlockText = "";
604
+ let blockCount = 0;
605
+ const resolveToolDeliveryPayload = (payload) => {
606
+ if (shouldSuppressLocalExecApprovalPrompt({
607
+ channel: normalizeMessageChannel(ctx.Surface ?? ctx.Provider),
608
+ cfg,
609
+ accountId: ctx.AccountId,
610
+ payload
611
+ })) return null;
612
+ if (shouldSendToolSummaries) return payload;
613
+ const execApproval = payload.channelData && typeof payload.channelData === "object" && !Array.isArray(payload.channelData) ? payload.channelData.execApproval : void 0;
614
+ if (execApproval && typeof execApproval === "object" && !Array.isArray(execApproval)) return payload;
615
+ if (!resolveSendableOutboundReplyParts(payload).hasMedia) return null;
616
+ return {
617
+ ...payload,
618
+ text: void 0
619
+ };
620
+ };
621
+ const typing = resolveRunTypingPolicy({
622
+ requestedPolicy: params.replyOptions?.typingPolicy,
623
+ suppressTyping: suppressDelivery || params.replyOptions?.suppressTyping === true || shouldSuppressTyping,
624
+ originatingChannel: routeReplyChannel,
625
+ systemEvent: shouldRouteToOriginating
626
+ });
627
+ const suppressDefaultToolProgressMessages = params.replyOptions?.suppressDefaultToolProgressMessages === true;
628
+ const onToolResultFromReplyOptions = params.replyOptions?.onToolResult;
629
+ const onPlanUpdateFromReplyOptions = params.replyOptions?.onPlanUpdate;
630
+ const onApprovalEventFromReplyOptions = params.replyOptions?.onApprovalEvent;
631
+ const onPatchSummaryFromReplyOptions = params.replyOptions?.onPatchSummary;
632
+ const replyResult = await (params.replyResolver ?? (await loadGetReplyFromConfigRuntime()).getReplyFromConfig)(ctx, {
633
+ ...params.replyOptions,
634
+ typingPolicy: typing.typingPolicy,
635
+ suppressTyping: typing.suppressTyping,
636
+ onToolResult: (payload) => {
637
+ const run = async () => {
638
+ await onToolResultFromReplyOptions?.(payload);
639
+ if (suppressDelivery) return;
640
+ const deliveryPayload = resolveToolDeliveryPayload(await normalizeReplyMediaPayload(await maybeApplyTtsToReplyPayload({
641
+ payload,
642
+ cfg,
643
+ channel: deliveryChannel,
644
+ kind: "tool",
645
+ inboundAudio,
646
+ ttsAuto: sessionTtsAuto
647
+ })));
648
+ if (!deliveryPayload) return;
649
+ if (suppressDefaultToolProgressMessages) {
650
+ const hasMedia = resolveSendableOutboundReplyParts(deliveryPayload).hasMedia;
651
+ const execApproval = deliveryPayload.channelData && typeof deliveryPayload.channelData === "object" && !Array.isArray(deliveryPayload.channelData) ? deliveryPayload.channelData.execApproval : void 0;
652
+ if (!hasMedia && !(execApproval && typeof execApproval === "object" && !Array.isArray(execApproval)) && deliveryPayload.isError !== true) return;
653
+ }
654
+ if (shouldRouteToOriginating) await sendPayloadAsync(deliveryPayload, void 0, false);
655
+ else dispatcher.sendToolResult(deliveryPayload);
656
+ };
657
+ return run();
658
+ },
659
+ onPlanUpdate: async (payload) => {
660
+ await onPlanUpdateFromReplyOptions?.(payload);
661
+ if (payload.phase !== "update" || suppressDefaultToolProgressMessages) return;
662
+ await sendPlanUpdate({
663
+ explanation: payload.explanation,
664
+ steps: payload.steps
665
+ });
666
+ },
667
+ onApprovalEvent: async (payload) => {
668
+ await onApprovalEventFromReplyOptions?.(payload);
669
+ if (payload.phase !== "requested" || suppressDefaultToolProgressMessages) return;
670
+ const label = summarizeApprovalLabel({
671
+ status: payload.status,
672
+ command: payload.command,
673
+ message: payload.message
674
+ });
675
+ if (!label) return;
676
+ await maybeSendWorkingStatus(label);
677
+ },
678
+ onPatchSummary: async (payload) => {
679
+ await onPatchSummaryFromReplyOptions?.(payload);
680
+ if (payload.phase !== "end" || suppressDefaultToolProgressMessages) return;
681
+ const label = summarizePatchLabel({
682
+ summary: payload.summary,
683
+ title: payload.title
684
+ });
685
+ if (!label) return;
686
+ await maybeSendWorkingStatus(label);
687
+ },
688
+ onBlockReply: (payload, context) => {
689
+ const run = async () => {
690
+ if (suppressDelivery) return;
691
+ if (payload.isReasoning === true) return;
692
+ if (payload.text && !payload.isCompactionNotice) {
693
+ if (accumulatedBlockText.length > 0) accumulatedBlockText += "\n";
694
+ accumulatedBlockText += payload.text;
695
+ blockCount++;
696
+ }
697
+ const payloadMetadata = getReplyPayloadMetadata(payload);
698
+ const queuedContext = payloadMetadata?.assistantMessageIndex !== void 0 ? {
699
+ ...context,
700
+ assistantMessageIndex: payloadMetadata.assistantMessageIndex
701
+ } : context;
702
+ await params.replyOptions?.onBlockReplyQueued?.(payload, queuedContext);
703
+ const normalizedPayload = await normalizeReplyMediaPayload(await maybeApplyTtsToReplyPayload({
704
+ payload,
705
+ cfg,
706
+ channel: deliveryChannel,
707
+ kind: "block",
708
+ inboundAudio,
709
+ ttsAuto: sessionTtsAuto
710
+ }));
711
+ if (shouldRouteToOriginating) await sendPayloadAsync(normalizedPayload, context?.abortSignal, false);
712
+ else dispatcher.sendBlockReply(normalizedPayload);
713
+ };
714
+ return run();
715
+ }
716
+ }, params.configOverride);
717
+ if (ctx.AcpDispatchTailAfterReset === true) {
718
+ ctx.AcpDispatchTailAfterReset = false;
719
+ if (hookRunner?.hasHooks("reply_dispatch")) {
720
+ const tailDispatchResult = await hookRunner.runReplyDispatch({
721
+ ctx,
722
+ runId: params.replyOptions?.runId,
723
+ sessionKey: acpDispatchSessionKey,
724
+ images: params.replyOptions?.images,
725
+ inboundAudio,
726
+ sessionTtsAuto,
727
+ ttsChannel: deliveryChannel,
728
+ suppressUserDelivery: suppressHookUserDelivery,
729
+ shouldRouteToOriginating,
730
+ originatingChannel: routeReplyChannel,
731
+ originatingTo: routeReplyTo,
732
+ shouldSendToolSummaries,
733
+ sendPolicy,
734
+ isTailDispatch: true
735
+ }, {
736
+ cfg,
737
+ dispatcher,
738
+ abortSignal: params.replyOptions?.abortSignal,
739
+ onReplyStart: params.replyOptions?.onReplyStart,
740
+ recordProcessed,
741
+ markIdle
742
+ });
743
+ if (tailDispatchResult?.handled) return {
744
+ queuedFinal: tailDispatchResult.queuedFinal,
745
+ counts: tailDispatchResult.counts
746
+ };
747
+ }
748
+ }
749
+ const replies = replyResult ? Array.isArray(replyResult) ? replyResult : [replyResult] : [];
750
+ let queuedFinal = false;
751
+ let routedFinalCount = 0;
752
+ if (!suppressDelivery) {
753
+ for (const reply of replies) {
754
+ if (reply.isReasoning === true) continue;
755
+ const finalReply = await sendFinalPayload(reply);
756
+ queuedFinal = finalReply.queuedFinal || queuedFinal;
757
+ routedFinalCount += finalReply.routedFinalCount;
758
+ }
759
+ if (resolveConfiguredTtsMode(cfg) === "final" && replies.length === 0 && blockCount > 0 && accumulatedBlockText.trim()) try {
760
+ const ttsSyntheticReply = await maybeApplyTtsToReplyPayload({
761
+ payload: { text: accumulatedBlockText },
762
+ cfg,
763
+ channel: deliveryChannel,
764
+ kind: "final",
765
+ inboundAudio,
766
+ ttsAuto: sessionTtsAuto
767
+ });
768
+ if (ttsSyntheticReply.mediaUrl) {
769
+ const ttsOnlyPayload = {
770
+ mediaUrl: ttsSyntheticReply.mediaUrl,
771
+ audioAsVoice: ttsSyntheticReply.audioAsVoice,
772
+ spokenText: accumulatedBlockText
773
+ };
774
+ const result = await routeReplyToOriginating(ttsOnlyPayload);
775
+ if (result) {
776
+ queuedFinal = result.ok || queuedFinal;
777
+ if (result.ok) routedFinalCount += 1;
778
+ if (!result.ok) logVerbose(`dispatch-from-config: route-reply (tts-only) failed: ${result.error ?? "unknown error"}`);
779
+ } else queuedFinal = dispatcher.sendFinalReply(ttsOnlyPayload) || queuedFinal;
780
+ }
781
+ } catch (err) {
782
+ logVerbose(`dispatch-from-config: accumulated block TTS failed: ${formatErrorMessage(err)}`);
783
+ }
784
+ }
785
+ const counts = dispatcher.getQueuedCounts();
786
+ counts.final += routedFinalCount;
787
+ if (inboundDedupeClaim.status === "claimed") commitInboundDedupe(inboundDedupeClaim.key);
788
+ recordProcessed("completed", pluginFallbackReason ? { reason: pluginFallbackReason } : void 0);
789
+ markIdle("message_completed");
790
+ return {
791
+ queuedFinal,
792
+ counts
793
+ };
794
+ } catch (err) {
795
+ if (inboundDedupeClaim.status === "claimed") releaseInboundDedupe(inboundDedupeClaim.key);
796
+ recordProcessed("error", { error: String(err) });
797
+ markIdle("message_error");
798
+ throw err;
799
+ }
800
+ }
801
+ //#endregion
802
+ //#region src/auto-reply/reply/dispatcher-registry.ts
803
+ const activeDispatchers = /* @__PURE__ */ new Set();
804
+ let nextId = 0;
805
+ /**
806
+ * Register a reply dispatcher for global tracking.
807
+ * Returns an unregister function to call when the dispatcher is no longer needed.
808
+ */
809
+ function registerDispatcher(dispatcher) {
810
+ const id = `dispatcher-${++nextId}`;
811
+ const tracked = {
812
+ id,
813
+ pending: dispatcher.pending,
814
+ waitForIdle: dispatcher.waitForIdle
815
+ };
816
+ activeDispatchers.add(tracked);
817
+ const unregister = () => {
818
+ activeDispatchers.delete(tracked);
819
+ };
820
+ return {
821
+ id,
822
+ unregister
823
+ };
824
+ }
825
+ /**
826
+ * Get the total number of pending replies across all dispatchers.
827
+ */
828
+ function getTotalPendingReplies() {
829
+ let total = 0;
830
+ for (const dispatcher of activeDispatchers) total += dispatcher.pending();
831
+ return total;
832
+ }
833
+ //#endregion
834
+ //#region src/auto-reply/reply/reply-dispatcher.ts
835
+ const DEFAULT_HUMAN_DELAY_MIN_MS = 800;
836
+ const DEFAULT_HUMAN_DELAY_MAX_MS = 2500;
837
+ const silentReplyLogger = createSubsystemLogger("silent-reply/dispatcher");
838
+ /** Generate a random delay within the configured range. */
839
+ function getHumanDelay(config) {
840
+ const mode = config?.mode ?? "off";
841
+ if (mode === "off") return 0;
842
+ const min = mode === "custom" ? config?.minMs ?? DEFAULT_HUMAN_DELAY_MIN_MS : DEFAULT_HUMAN_DELAY_MIN_MS;
843
+ const max = mode === "custom" ? config?.maxMs ?? DEFAULT_HUMAN_DELAY_MAX_MS : DEFAULT_HUMAN_DELAY_MAX_MS;
844
+ if (max <= min) return min;
845
+ return min + generateSecureInt(max - min + 1);
846
+ }
847
+ function normalizeReplyPayloadInternal(payload, opts) {
848
+ const prefixContext = opts.responsePrefixContextProvider?.() ?? opts.responsePrefixContext;
849
+ return normalizeReplyPayload(payload, {
850
+ responsePrefix: opts.responsePrefix,
851
+ responsePrefixContext: prefixContext,
852
+ onHeartbeatStrip: opts.onHeartbeatStrip,
853
+ transformReplyPayload: opts.transformReplyPayload,
854
+ onSkip: opts.onSkip
855
+ });
856
+ }
857
+ function resolveSilentFinalPayload(params) {
858
+ if (params.kind !== "final") return;
859
+ if (!isSilentReplyText(params.payload.text, "NO_REPLY")) return;
860
+ const context = params.silentReplyContext;
861
+ if (!context) return;
862
+ const resolvedSettings = resolveSilentReplySettings({
863
+ cfg: context.cfg,
864
+ sessionKey: context.sessionKey,
865
+ surface: context.surface,
866
+ conversationType: context.conversationType
867
+ });
868
+ if (resolvedSettings.policy === "allow") return;
869
+ if (resolvedSettings.rewrite) {
870
+ silentReplyLogger.debug("rewriting exact NO_REPLY final payload before delivery", {
871
+ hasSessionKey: Boolean(context.sessionKey),
872
+ surface: context.surface,
873
+ conversationType: context.conversationType,
874
+ resolvedPolicy: resolvedSettings.policy
875
+ });
876
+ return {
877
+ ...params.payload,
878
+ text: resolveSilentReplyRewriteText({ seed: `${context.sessionKey ?? context.surface ?? "silent-reply"}:${params.payload.text ?? ""}` })
879
+ };
880
+ }
881
+ if (!resolvedSettings.rewrite) silentReplyLogger.debug("preserving exact NO_REPLY final payload before normalization", {
882
+ hasSessionKey: Boolean(context.sessionKey),
883
+ surface: context.surface,
884
+ conversationType: context.conversationType,
885
+ resolvedPolicy: resolvedSettings.policy
886
+ });
887
+ return {
888
+ ...params.payload,
889
+ text: params.payload.text?.trim() || "NO_REPLY"
890
+ };
891
+ }
892
+ function createReplyDispatcher(options) {
893
+ let sendChain = Promise.resolve();
894
+ let pending = 1;
895
+ let completeCalled = false;
896
+ let sentFirstBlock = false;
897
+ const queuedCounts = {
898
+ tool: 0,
899
+ block: 0,
900
+ final: 0
901
+ };
902
+ const failedCounts = {
903
+ tool: 0,
904
+ block: 0,
905
+ final: 0
906
+ };
907
+ const cancelledCounts = {
908
+ tool: 0,
909
+ block: 0,
910
+ final: 0
911
+ };
912
+ const { unregister } = registerDispatcher({
913
+ pending: () => pending,
914
+ waitForIdle: () => sendChain
915
+ });
916
+ const enqueue = (kind, payload) => {
917
+ const originalWasExactSilent = isSilentReplyText(payload.text, SILENT_REPLY_TOKEN);
918
+ const normalized = resolveSilentFinalPayload({
919
+ kind,
920
+ payload,
921
+ silentReplyContext: options.silentReplyContext
922
+ }) ?? normalizeReplyPayloadInternal(payload, {
923
+ responsePrefix: options.responsePrefix,
924
+ responsePrefixContext: options.responsePrefixContext,
925
+ responsePrefixContextProvider: options.responsePrefixContextProvider,
926
+ transformReplyPayload: options.transformReplyPayload,
927
+ onHeartbeatStrip: options.onHeartbeatStrip,
928
+ onSkip: (reason) => options.onSkip?.(payload, {
929
+ kind,
930
+ reason
931
+ })
932
+ });
933
+ if (!normalized) {
934
+ if (kind === "final" && originalWasExactSilent) silentReplyLogger.debug("exact NO_REPLY final payload was skipped before delivery", {
935
+ hasSessionKey: Boolean(options.silentReplyContext?.sessionKey),
936
+ surface: options.silentReplyContext?.surface,
937
+ conversationType: options.silentReplyContext?.conversationType
938
+ });
939
+ return false;
940
+ }
941
+ queuedCounts[kind] += 1;
942
+ pending += 1;
943
+ const shouldDelay = kind === "block" && sentFirstBlock;
944
+ if (kind === "block") sentFirstBlock = true;
945
+ sendChain = sendChain.then(async () => {
946
+ if (shouldDelay) {
947
+ const delayMs = getHumanDelay(options.humanDelay);
948
+ if (delayMs > 0) await sleep(delayMs);
949
+ }
950
+ let deliverPayload = normalized;
951
+ if (options.beforeDeliver) {
952
+ deliverPayload = await options.beforeDeliver(normalized, { kind });
953
+ if (!deliverPayload) {
954
+ cancelledCounts[kind] += 1;
955
+ return;
956
+ }
957
+ }
958
+ await options.deliver(deliverPayload, { kind });
959
+ }).catch((err) => {
960
+ failedCounts[kind] += 1;
961
+ options.onError?.(err, { kind });
962
+ }).finally(() => {
963
+ pending -= 1;
964
+ if (pending === 1 && completeCalled) pending -= 1;
965
+ if (pending === 0) {
966
+ unregister();
967
+ options.onIdle?.();
968
+ }
969
+ });
970
+ return true;
971
+ };
972
+ const markComplete = () => {
973
+ if (completeCalled) return;
974
+ completeCalled = true;
975
+ Promise.resolve().then(() => {
976
+ if (pending === 1 && completeCalled) {
977
+ pending -= 1;
978
+ if (pending === 0) {
979
+ unregister();
980
+ options.onIdle?.();
981
+ }
982
+ }
983
+ });
984
+ };
985
+ return {
986
+ sendToolResult: (payload) => enqueue("tool", payload),
987
+ sendBlockReply: (payload) => enqueue("block", payload),
988
+ sendFinalReply: (payload) => enqueue("final", payload),
989
+ waitForIdle: () => sendChain,
990
+ getQueuedCounts: () => ({ ...queuedCounts }),
991
+ getCancelledCounts: () => ({ ...cancelledCounts }),
992
+ getFailedCounts: () => ({ ...failedCounts }),
993
+ markComplete
994
+ };
995
+ }
996
+ function createReplyDispatcherWithTyping(options) {
997
+ const { typingCallbacks, onReplyStart, onIdle, onCleanup, ...dispatcherOptions } = options;
998
+ const resolvedOnReplyStart = onReplyStart ?? typingCallbacks?.onReplyStart;
999
+ const resolvedOnIdle = onIdle ?? typingCallbacks?.onIdle;
1000
+ const resolvedOnCleanup = onCleanup ?? typingCallbacks?.onCleanup;
1001
+ let typingController;
1002
+ return {
1003
+ dispatcher: createReplyDispatcher({
1004
+ ...dispatcherOptions,
1005
+ onIdle: () => {
1006
+ typingController?.markDispatchIdle();
1007
+ resolvedOnIdle?.();
1008
+ }
1009
+ }),
1010
+ replyOptions: {
1011
+ onReplyStart: resolvedOnReplyStart,
1012
+ onTypingCleanup: resolvedOnCleanup,
1013
+ onTypingController: (typing) => {
1014
+ typingController = typing;
1015
+ }
1016
+ },
1017
+ markDispatchIdle: () => {
1018
+ typingController?.markDispatchIdle();
1019
+ resolvedOnIdle?.();
1020
+ },
1021
+ markRunComplete: () => {
1022
+ typingController?.markRunComplete();
1023
+ }
1024
+ };
1025
+ }
1026
+ //#endregion
1027
+ //#region src/auto-reply/dispatch.ts
1028
+ function resolveDispatcherSilentReplyContext(ctx, cfg) {
1029
+ const finalized = finalizeInboundContext(ctx);
1030
+ const policySessionKey = finalized.CommandSource === "native" ? finalized.CommandTargetSessionKey ?? finalized.SessionKey : finalized.SessionKey;
1031
+ const chatType = normalizeChatType(finalized.ChatType);
1032
+ const conversationType = finalized.CommandSource === "native" && finalized.CommandTargetSessionKey && finalized.CommandTargetSessionKey !== finalized.SessionKey ? void 0 : chatType === "direct" ? "direct" : chatType === "group" || chatType === "channel" ? "group" : void 0;
1033
+ return {
1034
+ cfg,
1035
+ sessionKey: policySessionKey,
1036
+ surface: finalized.Surface ?? finalized.Provider,
1037
+ conversationType
1038
+ };
1039
+ }
1040
+ function resolveInboundReplyHookTarget(finalized, hookCtx) {
1041
+ if (typeof finalized.OriginatingTo === "string" && finalized.OriginatingTo.trim()) return finalized.OriginatingTo;
1042
+ if (hookCtx.isGroup) return hookCtx.conversationId ?? hookCtx.to ?? hookCtx.from;
1043
+ return hookCtx.from || hookCtx.conversationId || hookCtx.to || "";
1044
+ }
1045
+ function buildMessageSendingBeforeDeliver(ctx) {
1046
+ const hookRunner = getGlobalHookRunner();
1047
+ if (!hookRunner?.hasHooks("message_sending")) return;
1048
+ const finalized = finalizeInboundContext(ctx);
1049
+ const hookCtx = deriveInboundMessageHookContext(finalized);
1050
+ const replyTarget = resolveInboundReplyHookTarget(finalized, hookCtx);
1051
+ return async (payload) => {
1052
+ if (!payload.text) return payload;
1053
+ const result = await hookRunner.runMessageSending({
1054
+ content: payload.text,
1055
+ to: replyTarget
1056
+ }, toPluginMessageContext(hookCtx));
1057
+ if (result?.cancel) return null;
1058
+ if (result?.content != null) return {
1059
+ ...payload,
1060
+ text: result.content
1061
+ };
1062
+ return payload;
1063
+ };
1064
+ }
1065
+ function finalizeDispatchResult(result, dispatcher) {
1066
+ const cancelledCounts = dispatcher.getCancelledCounts?.();
1067
+ if (!cancelledCounts) return result;
1068
+ const counts = {
1069
+ tool: Math.max(0, result.counts.tool - cancelledCounts.tool),
1070
+ block: Math.max(0, result.counts.block - cancelledCounts.block),
1071
+ final: Math.max(0, result.counts.final - cancelledCounts.final)
1072
+ };
1073
+ return {
1074
+ queuedFinal: result.queuedFinal && counts.final > 0,
1075
+ counts
1076
+ };
1077
+ }
1078
+ async function dispatchInboundMessage(params) {
1079
+ const finalized = finalizeInboundContext(params.ctx);
1080
+ return finalizeDispatchResult(await withReplyDispatcher({
1081
+ dispatcher: params.dispatcher,
1082
+ run: () => dispatchReplyFromConfig({
1083
+ ctx: finalized,
1084
+ cfg: params.cfg,
1085
+ dispatcher: params.dispatcher,
1086
+ replyOptions: params.replyOptions,
1087
+ replyResolver: params.replyResolver
1088
+ })
1089
+ }), params.dispatcher);
1090
+ }
1091
+ async function dispatchInboundMessageWithBufferedDispatcher(params) {
1092
+ const silentReplyContext = resolveDispatcherSilentReplyContext(params.ctx, params.cfg);
1093
+ const beforeDeliver = params.dispatcherOptions.beforeDeliver ?? buildMessageSendingBeforeDeliver(params.ctx);
1094
+ const { dispatcher, replyOptions, markDispatchIdle, markRunComplete } = createReplyDispatcherWithTyping({
1095
+ ...params.dispatcherOptions,
1096
+ beforeDeliver,
1097
+ silentReplyContext: params.dispatcherOptions.silentReplyContext ?? silentReplyContext
1098
+ });
1099
+ try {
1100
+ return await dispatchInboundMessage({
1101
+ ctx: params.ctx,
1102
+ cfg: params.cfg,
1103
+ dispatcher,
1104
+ replyResolver: params.replyResolver,
1105
+ replyOptions: {
1106
+ ...params.replyOptions,
1107
+ ...replyOptions
1108
+ }
1109
+ });
1110
+ } finally {
1111
+ markRunComplete();
1112
+ markDispatchIdle();
1113
+ }
1114
+ }
1115
+ async function dispatchInboundMessageWithDispatcher(params) {
1116
+ const silentReplyContext = resolveDispatcherSilentReplyContext(params.ctx, params.cfg);
1117
+ const dispatcher = createReplyDispatcher({
1118
+ ...params.dispatcherOptions,
1119
+ beforeDeliver: params.dispatcherOptions.beforeDeliver ?? buildMessageSendingBeforeDeliver(params.ctx),
1120
+ silentReplyContext: params.dispatcherOptions.silentReplyContext ?? silentReplyContext
1121
+ });
1122
+ return await dispatchInboundMessage({
1123
+ ctx: params.ctx,
1124
+ cfg: params.cfg,
1125
+ dispatcher,
1126
+ replyResolver: params.replyResolver,
1127
+ replyOptions: params.replyOptions
1128
+ });
1129
+ }
1130
+ //#endregion
1131
+ export { createReplyDispatcherWithTyping as a, withReplyDispatcher as c, createReplyDispatcher as i, dispatchInboundMessageWithBufferedDispatcher as n, getTotalPendingReplies as o, dispatchInboundMessageWithDispatcher as r, dispatchReplyFromConfig as s, dispatchInboundMessage as t };