@gaodefa/daocore 2026.5.51 → 2026.5.53

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 (1135) hide show
  1. package/dist/abort-DbmSukS6.js +277 -0
  2. package/dist/abort.runtime-DfTphPUe.js +2 -0
  3. package/dist/abort.runtime.js +1 -1
  4. package/dist/account-inspect-CrOeeGkg.js +173 -0
  5. package/dist/accounts-CF5wlCaC.js +119 -0
  6. package/dist/accounts-CfFTGexZ.js +107 -0
  7. package/dist/accounts-Cr9iBKG5.js +2 -0
  8. package/dist/accounts-DdAZRSd-.js +107 -0
  9. package/dist/acp/control-plane/manager.d.ts +2 -1
  10. package/dist/acp-runtime-B1CfWEsR.js +26 -0
  11. package/dist/acp-spawn-Bq8RHmXn.js +1275 -0
  12. package/dist/acp-spawn-BxyX0qDU.js +2 -0
  13. package/dist/acp-stateful-target-driver-y9Vk9ZkZ.js +89 -0
  14. package/dist/action-kill-Xr3eQUBu.js +33 -0
  15. package/dist/action-runtime-CweBFa8U.js +469 -0
  16. package/dist/action-runtime-api-DZY1J62H.js +2 -0
  17. package/dist/action-send-HdOQtFcz.js +39 -0
  18. package/dist/action-spawn-DWrPplrX.js +47 -0
  19. package/dist/actions-zZzXK7Ic.js +161 -0
  20. package/dist/actions.runtime-CK0aV6y4.js +5 -0
  21. package/dist/agent-command-DB0sppso.js +1367 -0
  22. package/dist/agent-command-DKqx29vm.d.ts +105 -0
  23. package/dist/agent-components.runtime-Drdzm2-F.js +10 -0
  24. package/dist/agent-components.runtime.js +1 -1
  25. package/dist/agent-harness-CGtBwZh6.d.ts +146 -0
  26. package/dist/agent-harness-runtime-Btzminw9.js +180 -0
  27. package/dist/agent-harness-task-runtime-DWiDnwnT.js +140 -0
  28. package/dist/agent-nenZtwAX.js +3 -0
  29. package/dist/agent-runner-execution-Cun_PNBn.js +1713 -0
  30. package/dist/agent-runner-utils-BfF--s17.js +266 -0
  31. package/dist/agent-runner.runtime-vxDguHci.js +3455 -0
  32. package/dist/agent-runner.runtime.js +1 -1
  33. package/dist/agent-runtime-C5xeqCn8.js +229 -0
  34. package/dist/agent-svdKN_62.js +2 -0
  35. package/dist/agent-via-gateway-DQa8cmBa.js +463 -0
  36. package/dist/api-BQxP3H11.js +134 -0
  37. package/dist/api-CT5SnVgO.js +2 -0
  38. package/dist/api-CtX70NwR.js +2 -0
  39. package/dist/api-CvUdFHq7.js +6 -0
  40. package/dist/api-DG9oHhm4.js +639 -0
  41. package/dist/api-DzfMdJ46.js +3 -0
  42. package/dist/apply-D8UoOoVD.js +41 -0
  43. package/dist/apply-DrHwBR1D.js +54 -0
  44. package/dist/approval-handler.runtime-CT8PWJ9W.js +130 -0
  45. package/dist/assistant-ByynDFnI.js +291 -0
  46. package/dist/attachment-normalize-DEAS_ziY.js +225 -0
  47. package/dist/attempt-execution-CQUmv8x2.js +558 -0
  48. package/dist/attempt-execution.runtime-AZYQQuAv.js +3 -0
  49. package/dist/attempt-execution.runtime.js +1 -1
  50. package/dist/attempt-execution.shared-2ZOaCHct.js +38 -0
  51. package/dist/attempt.prompt-helpers-B7ano4Xa.js +475 -0
  52. package/dist/attempt.tool-run-context-DBta4Vhq.js +2094 -0
  53. package/dist/binding-routing-DYUUioo1.js +113 -0
  54. package/dist/binding-targets-DthC_zAF.js +121 -0
  55. package/dist/bot-CHP8Hnzo.js +7894 -0
  56. package/dist/bot-deps-CLDgPV_x.js +747 -0
  57. package/dist/bot-deps-W9zVbYpY.js +2 -0
  58. package/dist/bot-message-context.runtime-B1-gGjAv.js +7 -0
  59. package/dist/bot-message-context.runtime.js +1 -1
  60. package/dist/bot-message-context.session.runtime-DUtlPLJq.js +12 -0
  61. package/dist/bot-message-context.session.runtime.js +1 -1
  62. package/dist/bot-native-commands.delivery.runtime-B2_Sb8-0.js +4 -0
  63. package/dist/bot-native-commands.delivery.runtime.js +1 -1
  64. package/dist/bot-native-commands.runtime-pplrKHcn.js +13 -0
  65. package/dist/bot-native-commands.runtime.js +1 -1
  66. package/dist/bridge-server-Du_qnIXr.js +113 -0
  67. package/dist/browser-cli-B2-Lzvd1.js +230 -0
  68. package/dist/browser-cli-actions-input-ZF6YYuIY.js +473 -0
  69. package/dist/browser-cli-actions-observe-DWLHFME1.js +81 -0
  70. package/dist/browser-cli-bTjCd41u.js +2 -0
  71. package/dist/browser-cli-debug-lzd4l2hl.js +137 -0
  72. package/dist/browser-cli-inspect-C5OnFKqx.js +104 -0
  73. package/dist/browser-cli-manage-BofwSOgU.js +443 -0
  74. package/dist/browser-cli-resize-CLs1i6Nu.js +26 -0
  75. package/dist/browser-cli-shared-6Jygx3GN.js +50 -0
  76. package/dist/browser-cli-state-BdoHl8ny.js +337 -0
  77. package/dist/browser-control-auth-DuI4vfIv.js +2 -0
  78. package/dist/browser-profiles-DkblgTjb.js +2 -0
  79. package/dist/browser-runtime-BiJKNDAE.js +384 -0
  80. package/dist/build-CrC0bToI.js +257 -0
  81. package/dist/build-info.json +2 -2
  82. package/dist/bundled/boot-md/handler.js +2 -2
  83. package/dist/bundled/session-memory/handler.js +1 -1
  84. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  85. package/dist/capability-cli-BHlS8tBg.js +1782 -0
  86. package/dist/channel-5iqpbW6B.js +867 -0
  87. package/dist/channel-BW3tbxJQ.js +1496 -0
  88. package/dist/channel-BWo67yh1.js +2126 -0
  89. package/dist/channel-BdhbzWTg.d.ts +427 -0
  90. package/dist/channel-BsDZhXfM.js +362 -0
  91. package/dist/channel-C95y8CWt.js +1556 -0
  92. package/dist/channel-CMKGn1i6.js +376 -0
  93. package/dist/channel-CMUiDCTQ.js +740 -0
  94. package/dist/channel-CNvxy1bb.js +808 -0
  95. package/dist/channel-CQzh6Wn1.js +653 -0
  96. package/dist/channel-CchnfGMs.js +481 -0
  97. package/dist/channel-CjWH9zRX.js +1777 -0
  98. package/dist/channel-CjZoZfa2.js +238 -0
  99. package/dist/channel-DKHlpUHA.js +1134 -0
  100. package/dist/channel-DfP8Sc0t.d.ts +6 -0
  101. package/dist/channel-DhZvHOpE.js +562 -0
  102. package/dist/channel-DtL_IvqV.js +508 -0
  103. package/dist/channel-GdNHqdaw.js +1249 -0
  104. package/dist/channel-ZkqVX5SL.js +955 -0
  105. package/dist/channel-actions.runtime-DYiOBQDx.js +265 -0
  106. package/dist/channel-actions.runtime.js +1 -1
  107. package/dist/channel-core-CiUQ9zxC.js +5 -0
  108. package/dist/channel-inbound-Ctv6wSJ3.js +80 -0
  109. package/dist/channel-lifecycle-DCTZ2J_8.d.ts +126 -0
  110. package/dist/channel-pairing-pKisqGWj.d.ts +58 -0
  111. package/dist/channel-plugin-runtime-CgGpeLjf.js +998 -0
  112. package/dist/channel-runtime-CPbfvG0l.js +408 -0
  113. package/dist/channel.runtime-5ebeoN8j.js +1008 -0
  114. package/dist/channel.runtime-B2Olk7LG.js +4 -0
  115. package/dist/channel.runtime-B4CnXDGx.js +652 -0
  116. package/dist/channel.runtime-BzLoF_dR.js +21009 -0
  117. package/dist/channel.runtime-CNCIcAd6.js +109 -0
  118. package/dist/channel.runtime-C_--rR-H.js +88 -0
  119. package/dist/channel.runtime-CmK77Uxp.js +254 -0
  120. package/dist/channel.runtime-DF5K3pkO.js +2528 -0
  121. package/dist/channel.runtime-iKNOt2eM.js +733 -0
  122. package/dist/channel.setup-CxvbmJQ2.js +343 -0
  123. package/dist/channel.setup-CzdDnMh7.js +1098 -0
  124. package/dist/channel.setup-Sku9g-22.js +10 -0
  125. package/dist/chat-BV-WLur6.js +2666 -0
  126. package/dist/chrome-CBr1Nlj5.js +1503 -0
  127. package/dist/cli/run-main.js +5 -5
  128. package/dist/cli-compaction-CzfXx99c.js +347 -0
  129. package/dist/cli-lsMRD5BD.js +1341 -0
  130. package/dist/cli-metadata-Cpdwx3O7.js +22 -0
  131. package/dist/cli-runner-DFh20BoX.js +2 -0
  132. package/dist/cli-runner-DjgUGfBa.js +540 -0
  133. package/dist/cli-runner.runtime-Cjd2VdQI.js +3 -0
  134. package/dist/cli-runner.runtime-uAtVtWM7.js +4 -0
  135. package/dist/cli-runner.runtime.js +1 -1
  136. package/dist/cli-startup-metadata.json +8 -8
  137. package/dist/client-D-yT6rne.js +650 -0
  138. package/dist/client-adapter-PXk4JoQR.js +897 -0
  139. package/dist/client-factory-C9zVXY0y.js +9 -0
  140. package/dist/command-auth-PrmmYdot.js +135 -0
  141. package/dist/command-handlers-DuHt0qVp.js +1609 -0
  142. package/dist/command-registry-B_v8R74Z.js +4 -0
  143. package/dist/command-registry-QvQgQxqT.js +9 -0
  144. package/dist/command-registry-core-dLVpK66o.js +110 -0
  145. package/dist/command-status.runtime-DM3aUyTe.js +90 -0
  146. package/dist/command-status.runtime.js +1 -1
  147. package/dist/commands-acp-DzUZwawt.js +74 -0
  148. package/dist/commands-compact.runtime-B6-Vv1CH.js +10 -0
  149. package/dist/commands-compact.runtime.js +1 -1
  150. package/dist/commands-handlers.runtime-CaTYrYbd.js +6154 -0
  151. package/dist/commands-handlers.runtime.js +1 -1
  152. package/dist/commands-status-NuvnoSL-.js +16 -0
  153. package/dist/commands-status-SMWi-mj9.js +3 -0
  154. package/dist/commands-status.runtime-SMWi-mj9.js +3 -0
  155. package/dist/commands-status.runtime.js +1 -1
  156. package/dist/commands-subagents-control.runtime-Cm9cxI8S.js +2 -0
  157. package/dist/commands-subagents-control.runtime-e7gSoCXL.js +3 -0
  158. package/dist/commands-subagents-control.runtime.js +1 -1
  159. package/dist/commands-system-prompt-C9pVUDbu.js +162 -0
  160. package/dist/commands-system-prompt-JP4vOPVK.js +2 -0
  161. package/dist/commands.runtime-Dg6eg0rn.js +176 -0
  162. package/dist/commands.runtime.js +1 -1
  163. package/dist/commitments/runtime.js +1 -1
  164. package/dist/compact-B2rH1SUd.js +480 -0
  165. package/dist/compact-D80suJg8.js +1141 -0
  166. package/dist/compact.runtime-D8nzDxmY.js +12 -0
  167. package/dist/compact.runtime.js +1 -1
  168. package/dist/completion-cli-DWxWi4aD.js +315 -0
  169. package/dist/computer-use-BGvZ1YTf.js +367 -0
  170. package/dist/config-DV-fdSq3.js +373 -0
  171. package/dist/config-DkblgTjb.js +2 -0
  172. package/dist/config-mutations-DsTp_oTJ.js +159 -0
  173. package/dist/context-engine-host-compat-BwIxzf7F.js +2 -0
  174. package/dist/context-engine-host-compat-CXhSw3Ub.js +288 -0
  175. package/dist/context-engine-lifecycle-CxxoOuT8.js +1274 -0
  176. package/dist/control-auth-Bb_hAwJF.js +114 -0
  177. package/dist/control-service-Dom28xYt.js +145 -0
  178. package/dist/control-ui/assets/agents-D8cdE1Eu.js +1008 -0
  179. package/dist/control-ui/assets/channel-config-extras-DHmcFd3r.js +2 -0
  180. package/dist/control-ui/assets/channels-C6IYonLY.js +367 -0
  181. package/dist/control-ui/assets/cron-BV8QhIs0.js +1013 -0
  182. package/dist/control-ui/assets/debug-CMKISsjW.js +97 -0
  183. package/dist/control-ui/assets/index-D_0M09s2.js +7406 -0
  184. package/dist/control-ui/assets/index-R-oyCoNF.css +1 -0
  185. package/dist/control-ui/assets/instances-Bjzgcv3j.js +57 -0
  186. package/dist/control-ui/assets/logs-Ca4STw-4.js +74 -0
  187. package/dist/control-ui/assets/nodes-CIYAksjC.js +436 -0
  188. package/dist/control-ui/assets/sessions-Cvu-i-9a.js +399 -0
  189. package/dist/control-ui/assets/skills-bzc2YBGL.js +314 -0
  190. package/dist/control-ui/assets/skills-shared-Dh00XbS9.js +11 -0
  191. package/dist/control-ui/index.html +2 -2
  192. package/dist/control-ui/sw.js +1 -1
  193. package/dist/conversation-binding-runtime-BXeidhrY.js +4 -0
  194. package/dist/conversation-runtime-Das7yftQ.js +31 -0
  195. package/dist/core-AxrxO8_x.js +282 -0
  196. package/dist/core-api-BL4BNR1C.js +5 -0
  197. package/dist/core-api-Bnc3J2fe.js +2 -0
  198. package/dist/crestodian/crestodian.js +1 -1
  199. package/dist/crestodian/rescue-message.js +1 -1
  200. package/dist/crestodian-CnfWHGFm.js +55 -0
  201. package/dist/daocore-tools-C1WpZGCu.js +11727 -0
  202. package/dist/delivery--FvYHWJO.js +1002 -0
  203. package/dist/dialogue-B40qxVGM.js +37 -0
  204. package/dist/dir-fetch-tool-fbOAtLfN.js +565 -0
  205. package/dist/dir-list-tool-BQ3k3hKf.js +100 -0
  206. package/dist/direct-dm-CuNsmrdk.js +64 -0
  207. package/dist/directive-handling.fast-lane-CQYYvYi_.js +68 -0
  208. package/dist/directive-handling.impl-DoLFcRUI.js +2 -0
  209. package/dist/directive-handling.impl-RsdNckR4.js +818 -0
  210. package/dist/directive-handling.model-selection-Ad4n0BBf.js +122 -0
  211. package/dist/directive-handling.persist.runtime-Dq8SQvB4.js +263 -0
  212. package/dist/directive-handling.persist.runtime.js +1 -1
  213. package/dist/dispatch-Bmw9mO6a.js +1640 -0
  214. package/dist/dispatch-acp-transcript.runtime-B7DKK79t.js +40 -0
  215. package/dist/dispatch-acp-transcript.runtime.js +1 -1
  216. package/dist/dispatch-acp.runtime-cVH58wGq.js +18 -0
  217. package/dist/dispatch-acp.runtime.js +1 -1
  218. package/dist/doctor-HffoL5ik.js +6 -0
  219. package/dist/doctor-Qg1Gj0PC.js +2 -0
  220. package/dist/doctor-config-flow-Dudp0oO_.js +1741 -0
  221. package/dist/doctor-core-checks-BTvmehLq.js +573 -0
  222. package/dist/doctor-core-checks-CcacCMGd.js +2 -0
  223. package/dist/doctor-health-DIu25ot8.js +65 -0
  224. package/dist/doctor-health-contributions-ZQUAiwng.js +696 -0
  225. package/dist/doctor-lint-C8RjoIYq.js +94 -0
  226. package/dist/doctor-state-integrity-D5NJcM0t.js +1231 -0
  227. package/dist/doctor-update-07o96Num.js +58 -0
  228. package/dist/dynamic-tools-BSIfb0RP.js +486 -0
  229. package/dist/embedded-backend-499B1IIV.js +579 -0
  230. package/dist/embedded-gateway-stub.runtime-Bqr2Z4Co.js +12 -0
  231. package/dist/embedded-gateway-stub.runtime.js +1 -1
  232. package/dist/exec-approvals-ClTqhSd7.js +149 -0
  233. package/dist/extensionAPI.js +1 -1
  234. package/dist/extensions/active-memory/index.js +1 -1
  235. package/dist/extensions/admin-http-rpc/index.js +1 -1
  236. package/dist/extensions/anthropic/doctor-contract-api.d.ts +1 -1
  237. package/dist/extensions/browser/browser-bridge.js +1 -1
  238. package/dist/extensions/browser/browser-config.js +4 -4
  239. package/dist/extensions/browser/browser-control-auth.js +2 -2
  240. package/dist/extensions/browser/browser-doctor.js +2 -2
  241. package/dist/extensions/browser/browser-maintenance.js +1 -1
  242. package/dist/extensions/browser/browser-profiles.js +2 -2
  243. package/dist/extensions/browser/browser-runtime-api.js +11 -11
  244. package/dist/extensions/browser/cli-metadata.js +1 -1
  245. package/dist/extensions/browser/index.js +1 -1
  246. package/dist/extensions/browser/plugin-registration.js +1 -1
  247. package/dist/extensions/browser/register.runtime.js +4 -4
  248. package/dist/extensions/browser/runtime-api.js +13 -13
  249. package/dist/extensions/browser/test-support.d.ts +1 -1
  250. package/dist/extensions/canvas/index.js +1 -1
  251. package/dist/extensions/clickclack/api.js +2 -2
  252. package/dist/extensions/clickclack/channel-plugin-api.js +1 -1
  253. package/dist/extensions/clickclack/runtime-api.js +2 -2
  254. package/dist/extensions/device-pair/api.js +1 -1
  255. package/dist/extensions/device-pair/pair-command-approve.js +1 -1
  256. package/dist/extensions/file-transfer/index.js +4 -4
  257. package/dist/extensions/google/doctor-contract-api.d.ts +1 -1
  258. package/dist/extensions/image-generation-core/api.d.ts +1 -1
  259. package/dist/extensions/imessage/api.js +2 -2
  260. package/dist/extensions/imessage/channel-plugin-api.js +1 -1
  261. package/dist/extensions/imessage/message-tool-api.d.ts +1 -1
  262. package/dist/extensions/imessage/runtime-api.d.ts +1 -1
  263. package/dist/extensions/imessage/runtime-api.js +3 -3
  264. package/dist/extensions/irc/api.js +2 -2
  265. package/dist/extensions/irc/channel-plugin-api.js +1 -1
  266. package/dist/extensions/llm-task/index.js +1 -1
  267. package/dist/extensions/mattermost/api.js +1 -1
  268. package/dist/extensions/mattermost/channel-plugin-api.js +1 -1
  269. package/dist/extensions/mattermost/channel-plugin-runtime.js +1 -1
  270. package/dist/extensions/mattermost/policy-api.js +1 -1
  271. package/dist/extensions/mattermost/runtime-api.d.ts +7 -7
  272. package/dist/extensions/mattermost/runtime-api.js +2 -2
  273. package/dist/extensions/mattermost/slash-route-api.js +1 -1
  274. package/dist/extensions/memory-core/cli-metadata.js +1 -1
  275. package/dist/extensions/migrate-claude/apply.js +1 -1
  276. package/dist/extensions/migrate-claude/index.js +1 -1
  277. package/dist/extensions/migrate-claude/plan.js +1 -1
  278. package/dist/extensions/migrate-claude/provider.js +1 -1
  279. package/dist/extensions/migrate-claude/targets.js +1 -1
  280. package/dist/extensions/migrate-hermes/apply.js +1 -1
  281. package/dist/extensions/migrate-hermes/index.js +1 -1
  282. package/dist/extensions/migrate-hermes/model.js +1 -1
  283. package/dist/extensions/migrate-hermes/plan.js +1 -1
  284. package/dist/extensions/migrate-hermes/provider.js +1 -1
  285. package/dist/extensions/migrate-hermes/secrets.js +1 -1
  286. package/dist/extensions/migrate-hermes/targets.js +1 -1
  287. package/dist/extensions/policy/api.js +1 -1
  288. package/dist/extensions/policy/index.js +2 -2
  289. package/dist/extensions/signal/api.d.ts +1 -1
  290. package/dist/extensions/signal/api.js +6 -6
  291. package/dist/extensions/signal/channel-plugin-api.js +1 -1
  292. package/dist/extensions/signal/reaction-runtime-api.js +1 -1
  293. package/dist/extensions/signal/runtime-api.d.ts +2 -2
  294. package/dist/extensions/signal/runtime-api.js +7 -7
  295. package/dist/extensions/skill-workshop/api.js +1 -1
  296. package/dist/extensions/skill-workshop/index.js +2 -2
  297. package/dist/extensions/telegram/account-inspect-api.js +1 -1
  298. package/dist/extensions/telegram/api.d.ts +1 -1
  299. package/dist/extensions/telegram/api.js +11 -11
  300. package/dist/extensions/telegram/channel-plugin-api.js +2 -2
  301. package/dist/extensions/telegram/contract-api.js +3 -3
  302. package/dist/extensions/telegram/runtime-api.js +7 -7
  303. package/dist/extensions/telegram/security-audit-contract-api.js +1 -1
  304. package/dist/extensions/telegram/setup-plugin-api.js +1 -1
  305. package/dist/extensions/telegram/test-api.js +2 -2
  306. package/dist/extensions/video-generation-core/api.d.ts +1 -1
  307. package/dist/extensions/webhooks/api.js +1 -1
  308. package/dist/extensions/webhooks/index.js +1 -1
  309. package/dist/extensions/webhooks/runtime-api.d.ts +2 -2
  310. package/dist/extensions/xai/index.js +4 -4
  311. package/dist/extensions/xai/realtime-transcription-provider.js +1 -1
  312. package/dist/extensions/xai/speech-provider.js +1 -1
  313. package/dist/extensions/xai/test-api.js +1 -1
  314. package/dist/extensions/xai/tts.js +1 -1
  315. package/dist/extensions/xai/web-search.js +1 -1
  316. package/dist/extensions/xai/xai-oauth.js +1 -1
  317. package/dist/file-fetch-tool-CJu8umi9.js +124 -0
  318. package/dist/file-write-tool-Dz49CI0K.js +127 -0
  319. package/dist/format-DBhooCE7.js +1145 -0
  320. package/dist/gateway-cli-D21vxek0.js +435 -0
  321. package/dist/gateway-method-runtime-qsRZHdfx.js +21 -0
  322. package/dist/get-reply-D140C4TM.js +4689 -0
  323. package/dist/get-reply-from-config.runtime-CaM7M0Zp.js +2 -0
  324. package/dist/get-reply-from-config.runtime.js +1 -1
  325. package/dist/graph-users-cBY7anTM.js +1419 -0
  326. package/dist/group-access-CZOQhsjs.js +112 -0
  327. package/dist/group-keys-B_lbVBmI.d.ts +17 -0
  328. package/dist/handle-action.guild-admin-DjuZqjM2.js +288 -0
  329. package/dist/harness-XL58LNpX.js +61 -0
  330. package/dist/health-CFPXXpFW.js +4 -0
  331. package/dist/heartbeat-runner-D_o-itnk.js +5 -0
  332. package/dist/heartbeat-runner.runtime-CPVGa3Gd.js +4 -0
  333. package/dist/heartbeat-runner.runtime.js +1 -1
  334. package/dist/hook-runtime-UU80d5qW.d.ts +108 -0
  335. package/dist/hooks-Bx3n6o-5.js +534 -0
  336. package/dist/inbound-direct-dm-runtime-6nIJyODo.js +2 -0
  337. package/dist/inbound-reply-dispatch-CoeXQvL6.js +148 -0
  338. package/dist/index.d.ts +1 -1
  339. package/dist/index.js +1 -1
  340. package/dist/init-C8Yc8LlO.js +59 -0
  341. package/dist/inline-buttons-BMPhhfsN.js +40 -0
  342. package/dist/internal-events-BS1EMi0C.js +90 -0
  343. package/dist/isolated-agent-Ct_AYfLb.js +2 -0
  344. package/dist/isolated-agent-DxVGoLjs.js +1118 -0
  345. package/dist/lifecycle-CGcqxM3V.js +571 -0
  346. package/dist/list.probe-R_AqbwD1.js +449 -0
  347. package/dist/list.status-command-DcaLppGJ.js +789 -0
  348. package/dist/llm-slug-generator-Bz1MaPt1.js +78 -0
  349. package/dist/llm-slug-generator.js +1 -1
  350. package/dist/local-dispatch.runtime-DnXAlwr7.js +9 -0
  351. package/dist/local-dispatch.runtime.js +1 -1
  352. package/dist/manager-D058VQAp.d.ts +10 -0
  353. package/dist/manager.core-DKeUsAcV.d.ts +198 -0
  354. package/dist/manager.runtime-1A0jFsbF.js +2714 -0
  355. package/dist/manager.runtime.js +1 -1
  356. package/dist/markdown-to-line-Gq4y1nH-.js +811 -0
  357. package/dist/mcp-http-BMgo3eu6.js +2 -0
  358. package/dist/mcp-http-BdgsyrHJ.js +555 -0
  359. package/dist/media-understanding-provider-CYrAwQ2G.js +339 -0
  360. package/dist/message-actions-DoFxM22K.js +145 -0
  361. package/dist/message-handler-CEvRtI9d.js +384 -0
  362. package/dist/message-handler-CJclaiC-.js +1715 -0
  363. package/dist/message-handler.preflight-DDVS50X3.js +1125 -0
  364. package/dist/message-handler.process-BuFXf8os.js +1484 -0
  365. package/dist/model-BqQrUk9a.js +74 -0
  366. package/dist/model-selection-2Lm1qMLE.js +272 -0
  367. package/dist/models-BjMdWXf2.js +104 -0
  368. package/dist/models-cli-RRK90p8k.js +256 -0
  369. package/dist/models-wWhwx_am.js +2 -0
  370. package/dist/monitor-C7VAs-uK.js +834 -0
  371. package/dist/monitor-CezSJDeG.js +60 -0
  372. package/dist/monitor-Cnzchc9n.js +2788 -0
  373. package/dist/monitor-Dcvw55ky.js +4377 -0
  374. package/dist/monitor-DuxFMl7d.js +715 -0
  375. package/dist/monitor-DxrfxRZL.js +2 -0
  376. package/dist/monitor-auth-UPQgTP9Y.js +179 -0
  377. package/dist/monitor-fYdQKsGp.js +1370 -0
  378. package/dist/monitor-polling.runtime-Db4NoLLg.js +883 -0
  379. package/dist/monitor-polling.runtime.js +1 -1
  380. package/dist/monitor-wcLtLTfx.js +1657 -0
  381. package/dist/monitor-webhook.runtime-DAr7kRbV.js +387 -0
  382. package/dist/monitor-webhook.runtime.js +1 -1
  383. package/dist/monitor.account-C1mUBkKA.js +5233 -0
  384. package/dist/monitor.runtime-Bqj8vHGY.js +2 -0
  385. package/dist/monitor.runtime.js +1 -1
  386. package/dist/monitor.webhook-Ir3T5B1s.js +180 -0
  387. package/dist/node-cli-sessions-MBQKJyrs.js +1228 -0
  388. package/dist/openai-http-9jmQ2o9Z.js +824 -0
  389. package/dist/openresponses-http-C3-s16Dp.js +1173 -0
  390. package/dist/operations-C1hhf_yC.js +805 -0
  391. package/dist/outbound-adapter-C5zBbuVO.js +543 -0
  392. package/dist/outbound-session-route-Bq_utu59.js +45 -0
  393. package/dist/outbound.runtime-QHoe8EWX.js +2 -0
  394. package/dist/outbound.runtime.js +1 -1
  395. package/dist/pairing-store-C-WQTUHq.d.ts +87 -0
  396. package/dist/pi-embedded-6xH25qP-.js +4 -0
  397. package/dist/pi-embedded-CkcV64LR.js +3796 -0
  398. package/dist/pi-embedded.runtime-CKpyReN5.js +4 -0
  399. package/dist/pi-embedded.runtime.js +1 -1
  400. package/dist/pi-tools-BbGodehg.js +2413 -0
  401. package/dist/plan-B_EcRdNP.js +112 -0
  402. package/dist/plan-DmMZJkHt.js +81 -0
  403. package/dist/plugin-CjfnnqXb.js +12396 -0
  404. package/dist/plugin-app-cache-key-Dak7S3ax.js +46 -0
  405. package/dist/plugin-enabled-B9wCs568.js +233 -0
  406. package/dist/plugin-registration-B3AVf0Xj.js +88 -0
  407. package/dist/plugin-sdk/.boundary-entry-shims.stamp +1 -1
  408. package/dist/plugin-sdk/acp-runtime-backend.js +1 -1
  409. package/dist/plugin-sdk/acp-runtime.js +2 -2
  410. package/dist/plugin-sdk/agent-harness-runtime.js +6 -6
  411. package/dist/plugin-sdk/agent-harness-task-runtime.js +1 -1
  412. package/dist/plugin-sdk/agent-harness.js +7 -7
  413. package/dist/plugin-sdk/agent-runtime.js +2 -2
  414. package/dist/plugin-sdk/channel-core.js +2 -2
  415. package/dist/plugin-sdk/channel-inbound.js +2 -2
  416. package/dist/plugin-sdk/channel-test-helpers.js +1 -1
  417. package/dist/plugin-sdk/command-auth.js +1 -1
  418. package/dist/plugin-sdk/command-status-runtime.js +1 -1
  419. package/dist/plugin-sdk/compat.js +1 -1
  420. package/dist/plugin-sdk/conversation-binding-runtime.js +2 -2
  421. package/dist/plugin-sdk/conversation-runtime.js +3 -3
  422. package/dist/plugin-sdk/core.js +2 -2
  423. package/dist/plugin-sdk/direct-dm.js +1 -1
  424. package/dist/plugin-sdk/gateway-method-runtime.js +1 -1
  425. package/dist/plugin-sdk/health.js +2 -2
  426. package/dist/plugin-sdk/inbound-reply-dispatch.js +1 -1
  427. package/dist/plugin-sdk/index.js +1 -1
  428. package/dist/plugin-sdk/mattermost.js +1 -1
  429. package/dist/plugin-sdk/plugin-test-contracts.js +2 -2
  430. package/dist/plugin-sdk/provider-test-contracts.js +4 -4
  431. package/dist/plugin-sdk/reply-runtime.js +4 -4
  432. package/dist/plugin-sdk/testing.js +2 -2
  433. package/dist/plugin-sdk/zalouser.js +1 -1
  434. package/dist/plugin-service-C2toP50L.js +1229 -0
  435. package/dist/plugins/runtime/index.js +4 -4
  436. package/dist/policy-B5jHUD04.js +138 -0
  437. package/dist/policy-C7_EFtGD.js +680 -0
  438. package/dist/postinstall-inventory.json +11606 -0
  439. package/dist/prepare.runtime-C41yGgw-.js +732 -0
  440. package/dist/prepare.runtime.js +1 -1
  441. package/dist/preview-warnings-rfGY8dVy.js +392 -0
  442. package/dist/probe-B0eSVoSm.js +682 -0
  443. package/dist/probe-CqAGxL6l.js +2 -0
  444. package/dist/probe-DFyoiqiI.js +2204 -0
  445. package/dist/probe-hR0HWnET.js +47 -0
  446. package/dist/program-CD73-5Xj.js +131 -0
  447. package/dist/provider-B0ujadL5.js +32 -0
  448. package/dist/provider-BxR_JJXW.js +152 -0
  449. package/dist/provider-C9mKa8qP.js +32 -0
  450. package/dist/provider-DbGPdInL.js +8735 -0
  451. package/dist/provider-dispatcher-CGPKPaP5.js +22 -0
  452. package/dist/provider-dispatcher.runtime.js +1 -1
  453. package/dist/provider-session.runtime-DKkydJWv.js +9 -0
  454. package/dist/provider-session.runtime.js +1 -1
  455. package/dist/provider.runtime-ChrWUTdG.js +2 -0
  456. package/dist/provider.runtime.js +1 -1
  457. package/dist/public-surface-loader-CMOWVmyY.js +114 -0
  458. package/dist/pw-ai-mygsAPX7.js +3029 -0
  459. package/dist/pw-role-snapshot-7_IMuYRR.js +333 -0
  460. package/dist/reaction-level-DFUu127f.js +19 -0
  461. package/dist/reaction-runtime-api-6LQnr6q_.js +116 -0
  462. package/dist/realtime-transcription-provider-LrzigbIT.js +205 -0
  463. package/dist/register-B9TeJvXU.js +2178 -0
  464. package/dist/register.agent-o9BDHbH2.js +156 -0
  465. package/dist/register.crestodian-BOUP_Pon.js +24 -0
  466. package/dist/register.maintenance-BC83-YdR.js +83 -0
  467. package/dist/register.runtime-DSHYrjtd.js +54 -0
  468. package/dist/register.subclis-BS5Lj5wU.js +3 -0
  469. package/dist/register.subclis-QQq9COp0.js +31 -0
  470. package/dist/register.subclis-core-DnNechJo.js +273 -0
  471. package/dist/repair-sequencing-CqjW4_hd.js +640 -0
  472. package/dist/reply-delivery-KRwW1tqL.js +196 -0
  473. package/dist/reply-runtime-DuaOZ9MH.d.ts +34 -0
  474. package/dist/reply-runtime-SSrAwVeQ.js +11 -0
  475. package/dist/reply.runtime-CaM7M0Zp.js +2 -0
  476. package/dist/reply.runtime.js +1 -1
  477. package/dist/request-CatWtIoq.js +54 -0
  478. package/dist/resolve-allowlist-Dxe9wc_Y.js +220 -0
  479. package/dist/result-fallback-classifier-B3kvqc2o.js +79 -0
  480. package/dist/route-BPWKlRDB.js +469 -0
  481. package/dist/route-resolution-BhkvdIUP.js +274 -0
  482. package/dist/routes-BOmtNSeT.js +2 -0
  483. package/dist/routes-Cr9bRW8t.js +3602 -0
  484. package/dist/run-attempt-DWBeHRdc.js +7704 -0
  485. package/dist/run-command-DNNFNkbv.js +23 -0
  486. package/dist/run-command-Kp7LWkQv.js +2 -0
  487. package/dist/run-embedded.runtime-BxV8m38U.js +4 -0
  488. package/dist/run-embedded.runtime.js +1 -1
  489. package/dist/run-execution-cli.runtime-B9I1oAEO.js +4 -0
  490. package/dist/run-execution-cli.runtime.js +1 -1
  491. package/dist/run-executor.runtime.js +1 -1
  492. package/dist/run-subagent-registry.runtime-BIsbEmUD.js +2 -0
  493. package/dist/run-subagent-registry.runtime.js +1 -1
  494. package/dist/run-vAv9-st8.js +1162 -0
  495. package/dist/runtime-3PDZU_1b.d.ts +17 -0
  496. package/dist/runtime-BXJM8M8F.js +1287 -0
  497. package/dist/runtime-BodO4UZT.js +438 -0
  498. package/dist/runtime-C_5j10Cp.js +6179 -0
  499. package/dist/runtime-api-9CEihqK3.d.ts +3151 -0
  500. package/dist/runtime-api-BbNLHCZ5.js +24 -0
  501. package/dist/runtime-api-HUquGiJa.js +4 -0
  502. package/dist/runtime-api-I6ur4A1S.js +17 -0
  503. package/dist/runtime-api-MQL0v6n2.js +13 -0
  504. package/dist/runtime-api-a340pYdX.js +13 -0
  505. package/dist/runtime-api-g_pGO9f3.js +21 -0
  506. package/dist/runtime-api-hLSYbpGH.js +3 -0
  507. package/dist/runtime-api.actions-Blt2bAHw.d.ts +23 -0
  508. package/dist/runtime-api.actions-CawQ9WKM.js +3 -0
  509. package/dist/runtime-api.monitor-DN3P4USq.js +6 -0
  510. package/dist/runtime-api.send-BIA6QfVI.js +4 -0
  511. package/dist/runtime-api.send-BygcWA7R.d.ts +38 -0
  512. package/dist/runtime-api.threads-DYnc3Jvu.js +2 -0
  513. package/dist/runtime-channel-CYlRNrxR.js +150 -0
  514. package/dist/runtime-channel-Ci0dC0Tq.js +2 -0
  515. package/dist/runtime-doctor-DVYwKwIT.d.ts +47 -0
  516. package/dist/runtime-embedded-pi.runtime-Wc_lZOzO.js +2 -0
  517. package/dist/runtime-embedded-pi.runtime.js +1 -1
  518. package/dist/sanitize-outbound-BFrYI8F4.js +127 -0
  519. package/dist/sdk-setup-tools-DLjnnh3Y.js +8 -0
  520. package/dist/secrets-DibHCqDz.js +113 -0
  521. package/dist/security-audit-CyMhUYN9.js +122 -0
  522. package/dist/security-audit-DAk0I2g8.js +118 -0
  523. package/dist/security-audit.runtime-DtdxZcEG.js +2 -0
  524. package/dist/security-audit.runtime.js +1 -1
  525. package/dist/selection-BJ2yQ0yh.js +16157 -0
  526. package/dist/selection-CJ3YNIjG.js +3 -0
  527. package/dist/send-Ar9e_pA3.js +1631 -0
  528. package/dist/send-BETlETJ5.d.ts +231 -0
  529. package/dist/send-BN-3u18j.js +2 -0
  530. package/dist/send-BYlEXkEO.js +143 -0
  531. package/dist/send-BusufuyP.js +192 -0
  532. package/dist/send-CpcmWYrM.d.ts +104 -0
  533. package/dist/send.components-C3FzEyYz.js +500 -0
  534. package/dist/send.components-CMi7rcIs.js +2 -0
  535. package/dist/send.runtime-D-nw3p-S.js +2 -0
  536. package/dist/send.runtime.js +1 -1
  537. package/dist/send.types-D_3tsfSL.d.ts +159 -0
  538. package/dist/server-CJVI2gjZ.js +24 -0
  539. package/dist/server-DZl7k4VX.js +73 -0
  540. package/dist/server-close.runtime.js +1 -1
  541. package/dist/server-context-BAAz3W-8.js +2 -0
  542. package/dist/server-context-BLrLchWj.js +955 -0
  543. package/dist/server-cron-CiyrI-WY.js +2 -0
  544. package/dist/server-cron-CzhteL8F.js +2989 -0
  545. package/dist/server-methods-DQ0gaIXu.js +16494 -0
  546. package/dist/server-node-events-D1TywtBI.js +596 -0
  547. package/dist/server-plugin-bootstrap-ByEZkPkc.js +70 -0
  548. package/dist/server-plugins-BVVgDSdq.d.ts +1 -0
  549. package/dist/server-plugins-CEZ-W7dG.js +432 -0
  550. package/dist/server-reload-handlers-DDXJwZWE.js +714 -0
  551. package/dist/server-restart-sentinel-C9l1iG1h.js +747 -0
  552. package/dist/server-restart-sentinel-CyweyjEa.js +2 -0
  553. package/dist/server-runtime-services-BQ08Hyco.js +2 -0
  554. package/dist/server-runtime-services-BjKoAkjM.js +267 -0
  555. package/dist/server-startup-plugins-C_Y62xZe.js +113 -0
  556. package/dist/server-startup-post-attach-DCAmn6Ct.js +716 -0
  557. package/dist/server-ws-runtime-CvN63X_w.js +349 -0
  558. package/dist/server.impl-yHI7jtXF.js +2586 -0
  559. package/dist/service-mHxeSPC2.js +1446 -0
  560. package/dist/session-binding-DtmTypDj.js +2 -0
  561. package/dist/session-binding-xtRKSQOW.js +219 -0
  562. package/dist/session-kill-http-GnTgzcvZ.js +121 -0
  563. package/dist/session-reset-service-Bw6li9Te.js +625 -0
  564. package/dist/session-route-D-PISLLo.js +93 -0
  565. package/dist/session-status.runtime-jiGvxIDK.js +2 -0
  566. package/dist/session-status.runtime.js +1 -1
  567. package/dist/session-subagent-reactivation.runtime-B9QimjvS.js +2 -0
  568. package/dist/session-subagent-reactivation.runtime.js +1 -1
  569. package/dist/session-tab-registry-BoqXuTYc.js +521 -0
  570. package/dist/sessions-history-http-CG934aaV.js +430 -0
  571. package/dist/sessions.runtime-Cl91aZ2M.js +2 -0
  572. package/dist/sessions.runtime.js +1 -1
  573. package/dist/setup-api-DAqXqbGP.js +29 -0
  574. package/dist/setup-core-Czt7XqlN.js +174 -0
  575. package/dist/setup-surface-CHETBocT.js +405 -0
  576. package/dist/setup-surface-CVtEDUic.js +320 -0
  577. package/dist/setup-surface-YW9INYKN.js +288 -0
  578. package/dist/setup-surface-utUyMdYz.js +221 -0
  579. package/dist/shared-DwZ1ZQM4.js +121 -0
  580. package/dist/shared-client-B2kMpTHH.js +2 -0
  581. package/dist/shared-client-DHJbz0yn.js +629 -0
  582. package/dist/side-question-Dlr5pcZK.js +683 -0
  583. package/dist/skill-tool-dispatch.runtime-CbDumhVh.js +143 -0
  584. package/dist/skill-tool-dispatch.runtime.js +1 -1
  585. package/dist/slash-state-BxzZ0Rmv.js +2166 -0
  586. package/dist/speech-provider-INk_7d-9.js +184 -0
  587. package/dist/src-DAMtNlRl.js +4256 -0
  588. package/dist/startup-context-DhSjA04E.js +313 -0
  589. package/dist/status-subagents.runtime-UViaj6fy.js +18 -0
  590. package/dist/status-subagents.runtime.js +1 -1
  591. package/dist/status-text-D4yQvJnW.js +296 -0
  592. package/dist/sticker-cache-CpE2UF0o.js +206 -0
  593. package/dist/sticker-vision.runtime-C5lk740o.js +17 -0
  594. package/dist/sticker-vision.runtime.js +1 -1
  595. package/dist/subagent-announce-DDensDxS.js +354 -0
  596. package/dist/subagent-announce-delivery-16skgjOt.js +958 -0
  597. package/dist/subagent-control-C2SGCamc.js +508 -0
  598. package/dist/subagent-hooks-BqabvLsv.js +2 -0
  599. package/dist/subagent-hooks-CGeDwTHC.js +2 -0
  600. package/dist/subagent-hooks-CR0M3L4o.js +146 -0
  601. package/dist/subagent-hooks-Dw9C-nUM.js +2 -0
  602. package/dist/subagent-hooks-api-B03j55PK.js +22 -0
  603. package/dist/subagent-hooks-api-B2i15coF.js +23 -0
  604. package/dist/subagent-hooks-api-BcopR7NZ.js +23 -0
  605. package/dist/subagent-hooks-eOUaLnxx.js +116 -0
  606. package/dist/subagent-hooks-l4-8TBr2.js +230 -0
  607. package/dist/subagent-orphan-recovery-CytpmJnf.js +352 -0
  608. package/dist/subagent-registry-BVVgDSdq.d.ts +1 -0
  609. package/dist/subagent-registry-DTDYUst1.js +2351 -0
  610. package/dist/subagent-registry-kGjRY7OP.js +3 -0
  611. package/dist/subagent-registry-read-BVVgDSdq.d.ts +1 -0
  612. package/dist/subagent-registry.runtime.js +1 -1
  613. package/dist/subagent-session-cleanup-C7MqSx3u.js +525 -0
  614. package/dist/subagent-spawn-DuLVHzht.js +1164 -0
  615. package/dist/target-id-BqKER5JR.js +107 -0
  616. package/dist/targets-DYNDWy1s.js +44 -0
  617. package/dist/targets-DuRWAuVM.js +19 -0
  618. package/dist/targets-aaR2Mlk_.js +19 -0
  619. package/dist/task-registry-control.runtime.d.ts +1 -1
  620. package/dist/task-registry-control.runtime.js +1 -1
  621. package/dist/telegram/token.js +1 -1
  622. package/dist/test-fixtures-xgg7UsEw.d.ts +27 -0
  623. package/dist/test-support-BVVgDSdq.d.ts +1 -0
  624. package/dist/testing-7ayMtB6I.js +267 -0
  625. package/dist/thread-bindings-BzpAXUwZ.js +232 -0
  626. package/dist/thread-bindings-Cu4J90KY.js +8 -0
  627. package/dist/thread-bindings-D5o9c3aE.js +228 -0
  628. package/dist/thread-bindings-DMy2kJ74.js +571 -0
  629. package/dist/thread-bindings.discord-api-BDj-jkBV.js +187 -0
  630. package/dist/thread-bindings.manager-C5jC_3Mo.js +2 -0
  631. package/dist/thread-bindings.manager-CLK7FYoE.js +536 -0
  632. package/dist/thread-lifecycle-DYeO0OTi.js +1614 -0
  633. package/dist/token-Ccki3ia9.js +134 -0
  634. package/dist/tool-BqIYC7Fz.js +139 -0
  635. package/dist/tool-actions.runtime-Cjbhroli.js +534 -0
  636. package/dist/tool-actions.runtime.js +1 -1
  637. package/dist/tool-resolution-D4klFB4B.js +149 -0
  638. package/dist/tools-effective-inventory-YuOuPKR8.js +204 -0
  639. package/dist/tools-invoke-http-BmQFkxSN.js +67 -0
  640. package/dist/tools-invoke-shared-DD4l34hg.js +200 -0
  641. package/dist/tts-BAQZtO6A.js +66 -0
  642. package/dist/tui-B-CC1PjA.js +2 -0
  643. package/dist/tui-backend-DLm_nQL8.js +256 -0
  644. package/dist/tui-cli-BfCs3qwc.js +37 -0
  645. package/dist/tui-qi8Vakes.js +4709 -0
  646. package/dist/typed-cases-cPb0tZig.d.ts +68 -0
  647. package/dist/update-cli-BP32xvfl.js +3664 -0
  648. package/dist/update-runner-DnbwY3OV.js +2390 -0
  649. package/dist/vision-tools-De-gGPAw.js +1409 -0
  650. package/dist/web-search-DJMus2yt.js +62 -0
  651. package/dist/web-search-provider.runtime-6Md25pj8.js +2 -0
  652. package/dist/web-search-provider.runtime-CBUbt7xF.js +328 -0
  653. package/dist/web-search-provider.runtime.js +1 -1
  654. package/dist/webhook-targets-Bixk4LO_.d.ts +99 -0
  655. package/dist/xai-oauth-Cud_8Og7.js +479 -0
  656. package/dist/xai-user-agent-dCQuZI6k.js +32 -0
  657. package/package.json +1 -1
  658. package/dist/abort-fu5ot-XT.js +0 -277
  659. package/dist/abort.runtime-D5daoBjn.js +0 -2
  660. package/dist/account-inspect-BzG5-Rgz.js +0 -173
  661. package/dist/accounts-CPcG2JIz.js +0 -107
  662. package/dist/accounts-CiDgcaPY.js +0 -2
  663. package/dist/accounts-DcI0wEyL.js +0 -107
  664. package/dist/accounts-xBYbyTsZ.js +0 -119
  665. package/dist/acp-runtime-DpVkymzf.js +0 -26
  666. package/dist/acp-spawn-CbNHSZr-.js +0 -1275
  667. package/dist/acp-spawn-DFG0HgXi.js +0 -2
  668. package/dist/acp-stateful-target-driver-pz6XosZ9.js +0 -89
  669. package/dist/action-kill-DJuPSfgy.js +0 -33
  670. package/dist/action-runtime-DxnMH2dB.js +0 -469
  671. package/dist/action-runtime-api-Dvo3Gbll.js +0 -2
  672. package/dist/action-send-WtfSYfhf.js +0 -39
  673. package/dist/action-spawn-CA4-_H9p.js +0 -47
  674. package/dist/actions-BQ2B4Vhj.js +0 -161
  675. package/dist/actions.runtime-Bw0OZtGG.js +0 -5
  676. package/dist/agent-CsPtASj4.js +0 -2
  677. package/dist/agent-command-D5KxwCVS.d.ts +0 -141
  678. package/dist/agent-command-DeA1YV0L.js +0 -1367
  679. package/dist/agent-components.runtime-CP2KCzTj.js +0 -10
  680. package/dist/agent-harness-CEPgjZ3p.d.ts +0 -146
  681. package/dist/agent-harness-runtime-hAssTrVq.js +0 -180
  682. package/dist/agent-harness-task-runtime-VSFzRIbH.js +0 -140
  683. package/dist/agent-rg2WmmbX.js +0 -3
  684. package/dist/agent-runner-execution-lRuwJobi.js +0 -1713
  685. package/dist/agent-runner-utils-Bluglnku.js +0 -266
  686. package/dist/agent-runner.runtime-B709koec.js +0 -3455
  687. package/dist/agent-runtime-DKr0TX79.js +0 -229
  688. package/dist/agent-via-gateway-J8tTS5o6.js +0 -463
  689. package/dist/api-BVSGXSkS.js +0 -3
  690. package/dist/api-C7LbY8d2.js +0 -6
  691. package/dist/api-ClLB89eP.js +0 -2
  692. package/dist/api-D7kpdmvQ.js +0 -2
  693. package/dist/api-DJaf27mk.js +0 -639
  694. package/dist/api-XpFyLrKp.js +0 -134
  695. package/dist/apply-CHHI0r0H.js +0 -41
  696. package/dist/apply-DoQ4g3Kr.js +0 -54
  697. package/dist/approval-handler.runtime-Jbt7zH9f.js +0 -130
  698. package/dist/assistant-DQw33Vzx.js +0 -291
  699. package/dist/attachment-normalize-CrbLuYsp.js +0 -225
  700. package/dist/attempt-execution-DkgSHSVj.js +0 -558
  701. package/dist/attempt-execution.runtime-DCcD7P4g.js +0 -3
  702. package/dist/attempt-execution.shared-Cok8CE9p.js +0 -38
  703. package/dist/attempt.prompt-helpers-Kok600qT.js +0 -475
  704. package/dist/attempt.tool-run-context-C5nkRM5Y.js +0 -2094
  705. package/dist/binding-routing-BILfy0c8.js +0 -113
  706. package/dist/binding-targets-BrYDo8Jx.js +0 -121
  707. package/dist/bot-CxJsNrtp.js +0 -7894
  708. package/dist/bot-deps-BWdw7DXt.js +0 -2
  709. package/dist/bot-deps-BbL_ePix.js +0 -747
  710. package/dist/bot-message-context.runtime-qkq-RzJY.js +0 -7
  711. package/dist/bot-message-context.session.runtime-CxuxYsNb.js +0 -12
  712. package/dist/bot-native-commands.delivery.runtime-BOjc08fe.js +0 -4
  713. package/dist/bot-native-commands.runtime-LtWQYEai.js +0 -13
  714. package/dist/bridge-server-BvrlsnvW.js +0 -113
  715. package/dist/browser-cli-BmH-wDEt.js +0 -230
  716. package/dist/browser-cli-D7JUe5WT.js +0 -2
  717. package/dist/browser-cli-actions-input-BtCjZh2W.js +0 -473
  718. package/dist/browser-cli-actions-observe-CKCy--u8.js +0 -81
  719. package/dist/browser-cli-debug-D7KF3hoB.js +0 -137
  720. package/dist/browser-cli-inspect-B5_Q_bKp.js +0 -104
  721. package/dist/browser-cli-manage-BNRyXUfb.js +0 -443
  722. package/dist/browser-cli-resize-BR9dybJM.js +0 -26
  723. package/dist/browser-cli-shared-ZfP-ZP1r.js +0 -50
  724. package/dist/browser-cli-state-BJRQ87Hp.js +0 -337
  725. package/dist/browser-control-auth-C1ZlS07R.js +0 -2
  726. package/dist/browser-profiles-BLgaJJYW.js +0 -2
  727. package/dist/browser-runtime-CX-EDgFi.js +0 -384
  728. package/dist/build-DOEtxYaU.js +0 -257
  729. package/dist/capability-cli-Mj0McddT.js +0 -1782
  730. package/dist/channel-BDvizmrp.js +0 -1556
  731. package/dist/channel-C749d8mG.js +0 -376
  732. package/dist/channel-CWP6h4W5.js +0 -1134
  733. package/dist/channel-CgzMA_Q0.js +0 -2126
  734. package/dist/channel-Chx_WUyI.js +0 -867
  735. package/dist/channel-Ctnzf_tM.js +0 -238
  736. package/dist/channel-CusFbCv9.js +0 -653
  737. package/dist/channel-D5jjabnb.js +0 -1249
  738. package/dist/channel-DF-fw8lK.js +0 -1496
  739. package/dist/channel-DKAG-w5b.js +0 -481
  740. package/dist/channel-DSbpV7ax.js +0 -808
  741. package/dist/channel-DiN2VJEK.js +0 -955
  742. package/dist/channel-DvN94bvt.js +0 -740
  743. package/dist/channel-DxtVMwdk.js +0 -508
  744. package/dist/channel-GubQ1f0C.js +0 -362
  745. package/dist/channel-JqEqZ04S.d.ts +0 -6
  746. package/dist/channel-MXOd30fz.d.ts +0 -427
  747. package/dist/channel-actions.runtime-DEb9ZniG.js +0 -265
  748. package/dist/channel-core-Dr6fp5Ub.js +0 -5
  749. package/dist/channel-inbound-FG-Mc5xc.js +0 -80
  750. package/dist/channel-lifecycle-DCl2GbRW.d.ts +0 -125
  751. package/dist/channel-pairing-BRqfYy30.d.ts +0 -58
  752. package/dist/channel-plugin-runtime-hiqeg-_c.js +0 -998
  753. package/dist/channel-rej8M5lJ.js +0 -1777
  754. package/dist/channel-runtime-DJp4CruI.js +0 -408
  755. package/dist/channel-z0v-MMYk.js +0 -562
  756. package/dist/channel.runtime-1o_vRC84.js +0 -109
  757. package/dist/channel.runtime-BXrIcht7.js +0 -254
  758. package/dist/channel.runtime-C9opTci8.js +0 -2528
  759. package/dist/channel.runtime-CBvyS9OE.js +0 -1008
  760. package/dist/channel.runtime-CSwcAfTq.js +0 -88
  761. package/dist/channel.runtime-DKFrmmAg.js +0 -652
  762. package/dist/channel.runtime-DTBcVFL7.js +0 -733
  763. package/dist/channel.runtime-E2IhUtz8.js +0 -4
  764. package/dist/channel.runtime-s8LoLneR.js +0 -21009
  765. package/dist/channel.setup-BU4bp4OI.js +0 -10
  766. package/dist/channel.setup-CpygZ2ZG.js +0 -343
  767. package/dist/channel.setup-Z7jM_Q-v.js +0 -1098
  768. package/dist/chat-BQA8JGz8.js +0 -2666
  769. package/dist/chrome-YaZdp6CU.js +0 -1503
  770. package/dist/cli-DvGvBxMy.js +0 -1341
  771. package/dist/cli-compaction-0ER1653L.js +0 -347
  772. package/dist/cli-metadata-BJX-MSNl.js +0 -22
  773. package/dist/cli-runner-BGc4U7E0.js +0 -2
  774. package/dist/cli-runner-CH30meJN.js +0 -540
  775. package/dist/cli-runner.runtime-BqU9giS7.js +0 -4
  776. package/dist/cli-runner.runtime-D14IpD46.js +0 -3
  777. package/dist/client-DqnCi7vL.js +0 -650
  778. package/dist/client-adapter-BKZ5qBVY.js +0 -897
  779. package/dist/client-factory-BbBpLxaP.js +0 -9
  780. package/dist/command-auth-fZ1DLCTo.js +0 -135
  781. package/dist/command-handlers-CHbhwC1N.js +0 -1609
  782. package/dist/command-registry-_Oons836.js +0 -4
  783. package/dist/command-registry-core-Btb-M6JE.js +0 -110
  784. package/dist/command-registry-gWuCKROh.js +0 -9
  785. package/dist/command-status.runtime-DLav1SGb.js +0 -90
  786. package/dist/commands-acp-DVbINB4V.js +0 -74
  787. package/dist/commands-compact.runtime-CqQIDvM8.js +0 -10
  788. package/dist/commands-handlers.runtime-DJBGEdTB.js +0 -6154
  789. package/dist/commands-status-BaDacW0z.js +0 -3
  790. package/dist/commands-status-CTZ-HwUc.js +0 -16
  791. package/dist/commands-status.runtime-BaDacW0z.js +0 -3
  792. package/dist/commands-subagents-control.runtime-B6SOliNd.js +0 -2
  793. package/dist/commands-subagents-control.runtime-DTdEiA7w.js +0 -3
  794. package/dist/commands-system-prompt-BAdsJpn8.js +0 -162
  795. package/dist/commands-system-prompt-CX5iT-44.js +0 -2
  796. package/dist/commands.runtime-DObObKfz.js +0 -176
  797. package/dist/compact-Bs_eAw33.js +0 -480
  798. package/dist/compact-Ck7hE3ba.js +0 -1141
  799. package/dist/compact.runtime-el4EYgrW.js +0 -12
  800. package/dist/completion-cli-BbDnqYnS.js +0 -315
  801. package/dist/computer-use-GvCUpEEf.js +0 -367
  802. package/dist/config-BLgaJJYW.js +0 -2
  803. package/dist/config-FCIVG4Db.js +0 -373
  804. package/dist/config-mutations-BIPJigAd.js +0 -159
  805. package/dist/context-engine-host-compat--OOY7QEI.js +0 -2
  806. package/dist/context-engine-host-compat-DYVeYR5u.js +0 -288
  807. package/dist/context-engine-lifecycle-DAB4GWd5.js +0 -1274
  808. package/dist/control-auth-BekRscGw.js +0 -114
  809. package/dist/control-service-Hg9bqOzH.js +0 -145
  810. package/dist/control-ui/assets/agents-BRFjPVUQ.js +0 -1008
  811. package/dist/control-ui/assets/channel-config-extras-BySqgsd3.js +0 -2
  812. package/dist/control-ui/assets/channels-CC3sudX4.js +0 -367
  813. package/dist/control-ui/assets/cron-D0s06fzI.js +0 -1013
  814. package/dist/control-ui/assets/debug-9oq9PYZU.js +0 -97
  815. package/dist/control-ui/assets/index-ChE1ypG4.js +0 -7381
  816. package/dist/control-ui/assets/index-Crl1466m.css +0 -1
  817. package/dist/control-ui/assets/instances-k9LggJet.js +0 -57
  818. package/dist/control-ui/assets/logs-DKvc2q9b.js +0 -74
  819. package/dist/control-ui/assets/nodes-Bn7kmEGE.js +0 -436
  820. package/dist/control-ui/assets/sessions-0K-_jD8O.js +0 -399
  821. package/dist/control-ui/assets/skills-C9d4OZr_.js +0 -314
  822. package/dist/control-ui/assets/skills-shared-Bv7GgVjx.js +0 -11
  823. package/dist/conversation-binding-runtime-CC1fW5Mc.js +0 -4
  824. package/dist/conversation-runtime-YK1oLoen.js +0 -31
  825. package/dist/core-D9SaX41X.js +0 -282
  826. package/dist/core-api-6x_6ros_.js +0 -2
  827. package/dist/core-api-DQaZ_B6s.js +0 -5
  828. package/dist/crestodian-DLJAlHQO.js +0 -55
  829. package/dist/daocore-tools-DnGMRYJ5.js +0 -11727
  830. package/dist/delivery-dlloZivQ.js +0 -1002
  831. package/dist/dialogue-BQcF-xHi.js +0 -37
  832. package/dist/dir-fetch-tool-BmkLMRQd.js +0 -565
  833. package/dist/dir-list-tool-lJdvGnnr.js +0 -100
  834. package/dist/direct-dm-BfzS7vxm.js +0 -64
  835. package/dist/directive-handling.fast-lane-BdYkpgfF.js +0 -68
  836. package/dist/directive-handling.impl-DRIFqx-C.js +0 -818
  837. package/dist/directive-handling.impl-DoXcyCdO.js +0 -2
  838. package/dist/directive-handling.model-selection-xgiP4xbL.js +0 -122
  839. package/dist/directive-handling.persist.runtime-Dl-jD_0m.js +0 -263
  840. package/dist/dispatch-acp-transcript.runtime-B-PwrS4S.js +0 -40
  841. package/dist/dispatch-acp.runtime-CQHluA8f.js +0 -18
  842. package/dist/dispatch-kxJ95i3A.js +0 -1640
  843. package/dist/doctor-3QQaqcgK.js +0 -2
  844. package/dist/doctor-B9I7SuuU.js +0 -6
  845. package/dist/doctor-config-flow-DZQY34yK.js +0 -1741
  846. package/dist/doctor-core-checks-C_o9kgoZ.js +0 -2
  847. package/dist/doctor-core-checks-jWtsa4Nz.js +0 -573
  848. package/dist/doctor-health-BJ5wJFg5.js +0 -65
  849. package/dist/doctor-health-contributions-DxNPaNU6.js +0 -696
  850. package/dist/doctor-lint-DQrwNSTd.js +0 -94
  851. package/dist/doctor-state-integrity-Ctb6H9Pr.js +0 -1231
  852. package/dist/doctor-update-BZrZGmOg.js +0 -58
  853. package/dist/dynamic-tools-B9sHtLKs.js +0 -486
  854. package/dist/embedded-backend-CVEWr5Vd.js +0 -579
  855. package/dist/embedded-gateway-stub.runtime-BUl3fCUr.js +0 -12
  856. package/dist/exec-approvals-U0VRo553.js +0 -149
  857. package/dist/file-fetch-tool-PskYnfdX.js +0 -124
  858. package/dist/file-write-tool-BWMKcxSs.js +0 -127
  859. package/dist/format-Dk3-Jpqj.js +0 -1145
  860. package/dist/gateway-cli-BEtRyNAV.js +0 -435
  861. package/dist/gateway-method-runtime-Ba3mc5Ui.js +0 -21
  862. package/dist/get-reply-B-kNh5PS.js +0 -4689
  863. package/dist/get-reply-from-config.runtime-D-49TKR5.js +0 -2
  864. package/dist/graph-users-DIK-qpar.js +0 -1419
  865. package/dist/group-access-B6LDV7nR.js +0 -112
  866. package/dist/group-keys-DnxWQtll.d.ts +0 -17
  867. package/dist/handle-action.guild-admin-Dz9DREmk.js +0 -288
  868. package/dist/harness-CJWitSNk.js +0 -61
  869. package/dist/health-SAxsj7q2.js +0 -4
  870. package/dist/heartbeat-runner-D2IpmXX0.js +0 -5
  871. package/dist/heartbeat-runner.runtime-BKwSStf9.js +0 -4
  872. package/dist/hook-runtime-Cm73yH0T.d.ts +0 -107
  873. package/dist/hooks-C9V4TVXi.js +0 -534
  874. package/dist/inbound-direct-dm-runtime-C-KKlFVB.js +0 -2
  875. package/dist/inbound-reply-dispatch-3Kvtrdcn.js +0 -148
  876. package/dist/init-BGepd_Xi.js +0 -59
  877. package/dist/inline-buttons-Dqa993W-.js +0 -40
  878. package/dist/internal-events-hTD06P4Z.js +0 -90
  879. package/dist/isolated-agent-C30IhhQ4.js +0 -1118
  880. package/dist/isolated-agent-D9rwsYrc.js +0 -2
  881. package/dist/lifecycle-lYxX16zr.js +0 -571
  882. package/dist/list.probe-BuLNPfwh.js +0 -449
  883. package/dist/list.status-command-C9FwGWNZ.js +0 -789
  884. package/dist/llm-slug-generator-DEOtPI7b.js +0 -78
  885. package/dist/local-dispatch.runtime-D2mwqssZ.js +0 -9
  886. package/dist/manager-CSN9j9hh.d.ts +0 -205
  887. package/dist/manager.runtime-eqnbDApb.js +0 -2714
  888. package/dist/markdown-to-line-n4E_Ss2j.js +0 -811
  889. package/dist/mcp-http-DG2YDXx1.js +0 -555
  890. package/dist/mcp-http-DiGvYUK1.js +0 -2
  891. package/dist/media-understanding-provider-BAzC42im.js +0 -339
  892. package/dist/message-actions-DfM9sh0u.js +0 -145
  893. package/dist/message-handler-D3j7tiLC.js +0 -1715
  894. package/dist/message-handler-PdqXVaqc.js +0 -384
  895. package/dist/message-handler.preflight-DVTL11NJ.js +0 -1125
  896. package/dist/message-handler.process-Beo6fyUz.js +0 -1484
  897. package/dist/model-DiiSzCXH.js +0 -74
  898. package/dist/model-selection-CeDXYcsy.js +0 -272
  899. package/dist/models-BecxnLfn.js +0 -104
  900. package/dist/models-BxPknoYN.js +0 -2
  901. package/dist/models-cli-CmGPOjEx.js +0 -256
  902. package/dist/monitor-B2qfveOv.js +0 -60
  903. package/dist/monitor-BIKmDw4B.js +0 -2
  904. package/dist/monitor-CJXHxvh-.js +0 -1657
  905. package/dist/monitor-CqndMsTS.js +0 -4377
  906. package/dist/monitor-Dg9KC5G4.js +0 -834
  907. package/dist/monitor-IbL8Gw1Y.js +0 -2788
  908. package/dist/monitor-LxpNUkve.js +0 -1370
  909. package/dist/monitor-auth-EPov6Z4x.js +0 -179
  910. package/dist/monitor-i7_7ne6w.js +0 -715
  911. package/dist/monitor-polling.runtime-BRFuwAQo.js +0 -883
  912. package/dist/monitor-webhook.runtime-CGyP4NKq.js +0 -387
  913. package/dist/monitor.account-L5cJkJbV.js +0 -5233
  914. package/dist/monitor.runtime-Caq1xo2T.js +0 -2
  915. package/dist/monitor.webhook-CWo_j5xt.js +0 -180
  916. package/dist/node-cli-sessions-Dlrq3Hrt.js +0 -1228
  917. package/dist/openai-http-Cbs9WY_K.js +0 -824
  918. package/dist/openresponses-http-Djc1TNo5.js +0 -1173
  919. package/dist/operations-CePwJ_bf.js +0 -805
  920. package/dist/outbound-adapter-Cmcx_Msg.js +0 -543
  921. package/dist/outbound-session-route-DIvKTIer.js +0 -45
  922. package/dist/outbound.runtime-BCm1uM9e.js +0 -2
  923. package/dist/pairing-challenge-DD0D0sfM.d.ts +0 -87
  924. package/dist/pi-embedded-BGYOawy9.js +0 -3796
  925. package/dist/pi-embedded-s_XN5zci.js +0 -4
  926. package/dist/pi-embedded.runtime-Iv_ADnNC.js +0 -4
  927. package/dist/pi-tools-b-Wh6fBG.js +0 -2413
  928. package/dist/plan-9Cb-QHmS.js +0 -112
  929. package/dist/plan-DOX8mLZM.js +0 -81
  930. package/dist/plugin-CRqD5XqH.js +0 -12396
  931. package/dist/plugin-app-cache-key-BKpHiVS2.js +0 -46
  932. package/dist/plugin-enabled-BEi_lYEW.js +0 -233
  933. package/dist/plugin-registration-D99tHdMd.js +0 -88
  934. package/dist/plugin-sdk/scripts/lib/plugin-sdk-doc-metadata.d.ts +0 -107
  935. package/dist/plugin-service-DBTlrK7m.js +0 -1229
  936. package/dist/policy-B-G2ltps.js +0 -680
  937. package/dist/policy-DCljYbZL.js +0 -138
  938. package/dist/prepare.runtime-Ewb81gRo.js +0 -732
  939. package/dist/preview-warnings-DhWnG_r-.js +0 -392
  940. package/dist/probe-Bqu475Tv.js +0 -2204
  941. package/dist/probe-CRWUBMuB.js +0 -682
  942. package/dist/probe-Dm3lYN25.js +0 -47
  943. package/dist/probe-LLx6ayxG.js +0 -2
  944. package/dist/program-vxEyXm2e.js +0 -131
  945. package/dist/provider-B2aKgXI0.js +0 -32
  946. package/dist/provider-BUYMN3uZ.js +0 -152
  947. package/dist/provider-BlBfyHXO.js +0 -32
  948. package/dist/provider-D3O0zKex.js +0 -8735
  949. package/dist/provider-dispatcher-CYuX21il.js +0 -22
  950. package/dist/provider-session.runtime-xIOzPEA7.js +0 -9
  951. package/dist/provider.runtime-C94TKQWq.js +0 -2
  952. package/dist/public-surface-loader-CDa3nA_L.js +0 -114
  953. package/dist/pw-ai-BH_nTHa5.js +0 -3029
  954. package/dist/pw-role-snapshot-BPi5ipRX.js +0 -333
  955. package/dist/reaction-level-CSHisLIF.js +0 -19
  956. package/dist/reaction-runtime-api-D5YNDU-7.js +0 -116
  957. package/dist/realtime-transcription-provider-B6-wne03.js +0 -205
  958. package/dist/register-AeYt54B0.js +0 -2178
  959. package/dist/register.agent-DuW_Cioa.js +0 -156
  960. package/dist/register.crestodian-DfuAvHf8.js +0 -24
  961. package/dist/register.maintenance-DhSW2XSZ.js +0 -83
  962. package/dist/register.runtime-CYWai1dl.js +0 -54
  963. package/dist/register.subclis-B4c9g5v0.js +0 -31
  964. package/dist/register.subclis-Do4TSxcj.js +0 -3
  965. package/dist/register.subclis-core-Dm9-Cc4K.js +0 -273
  966. package/dist/repair-sequencing-CKX_OEBn.js +0 -640
  967. package/dist/reply-delivery-Dx31Fawb.js +0 -196
  968. package/dist/reply-runtime-DyCbxbOD.js +0 -11
  969. package/dist/reply.runtime-D-49TKR5.js +0 -2
  970. package/dist/request-CZtiBI4R.js +0 -54
  971. package/dist/resolve-allowlist-C-WRtkEq.js +0 -220
  972. package/dist/result-fallback-classifier-BkI5uV-W.js +0 -79
  973. package/dist/route-BEeC4HAl.js +0 -469
  974. package/dist/route-resolution-CHA13yYB.js +0 -274
  975. package/dist/routes-CfBm1qOU.js +0 -2
  976. package/dist/routes-DsgV54GJ.js +0 -3602
  977. package/dist/run-DL8UkH0h.js +0 -1162
  978. package/dist/run-attempt-D0qv7bs7.js +0 -7704
  979. package/dist/run-command-BWyjy--D.js +0 -23
  980. package/dist/run-command-IDml3oWg.js +0 -2
  981. package/dist/run-embedded.runtime-DeIZpKHe.js +0 -4
  982. package/dist/run-execution-cli.runtime-yf9gfWAm.js +0 -4
  983. package/dist/run-subagent-registry.runtime-oZs4xMMU.js +0 -2
  984. package/dist/runtime-BDbGwqGy.js +0 -6179
  985. package/dist/runtime-Bwn06s0u.js +0 -438
  986. package/dist/runtime-CD6WyVpL.js +0 -1287
  987. package/dist/runtime-DbTiSX85.d.ts +0 -17
  988. package/dist/runtime-api-BzvORSkx.js +0 -4
  989. package/dist/runtime-api-CAORRCZU.js +0 -17
  990. package/dist/runtime-api-CZGRk5D1.js +0 -24
  991. package/dist/runtime-api-CZm1iIlw.js +0 -13
  992. package/dist/runtime-api-D0d1LZvp.js +0 -21
  993. package/dist/runtime-api-DPIkVTDM.js +0 -3
  994. package/dist/runtime-api-DbQDZRSI.js +0 -13
  995. package/dist/runtime-api-k3v6Q0lb2.d.ts +0 -3151
  996. package/dist/runtime-api.actions-C2-n4QQ5.d.ts +0 -23
  997. package/dist/runtime-api.actions-CuYXLj2I.js +0 -3
  998. package/dist/runtime-api.monitor-BPMqlEBC.js +0 -6
  999. package/dist/runtime-api.send-cXGaIwD8.js +0 -4
  1000. package/dist/runtime-api.send-t0FX9tXf.d.ts +0 -38
  1001. package/dist/runtime-api.threads-DF6EqVSY.js +0 -2
  1002. package/dist/runtime-channel-B2dCbld0.js +0 -2
  1003. package/dist/runtime-channel-BfzwZ133.js +0 -150
  1004. package/dist/runtime-doctor-_yVIDUi3.d.ts +0 -48
  1005. package/dist/runtime-embedded-pi.runtime-Bz4-Me2g.js +0 -2
  1006. package/dist/sanitize-outbound-52UJkVc2.js +0 -127
  1007. package/dist/sdk-setup-tools-DzA0rD_t.js +0 -8
  1008. package/dist/secrets-BzY28DjS.js +0 -113
  1009. package/dist/security-audit-B_x9Bqsd.js +0 -122
  1010. package/dist/security-audit-CaX5F2YD.js +0 -118
  1011. package/dist/security-audit.runtime-BZFJXu8H.js +0 -2
  1012. package/dist/selection-B4V4O6zr.js +0 -16157
  1013. package/dist/selection-Cp7REh-j.js +0 -3
  1014. package/dist/send-B5TXXeBz.d.ts +0 -231
  1015. package/dist/send-C8NgsGx0.js +0 -2
  1016. package/dist/send-CktHKbVL.js +0 -192
  1017. package/dist/send-DEMaBWpw.d.ts +0 -105
  1018. package/dist/send-DSDSSxuo.js +0 -1631
  1019. package/dist/send-I0iE28XZ.js +0 -143
  1020. package/dist/send.components-CdYNwUR8.js +0 -500
  1021. package/dist/send.components-DDmsziVe.js +0 -2
  1022. package/dist/send.runtime-DEr6-5Rp.js +0 -2
  1023. package/dist/send.types-DywwIqYK.d.ts +0 -160
  1024. package/dist/server-Bdu2XxWz.js +0 -24
  1025. package/dist/server-BnVdhBLM.js +0 -73
  1026. package/dist/server-context-B7bIBpAz.js +0 -2
  1027. package/dist/server-context-BlPO5a-j.js +0 -955
  1028. package/dist/server-cron-3tDiqp95.js +0 -2989
  1029. package/dist/server-cron-Ckfa7HkP.js +0 -2
  1030. package/dist/server-methods-BNAICSKA.js +0 -16494
  1031. package/dist/server-node-events-BSp5sE0Q.js +0 -596
  1032. package/dist/server-plugin-bootstrap-Noai-kpp.js +0 -70
  1033. package/dist/server-plugins-DYPvxv5q.js +0 -432
  1034. package/dist/server-reload-handlers-I8gCBw7C.js +0 -714
  1035. package/dist/server-restart-sentinel-Bykg5_Sm.js +0 -747
  1036. package/dist/server-restart-sentinel-Dz8m-1uN.js +0 -2
  1037. package/dist/server-runtime-services-B2DpVh1J.js +0 -2
  1038. package/dist/server-runtime-services-DPDcSogD.js +0 -267
  1039. package/dist/server-startup-plugins-DHFkcvFX.js +0 -113
  1040. package/dist/server-startup-post-attach-BvKY1MjB.js +0 -716
  1041. package/dist/server-ws-runtime-DbsgWSNE.js +0 -349
  1042. package/dist/server.impl-DkzYcRnc.js +0 -2586
  1043. package/dist/service-oKCE97n8.js +0 -1446
  1044. package/dist/session-binding-BCYHcgKv.js +0 -219
  1045. package/dist/session-binding-Dbc5SyV1.js +0 -2
  1046. package/dist/session-kill-http-MtEei2A_.js +0 -121
  1047. package/dist/session-reset-service-BetsGXPL.js +0 -625
  1048. package/dist/session-route-BNumUO6m.js +0 -93
  1049. package/dist/session-status.runtime-8-kVkZLZ.js +0 -2
  1050. package/dist/session-subagent-reactivation.runtime-C4xmUBc4.js +0 -2
  1051. package/dist/session-tab-registry-DldD575V.js +0 -521
  1052. package/dist/sessions-history-http-Dh8uuG7K.js +0 -430
  1053. package/dist/sessions.runtime-CTD1EISY.js +0 -2
  1054. package/dist/setup-api-ClFwxmWg.js +0 -29
  1055. package/dist/setup-core-DF053J7r.js +0 -174
  1056. package/dist/setup-surface-C3vtcmut.js +0 -221
  1057. package/dist/setup-surface-hKgM61lK.js +0 -288
  1058. package/dist/setup-surface-kl5kIfCD.js +0 -405
  1059. package/dist/setup-surface-o44p_EZs.js +0 -320
  1060. package/dist/shared-DuNbDPVK.js +0 -121
  1061. package/dist/shared-client-BGdKzX6-.js +0 -2
  1062. package/dist/shared-client-DiaCaBiw.js +0 -629
  1063. package/dist/side-question-vADB_V7t.js +0 -683
  1064. package/dist/skill-tool-dispatch.runtime-DeTiaxln.js +0 -143
  1065. package/dist/slash-state-TiAtCc3B.js +0 -2166
  1066. package/dist/speech-provider-Dko5aOz2.js +0 -184
  1067. package/dist/src-Bczx7izw.js +0 -4256
  1068. package/dist/startup-context-sYE5tS1C.js +0 -313
  1069. package/dist/status-subagents.runtime-B79dVmOZ.js +0 -18
  1070. package/dist/status-text-CNV3Xo_z.js +0 -296
  1071. package/dist/sticker-cache-ClnmeK7n.js +0 -206
  1072. package/dist/sticker-vision.runtime-DKWYX_Z0.js +0 -17
  1073. package/dist/subagent-announce-BxgiPcah.js +0 -354
  1074. package/dist/subagent-announce-delivery-M73wDt9b.js +0 -958
  1075. package/dist/subagent-control-Svp4alxT.js +0 -508
  1076. package/dist/subagent-hooks-B8fQ4SB-.js +0 -2
  1077. package/dist/subagent-hooks-Bide9UGs.js +0 -2
  1078. package/dist/subagent-hooks-BroJYfmc.js +0 -116
  1079. package/dist/subagent-hooks-CeLaGy0S.js +0 -2
  1080. package/dist/subagent-hooks-D0jzCSJB.js +0 -230
  1081. package/dist/subagent-hooks-DMtU9Utn.js +0 -146
  1082. package/dist/subagent-hooks-api-6X1AhZ92.js +0 -23
  1083. package/dist/subagent-hooks-api-C3hw2s-7.js +0 -22
  1084. package/dist/subagent-hooks-api-D0utPXhG.js +0 -23
  1085. package/dist/subagent-orphan-recovery-DlyXF_8M.js +0 -352
  1086. package/dist/subagent-registry-Ct9aaUSq.js +0 -2351
  1087. package/dist/subagent-registry-_ThKY_a5.js +0 -3
  1088. package/dist/subagent-session-cleanup-D9jhUKCY.js +0 -525
  1089. package/dist/subagent-spawn-Bl5_-Qro.js +0 -1164
  1090. package/dist/target-id-DgUyIiaj.js +0 -107
  1091. package/dist/targets-CV6YGekF.js +0 -19
  1092. package/dist/targets-Ct6zFYUl.js +0 -19
  1093. package/dist/targets-DQxwAOx5.js +0 -44
  1094. package/dist/test-fixtures-HY6a4nTW.d.ts +0 -26
  1095. package/dist/testing-JsUCJjUs.js +0 -267
  1096. package/dist/thread-bindings-BJJr5qB6.js +0 -232
  1097. package/dist/thread-bindings-BVe9r2rW.js +0 -571
  1098. package/dist/thread-bindings-p78_o8d0.js +0 -228
  1099. package/dist/thread-bindings-yvtEoUyM.js +0 -8
  1100. package/dist/thread-bindings.discord-api-DpdJ31xq.js +0 -187
  1101. package/dist/thread-bindings.manager-DkA46uP3.js +0 -536
  1102. package/dist/thread-bindings.manager-MVNj26UO.js +0 -2
  1103. package/dist/thread-lifecycle-CLhulJIV.js +0 -1614
  1104. package/dist/token-VGmXler6.js +0 -134
  1105. package/dist/tool-BJkgiGjR.js +0 -139
  1106. package/dist/tool-actions.runtime-DhrT4z_Z.js +0 -534
  1107. package/dist/tool-resolution-BJLcYvry.js +0 -149
  1108. package/dist/tools-effective-inventory-D1c6J-sI.js +0 -204
  1109. package/dist/tools-invoke-http-B-k9cOYf.js +0 -67
  1110. package/dist/tools-invoke-shared-qMHGnaLY.js +0 -200
  1111. package/dist/tts-CmxOJYRq.js +0 -66
  1112. package/dist/tui-BcRfXYtK.js +0 -2
  1113. package/dist/tui-ChmyCc_c.js +0 -4709
  1114. package/dist/tui-backend-BOAgkU7O.js +0 -256
  1115. package/dist/tui-cli-C_1WxXuf.js +0 -37
  1116. package/dist/typed-cases-D8uyQEzR.d.ts +0 -68
  1117. package/dist/update-cli-CBJVr7p3.js +0 -3664
  1118. package/dist/update-runner-DHzvirfV.js +0 -2379
  1119. package/dist/vision-tools-BIOoLPOZ.js +0 -1409
  1120. package/dist/web-search-8-XCZJzj.js +0 -62
  1121. package/dist/web-search-provider.runtime-BORgiL3n.js +0 -2
  1122. package/dist/web-search-provider.runtime-CCXm-JLK.js +0 -328
  1123. package/dist/webhook-targets-CW4Nl_cq.d.ts +0 -99
  1124. package/dist/xai-oauth-CcxHOluD.js +0 -479
  1125. package/dist/xai-user-agent-BE2MgJak.js +0 -32
  1126. /package/dist/{accounts-CqgATPC-2.d.ts → accounts-CqgATPC-.d.ts} +0 -0
  1127. /package/dist/{acp-runtime-backend-DFDX5U10.js → acp-runtime-backend-BQNm-KYC.js} +0 -0
  1128. /package/dist/{channel-actions-DMH2vVzJ.js → channel-actions-CMUt5769.js} +0 -0
  1129. /package/dist/{command-status-runtime-Du_onNYh.js → command-status-runtime-DXZZv5h_.js} +0 -0
  1130. /package/dist/{delegate-CDb4qcfr.js → delegate-BTCHfZIj.js} +0 -0
  1131. /package/dist/{dispatch-acp-0Se8OniI.js → dispatch-acp-DtdYZo4i.js} +0 -0
  1132. /package/dist/{heartbeat-runner-BdsqQ3pi.js → heartbeat-runner-BqUKIwmn.js} +0 -0
  1133. /package/dist/{library-CsfrQOyp.js → library-DavrGMix.js} +0 -0
  1134. /package/dist/{run-executor.runtime-OlsZwyZw.js → run-executor.runtime-DMU7greB.js} +0 -0
  1135. /package/dist/{shared-DxV6gup5.js → shared-Kl_LS_vA.js} +0 -0
