@symerian/symi 2.8.14 → 2.8.15

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 (281) hide show
  1. package/dist/{accounts-wWWkC0JH.js → accounts-3dCrO3oZ.js} +1 -1
  2. package/dist/{accounts-BsgY6sda.js → accounts-BRw8yhIW.js} +21 -21
  3. package/dist/{accounts-Bsg6r6H7.js → accounts-BuZxOb3B.js} +1 -1
  4. package/dist/{acp-cli-D7uCUCr8.js → acp-cli-BgR7mxTS.js} +2 -2
  5. package/dist/{acp-cli-CAU8UW9I.js → acp-cli-D1JYg9c1.js} +2 -2
  6. package/dist/{active-listener-AVNn5_U9.js → active-listener-BVZOh2T1.js} +1 -1
  7. package/dist/{agent-scope-Cpm7a9ss.js → agent-scope-CpEJ0B88.js} +3 -3
  8. package/dist/{agents-DlAvDWxz.js → agents-BhhAcFrX.js} +5 -5
  9. package/dist/{agents.config-BKKMbeeE.js → agents.config-BOvsz6E6.js} +1 -1
  10. package/dist/{agents.config-Dd-11klq.js → agents.config-D967tgmP.js} +1 -1
  11. package/dist/{audio-preflight-rrz8KyHd.js → audio-preflight-Cb-T0r6e.js} +29 -29
  12. package/dist/{audio-preflight-C6vpFnOG.js → audio-preflight-NdNUAZ0y.js} +4 -4
  13. package/dist/{audit-CB97BqHJ.js → audit-Dr_8rC6G.js} +2 -2
  14. package/dist/{audit-BhCJV2l6.js → audit-xiwEIT96.js} +2 -2
  15. package/dist/{auth-choice-C6woT6k2.js → auth-choice-DEKKbufH.js} +2 -2
  16. package/dist/{auth-choice-CRQRPwQt.js → auth-choice-Pzy-t2mh.js} +2 -2
  17. package/dist/{auth-profiles-BzB_Exeq.js → auth-profiles-C2vj6htZ.js} +17 -17
  18. package/dist/{banner-DrNha2_N.js → banner-CiHQEfyr.js} +1 -1
  19. package/dist/{bindings-xcRox9xM.js → bindings-BsHoBLIE.js} +2 -2
  20. package/dist/{browser-cli-5ME9iiC3.js → browser-cli-BQeCPbES.js} +3 -3
  21. package/dist/{browser-cli-BTci35qB.js → browser-cli-IXepRCZR.js} +3 -3
  22. package/dist/build-info.json +3 -3
  23. package/dist/bundled/boot-md/handler.js +54 -54
  24. package/dist/bundled/bootstrap-extra-files/handler.js +5 -5
  25. package/dist/bundled/command-logger/handler.js +1 -1
  26. package/dist/bundled/session-memory/handler.js +54 -54
  27. package/dist/{call-Cmb04dff.js → call-BkJK3eYP.js} +2 -1
  28. package/dist/{call-BrRWr7Lj.js → call-CAGvQYXj.js} +2 -1
  29. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  30. package/dist/{channel-activity-CzHaIUAp.js → channel-activity-D8QD7GoV.js} +1 -1
  31. package/dist/{channel-options-D8q9En4T.js → channel-options-DGuilErd.js} +1 -1
  32. package/dist/{channel-options-DYy2sCfN.js → channel-options-_erlRi2w.js} +1 -1
  33. package/dist/{channel-web-CRBU4eZk.js → channel-web-DwfovJKQ.js} +1 -1
  34. package/dist/{channels-cli-Dk3kUw9A.js → channels-cli-B2Zf1oz9.js} +9 -9
  35. package/dist/{channels-cli-BUk43hHR.js → channels-cli-DUsK2bXE.js} +9 -9
  36. package/dist/{chrome-DwXnykXR.js → chrome-BUT--ob3.js} +23 -23
  37. package/dist/{chrome-B14NNyfm.js → chrome-ROtrXlNs.js} +5 -5
  38. package/dist/{chunk-BcxcL1U3.js → chunk-BRe1o4Af.js} +1 -1
  39. package/dist/cli/daemon-cli.js +1 -1
  40. package/dist/{cli-5gWsnsB7.js → cli-BpmyiZc9.js} +6 -6
  41. package/dist/{cli-DjZzJy3t.js → cli-DUiSlxsb.js} +6 -6
  42. package/dist/{client-C7AOOnKZ.js → client-CYsBIR3j.js} +27 -1
  43. package/dist/{client-qUlxXXVJ.js → client-Cmq13-uF.js} +27 -1
  44. package/dist/{command-registry-LjFltTU9.js → command-registry-B8LVEWW9.js} +11 -11
  45. package/dist/{commands-registry-ByGkL6hs.js → commands-registry-DxbSTLNQ.js} +4 -4
  46. package/dist/{completion-cli-BVTGy8th.js → completion-cli-D-_MV8eA.js} +1 -1
  47. package/dist/{completion-cli-Cf6fYZWL.js → completion-cli-DZeK6_ev.js} +2 -2
  48. package/dist/{config-C4WnAd-c.js → config-BkZ9HOKT.js} +17 -17
  49. package/dist/{config-cli-C7DIbGxx.js → config-cli-B7ZvHIMY.js} +1 -1
  50. package/dist/{config-cli-EgWrCemi.js → config-cli-D_m0QL6c.js} +1 -1
  51. package/dist/{configure-B67uIawm.js → configure-DFg-N_i2.js} +6 -6
  52. package/dist/{configure-Bk-snuxh.js → configure-DXml-xDR.js} +6 -6
  53. package/dist/{consolidate-DRtVvG2U.js → consolidate-07QMweFF.js} +4 -4
  54. package/dist/control-ui/index.html +7 -0
  55. package/dist/control-ui/js/menu.js +2 -0
  56. package/dist/control-ui/js/settings.js +1 -0
  57. package/dist/{cron-cli-CGJveo7P.js → cron-cli-CZCm3aLt.js} +3 -3
  58. package/dist/{cron-cli-Crh_r2aK.js → cron-cli-Dq2FEfK1.js} +3 -3
  59. package/dist/{daemon-cli-Cq-IaYw4.js → daemon-cli-B2_uIgDM.js} +2 -2
  60. package/dist/{daemon-cli-CAIg9sMo.js → daemon-cli-CweMes2K.js} +2 -2
  61. package/dist/daemon-cli.js +27 -0
  62. package/dist/{deliver-SLYAWE19.js → deliver-B0OUq6RP.js} +20 -20
  63. package/dist/{deliver-D0bWiRCg.js → deliver-B_Q_nWJV.js} +1 -1
  64. package/dist/{devices-cli-CUT_8CuJ.js → devices-cli-3ui-Wcaj.js} +2 -2
  65. package/dist/{devices-cli-hSn5vjJZ.js → devices-cli-DeoPyzAd.js} +2 -2
  66. package/dist/{diagnostic-DTkZsRNM.js → diagnostic-BUcR3Meg.js} +1 -1
  67. package/dist/{doctor-completion-lE_33xaY.js → doctor-completion-CQXl3jf4.js} +1 -1
  68. package/dist/{doctor-completion-By066O3p.js → doctor-completion-Cu7DwgVw.js} +1 -1
  69. package/dist/entry.js +1 -1
  70. package/dist/{env-CB65jmJQ.js → env-BDXYbTKj.js} +1 -1
  71. package/dist/{exec-approvals-cli-BTfZiH6z.js → exec-approvals-cli-Bx9loYnQ.js} +4 -4
  72. package/dist/{exec-approvals-cli-DTad2Zi_.js → exec-approvals-cli-CTEn_Eu_.js} +4 -4
  73. package/dist/extensionAPI.js +7 -7
  74. package/dist/{frontmatter-CT1M0pRK.js → frontmatter-CTR5f_Ez.js} +4 -4
  75. package/dist/{gateway-cli-DqEgqVKC.js → gateway-cli-B2XchN3Y.js} +34 -16
  76. package/dist/{gateway-cli-C6uT2x34.js → gateway-cli-P0olUhID.js} +34 -16
  77. package/dist/{gateway-rpc-BKJyAcQd.js → gateway-rpc-DbSbyIcL.js} +1 -1
  78. package/dist/{gateway-rpc-DActF8Qj.js → gateway-rpc-QsFn5Zr1.js} +1 -1
  79. package/dist/{gemini-auth-D80BsXr2.js → gemini-auth-BefM10YB.js} +1 -1
  80. package/dist/{github-copilot-token-B8B2pmph.js → github-copilot-token-cCYzSU9h.js} +7 -7
  81. package/dist/{glass-ui-ws-77TY57IO.js → glass-ui-ws-Cs2jfN42.js} +13 -13
  82. package/dist/{glass-ui-ws-CLAUHeZR.js → glass-ui-ws-tIVOcdB2.js} +13 -13
  83. package/dist/{health-CvMHgR-L.js → health-Cs8wf7Hb.js} +2 -2
  84. package/dist/{health-2jkjZxY8.js → health-DMy1nA4K.js} +2 -2
  85. package/dist/{hooks-cli-CRZySOiz.js → hooks-cli-D6awUCDl.js} +7 -7
  86. package/dist/{hooks-cli-DSaezFsD.js → hooks-cli-DIH-zxCG.js} +7 -7
  87. package/dist/{image-BHF_fnIp.js → image-BuVL0jHI.js} +4 -4
  88. package/dist/{image-ops-CY7v6vvp.js → image-ops-C7CauEK8.js} +16 -16
  89. package/dist/{image-MNvheU8U.js → image-tzIqIuKx.js} +1 -1
  90. package/dist/index.js +11 -11
  91. package/dist/{internal-FNqguZSK.js → internal-DjnxpF_K.js} +11 -11
  92. package/dist/{ir-D6MiJpAy.js → ir-7tMVY7D_.js} +4 -4
  93. package/dist/llm-slug-generator.js +54 -54
  94. package/dist/{local-roots-tcdaIEhh.js → local-roots-ClipCZ9s.js} +5 -5
  95. package/dist/{login-D4ZkmSrY.js → login-D4rZWBXe.js} +7 -7
  96. package/dist/{login-qr-C9ftIq3n.js → login-qr-DdAVHOEC.js} +12 -12
  97. package/dist/{logs-cli-BPnrAg0W.js → logs-cli-1hn28HCu.js} +3 -3
  98. package/dist/{logs-cli-DiDesnnp.js → logs-cli-R4WwQvR2.js} +3 -3
  99. package/dist/{manager-DDELj5o9.js → manager-B60Ncruq.js} +1 -1
  100. package/dist/{manager-BtWtmpxN.js → manager-B76ofKkW.js} +1 -1
  101. package/dist/{manager-DxCmjSfP.js → manager-D0_H4LHh.js} +24 -24
  102. package/dist/{manager-DrmlegR2.js → manager-wF-n_prX.js} +1 -1
  103. package/dist/{manifest-registry-BvGv6lp9.js → manifest-registry-CBCGTsIb.js} +19 -19
  104. package/dist/{markdown-tables-CE-qSMGB.js → markdown-tables-x2Xe2UXh.js} +1 -1
  105. package/dist/{memory-cli-ENCASZJk.js → memory-cli-DRLrIa8h.js} +3 -3
  106. package/dist/{memory-cli-Qgbcxvuf.js → memory-cli-eSWCbEiS.js} +3 -3
  107. package/dist/{message-channel-lwVT8QjK.js → message-channel-OlFBYAw8.js} +1 -1
  108. package/dist/{models-COhUz7M9.js → models-B5H41UsH.js} +3 -3
  109. package/dist/{models-cli-CYvXBvmZ.js → models-cli-CHFi2_kC.js} +8 -8
  110. package/dist/{models-cli-CCxYcF4R.js → models-cli-CVfq_g6h.js} +7 -7
  111. package/dist/{node-cli-DwDQpTW5.js → node-cli-BBN6PoOG.js} +1 -1
  112. package/dist/{node-cli-DEcCM2p0.js → node-cli-BsAzTrAx.js} +1 -1
  113. package/dist/{nodes-cli-CqBLemeB.js → nodes-cli-DE60dv81.js} +3 -3
  114. package/dist/{nodes-cli-u8k6TPmF.js → nodes-cli-t3azniiS.js} +3 -3
  115. package/dist/{onboard-fVpLVnwg.js → onboard-DKK6UJjF.js} +3 -3
  116. package/dist/{onboard-CQNUYBIp.js → onboard-DgPzeL3U.js} +3 -3
  117. package/dist/{onboard-channels-CWw8G-6n.js → onboard-channels-BTuYOQO-.js} +1 -1
  118. package/dist/{onboard-channels-9erx07qe.js → onboard-channels-DvNwlvWZ.js} +1 -1
  119. package/dist/{onboard-helpers-C8f_xi6R.js → onboard-helpers-B7jBYbCU.js} +1 -1
  120. package/dist/{onboard-helpers-CF0Cp3OB.js → onboard-helpers-DjlGq6iG.js} +1 -1
  121. package/dist/{onboard-remote-DgGH0dTe.js → onboard-remote-CXuHbtrT.js} +1 -1
  122. package/dist/{onboard-remote-CWal5_aZ.js → onboard-remote-D7wGqONm.js} +1 -1
  123. package/dist/{onboard-skills-DnzJLU2H.js → onboard-skills-BDhqz3te.js} +1 -1
  124. package/dist/{onboard-skills-CO2TjuO3.js → onboard-skills-ChQnpMi-.js} +1 -1
  125. package/dist/{onboarding-D-OIkDwZ.js → onboarding-CCHq8fd9.js} +7 -7
  126. package/dist/{onboarding-CtEiH9WG.js → onboarding-CeqXuQPm.js} +7 -7
  127. package/dist/{onboarding.finalize-BY3HNjX4.js → onboarding.finalize-Cw4TWelq.js} +12 -12
  128. package/dist/{onboarding.finalize-DTbpLV-T.js → onboarding.finalize-DxWVkNx9.js} +11 -11
  129. package/dist/{onboarding.gateway-config-DlV0vso8.js → onboarding.gateway-config-Cm5jIfRz.js} +3 -3
  130. package/dist/{onboarding.gateway-config-D4rQoPRi.js → onboarding.gateway-config-wAyLcGRu.js} +3 -3
  131. package/dist/{outbound-C6Gm22UF.js → outbound-Zmd7UyQH.js} +7 -7
  132. package/dist/{outbound-attachment-BWyKV1Gy.js → outbound-attachment-DeCnZT-8.js} +2 -2
  133. package/dist/{paths-DEuVuViW.js → paths-CbQV9WEg.js} +1 -1
  134. package/dist/{pi-auth-json-Bv1NzJdR.js → pi-auth-json-RXOlh8ar.js} +1 -1
  135. package/dist/{pi-embedded-CdOdQw2i.js → pi-embedded-CGwqumSe.js} +163 -89
  136. package/dist/{pi-embedded-helpers-DwQ9wJeT.js → pi-embedded-helpers-D1_Sab0M.js} +73 -73
  137. package/dist/{pi-embedded-helpers-TcYQOZAY.js → pi-embedded-helpers-DjSdA5BG.js} +4 -4
  138. package/dist/{plugin-registry-BrJ0-qlu.js → plugin-registry-CJKHlm9W.js} +1 -1
  139. package/dist/{plugin-registry-Cuc8ORuR.js → plugin-registry-kiYkB_km.js} +1 -1
  140. package/dist/plugin-sdk/{channel-web-t8UOP6Zu.js → channel-web-C9SUmtjL.js} +1 -1
  141. package/dist/plugin-sdk/gateway/protocol/index.d.ts +6 -3
  142. package/dist/plugin-sdk/gateway/protocol/schema/tasks.d.ts +40 -0
  143. package/dist/plugin-sdk/gateway/protocol/schema/types.d.ts +3 -0
  144. package/dist/plugin-sdk/gateway/protocol/schema.d.ts +1 -0
  145. package/dist/plugin-sdk/index.js +3 -3
  146. package/dist/plugin-sdk/infra/long-task-state.d.ts +34 -0
  147. package/dist/plugin-sdk/{manager-BPm5oefC.js → manager-DUmxOoHb.js} +1 -1
  148. package/dist/plugin-sdk/{reply-BKAHTugL.js → reply-DwJ-3Et9.js} +149 -75
  149. package/dist/plugin-sdk/{synthesis-CVF7Fwhd.js → synthesis-BzYtaV97.js} +2 -2
  150. package/dist/plugin-sdk/{web-D0DsmFvw.js → web-BQzPfsd0.js} +3 -3
  151. package/dist/{plugins-v8k1XVOy.js → plugins-BzmbgY7s.js} +9 -9
  152. package/dist/{plugins-cli-BDalhI46.js → plugins-cli-DTI2yj-y.js} +7 -7
  153. package/dist/{plugins-cli-DFmriy-c.js → plugins-cli-tV4C5XJc.js} +7 -7
  154. package/dist/{program-DKh41c2a.js → program-8Zg4CY5d.js} +12 -12
  155. package/dist/{program-context-Cq7pqOrw.js → program-context-BcKgBBit.js} +30 -30
  156. package/dist/{prompt-select-styled-DvvSE_ni.js → prompt-select-styled-CfKZlGfF.js} +8 -8
  157. package/dist/{prompt-select-styled-BFCAZLwK.js → prompt-select-styled-DigPcXuk.js} +8 -8
  158. package/dist/{provider-auth-helpers-B-LkDxxi.js → provider-auth-helpers-BH3oyYln.js} +1 -1
  159. package/dist/{provider-auth-helpers-DXppgV1l.js → provider-auth-helpers-Db02DMW2.js} +1 -1
  160. package/dist/{push-apns-DvudhEAb.js → push-apns-7rC1ybp8.js} +1 -1
  161. package/dist/{push-apns-DCA47WA5.js → push-apns-f_6DGP6z.js} +1 -1
  162. package/dist/{pw-ai-40Jf9QIb.js → pw-ai-CQtaPvM8.js} +1 -1
  163. package/dist/{pw-ai-XGqnSWju.js → pw-ai-DWkC5eGA.js} +11 -11
  164. package/dist/{qmd-manager-CbRJhonG.js → qmd-manager-BXkbA8Y9.js} +8 -8
  165. package/dist/{register.agent-_BV5KyFb.js → register.agent-CocfT8Pk.js} +11 -11
  166. package/dist/{register.agent-aFj_SMi3.js → register.agent-DETyFsMT.js} +10 -10
  167. package/dist/{register.configure-Dx0Uhmlz.js → register.configure-BAiFzdYa.js} +13 -13
  168. package/dist/{register.configure-CvOoD5gE.js → register.configure-VcTwHq1a.js} +13 -13
  169. package/dist/{register.maintenance-BuZpoSik.js → register.maintenance-BajFgQEm.js} +12 -12
  170. package/dist/{register.maintenance-CMeJR7DG.js → register.maintenance-Bpr3QjJ1.js} +13 -13
  171. package/dist/{register.message-xxGePuRC.js → register.message-96EL0HQW.js} +7 -7
  172. package/dist/{register.message-qysZPg3G.js → register.message-CXabSYfO.js} +7 -7
  173. package/dist/{register.onboard-D4Aow7Gc.js → register.onboard-2KClPynN.js} +9 -9
  174. package/dist/{register.onboard-1MP2I0q4.js → register.onboard-mHEZSai5.js} +9 -9
  175. package/dist/{register.setup-BT74aXzA.js → register.setup-B-piY6Vs.js} +9 -9
  176. package/dist/{register.setup-DzliKkWh.js → register.setup-Di6tWG-W.js} +9 -9
  177. package/dist/{register.status-health-sessions-D7VYZlrU.js → register.status-health-sessions-BhIYRApE.js} +9 -9
  178. package/dist/{register.status-health-sessions-B3K2gZ72.js → register.status-health-sessions-ZX2odxGg.js} +9 -9
  179. package/dist/{register.subclis-BCy0IDRv.js → register.subclis-CQtXpheE.js} +20 -20
  180. package/dist/{registry-X6fUE0K7.js → registry-DYq1AYOv.js} +19 -19
  181. package/dist/{replies-86F3PldM.js → replies-CUWXgyx2.js} +3 -3
  182. package/dist/{reply-Dg1ZU3DZ.js → reply-D455A6SA.js} +125 -78
  183. package/dist/{reply-prefix-CI_IdwqH.js → reply-prefix-CvEIl6_d.js} +1 -1
  184. package/dist/{resolve-route-BgSuN9c6.js → resolve-route-Jy5dFY67.js} +4 -4
  185. package/dist/{retry-4oEAHckB.js → retry-B-y5suGA.js} +1 -1
  186. package/dist/{rpc-DYHXLh0P.js → rpc-C3ZUAjXK.js} +1 -1
  187. package/dist/{rpc-DdlEeEXT.js → rpc-St4eAsjR.js} +1 -1
  188. package/dist/{run-main-OS2aFAJ2.js → run-main-CnqZnevI.js} +20 -20
  189. package/dist/{runner-DFuAePEr.js → runner-Dpjulwnm.js} +1 -1
  190. package/dist/{runner-B5oNTtgf.js → runner-ecX1WzDt.js} +22 -22
  191. package/dist/{security-cli-BadXDWTh.js → security-cli-B8gavsuQ.js} +3 -3
  192. package/dist/{security-cli-D5y28-RH.js → security-cli-BSvxNP9m.js} +3 -3
  193. package/dist/{send-cCTQjuOZ.js → send-BKo1T3HF.js} +6 -6
  194. package/dist/{send-BTfqlrYd.js → send-Bb4it0te.js} +18 -18
  195. package/dist/{send-CSydU49L.js → send-C0QjmPaf.js} +10 -10
  196. package/dist/{send-Du-IfSne.js → send-Cpk3Ti6-.js} +6 -6
  197. package/dist/{send-ASDB3AzC.js → send-DFtnbzqy.js} +7 -7
  198. package/dist/{server-methods-D_iKJ-sj.js → server-methods-CYPSYbhs.js} +55 -11
  199. package/dist/{server-methods-BszFAkbJ.js → server-methods-DYjr-KwQ.js} +55 -11
  200. package/dist/{server-node-events-uBu3XOjd.js → server-node-events-C58gVs27.js} +7 -7
  201. package/dist/{server-node-events-CENHuAVz.js → server-node-events-DqJIrx86.js} +7 -7
  202. package/dist/{session-D8qLj_xN.js → session-BTeY6Gn2.js} +8 -8
  203. package/dist/{skill-commands-BcOduw6G.js → skill-commands-DG2lcozb.js} +16 -16
  204. package/dist/{skills-BrYDT4Jr.js → skills-CXxrn_e2.js} +24 -24
  205. package/dist/{sqlite-P-gMg7fi.js → sqlite-BN_hIcmu.js} +3 -3
  206. package/dist/{status-BvbJavmh.js → status-B_zW9YJ8.js} +1 -1
  207. package/dist/{status-CA0mUJld.js → status-DjjA-TOx.js} +6 -6
  208. package/dist/{status-CBnCPUMG.js → status-Qt6QDFJ1.js} +6 -6
  209. package/dist/{status-DJAeKN4G.js → status-sO6Y-c-v.js} +1 -1
  210. package/dist/{store-Ceagbc4L.js → store-01F_JM7O.js} +6 -6
  211. package/dist/{subagent-registry-C1OyZl-M.js → subagent-registry-B1HJJs3Q.js} +125 -78
  212. package/dist/{subsystem-CzXhCdeY.js → subsystem-BjyjJF-d.js} +1 -1
  213. package/dist/{synthesis-brHrnNF2.js → synthesis-BCSo0xoc.js} +6 -6
  214. package/dist/{synthesis-DuqSkHEr.js → synthesis-Ch82MDG8.js} +54 -54
  215. package/dist/{synthesis-z5B41p_r.js → synthesis-DAUJa_9I.js} +6 -6
  216. package/dist/{synthesis-DNTyB7JY.js → synthesis-DzSo6S9Y.js} +7 -7
  217. package/dist/{system-cli-BFopJ_xI.js → system-cli-BN9MXNk7.js} +3 -3
  218. package/dist/{system-cli-DryauSOX.js → system-cli-CD5latLh.js} +3 -3
  219. package/dist/{tables-qbCoZrYA.js → tables-DoG-pFrf.js} +1 -1
  220. package/dist/{target-errors-uNitqCCT.js → target-errors-DeJTztcq.js} +2 -2
  221. package/dist/{thinking-BV7SCNJP.js → thinking-BprCy23Z.js} +5 -5
  222. package/dist/{tokens-Bl5R3wPD.js → tokens-W0JzCJJM.js} +1 -1
  223. package/dist/{tool-images-JxNglLSr.js → tool-images-SqqWIT22.js} +2 -2
  224. package/dist/{tool-loop-detection-dfE771kg.js → tool-loop-detection-Dj9h1ogr.js} +3 -3
  225. package/dist/{tui-CvHbwJ3G.js → tui-Cu4TZK3I.js} +2 -2
  226. package/dist/{tui-BiBFm_RY.js → tui-DLkE0D7e.js} +2 -2
  227. package/dist/{tui-cli-CmyT9ctV.js → tui-cli-BfuEq3Q-.js} +3 -3
  228. package/dist/{tui-cli-CU6A8Bu2.js → tui-cli-DC9Bq-N_.js} +3 -3
  229. package/dist/{unified-runner-Czg3pdBc.js → unified-runner-CpyVnelK.js} +374 -300
  230. package/dist/{update-cli-CIzkVfmj.js → update-cli-BLQsvLIy.js} +13 -13
  231. package/dist/{update-cli-0lyGyl31.js → update-cli-CgDLDu8d.js} +14 -14
  232. package/dist/{update-runner-D7-LDziQ.js → update-runner-B1vMjo7o.js} +1 -1
  233. package/dist/{update-runner-aYPcKYAN.js → update-runner-DUHTdrZ0.js} +1 -1
  234. package/dist/{web-CN7wnU7w.js → web-Dbg9lDZ4.js} +6 -6
  235. package/dist/{web-BJ5dUZso.js → web-Dhh_eI3q.js} +7 -7
  236. package/dist/{web-B90A99YU.js → web-DpAeT8By.js} +58 -58
  237. package/dist/{web-Wk1ay1eQ.js → web-PhjuzK8Y.js} +7 -7
  238. package/dist/{whatsapp-actions-llk0IUn2.js → whatsapp-actions-DmVpLXmh.js} +23 -23
  239. package/dist/{workspace-CywO4ayZ.js → workspace-DscDraUb.js} +27 -27
  240. package/extensions/bluebubbles/package.json +1 -1
  241. package/extensions/copilot-proxy/package.json +1 -1
  242. package/extensions/diagnostics-otel/package.json +1 -1
  243. package/extensions/discord/package.json +1 -1
  244. package/extensions/feishu/package.json +1 -1
  245. package/extensions/google-antigravity-auth/package.json +1 -1
  246. package/extensions/google-gemini-cli-auth/package.json +1 -1
  247. package/extensions/googlechat/package.json +1 -1
  248. package/extensions/imessage/package.json +1 -1
  249. package/extensions/irc/package.json +1 -1
  250. package/extensions/learning-loop/package.json +1 -1
  251. package/extensions/line/package.json +1 -1
  252. package/extensions/llm-task/package.json +1 -1
  253. package/extensions/matrix/CHANGELOG.md +6 -0
  254. package/extensions/matrix/package.json +1 -1
  255. package/extensions/mattermost/package.json +1 -1
  256. package/extensions/memory-core/package.json +1 -1
  257. package/extensions/memory-lancedb/package.json +1 -1
  258. package/extensions/minimax-portal-auth/package.json +1 -1
  259. package/extensions/msteams/CHANGELOG.md +6 -0
  260. package/extensions/msteams/package.json +1 -1
  261. package/extensions/nextcloud-talk/package.json +1 -1
  262. package/extensions/nostr/CHANGELOG.md +6 -0
  263. package/extensions/nostr/package.json +1 -1
  264. package/extensions/open-prose/package.json +1 -1
  265. package/extensions/outlook/package.json +1 -1
  266. package/extensions/pipeline/package.json +1 -1
  267. package/extensions/signal/package.json +1 -1
  268. package/extensions/slack/package.json +1 -1
  269. package/extensions/telegram/package.json +1 -1
  270. package/extensions/tlon/package.json +1 -1
  271. package/extensions/twitch/CHANGELOG.md +6 -0
  272. package/extensions/twitch/package.json +1 -1
  273. package/extensions/voice-call/CHANGELOG.md +6 -0
  274. package/extensions/voice-call/package.json +1 -1
  275. package/extensions/whatsapp/package.json +1 -1
  276. package/extensions/zalo/CHANGELOG.md +6 -0
  277. package/extensions/zalo/package.json +1 -1
  278. package/extensions/zalouser/CHANGELOG.md +6 -0
  279. package/extensions/zalouser/package.json +1 -1
  280. package/package.json +1 -1
  281. package/dist/paths-CYmyCDsE.js +0 -212
