@symerian/symi 2.0.20 → 2.0.22

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 (349) hide show
  1. package/dist/{acp-cli-sXld4yJl.js → acp-cli-CucGW37J.js} +3 -3
  2. package/dist/{acp-cli-bbOWOXnN.js → acp-cli-bbMTiuvi.js} +3 -3
  3. package/dist/{agents-BuORPAb-.js → agents-DPqxmSTh.js} +8 -8
  4. package/dist/{agents.config-f39yfz8X.js → agents.config-D546KT_g.js} +1 -1
  5. package/dist/{agents.config-DHoCjDcA.js → agents.config-ah2sfVuh.js} +1 -1
  6. package/dist/{api-key-rotation-De1ivBc0.js → api-key-rotation-Yddo7iSo.js} +1 -1
  7. package/dist/{audio-preflight-USnUISOE.js → audio-preflight-19hTzgl9.js} +13 -13
  8. package/dist/{audio-preflight-C7tgYAnW.js → audio-preflight-CHWYpvI7.js} +7 -7
  9. package/dist/{audio-preflight-BxuYnm6k.js → audio-preflight-CU_XD3wQ.js} +7 -7
  10. package/dist/{audio-preflight-DCHBMKWE.js → audio-preflight-DUJsUsB1.js} +13 -13
  11. package/dist/{audit-DpqAVLn7.js → audit-BqIaLubU.js} +7 -7
  12. package/dist/{audit-Dxa-KhrA.js → audit-DHvgRd1-.js} +7 -7
  13. package/dist/{auth-choice-CMXdQiNi.js → auth-choice-CnkugX5j.js} +7 -7
  14. package/dist/{auth-choice-CtvhJkHT.js → auth-choice-DF-shD8r.js} +7 -7
  15. package/dist/{auth-profiles-Cs3GPB03.js → auth-profiles-BS_I3lKI.js} +21 -5
  16. package/dist/{auth-token-CbDExtp_.js → auth-token-BgP1x6qJ.js} +1 -1
  17. package/dist/{auth-token-DdkoxDu3.js → auth-token-DJczN1M9.js} +1 -1
  18. package/dist/{banner-CXdm0occ.js → banner-bvMTkZEs.js} +1 -1
  19. package/dist/{browser-cli-DQ0DQymk.js → browser-cli-B2ebOUVu.js} +4 -4
  20. package/dist/{browser-cli-8URbjVyN.js → browser-cli-BHhSGWsA.js} +4 -4
  21. package/dist/build-info.json +3 -3
  22. package/dist/bundled/boot-md/handler.js +18 -18
  23. package/dist/bundled/session-memory/handler.js +18 -18
  24. package/dist/{call-B-p451Eo.js → call-CvHdkyUu.js} +1 -1
  25. package/dist/{call-Cspuh_Jh.js → call-D8YrSTQS.js} +1 -1
  26. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  27. package/dist/{channel-options-C8A4aHBg.js → channel-options-B1CU1OhV.js} +1 -1
  28. package/dist/{channel-options-D2wffuUf.js → channel-options-WQIYmA0R.js} +1 -1
  29. package/dist/{channel-web-rV1Ov6LY.js → channel-web-CJj8XofR.js} +8 -8
  30. package/dist/{channels-cli-BJqzYIuv.js → channels-cli-BQHwMH-9.js} +38 -38
  31. package/dist/{channels-cli-Itgm_y4y.js → channels-cli-DKpgiqZM.js} +39 -39
  32. package/dist/{chrome-BUUMKYz7.js → chrome-Bb5ivmrz.js} +8 -8
  33. package/dist/{chrome-Chj8uCZN.js → chrome-CYmV7wN8.js} +1 -1
  34. package/dist/{chrome-B4BVdT6M.js → chrome-CkWGSMS5.js} +1 -1
  35. package/dist/{chrome-XQjc7KSW.js → chrome-Djqc4X4V.js} +1 -1
  36. package/dist/cli/daemon-cli.js +1 -1
  37. package/dist/{cli-LIphED4q.js → cli-B6wgV4te.js} +34 -34
  38. package/dist/{cli-eO-hVRgH.js → cli-rFD0PhFT.js} +33 -33
  39. package/dist/{command-registry-DfVT7wTW.js → command-registry-Dg8tEZn7.js} +11 -11
  40. package/dist/{commands-registry-DN93gKlx.js → commands-registry-DCUIFMIL.js} +1 -1
  41. package/dist/{commands-registry-nK_mZXUN.js → commands-registry-DSZSSHny.js} +1 -1
  42. package/dist/{commands-registry-tuRMQmX4.js → commands-registry-DhT2Skgp.js} +1 -1
  43. package/dist/{commands-registry-B_V42ZiZ.js → commands-registry-xbZ77kzw.js} +1 -1
  44. package/dist/{completion-cli-BOGuxOhF.js → completion-cli-B2KjRA9F.js} +1 -1
  45. package/dist/{completion-cli-CObwV9I2.js → completion-cli-FRiFEavP.js} +2 -2
  46. package/dist/{config-Crs8V2FU.js → config-6k8f4O94.js} +4 -2
  47. package/dist/{config-CxnbOYs8.js → config-CGJ96S46.js} +4 -2
  48. package/dist/{config-cli-DhVbRzoq.js → config-cli-L94gSwVv.js} +3 -3
  49. package/dist/{config-cli-BbgRYEdh.js → config-cli-YG0NXWaD.js} +3 -3
  50. package/dist/{config-guard-CNwpT-bm.js → config-guard-BfyorHCy.js} +5 -5
  51. package/dist/{config-guard-DvNDqIJp.js → config-guard-BmDOhJF-.js} +2 -2
  52. package/dist/{config-Bh5BJYfZ.js → config-oz6yMs1r.js} +4 -2
  53. package/dist/{config-BMStjqdp.js → config-uEQqNsoL.js} +4 -2
  54. package/dist/{config-validation-D0ku5PSk.js → config-validation-Dr-_vV9F.js} +1 -1
  55. package/dist/{config-validation-g8v4CRxO.js → config-validation-QqCZq8BO.js} +1 -1
  56. package/dist/{configure-BgTDW15F.js → configure-DjW5XA-i.js} +11 -11
  57. package/dist/{configure-DySsLNr7.js → configure-DpmVGU5C.js} +11 -11
  58. package/dist/{control-service-B7EmYYFH.js → control-service-C8yt3FSq.js} +4 -4
  59. package/dist/{control-service-BwrQoUMh.js → control-service-CjU6sFdJ.js} +4 -4
  60. package/dist/{cron-cli-D-nqfPZ5.js → cron-cli-97q0AjAn.js} +4 -4
  61. package/dist/{cron-cli-D9nGEQiu.js → cron-cli-BOD-J9a-.js} +4 -4
  62. package/dist/{daemon-cli-l5oXLo3n.js → daemon-cli-BT2sI9-3.js} +6 -6
  63. package/dist/{daemon-cli-DJR87xEg.js → daemon-cli-C6Ju1ptH.js} +6 -6
  64. package/dist/daemon-cli.js +3 -1
  65. package/dist/{daemon-runtime-BkVgNwLi.js → daemon-runtime-BySJ0Lp1.js} +1 -1
  66. package/dist/{daemon-runtime-D4sIbUkl.js → daemon-runtime-DFHqkET0.js} +1 -1
  67. package/dist/{deliver-CHWZIQz7.js → deliver-BpcMy6AD.js} +2 -2
  68. package/dist/{deliver-8jOk1f3v.js → deliver-CBkk7rHm.js} +3 -3
  69. package/dist/{deliver-8_lPbrcf.js → deliver-UASIwAO4.js} +2 -2
  70. package/dist/{deliver-C0Azi_cK.js → deliver-uSLZirbx.js} +3 -3
  71. package/dist/{devices-cli-V6vhbLKq.js → devices-cli-CuepNiOK.js} +3 -3
  72. package/dist/{devices-cli-CaK3Ausk.js → devices-cli-DCpwNXHx.js} +3 -3
  73. package/dist/{directory-cli-BmNzLgXc.js → directory-cli-C-l3hDLV.js} +2 -2
  74. package/dist/{directory-cli-Cd9lchia.js → directory-cli-CJrdIIMY.js} +2 -2
  75. package/dist/{dm-policy-shared-flFO0wFg.js → dm-policy-shared-Ctb5IkNa.js} +1 -1
  76. package/dist/{dm-policy-shared-CvHrO6D_.js → dm-policy-shared-DzlcnEMg.js} +1 -1
  77. package/dist/{dns-cli-BEOWeAGR.js → dns-cli-DDXNezGt.js} +2 -2
  78. package/dist/{dns-cli-mH-jPqkH.js → dns-cli-DTs_aknb.js} +2 -2
  79. package/dist/{doctor-completion-BfGNEmRG.js → doctor-completion-CSwxOlhu.js} +1 -1
  80. package/dist/{doctor-completion-C4gB2aiK.js → doctor-completion-D6bevOPA.js} +1 -1
  81. package/dist/{doctor-config-flow-Dd6-lC3V.js → doctor-config-flow-BTonoZiN.js} +3 -3
  82. package/dist/{doctor-config-flow-Dpnvu5A2.js → doctor-config-flow-CVPHaevC.js} +3 -3
  83. package/dist/entry.js +1 -1
  84. package/dist/{exec-approvals-cli-Dlf9s8ne.js → exec-approvals-cli-CIO2ZfDu.js} +5 -5
  85. package/dist/{exec-approvals-cli-lDvry8Xq.js → exec-approvals-cli-CyCL9HhA.js} +5 -5
  86. package/dist/extensionAPI.js +18 -18
  87. package/dist/{gateway-cli-Dm40SXo0.js → gateway-cli-C1nuI3Ec.js} +52 -52
  88. package/dist/{gateway-cli-D1k1Jm3d.js → gateway-cli-D4VSgdJh.js} +51 -51
  89. package/dist/{gateway-rpc-CCYQR5Bz.js → gateway-rpc-C08aRZPm.js} +1 -1
  90. package/dist/{gateway-rpc-aJiLRbJG.js → gateway-rpc-C8yFonDu.js} +1 -1
  91. package/dist/{gemini-auth-DmWoaMTb.js → gemini-auth-BoaKgS4s.js} +1 -1
  92. package/dist/{gemini-auth-2cinXFeY.js → gemini-auth-Cb6WywoJ.js} +1 -1
  93. package/dist/{gemini-auth-DtBB7-5F.js → gemini-auth-DcYr7a2U.js} +1 -1
  94. package/dist/{glass-ui-ws-r2tCQ_6u.js → glass-ui-ws-BIEY-Hp0.js} +42 -42
  95. package/dist/{glass-ui-ws-DN2hrUj_.js → glass-ui-ws-D-rChRuX.js} +43 -43
  96. package/dist/{health-B8dlEXGS.js → health-DDZwUqwB.js} +5 -5
  97. package/dist/{health-lr4bpKt4.js → health-DiRth-TA.js} +5 -5
  98. package/dist/{hooks-cli-Bq399X0k.js → hooks-cli-DNCFaCrN.js} +34 -34
  99. package/dist/{hooks-cli-BCizuq5S.js → hooks-cli-HNtzwpSV.js} +35 -35
  100. package/dist/{image-DOum3dyt.js → image-Cvu0YSjj.js} +3 -3
  101. package/dist/{image-bJzFwVE3.js → image-DBnlBG4I.js} +3 -3
  102. package/dist/{image-CNYGLoQl.js → image-DTQ8kORz.js} +3 -3
  103. package/dist/{image-BTLvoV0e.js → image-DViVUwBd.js} +3 -3
  104. package/dist/index.js +42 -42
  105. package/dist/{lifecycle-core-f8oPRRaQ.js → lifecycle-core-Dbt4g6Of.js} +2 -2
  106. package/dist/{lifecycle-core-C7fyJOuN.js → lifecycle-core-Dd9x949O.js} +2 -2
  107. package/dist/llm-slug-generator.js +18 -18
  108. package/dist/{login-CJf4Gdbq.js → login-CMot-0rl.js} +2 -2
  109. package/dist/{login-DTkUG4Mp.js → login-Cfm3bDH5.js} +2 -2
  110. package/dist/{login-C2C1yAD8.js → login-Cv_yqC3s.js} +2 -2
  111. package/dist/{login-BZsZO9ST.js → login-K4zjz_fH.js} +2 -2
  112. package/dist/{login-qr-CBPis3I2.js → login-qr-BMs92uQR.js} +3 -3
  113. package/dist/{login-qr-rvsxQT5p.js → login-qr-DLsX7QTE.js} +3 -3
  114. package/dist/{login-qr-C4uL0W0C.js → login-qr-DZhDF5IA.js} +3 -3
  115. package/dist/{login-qr-BSm4xrHW.js → login-qr-Dum8wEJm.js} +3 -3
  116. package/dist/{logs-cli-DJJ4_QXv.js → logs-cli-DGh7EDcI.js} +4 -4
  117. package/dist/{logs-cli-9__MsacS.js → logs-cli-ZVZ24zfk.js} +4 -4
  118. package/dist/{manager-D0d-bOOe.js → manager-ATGdr2di.js} +2 -2
  119. package/dist/{manager-Cw42HtQ7.js → manager-BB42BLb9.js} +2 -2
  120. package/dist/{manager-DqkRhYYl.js → manager-CkLgUBR9.js} +2 -2
  121. package/dist/{manager-D5ZbBYmN.js → manager-WMCMBAXk.js} +2 -2
  122. package/dist/{memory-cli-OWL3A7_N.js → memory-cli-Dyj4Z7nu.js} +5 -5
  123. package/dist/{memory-cli-D5iikkSG.js → memory-cli-Vk3GHSJH.js} +5 -5
  124. package/dist/{model-ApXxvnzl.js → model-CW9V-AKq.js} +1 -1
  125. package/dist/{model-DDV7HL-B.js → model-CaahPnPE.js} +1 -1
  126. package/dist/{model-auth-Db8I8QVL.js → model-auth-ueipoWgv.js} +21 -5
  127. package/dist/{model-catalog-Dq60dweH.js → model-catalog-B-RLz1zZ.js} +4 -4
  128. package/dist/{model-catalog-jhBOlBYp.js → model-catalog-BIB3bwBr.js} +4 -4
  129. package/dist/{model-picker-Bsyh5aNH.js → model-picker-BT5a_jUa.js} +3 -3
  130. package/dist/{model-picker-C1U-Jt0h.js → model-picker-BTOrJOu8.js} +3 -3
  131. package/dist/{model-selection-BBrZnKDw.js → model-selection-CSRFODzV.js} +21 -5
  132. package/dist/{model-selection-DBPwoBvb.js → model-selection-d3VVSx3Z.js} +21 -5
  133. package/dist/{models-CHlxEnA_.js → models-DeOa-Kw8.js} +14 -14
  134. package/dist/{models-cli-c3oNnRvc.js → models-cli-DmhxB26a.js} +39 -39
  135. package/dist/{models-cli-Chid5EBl.js → models-cli-Dti8CQ4l.js} +40 -40
  136. package/dist/{models-config-vcoi9QfD.js → models-config-BInyA1DL.js} +2 -2
  137. package/dist/{models-config-CjPV5JrE.js → models-config-BazBts_w.js} +2 -2
  138. package/dist/{node-cli-B9nJomOA.js → node-cli-BlscM5bI.js} +10 -10
  139. package/dist/{node-cli-DHVafAR8.js → node-cli-UQcJGA67.js} +10 -10
  140. package/dist/{nodes-cli-fvPbfbB4.js → nodes-cli-DqUBHLTT.js} +4 -4
  141. package/dist/{nodes-cli-CyVFmnaa.js → nodes-cli-Gymjb8nA.js} +4 -4
  142. package/dist/{onboard-CmGJK6jd.js → onboard-CeBeu3P1.js} +10 -10
  143. package/dist/{onboard-CoTgF9BA.js → onboard-DtVK6rjL.js} +10 -10
  144. package/dist/{onboard-channels-CFOV5ON5.js → onboard-channels-DaVmoOm_.js} +2 -2
  145. package/dist/{onboard-channels-5fkOyA_w.js → onboard-channels-W-oni7gS.js} +2 -2
  146. package/dist/{onboard-custom-CpKrCcyH.js → onboard-custom-BMylBbkO.js} +3 -3
  147. package/dist/{onboard-custom-DsPk-82B.js → onboard-custom-CZq7KuFG.js} +3 -3
  148. package/dist/{onboard-helpers-DIAvDwi8.js → onboard-helpers-9zN6ySeE.js} +2 -2
  149. package/dist/{onboard-helpers-C9emwuya.js → onboard-helpers-BPRytVKl.js} +2 -2
  150. package/dist/{onboard-remote-CJrAdmgq.js → onboard-remote-BXcnQk2C.js} +1 -1
  151. package/dist/{onboard-remote-DQu1ERap.js → onboard-remote-illc7Y2c.js} +1 -1
  152. package/dist/{onboard-skills-BC-T_r3T.js → onboard-skills-DzeH_8Ej.js} +2 -2
  153. package/dist/{onboard-skills-CtX6zH5x.js → onboard-skills-M_yUCwrM.js} +2 -2
  154. package/dist/{onboarding-Bzlyx4mj.js → onboarding-Cg9XTkBd.js} +11 -11
  155. package/dist/{onboarding-DFPgaJi4.js → onboarding-D8eDFwa2.js} +11 -11
  156. package/dist/{onboarding.finalize-DUgg4Kjt.js → onboarding.finalize-7WP463T8.js} +39 -39
  157. package/dist/{onboarding.finalize-Cc0y0cyU.js → onboarding.finalize-B1bb1wRw.js} +41 -41
  158. package/dist/{onboarding.gateway-config-GDMTEWcW.js → onboarding.gateway-config-CqbSOQXD.js} +5 -5
  159. package/dist/{onboarding.gateway-config-Cr1fFG05.js → onboarding.gateway-config-CxpI0qqU.js} +5 -5
  160. package/dist/{openai-model-default-l66tU27B.js → openai-model-default-DMZoKZ_-.js} +2 -2
  161. package/dist/{openai-model-default-BMY_YH9P.js → openai-model-default-lZlv0GsH.js} +2 -2
  162. package/dist/{outbound-DYyGKxSZ.js → outbound-1VspdkI5.js} +1 -1
  163. package/dist/{outbound-DXyOHKUR.js → outbound-BpdIzQuJ.js} +1 -1
  164. package/dist/{outbound-btxNyARe.js → outbound-DzVcjpPJ.js} +1 -1
  165. package/dist/{outbound-Qgo51Q1x.js → outbound-fyE60RfL.js} +1 -1
  166. package/dist/{pairing-cli-DC6MUFHZ.js → pairing-cli-Bd0PbASt.js} +4 -4
  167. package/dist/{pairing-cli-m3BrxJoY.js → pairing-cli-ZtAxWUcP.js} +4 -4
  168. package/dist/{pairing-labels-Ca15tgVV.js → pairing-labels-1pvats1t.js} +1 -1
  169. package/dist/{pairing-labels-D_XOc2nT.js → pairing-labels-BzrUs0Sz.js} +1 -1
  170. package/dist/{pairing-store-DdUVpKvp.js → pairing-store-BkBQpfrJ.js} +1 -1
  171. package/dist/{pairing-store-cjckhuQX.js → pairing-store-aDUZrmTs.js} +1 -1
  172. package/dist/{pi-auth-json-BqB9Z6Gg.js → pi-auth-json-B4WrT0Ru.js} +1 -1
  173. package/dist/{pi-auth-json-Ba2dEWAH.js → pi-auth-json-BNdShOEp.js} +2 -2
  174. package/dist/{pi-auth-json-BJB80_DY.js → pi-auth-json-BY543Me0.js} +1 -1
  175. package/dist/{pi-auth-json-etIDtHw9.js → pi-auth-json-DzLmsrh2.js} +1 -1
  176. package/dist/{pi-embedded-CEqwVgn6.js → pi-embedded-Dt55w8cV.js} +136 -54
  177. package/dist/{pi-embedded-Div9d5hA.js → pi-embedded-MQyUl4Vd.js} +132 -50
  178. package/dist/{pi-embedded-helpers-BflbNBBD.js → pi-embedded-helpers-BBkiCuKb.js} +1 -1
  179. package/dist/{pi-embedded-helpers-CAtkZb8c.js → pi-embedded-helpers-ByVF8Lq1.js} +6 -6
  180. package/dist/{pi-embedded-helpers-XJw27Ryb.js → pi-embedded-helpers-CMMNFzOl.js} +1 -1
  181. package/dist/{pi-embedded-helpers-z1mQ9EX3.js → pi-embedded-helpers-yCss7Bdi.js} +6 -6
  182. package/dist/{pi-tools.policy-P1akpJL8.js → pi-tools.policy-Df7vqwql.js} +2 -2
  183. package/dist/{pi-tools.policy-BJ7mumw5.js → pi-tools.policy-pnSSbfN7.js} +2 -2
  184. package/dist/{plugin-auto-enable-CdctkFTt.js → plugin-auto-enable-7e3Sk8je.js} +1 -1
  185. package/dist/{plugin-auto-enable-B-WfJQ_3.js → plugin-auto-enable-D0PiamQY.js} +1 -1
  186. package/dist/{plugin-registry-COIq8-Os.js → plugin-registry-CzCch-YI.js} +2 -2
  187. package/dist/{plugin-registry-BtvCdUXo.js → plugin-registry-qkOLPlY-.js} +2 -2
  188. package/dist/plugin-sdk/agents/failover-error.d.ts +1 -0
  189. package/dist/plugin-sdk/agents/ollama-stream.d.ts +1 -1
  190. package/dist/plugin-sdk/agents/pi-embedded-runner/run/params.d.ts +2 -0
  191. package/dist/plugin-sdk/agents/symipulse-timeout.d.ts +13 -0
  192. package/dist/plugin-sdk/{api-key-rotation-DNKq8sDG.js → api-key-rotation-2bCcXL6t.js} +1 -1
  193. package/dist/plugin-sdk/{audio-preflight-BLIDrYdM.js → audio-preflight-l78E5Rb2.js} +7 -7
  194. package/dist/plugin-sdk/{channel-web-Mw_6jv4Q.js → channel-web-C9N79DF5.js} +7 -7
  195. package/dist/plugin-sdk/{chrome-DZFDAzW-.js → chrome-kcjStvJ_.js} +1 -1
  196. package/dist/plugin-sdk/{commands-registry-un-LmdXo.js → commands-registry-DrBC1eVl.js} +1 -1
  197. package/dist/plugin-sdk/config/types.agent-defaults.d.ts +4 -0
  198. package/dist/plugin-sdk/config/zod-schema.agent-defaults.d.ts +2 -0
  199. package/dist/plugin-sdk/config/zod-schema.agents.d.ts +2 -0
  200. package/dist/plugin-sdk/config/zod-schema.d.ts +2 -0
  201. package/dist/plugin-sdk/{config-E1hS2lFY.js → config-BvR2BWLO.js} +4 -2
  202. package/dist/plugin-sdk/{deliver-DedoujTw.js → deliver-BGIOQ5Gg.js} +2 -2
  203. package/dist/plugin-sdk/{image-BTkmcfWM.js → image-DKyNtsLH.js} +3 -3
  204. package/dist/plugin-sdk/index.js +22 -22
  205. package/dist/plugin-sdk/{login-DsV1n99g.js → login-Do4CzQ80.js} +2 -2
  206. package/dist/plugin-sdk/{login-qr-BXuSdbtI.js → login-qr-7psuYtQU.js} +3 -3
  207. package/dist/plugin-sdk/{manager-BItSTruD.js → manager-ss11kI5-.js} +2 -2
  208. package/dist/plugin-sdk/{model-selection-aEd_4vFO.js → model-selection-BcrYHPfL.js} +21 -5
  209. package/dist/plugin-sdk/{outbound-2GErJr9p.js → outbound-BzBPDX20.js} +1 -1
  210. package/dist/plugin-sdk/{pi-auth-json-FyiScmI7.js → pi-auth-json-B0EP59Cx.js} +1 -1
  211. package/dist/plugin-sdk/{pi-embedded-helpers-ClMAnIcK.js → pi-embedded-helpers-Dd5EG8iK.js} +6 -6
  212. package/dist/plugin-sdk/{pw-ai-DgQXeoga.js → pw-ai-CUDy4Wnj.js} +3 -3
  213. package/dist/plugin-sdk/{replies-DgHmcQJm.js → replies-D8mtzEXN.js} +1 -1
  214. package/dist/plugin-sdk/{reply-YI3dgTPs.js → reply-DHEk1mbh.js} +132 -50
  215. package/dist/plugin-sdk/{runner-BZyapZ82.js → runner-DYM4KHsz.js} +5 -5
  216. package/dist/plugin-sdk/{send-BeLrD_W8.js → send-BUyY_agb.js} +1 -1
  217. package/dist/plugin-sdk/{send-pZOlfgD0.js → send-C0itht0P.js} +1 -1
  218. package/dist/plugin-sdk/{send-BnQuSlC7.js → send-DAQGJslJ.js} +1 -1
  219. package/dist/plugin-sdk/{send-BmtFyMcr.js → send-DEBJVTJY.js} +1 -1
  220. package/dist/plugin-sdk/{send-BRY1rgHy.js → send-DgwEMzAh.js} +2 -2
  221. package/dist/plugin-sdk/{session-Bjd4Dl7q.js → session-0e-LucZC.js} +1 -1
  222. package/dist/plugin-sdk/{skill-commands-Cwps3qpb.js → skill-commands-DABkEKjp.js} +1 -1
  223. package/dist/plugin-sdk/{web-Cfkw6REa.js → web-i-1y7OqN.js} +22 -22
  224. package/dist/plugin-sdk/{whatsapp-actions-ydkRfuPg.js → whatsapp-actions-Btj704qL.js} +3 -3
  225. package/dist/{plugins-cli-DVp3M6OP.js → plugins-cli-CuWdlZUL.js} +34 -34
  226. package/dist/{plugins-cli-B8UY2WDb.js → plugins-cli-gfyaL-JG.js} +35 -35
  227. package/dist/{program-Dp8zbXEu.js → program-BjfVIsbe.js} +41 -41
  228. package/dist/{program-context-BCbYtijc.js → program-context-BzaWpuOp.js} +38 -38
  229. package/dist/{prompt-select-styled-DITmevDg.js → prompt-select-styled-DX2M5ooT.js} +17 -17
  230. package/dist/{prompt-select-styled-CtGFyVQu.js → prompt-select-styled-DpDi0x9k.js} +17 -17
  231. package/dist/{provider-auth-helpers-CGsuHvvp.js → provider-auth-helpers-Bs6lQx_x.js} +4 -4
  232. package/dist/{provider-auth-helpers-BSGG0DG6.js → provider-auth-helpers-DdsVPRuX.js} +4 -4
  233. package/dist/{push-apns-DMADb1fM.js → push-apns-BhIc_b87.js} +1 -1
  234. package/dist/{push-apns-BswbDX0O.js → push-apns-ZauuwP2K.js} +1 -1
  235. package/dist/{pw-ai-D-O0LOKC.js → pw-ai-CIlFJoZJ.js} +3 -3
  236. package/dist/{pw-ai-qEd4Ii3S.js → pw-ai-CzGGXy9V.js} +3 -3
  237. package/dist/{pw-ai-5o71PJ5h.js → pw-ai-D3JHljxG.js} +3 -3
  238. package/dist/{pw-ai-C3t2kdhc.js → pw-ai-DCqUxhNF.js} +3 -3
  239. package/dist/{qr-cli-iTQlujHe.js → qr-cli-CAUfPqEg.js} +2 -2
  240. package/dist/{qr-cli-DC0qgjHf.js → qr-cli-Dq7eF1ux.js} +2 -2
  241. package/dist/{register.agent-CxGdVu0c.js → register.agent-B1sFFJFg.js} +43 -43
  242. package/dist/{register.agent-BsJfSKec.js → register.agent-CTrXGVfd.js} +45 -45
  243. package/dist/{register.configure-CS_Iyak-.js → register.configure-CcyX3Lc8.js} +48 -48
  244. package/dist/{register.configure-CY4Aj48-.js → register.configure-DDVmT6NY.js} +47 -47
  245. package/dist/{register.maintenance-vtbjaHAu.js → register.maintenance-CdoXyGzf.js} +44 -44
  246. package/dist/{register.maintenance-Buu-kJaZ.js → register.maintenance-LsWciVuT.js} +46 -46
  247. package/dist/{register.message-B4k856qi.js → register.message-CEhrWjQV.js} +35 -35
  248. package/dist/{register.message-DY4vxgF2.js → register.message-iAimOwns.js} +34 -34
  249. package/dist/{register.onboard-DUQf27DZ.js → register.onboard-B905_rz1.js} +43 -43
  250. package/dist/{register.onboard--fOBp5O7.js → register.onboard-BdspAIMb.js} +42 -42
  251. package/dist/{register.setup-7_oYVnsV.js → register.setup-3aRCKJ36.js} +43 -43
  252. package/dist/{register.setup-C1n4Lbkz.js → register.setup-DtBE_3fr.js} +42 -42
  253. package/dist/{register.status-health-sessions-Bg4ToSxp.js → register.status-health-sessions-BWr1hDot.js} +38 -38
  254. package/dist/{register.status-health-sessions-15XGlpir.js → register.status-health-sessions-DVGmTBQO.js} +40 -40
  255. package/dist/{register.subclis-228XfrkD.js → register.subclis-BZ3i4kMS.js} +28 -28
  256. package/dist/{replies-CHirod5x.js → replies-C0945t1U.js} +1 -1
  257. package/dist/{replies-B5Jh0OCP.js → replies-CVenpK6u.js} +1 -1
  258. package/dist/{replies-BVXZDrhw.js → replies-CeKPHa39.js} +1 -1
  259. package/dist/{replies-Cyt5jQaT.js → replies-ookj1cB4.js} +1 -1
  260. package/dist/{reply-Y4VH0suk.js → reply-DBq43zxh.js} +144 -62
  261. package/dist/{routes-D5iYXgsO.js → routes-BeqLs7B4.js} +3 -3
  262. package/dist/{routes-BtsprtPx.js → routes-D8eYH81h.js} +3 -3
  263. package/dist/{rpc-CjvivzOg.js → rpc-DM-s6c5g.js} +1 -1
  264. package/dist/{rpc-lMWCuyRt.js → rpc-_IQ1oqxy.js} +1 -1
  265. package/dist/{run-main-DJAM16EI.js → run-main-DHhJ9JFs.js} +53 -53
  266. package/dist/{runner-3kD2Hk1w.js → runner-Bdpb31wu.js} +5 -5
  267. package/dist/{runner-C6VtiNZz.js → runner-C-hs6BOd.js} +5 -5
  268. package/dist/{runner-b_ibT3sW.js → runner-CYBZ6_HI.js} +5 -5
  269. package/dist/{runner-_npJ-cn9.js → runner-_tldjZOG.js} +5 -5
  270. package/dist/{sandbox-CPR0wRyk.js → sandbox-B9cX1Qsg.js} +5 -5
  271. package/dist/{sandbox-BBGJMpXR.js → sandbox-BgudXNdX.js} +5 -5
  272. package/dist/{sandbox-cli-CHOc4ElC.js → sandbox-cli-Db06l-QO.js} +7 -7
  273. package/dist/{sandbox-cli-BgCrevMy.js → sandbox-cli-ITWFmBOM.js} +7 -7
  274. package/dist/{security-cli-iW-aIZ15.js → security-cli-CAMn5ETM.js} +12 -12
  275. package/dist/{security-cli-B7YKQ6Nh.js → security-cli-DFQoX6jC.js} +12 -12
  276. package/dist/{send--qdaLm4C.js → send-0GU9exFu.js} +1 -1
  277. package/dist/{send-BVKK9mIc.js → send-B-uN5xRM.js} +1 -1
  278. package/dist/{send-ytd5gZYc.js → send-B3ysC28K.js} +1 -1
  279. package/dist/{send-sS-DxRJV.js → send-B5EhOVKu.js} +1 -1
  280. package/dist/{send-Dfum4W06.js → send-B5uxhc4T.js} +1 -1
  281. package/dist/{send-C1fiVl-C.js → send-BDxgN_bQ.js} +1 -1
  282. package/dist/{send-Dfohx1Dj.js → send-Bo5CnXFq.js} +1 -1
  283. package/dist/{send-TtpoiB7G.js → send-C0MwqoIT.js} +1 -1
  284. package/dist/{send-QGcGaA1o.js → send-CAb_J0aw.js} +2 -2
  285. package/dist/{send-C7DzVT6I.js → send-CE4zNqBi.js} +1 -1
  286. package/dist/{send-B26isft5.js → send-CFLb_W1q.js} +1 -1
  287. package/dist/{send-BAM-zeo8.js → send-CLeHyMKL.js} +2 -2
  288. package/dist/{send-BxkOVx17.js → send-CTxPJl1v.js} +2 -2
  289. package/dist/{send-CboqahSN.js → send-CZNQ18eT.js} +2 -2
  290. package/dist/{send-CNZ2iT1h.js → send-DeWhmyHe.js} +1 -1
  291. package/dist/{send-DffO5_WA.js → send-Dq3yh0n_.js} +1 -1
  292. package/dist/{send-BfoI2xoz.js → send-Dub0pvGr.js} +1 -1
  293. package/dist/{send-Btgfdf6H.js → send-_8ePDRRf.js} +1 -1
  294. package/dist/{send-DVNiZsde.js → send-lPu6acJr.js} +1 -1
  295. package/dist/{send-DXw0_dn5.js → send-plufzQIM.js} +1 -1
  296. package/dist/{server-context-CZZZ5S6q.js → server-context-Bm5WfPwZ.js} +5 -5
  297. package/dist/{server-context-DiCxB7wV.js → server-context-C55J-UHj.js} +5 -5
  298. package/dist/{server-methods-Dry5eOvA.js → server-methods-BfVpF3_j.js} +18 -18
  299. package/dist/{server-methods-BuHg7me_.js → server-methods-CBz9kx2s.js} +17 -17
  300. package/dist/{server-node-events-BeTHU-es.js → server-node-events-BBMB3HWj.js} +35 -35
  301. package/dist/{server-node-events-D6jQar7n.js → server-node-events-DHlmMG_C.js} +34 -34
  302. package/dist/{session-BFbJf357.js → session-BCkXoaDO.js} +1 -1
  303. package/dist/{session-CiCHQ3Ah.js → session-BP0Gv1gb.js} +1 -1
  304. package/dist/{session-BdWP3apT.js → session-BTqGTD9l.js} +1 -1
  305. package/dist/{session-Dg44BpS1.js → session-CJI6lJIm.js} +1 -1
  306. package/dist/{session-utils-Cs-nCi4-.js → session-utils-v_SakJTj.js} +4 -4
  307. package/dist/{sessions-C_c07viS.js → sessions-C6D9nTJ2.js} +2 -2
  308. package/dist/{sessions-BF3cJslT.js → sessions-D_sYAXox.js} +2 -2
  309. package/dist/{sessions-RYattOnc.js → sessions-ZEWPPs4y.js} +4 -4
  310. package/dist/{shared-Dg2JustZ.js → shared-DayV2Be4.js} +2 -2
  311. package/dist/{shared-BmGIQ5oj.js → shared-uLuYqcbb.js} +2 -2
  312. package/dist/{skill-commands-BlfEmZ8t.js → skill-commands-DJHFzerm.js} +1 -1
  313. package/dist/{skill-commands-C2kxEz5h.js → skill-commands-Depo8UbH.js} +1 -1
  314. package/dist/{skill-commands-C_ZNSYNS.js → skill-commands-MyjdLY-a.js} +1 -1
  315. package/dist/{skill-commands-CSBmZ_di.js → skill-commands-XIkT9idK.js} +1 -1
  316. package/dist/{skills-cli-G_0fvsIb.js → skills-cli-2II5dTfj.js} +2 -2
  317. package/dist/{skills-cli-D9N3SSqr.js → skills-cli-BJ07WkIu.js} +2 -2
  318. package/dist/{status-BhHEy-GB.js → status--f4zX1DS.js} +12 -12
  319. package/dist/{status-B4XvnyFd.js → status-BcNi9OjQ.js} +11 -11
  320. package/dist/{status-D1XT9GsI.js → status-C-GM0R2c.js} +2 -2
  321. package/dist/{status-D1W5_38a.js → status-CCTReric.js} +2 -2
  322. package/dist/{status.update-9QVNoqzS.js → status.update-DhhtmPIK.js} +1 -1
  323. package/dist/{status.update-DAK4tN-2.js → status.update-MEvvwSyA.js} +1 -1
  324. package/dist/{subagent-registry-BE6XzWR3.js → subagent-registry-CiBbcgit.js} +145 -63
  325. package/dist/{system-cli-B0oAtepa.js → system-cli-DaHzRRZO.js} +4 -4
  326. package/dist/{system-cli-kixN2BmA.js → system-cli-NuL5CoT5.js} +4 -4
  327. package/dist/{systemd-hints-BPRCUlOg.js → systemd-hints-BwLHbZwk.js} +1 -1
  328. package/dist/{systemd-hints-CRzDDf1-.js → systemd-hints-C_Wzs8Ts.js} +1 -1
  329. package/dist/{tui-CwMmsLXs.js → tui-KWXGdBc4.js} +5 -5
  330. package/dist/{tui-PZpjjXWo.js → tui-L301QdxU.js} +5 -5
  331. package/dist/{tui-cli-CU2JJJI9.js → tui-cli-B0160VqT.js} +11 -11
  332. package/dist/{tui-cli-PTM4Eps5.js → tui-cli-CPydLAAS.js} +11 -11
  333. package/dist/{update-cli-W4gB5wor.js → update-cli-Cj1AmFgn.js} +47 -47
  334. package/dist/{update-cli-BY16EOnN.js → update-cli-DAzmC_i2.js} +49 -49
  335. package/dist/{update-runner-cgnDIePC.js → update-runner-CQCzp1FG.js} +1 -1
  336. package/dist/{update-runner-BIhfRHle.js → update-runner-CVh1ixYm.js} +1 -1
  337. package/dist/{web-Cyg-Awr5.js → web-BxUguUwU.js} +21 -21
  338. package/dist/{web-CBgI2sQ6.js → web-Dan0YPuK.js} +21 -21
  339. package/dist/{web-DKLD4TVE.js → web-svB71EDx.js} +37 -37
  340. package/dist/{web-Cbp0Q5xk.js → web-u_T-25Fh.js} +37 -37
  341. package/dist/{webhooks-cli-CAHebfVz.js → webhooks-cli-B8FUejkI.js} +2 -2
  342. package/dist/{webhooks-cli-B97uWTaD.js → webhooks-cli-D9CHLI9R.js} +2 -2
  343. package/dist/{whatsapp-actions-BgiS8DUJ.js → whatsapp-actions-8q4rBb8o.js} +3 -3
  344. package/dist/{whatsapp-actions-xhdGIJBd.js → whatsapp-actions-BKYl-9a-.js} +3 -3
  345. package/dist/{whatsapp-actions-BsVCZeLO.js → whatsapp-actions-BdSpem9R.js} +3 -3
  346. package/dist/{whatsapp-actions-DfJHCjBV.js → whatsapp-actions-b0l0LfoG.js} +3 -3
  347. package/dist/{with-timeout-CiGZZ4b2.js → with-timeout-D8WaDWjT.js} +1 -1
  348. package/dist/{with-timeout-C0euAxXp.js → with-timeout-J-NgpKB8.js} +1 -1
  349. package/package.json +1 -1