@@ -1,1713 +0,0 @@
1
- import { a as normalizeLowercaseStringOrEmpty, c as normalizeOptionalString, f as readStringValue, t as hasNonEmptyString } from "./string-coerce-DyL154ka.js";
2
- import { t as sanitizeForLog } from "./ansi-4r6vVvJt.js";
3
- import { i as formatErrorMessage } from "./errors-D_oyTIw2.js";
4
- import { C as hasSessionAutoModelFallbackProvenance, i as markAutoFallbackPrimaryProbe, n as entryMatchesAutoFallbackPrimaryProbe, p as resolveAutoFallbackPrimaryProbe, t as clearAutoFallbackPrimaryProbeSelection } from "./agent-scope-Dx1S0aWX.js";
5
- import { n as defaultRuntime } from "./runtime-E_A14BX_.js";
6
- import { o as isDiagnosticsEnabled } from "./diagnostic-events-DPfGiEBK.js";
7
- import { r as logVerbose } from "./globals-DhGeOA1P.js";
8
- import { f as resolveMessageChannel, i as isMarkdownCapableMessageChannel, r as isInternalMessageChannel } from "./message-channel-CRza_Xs_.js";
9
- import { l as resolveOpenAIRuntimeProviderForPi } from "./openai-codex-routing-VOt1IwnF.js";
10
- import { t as resolveAgentHarnessPolicy } from "./policy-DqVcSoDg.js";
11
- import { i as emitAgentEvent, l as onAgentEvent, u as registerAgentRunContext } from "./agent-events-Cfj53GyA.js";
12
- import { b as resolveGroupSessionKey, u as updateSessionStore } from "./store-C4uyNaPD.js";
13
- import "./sessions-4ZNlAnYc.js";
14
- import { x as resolveModelRefFromString } from "./model-selection-shared-BZqZE4Cv.js";
15
- import { t as isCliProvider } from "./model-selection-cli-MBGiFg3N.js";
16
- import { l as resolvePersistedOverrideModelRef } from "./model-selection-D1TyOrqK.js";
17
- import { d as sanitizeUserFacingText, i as formatRateLimitOrOverloadedErrorCopy, t as BILLING_ERROR_USER_MESSAGE } from "./sanitize-user-facing-text-T0c8YLm7.js";
18
- import { i as isOverloadedErrorMessage, o as isRateLimitErrorMessage, r as isBillingErrorMessage } from "./failover-matches-C-tab7FS.js";
19
- import { d as logSessionTurnCreated } from "./diagnostic-BjLrX3ad.js";
20
- import { a as isSilentReplyText, i as isSilentReplyPrefixText, n as SILENT_REPLY_TOKEN, o as startsWithSilentToken, s as stripLeadingSilentToken } from "./tokens-D8MVQSp9.js";
21
- import { o as resolveContextTokensForModel } from "./context-BK8i6-zU.js";
22
- import { n as GatewayDrainingError, t as CommandLaneClearedError } from "./command-queue-B4bof8Vu.js";
23
- import { l as markReplyPayloadForSourceSuppressionDelivery, r as copyReplyPayloadMetadata } from "./reply-payload-CiT5mlcY.js";
24
- import { m as resolveSendableOutboundReplyParts, s as hasOutboundReplyContent } from "./reply-payload-DMPQsrQC.js";
25
- import "./selection-B4V4O6zr.js";
26
- import { d as stripHeartbeatToken } from "./heartbeat-0BSacHYL.js";
27
- import { l as resolveBootstrapWarningSignaturesSeen } from "./bootstrap-budget-WP_UMPQC.js";
28
- import "./pi-embedded-helpers-Dpwa1qwE.js";
29
- import { n as classifyOAuthRefreshFailure, t as buildOAuthRefreshFailureLoginCommand } from "./oauth-refresh-failure-Dwv-Wme0.js";
30
- import { d as isContextOverflowError, g as isLikelyContextOverflowError, u as isCompactionFailureError, y as isTransientHttpError } from "./errors-Cr9ahrgU.js";
31
- import { G as isMessagingToolSendAction } from "./attempt.tool-run-context-C5nkRM5Y.js";
32
- import { d as parseReplyDirectives } from "./payloads-DecsNYNJ.js";
33
- import { o as LiveSessionModelSwitchError, r as runWithModelFallback, t as isFallbackSummaryError } from "./model-fallback-DTeTSdGO.js";
34
- import { i as isRenderablePayload, t as applyReplyTagsToPayload } from "./reply-payloads-kCeLwDmf.js";
35
- import { c as resolveCliRuntimeExecutionProvider, o as listLegacyRuntimeModelProviderAliases } from "./model-runtime-aliases-CEDWbZ3S.js";
36
- import { r as getCliSessionBinding } from "./cli-session-BPlVLy8x.js";
37
- import { t as ensureSelectedAgentHarnessPlugin } from "./runtime-plugin-5kEs6XNI.js";
38
- import { t as runEmbeddedPiAgent } from "./pi-embedded-BGYOawy9.js";
39
- import { n as buildAgentRuntimeOutcomePlan } from "./build-DOEtxYaU.js";
40
- import { n as resolveSilentReplyPolicy, t as resolveCurrentTurnImages } from "./current-turn-images-oLoQJcPF.js";
41
- import { c as resolveRunAuthProfile, o as resolveQueuedReplyRuntimeConfig, s as resolveModelFallbackOptions, t as buildEmbeddedRunExecutionParams } from "./agent-runner-utils-Bluglnku.js";
42
- import { t as runCliAgent } from "./cli-runner-CH30meJN.js";
43
- import { n as HEARTBEAT_EXTERNAL_RUN_FAILURE_TEXT, t as GENERIC_EXTERNAL_RUN_FAILURE_TEXT } from "./agent-runner-failure-copy-CU6Vmacs.js";
44
- import { n as resolveOriginMessageProvider } from "./origin-routing-BrwjqMJ_.js";
45
- import { n as createBlockReplyContentKey } from "./block-reply-pipeline-SGEZNJr-.js";
46
- import { t as createReplyMediaContext } from "./reply-media-paths.runtime-CSrfIWHK.js";
47
- import crypto from "node:crypto";
48
- //#region src/auto-reply/reply/agent-runner-cli-dispatch.ts
49
- function shouldBridgeCliAssistantTextToReasoning(provider) {
50
- return normalizeLowercaseStringOrEmpty(provider) === "claude-cli";
51
- }
52
- function createAssistantTextBridge(params) {
53
- const deliver = params.deliver;
54
- if (!deliver) return {
55
- unsubscribe: () => void 0,
56
- drain: async () => void 0
57
- };
58
- let lastText;
59
- let unsubscribed = false;
60
- let delivery = Promise.resolve();
61
- const rawUnsubscribe = onAgentEvent((evt) => {
62
- if (evt.runId !== params.runId || evt.stream !== "assistant") return;
63
- if (params.suppressed) return;
64
- const text = typeof evt.data.text === "string" ? evt.data.text : void 0;
65
- if (text === void 0 || text === lastText) return;
66
- lastText = text;
67
- delivery = delivery.then(() => deliver(text)).catch(() => void 0);
68
- });
69
- return {
70
- unsubscribe() {
71
- if (unsubscribed) return;
72
- unsubscribed = true;
73
- rawUnsubscribe();
74
- },
75
- async drain() {
76
- await delivery;
77
- }
78
- };
79
- }
80
- async function runCliAgentWithLifecycle(params) {
81
- const startedAt = params.startedAt ?? Date.now();
82
- const emitLifecycleStart = params.emitLifecycleStart ?? true;
83
- const emitLifecycleTerminal = params.emitLifecycleTerminal ?? true;
84
- params.onAgentRunStart?.();
85
- if (emitLifecycleStart) emitAgentEvent({
86
- runId: params.runId,
87
- stream: "lifecycle",
88
- data: {
89
- phase: "start",
90
- startedAt
91
- }
92
- });
93
- const assistantBridge = createAssistantTextBridge({
94
- runId: params.runId,
95
- suppressed: params.suppressAssistantBridge,
96
- deliver: params.onAssistantText
97
- });
98
- const reasoningBridge = createAssistantTextBridge({
99
- runId: params.runId,
100
- suppressed: params.suppressAssistantBridge,
101
- deliver: shouldBridgeCliAssistantTextToReasoning(params.provider) ? params.onReasoningText : void 0
102
- });
103
- let lifecycleTerminalEmitted = false;
104
- try {
105
- const rawResult = await runCliAgent(params.runParams);
106
- const result = params.transformResult?.(rawResult) ?? rawResult;
107
- assistantBridge.unsubscribe();
108
- reasoningBridge.unsubscribe();
109
- await assistantBridge.drain();
110
- await reasoningBridge.drain();
111
- const cliText = normalizeOptionalString(result.payloads?.[0]?.text);
112
- if (cliText) emitAgentEvent({
113
- runId: params.runId,
114
- stream: "assistant",
115
- data: { text: cliText }
116
- });
117
- if (emitLifecycleTerminal) {
118
- emitAgentEvent({
119
- runId: params.runId,
120
- stream: "lifecycle",
121
- data: {
122
- phase: "end",
123
- startedAt,
124
- endedAt: Date.now()
125
- }
126
- });
127
- lifecycleTerminalEmitted = true;
128
- }
129
- return result;
130
- } catch (err) {
131
- assistantBridge.unsubscribe();
132
- reasoningBridge.unsubscribe();
133
- await assistantBridge.drain();
134
- await reasoningBridge.drain();
135
- await params.onErrorBeforeLifecycle?.(err);
136
- if (emitLifecycleTerminal) {
137
- emitAgentEvent({
138
- runId: params.runId,
139
- stream: "lifecycle",
140
- data: {
141
- phase: "error",
142
- startedAt,
143
- endedAt: Date.now(),
144
- error: String(err)
145
- }
146
- });
147
- lifecycleTerminalEmitted = true;
148
- }
149
- throw err;
150
- } finally {
151
- assistantBridge.unsubscribe();
152
- reasoningBridge.unsubscribe();
153
- if (emitLifecycleTerminal && !lifecycleTerminalEmitted) emitAgentEvent({
154
- runId: params.runId,
155
- stream: "lifecycle",
156
- data: {
157
- phase: "error",
158
- startedAt,
159
- endedAt: Date.now(),
160
- error: "CLI run completed without lifecycle terminal event"
161
- }
162
- });
163
- }
164
- }
165
- //#endregion
166
- //#region src/auto-reply/reply/provider-request-error-classifier.ts
167
- const PROVIDER_CONVERSATION_STATE_ERROR_USER_MESSAGE = "⚠️ The model provider rejected the conversation state. Please try again, or use /new to start a fresh session.";
168
- function classifyProviderRequestError(err) {
169
- const technicalMessage = formatErrorMessage(err);
170
- if (isProviderConversationStateErrorMessage(technicalMessage)) return {
171
- code: "provider_conversation_state_error",
172
- userMessage: PROVIDER_CONVERSATION_STATE_ERROR_USER_MESSAGE,
173
- technicalMessage
174
- };
175
- }
176
- function isProviderConversationStateErrorMessage(message) {
177
- const lower = normalizeLowercaseStringOrEmpty(message);
178
- return lower.includes("custom tool call output is missing") && lower.includes("call id") || lower.includes("toolresult") && lower.includes("tooluse") && lower.includes("exceeds the number") && lower.includes("previous turn") || lower.includes("function call turn comes immediately after") || lower.includes("incorrect role information") || lower.includes("roles must alternate");
179
- }
180
- //#endregion
181
- //#region src/auto-reply/reply/reply-delivery.ts
182
- function normalizeReplyPayloadDirectives(params) {
183
- const parseMode = params.parseMode ?? "always";
184
- const silentToken = params.silentToken ?? "NO_REPLY";
185
- const sourceText = params.payload.text ?? "";
186
- const parsed = parseMode === "always" || parseMode === "auto" && (sourceText.includes("[[") || /media:/i.test(sourceText) || params.extractMarkdownImages === true && /!\[[^\]]*]\(/.test(sourceText) || sourceText.includes(silentToken)) ? parseReplyDirectives(sourceText, {
187
- currentMessageId: params.currentMessageId,
188
- silentToken,
189
- extractMarkdownImages: params.extractMarkdownImages
190
- }) : void 0;
191
- let text = parsed ? parsed.text || void 0 : params.payload.text || void 0;
192
- if (params.trimLeadingWhitespace && text) text = text.trimStart() || void 0;
193
- const mediaUrls = params.payload.mediaUrls ?? parsed?.mediaUrls;
194
- const mediaUrl = params.payload.mediaUrl ?? parsed?.mediaUrl ?? mediaUrls?.[0];
195
- return {
196
- payload: copyReplyPayloadMetadata(params.payload, {
197
- ...params.payload,
198
- text,
199
- mediaUrls,
200
- mediaUrl,
201
- replyToId: params.payload.replyToId ?? parsed?.replyToId,
202
- replyToTag: params.payload.replyToTag || parsed?.replyToTag,
203
- replyToCurrent: params.payload.replyToCurrent || parsed?.replyToCurrent,
204
- audioAsVoice: Boolean(params.payload.audioAsVoice || parsed?.audioAsVoice)
205
- }),
206
- isSilent: parsed?.isSilent ?? false
207
- };
208
- }
209
- async function sendDirectBlockReply(params) {
210
- params.directlySentBlockKeys.add(createBlockReplyContentKey(params.trackingPayload));
211
- await params.onBlockReply(params.payload);
212
- }
213
- function createBlockReplyDeliveryHandler(params) {
214
- return async (payload) => {
215
- const { text, skip } = params.normalizeStreamingText(payload);
216
- if (skip && !hasOutboundReplyContent({
217
- ...payload,
218
- text: void 0
219
- })) return;
220
- const implicitCurrentMessageAllowed = payload.replyToCurrent === true ? true : payload.replyToCurrent === false ? false : params.replyThreading?.implicitCurrentMessage !== "deny";
221
- const taggedPayload = applyReplyTagsToPayload({
222
- ...payload,
223
- text,
224
- mediaUrl: payload.mediaUrl ?? payload.mediaUrls?.[0],
225
- replyToId: payload.replyToId ?? (implicitCurrentMessageAllowed ? params.currentMessageId : void 0)
226
- }, params.currentMessageId);
227
- if (!isRenderablePayload(taggedPayload) && !payload.audioAsVoice) return;
228
- const normalized = normalizeReplyPayloadDirectives({
229
- payload: taggedPayload,
230
- currentMessageId: params.currentMessageId,
231
- silentToken: SILENT_REPLY_TOKEN,
232
- trimLeadingWhitespace: true,
233
- parseMode: "auto"
234
- });
235
- const mediaNormalizedPayload = params.normalizeMediaPaths ? await params.normalizeMediaPaths(normalized.payload) : normalized.payload;
236
- if (normalized.isSilent) mediaNormalizedPayload.text = void 0;
237
- const blockPayload = copyReplyPayloadMetadata(payload, params.applyReplyToMode(mediaNormalizedPayload));
238
- const blockHasNonTextContent = hasOutboundReplyContent({
239
- ...blockPayload,
240
- text: void 0
241
- });
242
- if (!blockPayload.text && !blockHasNonTextContent && !blockPayload.audioAsVoice) return;
243
- if (normalized.isSilent && !blockHasNonTextContent) return;
244
- if (blockPayload.text) params.typingSignals.signalTextDelta(blockPayload.text).catch((err) => {
245
- logVerbose(`block reply typing signal failed: ${String(err)}`);
246
- });
247
- if (params.blockStreamingEnabled && params.blockReplyPipeline) params.blockReplyPipeline.enqueue(blockPayload);
248
- else if (params.blockStreamingEnabled) await sendDirectBlockReply({
249
- onBlockReply: params.onBlockReply,
250
- directlySentBlockKeys: params.directlySentBlockKeys,
251
- trackingPayload: blockPayload,
252
- payload: blockPayload
253
- });
254
- else if (blockHasNonTextContent) await sendDirectBlockReply({
255
- onBlockReply: params.onBlockReply,
256
- directlySentBlockKeys: params.directlySentBlockKeys,
257
- trackingPayload: blockPayload,
258
- payload: blockPayload
259
- });
260
- };
261
- }
262
- function readApprovalScopeValue(value) {
263
- return value === "turn" || value === "session" ? value : void 0;
264
- }
265
- const FALLBACK_SELECTION_STATE_KEYS = [
266
- "providerOverride",
267
- "modelOverride",
268
- "modelOverrideSource",
269
- "modelOverrideFallbackOriginProvider",
270
- "modelOverrideFallbackOriginModel",
271
- "authProfileOverride",
272
- "authProfileOverrideSource",
273
- "authProfileOverrideCompactionCount"
274
- ];
275
- function setFallbackSelectionStateField(entry, key, value) {
276
- switch (key) {
277
- case "providerOverride":
278
- if (entry.providerOverride !== value) {
279
- entry.providerOverride = value;
280
- return true;
281
- }
282
- return false;
283
- case "modelOverride":
284
- if (entry.modelOverride !== value) {
285
- entry.modelOverride = value;
286
- return true;
287
- }
288
- return false;
289
- case "modelOverrideSource":
290
- if (entry.modelOverrideSource !== value) {
291
- entry.modelOverrideSource = value;
292
- return true;
293
- }
294
- return false;
295
- case "modelOverrideFallbackOriginProvider":
296
- if (entry.modelOverrideFallbackOriginProvider !== value) {
297
- entry.modelOverrideFallbackOriginProvider = value;
298
- return true;
299
- }
300
- return false;
301
- case "modelOverrideFallbackOriginModel":
302
- if (entry.modelOverrideFallbackOriginModel !== value) {
303
- entry.modelOverrideFallbackOriginModel = value;
304
- return true;
305
- }
306
- return false;
307
- case "authProfileOverride":
308
- if (entry.authProfileOverride !== value) {
309
- entry.authProfileOverride = value;
310
- return true;
311
- }
312
- return false;
313
- case "authProfileOverrideSource":
314
- if (entry.authProfileOverrideSource !== value) {
315
- entry.authProfileOverrideSource = value;
316
- return true;
317
- }
318
- return false;
319
- case "authProfileOverrideCompactionCount":
320
- if (entry.authProfileOverrideCompactionCount !== value) {
321
- entry.authProfileOverrideCompactionCount = value;
322
- return true;
323
- }
324
- return false;
325
- }
326
- throw new Error("Unsupported fallback selection state key");
327
- }
328
- function snapshotFallbackSelectionState(entry) {
329
- return {
330
- providerOverride: entry.providerOverride,
331
- modelOverride: entry.modelOverride,
332
- modelOverrideSource: entry.modelOverrideSource,
333
- modelOverrideFallbackOriginProvider: entry.modelOverrideFallbackOriginProvider,
334
- modelOverrideFallbackOriginModel: entry.modelOverrideFallbackOriginModel,
335
- authProfileOverride: entry.authProfileOverride,
336
- authProfileOverrideSource: entry.authProfileOverrideSource,
337
- authProfileOverrideCompactionCount: entry.authProfileOverrideCompactionCount
338
- };
339
- }
340
- function buildFallbackSelectionState(params) {
341
- return {
342
- providerOverride: params.provider,
343
- modelOverride: params.model,
344
- modelOverrideSource: "auto",
345
- modelOverrideFallbackOriginProvider: params.originProvider,
346
- modelOverrideFallbackOriginModel: params.originModel,
347
- authProfileOverride: params.authProfileId,
348
- authProfileOverrideSource: params.authProfileId ? params.authProfileIdSource : void 0,
349
- authProfileOverrideCompactionCount: void 0
350
- };
351
- }
352
- function resolveFallbackSelectionOrigin(params) {
353
- if (params.entry.modelOverrideSource === "auto" || params.entry.modelOverrideSource === void 0 && hasSessionAutoModelFallbackProvenance(params.entry)) {
354
- const persistedOriginProvider = normalizeOptionalString(params.entry.modelOverrideFallbackOriginProvider);
355
- const persistedOriginModel = normalizeOptionalString(params.entry.modelOverrideFallbackOriginModel);
356
- if (persistedOriginProvider && persistedOriginModel) return {
357
- provider: persistedOriginProvider,
358
- model: persistedOriginModel
359
- };
360
- }
361
- return {
362
- provider: params.run.provider,
363
- model: params.run.model
364
- };
365
- }
366
- function applyFallbackCandidateSelectionToEntry(params) {
367
- if (!params.force && params.provider === params.run.provider && params.model === params.run.model) return { updated: false };
368
- const scopedAuthProfile = resolveRunAuthProfile(params.run, params.provider);
369
- const origin = params.origin ?? resolveFallbackSelectionOrigin({
370
- entry: params.entry,
371
- run: params.run
372
- });
373
- const nextState = buildFallbackSelectionState({
374
- provider: params.provider,
375
- model: params.model,
376
- originProvider: origin.provider,
377
- originModel: origin.model,
378
- authProfileId: scopedAuthProfile.authProfileId,
379
- authProfileIdSource: scopedAuthProfile.authProfileIdSource
380
- });
381
- return {
382
- updated: applyFallbackSelectionState(params.entry, nextState, params.now),
383
- nextState
384
- };
385
- }
386
- function applyFallbackSelectionState(entry, nextState, now = Date.now()) {
387
- let updated = false;
388
- for (const key of FALLBACK_SELECTION_STATE_KEYS) {
389
- const nextValue = nextState[key];
390
- if (nextValue === void 0) {
391
- if (Object.hasOwn(entry, key)) {
392
- delete entry[key];
393
- updated = true;
394
- }
395
- continue;
396
- }
397
- if (entry[key] !== nextValue) updated = setFallbackSelectionStateField(entry, key, nextValue) || updated;
398
- }
399
- if (updated) entry.updatedAt = now;
400
- return updated;
401
- }
402
- function rollbackFallbackSelectionStateIfUnchanged(entry, expectedState, previousState, now = Date.now()) {
403
- let updated = false;
404
- for (const key of FALLBACK_SELECTION_STATE_KEYS) {
405
- if (entry[key] !== expectedState[key]) continue;
406
- const previousValue = previousState[key];
407
- if (previousValue === void 0) {
408
- if (Object.hasOwn(entry, key)) {
409
- delete entry[key];
410
- updated = true;
411
- }
412
- continue;
413
- }
414
- if (entry[key] !== previousValue) updated = setFallbackSelectionStateField(entry, key, previousValue) || updated;
415
- }
416
- if (updated) entry.updatedAt = now;
417
- return updated;
418
- }
419
- /**
420
- * Build a human-friendly rate-limit message from a FallbackSummaryError.
421
- * Includes a countdown when the soonest cooldown expiry is known.
422
- */
423
- function buildRateLimitCooldownMessage(err) {
424
- const codexUsageLimitMessage = extractCodexUsageLimitErrorMessage(err);
425
- if (codexUsageLimitMessage) return codexUsageLimitMessage;
426
- if (isFallbackSummaryError(err) && hasBillingAttemptSummary(err)) return BILLING_ERROR_USER_MESSAGE;
427
- if (isBillingErrorMessage(formatErrorMessage(err))) return BILLING_ERROR_USER_MESSAGE;
428
- if (!isFallbackSummaryError(err)) return "⚠️ All models are temporarily rate-limited. Please try again in a few minutes.";
429
- const expiry = err.soonestCooldownExpiry;
430
- const now = Date.now();
431
- if (typeof expiry === "number" && expiry > now) {
432
- const secsLeft = Math.max(1, Math.ceil((expiry - now) / 1e3));
433
- if (secsLeft <= 60) return `⚠️ Rate-limited — ready in ~${secsLeft}s. Please wait a moment.`;
434
- return `⚠️ Rate-limited — ready in ~${Math.ceil(secsLeft / 60)} min. Please try again shortly.`;
435
- }
436
- return "⚠️ All models are temporarily rate-limited. Please try again in a few minutes.";
437
- }
438
- function extractCodexUsageLimitErrorMessage(err) {
439
- if (isFallbackSummaryError(err)) {
440
- for (const attempt of err.attempts) {
441
- const message = extractCodexUsageLimitMessage(attempt.error);
442
- if (message) return `⚠️ ${message}`;
443
- }
444
- return;
445
- }
446
- const message = extractCodexUsageLimitMessage(formatErrorMessage(err));
447
- return message ? `⚠️ ${message}` : void 0;
448
- }
449
- function extractCodexUsageLimitMessage(text) {
450
- const markers = ["You've reached your Codex subscription usage limit.", "Codex usage limit reached."];
451
- let markerIndex;
452
- for (const marker of markers) {
453
- const index = text.indexOf(marker);
454
- if (index >= 0 && (markerIndex === void 0 || index < markerIndex)) markerIndex = index;
455
- }
456
- if (markerIndex === void 0) return;
457
- const message = sanitizeUserFacingText(text.slice(markerIndex), { errorContext: true }).split(/\r?\n/u).map((line) => line.trim()).filter(Boolean).join(" ").trim();
458
- if (!message) return;
459
- return message.length > 500 ? `${message.slice(0, 497)}...` : message;
460
- }
461
- function isPureTransientRateLimitSummary(err) {
462
- return isFallbackSummaryError(err) && err.attempts.length > 0 && err.attempts.every((attempt) => {
463
- const reason = attempt.reason;
464
- return reason === "rate_limit" || reason === "overloaded";
465
- });
466
- }
467
- function hasBillingAttemptSummary(err) {
468
- return isFallbackSummaryError(err) && err.attempts.length > 0 && err.attempts.some((attempt) => attempt.reason === "billing");
469
- }
470
- function collapseRepeatedFailureDetail(message) {
471
- const parts = message.split(/\s+\|\s+/u).map((part) => part.trim()).filter(Boolean);
472
- if (parts.length >= 2 && parts.every((part) => part === parts[0])) return parts[0];
473
- return message.trim();
474
- }
475
- const SAFE_MISSING_API_KEY_PROVIDERS = new Set([
476
- "anthropic",
477
- "google",
478
- "openai",
479
- "openai-codex"
480
- ]);
481
- const EXTERNAL_RUN_FAILURE_DETAIL_MAX_CHARS = 900;
482
- const AGENT_FAILED_BEFORE_REPLY_TEXT = "Agent failed before reply:";
483
- function isNonDirectConversationContext(ctx) {
484
- const chatType = normalizeLowercaseStringOrEmpty(ctx.ChatType);
485
- return chatType === "group" || chatType === "channel";
486
- }
487
- function isVerboseFailureDetailEnabled(level) {
488
- return level === "on" || level === "full";
489
- }
490
- function resolveExternalRunFailureTextForConversation(params) {
491
- if (!isNonDirectConversationContext(params.sessionCtx)) return params.text;
492
- if (!params.isGenericRunnerFailure && !params.text.includes(AGENT_FAILED_BEFORE_REPLY_TEXT)) return params.text;
493
- if (resolveSilentReplyPolicy({
494
- cfg: params.cfg,
495
- sessionKey: params.sessionCtx.SessionKey,
496
- surface: params.sessionCtx.Surface ?? params.sessionCtx.Provider,
497
- conversationType: "group"
498
- }) === "disallow") return params.text;
499
- return SILENT_REPLY_TOKEN;
500
- }
501
- const CLI_BACKEND_NO_OUTPUT_STALL_RE = /\bCLI produced no output for\s+(\d+)\s*s\s+and was terminated\b/iu;
502
- const CLI_BACKEND_OVERALL_TIMEOUT_RE = /\bCLI exceeded timeout\s*\(\s*(\d+)\s*s\s*\)\s+and was terminated\b/iu;
503
- const CLI_BACKEND_ROUTING_REF_BEFORE_ERROR_RE = /\b([\w.-]+\/[A-Za-z][\w.-]*)\s*:\s*CLI\b/iu;
504
- const CODEX_APP_SERVER_CLIENT_CLOSED_BEFORE_REPLY_RE = /\bcodex app-server client closed before turn completed\b/iu;
505
- const CODEX_APP_SERVER_TURN_COMPLETION_IDLE_TIMEOUT_RE = /\bcodex app-server turn idle timed out waiting for turn\/completed\b/iu;
506
- function buildCodexAppServerFailureText(message) {
507
- const normalizedMessage = collapseRepeatedFailureDetail(message);
508
- if (CODEX_APP_SERVER_CLIENT_CLOSED_BEFORE_REPLY_RE.test(normalizedMessage)) return "⚠️ Codex app-server connection closed before this turn finished. DaoCore retried once when the stdio turn was still replay-safe; please try again if this keeps happening.";
509
- if (CODEX_APP_SERVER_TURN_COMPLETION_IDLE_TIMEOUT_RE.test(normalizedMessage)) return "⚠️ Codex app-server stopped before confirming turn completion. DaoCore did not replay the turn automatically because it may still be active; try again, or use /new if the session stays stuck.";
510
- return null;
511
- }
512
- function buildCliBackendTimeoutFailureText(message) {
513
- const normalizedMessage = collapseRepeatedFailureDetail(message);
514
- const stall = normalizedMessage.match(CLI_BACKEND_NO_OUTPUT_STALL_RE);
515
- const overall = normalizedMessage.match(CLI_BACKEND_OVERALL_TIMEOUT_RE);
516
- const seconds = (stall ?? overall)?.[1];
517
- if (!seconds) return null;
518
- const routedModelRef = normalizedMessage.match(CLI_BACKEND_ROUTING_REF_BEFORE_ERROR_RE)?.[1];
519
- return `⚠️ CLI subprocess${routedModelRef ? ` (routing ${routedModelRef})` : ""}: timed out after ${seconds}s (${stall ? "no-output stall" : "overall CLI turn budget"}). The gateway may still be healthy. Try \`/new\`, a lighter model, or raise \`agents.defaults.timeoutSeconds\` and the watchdog \`noOutputTimeoutMs\` entries under \`cliBackends.<your-runtime>\`.`;
520
- }
521
- function buildMissingApiKeyFailureText(message) {
522
- const normalizedMessage = collapseRepeatedFailureDetail(message);
523
- const provider = normalizedMessage.match(/No API key found for provider "([^"]+)"/u)?.[1]?.trim().toLowerCase();
524
- if (!provider) return null;
525
- if (provider === "openai" && normalizedMessage.includes("OpenAI Codex OAuth")) return "⚠️ Missing API key for OpenAI on the gateway. Use `openai/gpt-5.5` with the Codex OAuth profile, or set `OPENAI_API_KEY` for direct OpenAI API-key runs.";
526
- if (SAFE_MISSING_API_KEY_PROVIDERS.has(provider)) return `⚠️ Missing API key for provider "${provider}". Configure the gateway auth for that provider, then try again.`;
527
- return "⚠️ Missing API key for the selected provider on the gateway. Configure provider auth, then try again.";
528
- }
529
- function formatForwardedExternalRunFailureText(message) {
530
- const sanitized = sanitizeUserFacingText(message, { errorContext: true }).trim().replace(/^⚠️\s*/u, "").replace(/\s+/gu, " ");
531
- if (!sanitized) return GENERIC_EXTERNAL_RUN_FAILURE_TEXT;
532
- const detail = sanitized.length > EXTERNAL_RUN_FAILURE_DETAIL_MAX_CHARS ? `${sanitized.slice(0, EXTERNAL_RUN_FAILURE_DETAIL_MAX_CHARS - 1).trimEnd()}…` : sanitized;
533
- return `⚠️ Agent failed before reply: ${detail}${/[.!?]$/u.test(detail) ? "" : "."} Please try again, or use /new to start a fresh session.`;
534
- }
535
- function buildExternalRunFailureReply(message, options) {
536
- const normalizedMessage = collapseRepeatedFailureDetail(message);
537
- const providerRequestError = classifyProviderRequestError(normalizedMessage);
538
- if (providerRequestError) return {
539
- text: providerRequestError.userMessage,
540
- isGenericRunnerFailure: false
541
- };
542
- const missingApiKeyFailure = buildMissingApiKeyFailureText(normalizedMessage);
543
- if (missingApiKeyFailure) return {
544
- text: missingApiKeyFailure,
545
- isGenericRunnerFailure: false
546
- };
547
- const oauthRefreshFailure = classifyOAuthRefreshFailure(normalizedMessage);
548
- if (oauthRefreshFailure) {
549
- const loginCommand = buildOAuthRefreshFailureLoginCommand(oauthRefreshFailure.provider);
550
- if (oauthRefreshFailure.reason) return {
551
- text: `⚠️ Model login expired on the gateway${oauthRefreshFailure.provider ? ` for ${oauthRefreshFailure.provider}` : ""}. Re-auth with \`${loginCommand}\`, then try again.`,
552
- isGenericRunnerFailure: false
553
- };
554
- return {
555
- text: `⚠️ Model login failed on the gateway${oauthRefreshFailure.provider ? ` for ${oauthRefreshFailure.provider}` : ""}. Please try again. If this keeps happening, re-auth with \`${loginCommand}\`.`,
556
- isGenericRunnerFailure: false
557
- };
558
- }
559
- if (options?.isHeartbeat) return {
560
- text: HEARTBEAT_EXTERNAL_RUN_FAILURE_TEXT,
561
- isGenericRunnerFailure: false
562
- };
563
- const cliBackendTimeoutFailure = buildCliBackendTimeoutFailureText(normalizedMessage);
564
- if (cliBackendTimeoutFailure) return {
565
- text: cliBackendTimeoutFailure,
566
- isGenericRunnerFailure: false
567
- };
568
- const codexAppServerFailure = buildCodexAppServerFailureText(normalizedMessage);
569
- if (codexAppServerFailure) return {
570
- text: codexAppServerFailure,
571
- isGenericRunnerFailure: false
572
- };
573
- return {
574
- text: options?.includeDetails ? formatForwardedExternalRunFailureText(normalizedMessage) : GENERIC_EXTERNAL_RUN_FAILURE_TEXT,
575
- isGenericRunnerFailure: true
576
- };
577
- }
578
- function markAgentRunFailureReplyPayload(payload) {
579
- return markReplyPayloadForSourceSuppressionDelivery(payload);
580
- }
581
- function buildKnownAgentRunFailureReplyPayload(params) {
582
- const message = formatErrorMessage(params.err);
583
- const isFallbackSummary = isFallbackSummaryError(params.err);
584
- if (isFallbackSummary ? hasBillingAttemptSummary(params.err) : isBillingErrorMessage(message)) return markAgentRunFailureReplyPayload({ text: resolveExternalRunFailureTextForConversation({
585
- text: BILLING_ERROR_USER_MESSAGE,
586
- sessionCtx: params.sessionCtx,
587
- isGenericRunnerFailure: false,
588
- cfg: params.cfg
589
- }) });
590
- const isPureTransientSummary = isFallbackSummary ? isPureTransientRateLimitSummary(params.err) : false;
591
- const isRateLimit = isFallbackSummary ? isPureTransientSummary : isRateLimitErrorMessage(message);
592
- const rateLimitOrOverloadedCopy = !isFallbackSummary || isPureTransientSummary ? formatRateLimitOrOverloadedErrorCopy(message) : void 0;
593
- if (isRateLimit && !isOverloadedErrorMessage(message)) return markAgentRunFailureReplyPayload({ text: resolveExternalRunFailureTextForConversation({
594
- text: buildRateLimitCooldownMessage(params.err),
595
- sessionCtx: params.sessionCtx,
596
- isGenericRunnerFailure: false,
597
- cfg: params.cfg
598
- }) });
599
- if (rateLimitOrOverloadedCopy) return markAgentRunFailureReplyPayload({ text: resolveExternalRunFailureTextForConversation({
600
- text: rateLimitOrOverloadedCopy,
601
- sessionCtx: params.sessionCtx,
602
- isGenericRunnerFailure: false,
603
- cfg: params.cfg
604
- }) });
605
- const externalRunFailureReply = buildExternalRunFailureReply(message, { includeDetails: isVerboseFailureDetailEnabled(params.resolvedVerboseLevel) });
606
- if (externalRunFailureReply.isGenericRunnerFailure) return;
607
- return markAgentRunFailureReplyPayload({ text: resolveExternalRunFailureTextForConversation({
608
- text: externalRunFailureReply.text,
609
- sessionCtx: params.sessionCtx,
610
- isGenericRunnerFailure: false,
611
- cfg: params.cfg
612
- }) });
613
- }
614
- const CONTEXT_OVERFLOW_RESET_HINT = "\n\nTo prevent this, increase your compaction buffer by setting `agents.defaults.compaction.reserveTokensFloor` to 20000 or higher in your config.";
615
- function resolveAgentHeartbeatModelRaw(params) {
616
- const defaultModel = normalizeOptionalString(params.cfg.agents?.defaults?.heartbeat?.model);
617
- const agentId = normalizeLowercaseStringOrEmpty(params.agentId);
618
- return (agentId ? normalizeOptionalString(params.cfg.agents?.list?.find((entry) => normalizeLowercaseStringOrEmpty(entry?.id) === agentId)?.heartbeat?.model) : void 0) ?? defaultModel;
619
- }
620
- function normalizeModelRefForCompare(ref) {
621
- if (!ref) return;
622
- const provider = normalizeLowercaseStringOrEmpty(ref.provider);
623
- const model = normalizeLowercaseStringOrEmpty(ref.model);
624
- return provider && model ? {
625
- provider,
626
- model
627
- } : void 0;
628
- }
629
- function modelRefsEqual(left, right) {
630
- const normalizedLeft = normalizeModelRefForCompare(left);
631
- const normalizedRight = normalizeModelRefForCompare(right);
632
- if (!normalizedLeft || !normalizedRight) return false;
633
- return normalizedLeft.provider === normalizedRight.provider && normalizedLeft.model === normalizedRight.model;
634
- }
635
- function formatContextWindowLabel(tokens) {
636
- if (tokens >= 1e6) return `${Math.round(tokens / 1e6 * 10) / 10}M`;
637
- return `${Math.round(tokens / 1024)}k`;
638
- }
639
- function normalizePositiveContextTokens(value) {
640
- if (typeof value !== "number" || !Number.isFinite(value) || value <= 0) return;
641
- return Math.floor(value);
642
- }
643
- function resolveAgentContextTokensForHint(params) {
644
- const defaultContextTokens = normalizePositiveContextTokens(params.cfg.agents?.defaults?.contextTokens);
645
- const agentId = normalizeLowercaseStringOrEmpty(params.agentId);
646
- return (agentId ? normalizePositiveContextTokens(params.cfg.agents?.list?.find((entry) => normalizeLowercaseStringOrEmpty(entry?.id) === agentId)?.contextTokens) : void 0) ?? defaultContextTokens;
647
- }
648
- function resolveContextWindowForHint(params) {
649
- const sessionContextTokens = normalizePositiveContextTokens(params.activeSessionEntry?.contextTokens);
650
- const contextTokens = resolveContextTokensForModel({
651
- cfg: params.cfg,
652
- provider: params.ref.provider,
653
- model: params.ref.model,
654
- allowAsyncLoad: false
655
- }) ?? sessionContextTokens;
656
- if (contextTokens === void 0) return;
657
- const agentContextTokens = resolveAgentContextTokensForHint({
658
- cfg: params.cfg,
659
- agentId: params.agentId
660
- });
661
- return agentContextTokens !== void 0 ? Math.min(agentContextTokens, contextTokens) : contextTokens;
662
- }
663
- function resolveHeartbeatBleedHint(params) {
664
- const primaryProvider = normalizeOptionalString(params.primaryProvider);
665
- const primaryModel = normalizeOptionalString(params.primaryModel);
666
- if (!primaryProvider || !primaryModel) return;
667
- const runtimeProvider = normalizeOptionalString(params.activeSessionEntry?.modelProvider);
668
- const runtimeModel = normalizeOptionalString(params.activeSessionEntry?.model);
669
- if (!runtimeProvider || !runtimeModel) return;
670
- const primaryRef = {
671
- provider: primaryProvider,
672
- model: primaryModel
673
- };
674
- const runtimeRef = {
675
- provider: runtimeProvider,
676
- model: runtimeModel
677
- };
678
- if (modelRefsEqual(primaryRef, runtimeRef)) return;
679
- const heartbeatModelRaw = resolveAgentHeartbeatModelRaw({
680
- cfg: params.cfg,
681
- agentId: params.agentId
682
- });
683
- if (!modelRefsEqual(runtimeRef, heartbeatModelRaw ? resolveModelRefFromString({
684
- cfg: params.cfg,
685
- raw: heartbeatModelRaw,
686
- defaultProvider: primaryProvider
687
- })?.ref : void 0)) return;
688
- const runtimeWindow = resolveContextWindowForHint({
689
- cfg: params.cfg,
690
- agentId: params.agentId,
691
- ref: runtimeRef,
692
- activeSessionEntry: params.activeSessionEntry
693
- });
694
- const primaryWindow = resolveContextWindowForHint({
695
- cfg: params.cfg,
696
- agentId: params.agentId,
697
- ref: primaryRef
698
- });
699
- if (typeof runtimeWindow === "number" && typeof primaryWindow === "number" && runtimeWindow >= primaryWindow) return;
700
- return `\n\nThe previous heartbeat turn left this session on ${runtimeProvider}/${runtimeModel}${typeof runtimeWindow === "number" && runtimeWindow > 0 ? ` (${formatContextWindowLabel(runtimeWindow)} context)` : ""} instead of ${primaryProvider}/${primaryModel}. This matches the configured \`heartbeat.model\`, so the overflow is likely heartbeat model bleed rather than a compaction-buffer problem. Set \`heartbeat.isolatedSession: true\`, enable \`heartbeat.lightContext: true\`, or use a heartbeat model with a larger context window.`;
701
- }
702
- function buildContextOverflowRecoveryText(params) {
703
- return (params.preserveSessionMapping ? "⚠️ Auto-compaction could not recover this turn. I kept this conversation mapped to the current session. Please try again, use /compact, or use /new to start a fresh session." : params.duringCompaction ? "⚠️ Context limit exceeded during compaction. I've reset our conversation to start fresh - please try again." : "⚠️ Context limit exceeded. I've reset our conversation to start fresh - please try again.") + (resolveHeartbeatBleedHint({
704
- cfg: params.cfg,
705
- agentId: params.agentId,
706
- primaryProvider: params.primaryProvider,
707
- primaryModel: params.primaryModel,
708
- activeSessionEntry: params.activeSessionEntry
709
- }) ?? CONTEXT_OVERFLOW_RESET_HINT);
710
- }
711
- function buildRestartLifecycleReplyText() {
712
- return "⚠️ Gateway is restarting. Please wait a few seconds and try again.";
713
- }
714
- function resolveRestartLifecycleError(err) {
715
- const pending = [err];
716
- const seen = /* @__PURE__ */ new Set();
717
- let pendingIndex = 0;
718
- while (pendingIndex < pending.length) {
719
- const candidate = pending[pendingIndex++];
720
- if (!candidate || seen.has(candidate)) continue;
721
- seen.add(candidate);
722
- if (candidate instanceof GatewayDrainingError || candidate instanceof CommandLaneClearedError) return candidate;
723
- if (isFallbackSummaryError(candidate)) for (const attempt of candidate.attempts) pending.push(attempt.error);
724
- if (candidate instanceof Error && "cause" in candidate) pending.push(candidate.cause);
725
- }
726
- }
727
- function isReplyOperationUserAbort(replyOperation) {
728
- return replyOperation?.result?.kind === "aborted" && replyOperation.result.code === "aborted_by_user";
729
- }
730
- function isReplyOperationRestartAbort(replyOperation) {
731
- return replyOperation?.result?.kind === "aborted" && replyOperation.result.code === "aborted_for_restart";
732
- }
733
- function createEmbeddedLifecycleTerminalBackstop(params) {
734
- let terminalEmitted = false;
735
- let startedAt;
736
- const note = (evt) => {
737
- if (evt.stream !== "lifecycle") return;
738
- const phase = readStringValue(evt.data.phase);
739
- if (phase === "start" && typeof evt.data.startedAt === "number") startedAt = evt.data.startedAt;
740
- if (phase === "end" || phase === "error") terminalEmitted = true;
741
- };
742
- const emit = (phase, resultOrError) => {
743
- if (terminalEmitted) return;
744
- terminalEmitted = true;
745
- const data = {
746
- phase,
747
- endedAt: Date.now(),
748
- ...startedAt !== void 0 ? { startedAt } : {}
749
- };
750
- if (phase === "error") data.error = formatErrorMessage(resultOrError);
751
- else {
752
- const meta = resultOrError && typeof resultOrError === "object" && "meta" in resultOrError ? resultOrError.meta : void 0;
753
- if (meta?.aborted === true) data.aborted = true;
754
- const stopReason = readStringValue(meta?.stopReason);
755
- if (stopReason) data.stopReason = stopReason;
756
- const livenessState = readStringValue(meta?.livenessState);
757
- if (livenessState) data.livenessState = livenessState;
758
- if (meta?.replayInvalid === true) data.replayInvalid = true;
759
- }
760
- emitAgentEvent({
761
- runId: params.runId,
762
- ...params.sessionKey ? { sessionKey: params.sessionKey } : {},
763
- stream: "lifecycle",
764
- data
765
- });
766
- };
767
- return {
768
- emit,
769
- note
770
- };
771
- }
772
- function emitModelFallbackStepLifecycle(params) {
773
- emitAgentEvent({
774
- runId: params.runId,
775
- ...params.sessionKey ? { sessionKey: params.sessionKey } : {},
776
- stream: "lifecycle",
777
- data: {
778
- phase: "fallback_step",
779
- ...params.step
780
- }
781
- });
782
- }
783
- function resolveSessionRuntimeOverrideForProvider(params) {
784
- const provider = normalizeLowercaseStringOrEmpty(params.provider);
785
- const runtime = normalizeLowercaseStringOrEmpty(params.entry?.agentRuntimeOverride);
786
- if (!runtime || runtime === "auto" || runtime === "default") return;
787
- if (runtime === "pi") return "pi";
788
- if (provider === "openai" && runtime === "codex") return "codex";
789
- return listLegacyRuntimeModelProviderAliases().find((alias) => normalizeLowercaseStringOrEmpty(alias.provider) === provider && normalizeLowercaseStringOrEmpty(alias.runtime) === runtime)?.runtime;
790
- }
791
- function resolveRunAfterAutoFallbackPrimaryProbeRecheck(params) {
792
- const probe = params.run.autoFallbackPrimaryProbe;
793
- if (!probe || !params.sessionKey) return params.run;
794
- if (!params.entry) return params.run;
795
- const resolveEntrySelectionRun = () => {
796
- const entryRef = resolvePersistedOverrideModelRef({
797
- defaultProvider: params.run.provider,
798
- overrideProvider: params.entry?.providerOverride,
799
- overrideModel: params.entry?.modelOverride
800
- });
801
- const hasEntryModelOverride = Boolean(entryRef);
802
- const authProfileId = normalizeOptionalString(params.entry?.authProfileOverride);
803
- const fallbackRun = {
804
- ...params.run,
805
- provider: entryRef?.provider ?? params.run.provider,
806
- model: entryRef?.model ?? params.run.model,
807
- autoFallbackPrimaryProbe: void 0
808
- };
809
- if (hasEntryModelOverride) {
810
- fallbackRun.hasSessionModelOverride = true;
811
- fallbackRun.hasAutoFallbackProvenance = hasSessionAutoModelFallbackProvenance(params.entry) || void 0;
812
- } else {
813
- delete fallbackRun.hasSessionModelOverride;
814
- delete fallbackRun.hasAutoFallbackProvenance;
815
- }
816
- if (hasEntryModelOverride && params.entry?.modelOverrideSource) fallbackRun.modelOverrideSource = params.entry.modelOverrideSource;
817
- else delete fallbackRun.modelOverrideSource;
818
- if (hasEntryModelOverride && authProfileId) {
819
- fallbackRun.authProfileId = authProfileId;
820
- if (params.entry?.authProfileOverrideSource) fallbackRun.authProfileIdSource = params.entry.authProfileOverrideSource;
821
- else delete fallbackRun.authProfileIdSource;
822
- } else if (hasEntryModelOverride) {
823
- delete fallbackRun.authProfileId;
824
- delete fallbackRun.authProfileIdSource;
825
- }
826
- return fallbackRun;
827
- };
828
- const refreshedProbe = resolveAutoFallbackPrimaryProbe({
829
- entry: params.entry,
830
- sessionKey: params.sessionKey,
831
- primaryProvider: probe.provider,
832
- primaryModel: probe.model
833
- });
834
- if (!refreshedProbe) return resolveEntrySelectionRun();
835
- return {
836
- ...params.run,
837
- provider: refreshedProbe.provider,
838
- model: refreshedProbe.model,
839
- autoFallbackPrimaryProbe: refreshedProbe
840
- };
841
- }
842
- async function runAgentTurnWithFallback(params) {
843
- const TRANSIENT_HTTP_RETRY_DELAY_MS = 2500;
844
- let didLogHeartbeatStrip = false;
845
- let autoCompactionCount = 0;
846
- const directlySentBlockKeys = /* @__PURE__ */ new Set();
847
- let runnableRun = resolveRunAfterAutoFallbackPrimaryProbeRecheck({
848
- run: params.followupRun.run,
849
- entry: params.activeSessionStore?.[params.sessionKey ?? ""] ?? params.getActiveSessionEntry(),
850
- sessionKey: params.sessionKey
851
- });
852
- if (runnableRun !== params.followupRun.run) params.followupRun.run = runnableRun;
853
- const runtimeConfig = resolveQueuedReplyRuntimeConfig(runnableRun.config);
854
- let effectiveRun = runtimeConfig === runnableRun.config ? runnableRun : {
855
- ...runnableRun,
856
- config: runtimeConfig
857
- };
858
- const resolveRunForFallbackCandidate = (provider, model) => {
859
- const probe = effectiveRun.autoFallbackPrimaryProbe;
860
- const isPrimaryProbeCandidate = probe && provider === probe.provider && model === probe.model;
861
- if (probe && provider === probe.fallbackProvider && !isPrimaryProbeCandidate && probe.fallbackAuthProfileId) {
862
- const candidateRun = {
863
- ...effectiveRun,
864
- provider,
865
- model,
866
- authProfileId: probe.fallbackAuthProfileId
867
- };
868
- if (probe.fallbackAuthProfileIdSource) candidateRun.authProfileIdSource = probe.fallbackAuthProfileIdSource;
869
- else delete candidateRun.authProfileIdSource;
870
- return candidateRun;
871
- }
872
- return effectiveRun;
873
- };
874
- const applyLiveModelSwitchToRun = (run, err) => {
875
- run.provider = err.provider;
876
- run.model = err.model;
877
- run.authProfileId = err.authProfileId;
878
- run.authProfileIdSource = err.authProfileId ? err.authProfileIdSource : void 0;
879
- run.autoFallbackPrimaryProbe = void 0;
880
- };
881
- const runId = params.opts?.runId ?? crypto.randomUUID();
882
- if (isDiagnosticsEnabled(runtimeConfig)) logSessionTurnCreated({
883
- runId,
884
- sessionKey: params.sessionKey,
885
- sessionId: params.followupRun.run.sessionId,
886
- agentId: params.followupRun.run.agentId,
887
- channel: params.followupRun.run.messageProvider ?? params.sessionCtx.Surface ?? params.sessionCtx.Provider,
888
- trigger: params.isHeartbeat ? "heartbeat" : "user"
889
- });
890
- const replyMediaContext = params.replyMediaContext ?? createReplyMediaContext({
891
- cfg: runtimeConfig,
892
- sessionKey: params.sessionKey,
893
- workspaceDir: params.followupRun.run.workspaceDir,
894
- messageProvider: params.followupRun.run.messageProvider,
895
- accountId: params.followupRun.originatingAccountId ?? params.followupRun.run.agentAccountId,
896
- groupId: params.followupRun.run.groupId,
897
- groupChannel: params.followupRun.run.groupChannel,
898
- groupSpace: params.followupRun.run.groupSpace,
899
- requesterSenderId: params.followupRun.run.senderId,
900
- requesterSenderName: params.followupRun.run.senderName,
901
- requesterSenderUsername: params.followupRun.run.senderUsername,
902
- requesterSenderE164: params.followupRun.run.senderE164
903
- });
904
- const currentTurnImages = await resolveCurrentTurnImages({
905
- ctx: params.sessionCtx,
906
- cfg: runtimeConfig,
907
- images: params.followupRun.images ?? params.opts?.images,
908
- imageOrder: params.followupRun.imageOrder ?? params.opts?.imageOrder
909
- });
910
- let didNotifyAgentRunStart = false;
911
- const notifyAgentRunStart = () => {
912
- if (didNotifyAgentRunStart) return;
913
- didNotifyAgentRunStart = true;
914
- params.opts?.onAgentRunStart?.(runId);
915
- };
916
- const currentMessageId = params.sessionCtx.MessageSidFull ?? params.sessionCtx.MessageSid;
917
- const shouldNotifyUserAboutCompaction = runtimeConfig?.agents?.defaults?.compaction?.notifyUser === true;
918
- const sendCompactionNotice = async (phase) => {
919
- if (!params.opts?.onBlockReply) return;
920
- const text = phase === "start" ? "🧹 Compacting context..." : phase === "end" ? "🧹 Compaction complete" : "🧹 Compaction incomplete";
921
- const noticePayload = params.applyReplyToMode({
922
- text,
923
- replyToId: currentMessageId,
924
- replyToCurrent: true,
925
- isCompactionNotice: true
926
- });
927
- try {
928
- await params.opts.onBlockReply(noticePayload);
929
- } catch (err) {
930
- logVerbose(`compaction ${phase} notice delivery failed (non-fatal): ${String(err)}`);
931
- }
932
- };
933
- const readCompactionHookMessages = (value) => {
934
- if (!Array.isArray(value)) return [];
935
- return value.filter((entry) => typeof entry === "string").map((entry) => entry.trim()).filter((entry) => entry.length > 0);
936
- };
937
- const sendCompactionHookMessages = async (messages) => {
938
- if (!params.opts?.onBlockReply || messages.length === 0) return;
939
- const noticePayload = params.applyReplyToMode({
940
- text: messages.join("\n\n"),
941
- replyToId: currentMessageId,
942
- replyToCurrent: true,
943
- isCompactionNotice: true
944
- });
945
- try {
946
- await params.opts.onBlockReply(noticePayload);
947
- } catch (err) {
948
- logVerbose(`compaction hook notice delivery failed (non-fatal): ${String(err)}`);
949
- }
950
- };
951
- const shouldSurfaceToControlUi = isInternalMessageChannel(params.followupRun.run.messageProvider ?? params.sessionCtx.Surface ?? params.sessionCtx.Provider);
952
- if (params.sessionKey) registerAgentRunContext(runId, {
953
- sessionKey: params.sessionKey,
954
- verboseLevel: params.resolvedVerboseLevel,
955
- isHeartbeat: params.isHeartbeat,
956
- isControlUiVisible: shouldSurfaceToControlUi
957
- });
958
- let runResult;
959
- let fallbackProvider = params.followupRun.run.provider;
960
- let fallbackModel = params.followupRun.run.model;
961
- let fallbackAttempts = [];
962
- let didRetryTransientHttpError = false;
963
- let liveModelSwitchRetries = 0;
964
- let bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(params.getActiveSessionEntry()?.systemPromptReport);
965
- let pendingFallbackCandidateRollback;
966
- const clearPendingFallbackRollback = (rollback) => {
967
- if (!rollback || pendingFallbackCandidateRollback?.rollback === rollback) pendingFallbackCandidateRollback = void 0;
968
- };
969
- const rollbackClassifiedFallbackCandidateSelection = async (provider, model) => {
970
- const pending = pendingFallbackCandidateRollback;
971
- if (!pending || pending.provider !== provider || pending.model !== model) return;
972
- pendingFallbackCandidateRollback = void 0;
973
- try {
974
- await pending.rollback();
975
- } catch (rollbackError) {
976
- logVerbose(`failed to roll back classified fallback candidate selection (non-fatal): ${String(rollbackError)}`);
977
- }
978
- };
979
- const persistFallbackCandidateSelection = async (provider, model, candidateRun) => {
980
- if (effectiveRun.hasOneTurnModelOverride === true) return;
981
- if (!params.sessionKey || !params.activeSessionStore || provider === effectiveRun.provider && model === effectiveRun.model) return;
982
- const activeSessionEntry = params.activeSessionStore[params.sessionKey] ?? params.getActiveSessionEntry();
983
- if (!activeSessionEntry) return;
984
- if (activeSessionEntry.modelOverrideSource === "user" || activeSessionEntry.modelOverrideSource === void 0 && Boolean(normalizeOptionalString(activeSessionEntry.modelOverride)) && !hasSessionAutoModelFallbackProvenance(activeSessionEntry)) return;
985
- const previousState = snapshotFallbackSelectionState(activeSessionEntry);
986
- const applied = applyFallbackCandidateSelectionToEntry({
987
- entry: activeSessionEntry,
988
- run: candidateRun !== effectiveRun && effectiveRun.autoFallbackPrimaryProbe ? {
989
- ...candidateRun,
990
- provider: candidateRun.provider,
991
- model: effectiveRun.model
992
- } : candidateRun,
993
- provider,
994
- model,
995
- force: candidateRun !== effectiveRun && Boolean(effectiveRun.autoFallbackPrimaryProbe),
996
- ...effectiveRun.autoFallbackPrimaryProbe ? { origin: {
997
- provider: effectiveRun.autoFallbackPrimaryProbe.provider,
998
- model: effectiveRun.autoFallbackPrimaryProbe.model
999
- } } : {}
1000
- });
1001
- const nextState = applied.nextState;
1002
- if (!applied.updated || !nextState) return;
1003
- params.activeSessionStore[params.sessionKey] = activeSessionEntry;
1004
- try {
1005
- if (params.storePath) await updateSessionStore(params.storePath, (store) => {
1006
- const persistedEntry = store[params.sessionKey];
1007
- if (!persistedEntry) return;
1008
- applyFallbackSelectionState(persistedEntry, nextState);
1009
- store[params.sessionKey] = persistedEntry;
1010
- });
1011
- } catch (error) {
1012
- rollbackFallbackSelectionStateIfUnchanged(activeSessionEntry, nextState, previousState);
1013
- params.activeSessionStore[params.sessionKey] = activeSessionEntry;
1014
- throw error;
1015
- }
1016
- return async () => {
1017
- if (rollbackFallbackSelectionStateIfUnchanged(activeSessionEntry, nextState, previousState)) params.activeSessionStore[params.sessionKey] = activeSessionEntry;
1018
- if (!params.storePath) return;
1019
- await updateSessionStore(params.storePath, (store) => {
1020
- const persistedEntry = store[params.sessionKey];
1021
- if (!persistedEntry) return;
1022
- if (rollbackFallbackSelectionStateIfUnchanged(persistedEntry, nextState, previousState)) store[params.sessionKey] = persistedEntry;
1023
- });
1024
- };
1025
- };
1026
- const clearRecoveredAutoFallbackPrimaryProbe = async (paramsForClear) => {
1027
- const probe = effectiveRun.autoFallbackPrimaryProbe;
1028
- if (!probe) return;
1029
- if (paramsForClear.provider !== probe.provider || paramsForClear.model !== probe.model) return;
1030
- if (!params.sessionKey || !params.activeSessionStore) return;
1031
- const activeSessionEntry = params.activeSessionStore[params.sessionKey] ?? params.getActiveSessionEntry();
1032
- if (!activeSessionEntry) return;
1033
- if (!entryMatchesAutoFallbackPrimaryProbe(activeSessionEntry, probe)) return;
1034
- clearAutoFallbackPrimaryProbeSelection(activeSessionEntry);
1035
- params.activeSessionStore[params.sessionKey] = activeSessionEntry;
1036
- if (!params.storePath) return;
1037
- await updateSessionStore(params.storePath, (store) => {
1038
- const persistedEntry = store[params.sessionKey];
1039
- if (!persistedEntry) return;
1040
- if (!entryMatchesAutoFallbackPrimaryProbe(persistedEntry, probe)) return;
1041
- clearAutoFallbackPrimaryProbeSelection(persistedEntry);
1042
- store[params.sessionKey] = persistedEntry;
1043
- });
1044
- };
1045
- while (true) try {
1046
- const normalizeStreamingText = (payload) => {
1047
- let text = payload.text;
1048
- const reply = resolveSendableOutboundReplyParts(payload);
1049
- if (params.followupRun.run.silentExpected) return { skip: true };
1050
- if (!params.isHeartbeat && text?.includes("HEARTBEAT_OK")) {
1051
- const stripped = stripHeartbeatToken(text, { mode: "message" });
1052
- if (stripped.didStrip && !didLogHeartbeatStrip) {
1053
- didLogHeartbeatStrip = true;
1054
- logVerbose("Stripped stray HEARTBEAT_OK token from reply");
1055
- }
1056
- if (stripped.shouldSkip && !reply.hasMedia) return { skip: true };
1057
- text = stripped.text;
1058
- }
1059
- if (isSilentReplyText(text, "NO_REPLY")) return { skip: true };
1060
- if (isSilentReplyPrefixText(text, "NO_REPLY") || isSilentReplyPrefixText(text, "HEARTBEAT_OK")) return { skip: true };
1061
- if (text && startsWithSilentToken(text, "NO_REPLY")) text = stripLeadingSilentToken(text, SILENT_REPLY_TOKEN);
1062
- if (!text) {
1063
- if (reply.hasMedia) return {
1064
- text: void 0,
1065
- skip: false
1066
- };
1067
- return { skip: true };
1068
- }
1069
- const sanitized = sanitizeUserFacingText(text, { errorContext: Boolean(payload.isError) });
1070
- if (!sanitized.trim()) return { skip: true };
1071
- return {
1072
- text: sanitized,
1073
- skip: false
1074
- };
1075
- };
1076
- const handlePartialForTyping = async (payload) => {
1077
- if (isSilentReplyPrefixText(payload.text, "NO_REPLY")) return;
1078
- const { text, skip } = normalizeStreamingText(payload);
1079
- if (skip || !text) return;
1080
- await params.typingSignals.signalTextDelta(text);
1081
- return text;
1082
- };
1083
- const blockReplyPipeline = params.blockReplyPipeline;
1084
- const blockReplyHandler = params.opts?.onBlockReply ? createBlockReplyDeliveryHandler({
1085
- onBlockReply: params.opts.onBlockReply,
1086
- currentMessageId: params.sessionCtx.MessageSidFull ?? params.sessionCtx.MessageSid,
1087
- replyThreading: params.replyThreading,
1088
- normalizeStreamingText,
1089
- applyReplyToMode: params.applyReplyToMode,
1090
- normalizeMediaPaths: replyMediaContext.normalizePayload,
1091
- typingSignals: params.typingSignals,
1092
- blockStreamingEnabled: params.blockStreamingEnabled,
1093
- blockReplyPipeline,
1094
- directlySentBlockKeys
1095
- }) : void 0;
1096
- let messageToolOnlyDeliveryCompleted = false;
1097
- const messageToolOnlyDeliveryToolCallIds = /* @__PURE__ */ new Set();
1098
- const sourceRepliesAreToolOnly = params.followupRun.run.sourceReplyDeliveryMode === "message_tool_only";
1099
- const shouldSuppressProgressAfterMessageToolDelivery = () => sourceRepliesAreToolOnly && messageToolOnlyDeliveryCompleted;
1100
- const onToolResult = params.opts?.onToolResult;
1101
- const outcomePlan = buildAgentRuntimeOutcomePlan();
1102
- const runLane = "main";
1103
- let queuedUserMessagePersistedAcrossFallback = false;
1104
- let assistantErrorPersistedAcrossFallback = false;
1105
- const fallbackResult = await runWithModelFallback({
1106
- ...resolveModelFallbackOptions(effectiveRun, runtimeConfig),
1107
- runId,
1108
- sessionId: params.followupRun.run.sessionId,
1109
- lane: runLane,
1110
- resolveAgentHarnessRuntimeOverride: (provider) => resolveSessionRuntimeOverrideForProvider({
1111
- provider,
1112
- entry: params.getActiveSessionEntry()
1113
- }),
1114
- prepareAgentHarnessRuntime: async ({ provider, model, agentHarnessRuntimeOverride }) => {
1115
- await ensureSelectedAgentHarnessPlugin({
1116
- config: runtimeConfig,
1117
- provider,
1118
- modelId: model,
1119
- agentId: params.followupRun.run.agentId,
1120
- sessionKey: params.followupRun.run.runtimePolicySessionKey ?? params.sessionKey,
1121
- agentHarnessRuntimeOverride,
1122
- workspaceDir: params.followupRun.run.workspaceDir
1123
- });
1124
- },
1125
- onFallbackStep: (step) => {
1126
- emitModelFallbackStepLifecycle({
1127
- runId,
1128
- sessionKey: params.sessionKey,
1129
- step
1130
- });
1131
- },
1132
- classifyResult: async ({ result, provider, model }) => {
1133
- const classification = outcomePlan.classifyRunResult({
1134
- result,
1135
- provider,
1136
- model,
1137
- hasDirectlySentBlockReply: directlySentBlockKeys.size > 0,
1138
- hasBlockReplyPipelineOutput: Boolean(blockReplyPipeline?.hasBuffered() || blockReplyPipeline?.didStream())
1139
- });
1140
- if (classification) await rollbackClassifiedFallbackCandidateSelection(provider, model);
1141
- return classification;
1142
- },
1143
- run: async (provider, model, runOptions) => {
1144
- const suppressQueuedUserPersistenceForCandidate = (params.followupRun.run.suppressNextUserMessagePersistence ?? false) || queuedUserMessagePersistedAcrossFallback;
1145
- const suppressAssistantErrorPersistenceForCandidate = assistantErrorPersistedAcrossFallback;
1146
- const candidateRun = resolveRunForFallbackCandidate(provider, model);
1147
- const activeProbe = effectiveRun.autoFallbackPrimaryProbe;
1148
- if (activeProbe && provider === activeProbe.provider && model === activeProbe.model) markAutoFallbackPrimaryProbe({
1149
- probe: activeProbe,
1150
- sessionKey: params.sessionKey
1151
- });
1152
- params.opts?.onModelSelected?.({
1153
- provider,
1154
- model,
1155
- thinkLevel: params.followupRun.run.thinkLevel
1156
- });
1157
- let rollbackFallbackCandidateSelection;
1158
- try {
1159
- rollbackFallbackCandidateSelection = await persistFallbackCandidateSelection(provider, model, candidateRun);
1160
- if (rollbackFallbackCandidateSelection) pendingFallbackCandidateRollback = {
1161
- provider,
1162
- model,
1163
- rollback: rollbackFallbackCandidateSelection
1164
- };
1165
- } catch (error) {
1166
- logVerbose(`failed to persist fallback candidate selection (non-fatal): ${String(error)}`);
1167
- }
1168
- const sessionRuntimeOverride = resolveSessionRuntimeOverrideForProvider({
1169
- provider,
1170
- entry: params.getActiveSessionEntry()
1171
- });
1172
- const selectedAuthProfile = resolveRunAuthProfile(candidateRun, provider, { config: runtimeConfig });
1173
- const cliExecutionProvider = sessionRuntimeOverride === "pi" ? provider : (sessionRuntimeOverride && isCliProvider(sessionRuntimeOverride, runtimeConfig) ? sessionRuntimeOverride : void 0) ?? resolveCliRuntimeExecutionProvider({
1174
- provider,
1175
- cfg: runtimeConfig,
1176
- agentId: params.followupRun.run.agentId,
1177
- modelId: model,
1178
- authProfileId: selectedAuthProfile.authProfileId
1179
- }) ?? provider;
1180
- if (isCliProvider(cliExecutionProvider, runtimeConfig)) {
1181
- const isRoomEventCliRun = params.followupRun.currentInboundEventKind === "room_event";
1182
- const cliSessionBinding = isRoomEventCliRun ? void 0 : getCliSessionBinding(params.getActiveSessionEntry(), cliExecutionProvider);
1183
- const authProfile = resolveRunAuthProfile(candidateRun, cliExecutionProvider, { config: runtimeConfig });
1184
- const hookMessageProvider = resolveOriginMessageProvider({
1185
- originatingChannel: params.followupRun.originatingChannel,
1186
- provider: params.sessionCtx.Provider
1187
- });
1188
- const result = await runCliAgentWithLifecycle({
1189
- runId,
1190
- provider: cliExecutionProvider,
1191
- onAgentRunStart: notifyAgentRunStart,
1192
- suppressAssistantBridge: params.followupRun.run.silentExpected,
1193
- onAssistantText: async (text) => {
1194
- const textForTyping = await handlePartialForTyping({ text });
1195
- if (textForTyping === void 0 || !params.opts?.onPartialReply) return;
1196
- await params.opts.onPartialReply({ text: textForTyping });
1197
- },
1198
- onReasoningText: async (text) => {
1199
- await params.opts?.onReasoningStream?.({ text });
1200
- },
1201
- onErrorBeforeLifecycle: async () => {
1202
- if (!rollbackFallbackCandidateSelection) return;
1203
- try {
1204
- await rollbackFallbackCandidateSelection();
1205
- clearPendingFallbackRollback(rollbackFallbackCandidateSelection);
1206
- } catch (rollbackError) {
1207
- logVerbose(`failed to roll back fallback candidate selection (non-fatal): ${String(rollbackError)}`);
1208
- }
1209
- },
1210
- runParams: {
1211
- sessionId: params.followupRun.run.sessionId,
1212
- sessionKey: params.sessionKey,
1213
- agentId: params.followupRun.run.agentId,
1214
- trigger: params.isHeartbeat ? "heartbeat" : "user",
1215
- sessionFile: params.followupRun.run.sessionFile,
1216
- workspaceDir: params.followupRun.run.workspaceDir,
1217
- config: runtimeConfig,
1218
- prompt: params.commandBody,
1219
- transcriptPrompt: params.transcriptCommandBody,
1220
- currentInboundEventKind: params.followupRun.currentInboundEventKind,
1221
- currentInboundContext: params.followupRun.currentInboundContext,
1222
- inputProvenance: params.followupRun.run.inputProvenance,
1223
- provider: cliExecutionProvider,
1224
- model,
1225
- thinkLevel: params.followupRun.run.thinkLevel,
1226
- timeoutMs: params.followupRun.run.timeoutMs,
1227
- runId,
1228
- lane: runLane,
1229
- extraSystemPrompt: params.followupRun.run.extraSystemPrompt,
1230
- sourceReplyDeliveryMode: params.followupRun.run.sourceReplyDeliveryMode,
1231
- silentReplyPromptMode: params.followupRun.run.silentReplyPromptMode,
1232
- extraSystemPromptStatic: params.followupRun.run.extraSystemPromptStatic,
1233
- ownerNumbers: params.followupRun.run.ownerNumbers,
1234
- cliSessionId: cliSessionBinding?.sessionId,
1235
- cliSessionBinding,
1236
- authProfileId: authProfile.authProfileId,
1237
- bootstrapPromptWarningSignaturesSeen,
1238
- bootstrapPromptWarningSignature: bootstrapPromptWarningSignaturesSeen[bootstrapPromptWarningSignaturesSeen.length - 1],
1239
- images: currentTurnImages.images,
1240
- imageOrder: currentTurnImages.imageOrder,
1241
- skillsSnapshot: params.followupRun.run.skillsSnapshot,
1242
- messageChannel: params.followupRun.originatingChannel ?? void 0,
1243
- messageProvider: hookMessageProvider,
1244
- agentAccountId: params.followupRun.run.agentAccountId,
1245
- senderIsOwner: params.followupRun.run.senderIsOwner,
1246
- disableTools: params.opts?.disableTools,
1247
- abortSignal: params.replyOperation?.abortSignal ?? params.opts?.abortSignal,
1248
- replyOperation: params.replyOperation
1249
- },
1250
- transformResult: (rawResult) => isRoomEventCliRun && rawResult.meta.agentMeta ? (() => {
1251
- const { cliSessionBinding: _cliSessionBinding, ...agentMeta } = rawResult.meta.agentMeta;
1252
- return {
1253
- ...rawResult,
1254
- meta: {
1255
- ...rawResult.meta,
1256
- agentMeta: {
1257
- ...agentMeta,
1258
- sessionId: ""
1259
- }
1260
- }
1261
- };
1262
- })() : rawResult
1263
- });
1264
- bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(result.meta?.systemPromptReport);
1265
- return result;
1266
- }
1267
- const { embeddedContext, senderContext, runBaseParams } = buildEmbeddedRunExecutionParams({
1268
- run: candidateRun,
1269
- sessionCtx: params.sessionCtx,
1270
- hasRepliedRef: params.opts?.hasRepliedRef,
1271
- provider,
1272
- runId,
1273
- allowTransientCooldownProbe: runOptions?.allowTransientCooldownProbe,
1274
- model
1275
- });
1276
- const agentHarnessPolicy = sessionRuntimeOverride ? {
1277
- runtime: sessionRuntimeOverride,
1278
- runtimeSource: "model"
1279
- } : resolveAgentHarnessPolicy({
1280
- provider,
1281
- modelId: model,
1282
- config: runtimeConfig,
1283
- agentId: params.followupRun.run.agentId,
1284
- sessionKey: params.followupRun.run.runtimePolicySessionKey ?? params.sessionKey
1285
- });
1286
- const embeddedRunProvider = resolveOpenAIRuntimeProviderForPi({
1287
- provider,
1288
- harnessRuntime: agentHarnessPolicy.runtime,
1289
- authProfileProvider: runBaseParams.authProfileId?.split(":", 1)[0],
1290
- authProfileId: runBaseParams.authProfileId,
1291
- config: runtimeConfig,
1292
- workspaceDir: params.followupRun.run.workspaceDir
1293
- });
1294
- const embeddedRunHarnessOverride = sessionRuntimeOverride ?? (agentHarnessPolicy.runtime === "pi" && embeddedRunProvider !== provider ? "pi" : void 0);
1295
- return (async () => {
1296
- let attemptCompactionCount = 0;
1297
- const lifecycleBackstop = createEmbeddedLifecycleTerminalBackstop({
1298
- runId,
1299
- sessionKey: params.sessionKey
1300
- });
1301
- try {
1302
- const result = await runEmbeddedPiAgent({
1303
- ...embeddedContext,
1304
- allowGatewaySubagentBinding: true,
1305
- trigger: params.isHeartbeat ? "heartbeat" : "user",
1306
- groupId: resolveGroupSessionKey(params.sessionCtx)?.id,
1307
- groupChannel: normalizeOptionalString(params.sessionCtx.GroupChannel) ?? normalizeOptionalString(params.sessionCtx.GroupSubject),
1308
- groupSpace: normalizeOptionalString(params.sessionCtx.GroupSpace),
1309
- ...senderContext,
1310
- ...runBaseParams,
1311
- provider: embeddedRunProvider,
1312
- agentHarnessId: embeddedRunHarnessOverride,
1313
- agentHarnessRuntimeOverride: embeddedRunHarnessOverride,
1314
- sandboxSessionKey: params.runtimePolicySessionKey,
1315
- prompt: params.commandBody,
1316
- transcriptPrompt: params.transcriptCommandBody,
1317
- currentInboundEventKind: params.followupRun.currentInboundEventKind,
1318
- currentInboundContext: params.followupRun.currentInboundContext,
1319
- extraSystemPrompt: params.followupRun.run.extraSystemPrompt,
1320
- sourceReplyDeliveryMode: params.followupRun.run.sourceReplyDeliveryMode,
1321
- forceMessageTool: params.followupRun.run.sourceReplyDeliveryMode === "message_tool_only",
1322
- silentReplyPromptMode: params.followupRun.run.silentReplyPromptMode,
1323
- suppressNextUserMessagePersistence: suppressQueuedUserPersistenceForCandidate,
1324
- onUserMessagePersisted: () => {
1325
- queuedUserMessagePersistedAcrossFallback = true;
1326
- },
1327
- suppressTranscriptOnlyAssistantPersistence: params.followupRun.run.suppressTranscriptOnlyAssistantPersistence,
1328
- suppressAssistantErrorPersistence: suppressAssistantErrorPersistenceForCandidate,
1329
- onAssistantErrorMessagePersisted: () => {
1330
- assistantErrorPersistedAcrossFallback = true;
1331
- },
1332
- toolResultFormat: (() => {
1333
- const channel = resolveMessageChannel(params.sessionCtx.Surface, params.sessionCtx.Provider);
1334
- if (!channel) return "markdown";
1335
- return isMarkdownCapableMessageChannel(channel) ? "markdown" : "plain";
1336
- })(),
1337
- toolProgressDetail: params.toolProgressDetail,
1338
- suppressToolErrorWarnings: params.opts?.suppressToolErrorWarnings,
1339
- disableTools: params.opts?.disableTools,
1340
- enableHeartbeatTool: params.opts?.enableHeartbeatTool,
1341
- forceHeartbeatTool: params.opts?.forceHeartbeatTool,
1342
- bootstrapContextMode: params.opts?.bootstrapContextMode,
1343
- bootstrapContextRunKind: params.opts?.isHeartbeat ? "heartbeat" : "default",
1344
- images: currentTurnImages.images,
1345
- imageOrder: currentTurnImages.imageOrder,
1346
- abortSignal: params.replyOperation?.abortSignal ?? params.opts?.abortSignal,
1347
- replyOperation: params.replyOperation,
1348
- blockReplyBreak: params.resolvedBlockStreamingBreak,
1349
- blockReplyChunking: params.blockReplyChunking,
1350
- onPartialReply: async (payload) => {
1351
- const textForTyping = await handlePartialForTyping(payload);
1352
- if (!params.opts?.onPartialReply || textForTyping === void 0) return;
1353
- await params.opts.onPartialReply({
1354
- text: textForTyping,
1355
- mediaUrls: payload.mediaUrls
1356
- });
1357
- },
1358
- onAssistantMessageStart: async () => {
1359
- await params.typingSignals.signalMessageStart();
1360
- await params.opts?.onAssistantMessageStart?.();
1361
- },
1362
- onReasoningStream: params.typingSignals.shouldStartOnReasoning || params.opts?.onReasoningStream ? async (payload) => {
1363
- if (params.followupRun.run.silentExpected) return;
1364
- await params.typingSignals.signalReasoningDelta();
1365
- await params.opts?.onReasoningStream?.({
1366
- text: payload.text,
1367
- mediaUrls: payload.mediaUrls
1368
- });
1369
- } : void 0,
1370
- onReasoningEnd: params.opts?.onReasoningEnd,
1371
- onAgentEvent: async (evt) => {
1372
- lifecycleBackstop.note(evt);
1373
- const hasLifecyclePhase = evt.stream === "lifecycle" && typeof evt.data.phase === "string";
1374
- if (evt.stream !== "lifecycle" || hasLifecyclePhase) notifyAgentRunStart();
1375
- if (evt.stream === "tool") {
1376
- const phase = readStringValue(evt.data.phase) ?? "";
1377
- const name = readStringValue(evt.data.name);
1378
- const toolCallId = readStringValue(evt.data.toolCallId) ?? "";
1379
- const args = evt.data.args && typeof evt.data.args === "object" ? evt.data.args : void 0;
1380
- if (sourceRepliesAreToolOnly && toolCallId && name && (phase === "start" || phase === "update") && args && isMessagingToolSendAction(name, args)) messageToolOnlyDeliveryToolCallIds.add(toolCallId);
1381
- if (shouldSuppressProgressAfterMessageToolDelivery()) return;
1382
- if (phase === "start" || phase === "update") {
1383
- const toolStartProgressPromise = params.opts?.onToolStart?.({
1384
- name,
1385
- phase,
1386
- args,
1387
- detailMode: params.toolProgressDetail
1388
- });
1389
- await Promise.all([params.typingSignals.signalToolStart(), toolStartProgressPromise]);
1390
- }
1391
- }
1392
- const suppressItemChannelProgress = evt.stream === "item" && evt.data.suppressChannelProgress === true && Boolean(params.opts?.onToolStart);
1393
- const itemPhase = evt.stream === "item" ? readStringValue(evt.data.phase) : "";
1394
- const itemName = evt.stream === "item" ? readStringValue(evt.data.name) : "";
1395
- const itemStatus = evt.stream === "item" ? readStringValue(evt.data.status) : "";
1396
- const itemToolCallId = evt.stream === "item" ? readStringValue(evt.data.toolCallId) ?? "" : "";
1397
- const completedMessageToolDelivery = sourceRepliesAreToolOnly && itemPhase === "end" && itemStatus === "completed" && itemToolCallId.length > 0 && messageToolOnlyDeliveryToolCallIds.has(itemToolCallId);
1398
- const suppressProgressAfterMessageToolDelivery = shouldSuppressProgressAfterMessageToolDelivery();
1399
- if (completedMessageToolDelivery) {
1400
- messageToolOnlyDeliveryToolCallIds.delete(itemToolCallId);
1401
- messageToolOnlyDeliveryCompleted = true;
1402
- }
1403
- if (evt.stream === "item" && !suppressItemChannelProgress && (!suppressProgressAfterMessageToolDelivery || completedMessageToolDelivery)) await params.opts?.onItemEvent?.({
1404
- itemId: readStringValue(evt.data.itemId),
1405
- kind: readStringValue(evt.data.kind),
1406
- title: readStringValue(evt.data.title),
1407
- name: itemName,
1408
- phase: itemPhase,
1409
- status: itemStatus,
1410
- summary: readStringValue(evt.data.summary),
1411
- progressText: readStringValue(evt.data.progressText),
1412
- meta: readStringValue(evt.data.meta),
1413
- approvalId: readStringValue(evt.data.approvalId),
1414
- approvalSlug: readStringValue(evt.data.approvalSlug)
1415
- });
1416
- if (evt.stream === "plan" && !shouldSuppressProgressAfterMessageToolDelivery()) await params.opts?.onPlanUpdate?.({
1417
- phase: readStringValue(evt.data.phase),
1418
- title: readStringValue(evt.data.title),
1419
- explanation: readStringValue(evt.data.explanation),
1420
- steps: Array.isArray(evt.data.steps) ? evt.data.steps.filter((step) => typeof step === "string") : void 0,
1421
- source: readStringValue(evt.data.source)
1422
- });
1423
- if (evt.stream === "approval" && !shouldSuppressProgressAfterMessageToolDelivery()) await params.opts?.onApprovalEvent?.({
1424
- phase: readStringValue(evt.data.phase),
1425
- kind: readStringValue(evt.data.kind),
1426
- status: readStringValue(evt.data.status),
1427
- title: readStringValue(evt.data.title),
1428
- itemId: readStringValue(evt.data.itemId),
1429
- toolCallId: readStringValue(evt.data.toolCallId),
1430
- approvalId: readStringValue(evt.data.approvalId),
1431
- approvalSlug: readStringValue(evt.data.approvalSlug),
1432
- command: readStringValue(evt.data.command),
1433
- host: readStringValue(evt.data.host),
1434
- reason: readStringValue(evt.data.reason),
1435
- scope: readApprovalScopeValue(evt.data.scope),
1436
- message: readStringValue(evt.data.message)
1437
- });
1438
- if (evt.stream === "command_output" && !shouldSuppressProgressAfterMessageToolDelivery()) await params.opts?.onCommandOutput?.({
1439
- itemId: readStringValue(evt.data.itemId),
1440
- phase: readStringValue(evt.data.phase),
1441
- title: readStringValue(evt.data.title),
1442
- toolCallId: readStringValue(evt.data.toolCallId),
1443
- name: readStringValue(evt.data.name),
1444
- output: readStringValue(evt.data.output),
1445
- status: readStringValue(evt.data.status),
1446
- exitCode: typeof evt.data.exitCode === "number" || evt.data.exitCode === null ? evt.data.exitCode : void 0,
1447
- durationMs: typeof evt.data.durationMs === "number" ? evt.data.durationMs : void 0,
1448
- cwd: readStringValue(evt.data.cwd)
1449
- });
1450
- if (evt.stream === "patch" && !shouldSuppressProgressAfterMessageToolDelivery()) await params.opts?.onPatchSummary?.({
1451
- itemId: readStringValue(evt.data.itemId),
1452
- phase: readStringValue(evt.data.phase),
1453
- title: readStringValue(evt.data.title),
1454
- toolCallId: readStringValue(evt.data.toolCallId),
1455
- name: readStringValue(evt.data.name),
1456
- added: Array.isArray(evt.data.added) ? evt.data.added.filter((entry) => typeof entry === "string") : void 0,
1457
- modified: Array.isArray(evt.data.modified) ? evt.data.modified.filter((entry) => typeof entry === "string") : void 0,
1458
- deleted: Array.isArray(evt.data.deleted) ? evt.data.deleted.filter((entry) => typeof entry === "string") : void 0,
1459
- summary: readStringValue(evt.data.summary)
1460
- });
1461
- if (evt.stream === "compaction") {
1462
- const phase = readStringValue(evt.data.phase) ?? "";
1463
- const hookMessages = readCompactionHookMessages(evt.data.messages);
1464
- if (phase === "start") {
1465
- if (params.opts?.onCompactionStart) await params.opts.onCompactionStart();
1466
- if (hookMessages.length > 0) await sendCompactionHookMessages(hookMessages);
1467
- else if (!params.opts?.onCompactionStart && shouldNotifyUserAboutCompaction) await sendCompactionNotice("start");
1468
- }
1469
- if (phase === "end") {
1470
- if (evt.data?.completed === true) {
1471
- attemptCompactionCount += 1;
1472
- if (params.opts?.onCompactionEnd) await params.opts.onCompactionEnd();
1473
- if (hookMessages.length > 0) await sendCompactionHookMessages(hookMessages);
1474
- else if (!params.opts?.onCompactionEnd && shouldNotifyUserAboutCompaction) await sendCompactionNotice("end");
1475
- } else if (hookMessages.length > 0) await sendCompactionHookMessages(hookMessages);
1476
- else if (shouldNotifyUserAboutCompaction) await sendCompactionNotice("incomplete");
1477
- }
1478
- }
1479
- },
1480
- onBlockReply: blockReplyHandler,
1481
- onBlockReplyFlush: params.blockStreamingEnabled && blockReplyPipeline ? async () => {
1482
- await blockReplyPipeline.flush({ force: true });
1483
- } : void 0,
1484
- shouldEmitToolResult: params.shouldEmitToolResult,
1485
- shouldEmitToolOutput: params.shouldEmitToolOutput,
1486
- bootstrapPromptWarningSignaturesSeen,
1487
- bootstrapPromptWarningSignature: bootstrapPromptWarningSignaturesSeen[bootstrapPromptWarningSignaturesSeen.length - 1],
1488
- onToolResult: onToolResult ? (() => {
1489
- let toolResultChain = Promise.resolve();
1490
- return (payload) => {
1491
- toolResultChain = toolResultChain.then(async () => {
1492
- const { text, skip } = normalizeStreamingText(payload);
1493
- if (skip) return;
1494
- if (text !== void 0) await params.typingSignals.signalTextDelta(text);
1495
- await onToolResult({
1496
- ...payload,
1497
- text
1498
- });
1499
- }).catch((err) => {
1500
- logVerbose(`tool result delivery failed: ${String(err)}`);
1501
- });
1502
- const task = toolResultChain.finally(() => {
1503
- params.pendingToolTasks.delete(task);
1504
- });
1505
- params.pendingToolTasks.add(task);
1506
- };
1507
- })() : void 0
1508
- });
1509
- bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(result.meta?.systemPromptReport);
1510
- lifecycleBackstop.emit("end", result);
1511
- const resultCompactionCount = Math.max(0, result.meta?.agentMeta?.compactionCount ?? 0);
1512
- attemptCompactionCount = Math.max(attemptCompactionCount, resultCompactionCount);
1513
- return result;
1514
- } catch (err) {
1515
- if (rollbackFallbackCandidateSelection) try {
1516
- await rollbackFallbackCandidateSelection();
1517
- clearPendingFallbackRollback(rollbackFallbackCandidateSelection);
1518
- } catch (rollbackError) {
1519
- logVerbose(`failed to roll back fallback candidate selection (non-fatal): ${String(rollbackError)}`);
1520
- }
1521
- lifecycleBackstop.emit("error", err);
1522
- throw err;
1523
- } finally {
1524
- autoCompactionCount += attemptCompactionCount;
1525
- }
1526
- })();
1527
- }
1528
- });
1529
- runResult = fallbackResult.result;
1530
- fallbackProvider = fallbackResult.provider;
1531
- fallbackModel = fallbackResult.model;
1532
- fallbackAttempts = Array.isArray(fallbackResult.attempts) ? fallbackResult.attempts.map((attempt) => ({
1533
- provider: attempt.provider,
1534
- model: attempt.model,
1535
- error: attempt.error,
1536
- reason: attempt.reason || void 0,
1537
- status: typeof attempt.status === "number" ? attempt.status : void 0,
1538
- code: attempt.code || void 0
1539
- })) : [];
1540
- await clearRecoveredAutoFallbackPrimaryProbe({
1541
- provider: fallbackProvider,
1542
- model: fallbackModel
1543
- });
1544
- const embeddedError = runResult.meta?.error;
1545
- if (embeddedError && isContextOverflowError(embeddedError.message)) {
1546
- defaultRuntime.error(`Auto-compaction failed (${embeddedError.message}). Preserving existing session mapping for ${params.sessionKey ?? params.followupRun.run.sessionId}.`);
1547
- params.replyOperation?.fail("run_failed", embeddedError);
1548
- return {
1549
- kind: "final",
1550
- payload: markAgentRunFailureReplyPayload({ text: buildContextOverflowRecoveryText({
1551
- preserveSessionMapping: true,
1552
- cfg: runtimeConfig,
1553
- agentId: params.followupRun.run.agentId,
1554
- primaryProvider: params.followupRun.run.provider,
1555
- primaryModel: params.followupRun.run.model,
1556
- activeSessionEntry: params.getActiveSessionEntry()
1557
- }) })
1558
- };
1559
- }
1560
- if (embeddedError?.kind === "role_ordering") {
1561
- const providerRequestError = classifyProviderRequestError(embeddedError);
1562
- params.replyOperation?.fail("run_failed", embeddedError);
1563
- const embeddedErrorText = formatErrorMessage(embeddedError).replace(/\.\s*$/, "");
1564
- return {
1565
- kind: "final",
1566
- payload: markAgentRunFailureReplyPayload({ text: shouldSurfaceToControlUi ? `⚠️ Agent failed before reply: ${embeddedErrorText}.\nLogs: daocore logs --follow` : providerRequestError?.userMessage ?? "⚠️ The model provider rejected the conversation state. Please try again, or use /new to start a fresh session." })
1567
- };
1568
- }
1569
- break;
1570
- } catch (err) {
1571
- if (err instanceof LiveSessionModelSwitchError) {
1572
- liveModelSwitchRetries += 1;
1573
- if (liveModelSwitchRetries > 2) {
1574
- defaultRuntime.error(`Live model switch failed after 2 retries (${sanitizeForLog(err.provider)}/${sanitizeForLog(err.model)}). The requested model may be unavailable.`);
1575
- const switchErrorText = shouldSurfaceToControlUi ? "⚠️ Agent failed before reply: model switch could not be completed. The requested model may be temporarily unavailable.\nLogs: daocore logs --follow" : isVerboseFailureDetailEnabled(params.resolvedVerboseLevel) ? "⚠️ Agent failed before reply: model switch could not be completed. The requested model may be temporarily unavailable. Please try again shortly." : "⚠️ Model switch could not be completed. The requested model may be temporarily unavailable. Please try again shortly.";
1576
- params.replyOperation?.fail("run_failed", err);
1577
- return {
1578
- kind: "final",
1579
- payload: markAgentRunFailureReplyPayload({ text: resolveExternalRunFailureTextForConversation({
1580
- text: switchErrorText,
1581
- sessionCtx: params.sessionCtx,
1582
- isGenericRunnerFailure: !shouldSurfaceToControlUi,
1583
- cfg: params.followupRun.run.config
1584
- }) })
1585
- };
1586
- }
1587
- applyLiveModelSwitchToRun(params.followupRun.run, err);
1588
- if (runnableRun !== params.followupRun.run) applyLiveModelSwitchToRun(runnableRun, err);
1589
- if (effectiveRun !== runnableRun && effectiveRun !== params.followupRun.run) applyLiveModelSwitchToRun(effectiveRun, err);
1590
- fallbackProvider = err.provider;
1591
- fallbackModel = err.model;
1592
- continue;
1593
- }
1594
- const message = formatErrorMessage(err);
1595
- const isBilling = isFallbackSummaryError(err) ? hasBillingAttemptSummary(err) : isBillingErrorMessage(message);
1596
- const isContextOverflow = !isBilling && isLikelyContextOverflowError(message);
1597
- const isCompactionFailure = !isBilling && isCompactionFailureError(message);
1598
- const providerRequestError = !isBilling && !shouldSurfaceToControlUi ? classifyProviderRequestError(err) : void 0;
1599
- const isTransientHttp = isTransientHttpError(message);
1600
- if (isReplyOperationRestartAbort(params.replyOperation)) return {
1601
- kind: "final",
1602
- payload: markAgentRunFailureReplyPayload({ text: buildRestartLifecycleReplyText() })
1603
- };
1604
- if (isReplyOperationUserAbort(params.replyOperation)) return {
1605
- kind: "final",
1606
- payload: { text: SILENT_REPLY_TOKEN }
1607
- };
1608
- const restartLifecycleError = resolveRestartLifecycleError(err);
1609
- if (restartLifecycleError instanceof GatewayDrainingError) {
1610
- params.replyOperation?.fail("gateway_draining", restartLifecycleError);
1611
- return {
1612
- kind: "final",
1613
- payload: markAgentRunFailureReplyPayload({ text: buildRestartLifecycleReplyText() })
1614
- };
1615
- }
1616
- if (restartLifecycleError instanceof CommandLaneClearedError) {
1617
- params.replyOperation?.fail("command_lane_cleared", restartLifecycleError);
1618
- return {
1619
- kind: "final",
1620
- payload: markAgentRunFailureReplyPayload({ text: buildRestartLifecycleReplyText() })
1621
- };
1622
- }
1623
- if (isCompactionFailure) {
1624
- defaultRuntime.error(`Auto-compaction failed (${message}). Preserving existing session mapping for ${params.sessionKey ?? params.followupRun.run.sessionId}.`);
1625
- params.replyOperation?.fail("run_failed", err);
1626
- return {
1627
- kind: "final",
1628
- payload: markAgentRunFailureReplyPayload({ text: buildContextOverflowRecoveryText({
1629
- duringCompaction: true,
1630
- preserveSessionMapping: true,
1631
- cfg: runtimeConfig,
1632
- agentId: params.followupRun.run.agentId,
1633
- primaryProvider: params.followupRun.run.provider,
1634
- primaryModel: params.followupRun.run.model,
1635
- activeSessionEntry: params.getActiveSessionEntry()
1636
- }) })
1637
- };
1638
- }
1639
- if (providerRequestError) {
1640
- params.replyOperation?.fail("run_failed", err);
1641
- return {
1642
- kind: "final",
1643
- payload: markAgentRunFailureReplyPayload({ text: providerRequestError.userMessage })
1644
- };
1645
- }
1646
- if (isTransientHttp && !didRetryTransientHttpError) {
1647
- didRetryTransientHttpError = true;
1648
- defaultRuntime.error(`Transient HTTP provider error before reply (${message}). Retrying once in ${TRANSIENT_HTTP_RETRY_DELAY_MS}ms.`);
1649
- await new Promise((resolve) => {
1650
- setTimeout(resolve, TRANSIENT_HTTP_RETRY_DELAY_MS);
1651
- });
1652
- continue;
1653
- }
1654
- defaultRuntime.error(`Embedded agent failed before reply: ${message}`);
1655
- const isFallbackSummary = isFallbackSummaryError(err);
1656
- const isPureTransientSummary = isFallbackSummary ? isPureTransientRateLimitSummary(err) : false;
1657
- const isRateLimit = isFallbackSummary ? isPureTransientSummary : isRateLimitErrorMessage(message);
1658
- const rateLimitOrOverloadedCopy = !isFallbackSummary || isPureTransientSummary ? formatRateLimitOrOverloadedErrorCopy(message) : void 0;
1659
- const trimmedMessage = (isTransientHttp ? sanitizeUserFacingText(message, { errorContext: true }) : message).replace(/\.\s*$/, "");
1660
- const externalRunFailureReply = !isBilling && !(isRateLimit && !isOverloadedErrorMessage(message)) && !rateLimitOrOverloadedCopy && !isContextOverflow && !shouldSurfaceToControlUi ? buildExternalRunFailureReply(message, {
1661
- includeDetails: isVerboseFailureDetailEnabled(params.resolvedVerboseLevel),
1662
- isHeartbeat: params.isHeartbeat
1663
- }) : void 0;
1664
- const genericFallbackText = params.isHeartbeat ? HEARTBEAT_EXTERNAL_RUN_FAILURE_TEXT : GENERIC_EXTERNAL_RUN_FAILURE_TEXT;
1665
- const userVisibleFallbackText = resolveExternalRunFailureTextForConversation({
1666
- text: isBilling ? BILLING_ERROR_USER_MESSAGE : isRateLimit && !isOverloadedErrorMessage(message) ? buildRateLimitCooldownMessage(err) : rateLimitOrOverloadedCopy ? rateLimitOrOverloadedCopy : isContextOverflow ? "⚠️ Context overflow — prompt too large for this model. Try a shorter message or a larger-context model." : shouldSurfaceToControlUi ? `⚠️ Agent failed before reply: ${trimmedMessage}.\nLogs: daocore logs --follow` : externalRunFailureReply?.text ?? genericFallbackText,
1667
- sessionCtx: params.sessionCtx,
1668
- isGenericRunnerFailure: externalRunFailureReply?.isGenericRunnerFailure ?? false,
1669
- cfg: params.followupRun.run.config
1670
- });
1671
- params.replyOperation?.fail("run_failed", err);
1672
- return {
1673
- kind: "final",
1674
- payload: markAgentRunFailureReplyPayload({ text: userVisibleFallbackText })
1675
- };
1676
- }
1677
- const finalEmbeddedError = runResult?.meta?.error;
1678
- const hasPayloadText = runResult?.payloads?.some((p) => normalizeOptionalString(p.text));
1679
- if (finalEmbeddedError && !hasPayloadText) {
1680
- if (isContextOverflowError(finalEmbeddedError.message ?? "")) {
1681
- params.replyOperation?.fail("run_failed", finalEmbeddedError);
1682
- return {
1683
- kind: "final",
1684
- payload: markAgentRunFailureReplyPayload({ text: "⚠️ Context overflow — this conversation is too large for the model. Use /new to start a fresh session." })
1685
- };
1686
- }
1687
- }
1688
- if (runResult) {
1689
- if (!runResult.payloads?.some((p) => !p.isError && !p.isReasoning && hasOutboundReplyContent(p, { trimText: true }))) {
1690
- const metaErrorMsg = finalEmbeddedError?.message ?? "";
1691
- const rawErrorPayloadText = runResult.payloads?.find((p) => p.isError && hasNonEmptyString(p.text) && !p.text.startsWith("⚠️"))?.text ?? "";
1692
- const errorCandidate = metaErrorMsg || rawErrorPayloadText;
1693
- const formattedErrorCandidate = errorCandidate ? formatRateLimitOrOverloadedErrorCopy(errorCandidate) : void 0;
1694
- if (formattedErrorCandidate) runResult.payloads = [markAgentRunFailureReplyPayload({
1695
- text: formattedErrorCandidate,
1696
- isError: true
1697
- })];
1698
- }
1699
- }
1700
- return {
1701
- kind: "success",
1702
- runId,
1703
- runResult,
1704
- fallbackProvider,
1705
- fallbackModel,
1706
- fallbackAttempts,
1707
- didLogHeartbeatStrip,
1708
- autoCompactionCount,
1709
- directlySentBlockKeys: directlySentBlockKeys.size > 0 ? directlySentBlockKeys : void 0
1710
- };
1711
- }
1712
- //#endregion
1713
- export { normalizeReplyPayloadDirectives as a, runAgentTurnWithFallback as i, resolveRunAfterAutoFallbackPrimaryProbeRecheck as n, runCliAgentWithLifecycle as o, resolveSessionRuntimeOverrideForProvider as r, buildKnownAgentRunFailureReplyPayload as t };