@@ -14,7 +14,7 @@ import { a as logoutWeb, i as logWebSelfId, l as readWebSelfId, p as webAuthExis
14
14
  import { t as normalizeChatType } from "./chat-type-DFDuk3FY.js";
15
15
  import { a as resolveSlackWebClientOptions, c as buildSlackBlocksFallbackText, i as createSlackWebClient, l as parseSlackTarget, o as parseSlackBlocksInput, s as validateSlackBlocksArray, t as sendMessageSlack, u as resolveSlackChannelId } from "./send-BaBv1rAU.js";
16
16
  import { $ as fetchChannelPermissionsDiscord, A as unpinMessageDiscord, B as listScheduledEventsDiscord, C as editMessageDiscord, Ct as resolveTimestampMs, D as pinMessageDiscord, Dt as normalizeChannelSlug, E as listThreadsDiscord, Et as buildChannelKeyCandidates, F as fetchMemberInfoDiscord, G as uploadStickerDiscord, H as timeoutMemberDiscord, I as fetchRoleInfoDiscord, J as editChannelDiscord, K as createChannelDiscord, L as fetchVoiceStatusDiscord, M as banMemberDiscord, N as createScheduledEventDiscord, O as readMessagesDiscord, Ot as resolveChannelEntryMatchWithFallback, P as fetchChannelInfoDiscord, Q as stripUndefinedFields, R as kickMemberDiscord, S as deleteMessageDiscord, St as resolveDiscordSystemLocation, T as listPinsDiscord, Tt as applyChannelMatchMeta, U as listGuildEmojisDiscord, V as removeRoleDiscord, W as uploadEmojiDiscord, X as removeChannelPermissionDiscord, Y as moveChannelDiscord, Z as setChannelPermissionDiscord, _ as sendPollDiscord, _t as resolveDiscordShouldRequireMention, a as removeReactionDiscord, at as resolveDiscordChannelId, b as sendWebhookMessageDiscord, bt as formatDiscordReactionEmoji, c as formatDiscordComponentEventText, ct as allowListMatches$1, d as parseDiscordModalCustomId, dt as normalizeDiscordSlug, et as hasAnyGuildPermissionDiscord, f as parseDiscordModalCustomIdForCarbon, ft as resolveDiscordAllowListMatch, g as sendMessageDiscord, gt as resolveDiscordOwnerAllowFrom, h as resolveDiscordModalEntry, ht as resolveDiscordMemberAccessState, i as removeOwnReactionsDiscord, it as parseDiscordTarget, j as addRoleDiscord, k as searchMessagesDiscord, l as parseDiscordComponentCustomId, lt as isDiscordGroupAllowedByPolicy, m as resolveDiscordComponentEntry, mt as resolveDiscordGuildEntry, n as fetchReactionsDiscord, nt as createDiscordClient, o as sendDiscordComponentMessage, ot as listDiscordDirectoryGroupsLive, p as readDiscordComponentSpec, pt as resolveDiscordChannelConfigWithFallback, q as deleteChannelDiscord, r as reactMessageDiscord, rt as createDiscordRestClient, s as createDiscordFormModal, st as listDiscordDirectoryPeersLive, tt as chunkDiscordTextWithMode, u as parseDiscordComponentCustomIdForCarbon, ut as normalizeDiscordAllowList, v as sendStickerDiscord, vt as resolveGroupDmAllow, w as fetchMessageDiscord, wt as fetchDiscord, x as createThreadDiscord, xt as formatDiscordUserTag, y as sendVoiceMessageDiscord, yt as shouldEmitDiscordReactionNotification, z as listGuildChannelsDiscord } from "./send-DLVrnezL.js";
17
- import { C as getGlobalHookRunner, S as parseInlineDirectives$1, _ as normalizeTargetForProvider, a as normalizeOutboundPayloadsForJson, b as MEDIA_TOKEN_RE, c as applyReplyThreading, d as isRenderablePayload, f as shouldSuppressMessagingToolReplies, g as normalizeChannelTargetInput, h as buildTargetResolverSignature, i as normalizeOutboundPayloads, l as filterMessagingToolDuplicates, m as resolveReplyToMode, o as normalizeReplyPayloadsForDelivery, p as createReplyToModeFilterForChannel, r as formatOutboundPayloadLog, s as applyReplyTagsToPayload, t as deliverOutboundPayloads, u as filterMessagingToolMediaDuplicates, v as throwIfAborted, w as initializeGlobalHookRunner, x as splitMediaFromOutput, y as parseReplyDirectives } from "./deliver-D0bWiRCg.js";
17
+ import { C as getGlobalHookRunner, S as parseInlineDirectives$1, _ as normalizeTargetForProvider, a as normalizeOutboundPayloadsForJson, b as MEDIA_TOKEN_RE, c as applyReplyThreading, d as isRenderablePayload, f as shouldSuppressMessagingToolReplies, g as normalizeChannelTargetInput, h as buildTargetResolverSignature, i as normalizeOutboundPayloads, l as filterMessagingToolDuplicates, m as resolveReplyToMode, o as normalizeReplyPayloadsForDelivery, p as createReplyToModeFilterForChannel, r as formatOutboundPayloadLog, s as applyReplyTagsToPayload, t as deliverOutboundPayloads, u as filterMessagingToolMediaDuplicates, v as throwIfAborted, w as initializeGlobalHookRunner, x as splitMediaFromOutput, y as parseReplyDirectives } from "./deliver-B_Q_nWJV.js";
18
18
  import { a as logMessageProcessed, c as logWebhookError, d as startDiagnosticHeartbeat, f as stopDiagnosticHeartbeat, i as logLaneEnqueue, l as logWebhookProcessed, m as isDiagnosticsEnabled, o as logMessageQueued, p as emitDiagnosticEvent, r as logLaneDequeue, s as logSessionStateChange, t as diag, u as logWebhookReceived } from "./diagnostic-Kbl70eCP.js";
19
19
  import { r as getDiagnosticSessionState } from "./diagnostic-session-state-C1vRJs5w.js";
20
20
  import { n as resolveSignalAccount, t as listEnabledSignalAccounts } from "./accounts-8zZqL37v.js";
@@ -22,10 +22,10 @@ import { $ as isVoiceCompatibleAudio, A as extractTelegramLocation, B as normali
22
22
  import { d as detectMime, f as extensionForMime, g as isGifMedia, h as isAudioFileName, i as getImageMetadata, m as imageMimeFromFormat, s as resizeToJpeg, x as mediaKindFromMime, y as MAX_IMAGE_BYTES } from "./image-ops-ByaQt43P.js";
23
23
  import { n as discoverModels, t as discoverAuthStorage } from "./pi-model-discovery-j5tVLINv.js";
24
24
  import { a as isMarkdownCapableMessageChannel, c as resolveGatewayMessageChannel, d as GATEWAY_CLIENT_MODES, f as GATEWAY_CLIENT_NAMES, i as isInternalMessageChannel, l as resolveMessageChannel, n as isDeliverableMessageChannel, o as listDeliverableMessageChannels, r as isGatewayMessageChannel, s as normalizeMessageChannel, t as INTERNAL_MESSAGE_CHANNEL, u as GATEWAY_CLIENT_IDS } from "./message-channel-BQINJQIT.js";
25
- import { $ as mergeDeliveryContext, A as isTransientHttpError, At as DEFAULT_UPLOAD_DIR, Bt as expandToolGroups, C as isContextOverflowError, Ct as resolveGroupSessionKey, D as isRateLimitAssistantError, Dt as registerBrowserRoutes, E as isLikelyContextOverflowError, Et as createBrowserRouteContext, F as resolveSandboxContext, Ft as resolveSandboxConfigForAgent, Gt as compileGlobPatterns, H as loadSessionStore, Ht as normalizeToolName, I as resolveSandboxRuntimeStatus, It as applyOwnerOnlyToolPolicy, J as updateSessionStoreEntry, Jt as ensureSessionHeader, K as updateLastRoute, Kt as matchesAnyGlobPattern, L as extractDeliveryInfo, Lt as buildPluginToolGroups, M as parseImageSizeError, Mt as getBridgeAuthForPort, N as sanitizeUserFacingText, Nt as ensureBrowserControlAuth, O as isRawApiErrorPayload, Ot as resolveBrowserConfig, P as ensureSandboxWorkspaceForSession, Pt as resolveBrowserControlAuth, Q as deliveryContextKey, R as parseSessionThreadInfo, Rt as collectExplicitAllowlist, S as isCompactionFailureError, St as deriveSessionMetaPatch, T as isFailoverErrorMessage, Tt as resolveSessionLockMaxHoldFromTimeout, U as readSessionUpdatedAt, Ut as resolveToolProfilePolicy, V as resolveAndPersistSessionFile, Vt as mergeAlsoAllowPolicy, W as recordSessionMetaFromInbound, Wt as stripPluginOnlyAllowlist, X as resolveCacheTtlMs$1, Xt as resolveBootstrapTotalMaxChars, Y as isCacheEnabled, Yt as resolveBootstrapMaxChars, Z as deliveryContextFromSession, Zt as sanitizeGoogleTurnOrdering, _ as formatRawAssistantErrorForUi, _t as DEFAULT_RESET_TRIGGERS, a as isMessagingToolDuplicateNormalized, at as countToolResults, b as isBillingAssistantError, bt as resolveExplicitAgentSessionKey, c as extractToolCallsFromAssistant, ct as applyInputProvenanceToUserMessage, d as isAntigravityClaude, dt as resolveSessionKey, et as normalizeDeliveryContext, f as isGoogleModelApi, ft as evaluateSessionFreshness, g as formatBillingErrorMessage, gt as resolveThreadFlag, h as formatAssistantErrorText, ht as resolveSessionResetType, it as capArrayByJsonBytes, j as parseImageDimensionError, jt as resolveExistingPathsWithinRoot, k as isTimeoutErrorMessage, kt as resolveProfile, l as extractToolResultId, lt as hasInterSessionUserProvenance, m as classifyFailoverReason, mt as resolveSessionResetPolicy, n as validateGeminiTurns, nt as normalizeAccountId$3, o as normalizeTextForComparison, ot as extractToolCallNames, p as BILLING_ERROR_USER_MESSAGE, pt as resolveChannelResetConfig, q as updateSessionStore, qt as buildBootstrapContextFiles, r as pickFallbackThinkingLevel, rt as archiveSessionTranscripts, s as sanitizeSessionMessagesImages, st as INPUT_PROVENANCE_KIND_VALUES, t as validateAnthropicTurns, tt as normalizeSessionDeliveryFields, u as downgradeOpenAIReasoningBlocks, ut as normalizeInputProvenance, v as getApiErrorPayloadFingerprint, vt as resolveFreshSessionTotalTokens, w as isFailoverAssistantError, wt as acquireSessionWriteLock, x as isCloudCodeAssistFormatError, xt as resolveMainSessionKey, y as isAuthAssistantError, yt as canonicalizeMainSessionAlias, z as appendAssistantMessageToSessionTranscript, zt as expandPolicyWithPluginGroups } from "./pi-embedded-helpers-TcYQOZAY.js";
25
+ import { $ as mergeDeliveryContext, A as isTransientHttpError, At as DEFAULT_UPLOAD_DIR, Bt as expandToolGroups, C as isContextOverflowError, Ct as resolveGroupSessionKey, D as isRateLimitAssistantError, Dt as registerBrowserRoutes, E as isLikelyContextOverflowError, Et as createBrowserRouteContext, F as resolveSandboxContext, Ft as resolveSandboxConfigForAgent, Gt as compileGlobPatterns, H as loadSessionStore, Ht as normalizeToolName, I as resolveSandboxRuntimeStatus, It as applyOwnerOnlyToolPolicy, J as updateSessionStoreEntry, Jt as ensureSessionHeader, K as updateLastRoute, Kt as matchesAnyGlobPattern, L as extractDeliveryInfo, Lt as buildPluginToolGroups, M as parseImageSizeError, Mt as getBridgeAuthForPort, N as sanitizeUserFacingText, Nt as ensureBrowserControlAuth, O as isRawApiErrorPayload, Ot as resolveBrowserConfig, P as ensureSandboxWorkspaceForSession, Pt as resolveBrowserControlAuth, Q as deliveryContextKey, R as parseSessionThreadInfo, Rt as collectExplicitAllowlist, S as isCompactionFailureError, St as deriveSessionMetaPatch, T as isFailoverErrorMessage, Tt as resolveSessionLockMaxHoldFromTimeout, U as readSessionUpdatedAt, Ut as resolveToolProfilePolicy, V as resolveAndPersistSessionFile, Vt as mergeAlsoAllowPolicy, W as recordSessionMetaFromInbound, Wt as stripPluginOnlyAllowlist, X as resolveCacheTtlMs$1, Xt as resolveBootstrapTotalMaxChars, Y as isCacheEnabled, Yt as resolveBootstrapMaxChars, Z as deliveryContextFromSession, Zt as sanitizeGoogleTurnOrdering, _ as formatRawAssistantErrorForUi, _t as DEFAULT_RESET_TRIGGERS, a as isMessagingToolDuplicateNormalized, at as countToolResults, b as isBillingAssistantError, bt as resolveExplicitAgentSessionKey, c as extractToolCallsFromAssistant, ct as applyInputProvenanceToUserMessage, d as isAntigravityClaude, dt as resolveSessionKey, et as normalizeDeliveryContext, f as isGoogleModelApi, ft as evaluateSessionFreshness, g as formatBillingErrorMessage, gt as resolveThreadFlag, h as formatAssistantErrorText, ht as resolveSessionResetType, it as capArrayByJsonBytes, j as parseImageDimensionError, jt as resolveExistingPathsWithinRoot, k as isTimeoutErrorMessage, kt as resolveProfile, l as extractToolResultId, lt as hasInterSessionUserProvenance, m as classifyFailoverReason, mt as resolveSessionResetPolicy, n as validateGeminiTurns, nt as normalizeAccountId$3, o as normalizeTextForComparison, ot as extractToolCallNames, p as BILLING_ERROR_USER_MESSAGE, pt as resolveChannelResetConfig, q as updateSessionStore, qt as buildBootstrapContextFiles, r as pickFallbackThinkingLevel, rt as archiveSessionTranscripts, s as sanitizeSessionMessagesImages, st as INPUT_PROVENANCE_KIND_VALUES, t as validateAnthropicTurns, tt as normalizeSessionDeliveryFields, u as downgradeOpenAIReasoningBlocks, ut as normalizeInputProvenance, v as getApiErrorPayloadFingerprint, vt as resolveFreshSessionTotalTokens, w as isFailoverAssistantError, wt as acquireSessionWriteLock, x as isCloudCodeAssistFormatError, xt as resolveMainSessionKey, y as isAuthAssistantError, yt as canonicalizeMainSessionAlias, z as appendAssistantMessageToSessionTranscript, zt as expandPolicyWithPluginGroups } from "./pi-embedded-helpers-DjSdA5BG.js";
26
26
  import { A as VERSION, C as getConfigValueAtPath, D as isSafeExecutableValue, E as unsetConfigValueAtPath, O as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH, S as unsetConfigOverride, T as setConfigValueAtPath, _ as parseDurationMs, a as writeConfigFile, b as resetConfigOverrides, c as TELEGRAM_COMMAND_NAME_PATTERN, f as isInboundPathAllowed, g as normalizeScpRemoteHost, h as resolveIMessageRemoteAttachmentRoots, i as resolveConfigSnapshotHash, k as resolveAgentMaxConcurrent, l as normalizeTelegramCommandName, m as resolveIMessageAttachmentRoots, n as loadConfig, o as validateConfigObjectWithPlugins, r as readConfigFileSnapshot, u as resolveTelegramCustomCommands, v as validateJsonSchemaValue, w as parseConfigPath, x as setConfigOverride, y as getConfigOverrides } from "./config-BAVNLbja.js";
27
27
  import { c as normalizePluginsConfig, f as isPathInsideWithRealpath, i as safeStatSync, l as resolveEnableState, n as discoverSymiPlugins, p as isDangerousHostEnvVarName, r as isPathInside, s as applyTestPluginDefaults, t as loadPluginManifestRegistry, u as resolveMemorySlotDecision } from "./manifest-registry-DWdYdchb.js";
28
- import { C as rawDataToString, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, T as isSecureWebSocketUrl, x as ensureChromeExtensionRelayServer } from "./chrome-B14NNyfm.js";
28
+ import { C as rawDataToString, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, T as isSecureWebSocketUrl, x as ensureChromeExtensionRelayServer } from "./chrome-BUT--ob3.js";
29
29
  import { c as assertSandboxPath, d as resolveSandboxedMediaSource, f as applySkillEnvOverrides, i as resolveSkillsPromptForRun, l as resolveSandboxInputPath, n as buildWorkspaceSkillSnapshot, p as applySkillEnvOverridesFromSnapshot, r as loadWorkspaceSkillEntries, s as assertMediaNotDataUrl } from "./skills-XEbTRNYL.js";
30
30
  import { n as formatErrorMessage, r as formatUncaughtError } from "./errors-CPfngF0S.js";
31
31
  import { i as isBlockedHostnameOrIp, o as normalizeHostname, t as SsrFBlockedError } from "./ssrf-CxfFyMRZ.js";
@@ -36,8 +36,8 @@ import { t as resolveIMessageAccount } from "./accounts-DImOt9jX.js";
36
36
  import { i as resolveSessionTranscriptPath, n as resolveSessionFilePath, o as resolveSessionTranscriptsDirForAgent, r as resolveSessionFilePathOptions, s as resolveStorePath, t as resolveDefaultSessionStorePath } from "./paths-DkMamAQ-.js";
37
37
  import { t as emitSessionTranscriptUpdate } from "./transcript-events-C8Tqw4td.js";
38
38
  import { i as resolveImageSanitizationLimits, n as sanitizeImageBlocks, r as sanitizeToolResultImages } from "./tool-images-ChC2CXaN.js";
39
- import { S as ensureSymiModelsJson, _ as stripMinimaxToolCallXml, a as decodeDataUrl, b as stripReasoningTagsFromText, c as extractAssistantText$1, d as extractThinkingFromTaggedText, f as formatReasoningMessage, g as stripDowngradedToolCallText, h as promoteThinkingTagsToBlocks, i as coerceImageModelConfig, l as extractAssistantThinking, m as isAssistantMessage, o as resolveProviderVisionModelFromConfig, p as inferToolMetaFromArgs, r as coerceImageAssistantText, s as minimaxUnderstandImage, u as extractThinkingFromTaggedStream, v as stripThinkingTagsFromText, x as extractTextFromChatContent, y as resolveToolDisplay } from "./image-MNvheU8U.js";
40
- import { a as resolveMemorySearchConfig, i as resolveOllamaBaseUrl, r as probeOllamaEmbeddingModels, t as MemoryIndexManager } from "./manager-BtWtmpxN.js";
39
+ import { S as ensureSymiModelsJson, _ as stripMinimaxToolCallXml, a as decodeDataUrl, b as stripReasoningTagsFromText, c as extractAssistantText$1, d as extractThinkingFromTaggedText, f as formatReasoningMessage, g as stripDowngradedToolCallText, h as promoteThinkingTagsToBlocks, i as coerceImageModelConfig, l as extractAssistantThinking, m as isAssistantMessage, o as resolveProviderVisionModelFromConfig, p as inferToolMetaFromArgs, r as coerceImageAssistantText, s as minimaxUnderstandImage, u as extractThinkingFromTaggedStream, v as stripThinkingTagsFromText, x as extractTextFromChatContent, y as resolveToolDisplay } from "./image-tzIqIuKx.js";
40
+ import { a as resolveMemorySearchConfig, i as resolveOllamaBaseUrl, r as probeOllamaEmbeddingModels, t as MemoryIndexManager } from "./manager-B76ofKkW.js";
41
41
  import { c as normalizeExtraMemoryPaths, f as runTasksWithConcurrency, s as listMemoryFiles } from "./internal-479FB0St.js";
42
42
  import { n as retryAsync } from "./retry-QGp0jvVi.js";
43
43
  import { a as createActionGate, c as jsonResult, d as readReactionParams, f as readStringArrayParam, l as parseAvailableTags, m as readStringParam, n as missingTargetError, o as imageResult, p as readStringOrNumberParam, r as unknownTargetError, s as imageResultFromFile, t as ambiguousTargetError, u as readNumberParam } from "./target-errors-Dm716SF3.js";
@@ -49,7 +49,7 @@ import { a as loadWebMedia, i as getDefaultLocalRoots } from "./ir-0kwEfxD4.js";
49
49
  import { _ as resolveNativeCommandsEnabled, a as listChatCommandsForConfig, c as normalizeCommandBody, d as resolveCommandArgMenu, f as serializeCommandArgs, g as isRestartEnabled, h as isNativeCommandsExplicitlyDisabled, i as listChatCommands, l as parseCommandArgs, m as isCommandFlagEnabled, o as listNativeCommandSpecs, p as shouldHandleTextCommands, r as findCommandByNativeName, s as listNativeCommandSpecsForConfig, t as buildCommandTextFromArgs, u as resolveCommandArgChoices, v as resolveNativeSkillsEnabled } from "./commands-registry-ke7KirEH.js";
50
50
  import { c as getSkillsSnapshotVersion, d as createAsyncLock, f as readJsonFile, i as resolveSkillCommandInvocation, l as pruneExpiredPending, n as listSkillCommandsForAgents, o as getRemoteSkillEligibility, p as writeJsonAtomic, r as listSkillCommandsForWorkspace, s as ensureSkillsWatcher, t as listReservedChatSlashCommandNames, u as resolvePairingPaths } from "./skill-commands-CSF7Poen.js";
51
51
  import { r as normalizeInboundTextNewlines, t as finalizeInboundContext } from "./inbound-context-CgGv6nTy.js";
52
- import { _ as resolveMediaUnderstandingScope, a as resolveMediaAttachmentLocalRoots, c as loadModelCatalog, d as resolveAttachmentKind, f as buildRandomTempFilePath, g as normalizeMediaUnderstandingChatType, h as resolveTimeoutMs$1, i as resolveAutoImageModel, l as modelSupportsVision, m as resolveConcurrency, n as createMediaAttachmentCache, o as runCapability, p as registerUnhandledRejectionHandler, r as normalizeMediaAttachments, s as findModelInCatalog, t as buildProviderRegistry, v as CLI_OUTPUT_MAX_BUFFER, y as applyTemplate } from "./runner-DFuAePEr.js";
52
+ import { _ as resolveMediaUnderstandingScope, a as resolveMediaAttachmentLocalRoots, c as loadModelCatalog, d as resolveAttachmentKind, f as buildRandomTempFilePath, g as normalizeMediaUnderstandingChatType, h as resolveTimeoutMs$1, i as resolveAutoImageModel, l as modelSupportsVision, m as resolveConcurrency, n as createMediaAttachmentCache, o as runCapability, p as registerUnhandledRejectionHandler, r as normalizeMediaAttachments, s as findModelInCatalog, t as buildProviderRegistry, v as CLI_OUTPUT_MAX_BUFFER, y as applyTemplate } from "./runner-Dpjulwnm.js";
53
53
  import { n as wrapFetchWithAbortSignal, t as resolveFetch } from "./fetch-WLZaC77l.js";
54
54
  import { n as recordCommandPoll, r as resetCommandPollCount } from "./command-poll-backoff-BaoETsQI.js";
55
55
  import { n as recordChannelActivity, r as createDiscordRetryRunner, t as getChannelActivity } from "./channel-activity-C-6tM-GK.js";
@@ -80,7 +80,7 @@ import { EdgeTTS } from "node-edge-tts";
80
80
  import AjvPkg from "ajv";
81
81
  import { createServer } from "node:http";
82
82
  import { ProxyAgent, fetch as fetch$1 } from "undici";
83
- import WebSocket, { WebSocket as WebSocket$1 } from "ws";
83
+ import WebSocket$1, { WebSocket } from "ws";
84
84
  import { Buffer as Buffer$1 } from "node:buffer";
85
85
  import { createJiti } from "jiti";
86
86
  import { Type } from "@sinclair/typebox";
@@ -3473,7 +3473,7 @@ async function getMemorySearchManager(params) {
3473
3473
  const wrapper = new FallbackMemoryManager({
3474
3474
  primary,
3475
3475
  fallbackFactory: async () => {
3476
- const { MemoryIndexManager } = await import("./manager-BtWtmpxN.js").then((n) => n.n);
3476
+ const { MemoryIndexManager } = await import("./manager-B76ofKkW.js").then((n) => n.n);
3477
3477
  return await MemoryIndexManager.get(params);
3478
3478
  }
3479
3479
  }, () => QMD_MANAGER_CACHE.delete(cacheKey));
@@ -3486,7 +3486,7 @@ async function getMemorySearchManager(params) {
3486
3486
  }
3487
3487
  }
3488
3488
  try {
3489
- const { MemoryIndexManager } = await import("./manager-BtWtmpxN.js").then((n) => n.n);
3489
+ const { MemoryIndexManager } = await import("./manager-B76ofKkW.js").then((n) => n.n);
3490
3490
  return { manager: await MemoryIndexManager.get(params) };
3491
3491
  } catch (err) {
3492
3492
  return {
@@ -5608,6 +5608,31 @@ const SessionsUsageParamsSchema = Type.Object({
5608
5608
  includeContextWeight: Type.Optional(Type.Boolean())
5609
5609
  }, { additionalProperties: false });
5610
5610
 
5611
+ //#endregion
5612
+ //#region src/gateway/protocol/schema/tasks.ts
5613
+ /**
5614
+ * tasks.list — enumerates long-running detached tasks across configured
5615
+ * agent workspaces. Optional `workdir` override scans a single absolute
5616
+ * directory instead.
5617
+ */
5618
+ const TasksListParamsSchema = Type.Object({ workdir: Type.Optional(Type.String()) }, { additionalProperties: false });
5619
+ const TaskInfoSchema = Type.Object({
5620
+ id: Type.String(),
5621
+ agentId: Type.Optional(Type.String()),
5622
+ workdir: Type.String(),
5623
+ pid: Type.Union([Type.Integer(), Type.Null()]),
5624
+ alive: Type.Boolean(),
5625
+ archived: Type.Boolean(),
5626
+ status: Type.String(),
5627
+ started: Type.Union([Type.String(), Type.Null()]),
5628
+ cmd: Type.Union([Type.String(), Type.Null()]),
5629
+ pidPath: Type.String(),
5630
+ statusPath: Type.String(),
5631
+ archivedPath: Type.String(),
5632
+ logPath: Type.String()
5633
+ }, { additionalProperties: false });
5634
+ const TasksListResultSchema = Type.Object({ tasks: Type.Array(TaskInfoSchema) }, { additionalProperties: false });
5635
+
5611
5636
  //#endregion
5612
5637
  //#region src/gateway/protocol/schema/wizard.ts
5613
5638
  const WizardRunStatusSchema = Type.Union([
@@ -5693,6 +5718,7 @@ const validateAgentIdentityParams = ajv.compile(AgentIdentityParamsSchema);
5693
5718
  const validateAgentWaitParams = ajv.compile(AgentWaitParamsSchema);
5694
5719
  const validateWakeParams = ajv.compile(WakeParamsSchema);
5695
5720
  const validateAgentsListParams = ajv.compile(AgentsListParamsSchema);
5721
+ const validateTasksListParams = ajv.compile(TasksListParamsSchema);
5696
5722
  const validateAgentsCreateParams = ajv.compile(AgentsCreateParamsSchema);
5697
5723
  const validateAgentsUpdateParams = ajv.compile(AgentsUpdateParamsSchema);
5698
5724
  const validateAgentsDeleteParams = ajv.compile(AgentsDeleteParamsSchema);
@@ -5818,7 +5844,7 @@ var GatewayClient = class {
5818
5844
  if (fingerprint !== expected) return /* @__PURE__ */ new Error("gateway tls fingerprint mismatch");
5819
5845
  });
5820
5846
  }
5821
- this.ws = new WebSocket$1(url, wsOptions);
5847
+ this.ws = new WebSocket(url, wsOptions);
5822
5848
  this.ws.on("open", () => {
5823
5849
  if (url.startsWith("wss://") && this.opts.tlsFingerprint) {
5824
5850
  const tlsError = this.validateTlsFingerprint();
@@ -6037,7 +6063,7 @@ var GatewayClient = class {
6037
6063
  return null;
6038
6064
  }
6039
6065
  async request(method, params, opts) {
6040
- if (!this.ws || this.ws.readyState !== WebSocket$1.OPEN) throw new Error("gateway not connected");
6066
+ if (!this.ws || this.ws.readyState !== WebSocket.OPEN) throw new Error("gateway not connected");
6041
6067
  const id = randomUUID();
6042
6068
  const frame = {
6043
6069
  type: "req",
@@ -6115,6 +6141,7 @@ const METHOD_SCOPE_GROUPS = {
6115
6141
  "cron.list",
6116
6142
  "cron.status",
6117
6143
  "cron.runs",
6144
+ "tasks.list",
6118
6145
  "system-presence",
6119
6146
  "last-heartbeat",
6120
6147
  "node.list",
@@ -7304,7 +7331,7 @@ async function routeReply(params) {
7304
7331
  const resolvedReplyToId = replyToId ?? (channelId === "slack" && threadId != null && threadId !== "" ? String(threadId) : void 0);
7305
7332
  const resolvedThreadId = channelId === "slack" ? null : threadId ?? null;
7306
7333
  try {
7307
- const { deliverOutboundPayloads } = await import("./deliver-D0bWiRCg.js").then((n) => n.n);
7334
+ const { deliverOutboundPayloads } = await import("./deliver-B_Q_nWJV.js").then((n) => n.n);
7308
7335
  return {
7309
7336
  ok: true,
7310
7337
  messageId: (await deliverOutboundPayloads({
@@ -36661,6 +36688,103 @@ function createSubagentsTool(opts) {
36661
36688
  };
36662
36689
  }
36663
36690
 
36691
+ //#endregion
36692
+ //#region src/infra/long-task-state.ts
36693
+ /**
36694
+ * Shared helpers for reading the on-disk state files written by
36695
+ * skills/long-task/scripts/detach-task.sh:
36696
+ *
36697
+ * task-<id>.pid — PID of the detached process
36698
+ * task-<id>.cmd — literal command line
36699
+ * task-<id>.started — ISO-8601 start timestamp
36700
+ * task-<id>.log — combined stdout + stderr
36701
+ * task-<id>.status — current state line
36702
+ * task-<id>.archived — tombstone written by the janitor when it sweeps
36703
+ * a finished task more than 7 days old
36704
+ *
36705
+ * Both the agent-facing tools (task_list / task_cancel) and the gateway's
36706
+ * tasks.list RPC consume this helper so the two views stay in sync.
36707
+ */
36708
+ const TASK_FILE_PREFIX = "task-";
36709
+ const TASK_ID_RE = /^[a-zA-Z0-9_][a-zA-Z0-9._-]{0,59}$/;
36710
+ const TASK_FILE_SUFFIXES = [
36711
+ ".pid",
36712
+ ".status",
36713
+ ".started",
36714
+ ".cmd",
36715
+ ".log",
36716
+ ".archived"
36717
+ ];
36718
+ function defaultIsPidAlive(pid) {
36719
+ try {
36720
+ process.kill(pid, 0);
36721
+ return true;
36722
+ } catch (err) {
36723
+ if (err.code === "EPERM") return true;
36724
+ return false;
36725
+ }
36726
+ }
36727
+ async function safeRead(filePath) {
36728
+ try {
36729
+ return (await fs.promises.readFile(filePath, "utf8")).trim();
36730
+ } catch {
36731
+ return null;
36732
+ }
36733
+ }
36734
+ async function readTaskInfo(workdir, id, isPidAlive = defaultIsPidAlive) {
36735
+ const pidPath = path.join(workdir, `${TASK_FILE_PREFIX}${id}.pid`);
36736
+ const statusPath = path.join(workdir, `${TASK_FILE_PREFIX}${id}.status`);
36737
+ const archivedPath = path.join(workdir, `${TASK_FILE_PREFIX}${id}.archived`);
36738
+ const logPath = path.join(workdir, `${TASK_FILE_PREFIX}${id}.log`);
36739
+ const [pidText, status, started, cmd, archived] = await Promise.all([
36740
+ safeRead(pidPath),
36741
+ safeRead(statusPath),
36742
+ safeRead(path.join(workdir, `${TASK_FILE_PREFIX}${id}.started`)),
36743
+ safeRead(path.join(workdir, `${TASK_FILE_PREFIX}${id}.cmd`)),
36744
+ safeRead(archivedPath)
36745
+ ]);
36746
+ let pid = null;
36747
+ if (pidText) {
36748
+ const parsed = Number.parseInt(pidText, 10);
36749
+ if (Number.isFinite(parsed) && parsed > 0) pid = parsed;
36750
+ }
36751
+ let resolvedStatus;
36752
+ if (status) resolvedStatus = status;
36753
+ else if (archived) resolvedStatus = archived;
36754
+ else resolvedStatus = "missing";
36755
+ return {
36756
+ id,
36757
+ pid,
36758
+ alive: pid !== null && isPidAlive(pid),
36759
+ archived: archived !== null,
36760
+ status: resolvedStatus,
36761
+ started,
36762
+ cmd,
36763
+ pidPath,
36764
+ statusPath,
36765
+ archivedPath,
36766
+ logPath
36767
+ };
36768
+ }
36769
+ async function listTasksInWorkdir(workdir, isPidAlive = defaultIsPidAlive) {
36770
+ let entries;
36771
+ try {
36772
+ entries = await fs.promises.readdir(workdir);
36773
+ } catch {
36774
+ return [];
36775
+ }
36776
+ const taskIds = /* @__PURE__ */ new Set();
36777
+ for (const entry of entries) {
36778
+ if (!entry.startsWith(TASK_FILE_PREFIX)) continue;
36779
+ for (const suffix of TASK_FILE_SUFFIXES) if (entry.endsWith(suffix)) {
36780
+ const id = entry.slice(5, -suffix.length);
36781
+ if (id.length > 0 && TASK_ID_RE.test(id)) taskIds.add(id);
36782
+ break;
36783
+ }
36784
+ }
36785
+ return await Promise.all([...taskIds].toSorted().map((id) => readTaskInfo(workdir, id, isPidAlive)));
36786
+ }
36787
+
36664
36788
  //#endregion
36665
36789
  //#region src/agents/tools/task-tool.ts
36666
36790
  /**
@@ -36670,21 +36794,14 @@ function createSubagentsTool(opts) {
36670
36794
  * script writes task-<id>.{pid,cmd,started,log,status} state files into
36671
36795
  * the agent's workspace; these tools read and act on those files so the
36672
36796
  * agent can answer "what's running?" and kill a task without needing
36673
- * shell access.
36797
+ * shell access. Shared scanning logic lives in
36798
+ * src/infra/long-task-state.ts so the gateway's tasks.list RPC and these
36799
+ * agent tools agree on every shape detail.
36674
36800
  *
36675
36801
  * task-id allow-list mirrors detach-task.sh: 1–60 chars from
36676
36802
  * [a-zA-Z0-9._-], must not start with '.' or '-'. Diverging would let the
36677
36803
  * agent kill processes it never spawned via path traversal.
36678
36804
  */
36679
- const TASK_FILE_PREFIX = "task-";
36680
- const TASK_ID_RE = /^[a-zA-Z0-9_][a-zA-Z0-9._-]{0,59}$/;
36681
- const TASK_FILE_SUFFIXES = [
36682
- ".pid",
36683
- ".status",
36684
- ".started",
36685
- ".cmd",
36686
- ".log"
36687
- ];
36688
36805
  const ALLOWED_SIGNALS = new Set([
36689
36806
  "SIGTERM",
36690
36807
  "SIGINT",
@@ -36716,58 +36833,30 @@ function isPidAlive(pid) {
36716
36833
  return false;
36717
36834
  }
36718
36835
  }
36719
- async function safeRead(filePath) {
36720
- try {
36721
- return (await fs.promises.readFile(filePath, "utf8")).trim();
36722
- } catch {
36723
- return null;
36724
- }
36725
- }
36726
36836
  function resolveWorkdir(deps, override) {
36727
36837
  const raw = override?.trim();
36728
36838
  if (!raw) return deps.workspaceDir;
36729
36839
  if (!path.isAbsolute(raw)) throw new Error(`workdir must be an absolute path (got: ${raw})`);
36730
36840
  return raw;
36731
36841
  }
36732
- async function readTaskInfo(workdir, id) {
36733
- const pidPath = path.join(workdir, `${TASK_FILE_PREFIX}${id}.pid`);
36734
- const [pidText, status, started, cmd] = await Promise.all([
36735
- safeRead(pidPath),
36736
- safeRead(path.join(workdir, `${TASK_FILE_PREFIX}${id}.status`)),
36737
- safeRead(path.join(workdir, `${TASK_FILE_PREFIX}${id}.started`)),
36738
- safeRead(path.join(workdir, `${TASK_FILE_PREFIX}${id}.cmd`))
36739
- ]);
36740
- let pid = null;
36741
- if (pidText) {
36742
- const parsed = Number.parseInt(pidText, 10);
36743
- if (Number.isFinite(parsed) && parsed > 0) pid = parsed;
36744
- }
36745
- return {
36746
- id,
36747
- pid,
36748
- alive: pid !== null && isPidAlive(pid),
36749
- status: status ?? "missing",
36750
- started,
36751
- cmd,
36752
- pidPath,
36753
- statusPath: path.join(workdir, `${TASK_FILE_PREFIX}${id}.status`),
36754
- logPath: path.join(workdir, `${TASK_FILE_PREFIX}${id}.log`)
36755
- };
36756
- }
36757
36842
  function createTaskListTool(deps) {
36758
36843
  return {
36759
36844
  label: "Task List",
36760
36845
  name: "task_list",
36761
36846
  description: `List long-running detached tasks in the agent's workspace.
36762
36847
 
36763
- Globs task-<id>.{pid,status,started,cmd,log} files, reads their state, and
36764
- checks each PID's liveness. Use this to find the task-id of a running
36765
- detach-task before calling task_cancel, or to answer "what's running right
36766
- now?" without re-asking the user.
36767
-
36768
- Returns: { workdir, tasks: [{ id, pid, alive, status, started, cmd, pidPath, statusPath, logPath }] }.
36769
- Tasks whose .pid file is missing are still listed (alive=false, pid=null) so
36770
- the agent can spot orphan state files.`,
36848
+ Globs task-<id>.{pid,status,started,cmd,log,archived} files, reads their
36849
+ state, and checks each PID's liveness. Use this to find the task-id of a
36850
+ running detach-task before calling task_cancel, or to answer "what's
36851
+ running right now?" without re-asking the user.
36852
+
36853
+ Returns: { workdir, tasks: [{ id, pid, alive, status, archived, started, cmd, pidPath, statusPath, archivedPath, logPath }] }.
36854
+ - archived=true means the janitor swept this task's live state files (>7d
36855
+ dead) and replaced them with a tombstone. The canonical end status is
36856
+ preserved in the .archived file. Distinct from "missing" (no tombstone,
36857
+ no live files) which means the task crashed or its workdir was wiped.
36858
+ - Tasks whose .pid file is missing are still listed (alive=false, pid=null)
36859
+ so the agent can spot orphan state files.`,
36771
36860
  parameters: TaskListSchema,
36772
36861
  execute: async (_toolCallId, args) => {
36773
36862
  const override = readStringParam(args, "workdir");
@@ -36781,34 +36870,19 @@ the agent can spot orphan state files.`,
36781
36870
  error: err instanceof Error ? err.message : String(err)
36782
36871
  });
36783
36872
  }
36784
- let entries;
36785
36873
  try {
36786
- entries = await fs.promises.readdir(workdir);
36787
- } catch (err) {
36788
- if (err.code === "ENOENT") return jsonResult({
36874
+ const tasks = await listTasksInWorkdir(workdir, isPidAlive);
36875
+ return jsonResult({
36789
36876
  workdir,
36790
- tasks: []
36877
+ tasks
36791
36878
  });
36879
+ } catch (err) {
36792
36880
  return jsonResult({
36793
36881
  workdir,
36794
36882
  tasks: [],
36795
36883
  error: err instanceof Error ? err.message : String(err)
36796
36884
  });
36797
36885
  }
36798
- const taskIds = /* @__PURE__ */ new Set();
36799
- for (const entry of entries) {
36800
- if (!entry.startsWith(TASK_FILE_PREFIX)) continue;
36801
- for (const suffix of TASK_FILE_SUFFIXES) if (entry.endsWith(suffix)) {
36802
- const id = entry.slice(5, -suffix.length);
36803
- if (id.length > 0 && TASK_ID_RE.test(id)) taskIds.add(id);
36804
- break;
36805
- }
36806
- }
36807
- const tasks = await Promise.all([...taskIds].toSorted().map((id) => readTaskInfo(workdir, id)));
36808
- return jsonResult({
36809
- workdir,
36810
- tasks
36811
- });
36812
36886
  }
36813
36887
  };
36814
36888
  }
@@ -46026,7 +46100,7 @@ async function buildLongTaskPromptSuffix(params) {
46026
46100
  "- Register a cron monitor via the `cron` tool's `add` action. Use the schema documented in that tool's own description for the exact field names — do NOT guess. The monitor should fire roughly every 3 minutes as an isolated agentTurn job, and its message must literally contain the task-id, PID, log path, and status path so the future turn has enough context without re-deriving them.",
46027
46101
  "- Safe status read (inside the monitor turn):",
46028
46102
  " `status=$(cat \"<workdir>/task-<id>.status\" 2>/dev/null || echo missing)`",
46029
- " Possible values: `running pid=<N> started=<ISO>`, `complete rc=<N> ended=<ISO>`, `aborted rc=<N> signal=<TERM|INT|HUP> ended=<ISO>`, or `missing` if the file was cleaned up.",
46103
+ " Possible values: `running pid=<N> started=<ISO>`, `complete rc=<N> ended=<ISO>`, `aborted rc=<N> signal=<TERM|INT|HUP> ended=<ISO>`, `archived swept-from=… at=<ISO>` if the janitor archived an old finished task, or `missing` only when neither `.status` nor `.archived` exists (task crashed or workdir was wiped).",
46030
46104
  "- Monitor responsibilities each tick:",
46031
46105
  " • If status begins with `running`: tail -n 20 <log>, post a one-sentence progress line.",
46032
46106
  " • If status begins with `complete`: post a final summary with rc and tail, then call cron action=remove on this job id.",
@@ -51538,7 +51612,7 @@ async function deliverSessionMaintenanceWarning(params) {
51538
51612
  return;
51539
51613
  }
51540
51614
  try {
51541
- const { deliverOutboundPayloads } = await import("./deliver-D0bWiRCg.js").then((n) => n.n);
51615
+ const { deliverOutboundPayloads } = await import("./deliver-B_Q_nWJV.js").then((n) => n.n);
51542
51616
  await deliverOutboundPayloads({
51543
51617
  cfg: params.cfg,
51544
51618
  channel,
@@ -54984,7 +55058,7 @@ async function describeStickerImage(params) {
54984
55058
  logVerbose(`telegram: describing sticker with ${provider}/${model}`);
54985
55059
  try {
54986
55060
  const buffer = await fs$1.readFile(imagePath);
54987
- const { describeImageWithModel } = await import("./image-MNvheU8U.js").then((n) => n.n);
55061
+ const { describeImageWithModel } = await import("./image-tzIqIuKx.js").then((n) => n.n);
54988
55062
  return (await describeImageWithModel({
54989
55063
  buffer,
54990
55064
  fileName: "sticker.webp",
@@ -57733,7 +57807,7 @@ async function preflightDiscordMessage(params) {
57733
57807
  let preflightTranscript;
57734
57808
  const hasAudioAttachment = message.attachments?.some((att) => att.contentType?.startsWith("audio/"));
57735
57809
  if (!isDirectMessage && shouldRequireMention && hasAudioAttachment && !baseText && mentionRegexes.length > 0) try {
57736
- const { transcribeFirstAudio } = await import("./audio-preflight-C6vpFnOG.js");
57810
+ const { transcribeFirstAudio } = await import("./audio-preflight-NdNUAZ0y.js");
57737
57811
  const audioPaths = message.attachments?.filter((att) => att.contentType?.startsWith("audio/")).map((att) => att.url) ?? [];
57738
57812
  if (audioPaths.length > 0) preflightTranscript = await transcribeFirstAudio({
57739
57813
  ctx: {
@@ -61516,7 +61590,7 @@ function isVoiceChannelType(type) {
61516
61590
  function createDefaultDeps() {
61517
61591
  return {
61518
61592
  sendMessageWhatsApp: async (...args) => {
61519
- const { sendMessageWhatsApp } = await import("./web-Wk1ay1eQ.js");
61593
+ const { sendMessageWhatsApp } = await import("./web-PhjuzK8Y.js");
61520
61594
  return await sendMessageWhatsApp(...args);
61521
61595
  },
61522
61596
  sendMessageTelegram: async (...args) => {
@@ -64421,7 +64495,7 @@ function createDiscordGatewayPlugin(params) {
64421
64495
  super(options);
64422
64496
  }
64423
64497
  createWebSocket(url) {
64424
- return new WebSocket(url, { agent });
64498
+ return new WebSocket$1(url, { agent });
64425
64499
  }
64426
64500
  }
64427
64501
  return new ProxyGatewayPlugin();
@@ -74639,7 +74713,7 @@ const buildTelegramMessageContext = async ({ primaryCtx, allMedia, storeAllowFro
74639
74713
  const hasAudio = allMedia.some((media) => media.contentType?.startsWith("audio/"));
74640
74714
  let preflightTranscript;
74641
74715
  if (isGroup && requireMention && hasAudio && !hasUserText && mentionRegexes.length > 0) try {
74642
- const { transcribeFirstAudio } = await import("./audio-preflight-C6vpFnOG.js");
74716
+ const { transcribeFirstAudio } = await import("./audio-preflight-NdNUAZ0y.js");
74643
74717
  preflightTranscript = await transcribeFirstAudio({
74644
74718
  ctx: {
74645
74719
  MediaPaths: allMedia.length > 0 ? allMedia.map((m) => m.path) : void 0,
@@ -76796,7 +76870,7 @@ function loadWebLoginQr() {
76796
76870
  return webLoginQrPromise;
76797
76871
  }
76798
76872
  function loadWebChannel() {
76799
- webChannelPromise ??= import("./web-Wk1ay1eQ.js");
76873
+ webChannelPromise ??= import("./web-PhjuzK8Y.js");
76800
76874
  return webChannelPromise;
76801
76875
  }
76802
76876
  function loadWhatsAppActions() {