@@ -11,22 +11,22 @@ import { a as logoutWeb, i as logWebSelfId, l as readWebSelfId, p as webAuthExis
11
11
  import { t as normalizeChatType } from "./chat-type-C_KiWNAH.js";
12
12
  import { t as parseBooleanValue$1 } from "./boolean-B8-BqKGQ.js";
13
13
  import { n as resolveCliName, r as isTruthyEnvValue, t as formatCliCommand } from "./command-format-BaxDnULz.js";
14
- 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-DffO5_WA.js";
15
- 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-BVKK9mIc.js";
16
- 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-CHWZIQz7.js";
14
+ 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-Dq3yh0n_.js";
15
+ 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-B-uN5xRM.js";
16
+ 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-BpcMy6AD.js";
17
17
  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-CI0kRQkt.js";
18
18
  import { r as getDiagnosticSessionState } from "./diagnostic-session-state-Bxo4UHOL.js";
19
19
  import { n as resolveSignalAccount, t as listEnabledSignalAccounts } from "./accounts-CWktKM8a.js";
20
- import { $ as isVoiceCompatibleAudio, A as extractTelegramLocation, B as normalizeAllowFromWithStore$1, C as buildTelegramGroupFrom, D as buildTypingThreadParams, E as buildTelegramThreadParams, F as resolveTelegramMediaPlaceholder, G as formatLocationText, H as firstDefined$1, I as resolveTelegramReplyId, J as readChannelAllowFromStore, K as toLocationContext, L as resolveTelegramStreamMode, M as normalizeForwardedContext, N as resolveTelegramForumThreadId, O as describeReplyTarget, P as resolveTelegramGroupAllowFromContext, Q as listPairingChannels, R as resolveTelegramThreadSpec, S as buildSenderName, T as buildTelegramParentPeer, U as isSenderIdAllowed, V as resolveSenderAllowMatch, W as mergeAllowFromSources, X as upsertChannelPairingRequest, Y as removeChannelAllowFromStoreEntry, Z as getPairingAdapter, _ as resolveTelegramFetch, a as reactMessageTelegram, b as buildGroupLabel, c as sendStickerTelegram, d as wasSentByBot, et as parseTelegramTarget, f as isRecoverableTelegramNetworkError, g as wrapFileReferencesInHtml, h as renderTelegramHtmlText, i as editMessageTelegram, j as hasBotMention, k as expandTextLinks, m as markdownToTelegramHtml, n as createForumTopicTelegram, o as sendMessageTelegram, p as markdownToTelegramChunks, q as addChannelAllowFromStoreEntry, r as deleteMessageTelegram, s as sendPollTelegram, t as buildInlineKeyboard, tt as resolveTelegramTargetChatType, u as resolveTelegramVoiceSend, v as splitTelegramCaption, w as buildTelegramGroupPeerId, x as buildSenderLabel, y as withTelegramApiErrorLogging, z as isSenderAllowed$1 } from "./send-BAM-zeo8.js";
20
+ import { $ as isVoiceCompatibleAudio, A as extractTelegramLocation, B as normalizeAllowFromWithStore$1, C as buildTelegramGroupFrom, D as buildTypingThreadParams, E as buildTelegramThreadParams, F as resolveTelegramMediaPlaceholder, G as formatLocationText, H as firstDefined$1, I as resolveTelegramReplyId, J as readChannelAllowFromStore, K as toLocationContext, L as resolveTelegramStreamMode, M as normalizeForwardedContext, N as resolveTelegramForumThreadId, O as describeReplyTarget, P as resolveTelegramGroupAllowFromContext, Q as listPairingChannels, R as resolveTelegramThreadSpec, S as buildSenderName, T as buildTelegramParentPeer, U as isSenderIdAllowed, V as resolveSenderAllowMatch, W as mergeAllowFromSources, X as upsertChannelPairingRequest, Y as removeChannelAllowFromStoreEntry, Z as getPairingAdapter, _ as resolveTelegramFetch, a as reactMessageTelegram, b as buildGroupLabel, c as sendStickerTelegram, d as wasSentByBot, et as parseTelegramTarget, f as isRecoverableTelegramNetworkError, g as wrapFileReferencesInHtml, h as renderTelegramHtmlText, i as editMessageTelegram, j as hasBotMention, k as expandTextLinks, m as markdownToTelegramHtml, n as createForumTopicTelegram, o as sendMessageTelegram, p as markdownToTelegramChunks, q as addChannelAllowFromStoreEntry, r as deleteMessageTelegram, s as sendPollTelegram, t as buildInlineKeyboard, tt as resolveTelegramTargetChatType, u as resolveTelegramVoiceSend, v as splitTelegramCaption, w as buildTelegramGroupPeerId, x as buildSenderLabel, y as withTelegramApiErrorLogging, z as isSenderAllowed$1 } from "./send-CLeHyMKL.js";
21
21
  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-CvJzsyvE.js";
22
- import { A as normalizeProviderId, C as buildAllowedModelSet, D as isCliProvider, E as findNormalizedProviderValue, F as resolveSubagentSpawnModelSelection, G as DEFAULT_MODEL, H as OLLAMA_NATIVE_BASE_URL, I as resolveThinkingDefault, J as normalizeSecretInput, K as DEFAULT_PROVIDER, M as resolveConfiguredModelRef, N as resolveDefaultModelForAgent, O as modelKey, P as resolveModelRefFromString, T as buildModelAliasIndex, U as createOllamaStreamFn, W as DEFAULT_CONTEXT_TOKENS, Y as getShellPathFromLoginShell, Z as resolveShellEnvFallbackTimeoutMs, _ as ensureAuthProfileStore, a as resolveEnvApiKey, b as withFileLock, c as resolveAuthProfileOrder, d as markAuthProfileFailure, f as markAuthProfileUsed, g as markAuthProfileGood, h as listProfilesForProvider, i as resolveApiKeyForProvider, k as normalizeModelRef$2, l as getSoonestCooldownExpiry, m as dedupeProfileIds, n as getCustomProviderApiKey, o as resolveModelAuthMode, p as resolveApiKeyForProfile, q as resolveAuthProfileDisplayLabel, r as requireApiKey, t as getApiKeyForModel, u as isProfileInCooldown, v as resolveAuthStorePathForDisplay, w as buildConfiguredAllowlistKeys, y as resolveSymiAgentDir } from "./model-auth-Db8I8QVL.js";
22
+ import { A as normalizeProviderId, C as buildAllowedModelSet, D as isCliProvider, E as findNormalizedProviderValue, F as resolveSubagentSpawnModelSelection, G as DEFAULT_MODEL, H as OLLAMA_NATIVE_BASE_URL, I as resolveThinkingDefault, J as normalizeSecretInput, K as DEFAULT_PROVIDER, M as resolveConfiguredModelRef, N as resolveDefaultModelForAgent, O as modelKey, P as resolveModelRefFromString, T as buildModelAliasIndex, U as createOllamaStreamFn, W as DEFAULT_CONTEXT_TOKENS, Y as getShellPathFromLoginShell, Z as resolveShellEnvFallbackTimeoutMs, _ as ensureAuthProfileStore, a as resolveEnvApiKey, b as withFileLock, c as resolveAuthProfileOrder, d as markAuthProfileFailure, f as markAuthProfileUsed, g as markAuthProfileGood, h as listProfilesForProvider, i as resolveApiKeyForProvider, k as normalizeModelRef$2, l as getSoonestCooldownExpiry, m as dedupeProfileIds, n as getCustomProviderApiKey, o as resolveModelAuthMode, p as resolveApiKeyForProfile, q as resolveAuthProfileDisplayLabel, r as requireApiKey, t as getApiKeyForModel, u as isProfileInCooldown, v as resolveAuthStorePathForDisplay, w as buildConfiguredAllowlistKeys, y as resolveSymiAgentDir } from "./model-auth-ueipoWgv.js";
23
23
  import { a as saveJsonFile, i as loadJsonFile } from "./github-copilot-token-C_qUP7p5.js";
24
24
  import { n as discoverModels, t as discoverAuthStorage } from "./pi-model-discovery-DaNAekda.js";
25
25
  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-Dz5lr5b0.js";
26
- import { $ as normalizeDeliveryContext, 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, G as updateLastRoute, Gt as compileGlobPatterns, H as loadSessionStore, Ht as normalizeToolName, I as resolveSandboxRuntimeStatus, It as applyOwnerOnlyToolPolicy, J as isCacheEnabled, Jt as ensureSessionHeader, K as updateSessionStore, 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 mergeDeliveryContext, 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 deliveryContextFromSession, Xt as resolveBootstrapTotalMaxChars, Y as resolveCacheTtlMs$1, Yt as resolveBootstrapMaxChars, Z as deliveryContextKey, Zt as sanitizeGoogleTurnOrdering, _ as formatRawAssistantErrorForUi, _t as resolveFreshSessionTotalTokens, a as isMessagingToolDuplicateNormalized, at as extractToolCallNames, b as isBillingAssistantError, bt as resolveExplicitAgentSessionKey, c as extractToolCallsFromAssistant, ct as hasInterSessionUserProvenance, d as isAntigravityClaude, dt as evaluateSessionFreshness, et as normalizeSessionDeliveryFields, f as isGoogleModelApi, ft as resolveChannelResetConfig, g as formatBillingErrorMessage, gt as DEFAULT_RESET_TRIGGERS, h as formatAssistantErrorText, ht as resolveThreadFlag, it as countToolResults, j as parseImageDimensionError, jt as resolveExistingPathsWithinRoot, k as isTimeoutErrorMessage, kt as resolveProfile, l as extractToolResultId, lt as normalizeInputProvenance, m as classifyFailoverReason, mt as resolveSessionResetType, n as validateGeminiTurns, nt as archiveSessionTranscripts, o as normalizeTextForComparison, ot as INPUT_PROVENANCE_KIND_VALUES, p as BILLING_ERROR_USER_MESSAGE, pt as resolveSessionResetPolicy, q as updateSessionStoreEntry, qt as buildBootstrapContextFiles, r as pickFallbackThinkingLevel, rt as capArrayByJsonBytes, s as sanitizeSessionMessagesImages, st as applyInputProvenanceToUserMessage, t as validateAnthropicTurns, tt as normalizeAccountId$3, u as downgradeOpenAIReasoningBlocks, ut as resolveSessionKey, v as getApiErrorPayloadFingerprint, vt as canonicalizeMainSessionAlias, w as isFailoverAssistantError, wt as acquireSessionWriteLock, x as isCloudCodeAssistFormatError, xt as resolveMainSessionKey, y as isAuthAssistantError, z as appendAssistantMessageToSessionTranscript, zt as expandPolicyWithPluginGroups } from "./pi-embedded-helpers-z1mQ9EX3.js";
27
- 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-Bh5BJYfZ.js";
26
+ import { $ as normalizeDeliveryContext, 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, G as updateLastRoute, Gt as compileGlobPatterns, H as loadSessionStore, Ht as normalizeToolName, I as resolveSandboxRuntimeStatus, It as applyOwnerOnlyToolPolicy, J as isCacheEnabled, Jt as ensureSessionHeader, K as updateSessionStore, 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 mergeDeliveryContext, 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 deliveryContextFromSession, Xt as resolveBootstrapTotalMaxChars, Y as resolveCacheTtlMs$1, Yt as resolveBootstrapMaxChars, Z as deliveryContextKey, Zt as sanitizeGoogleTurnOrdering, _ as formatRawAssistantErrorForUi, _t as resolveFreshSessionTotalTokens, a as isMessagingToolDuplicateNormalized, at as extractToolCallNames, b as isBillingAssistantError, bt as resolveExplicitAgentSessionKey, c as extractToolCallsFromAssistant, ct as hasInterSessionUserProvenance, d as isAntigravityClaude, dt as evaluateSessionFreshness, et as normalizeSessionDeliveryFields, f as isGoogleModelApi, ft as resolveChannelResetConfig, g as formatBillingErrorMessage, gt as DEFAULT_RESET_TRIGGERS, h as formatAssistantErrorText, ht as resolveThreadFlag, it as countToolResults, j as parseImageDimensionError, jt as resolveExistingPathsWithinRoot, k as isTimeoutErrorMessage, kt as resolveProfile, l as extractToolResultId, lt as normalizeInputProvenance, m as classifyFailoverReason, mt as resolveSessionResetType, n as validateGeminiTurns, nt as archiveSessionTranscripts, o as normalizeTextForComparison, ot as INPUT_PROVENANCE_KIND_VALUES, p as BILLING_ERROR_USER_MESSAGE, pt as resolveSessionResetPolicy, q as updateSessionStoreEntry, qt as buildBootstrapContextFiles, r as pickFallbackThinkingLevel, rt as capArrayByJsonBytes, s as sanitizeSessionMessagesImages, st as applyInputProvenanceToUserMessage, t as validateAnthropicTurns, tt as normalizeAccountId$3, u as downgradeOpenAIReasoningBlocks, ut as resolveSessionKey, v as getApiErrorPayloadFingerprint, vt as canonicalizeMainSessionAlias, w as isFailoverAssistantError, wt as acquireSessionWriteLock, x as isCloudCodeAssistFormatError, xt as resolveMainSessionKey, y as isAuthAssistantError, z as appendAssistantMessageToSessionTranscript, zt as expandPolicyWithPluginGroups } from "./pi-embedded-helpers-yCss7Bdi.js";
27
+ 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-oz6yMs1r.js";
28
28
  import { a as applyTestPluginDefaults, c as resolveMemorySlotDecision, d as isDangerousHostEnvVarName, i as safeStatSync, n as discoverSymiPlugins, o as normalizePluginsConfig, r as isPathInside, s as resolveEnableState, t as loadPluginManifestRegistry, u as isPathInsideWithRealpath } from "./manifest-registry-D0IQ3WuX.js";
29
- import { C as rawDataToString, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, T as isSecureWebSocketUrl, x as ensureChromeExtensionRelayServer } from "./chrome-B4BVdT6M.js";
29
+ import { C as rawDataToString, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, T as isSecureWebSocketUrl, x as ensureChromeExtensionRelayServer } from "./chrome-CkWGSMS5.js";
30
30
  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-BFekKL7i.js";
31
31
  import { n as formatErrorMessage, r as formatUncaughtError } from "./errors-BoQgnc8X.js";
32
32
  import { i as isBlockedHostnameOrIp, o as normalizeHostname, t as SsrFBlockedError } from "./ssrf-BTMDZjHT.js";
@@ -37,9 +37,9 @@ import { t as resolveIMessageAccount } from "./accounts-qtxJ-6em.js";
37
37
  import { i as resolveSessionTranscriptPath, n as resolveSessionFilePath, o as resolveSessionTranscriptsDirForAgent, r as resolveSessionFilePathOptions, s as resolveStorePath, t as resolveDefaultSessionStorePath } from "./paths-DLyHUt31.js";
38
38
  import { t as emitSessionTranscriptUpdate } from "./transcript-events-DDYvbmRV.js";
39
39
  import { i as resolveImageSanitizationLimits, n as sanitizeImageBlocks, r as sanitizeToolResultImages } from "./tool-images-DXB7tqWi.js";
40
- 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-DOum3dyt.js";
40
+ 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-Cvu0YSjj.js";
41
41
  import { a as resolveAgentIdentity, i as resolveAckReaction, o as resolveEffectiveMessagesConfig, r as resolveResponsePrefixTemplate, s as resolveHumanDelayConfig, t as createReplyPrefixOptions } from "./reply-prefix-XlyuyChD.js";
42
- import { i as resolveMemorySearchConfig, n as probeOllamaEmbeddingModels, r as resolveOllamaBaseUrl } from "./manager-D5ZbBYmN.js";
42
+ import { i as resolveMemorySearchConfig, n as probeOllamaEmbeddingModels, r as resolveOllamaBaseUrl } from "./manager-WMCMBAXk.js";
43
43
  import { d as listMemoryFiles, f as normalizeExtraMemoryPaths, g as runTasksWithConcurrency } from "./sqlite-DRbx2dhW.js";
44
44
  import { n as retryAsync } from "./retry-Cly39XZB.js";
45
45
  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-Be1SwYlW.js";
@@ -48,20 +48,20 @@ import { n as resolveMarkdownTableMode } from "./markdown-tables-iMQQZu4Q.js";
48
48
  import { n as fetchWithTimeout, t as bindAbortRelay } from "./fetch-timeout-DL3f_O53.js";
49
49
  import { a as readResponseWithLimit, i as fetchRemoteMedia, n as getDefaultMediaLocalRoots, o as fetchWithSsrFGuard, t as getAgentScopedMediaLocalRoots } from "./local-roots-DMwIh5cS.js";
50
50
  import { a as loadWebMedia, i as getDefaultLocalRoots } from "./ir-DccrnjsE.js";
51
- 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-tuRMQmX4.js";
52
- 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-C2kxEz5h.js";
51
+ 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-DhT2Skgp.js";
52
+ 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-Depo8UbH.js";
53
53
  import { r as normalizeInboundTextNewlines, t as finalizeInboundContext } from "./inbound-context-BlHX0H3E.js";
54
- 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-C6VtiNZz.js";
54
+ 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-C-hs6BOd.js";
55
55
  import { n as wrapFetchWithAbortSignal, t as resolveFetch } from "./fetch-Bso4i15F.js";
56
56
  import { n as recordCommandPoll, r as resetCommandPollCount } from "./command-poll-backoff-Bup9wS1y.js";
57
57
  import { n as recordChannelActivity, r as createDiscordRetryRunner, t as getChannelActivity } from "./channel-activity-CsM_hJ_s.js";
58
58
  import { n as normalizePollInput } from "./polls-CCuCaqgv.js";
59
59
  import { t as convertMarkdownTables } from "./tables-DuZspiBu.js";
60
- import { a as resolveSignalRpcContext, c as streamSignalEvents, n as sendReadReceiptSignal, o as signalCheck, r as sendTypingSignal, s as signalRpcRequest, t as sendMessageSignal } from "./send-BfoI2xoz.js";
61
- import { a as formatIMessageChatTarget, c as parseIMessageTarget, i as DEFAULT_IMESSAGE_PROBE_TIMEOUT_MS, o as isAllowedIMessageSender, r as createIMessageRpcClient, s as normalizeIMessageHandle, t as sendMessageIMessage } from "./send-ytd5gZYc.js";
60
+ import { a as resolveSignalRpcContext, c as streamSignalEvents, n as sendReadReceiptSignal, o as signalCheck, r as sendTypingSignal, s as signalRpcRequest, t as sendMessageSignal } from "./send-Dub0pvGr.js";
61
+ import { a as formatIMessageChatTarget, c as parseIMessageTarget, i as DEFAULT_IMESSAGE_PROBE_TIMEOUT_MS, o as isAllowedIMessageSender, r as createIMessageRpcClient, s as normalizeIMessageHandle, t as sendMessageIMessage } from "./send-B3ysC28K.js";
62
62
  import { n as resolveAgentRoute, t as buildAgentSessionKey } from "./resolve-route-CZ-1eqw0.js";
63
63
  import { t as makeProxyFetch } from "./proxy-CBJ1upuz.js";
64
- import { a as createReplyReferencePlanner, i as resolveSlackThreadTs, n as deliverReplies$3, t as createSlackReplyDeliveryPlan } from "./replies-BVXZDrhw.js";
64
+ import { a as createReplyReferencePlanner, i as resolveSlackThreadTs, n as deliverReplies$3, t as createSlackReplyDeliveryPlan } from "./replies-CeKPHa39.js";
65
65
  import { t as getActiveWebListener } from "./active-listener-C9r8ZB9m.js";
66
66
  import { createRequire } from "node:module";
67
67
  import * as fs$2 from "node:fs/promises";
@@ -3474,7 +3474,7 @@ async function getMemorySearchManager(params) {
3474
3474
  const wrapper = new FallbackMemoryManager({
3475
3475
  primary,
3476
3476
  fallbackFactory: async () => {
3477
- const { MemoryIndexManager } = await import("./manager-D5ZbBYmN.js").then((n) => n.t);
3477
+ const { MemoryIndexManager } = await import("./manager-WMCMBAXk.js").then((n) => n.t);
3478
3478
  return await MemoryIndexManager.get(params);
3479
3479
  }
3480
3480
  }, () => QMD_MANAGER_CACHE.delete(cacheKey));
@@ -3487,7 +3487,7 @@ async function getMemorySearchManager(params) {
3487
3487
  }
3488
3488
  }
3489
3489
  try {
3490
- const { MemoryIndexManager } = await import("./manager-D5ZbBYmN.js").then((n) => n.t);
3490
+ const { MemoryIndexManager } = await import("./manager-WMCMBAXk.js").then((n) => n.t);
3491
3491
  return { manager: await MemoryIndexManager.get(params) };
3492
3492
  } catch (err) {
3493
3493
  return {
@@ -7201,7 +7201,7 @@ async function routeReply(params) {
7201
7201
  const resolvedReplyToId = replyToId ?? (channelId === "slack" && threadId != null && threadId !== "" ? String(threadId) : void 0);
7202
7202
  const resolvedThreadId = channelId === "slack" ? null : threadId ?? null;
7203
7203
  try {
7204
- const { deliverOutboundPayloads } = await import("./deliver-CHWZIQz7.js").then((n) => n.n);
7204
+ const { deliverOutboundPayloads } = await import("./deliver-BpcMy6AD.js").then((n) => n.n);
7205
7205
  return {
7206
7206
  ok: true,
7207
7207
  messageId: (await deliverOutboundPayloads({
@@ -8977,29 +8977,29 @@ function getSubagentRunsSnapshotForRead(inMemoryRuns) {
8977
8977
  //#region src/agents/timeout.ts
8978
8978
  const DEFAULT_AGENT_TIMEOUT_SECONDS = 1800;
8979
8979
  const MAX_SAFE_TIMEOUT_MS = 2147e6;
8980
- const normalizeNumber = (value) => typeof value === "number" && Number.isFinite(value) ? Math.floor(value) : void 0;
8980
+ const normalizeNumber$1 = (value) => typeof value === "number" && Number.isFinite(value) ? Math.floor(value) : void 0;
8981
8981
  function resolveAgentTimeoutSeconds(cfg) {
8982
- const seconds = normalizeNumber(cfg?.agents?.defaults?.timeoutSeconds) ?? DEFAULT_AGENT_TIMEOUT_SECONDS;
8982
+ const seconds = normalizeNumber$1(cfg?.agents?.defaults?.timeoutSeconds) ?? DEFAULT_AGENT_TIMEOUT_SECONDS;
8983
8983
  return Math.max(seconds, 1);
8984
8984
  }
8985
8985
  function resolveAgentTimeoutMs(opts) {
8986
- const minMs = Math.max(normalizeNumber(opts.minMs) ?? 1, 1);
8986
+ const minMs = Math.max(normalizeNumber$1(opts.minMs) ?? 1, 1);
8987
8987
  const clampTimeoutMs = (valueMs) => Math.min(Math.max(valueMs, minMs), MAX_SAFE_TIMEOUT_MS);
8988
8988
  const defaultMs = clampTimeoutMs(resolveAgentTimeoutSeconds(opts.cfg) * 1e3);
8989
8989
  const NO_TIMEOUT_MS = MAX_SAFE_TIMEOUT_MS;
8990
- const overrideMs = normalizeNumber(opts.overrideMs);
8990
+ const overrideMs = normalizeNumber$1(opts.overrideMs);
8991
8991
  if (overrideMs !== void 0) {
8992
8992
  if (overrideMs === 0) return NO_TIMEOUT_MS;
8993
8993
  if (overrideMs < 0) return defaultMs;
8994
8994
  return clampTimeoutMs(overrideMs);
8995
8995
  }
8996
- const overrideSeconds = normalizeNumber(opts.overrideSeconds);
8996
+ const overrideSeconds = normalizeNumber$1(opts.overrideSeconds);
8997
8997
  if (overrideSeconds !== void 0) {
8998
8998
  if (overrideSeconds === 0) return NO_TIMEOUT_MS;
8999
8999
  if (overrideSeconds < 0) return defaultMs;
9000
9000
  return clampTimeoutMs(overrideSeconds * 1e3);
9001
9001
  }
9002
- const modelSeconds = normalizeNumber(opts.modelTimeoutSeconds);
9002
+ const modelSeconds = normalizeNumber$1(opts.modelTimeoutSeconds);
9003
9003
  if (modelSeconds !== void 0 && modelSeconds > 0) return clampTimeoutMs(modelSeconds * 1e3);
9004
9004
  return defaultMs;
9005
9005
  }
@@ -12656,7 +12656,7 @@ async function createModelSelectionState(params) {
12656
12656
  }
12657
12657
  }
12658
12658
  if (sessionEntry && sessionStore && sessionKey && sessionEntry.authProfileOverride) {
12659
- const { ensureAuthProfileStore } = await import("./model-auth-Db8I8QVL.js").then((n) => n.s);
12659
+ const { ensureAuthProfileStore } = await import("./model-auth-ueipoWgv.js").then((n) => n.s);
12660
12660
  const profile = ensureAuthProfileStore(void 0, { allowKeychainPrompt: false }).profiles[sessionEntry.authProfileOverride];
12661
12661
  const providerKey = normalizeProviderId(provider);
12662
12662
  if (!profile || normalizeProviderId(profile.provider) !== providerKey) await clearSessionAuthProfileOverride({
@@ -21785,6 +21785,14 @@ function buildAgentSystemPrompt(params) {
21785
21785
  "Keep narration brief and value-dense; avoid repeating obvious steps.",
21786
21786
  "Use plain human language for narration unless in a technical context.",
21787
21787
  "",
21788
+ "## Edit Tool Best Practices",
21789
+ "When using the edit tool, the oldText must match the file EXACTLY (whitespace, indentation, and all).",
21790
+ "To avoid match failures:",
21791
+ "- Use the SHORTEST unique snippet that identifies the edit location (1-3 lines). Do NOT paste large blocks.",
21792
+ "- ALWAYS read the file first, then copy the exact text from the read output for oldText.",
21793
+ "- If an edit fails with 'Could not find the exact text', re-read the file and retry with the exact text from the fresh read. Do NOT move on or fix a different issue.",
21794
+ "- Prefer lines with distinctive content (function names, unique strings) over generic code (braces, blank lines).",
21795
+ "",
21788
21796
  ...safetySection,
21789
21797
  "## Symi CLI Quick Reference",
21790
21798
  "Symi is controlled via subcommands. Do not invent commands.",
@@ -41649,7 +41657,7 @@ async function deliverSessionMaintenanceWarning(params) {
41649
41657
  return;
41650
41658
  }
41651
41659
  try {
41652
- const { deliverOutboundPayloads } = await import("./deliver-CHWZIQz7.js").then((n) => n.n);
41660
+ const { deliverOutboundPayloads } = await import("./deliver-BpcMy6AD.js").then((n) => n.n);
41653
41661
  await deliverOutboundPayloads({
41654
41662
  cfg: params.cfg,
41655
41663
  channel,
@@ -45095,7 +45103,7 @@ async function describeStickerImage(params) {
45095
45103
  logVerbose(`telegram: describing sticker with ${provider}/${model}`);
45096
45104
  try {
45097
45105
  const buffer = await fs.readFile(imagePath);
45098
- const { describeImageWithModel } = await import("./image-DOum3dyt.js").then((n) => n.n);
45106
+ const { describeImageWithModel } = await import("./image-Cvu0YSjj.js").then((n) => n.n);
45099
45107
  return (await describeImageWithModel({
45100
45108
  buffer,
45101
45109
  fileName: "sticker.webp",
@@ -45518,7 +45526,7 @@ function createWhatsAppLoginTool() {
45518
45526
  force: Type.Optional(Type.Boolean())
45519
45527
  }),
45520
45528
  execute: async (_toolCallId, args) => {
45521
- const { startWebLoginWithQr, waitForWebLogin } = await import("./login-qr-CBPis3I2.js");
45529
+ const { startWebLoginWithQr, waitForWebLogin } = await import("./login-qr-BMs92uQR.js");
45522
45530
  if ((args?.action ?? "start") === "wait") {
45523
45531
  const result = await waitForWebLogin({ timeoutMs: typeof args.timeoutMs === "number" ? args.timeoutMs : void 0 });
45524
45532
  return {
@@ -47757,7 +47765,7 @@ async function preflightDiscordMessage(params) {
47757
47765
  let preflightTranscript;
47758
47766
  const hasAudioAttachment = message.attachments?.some((att) => att.contentType?.startsWith("audio/"));
47759
47767
  if (!isDirectMessage && shouldRequireMention && hasAudioAttachment && !baseText && mentionRegexes.length > 0) try {
47760
- const { transcribeFirstAudio } = await import("./audio-preflight-C7tgYAnW.js");
47768
+ const { transcribeFirstAudio } = await import("./audio-preflight-CHWYpvI7.js");
47761
47769
  const audioPaths = message.attachments?.filter((att) => att.contentType?.startsWith("audio/")).map((att) => att.url) ?? [];
47762
47770
  if (audioPaths.length > 0) preflightTranscript = await transcribeFirstAudio({
47763
47771
  ctx: {
@@ -51763,27 +51771,27 @@ function isVoiceChannelType(type) {
51763
51771
  function createDefaultDeps() {
51764
51772
  return {
51765
51773
  sendMessageWhatsApp: async (...args) => {
51766
- const { sendMessageWhatsApp } = await import("./web-Cyg-Awr5.js");
51774
+ const { sendMessageWhatsApp } = await import("./web-BxUguUwU.js");
51767
51775
  return await sendMessageWhatsApp(...args);
51768
51776
  },
51769
51777
  sendMessageTelegram: async (...args) => {
51770
- const { sendMessageTelegram } = await import("./send-BAM-zeo8.js").then((n) => n.l);
51778
+ const { sendMessageTelegram } = await import("./send-CLeHyMKL.js").then((n) => n.l);
51771
51779
  return await sendMessageTelegram(...args);
51772
51780
  },
51773
51781
  sendMessageDiscord: async (...args) => {
51774
- const { sendMessageDiscord } = await import("./send-BVKK9mIc.js").then((n) => n.t);
51782
+ const { sendMessageDiscord } = await import("./send-B-uN5xRM.js").then((n) => n.t);
51775
51783
  return await sendMessageDiscord(...args);
51776
51784
  },
51777
51785
  sendMessageSlack: async (...args) => {
51778
- const { sendMessageSlack } = await import("./send-DffO5_WA.js").then((n) => n.n);
51786
+ const { sendMessageSlack } = await import("./send-Dq3yh0n_.js").then((n) => n.n);
51779
51787
  return await sendMessageSlack(...args);
51780
51788
  },
51781
51789
  sendMessageSignal: async (...args) => {
51782
- const { sendMessageSignal } = await import("./send-BfoI2xoz.js").then((n) => n.i);
51790
+ const { sendMessageSignal } = await import("./send-Dub0pvGr.js").then((n) => n.i);
51783
51791
  return await sendMessageSignal(...args);
51784
51792
  },
51785
51793
  sendMessageIMessage: async (...args) => {
51786
- const { sendMessageIMessage } = await import("./send-ytd5gZYc.js").then((n) => n.n);
51794
+ const { sendMessageIMessage } = await import("./send-B3ysC28K.js").then((n) => n.n);
51787
51795
  return await sendMessageIMessage(...args);
51788
51796
  }
51789
51797
  };
@@ -62212,7 +62220,7 @@ function readSlackExternalArgMenuToken(raw) {
62212
62220
  }
62213
62221
  let commandsRegistry;
62214
62222
  async function getCommandsRegistry() {
62215
- if (!commandsRegistry) commandsRegistry = await import("./commands-registry-tuRMQmX4.js").then((n) => n.n);
62223
+ if (!commandsRegistry) commandsRegistry = await import("./commands-registry-DhT2Skgp.js").then((n) => n.n);
62216
62224
  return commandsRegistry;
62217
62225
  }
62218
62226
  function encodeSlackCommandArgValue(parts) {
@@ -62615,7 +62623,7 @@ async function registerSlackMonitorSlashCommands(params) {
62615
62623
  });
62616
62624
  const deliverSlashPayloads = async (replies) => {
62617
62625
  const [{ deliverSlackSlashReplies }, { resolveChunkMode }, { resolveMarkdownTableMode }] = await Promise.all([
62618
- import("./replies-BVXZDrhw.js").then((n) => n.r),
62626
+ import("./replies-CeKPHa39.js").then((n) => n.r),
62619
62627
  import("./chunk-BW5f05BR.js").then((n) => n.s),
62620
62628
  import("./markdown-tables-iMQQZu4Q.js").then((n) => n.t)
62621
62629
  ]);
@@ -62670,7 +62678,7 @@ async function registerSlackMonitorSlashCommands(params) {
62670
62678
  let nativeCommands = [];
62671
62679
  if (nativeEnabled) {
62672
62680
  reg = await getCommandsRegistry();
62673
- const skillCommands = nativeSkillsEnabled ? (await import("./skill-commands-C2kxEz5h.js").then((n) => n.a)).listSkillCommandsForAgents({ cfg }) : [];
62681
+ const skillCommands = nativeSkillsEnabled ? (await import("./skill-commands-Depo8UbH.js").then((n) => n.a)).listSkillCommandsForAgents({ cfg }) : [];
62674
62682
  nativeCommands = reg.listNativeCommandSpecsForConfig(cfg, {
62675
62683
  skillCommands,
62676
62684
  provider: "slack"
@@ -64888,7 +64896,7 @@ const buildTelegramMessageContext = async ({ primaryCtx, allMedia, storeAllowFro
64888
64896
  const hasAudio = allMedia.some((media) => media.contentType?.startsWith("audio/"));
64889
64897
  let preflightTranscript;
64890
64898
  if (isGroup && requireMention && hasAudio && !hasUserText && mentionRegexes.length > 0) try {
64891
- const { transcribeFirstAudio } = await import("./audio-preflight-C7tgYAnW.js");
64899
+ const { transcribeFirstAudio } = await import("./audio-preflight-CHWYpvI7.js");
64892
64900
  preflightTranscript = await transcribeFirstAudio({
64893
64901
  ctx: {
64894
64902
  MediaPaths: allMedia.length > 0 ? allMedia.map((m) => m.path) : void 0,
@@ -67033,23 +67041,23 @@ let webLoginQrPromise = null;
67033
67041
  let webChannelPromise = null;
67034
67042
  let whatsappActionsPromise = null;
67035
67043
  function loadWebOutbound() {
67036
- webOutboundPromise ??= import("./outbound-Qgo51Q1x.js").then((n) => n.t);
67044
+ webOutboundPromise ??= import("./outbound-fyE60RfL.js").then((n) => n.t);
67037
67045
  return webOutboundPromise;
67038
67046
  }
67039
67047
  function loadWebLogin() {
67040
- webLoginPromise ??= import("./login-CJf4Gdbq.js").then((n) => n.n);
67048
+ webLoginPromise ??= import("./login-CMot-0rl.js").then((n) => n.n);
67041
67049
  return webLoginPromise;
67042
67050
  }
67043
67051
  function loadWebLoginQr() {
67044
- webLoginQrPromise ??= import("./login-qr-CBPis3I2.js");
67052
+ webLoginQrPromise ??= import("./login-qr-BMs92uQR.js");
67045
67053
  return webLoginQrPromise;
67046
67054
  }
67047
67055
  function loadWebChannel() {
67048
- webChannelPromise ??= import("./web-Cyg-Awr5.js");
67056
+ webChannelPromise ??= import("./web-BxUguUwU.js");
67049
67057
  return webChannelPromise;
67050
67058
  }
67051
67059
  function loadWhatsAppActions() {
67052
- whatsappActionsPromise ??= import("./whatsapp-actions-DfJHCjBV.js");
67060
+ whatsappActionsPromise ??= import("./whatsapp-actions-b0l0LfoG.js");
67053
67061
  return whatsappActionsPromise;
67054
67062
  }
67055
67063
  function createPluginRuntime() {
@@ -75022,6 +75030,31 @@ Use the message tool with buttons:
75022
75030
  [{"label": "✅ Proceed", "data": "/plan-proceed"}, {"label": "✏️ Modify", "data": "/plan-modify"}, {"label": "❌ Cancel", "data": "/plan-cancel"}]
75023
75031
  </plan_mode>`;
75024
75032
 
75033
+ //#endregion
75034
+ //#region src/agents/symipulse-timeout.ts
75035
+ /**
75036
+ * Symipulse inactivity timeout resolution.
75037
+ *
75038
+ * The symipulse timer resets on every model/tool activity signal (streaming
75039
+ * chunk, tool execution, compaction, etc.). It fires only when the run is
75040
+ * truly idle — distinguishing "model working slowly on large context" from
75041
+ * "model stuck / connection lost".
75042
+ */
75043
+ const DEFAULT_SYMIPULSE_RATIO = .5;
75044
+ const MIN_SYMIPULSE_MS = 12e4;
75045
+ const MAX_SYMIPULSE_MS = 9e5;
75046
+ const SYMIPULSE_MIN_TIMEOUT_MS = 3e4;
75047
+ const normalizeNumber = (value) => typeof value === "number" && Number.isFinite(value) ? Math.floor(value) : void 0;
75048
+ function resolveSymipulseMs(opts) {
75049
+ const cap = Math.max(SYMIPULSE_MIN_TIMEOUT_MS, opts.runTimeoutMs - 1e3);
75050
+ const modelMs = normalizeNumber(opts.modelSeconds != null ? opts.modelSeconds * 1e3 : void 0);
75051
+ if (modelMs !== void 0 && modelMs > 0) return Math.min(Math.max(modelMs, SYMIPULSE_MIN_TIMEOUT_MS), cap);
75052
+ const configMs = normalizeNumber(opts.configSeconds != null ? opts.configSeconds * 1e3 : void 0);
75053
+ if (configMs !== void 0 && configMs > 0) return Math.min(Math.max(configMs, SYMIPULSE_MIN_TIMEOUT_MS), cap);
75054
+ const computed = Math.floor(opts.runTimeoutMs * DEFAULT_SYMIPULSE_RATIO);
75055
+ return Math.min(Math.max(computed, MIN_SYMIPULSE_MS), Math.min(MAX_SYMIPULSE_MS, cap));
75056
+ }
75057
+
75025
75058
  //#endregion
75026
75059
  //#region src/agents/pi-embedded-runner/abort.ts
75027
75060
  /**
@@ -76155,6 +76188,36 @@ async function runEmbeddedAttempt(params) {
76155
76188
  });
76156
76189
  });
76157
76190
  };
76191
+ const resolveModelSymipulseSeconds = () => {
76192
+ const key = params.modelId;
76193
+ if (!key) return null;
76194
+ return (params.config?.agents?.defaults?.models)?.[key]?.symipulseSeconds ?? null;
76195
+ };
76196
+ const symipulseMs = params.symipulseMs ?? resolveSymipulseMs({
76197
+ runTimeoutMs: params.timeoutMs,
76198
+ configSeconds: params.config?.agents?.defaults?.symipulseSeconds,
76199
+ modelSeconds: resolveModelSymipulseSeconds()
76200
+ });
76201
+ let symipulseTimer = null;
76202
+ const makeSymipulseAbortReason = () => {
76203
+ const err = /* @__PURE__ */ new Error(`symipulse: no model/tool activity for ${Math.round(symipulseMs / 1e3)}s (inactivity timeout). Run timeout was ${Math.round(params.timeoutMs / 1e3)}s. Increase symipulseSeconds or check model connectivity.`);
76204
+ err.name = "SymipulseTimeoutError";
76205
+ return err;
76206
+ };
76207
+ const clearSymipulseTimer = () => {
76208
+ if (symipulseTimer) {
76209
+ clearTimeout(symipulseTimer);
76210
+ symipulseTimer = null;
76211
+ }
76212
+ };
76213
+ let armSymipulseTimer;
76214
+ const withSymipulse = (fn) => {
76215
+ if (!fn) return fn;
76216
+ return ((...args) => {
76217
+ armSymipulseTimer();
76218
+ return fn(...args);
76219
+ });
76220
+ };
76158
76221
  const subscription = subscribeEmbeddedPiSession({
76159
76222
  session: activeSession,
76160
76223
  runId: params.runId,
@@ -76164,16 +76227,19 @@ async function runEmbeddedAttempt(params) {
76164
76227
  toolResultFormat: params.toolResultFormat,
76165
76228
  shouldEmitToolResult: params.shouldEmitToolResult,
76166
76229
  shouldEmitToolOutput: params.shouldEmitToolOutput,
76167
- onToolResult: params.onToolResult,
76168
- onReasoningStream: params.onReasoningStream,
76230
+ onToolResult: withSymipulse(params.onToolResult),
76231
+ onReasoningStream: withSymipulse(params.onReasoningStream),
76169
76232
  onReasoningEnd: params.onReasoningEnd,
76170
- onBlockReply: params.onBlockReply,
76233
+ onBlockReply: withSymipulse(params.onBlockReply),
76171
76234
  onBlockReplyFlush: params.onBlockReplyFlush,
76172
76235
  blockReplyBreak: params.blockReplyBreak,
76173
76236
  blockReplyChunking: params.blockReplyChunking,
76174
- onPartialReply: params.onPartialReply,
76237
+ onPartialReply: withSymipulse(params.onPartialReply),
76175
76238
  onAssistantMessageStart: params.onAssistantMessageStart,
76176
- onAgentEvent: params.onAgentEvent,
76239
+ onAgentEvent: (evt) => {
76240
+ armSymipulseTimer();
76241
+ params.onAgentEvent?.(evt);
76242
+ },
76177
76243
  enforceFinalTag: params.enforceFinalTag,
76178
76244
  config: params.config,
76179
76245
  sessionKey: params.sessionKey ?? params.sessionId
@@ -76203,6 +76269,21 @@ async function runEmbeddedAttempt(params) {
76203
76269
  if (!isProbeSession) log$2.warn(`embedded run abort still streaming: runId=${params.runId} sessionId=${params.sessionId}`);
76204
76270
  }, 1e4);
76205
76271
  }, Math.max(1, params.timeoutMs));
76272
+ armSymipulseTimer = () => {
76273
+ if (aborted) return;
76274
+ clearSymipulseTimer();
76275
+ symipulseTimer = setTimeout(() => {
76276
+ if (aborted) return;
76277
+ if (!isProbeSession) log$2.warn(`symipulse timeout: runId=${params.runId} sessionId=${params.sessionId} symipulseMs=${symipulseMs} (no activity)`);
76278
+ if (shouldFlagCompactionTimeout({
76279
+ isTimeout: true,
76280
+ isCompactionPendingOrRetrying: subscription.isCompacting(),
76281
+ isCompactionInFlight: activeSession.isCompacting
76282
+ })) timedOutDuringCompaction = true;
76283
+ abortRun(true, makeSymipulseAbortReason());
76284
+ }, Math.max(1, symipulseMs));
76285
+ };
76286
+ armSymipulseTimer();
76206
76287
  let messagesSnapshot = [];
76207
76288
  let sessionIdUsed = activeSession.sessionId;
76208
76289
  const onAbort = () => {
@@ -76423,6 +76504,7 @@ async function runEmbeddedAttempt(params) {
76423
76504
  });
76424
76505
  } finally {
76425
76506
  clearTimeout(abortTimer);
76507
+ clearSymipulseTimer();
76426
76508
  if (abortWarnTimer) clearTimeout(abortWarnTimer);
76427
76509
  if (!isProbeSession && (aborted || timedOut) && !timedOutDuringCompaction) log$2.debug(`run cleanup: runId=${params.runId} sessionId=${params.sessionId} aborted=${aborted} timedOut=${timedOut}`);
76428
76510
  try {
@@ -1,6 +1,6 @@
1
1
  import { E as truncateUtf16Safe } from "./utils-B-0b9bGM.js";
2
2
  import { s as normalizeThinkLevel } from "./thinking-EAliFiVK.js";
3
- import { s as formatSandboxToolPolicyBlockedMessage } from "./sandbox-BBGJMpXR.js";
3
+ import { s as formatSandboxToolPolicyBlockedMessage } from "./sandbox-BgudXNdX.js";
4
4
  import { t as sanitizeContentBlocksImages } from "./tool-images-DvUBlqjX.js";
5
5
  import path from "node:path";
6
6
  import fs from "node:fs/promises";
@@ -3,14 +3,14 @@ import { c as normalizeMainKey, l as resolveAgentIdFromSessionKey, m as normaliz
3
3
  import { A as normalizeE164, P as resolveUserPath, V as truncateUtf16Safe, lt as resolvePreferredSymiTmpDir, t as CHANNEL_IDS } from "./registry-BhoUuugi.js";
4
4
  import { E as runExec, _ as DEFAULT_SYMIPULSE_FILENAME, b as ensureAgentWorkspace, f as DEFAULT_AGENTS_FILENAME, g as DEFAULT_SYMICORE_FILENAME, h as DEFAULT_IDENTITY_FILENAME, m as DEFAULT_BOOTSTRAP_FILENAME, n as resolveAgentConfig, p as DEFAULT_AGENT_WORKSPACE_DIR, u as resolveSessionAgentId, v as DEFAULT_TOOLS_FILENAME, y as DEFAULT_USER_FILENAME } from "./agent-scope-Cbl5pNe1.js";
5
5
  import { r as defaultRuntime, t as createSubsystemLogger } from "./subsystem-CZixfwU8.js";
6
- import { J as isPidAlive, q as resolveProcessScopedMap } from "./model-selection-DBPwoBvb.js";
6
+ import { J as isPidAlive, q as resolveProcessScopedMap } from "./model-selection-d3VVSx3Z.js";
7
7
  import { n as parseBooleanValue, r as formatCliCommand } from "./env-CQ_DQOwT.js";
8
8
  import { r as normalizeChannelId } from "./plugins-71oIavrF.js";
9
9
  import { t as normalizeChatType } from "./chat-type-DFDuk3FY.js";
10
10
  import { c as SafeOpenError, i as getImageMetadata, l as openFileWithinRoot, n as buildImageResizeSideGrid, s as resizeToJpeg, t as IMAGE_REDUCE_QUALITY_STEPS } from "./image-ops-ByaQt43P.js";
11
11
  import { o as listDeliverableMessageChannels, s as normalizeMessageChannel } from "./message-channel-BQINJQIT.js";
12
- import { _ as parseDurationMs, a as writeConfigFile, n as loadConfig, s as parseByteSize, t as createConfigIO } from "./config-Crs8V2FU.js";
13
- import { A as DEFAULT_BROWSER_EVALUATE_ENABLED, D as DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS, E as DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH, M as DEFAULT_SYMI_BROWSER_ENABLED, N as DEFAULT_SYMI_BROWSER_PROFILE_NAME, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, S as stopChromeExtensionRelayServer, _ as fetchJson, a as resolveSymiUserDataDir, c as captureScreenshot, d as normalizeCdpWsUrl, f as snapshotAria, g as appendCdpPath, h as withBrowserNavigationPolicy, i as launchSymiChrome, j as DEFAULT_SYMI_BROWSER_COLOR, k as DEFAULT_BROWSER_DEFAULT_PROFILE_NAME, l as createTargetViaCdp, m as assertBrowserNavigationAllowed, n as isChromeCdpReady, o as stopSymiChrome, p as InvalidBrowserNavigationUrlError, r as isChromeReachable, s as resolveBrowserExecutableForPlatform, v as fetchOk, w as isLoopbackHost, x as ensureChromeExtensionRelayServer } from "./chrome-BUUMKYz7.js";
12
+ import { _ as parseDurationMs, a as writeConfigFile, n as loadConfig, s as parseByteSize, t as createConfigIO } from "./config-6k8f4O94.js";
13
+ import { A as DEFAULT_BROWSER_EVALUATE_ENABLED, D as DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS, E as DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH, M as DEFAULT_SYMI_BROWSER_ENABLED, N as DEFAULT_SYMI_BROWSER_PROFILE_NAME, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, S as stopChromeExtensionRelayServer, _ as fetchJson, a as resolveSymiUserDataDir, c as captureScreenshot, d as normalizeCdpWsUrl, f as snapshotAria, g as appendCdpPath, h as withBrowserNavigationPolicy, i as launchSymiChrome, j as DEFAULT_SYMI_BROWSER_COLOR, k as DEFAULT_BROWSER_DEFAULT_PROFILE_NAME, l as createTargetViaCdp, m as assertBrowserNavigationAllowed, n as isChromeCdpReady, o as stopSymiChrome, p as InvalidBrowserNavigationUrlError, r as isChromeReachable, s as resolveBrowserExecutableForPlatform, v as fetchOk, w as isLoopbackHost, x as ensureChromeExtensionRelayServer } from "./chrome-Bb5ivmrz.js";
14
14
  import { a as syncSkillsToWorkspace, l as resolveSandboxInputPath, m as sanitizeEnvVars, u as resolveSandboxPath } from "./skills-BNpGMnp-.js";
15
15
  import { n as formatErrorMessage, t as extractErrorCode } from "./errors-CPfngF0S.js";
16
16
  import { t as SsrFBlockedError } from "./ssrf-CxfFyMRZ.js";
@@ -931,7 +931,7 @@ function isModuleNotFoundError(err) {
931
931
  }
932
932
  async function loadPwAiModule(mode) {
933
933
  try {
934
- return await import("./pw-ai-D-O0LOKC.js");
934
+ return await import("./pw-ai-CIlFJoZJ.js");
935
935
  } catch (err) {
936
936
  if (mode === "soft") return null;
937
937
  if (isModuleNotFoundError(err)) return null;
@@ -3471,11 +3471,11 @@ function createProfileContext(opts, profile) {
3471
3471
  const userDataDir = resolveSymiUserDataDir(profile.name);
3472
3472
  const profileState = getProfileState();
3473
3473
  if (await isHttpReachable(300) && !profileState.running) try {
3474
- await (await import("./pw-ai-D-O0LOKC.js")).closePlaywrightBrowserConnection();
3474
+ await (await import("./pw-ai-CIlFJoZJ.js")).closePlaywrightBrowserConnection();
3475
3475
  } catch {}
3476
3476
  if (profileState.running) await stopRunningBrowser();
3477
3477
  try {
3478
- await (await import("./pw-ai-D-O0LOKC.js")).closePlaywrightBrowserConnection();
3478
+ await (await import("./pw-ai-CIlFJoZJ.js")).closePlaywrightBrowserConnection();
3479
3479
  } catch {}
3480
3480
  if (!fs.existsSync(userDataDir)) return {
3481
3481
  moved: false,
@@ -1,5 +1,5 @@
1
1
  import { pt as truncateUtf16Safe } from "./entry.js";
2
- import { s as formatSandboxToolPolicyBlockedMessage } from "./sandbox-CPR0wRyk.js";
2
+ import { s as formatSandboxToolPolicyBlockedMessage } from "./sandbox-B9cX1Qsg.js";
3
3
  import { t as sanitizeContentBlocksImages } from "./tool-images-CVLISeRT.js";
4
4
  import { s as normalizeThinkLevel } from "./thinking-8sKPnzpp.js";
5
5
  import path from "node:path";
@@ -9,10 +9,10 @@ import { t as normalizeChatType } from "./chat-type-C_KiWNAH.js";
9
9
  import { t as parseBooleanValue } from "./boolean-B8-BqKGQ.js";
10
10
  import { t as formatCliCommand } from "./command-format-BaxDnULz.js";
11
11
  import { c as SafeOpenError, i as getImageMetadata, l as openFileWithinRoot, n as buildImageResizeSideGrid, s as resizeToJpeg, t as IMAGE_REDUCE_QUALITY_STEPS } from "./image-ops-CvJzsyvE.js";
12
- import { S as isPidAlive, x as resolveProcessScopedMap } from "./model-auth-Db8I8QVL.js";
12
+ import { S as isPidAlive, x as resolveProcessScopedMap } from "./model-auth-ueipoWgv.js";
13
13
  import { o as listDeliverableMessageChannels, s as normalizeMessageChannel } from "./message-channel-Dz5lr5b0.js";
14
- import { _ as parseDurationMs, a as writeConfigFile, n as loadConfig, s as parseByteSize, t as createConfigIO } from "./config-Bh5BJYfZ.js";
15
- import { A as DEFAULT_BROWSER_EVALUATE_ENABLED, D as DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS, E as DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH, M as DEFAULT_SYMI_BROWSER_ENABLED, N as DEFAULT_SYMI_BROWSER_PROFILE_NAME, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, S as stopChromeExtensionRelayServer, _ as fetchJson, a as resolveSymiUserDataDir, c as captureScreenshot, d as normalizeCdpWsUrl, f as snapshotAria, g as appendCdpPath, h as withBrowserNavigationPolicy, i as launchSymiChrome, j as DEFAULT_SYMI_BROWSER_COLOR, k as DEFAULT_BROWSER_DEFAULT_PROFILE_NAME, l as createTargetViaCdp, m as assertBrowserNavigationAllowed, n as isChromeCdpReady, o as stopSymiChrome, p as InvalidBrowserNavigationUrlError, r as isChromeReachable, s as resolveBrowserExecutableForPlatform, v as fetchOk, w as isLoopbackHost, x as ensureChromeExtensionRelayServer } from "./chrome-B4BVdT6M.js";
14
+ import { _ as parseDurationMs, a as writeConfigFile, n as loadConfig, s as parseByteSize, t as createConfigIO } from "./config-oz6yMs1r.js";
15
+ import { A as DEFAULT_BROWSER_EVALUATE_ENABLED, D as DEFAULT_AI_SNAPSHOT_EFFICIENT_MAX_CHARS, E as DEFAULT_AI_SNAPSHOT_EFFICIENT_DEPTH, M as DEFAULT_SYMI_BROWSER_ENABLED, N as DEFAULT_SYMI_BROWSER_PROFILE_NAME, O as DEFAULT_AI_SNAPSHOT_MAX_CHARS, S as stopChromeExtensionRelayServer, _ as fetchJson, a as resolveSymiUserDataDir, c as captureScreenshot, d as normalizeCdpWsUrl, f as snapshotAria, g as appendCdpPath, h as withBrowserNavigationPolicy, i as launchSymiChrome, j as DEFAULT_SYMI_BROWSER_COLOR, k as DEFAULT_BROWSER_DEFAULT_PROFILE_NAME, l as createTargetViaCdp, m as assertBrowserNavigationAllowed, n as isChromeCdpReady, o as stopSymiChrome, p as InvalidBrowserNavigationUrlError, r as isChromeReachable, s as resolveBrowserExecutableForPlatform, v as fetchOk, w as isLoopbackHost, x as ensureChromeExtensionRelayServer } from "./chrome-CkWGSMS5.js";
16
16
  import { a as syncSkillsToWorkspace, l as resolveSandboxInputPath, m as sanitizeEnvVars, u as resolveSandboxPath } from "./skills-BFekKL7i.js";
17
17
  import { n as formatErrorMessage, t as extractErrorCode } from "./errors-BoQgnc8X.js";
18
18
  import { t as SsrFBlockedError } from "./ssrf-BTMDZjHT.js";
@@ -933,7 +933,7 @@ function isModuleNotFoundError(err) {
933
933
  }
934
934
  async function loadPwAiModule(mode) {
935
935
  try {
936
- return await import("./pw-ai-qEd4Ii3S.js");
936
+ return await import("./pw-ai-CzGGXy9V.js");
937
937
  } catch (err) {
938
938
  if (mode === "soft") return null;
939
939
  if (isModuleNotFoundError(err)) return null;
@@ -3473,11 +3473,11 @@ function createProfileContext(opts, profile) {
3473
3473
  const userDataDir = resolveSymiUserDataDir(profile.name);
3474
3474
  const profileState = getProfileState();
3475
3475
  if (await isHttpReachable(300) && !profileState.running) try {
3476
- await (await import("./pw-ai-qEd4Ii3S.js")).closePlaywrightBrowserConnection();
3476
+ await (await import("./pw-ai-CzGGXy9V.js")).closePlaywrightBrowserConnection();
3477
3477
  } catch {}
3478
3478
  if (profileState.running) await stopRunningBrowser();
3479
3479
  try {
3480
- await (await import("./pw-ai-qEd4Ii3S.js")).closePlaywrightBrowserConnection();
3480
+ await (await import("./pw-ai-CzGGXy9V.js")).closePlaywrightBrowserConnection();
3481
3481
  } catch {}
3482
3482
  if (!fs$1.existsSync(userDataDir)) return {
3483
3483
  moved: false,
@@ -1,8 +1,8 @@
1
1
  import { C as resolveThreadParentSessionKey, l as resolveAgentIdFromSessionKey } from "./session-key-DjZ7Z1hW.js";
2
2
  import { r as resolveAgentConfig } from "./agent-scope-D-jRCY0d.js";
3
- import { z as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH } from "./config-CxnbOYs8.js";
3
+ import { z as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH } from "./config-CGJ96S46.js";
4
4
  import { l as normalizeMessageChannel } from "./message-channel-C9dERklz.js";
5
- import { T as matchesAnyGlobPattern, w as compileGlobPatterns, x as normalizeToolName, y as expandToolGroups } from "./sandbox-CPR0wRyk.js";
5
+ import { T as matchesAnyGlobPattern, w as compileGlobPatterns, x as normalizeToolName, y as expandToolGroups } from "./sandbox-B9cX1Qsg.js";
6
6
  import { o as resolveChannelGroupToolsPolicy, t as getChannelDock } from "./dock-DKxQXuAg.js";
7
7
 
8
8
  //#region src/agents/sandbox-tool-policy.ts
@@ -1,8 +1,8 @@
1
1
  import { C as resolveThreadParentSessionKey, l as resolveAgentIdFromSessionKey } from "./session-key-DCt45XZa.js";
2
2
  import { r as resolveAgentConfig } from "./agent-scope-CgUHAtCo.js";
3
3
  import { l as normalizeMessageChannel } from "./message-channel-aT-I_DTX.js";
4
- import { z as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH } from "./config-BMStjqdp.js";
5
- import { T as matchesAnyGlobPattern, w as compileGlobPatterns, x as normalizeToolName, y as expandToolGroups } from "./sandbox-BBGJMpXR.js";
4
+ import { z as DEFAULT_SUBAGENT_MAX_SPAWN_DEPTH } from "./config-uEQqNsoL.js";
5
+ import { T as matchesAnyGlobPattern, w as compileGlobPatterns, x as normalizeToolName, y as expandToolGroups } from "./sandbox-BgudXNdX.js";
6
6
  import { o as resolveChannelGroupToolsPolicy, t as getChannelDock } from "./dock-BhS32F6E.js";
7
7
 
8
8
  //#region src/agents/sandbox-tool-policy.ts
@@ -1,6 +1,6 @@
1
1
  import { d as isRecord } from "./utils-B-0b9bGM.js";
2
2
  import { o as getChatChannelMeta, s as listChatChannels, u as normalizeChatChannelId } from "./registry-Cja8eT7G.js";
3
- import { l as normalizeProviderId } from "./model-selection-BBrZnKDw.js";
3
+ import { l as normalizeProviderId } from "./model-selection-CSRFODzV.js";
4
4
  import { t as hasAnyWhatsAppAuth } from "./accounts-DDuIpcln.js";
5
5
  import { n as getChannelPluginCatalogEntry, r as listChannelPluginCatalogEntries } from "./catalog-RiADx7MA.js";
6
6
  import { t as ensurePluginAllowlisted } from "./plugins-allowlist-sArtGE-d.js";
@@ -1,5 +1,5 @@
1
1
  import { D as getChatChannelMeta, O as listChatChannels, Q as isRecord, j as normalizeChatChannelId } from "./entry.js";
2
- import { L as normalizeProviderId } from "./auth-profiles-Cs3GPB03.js";
2
+ import { L as normalizeProviderId } from "./auth-profiles-BS_I3lKI.js";
3
3
  import { t as hasAnyWhatsAppAuth } from "./accounts-D9ITgITj.js";
4
4
  import { n as getChannelPluginCatalogEntry, r as listChannelPluginCatalogEntries } from "./catalog-DLQFKucJ.js";
5
5
  import { t as ensurePluginAllowlisted } from "./plugins-allowlist-CCpr61rO.js";
@@ -1,8 +1,8 @@
1
1
  import { t as __exportAll } from "./rolldown-runtime-Cbj13DAv.js";
2
2
  import { M as getActivePluginRegistry, o as createSubsystemLogger } from "./entry.js";
3
3
  import { c as resolveAgentWorkspaceDir, l as resolveDefaultAgentId } from "./agent-scope-D-jRCY0d.js";
4
- import { i as loadConfig } from "./config-CxnbOYs8.js";
5
- import { _ as loadSymiPlugins } from "./subagent-registry-BE6XzWR3.js";
4
+ import { i as loadConfig } from "./config-CGJ96S46.js";
5
+ import { _ as loadSymiPlugins } from "./subagent-registry-CiBbcgit.js";
6
6
 
7
7
  //#region src/cli/plugin-registry.ts
8
8
  var plugin_registry_exports = /* @__PURE__ */ __exportAll({ ensurePluginRegistryLoaded: () => ensurePluginRegistryLoaded });