vora-ai 0.1.0

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 (2380) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +606 -0
  3. package/assets/avatar-placeholder.svg +19 -0
  4. package/assets/chrome-extension/icons/icon128.png +0 -0
  5. package/assets/chrome-extension/icons/icon16.png +0 -0
  6. package/assets/chrome-extension/icons/icon32.png +0 -0
  7. package/assets/chrome-extension/icons/icon48.png +0 -0
  8. package/assets/dmg-background-small.png +0 -0
  9. package/assets/dmg-background.png +0 -0
  10. package/dist/abort-bAEt3OX0.js +192 -0
  11. package/dist/abort-cutoff-BW9X8atp.js +56 -0
  12. package/dist/abort-cutoff.runtime-BTdcverG.js +20 -0
  13. package/dist/abort-primitives-BkLaStf6.js +92 -0
  14. package/dist/abort-signal-OQ0B1Hsw.js +13 -0
  15. package/dist/abort.runtime-Bk-WTrsH.js +2 -0
  16. package/dist/access-DUWbTdtq.js +82 -0
  17. package/dist/account-action-gate-BhV8CpjB.js +12 -0
  18. package/dist/account-core-BxpV-R9y.js +26 -0
  19. package/dist/account-helpers-D1v4-R4z.js +102 -0
  20. package/dist/account-helpers-DsRxse98.js +1 -0
  21. package/dist/account-id-Da7aL0Gd.js +1 -0
  22. package/dist/account-inspect-CAOMlXxX.js +158 -0
  23. package/dist/account-inspect-sHk3NdqU.js +81 -0
  24. package/dist/account-lookup-C6jbidQL.js +17 -0
  25. package/dist/account-resolution-DKAWqmga.js +30 -0
  26. package/dist/account-snapshot-fields-D7AI5hQQ.js +130 -0
  27. package/dist/account-summary-BgeGcB_3.js +36 -0
  28. package/dist/accounts-Db4FI6Zz.js +58 -0
  29. package/dist/accounts-qrnlKu1q.js +137 -0
  30. package/dist/ack-reactions-BZ-o06GS.js +43 -0
  31. package/dist/acp-cli-BvaZntRI.js +88 -0
  32. package/dist/acp-runtime-JWaJYUhz.js +8 -0
  33. package/dist/acp-stateful-target-driver-Bw7044NV.js +60 -0
  34. package/dist/action-runtime-api-Oe9YXMPW.js +1026 -0
  35. package/dist/agent-B1rpctfA.js +2 -0
  36. package/dist/agent-command-Ca6TUUTc.js +1462 -0
  37. package/dist/agent-events-DvBJWaR9.js +51 -0
  38. package/dist/agent-list-BLH_azHg.js +52 -0
  39. package/dist/agent-media-payload-DJHM1u8B.js +17 -0
  40. package/dist/agent-paths-A_P9FLsb.js +12 -0
  41. package/dist/agent-runner-utils-9OoCJtjv.js +178 -0
  42. package/dist/agent-runner.runtime-CBOjZZGX.js +2205 -0
  43. package/dist/agent-runtime-DUidz-g-.js +142 -0
  44. package/dist/agent-scope-BsqFyt8u.js +203 -0
  45. package/dist/agents/auth-profiles.runtime.js +7 -0
  46. package/dist/agents/pi-model-discovery-runtime.js +2 -0
  47. package/dist/agents-BalJcJ6y.js +5 -0
  48. package/dist/agents-C3mHfRHd.js +888 -0
  49. package/dist/agents.config-BDTgYzjf.js +3 -0
  50. package/dist/agents.config-CD4kuH-_.js +121 -0
  51. package/dist/allow-from-Bj0HDNYh.js +20 -0
  52. package/dist/allow-from-D-rvXQ8h.js +9 -0
  53. package/dist/allow-from-xOap1t02.js +62 -0
  54. package/dist/allow-list-BFJp0pl8.js +341 -0
  55. package/dist/allowlist-config-edit-Cm1yBM1Z.js +279 -0
  56. package/dist/allowlist-match-CvP7M2nU.js +63 -0
  57. package/dist/ansi-B_0KjIJj.js +54 -0
  58. package/dist/anthropic-vertex-CmYuMVC4.js +21 -0
  59. package/dist/anthropic-vertex-stream-CDum4sTM.js +631 -0
  60. package/dist/api-C8PGNlY8.js +10 -0
  61. package/dist/api-CUkBKFva.js +74 -0
  62. package/dist/api-builder-Dxtk0Cjs.js +172 -0
  63. package/dist/api-fetch-D1Orij33.js +35 -0
  64. package/dist/api-key-rotation-BgD2ZwFB.js +150 -0
  65. package/dist/apply-uNQmdYrd.js +485 -0
  66. package/dist/apply.runtime-CDBPl8wO.js +166 -0
  67. package/dist/apply.runtime-DXzYQs7u.js +2 -0
  68. package/dist/approval-renderers-D-qQquHC.js +83 -0
  69. package/dist/approval-runtime-DodHpuxq.js +122 -0
  70. package/dist/archive-BUHAoH49.js +537 -0
  71. package/dist/arg-split-ShoVtQWt.js +38 -0
  72. package/dist/artifacts-UsJTFgjT.js +52 -0
  73. package/dist/assistant-error-format-KDZ_osDM.js +109 -0
  74. package/dist/audio-DFt2UJ9l.js +41 -0
  75. package/dist/audit-234llk_L.js +85 -0
  76. package/dist/audit-BzzkNrPw.js +893 -0
  77. package/dist/audit-D8ikC9Ex.js +54 -0
  78. package/dist/audit-channel.allow-from.runtime-todwwiYs.js +5 -0
  79. package/dist/audit-channel.collect.runtime-DmpUSGTW.js +528 -0
  80. package/dist/audit-channel.discord.runtime-eztVMsVi.js +5 -0
  81. package/dist/audit-channel.telegram.runtime-C1XTQaXt.js +8 -0
  82. package/dist/audit-channel.zalouser.runtime-0HM10car.js +5 -0
  83. package/dist/audit-extra.async-CSQaJlTH.js +820 -0
  84. package/dist/audit-fs-ClsvRCTg.js +375 -0
  85. package/dist/audit-membership-runtime-ByM59rIs.js +55 -0
  86. package/dist/audit.deep.runtime-DXGK_1J_.js +2 -0
  87. package/dist/audit.nondeep.runtime-DJXN9aBX.js +831 -0
  88. package/dist/audit.runtime-BS7_g95e.js +7 -0
  89. package/dist/auth-DEuZoVpN.js +371 -0
  90. package/dist/auth-choice-9Go6Q-oV.js +3 -0
  91. package/dist/auth-choice-BQBEikSW.js +69 -0
  92. package/dist/auth-choice-CbU_5K03.js +341 -0
  93. package/dist/auth-choice-legacy-D9rcQsLS.js +44 -0
  94. package/dist/auth-choice-options-DzvdP-W5.js +98 -0
  95. package/dist/auth-choice-prompt-CAt3z9Wn.js +2 -0
  96. package/dist/auth-choice-prompt-DfuSZB7t.js +36 -0
  97. package/dist/auth-choice.apply-helpers-CxPMo6aR.js +2 -0
  98. package/dist/auth-choice.plugin-providers.runtime-C4iPKNWh.js +11 -0
  99. package/dist/auth-health-CztAfAX3.js +165 -0
  100. package/dist/auth-mode-policy-C2dpPPMZ.js +18 -0
  101. package/dist/auth-profiles-DgsNxC4M.js +431 -0
  102. package/dist/auth-rate-limit-B3HOQz3U.js +119 -0
  103. package/dist/avatar-policy-D_F2Olbt.js +67 -0
  104. package/dist/backend-config-DRYC_KQP.js +311 -0
  105. package/dist/backoff-C-fId8Y0.js +18 -0
  106. package/dist/backup-create-CWffgs90.js +462 -0
  107. package/dist/banner-BJJQ_jor.js +2 -0
  108. package/dist/banner-CzYuF1AM.js +369 -0
  109. package/dist/base-session-key-yPDY2ReX.js +14 -0
  110. package/dist/binaries-D04aDwRb.js +2 -0
  111. package/dist/binaries-UyZ8gKvx.js +11 -0
  112. package/dist/binding-registry-DeW6GWl7.js +422 -0
  113. package/dist/binding-targets-Dew-Cmhe.js +99 -0
  114. package/dist/bindings-Be6kpbqd.js +21 -0
  115. package/dist/bindings-C415Adm_.js +69 -0
  116. package/dist/block-reply-pipeline-DOyiLrmk.js +266 -0
  117. package/dist/block-streaming-irtDjCPX.js +107 -0
  118. package/dist/bluebubbles-cpaV8DUH.js +64 -0
  119. package/dist/bluebubbles-policy-DO-t7OnD.js +13 -0
  120. package/dist/boolean-BRxEL2pT.js +29 -0
  121. package/dist/boolean-param-B3tzmZ3k.js +13 -0
  122. package/dist/bootstrap-budget-lNGYv_xu.js +314 -0
  123. package/dist/bootstrap-cache-CwL_mvEY.js +19 -0
  124. package/dist/bot-message-context-BDfCxJZs.js +1213 -0
  125. package/dist/bot-message-context-C-8RvNrP.js +2 -0
  126. package/dist/bot-native-commands.delivery.runtime-z0viWrSs.js +3 -0
  127. package/dist/boundary-file-read-DzY137L0.js +192 -0
  128. package/dist/brave-web-search-provider-Bab38BrX.js +441 -0
  129. package/dist/brew-CTkvvpxg.js +44 -0
  130. package/dist/browser-open-BU6ETbQQ.js +94 -0
  131. package/dist/browser-runtime-C9uxHbGW.js +76 -0
  132. package/dist/browser-support-Bb_k0jpF.js +34 -0
  133. package/dist/btw-command-NOqYNWtX.js +16 -0
  134. package/dist/bundle-lsp-BeRKY2JZ.js +93 -0
  135. package/dist/bundle-mcp-Bx8MNFO5.js +263 -0
  136. package/dist/bundled/boot-md/handler.js +180 -0
  137. package/dist/bundled/bootstrap-extra-files/handler.js +42 -0
  138. package/dist/bundled/command-logger/handler.js +56 -0
  139. package/dist/bundled/session-memory/handler.js +196 -0
  140. package/dist/bundled-capability-metadata-BJSb_HDr.js +38 -0
  141. package/dist/bundled-compat-CAM7KkKK.js +64 -0
  142. package/dist/bundled-plugin-metadata-DuQVm9f5.js +621 -0
  143. package/dist/bundled-sources-cwLmVfLO.js +53 -0
  144. package/dist/cache-controls-CpBpLE7o.js +40 -0
  145. package/dist/call-CYGZtInt.js +649 -0
  146. package/dist/call-DNl9zM74.js +2 -0
  147. package/dist/capability-provider-runtime-yc24eaUD.js +40 -0
  148. package/dist/catalog-CTTRbG9P.js +272 -0
  149. package/dist/channel-Ur_UNzw2.js +679 -0
  150. package/dist/channel-account-context-BWgKFgVH.js +104 -0
  151. package/dist/channel-actions-BOFC-_zU.js +39 -0
  152. package/dist/channel-catalog.json +26 -0
  153. package/dist/channel-config-B-7hYcg1.js +115 -0
  154. package/dist/channel-config-helpers-C1S4WfJJ.js +482 -0
  155. package/dist/channel-config-schema-2huPMu2x.js +6 -0
  156. package/dist/channel-feedback-Ro-BTZzh.js +257 -0
  157. package/dist/channel-inbound-_DJyFgZs.js +30 -0
  158. package/dist/channel-issues-BPmcKiOr.js +13 -0
  159. package/dist/channel-lifecycle-tykcw1CK.js +286 -0
  160. package/dist/channel-lifecycle.core-3OcmXTam.js +69 -0
  161. package/dist/channel-options-DgOdpBj-.js +39 -0
  162. package/dist/channel-pairing-Dx7NU9a4.js +68 -0
  163. package/dist/channel-plugin-common-B7gWshwF.js +4 -0
  164. package/dist/channel-plugin-ids-DGJsaNeP.js +230 -0
  165. package/dist/channel-plugin-resolution-B3C2B0Xc.js +113 -0
  166. package/dist/channel-policy-BiAdlZRY.js +32 -0
  167. package/dist/channel-reply-pipeline-DZQu_Smr.js +16 -0
  168. package/dist/channel-resolution-BRpGejEv.js +57 -0
  169. package/dist/channel-runtime-B3OwaSIN.js +8 -0
  170. package/dist/channel-selection-CJiUKode.js +125 -0
  171. package/dist/channel-send-result-C4cfMY3q.js +40 -0
  172. package/dist/channel-setup-CVb_d9r3.js +51 -0
  173. package/dist/channel-status-is1j_O8T.js +2 -0
  174. package/dist/channel-summary-CcHbPriu.js +2 -0
  175. package/dist/channel-summary-ChMRan7Y.js +139 -0
  176. package/dist/channel-target-B2-JZuxb.js +157 -0
  177. package/dist/channel-targets-C7I-yneV.js +173 -0
  178. package/dist/channel.runtime-DPqGWQMI.js +5 -0
  179. package/dist/channels-BLrLpPbs.js +1134 -0
  180. package/dist/channels-ClZdlIAP.js +409 -0
  181. package/dist/channels-cli-CxyDo24U.js +246 -0
  182. package/dist/channels-status-issues-DOvoiysl.js +17 -0
  183. package/dist/chat-envelope-BKa8gVwt.js +158 -0
  184. package/dist/chat-meta-CxxUMjgT.js +77 -0
  185. package/dist/chat-type-D66QkgK0.js +10 -0
  186. package/dist/chunk-BRNunu6m.js +334 -0
  187. package/dist/chunk-DBEY4PJZ.js +16 -0
  188. package/dist/chutes-oauth-df1s-ETh.js +127 -0
  189. package/dist/cjk-chars-nOH-kRF8.js +50 -0
  190. package/dist/clack-prompter-ByYhQnEc.js +112 -0
  191. package/dist/clawbot-cli-B1PP3cQS.js +9 -0
  192. package/dist/clawhub-BlNkstQC.js +163 -0
  193. package/dist/clawhub-PHPunBYA.js +263 -0
  194. package/dist/cli/daemon-cli.js +3 -0
  195. package/dist/cli-BVs9q78-.js +2 -0
  196. package/dist/cli-backend-BY5ACL_R.js +1 -0
  197. package/dist/cli-backend-MiCoOt1Y.js +44 -0
  198. package/dist/cli-eS9_49Ka.js +153 -0
  199. package/dist/cli-name-l1qeysOp.js +21 -0
  200. package/dist/cli-runner-rgKmST01.js +1010 -0
  201. package/dist/cli-utils-CMfpS8SF.js +40 -0
  202. package/dist/cli-watchdog-defaults-3Qs4l3Yf.js +14 -0
  203. package/dist/cmd-argv-BafMhhA4.js +68 -0
  204. package/dist/codex-native-web-search-CWYqRu9M.js +2 -0
  205. package/dist/codex-native-web-search-CbRntg-q.js +155 -0
  206. package/dist/command-auth-CJsP4GL7.js +64 -0
  207. package/dist/command-auth-Dfgmp_6_.js +356 -0
  208. package/dist/command-auth-native-CdgZoflY.js +3 -0
  209. package/dist/command-detection-CyrUVnod.js +46 -0
  210. package/dist/command-format-CfBy_-A6.js +2 -0
  211. package/dist/command-format-DmvS76BD.js +22 -0
  212. package/dist/command-gating-HO-bVa6h.js +40 -0
  213. package/dist/command-options-BUoAEXAi.js +25 -0
  214. package/dist/command-poll-backoff-BbGeC12t.js +56 -0
  215. package/dist/command-poll-backoff.runtime-BDcejg_n.js +7 -0
  216. package/dist/command-registry-C0kFYtIa.js +199 -0
  217. package/dist/command-registry-VUV6Y6SA.js +3 -0
  218. package/dist/command-secret-gateway-B2PsoqGE.js +2 -0
  219. package/dist/command-secret-gateway-rXrG4_xf.js +449 -0
  220. package/dist/command-secret-targets-BMcCyKKM.js +85 -0
  221. package/dist/command-secret-targets-DYLJqbik.js +2 -0
  222. package/dist/commands/status.summary.runtime.js +146 -0
  223. package/dist/commands-BNN8qnEq.js +42 -0
  224. package/dist/commands-D905e2TE.js +4 -0
  225. package/dist/commands-acp-DxpRaS_2.js +994 -0
  226. package/dist/commands-context-DYfg86cW.js +33 -0
  227. package/dist/commands-core-BkTgFXRe.js +185 -0
  228. package/dist/commands-core.runtime-DL4UA7LO.js +2 -0
  229. package/dist/commands-handlers.runtime-Dnqn4WRI.js +3597 -0
  230. package/dist/commands-info-9qXzZJZy.js +638 -0
  231. package/dist/commands-models-DaGXLYpI.js +395 -0
  232. package/dist/commands-rHJt1A27.js +192 -0
  233. package/dist/commands-registry-DsvlObRs.js +295 -0
  234. package/dist/commands-registry.data-D4mfAJVD.js +928 -0
  235. package/dist/commands-registry.runtime-CvK5vfUk.js +2 -0
  236. package/dist/commands-status.runtime-Biqry_fJ.js +2 -0
  237. package/dist/commands.runtime-BQNIS1_C.js +4 -0
  238. package/dist/common-B8KXadTs.js +206 -0
  239. package/dist/compact.runtime-DrIYPOe_.js +7 -0
  240. package/dist/completion-cli-DADmFZNY.js +2 -0
  241. package/dist/completion-cli-Xpp8XJNt.js +466 -0
  242. package/dist/config-B8J_0cJd.js +41 -0
  243. package/dist/config-BeMghpRW.js +136 -0
  244. package/dist/config-C6sbf2mt.js +7 -0
  245. package/dist/config-CKbWnj3S.js +52 -0
  246. package/dist/config-DUHgkJzn.js +421 -0
  247. package/dist/config-cli-CwphzfyS.js +944 -0
  248. package/dist/config-eval-DM9FHTGd.js +100 -0
  249. package/dist/config-guard-BQvfMpPf.js +94 -0
  250. package/dist/config-helpers-DiGV2z9-.js +117 -0
  251. package/dist/config-paths-h016qQJq.js +8 -0
  252. package/dist/config-presence-C16x_f3x.js +79 -0
  253. package/dist/config-regex-CvZFnWkO.js +39 -0
  254. package/dist/config-runtime-CGUisiU5.js +12 -0
  255. package/dist/config-schema-5JUAk8XL.js +202 -0
  256. package/dist/config-schema-BRTDDWFV.js +65 -0
  257. package/dist/config-schema-B_uHmf_j.js +133 -0
  258. package/dist/config-schema-dV8ghEVQ.js +85 -0
  259. package/dist/config-state-CiYvCzdZ.js +185 -0
  260. package/dist/config-validation-CzH2O_-H.js +276 -0
  261. package/dist/config-value-B0LE9l8u.js +25 -0
  262. package/dist/configure-BUZKW20U.js +1140 -0
  263. package/dist/configure-CFbHMkXc.js +2 -0
  264. package/dist/configured-provider-fallback-HW8QhjlX.js +15 -0
  265. package/dist/connection-auth-Cs3qTX0J.js +30 -0
  266. package/dist/connection-details-GqZVX1_1.js +56 -0
  267. package/dist/constants-lHqfjBOu.js +71 -0
  268. package/dist/content-blocks-DdN51R-1.js +1640 -0
  269. package/dist/context-Bv7BKF9l.js +227 -0
  270. package/dist/context-window-guard-BKQgasN7.js +46 -0
  271. package/dist/control-ui/apple-touch-icon.png +0 -0
  272. package/dist/control-ui/assets/agents-sN8RQ1eS.js +813 -0
  273. package/dist/control-ui/assets/anthropic-ZDTkKd9P.js +37 -0
  274. package/dist/control-ui/assets/azure-openai-responses-CQjyuM35.js +2 -0
  275. package/dist/control-ui/assets/channel-config-extras-DNCeHtEf.js +2 -0
  276. package/dist/control-ui/assets/channels-LecGHhYY.js +349 -0
  277. package/dist/control-ui/assets/cron-BCSmuADd.js +928 -0
  278. package/dist/control-ui/assets/de-BhrN2Nih.js +2 -0
  279. package/dist/control-ui/assets/debug-DIDwUeSi.js +94 -0
  280. package/dist/control-ui/assets/directive-C6NBp6xJ.js +2 -0
  281. package/dist/control-ui/assets/dist-D8DZLmCF.js +18 -0
  282. package/dist/control-ui/assets/es-D2hTJirx.js +2 -0
  283. package/dist/control-ui/assets/event-stream-B8X6sYaV.js +2 -0
  284. package/dist/control-ui/assets/format-Cbj45nru.js +2 -0
  285. package/dist/control-ui/assets/github-copilot-headers-CrI0CIJ7.js +2 -0
  286. package/dist/control-ui/assets/google-gemini-cli-BpxbH95Q.js +3 -0
  287. package/dist/control-ui/assets/google-shared-CbPHVnPr.js +12 -0
  288. package/dist/control-ui/assets/google-vertex-lQwbjEII.js +2 -0
  289. package/dist/control-ui/assets/google-xtjMQAen.js +2 -0
  290. package/dist/control-ui/assets/hash-Bt1aVMQ3.js +2 -0
  291. package/dist/control-ui/assets/index-DqTClMaZ.js +4714 -0
  292. package/dist/control-ui/assets/index-yaW_F-Wi.css +1 -0
  293. package/dist/control-ui/assets/instances-CMgIM69b.js +57 -0
  294. package/dist/control-ui/assets/lit-zdTgzAJI.js +3 -0
  295. package/dist/control-ui/assets/logs-vVeVJ0CI.js +74 -0
  296. package/dist/control-ui/assets/mistral-u1o8NcCM.js +8 -0
  297. package/dist/control-ui/assets/nodes-B1R45Hyv.js +430 -0
  298. package/dist/control-ui/assets/openai-Cn7eGqwa.js +17 -0
  299. package/dist/control-ui/assets/openai-codex-responses-o0Z3RMWa.js +8 -0
  300. package/dist/control-ui/assets/openai-completions-7V2Ovprv.js +6 -0
  301. package/dist/control-ui/assets/openai-responses-oNxOx3Q1.js +2 -0
  302. package/dist/control-ui/assets/openai-responses-shared-OKpfrZ-q.js +11 -0
  303. package/dist/control-ui/assets/preload-helper-xBbMyY7u.js +1 -0
  304. package/dist/control-ui/assets/pt-BR-Bd9tFPER.js +2 -0
  305. package/dist/control-ui/assets/sessions-Lc0IvBNe.js +236 -0
  306. package/dist/control-ui/assets/skills-k1ptbgMP.js +216 -0
  307. package/dist/control-ui/assets/skills-shared-D4l2M8cL.js +11 -0
  308. package/dist/control-ui/assets/transform-messages-XKqwKV3D.js +2 -0
  309. package/dist/control-ui/assets/zh-CN-DvLwUwA1.js +2 -0
  310. package/dist/control-ui/assets/zh-TW-BXT7QT3h.js +2 -0
  311. package/dist/control-ui/favicon-32.png +0 -0
  312. package/dist/control-ui/favicon.ico +0 -0
  313. package/dist/control-ui/favicon.svg +22 -0
  314. package/dist/control-ui/index.html +75 -0
  315. package/dist/control-ui-assets-DbOOvjtb.js +233 -0
  316. package/dist/control-ui-shared-DsqkrmmN.js +29 -0
  317. package/dist/conversation-binding-input-BGI5gsf7.js +250 -0
  318. package/dist/conversation-binding-xxmmj56H.js +520 -0
  319. package/dist/conversation-id-B2-7oYz5.js +9 -0
  320. package/dist/conversation-label-CDBJEzqs.js +32 -0
  321. package/dist/conversation-runtime-CPXVzEGP.js +85 -0
  322. package/dist/core-DidBIGEJ.js +195 -0
  323. package/dist/core-api-VzeJYIaC.js +670 -0
  324. package/dist/core-command-descriptors-OO8iMaXR.js +91 -0
  325. package/dist/credential-planner-B6V18E6X.js +109 -0
  326. package/dist/credentials-T7b82ytT.js +135 -0
  327. package/dist/cron-cli-D2epg2QX.js +643 -0
  328. package/dist/current-time-AvIq1E3O.js +20 -0
  329. package/dist/daemon-cli-Be7LAwcB.js +368 -0
  330. package/dist/daemon-install-CfvYrNa-.js +63 -0
  331. package/dist/daemon-install-plan.shared-Dm6sK7Lg.js +222 -0
  332. package/dist/daemon-runtime-DPejcJWG.js +12 -0
  333. package/dist/dangerous-config-flags-DyYwhFd-.js +38 -0
  334. package/dist/dangerous-name-matching-DJGvHcqL.js +48 -0
  335. package/dist/date-time-ChwO2p0r.js +118 -0
  336. package/dist/dedupe-ClGH5AD-.js +59 -0
  337. package/dist/default-account-warnings-DhrBUOxe.js +15 -0
  338. package/dist/default-models-p_jLxv9h.js +35 -0
  339. package/dist/defaults-DAt--D9n.js +6 -0
  340. package/dist/delegate-D_a6-aW6.js +43 -0
  341. package/dist/deliver-NyzvqqW3.js +954 -0
  342. package/dist/deliver-YFpAT2Gv.js +3 -0
  343. package/dist/deliver-runtime-CDYmnxXC.js +2 -0
  344. package/dist/delivery-DHz1_gua.js +819 -0
  345. package/dist/delivery-context-wkeob4lC.js +106 -0
  346. package/dist/delivery-info-0NXZH054.js +36 -0
  347. package/dist/delivery-queue-BceSoMom.js +2 -0
  348. package/dist/delivery-queue-Dij4z9yQ.js +289 -0
  349. package/dist/deps-xJ6d5mcR.js +67 -0
  350. package/dist/detect-binary-D5oXUD9C.js +30 -0
  351. package/dist/device-auth-BPeQrfAM.js +19 -0
  352. package/dist/device-bootstrap-IW2esZhx.js +176 -0
  353. package/dist/device-identity-2GhXUC5d.js +2 -0
  354. package/dist/device-identity-DH-dBXN2.js +140 -0
  355. package/dist/device-metadata-normalization-DesKWnX9.js +21 -0
  356. package/dist/device-pairing-D-eXc4mS.js +543 -0
  357. package/dist/devices-cli-CUkbtT5k.js +328 -0
  358. package/dist/diagnostic-BYcJF51S.js +311 -0
  359. package/dist/diagnostic-events-R6R0hsS8.js +48 -0
  360. package/dist/diagnostic-flags-DI1-YJxA.js +64 -0
  361. package/dist/diagnostic-runtime-iwrls2oi.js +1 -0
  362. package/dist/diagnostics-Bn7WBAMb.js +2 -0
  363. package/dist/diagnostics-CNOhNbiG.js +33 -0
  364. package/dist/direct-dm-DX9Sqse3.js +139 -0
  365. package/dist/directive-handling.defaults-CiM3zY4c.js +19 -0
  366. package/dist/directive-handling.fast-lane-CBsRyqm9.js +64 -0
  367. package/dist/directive-handling.fast-lane-CkLifH7t.js +2 -0
  368. package/dist/directive-handling.impl-DDDo9_pC.js +2 -0
  369. package/dist/directive-handling.impl-Rcgo5SCg.js +674 -0
  370. package/dist/directive-handling.levels-Dlk68wUB.js +2 -0
  371. package/dist/directive-handling.levels-Y1fuvRYT.js +12 -0
  372. package/dist/directive-handling.parse-CMEE0kEW.js +375 -0
  373. package/dist/directive-handling.persist-CvEtXaAd.js +133 -0
  374. package/dist/directive-handling.persist.runtime-Cdksoe_I.js +2 -0
  375. package/dist/directive-handling.shared-8kteIv4q.js +158 -0
  376. package/dist/directive-tags-B4NiUGng.js +109 -0
  377. package/dist/directives-DLcHC9jG.js +209 -0
  378. package/dist/directory-cache-KFfoEzq3.js +62 -0
  379. package/dist/directory-cli-DUY3BGGz.js +238 -0
  380. package/dist/directory-config-helpers-DBmVJY3U.js +141 -0
  381. package/dist/directory-runtime-DWVDd3A5.js +20 -0
  382. package/dist/discord-2uEduGX9.js +6 -0
  383. package/dist/discord-BMCiYFK_.js +11 -0
  384. package/dist/discord-account-HmxkZycn.js +11 -0
  385. package/dist/discord-core-Pl5ukuXB.js +5 -0
  386. package/dist/discord-runtime-surface-DNQNbA29.js +67 -0
  387. package/dist/discord-session-key-DoaFTAH3.js +11 -0
  388. package/dist/discord-surface-Cn77ggmj.js +30 -0
  389. package/dist/discord-thread-bindings-DRMbWo4Q.js +21 -0
  390. package/dist/discord-timeouts-Cv7cpmLu.js +12 -0
  391. package/dist/dispatch-CZypQktI.js +842 -0
  392. package/dist/dispatch-acp.runtime-DVu2VG71.js +887 -0
  393. package/dist/dist-C22HbjJn.js +3 -0
  394. package/dist/dist-C26-w-eb.js +14245 -0
  395. package/dist/dist-_cqaGkQM.js +503 -0
  396. package/dist/dm-policy-shared-BsSmWpF_.js +188 -0
  397. package/dist/dns-cli-CypS3rSW.js +192 -0
  398. package/dist/docker-e3sy4uxj.js +837 -0
  399. package/dist/docs-cli-CAc6XPQ1.js +156 -0
  400. package/dist/doctor-completion-D1GX1eYy.js +90 -0
  401. package/dist/doctor-config-preflight-BIjpCYLH.js +2 -0
  402. package/dist/doctor-config-preflight-C5YWG1Il.js +147 -0
  403. package/dist/doctor-state-migrations-C4JRWbB5.js +2 -0
  404. package/dist/doctor-state-migrations-Hkw1WYQh.js +3 -0
  405. package/dist/dotenv-5B3Ltg5m.js +11 -0
  406. package/dist/dotenv-C-ipPVRV.js +91 -0
  407. package/dist/enable-1JBZrsl3.js +57 -0
  408. package/dist/entry-status-8GZhSwz9.js +172 -0
  409. package/dist/entry.js +209 -0
  410. package/dist/env-DAI7QbHD.js +40 -0
  411. package/dist/env-substitution-D4FvNwAw.js +136 -0
  412. package/dist/envelope-BT4nxsRe.js +137 -0
  413. package/dist/error-runtime-BWR3edBz.js +2 -0
  414. package/dist/error-text-Dz9S7qeJ.js +9 -0
  415. package/dist/errors-BVF4CQJh.js +15 -0
  416. package/dist/errors-BxyFnvP3.js +58 -0
  417. package/dist/exa-web-search-provider-YdwhKG_r.js +355 -0
  418. package/dist/exec-DBEtpL4G.js +2 -0
  419. package/dist/exec-DNTgEe82.js +375 -0
  420. package/dist/exec-approval-reply-CIaFux57.js +161 -0
  421. package/dist/exec-approval-session-target-BsD_thnK.js +159 -0
  422. package/dist/exec-approvals-D6Kd1FHX.js +120 -0
  423. package/dist/exec-approvals-XWl5Qihe.js +394 -0
  424. package/dist/exec-approvals-allowlist-B90zHMFx.js +771 -0
  425. package/dist/exec-approvals-cli-CBwEU5lx.js +375 -0
  426. package/dist/exec-safe-bin-runtime-policy-CQ_6FV8z.js +90 -0
  427. package/dist/exec-safety-FkFR1qf5.js +24 -0
  428. package/dist/extensionAPI.js +17 -0
  429. package/dist/extensions/brave/index.js +13 -0
  430. package/dist/extensions/brave/package.json +12 -0
  431. package/dist/extensions/brave/test-api.js +2 -0
  432. package/dist/extensions/brave/vora.plugin.json +50 -0
  433. package/dist/extensions/brave/web-search-provider.js +2 -0
  434. package/dist/extensions/browser/browser-runtime-api.js +4 -0
  435. package/dist/extensions/browser/index.js +20 -0
  436. package/dist/extensions/browser/package.json +12 -0
  437. package/dist/extensions/browser/runtime-api.js +6 -0
  438. package/dist/extensions/browser/test-support.js +19 -0
  439. package/dist/extensions/browser/vora.plugin.json +9 -0
  440. package/dist/extensions/discord/action-runtime-api.js +2 -0
  441. package/dist/extensions/discord/api.js +14 -0
  442. package/dist/extensions/discord/channel-config-api.js +2 -0
  443. package/dist/extensions/discord/index.js +615 -0
  444. package/dist/extensions/discord/package.json +40 -0
  445. package/dist/extensions/discord/runtime-api.js +229 -0
  446. package/dist/extensions/discord/session-key-api.js +2 -0
  447. package/dist/extensions/discord/setup-entry.js +10 -0
  448. package/dist/extensions/discord/test-api.js +45 -0
  449. package/dist/extensions/discord/timeouts.js +2 -0
  450. package/dist/extensions/discord/vora.plugin.json +11 -0
  451. package/dist/extensions/exa/index.js +13 -0
  452. package/dist/extensions/exa/package.json +12 -0
  453. package/dist/extensions/exa/vora.plugin.json +39 -0
  454. package/dist/extensions/exa/web-search-provider.js +2 -0
  455. package/dist/extensions/openai/api.js +4 -0
  456. package/dist/extensions/openai/cli-backend.js +2 -0
  457. package/dist/extensions/openai/default-models.js +2 -0
  458. package/dist/extensions/openai/image-generation-provider.js +2 -0
  459. package/dist/extensions/openai/index.js +24 -0
  460. package/dist/extensions/openai/media-understanding-provider.js +2 -0
  461. package/dist/extensions/openai/openai-codex-auth-identity.js +2 -0
  462. package/dist/extensions/openai/openai-codex-catalog.js +2 -0
  463. package/dist/extensions/openai/openai-codex-provider.js +2 -0
  464. package/dist/extensions/openai/openai-codex-provider.runtime.js +14 -0
  465. package/dist/extensions/openai/openai-provider.js +2 -0
  466. package/dist/extensions/openai/package.json +12 -0
  467. package/dist/extensions/openai/shared.js +4 -0
  468. package/dist/extensions/openai/speech-provider.js +2 -0
  469. package/dist/extensions/openai/test-api.js +5 -0
  470. package/dist/extensions/openai/tts.js +2 -0
  471. package/dist/extensions/openai/vora.plugin.json +61 -0
  472. package/dist/extensions/tavily/index.js +128 -0
  473. package/dist/extensions/tavily/package.json +12 -0
  474. package/dist/extensions/tavily/skills/tavily/SKILL.md +94 -0
  475. package/dist/extensions/tavily/vora.plugin.json +53 -0
  476. package/dist/extensions/tavily/web-search-provider.js +2 -0
  477. package/dist/extensions/telegram/allow-from.js +2 -0
  478. package/dist/extensions/telegram/api.js +13 -0
  479. package/dist/extensions/telegram/channel-config-api.js +2 -0
  480. package/dist/extensions/telegram/index.js +12 -0
  481. package/dist/extensions/telegram/package.json +37 -0
  482. package/dist/extensions/telegram/runtime-api.js +24 -0
  483. package/dist/extensions/telegram/session-key-api.js +2 -0
  484. package/dist/extensions/telegram/setup-entry.js +13 -0
  485. package/dist/extensions/telegram/test-api.js +87 -0
  486. package/dist/extensions/telegram/test-support.js +72 -0
  487. package/dist/extensions/telegram/update-offset-runtime-api.js +2 -0
  488. package/dist/extensions/telegram/vora.plugin.json +11 -0
  489. package/dist/external-content-CCU3ADB4.js +242 -0
  490. package/dist/facade-runtime-FE2gvW08.js +183 -0
  491. package/dist/failover-error-Bv6ZpTGn.js +194 -0
  492. package/dist/feishu-conversation-CRGPLs2e.js +17 -0
  493. package/dist/feishu-setup-D3qBPVeH.js +12 -0
  494. package/dist/fetch-B7l-vxJ5.js +65 -0
  495. package/dist/fetch-BlEbs4zu.js +416 -0
  496. package/dist/fetch-guard-DECxJSgV.js +132 -0
  497. package/dist/fetch-mock-Y15aY-vX.js +6 -0
  498. package/dist/fetch-runtime-DfJc8pAb.js +4 -0
  499. package/dist/fetch-timeout-DlhFJxaz.js +58 -0
  500. package/dist/file-identity-CFjEVvlD.js +567 -0
  501. package/dist/file-lock-I_Ef85iM.js +141 -0
  502. package/dist/file-lock-_Bv5Z0H8.js +2 -0
  503. package/dist/format-Cmirp0jV.js +19 -0
  504. package/dist/format-DTr5MrB3.js +787 -0
  505. package/dist/format-datetime-BzFsOTtu.js +73 -0
  506. package/dist/format-duration-3-yx54b_.js +57 -0
  507. package/dist/format-relative-CKRrUR_e.js +54 -0
  508. package/dist/frontmatter-7NzkXiTl.js +45 -0
  509. package/dist/frontmatter-BruYJzuJ.js +210 -0
  510. package/dist/fs-safe-C7Y0npoY.js +999 -0
  511. package/dist/gateway-cli-CL9kkVgP.js +25330 -0
  512. package/dist/gateway-discovery-targets-Nj88oSf4.js +430 -0
  513. package/dist/gateway-install-token-DT4JSzW6.js +231 -0
  514. package/dist/gateway-presence-C9FNv0wz.js +15 -0
  515. package/dist/gateway-registry-bOE6bwiW.js +74 -0
  516. package/dist/gateway-rpc-EUERnNbW.js +26 -0
  517. package/dist/gateway-runtime-DA85e49x.js +12 -0
  518. package/dist/gaxios-fetch-compat-TyJGVB6l.js +180 -0
  519. package/dist/gemini-auth-DU9RM3Fo.js +29 -0
  520. package/dist/get-reply-from-config.runtime-BTZAHGwc.js +2 -0
  521. package/dist/git-commit-B_DkJ7LE.js +177 -0
  522. package/dist/git-commit-Bx0Yma3I.js +2 -0
  523. package/dist/github-copilot-login-BiqEMA_7.js +11 -0
  524. package/dist/github-copilot-token-BMHm0urT.js +2 -0
  525. package/dist/github-copilot-token-CGpIsMSL.js +77 -0
  526. package/dist/global-singleton-54zT3rCn.js +13 -0
  527. package/dist/global-singleton-o2ArPCEw.js +1 -0
  528. package/dist/global-state-DUuMGgts.js +17 -0
  529. package/dist/globals-DNhziPZz.js +25 -0
  530. package/dist/gmail-setup-utils-B4xK25jT.js +421 -0
  531. package/dist/google-CPRZDTjq.js +24 -0
  532. package/dist/group-access-Cd6mU7Ys.js +113 -0
  533. package/dist/group-activation-BwfaA0gP.js +22 -0
  534. package/dist/group-id-vLZLwNVz.js +11 -0
  535. package/dist/group-policy-Cr7UXkoj.js +201 -0
  536. package/dist/group-policy-warnings-DmIDYgw8.js +196 -0
  537. package/dist/groups.runtime-DKOqtNQC.js +7 -0
  538. package/dist/handle-action-DsH0nVWk.js +500 -0
  539. package/dist/health-B3O0HygG.js +577 -0
  540. package/dist/health-CojrwX7m.js +2 -0
  541. package/dist/health-format-JFM9rFJB.js +26 -0
  542. package/dist/heartbeat-C1Xvupsk.js +122 -0
  543. package/dist/heartbeat-reply-payload-C-Rlp4k5.js +13 -0
  544. package/dist/heartbeat-summary-D5pDHsmN.js +57 -0
  545. package/dist/heartbeat-visibility-kNXllOIC.js +102 -0
  546. package/dist/heartbeat-wake-DfVExPSU.js +188 -0
  547. package/dist/help-CpuviX5S.js +81 -0
  548. package/dist/help-format-Dad85O74.js +15 -0
  549. package/dist/helpers-4IKdDZX5.js +24 -0
  550. package/dist/helpers-fNw5R_YT.js +32 -0
  551. package/dist/history-CK-v5j98.js +102 -0
  552. package/dist/home-dir-BXPtwSCY.js +83 -0
  553. package/dist/hook-runner-global-DEn0PCL0.js +602 -0
  554. package/dist/hook-runtime-Dn-Congb.js +3 -0
  555. package/dist/hooks-cli-DNKW70lO.js +353 -0
  556. package/dist/hooks-policy-Ad8y_Dfl.js +20 -0
  557. package/dist/hooks-status-Cb31D01g.js +86 -0
  558. package/dist/host-env-security-Cks-ZF3X.js +285 -0
  559. package/dist/hostname-BYGiBG2v.js +8 -0
  560. package/dist/http-body-DoRUn0Id.js +238 -0
  561. package/dist/http-registry-1oFXUjVZ.js +54 -0
  562. package/dist/http-route-overlap-CRbY2bBV.js +101 -0
  563. package/dist/identity-BBfQnFMg.js +29 -0
  564. package/dist/identity-BoQQh6Y8.js +26 -0
  565. package/dist/identity-D7VGm34b.js +84 -0
  566. package/dist/identity-avatar-CBJpFxtc.js +86 -0
  567. package/dist/identity-file-9bBicCze.js +60 -0
  568. package/dist/image-UFatuV93.js +152 -0
  569. package/dist/image-generation-CB1-VO0n.js +1 -0
  570. package/dist/image-generation-provider-CoHdiPC_.js +86 -0
  571. package/dist/image-ops-EABsGjsc.js +476 -0
  572. package/dist/image-runtime-ZZOiUbiY.js +7 -0
  573. package/dist/imessage-UUBzYSCn.js +19 -0
  574. package/dist/inbound-context-BxNfypB6.js +59 -0
  575. package/dist/inbound-context-DQ_fXNSa.js +38 -0
  576. package/dist/inbound-debounce-YEtyt_k_.js +159 -0
  577. package/dist/inbound-envelope-B6C8FhsE.js +61 -0
  578. package/dist/inbound-reply-dispatch-BP3sajLc.js +73 -0
  579. package/dist/inbound-text-DibnKFqn.js +14 -0
  580. package/dist/inbound.runtime-SCcR_etw.js +3 -0
  581. package/dist/includes-CHoL4g8x.js +188 -0
  582. package/dist/includes-scan-rcUlg6Nq.js +55 -0
  583. package/dist/index.js +56 -0
  584. package/dist/infra/warning-filter.js +2 -0
  585. package/dist/infra-runtime-D1S_mYfO.js +326 -0
  586. package/dist/input-files-BJKZz7LU.js +251 -0
  587. package/dist/input-provenance-DqtZ-oaB.js +44 -0
  588. package/dist/inspect-BdrrX2i3.js +282 -0
  589. package/dist/install-BwbpybtH.js +588 -0
  590. package/dist/install-package-dir-DhoPrQ04.js +284 -0
  591. package/dist/install-safe-path-BK_5xK2H.js +69 -0
  592. package/dist/install-security-scan-qS3b3qEq.js +22 -0
  593. package/dist/install-security-scan.runtime-BChyO9J8.js +166 -0
  594. package/dist/install-source-utils-BvLftGQS.js +167 -0
  595. package/dist/install-target-CTg66IIO.js +175 -0
  596. package/dist/install.runtime-BTSq91Fr.js +27 -0
  597. package/dist/install.runtime-D4V_unI1.js +11 -0
  598. package/dist/installs-CRoSOFIQ.js +28 -0
  599. package/dist/interactive-C3NpHdfG.js +8 -0
  600. package/dist/interactive-runtime-ihi8xJat.js +1 -0
  601. package/dist/internal-DBQug4hL.js +411 -0
  602. package/dist/internal-hooks-BbEvCG0I.js +155 -0
  603. package/dist/io-B07IaARR.js +20276 -0
  604. package/dist/io-CNajM2P9.js +4 -0
  605. package/dist/ip-B9fdE2gz.js +208 -0
  606. package/dist/ipv4-C3dcphoh.js +82 -0
  607. package/dist/irc-surface-76sLILVt.js +15 -0
  608. package/dist/is-main-Bv5ej4lF.js +27 -0
  609. package/dist/issue-format-BSF24W54.js +31 -0
  610. package/dist/issue-format-DOmwnG2e.js +2 -0
  611. package/dist/json-file-BWMSefn1.js +23 -0
  612. package/dist/json-files-BTzholfl.js +72 -0
  613. package/dist/json-mode-BSMgY7a9.js +34 -0
  614. package/dist/json-pointer-jqlJaexT.js +43 -0
  615. package/dist/json-store-BMjN0M0e.js +37 -0
  616. package/dist/keyed-async-queue-BThh1lNJ.js +32 -0
  617. package/dist/kill-tree-B6ozo-AE.js +82 -0
  618. package/dist/kill-tree-Cqktd2UA.js +2 -0
  619. package/dist/launchd-D65d45MJ.js +517 -0
  620. package/dist/lazy-runtime-CeSDvNOX.js +29 -0
  621. package/dist/lazy-service-module-BfNSCPnr.js +24 -0
  622. package/dist/legacy-names-alNfx9uv.js +7 -0
  623. package/dist/legacy-web-search-PlL5wfRE.js +140 -0
  624. package/dist/legacy.shared-BdJdF_Ji.js +45 -0
  625. package/dist/level-overrides-DkpAP8Z5.js +36 -0
  626. package/dist/library-D0LkGi9S.js +44 -0
  627. package/dist/lifecycle-core-LQrm8n7o.js +401 -0
  628. package/dist/line-C7MzXHd9.js +4 -0
  629. package/dist/line-runtime-D0TK2zdy.js +60 -0
  630. package/dist/line-surface-CN8Lvuud.js +27 -0
  631. package/dist/links-Dew9XRNK.js +17 -0
  632. package/dist/listeners-CUHNPyTB.js +14 -0
  633. package/dist/llm-slug-generator-DdO4_-IV.js +68 -0
  634. package/dist/llm-slug-generator.js +2 -0
  635. package/dist/load-CadZ3tcc.js +28 -0
  636. package/dist/loader-CbUrcgTY.js +2096 -0
  637. package/dist/local-file-access-BKg2BnYT.js +49 -0
  638. package/dist/location-DAl2Dv-o.js +42 -0
  639. package/dist/logger-BOH4EG1g.js +75 -0
  640. package/dist/logger-DXmZnecR.js +582 -0
  641. package/dist/logger-hR5Nn0oR.js +11 -0
  642. package/dist/logging-BVrQyk5K.js +13 -0
  643. package/dist/logging-BoyMPDyh.js +16 -0
  644. package/dist/logging-DPN6sRQx.js +3 -0
  645. package/dist/logging-core-BOrwsQp5.js +3 -0
  646. package/dist/logging-x8ySQJz4.js +2 -0
  647. package/dist/logs-cli-DUKwlDzr.js +221 -0
  648. package/dist/magic-string.es-CnHiwmBJ.js +1011 -0
  649. package/dist/main-session-BQ1fLshb.js +38 -0
  650. package/dist/manager-BfZUkAlZ.js +7 -0
  651. package/dist/manager.runtime-CiRcAT_V.js +670 -0
  652. package/dist/manifest-D49j8zhq.js +231 -0
  653. package/dist/manifest-registry-CVwreH55.js +955 -0
  654. package/dist/map-size-CHeGE-Hu.js +15 -0
  655. package/dist/markdown-tables-D2sUymqZ.js +31 -0
  656. package/dist/mask-api-key-Dxw856id.js +10 -0
  657. package/dist/matrix-Ds9X7gxo.js +340 -0
  658. package/dist/matrix-config-helpers-CXItIHIe.js +153 -0
  659. package/dist/matrix-helper-dQNUz9y1.js +20 -0
  660. package/dist/matrix-migration-snapshot-BSPlCZpf.js +714 -0
  661. package/dist/matrix-runtime-surface-Dggb-0DD.js +12 -0
  662. package/dist/matrix-surface-CxJ9TM8l.js +13 -0
  663. package/dist/matrix-thread-bindings-CT4Dqsid.js +12 -0
  664. package/dist/mcp/plugin-tools-serve.js +105 -0
  665. package/dist/mcp-cli-IzvP-l2E.js +768 -0
  666. package/dist/mcp-config-Bul9F_lO.js +117 -0
  667. package/dist/media-limits-CfgImPSH.js +14 -0
  668. package/dist/media-runtime-D2qFlSNy.js +293 -0
  669. package/dist/media-understanding-D930-yxA.js +43 -0
  670. package/dist/media-understanding-provider-WeSvV5Jz.js +27 -0
  671. package/dist/media-understanding-runtime-C2xB_w9c.js +15 -0
  672. package/dist/media-understanding.runtime-Cad8YO-5.js +7 -0
  673. package/dist/memory-core-engine-runtime-e08xLNwK.js +14 -0
  674. package/dist/memory-core-host-engine-embeddings-CeqjF8mF.js +1369 -0
  675. package/dist/memory-core-host-engine-qmd-2rX9HR2g.js +375 -0
  676. package/dist/memory-core-host-engine-storage-BocZ6yow.js +109 -0
  677. package/dist/memory-core-host-multimodal-DgBuQzZm.js +1 -0
  678. package/dist/memory-core-host-query-Cekrv97-.js +2 -0
  679. package/dist/memory-core-host-runtime-cli--EQHw17R.js +10 -0
  680. package/dist/memory-core-host-runtime-core-DX17el9Z.js +8 -0
  681. package/dist/memory-core-host-runtime-files-CeDFldc-.js +3 -0
  682. package/dist/memory-core-host-secret-BUGjwboV.js +1 -0
  683. package/dist/memory-core-host-status-C7nF33J8.js +44 -0
  684. package/dist/memory-embedding-providers-C8KLZUqC.js +34 -0
  685. package/dist/memory-runtime-D2rQY7mY.js +2 -0
  686. package/dist/memory-runtime-WuWYrOU9.js +30 -0
  687. package/dist/memory-search-BQs_twVs.js +2 -0
  688. package/dist/memory-search-L16IM5VZ.js +202 -0
  689. package/dist/memory-state-BPOopEhZ.js +41 -0
  690. package/dist/mention-gating-BJSMiJu8.js +25 -0
  691. package/dist/mentions-D0fLhfbe.js +155 -0
  692. package/dist/mentions-Ksl6lu1X.js +65 -0
  693. package/dist/merge-patch-CY3S-7zE.js +240 -0
  694. package/dist/message-D1nCeSGV.js +205 -0
  695. package/dist/message-action-discovery-Bp_zFTg1.js +133 -0
  696. package/dist/message-action-runner-DOaZ7jbV.js +1601 -0
  697. package/dist/message-channel-Di9LQZCg.js +105 -0
  698. package/dist/message-handler-CVxycGRP.js +1759 -0
  699. package/dist/message-hook-mappers-CgJovp_6.js +255 -0
  700. package/dist/message-secret-scope-BsvGcXOU.js +104 -0
  701. package/dist/method-scopes-1fMDkPgy.js +2608 -0
  702. package/dist/mime-CPj5mSwT.js +150 -0
  703. package/dist/min-host-version-BROqyGiT.js +348 -0
  704. package/dist/minimax-vlm-ciXgon3-.js +502 -0
  705. package/dist/model-auth-FAjaPIyj.js +330 -0
  706. package/dist/model-auth-env-aXebmtnO.js +42 -0
  707. package/dist/model-auth-label-BdkmYsfL.js +45 -0
  708. package/dist/model-auth-markers-CAxoOhNr.js +70 -0
  709. package/dist/model-auth-runtime-shared-C6EfNsiC.js +18 -0
  710. package/dist/model-catalog-DcYmAWnK.js +208 -0
  711. package/dist/model-catalog.runtime-BnfcWBe6.js +2 -0
  712. package/dist/model-input-shLH7pnZ.js +20 -0
  713. package/dist/model-overrides-CCPXEsf4.js +61 -0
  714. package/dist/model-overrides-CbljEHPO.js +84 -0
  715. package/dist/model-param-b-C9Se0GAW.js +15 -0
  716. package/dist/model-picker-7YHY1_DM.js +439 -0
  717. package/dist/model-picker-cAVRu3J8.js +3 -0
  718. package/dist/model-picker.runtime-DbCF7jcT.js +15 -0
  719. package/dist/model-selection-DLV9QudA.js +486 -0
  720. package/dist/model-selection-teaznyVt.js +407 -0
  721. package/dist/model-suppression-DxU9Wl3w.js +24 -0
  722. package/dist/model-suppression.runtime-DdJpj7Pn.js +7 -0
  723. package/dist/models-BktgoCTN.js +3 -0
  724. package/dist/models-DxC1yWIR.js +2550 -0
  725. package/dist/models-cli-BQJGDwlZ.js +197 -0
  726. package/dist/models-config-BrM95ZWn.js +2 -0
  727. package/dist/models-config-WznILp-f.js +1106 -0
  728. package/dist/models-config.runtime-DKvV7dBw.js +2 -0
  729. package/dist/monitor-B7Wimfc0.js +6004 -0
  730. package/dist/moonshot-stream-wrappers-CAVTNNIV.js +27 -0
  731. package/dist/moonshot-thinking-stream-wrappers-DSGFaY0P.js +69 -0
  732. package/dist/multimodal-fHfIB02R.js +66 -0
  733. package/dist/mutable-allowlist-detectors-Cz3_rHTS.js +62 -0
  734. package/dist/native-command-session-targets-YEwzYdBY.js +10 -0
  735. package/dist/net-DV8cgxeU.js +264 -0
  736. package/dist/network-mode-DlVi9UOI.js +17 -0
  737. package/dist/node-cli-BOOTFx0A.js +2201 -0
  738. package/dist/node-command-policy-H9JvUbqw.js +190 -0
  739. package/dist/node-commands-CtUW-J-z.js +11 -0
  740. package/dist/node-require-BgDD9bTi.js +14 -0
  741. package/dist/node-resolve-r0n2qCFZ.js +110 -0
  742. package/dist/node-service-BTIQHcIe.js +68 -0
  743. package/dist/node-startup-env-CVMjxAUF.js +50 -0
  744. package/dist/nodes-cli-DSe8_891.js +1050 -0
  745. package/dist/nodes-screen-BFBwMK0F.js +219 -0
  746. package/dist/nodes.helpers-C5_joVF0.js +204 -0
  747. package/dist/normalize-TCHtmmQz.js +35 -0
  748. package/dist/normalize-reply-D3AZv-Ku.js +500 -0
  749. package/dist/normalize-secret-input-Botsab7G.js +32 -0
  750. package/dist/note-BopuvWl0.js +109 -0
  751. package/dist/npm-registry-spec-C04c6qSA.js +100 -0
  752. package/dist/ollama-DHGG2Bt4.js +26 -0
  753. package/dist/ollama-surface-C297W-Hb.js +24 -0
  754. package/dist/onboard-BLF26Ra3.js +591 -0
  755. package/dist/onboard-channels-C7VwUlqL.js +2 -0
  756. package/dist/onboard-channels-CNYuwk6A.js +705 -0
  757. package/dist/onboard-config-BHR99vFk.js +2 -0
  758. package/dist/onboard-config-CDwd7KFG.js +29 -0
  759. package/dist/onboard-custom-B-SjrGJ_.js +2 -0
  760. package/dist/onboard-custom-BYciMnUV.js +646 -0
  761. package/dist/onboard-helpers-CXSVhHmw.js +4 -0
  762. package/dist/onboard-helpers-DQzH15KX.js +272 -0
  763. package/dist/onboard-hooks-dbSmp47O.js +52 -0
  764. package/dist/onboard-remote-76zO-wtV.js +2 -0
  765. package/dist/onboard-remote-CV8CYWRk.js +193 -0
  766. package/dist/onboard-search-CR1tclPf.js +339 -0
  767. package/dist/onboard-skills-B3nol3_I.js +2 -0
  768. package/dist/onboard-skills-BWzgYZiw.js +134 -0
  769. package/dist/openai-CYdnp7Xp.js +21 -0
  770. package/dist/openai-codex-auth-identity-DYIekza3.js +40 -0
  771. package/dist/openai-codex-catalog-C9jNVPkk.js +11 -0
  772. package/dist/openai-codex-provider-CihFFdms.js +254 -0
  773. package/dist/openai-provider-CY9og1U4.js +272 -0
  774. package/dist/openai-stream-wrappers-DMltslUP.js +453 -0
  775. package/dist/operator-approvals-client-CrZARXVS.js +33 -0
  776. package/dist/order-EE5jGs_C.js +744 -0
  777. package/dist/origin-routing-IIB1gZNP.js +15 -0
  778. package/dist/os-summary-B2xVpxVk.js +26 -0
  779. package/dist/outbound-adapter-BXuNyLX4.js +181 -0
  780. package/dist/outbound-media-Do8el7w-.js +48 -0
  781. package/dist/outbound-runtime-BsrPMYQX.js +2 -0
  782. package/dist/outbound-send-deps-RCYokJDu.js +7 -0
  783. package/dist/pairing-challenge-C6zO1O_e.js +33 -0
  784. package/dist/pairing-cli-lSGiQegx.js +116 -0
  785. package/dist/pairing-labels-CqTzyQv4.js +7 -0
  786. package/dist/pairing-message-CLV_7GCg.js +4 -0
  787. package/dist/pairing-messages-Bms_bews.js +23 -0
  788. package/dist/pairing-pending-CymkYopg.js +14 -0
  789. package/dist/pairing-store-BgSXc67b.js +617 -0
  790. package/dist/pairing-token-trqjnXaR.js +80 -0
  791. package/dist/parse-duration-FGYGEVrK.js +41 -0
  792. package/dist/parse-finite-number-CpMi4ac9.js +30 -0
  793. package/dist/parse-log-line-DB02BPsG.js +43 -0
  794. package/dist/parse-port-CfkrReDG.js +8 -0
  795. package/dist/parse-timeout-CqVxIetA.js +27 -0
  796. package/dist/path-alias-guards-CTG--JDv.js +40 -0
  797. package/dist/path-env-Coe9j6U3.js +87 -0
  798. package/dist/path-safety-BtrNm8CZ.js +12 -0
  799. package/dist/paths-dFp6bjkV.js +180 -0
  800. package/dist/paths-voC5pD8X.js +201 -0
  801. package/dist/payload-BiCTL_Go.js +90 -0
  802. package/dist/pdf-extract-DYqhcrys.js +73 -0
  803. package/dist/persistent-bindings.resolve-BG1W2wH2.js +12 -0
  804. package/dist/persistent-bindings.types-yg27a-LN.js +6 -0
  805. package/dist/persistent-dedupe-DeJFOp8F.js +116 -0
  806. package/dist/pi-model-discovery-4V1cP6C-.js +188 -0
  807. package/dist/pi-settings-tFYTni5h.js +57 -0
  808. package/dist/plugin-approvals-BBS3Vgt6.js +34 -0
  809. package/dist/plugin-auto-enable-B4gIDfiP.js +349 -0
  810. package/dist/plugin-entry-D7EjsbGL.js +25 -0
  811. package/dist/plugin-install-CBe57uiZ.js +2 -0
  812. package/dist/plugin-install-PbQ6ukY-.js +191 -0
  813. package/dist/plugin-install-config-policy-MQbVt-fA.js +93 -0
  814. package/dist/plugin-install-path-warnings-BfBOA9nm.js +40 -0
  815. package/dist/plugin-install-plan-DKH1Osjr.js +50 -0
  816. package/dist/plugin-registry-D2DvWTxI.js +2 -0
  817. package/dist/plugin-registry-t_GnpNNe.js +70 -0
  818. package/dist/plugin-runtime-kxm6OF3O.js +6 -0
  819. package/dist/plugin-sdk/account-core.js +8 -0
  820. package/dist/plugin-sdk/account-helpers.js +4 -0
  821. package/dist/plugin-sdk/account-id.js +3 -0
  822. package/dist/plugin-sdk/account-resolution.js +12 -0
  823. package/dist/plugin-sdk/acp-runtime.js +6 -0
  824. package/dist/plugin-sdk/agent-config-primitives.js +3 -0
  825. package/dist/plugin-sdk/agent-runtime.js +29 -0
  826. package/dist/plugin-sdk/allow-from.js +5 -0
  827. package/dist/plugin-sdk/allowlist-config-edit.js +2 -0
  828. package/dist/plugin-sdk/amazon-bedrock.js +15 -0
  829. package/dist/plugin-sdk/anthropic-vertex.js +2 -0
  830. package/dist/plugin-sdk/approval-runtime.js +7 -0
  831. package/dist/plugin-sdk/bluebubbles-policy.js +2 -0
  832. package/dist/plugin-sdk/bluebubbles.js +255 -0
  833. package/dist/plugin-sdk/boolean-param.js +2 -0
  834. package/dist/plugin-sdk/browser-runtime.js +2 -0
  835. package/dist/plugin-sdk/browser-support.js +44 -0
  836. package/dist/plugin-sdk/browser.js +15 -0
  837. package/dist/plugin-sdk/byteplus.js +17 -0
  838. package/dist/plugin-sdk/channel-actions.js +3 -0
  839. package/dist/plugin-sdk/channel-config-helpers.js +2 -0
  840. package/dist/plugin-sdk/channel-config-primitives.js +3 -0
  841. package/dist/plugin-sdk/channel-config-schema.js +7 -0
  842. package/dist/plugin-sdk/channel-config-writes.js +2 -0
  843. package/dist/plugin-sdk/channel-contract.js +1 -0
  844. package/dist/plugin-sdk/channel-feedback.js +5 -0
  845. package/dist/plugin-sdk/channel-inbound.js +10 -0
  846. package/dist/plugin-sdk/channel-lifecycle.js +3 -0
  847. package/dist/plugin-sdk/channel-pairing.js +2 -0
  848. package/dist/plugin-sdk/channel-policy.js +6 -0
  849. package/dist/plugin-sdk/channel-reply-pipeline.js +2 -0
  850. package/dist/plugin-sdk/channel-runtime.js +15 -0
  851. package/dist/plugin-sdk/channel-send-result.js +2 -0
  852. package/dist/plugin-sdk/channel-setup.js +5 -0
  853. package/dist/plugin-sdk/channel-status.js +5 -0
  854. package/dist/plugin-sdk/channel-targets.js +4 -0
  855. package/dist/plugin-sdk/chutes.js +20 -0
  856. package/dist/plugin-sdk/cli-backend.js +3 -0
  857. package/dist/plugin-sdk/cli-runtime.js +6 -0
  858. package/dist/plugin-sdk/cloudflare-ai-gateway.js +18 -0
  859. package/dist/plugin-sdk/collection-runtime.js +2 -0
  860. package/dist/plugin-sdk/command-auth-native.js +6 -0
  861. package/dist/plugin-sdk/command-auth.js +14 -0
  862. package/dist/plugin-sdk/compat.js +35 -0
  863. package/dist/plugin-sdk/config-runtime.js +22 -0
  864. package/dist/plugin-sdk/conversation-runtime.js +15 -0
  865. package/dist/plugin-sdk/core.js +22 -0
  866. package/dist/plugin-sdk/deepseek.js +14 -0
  867. package/dist/plugin-sdk/device-bootstrap.js +3 -0
  868. package/dist/plugin-sdk/diagnostic-runtime.js +4 -0
  869. package/dist/plugin-sdk/diagnostics-otel.js +5 -0
  870. package/dist/plugin-sdk/diffs.js +3 -0
  871. package/dist/plugin-sdk/direct-dm.js +2 -0
  872. package/dist/plugin-sdk/directory-runtime.js +5 -0
  873. package/dist/plugin-sdk/discord-account.js +2 -0
  874. package/dist/plugin-sdk/discord-core.js +9 -0
  875. package/dist/plugin-sdk/discord-runtime-surface.js +2 -0
  876. package/dist/plugin-sdk/discord-session-key.js +2 -0
  877. package/dist/plugin-sdk/discord-surface.js +2 -0
  878. package/dist/plugin-sdk/discord-thread-bindings.js +2 -0
  879. package/dist/plugin-sdk/discord-timeouts.js +2 -0
  880. package/dist/plugin-sdk/discord.js +21 -0
  881. package/dist/plugin-sdk/error-runtime.js +3 -0
  882. package/dist/plugin-sdk/extension-shared.js +75 -0
  883. package/dist/plugin-sdk/feishu-conversation.js +2 -0
  884. package/dist/plugin-sdk/feishu-setup.js +2 -0
  885. package/dist/plugin-sdk/feishu.js +33 -0
  886. package/dist/plugin-sdk/fetch-runtime.js +7 -0
  887. package/dist/plugin-sdk/file-lock.js +2 -0
  888. package/dist/plugin-sdk/gateway-runtime.js +4 -0
  889. package/dist/plugin-sdk/github-copilot-login.js +2 -0
  890. package/dist/plugin-sdk/github-copilot-token.js +2 -0
  891. package/dist/plugin-sdk/global-singleton.js +4 -0
  892. package/dist/plugin-sdk/google.js +2 -0
  893. package/dist/plugin-sdk/googlechat.js +58 -0
  894. package/dist/plugin-sdk/group-access.js +2 -0
  895. package/dist/plugin-sdk/hook-runtime.js +4 -0
  896. package/dist/plugin-sdk/host-runtime.js +3 -0
  897. package/dist/plugin-sdk/huggingface.js +18 -0
  898. package/dist/plugin-sdk/image-generation-core.js +63 -0
  899. package/dist/plugin-sdk/image-generation.js +2 -0
  900. package/dist/plugin-sdk/index.js +5 -0
  901. package/dist/plugin-sdk/infra-runtime.js +45 -0
  902. package/dist/plugin-sdk/interactive-runtime.js +4 -0
  903. package/dist/plugin-sdk/irc-surface.js +2 -0
  904. package/dist/plugin-sdk/irc.js +30 -0
  905. package/dist/plugin-sdk/json-store.js +3 -0
  906. package/dist/plugin-sdk/keyed-async-queue.js +2 -0
  907. package/dist/plugin-sdk/kilocode.js +23 -0
  908. package/dist/plugin-sdk/kimi-coding.js +11 -0
  909. package/dist/plugin-sdk/lazy-runtime.js +2 -0
  910. package/dist/plugin-sdk/line-core.js +6 -0
  911. package/dist/plugin-sdk/line-runtime.js +2 -0
  912. package/dist/plugin-sdk/line-surface.js +2 -0
  913. package/dist/plugin-sdk/line.js +9 -0
  914. package/dist/plugin-sdk/llm-task.js +5 -0
  915. package/dist/plugin-sdk/logging-core.js +5 -0
  916. package/dist/plugin-sdk/matrix-helper.js +2 -0
  917. package/dist/plugin-sdk/matrix-runtime-heavy.js +4 -0
  918. package/dist/plugin-sdk/matrix-runtime-shared.js +2 -0
  919. package/dist/plugin-sdk/matrix-runtime-surface.js +2 -0
  920. package/dist/plugin-sdk/matrix-surface.js +2 -0
  921. package/dist/plugin-sdk/matrix-thread-bindings.js +2 -0
  922. package/dist/plugin-sdk/matrix.js +64 -0
  923. package/dist/plugin-sdk/mattermost-policy.js +11 -0
  924. package/dist/plugin-sdk/mattermost.js +42 -0
  925. package/dist/plugin-sdk/media-runtime.js +15 -0
  926. package/dist/plugin-sdk/media-understanding-runtime.js +2 -0
  927. package/dist/plugin-sdk/media-understanding.js +3 -0
  928. package/dist/plugin-sdk/memory-core-engine-runtime.js +2 -0
  929. package/dist/plugin-sdk/memory-core-host-engine-embeddings.js +6 -0
  930. package/dist/plugin-sdk/memory-core-host-engine-foundation.js +17 -0
  931. package/dist/plugin-sdk/memory-core-host-engine-qmd.js +3 -0
  932. package/dist/plugin-sdk/memory-core-host-engine-storage.js +4 -0
  933. package/dist/plugin-sdk/memory-core-host-multimodal.js +3 -0
  934. package/dist/plugin-sdk/memory-core-host-query.js +3 -0
  935. package/dist/plugin-sdk/memory-core-host-runtime-cli.js +12 -0
  936. package/dist/plugin-sdk/memory-core-host-runtime-core.js +13 -0
  937. package/dist/plugin-sdk/memory-core-host-runtime-files.js +4 -0
  938. package/dist/plugin-sdk/memory-core-host-secret.js +3 -0
  939. package/dist/plugin-sdk/memory-core-host-status.js +2 -0
  940. package/dist/plugin-sdk/memory-core.js +28 -0
  941. package/dist/plugin-sdk/memory-lancedb.js +4 -0
  942. package/dist/plugin-sdk/minimax.js +24 -0
  943. package/dist/plugin-sdk/mistral.js +17 -0
  944. package/dist/plugin-sdk/modelstudio-definitions.js +19 -0
  945. package/dist/plugin-sdk/modelstudio.js +24 -0
  946. package/dist/plugin-sdk/moonshot.js +17 -0
  947. package/dist/plugin-sdk/msteams.js +54 -0
  948. package/dist/plugin-sdk/nextcloud-talk.js +35 -0
  949. package/dist/plugin-sdk/nostr.js +24 -0
  950. package/dist/plugin-sdk/nvidia.js +11 -0
  951. package/dist/plugin-sdk/ollama-surface.js +2 -0
  952. package/dist/plugin-sdk/ollama.js +2 -0
  953. package/dist/plugin-sdk/openai.js +2 -0
  954. package/dist/plugin-sdk/opencode-go.js +14 -0
  955. package/dist/plugin-sdk/opencode.js +15 -0
  956. package/dist/plugin-sdk/outbound-runtime.js +5 -0
  957. package/dist/plugin-sdk/param-readers.js +2 -0
  958. package/dist/plugin-sdk/plugin-entry.js +3 -0
  959. package/dist/plugin-sdk/plugin-runtime.js +8 -0
  960. package/dist/plugin-sdk/process-runtime.js +2 -0
  961. package/dist/plugin-sdk/provider-auth-api-key.js +9 -0
  962. package/dist/plugin-sdk/provider-auth-login.js +2 -0
  963. package/dist/plugin-sdk/provider-auth-result.js +2 -0
  964. package/dist/plugin-sdk/provider-auth-runtime.js +5 -0
  965. package/dist/plugin-sdk/provider-auth.js +17 -0
  966. package/dist/plugin-sdk/provider-catalog-shared.js +2 -0
  967. package/dist/plugin-sdk/provider-entry.js +86 -0
  968. package/dist/plugin-sdk/provider-env-vars.js +2 -0
  969. package/dist/plugin-sdk/provider-http.js +3 -0
  970. package/dist/plugin-sdk/provider-model-shared.js +5 -0
  971. package/dist/plugin-sdk/provider-moonshot.js +3 -0
  972. package/dist/plugin-sdk/provider-onboard.js +3 -0
  973. package/dist/plugin-sdk/provider-setup.js +2 -0
  974. package/dist/plugin-sdk/provider-stream.js +4 -0
  975. package/dist/plugin-sdk/provider-tools.js +2 -0
  976. package/dist/plugin-sdk/provider-usage.js +3 -0
  977. package/dist/plugin-sdk/provider-web-search.js +6 -0
  978. package/dist/plugin-sdk/provider-zai-endpoint.js +116 -0
  979. package/dist/plugin-sdk/qianfan.js +13 -0
  980. package/dist/plugin-sdk/reply-chunking.js +3 -0
  981. package/dist/plugin-sdk/reply-dispatch-runtime.js +5 -0
  982. package/dist/plugin-sdk/reply-history.js +3 -0
  983. package/dist/plugin-sdk/reply-payload.js +2 -0
  984. package/dist/plugin-sdk/reply-runtime.js +14 -0
  985. package/dist/plugin-sdk/request-url.js +2 -0
  986. package/dist/plugin-sdk/retry-runtime.js +4 -0
  987. package/dist/plugin-sdk/root-alias.cjs +347 -0
  988. package/dist/plugin-sdk/routing.js +9 -0
  989. package/dist/plugin-sdk/runtime-env.js +17 -0
  990. package/dist/plugin-sdk/runtime-store.js +2 -0
  991. package/dist/plugin-sdk/runtime.js +9 -0
  992. package/dist/plugin-sdk/sandbox.js +5 -0
  993. package/dist/plugin-sdk/secret-input.js +4 -0
  994. package/dist/plugin-sdk/security-runtime.js +5 -0
  995. package/dist/plugin-sdk/self-hosted-provider-setup.js +2 -0
  996. package/dist/plugin-sdk/setup-adapter-runtime.js +3 -0
  997. package/dist/plugin-sdk/setup-runtime.js +6 -0
  998. package/dist/plugin-sdk/setup-tools.js +6 -0
  999. package/dist/plugin-sdk/setup.js +13 -0
  1000. package/dist/plugin-sdk/sglang.js +15 -0
  1001. package/dist/plugin-sdk/signal-account.js +2 -0
  1002. package/dist/plugin-sdk/signal-surface.js +2 -0
  1003. package/dist/plugin-sdk/signal.js +24 -0
  1004. package/dist/plugin-sdk/slack-account.js +2 -0
  1005. package/dist/plugin-sdk/slack-core.js +7 -0
  1006. package/dist/plugin-sdk/slack-runtime-surface.js +2 -0
  1007. package/dist/plugin-sdk/slack-surface.js +2 -0
  1008. package/dist/plugin-sdk/slack-target-parser.js +2 -0
  1009. package/dist/plugin-sdk/slack-targets.js +3 -0
  1010. package/dist/plugin-sdk/slack.js +20 -0
  1011. package/dist/plugin-sdk/speech-core.js +4 -0
  1012. package/dist/plugin-sdk/speech-runtime.js +2 -0
  1013. package/dist/plugin-sdk/speech.js +5 -0
  1014. package/dist/plugin-sdk/ssrf-runtime.js +6 -0
  1015. package/dist/plugin-sdk/state-paths.js +3 -0
  1016. package/dist/plugin-sdk/status-helpers.js +4 -0
  1017. package/dist/plugin-sdk/synthetic.js +17 -0
  1018. package/dist/plugin-sdk/telegram-account.js +2 -0
  1019. package/dist/plugin-sdk/telegram-allow-from.js +12 -0
  1020. package/dist/plugin-sdk/telegram-core.js +18 -0
  1021. package/dist/plugin-sdk/telegram-surface.js +42 -0
  1022. package/dist/plugin-sdk/temp-path.js +4 -0
  1023. package/dist/plugin-sdk/testing.js +11 -0
  1024. package/dist/plugin-sdk/text-runtime.js +20 -0
  1025. package/dist/plugin-sdk/thread-bindings-runtime.js +3 -0
  1026. package/dist/plugin-sdk/thread-ownership.js +4 -0
  1027. package/dist/plugin-sdk/tlon.js +23 -0
  1028. package/dist/plugin-sdk/together.js +16 -0
  1029. package/dist/plugin-sdk/tool-send.js +2 -0
  1030. package/dist/plugin-sdk/twitch.js +17 -0
  1031. package/dist/plugin-sdk/venice.js +16 -0
  1032. package/dist/plugin-sdk/vllm.js +15 -0
  1033. package/dist/plugin-sdk/voice-call.js +6 -0
  1034. package/dist/plugin-sdk/volcengine.js +17 -0
  1035. package/dist/plugin-sdk/web-media.js +3 -0
  1036. package/dist/plugin-sdk/webhook-ingress.js +9 -0
  1037. package/dist/plugin-sdk/webhook-path.js +2 -0
  1038. package/dist/plugin-sdk/webhook-request-guards.js +3 -0
  1039. package/dist/plugin-sdk/whatsapp-auth-presence.js +3 -0
  1040. package/dist/plugin-sdk/whatsapp-core.js +11 -0
  1041. package/dist/plugin-sdk/whatsapp-shared.js +3 -0
  1042. package/dist/plugin-sdk/whatsapp-surface.js +2 -0
  1043. package/dist/plugin-sdk/whatsapp-targets.js +2 -0
  1044. package/dist/plugin-sdk/windows-spawn.js +2 -0
  1045. package/dist/plugin-sdk/xai.js +2 -0
  1046. package/dist/plugin-sdk/zalo-setup.js +2 -0
  1047. package/dist/plugin-sdk/zalo.js +37 -0
  1048. package/dist/plugin-sdk/zalouser.js +39 -0
  1049. package/dist/plugin-sdk/zod.js +2 -0
  1050. package/dist/plugins/build-smoke-entry.js +4 -0
  1051. package/dist/plugins/provider-runtime.runtime.js +2 -0
  1052. package/dist/plugins/runtime/index.js +2 -0
  1053. package/dist/plugins/runtime/runtime-line.contract.js +23 -0
  1054. package/dist/plugins-BUhqQahf.js +7 -0
  1055. package/dist/plugins-D3E9gBoB.js +5 -0
  1056. package/dist/plugins-allowlist-BsE4VUd6.js +14 -0
  1057. package/dist/plugins-cli-DNIRlpEw.js +551 -0
  1058. package/dist/plugins-command-helpers-D0cHWZ8k.js +116 -0
  1059. package/dist/plugins-install-persist-B4VRDkMW.js +121 -0
  1060. package/dist/plugins-update-command-CVpqSCHk.js +974 -0
  1061. package/dist/pluralkit-BLAFsOsu.js +21 -0
  1062. package/dist/poll-params-BRovIMUP.js +52 -0
  1063. package/dist/polls-BJAJSaiP.js +35 -0
  1064. package/dist/port-defaults-BSVMFkjY.js +30 -0
  1065. package/dist/ports-Bc5Ccog1.js +262 -0
  1066. package/dist/ports-C4UXOMrf.js +432 -0
  1067. package/dist/ports-lsof-BGtOoYbU.js +25 -0
  1068. package/dist/ports-probe-BsWR8TFT.js +14 -0
  1069. package/dist/preflight-audio.runtime-C9Vy2rmC.js +7 -0
  1070. package/dist/probe-BQag0DWb.js +178 -0
  1071. package/dist/probe-Ba_tzX9A.js +383 -0
  1072. package/dist/probe-CU89zpYY.js +2 -0
  1073. package/dist/probe-DqrD8L5s.js +137 -0
  1074. package/dist/probe-auth-B_8xyHva.js +63 -0
  1075. package/dist/probe-auth-ynM8e9Ac.js +2 -0
  1076. package/dist/probe.runtime-CJ9xp7YD.js +2 -0
  1077. package/dist/process-scoped-map-DSo5-USL.js +61 -0
  1078. package/dist/profile-utils-C7uzTwgJ.js +15 -0
  1079. package/dist/profiles-bHSSYfJl.js +79 -0
  1080. package/dist/program-context-87EEruZh.js +10 -0
  1081. package/dist/program-context-D14SwQxo.js +2 -0
  1082. package/dist/program-wvgzSxLY.js +158 -0
  1083. package/dist/progress-BvK_oMpz.js +132 -0
  1084. package/dist/prompt-CtkpPKiX.js +2 -0
  1085. package/dist/prompt-DOBS3BID.js +20 -0
  1086. package/dist/prompt-select-styled-c91_PlKW.js +5468 -0
  1087. package/dist/prompt-style-DRmsfagi.js +7 -0
  1088. package/dist/prompts-DAJPf5yB.js +9 -0
  1089. package/dist/prototype-keys-BWjW0VW8.js +11 -0
  1090. package/dist/provider-C6dmSPJE.js +7237 -0
  1091. package/dist/provider-api-key-auth-BBRnMefH.js +109 -0
  1092. package/dist/provider-api-key-auth.runtime-obo7wOYn.js +14 -0
  1093. package/dist/provider-auth-BTrDFsFt.js +43 -0
  1094. package/dist/provider-auth-api-key-BhD_cXM7.js +5 -0
  1095. package/dist/provider-auth-choice-2fsBmYtb.js +134 -0
  1096. package/dist/provider-auth-choice-helpers-DLlNwVwg.js +58 -0
  1097. package/dist/provider-auth-choice-preference-BkZTzT1J.js +44 -0
  1098. package/dist/provider-auth-choice.runtime-BHkXn7WH.js +14 -0
  1099. package/dist/provider-auth-choice.runtime-r6ydqD_o.js +2 -0
  1100. package/dist/provider-auth-choices-AHFkSF9C.js +65 -0
  1101. package/dist/provider-auth-guidance-Bo67Hboq.js +35 -0
  1102. package/dist/provider-auth-helpers-Bk-AB5Wp.js +92 -0
  1103. package/dist/provider-auth-input-kKdGWlxc.js +116 -0
  1104. package/dist/provider-auth-login-dOLrU5NV.js +8 -0
  1105. package/dist/provider-auth-login.runtime-C_GzFGmF.js +196 -0
  1106. package/dist/provider-auth-mode-B8uz1z07.js +20 -0
  1107. package/dist/provider-auth-ref-Bq-MejeL.js +2 -0
  1108. package/dist/provider-auth-ref-DRl66ULG.js +171 -0
  1109. package/dist/provider-auth-result-CkUVvE5c.js +31 -0
  1110. package/dist/provider-auth-runtime-BRAnqbBW.js +32 -0
  1111. package/dist/provider-catalog-shared-BdXDqt2_.js +28 -0
  1112. package/dist/provider-discovery.runtime-BKQXZvW1.js +10 -0
  1113. package/dist/provider-dispatcher-Cic3Zvgm.js +22 -0
  1114. package/dist/provider-env-vars-X-m-m1cR.js +119 -0
  1115. package/dist/provider-flow-rMDy096Q.js +93 -0
  1116. package/dist/provider-id-CTiEzT1T.js +30 -0
  1117. package/dist/provider-model-primary-QC1J1e8s.js +26 -0
  1118. package/dist/provider-model-shared-YwZtB78q.js +104 -0
  1119. package/dist/provider-oauth-flow-DGhuMjqj.js +33 -0
  1120. package/dist/provider-onboard-Dhee14q4.js +264 -0
  1121. package/dist/provider-openai-codex-oauth-tls-CExxHKyb.js +101 -0
  1122. package/dist/provider-registry-7IbNpklR.js +49 -0
  1123. package/dist/provider-runtime-C3NxbOtm.js +2 -0
  1124. package/dist/provider-runtime-DWDjorB4.js +275 -0
  1125. package/dist/provider-runtime.runtime-BYVCPiGA.js +26 -0
  1126. package/dist/provider-self-hosted-setup-Cr4L3fdW.js +272 -0
  1127. package/dist/provider-session.runtime-BHtGAIna.js +8 -0
  1128. package/dist/provider-stream-DpUrpHvN.js +266 -0
  1129. package/dist/provider-tools-L23YSx8p.js +37 -0
  1130. package/dist/provider-usage-BWLu6XJt.js +375 -0
  1131. package/dist/provider-usage-BwHu9Ee_.js +3 -0
  1132. package/dist/provider-usage-CfYpxnUD.js +2 -0
  1133. package/dist/provider-usage.fetch-BCNscJcf.js +633 -0
  1134. package/dist/provider-web-search-CJBYgiMq.js +717 -0
  1135. package/dist/provider-wizard-BGXsleZZ.js +209 -0
  1136. package/dist/provider.runtime-BS0qB3qa.js +2 -0
  1137. package/dist/providers-DTi5kDSF.js +59 -0
  1138. package/dist/providers.runtime-7kqrRLzO.js +55 -0
  1139. package/dist/proxy-env-CEq84zdW.js +40 -0
  1140. package/dist/proxy-fetch-BI4S6OOr.js +55 -0
  1141. package/dist/push-apns-btlZ1qmo.js +921 -0
  1142. package/dist/pw-ai-Crk1oU2c.js +1827 -0
  1143. package/dist/qr-cli-CBrnKR40.js +368 -0
  1144. package/dist/qr-cli-D35IbCMe.js +2 -0
  1145. package/dist/query-expansion-CTVRVJBc.js +633 -0
  1146. package/dist/read-only-account-inspect-CtMAYZjJ.js +9 -0
  1147. package/dist/read-only-account-inspect.telegram-DsWhEWsi.js +202 -0
  1148. package/dist/reasoning-tags-C0A8lJGB.js +77 -0
  1149. package/dist/redact-BDinS1q9.js +102 -0
  1150. package/dist/redact-identifier-CIxwZTyq.js +13 -0
  1151. package/dist/redact-sensitive-url-BYqi2BEL.js +50 -0
  1152. package/dist/redirect-headers-BX_akPpf.js +25 -0
  1153. package/dist/ref-contract-D5ynmOGd.js +53 -0
  1154. package/dist/register-lazy-command-C1up25zY.js +43 -0
  1155. package/dist/register.agent-BoS4J17I.js +239 -0
  1156. package/dist/register.backup-CJxtB0Qd.js +236 -0
  1157. package/dist/register.configure-a7pFaHfe.js +15 -0
  1158. package/dist/register.maintenance-BtI8X-uf.js +450 -0
  1159. package/dist/register.message-BQRkPLq3.js +643 -0
  1160. package/dist/register.onboard-CthiWQxu.js +79 -0
  1161. package/dist/register.setup-BnxRKFDi.js +104 -0
  1162. package/dist/register.status-health-sessions-CHaa5NX0.js +705 -0
  1163. package/dist/register.subclis-DKmBSSCn.js +3 -0
  1164. package/dist/register.subclis-TJY--uPt.js +287 -0
  1165. package/dist/registry-8eF_COje.js +667 -0
  1166. package/dist/registry-B84vjqPA.js +11 -0
  1167. package/dist/registry-CJH_346k.js +60 -0
  1168. package/dist/registry-CiuAeUhZ.js +50 -0
  1169. package/dist/registry-DrnXCaTU.js +219 -0
  1170. package/dist/repair-bIiF2iJn.js +112 -0
  1171. package/dist/reply-B1wBiwTS.js +3134 -0
  1172. package/dist/reply-dispatch-runtime-nSg-l3YV.js +3 -0
  1173. package/dist/reply-history-DiOD0MK2.js +2 -0
  1174. package/dist/reply-payload-D0XXyIHC.js +232 -0
  1175. package/dist/reply-payloads-DW1w7Ckr.js +116 -0
  1176. package/dist/reply-payloads-dedupe-BEPyuQQJ.js +135 -0
  1177. package/dist/reply-payloads-dedupe.runtime-ClraIPuB.js +2 -0
  1178. package/dist/reply-prefix-Bmqt3err.js +39 -0
  1179. package/dist/reply-runtime-bbaSgEmi.js +123 -0
  1180. package/dist/reply.runtime-leqfq1BG.js +2 -0
  1181. package/dist/request-url-B5e58odi.js +10 -0
  1182. package/dist/resolve-B-OthG4M.js +2 -0
  1183. package/dist/resolve-BjvAwAfZ.js +619 -0
  1184. package/dist/resolve-bBpW2W5z.js +174 -0
  1185. package/dist/resolve-channels-543uTQ-Q.js +263 -0
  1186. package/dist/resolve-configured-secret-input-string-CcNZQ54A.js +112 -0
  1187. package/dist/resolve-route-CCHWflcJ.js +486 -0
  1188. package/dist/resolve-system-bin-M8rzqZWg.js +120 -0
  1189. package/dist/resolve-users-B2hIFlh6.js +145 -0
  1190. package/dist/resolve-utils-B34dER9i.js +102 -0
  1191. package/dist/response-prefix-template-CmRtMrPn.js +50 -0
  1192. package/dist/restart-sentinel-BEGeUiKE.js +70 -0
  1193. package/dist/restart-stale-pids-Co_AHlf1.js +187 -0
  1194. package/dist/retry-DB6rKQUK.js +76 -0
  1195. package/dist/retry-policy-vpZZs4Ql.js +58 -0
  1196. package/dist/retry-runtime-BwFtUlOC.js +3 -0
  1197. package/dist/root-help-BKc92COf.js +53 -0
  1198. package/dist/route-reply-BhwCACur.js +133 -0
  1199. package/dist/route-reply.runtime-CR3o0GzY.js +2 -0
  1200. package/dist/route-resolution-C30ccEVA.js +1222 -0
  1201. package/dist/routes-BkjFgytb.js +6880 -0
  1202. package/dist/routing-B6ZVsl1G.js +16 -0
  1203. package/dist/rpc-Ceg29ThW.js +67 -0
  1204. package/dist/run-command-Bec0f6Qx.js +32 -0
  1205. package/dist/run-main-B5ZRlNEV.js +425 -0
  1206. package/dist/run-with-concurrency-oNPuq9N9.js +41 -0
  1207. package/dist/runner-BEbGymO4.js +1478 -0
  1208. package/dist/runtime-B3T4VytJ.js +1627 -0
  1209. package/dist/runtime-CiU2aDgB.js +42 -0
  1210. package/dist/runtime-D0VpiCHi.js +125 -0
  1211. package/dist/runtime-Dtd5v6Gj.js +153 -0
  1212. package/dist/runtime-Fhelf5Qd.js +126 -0
  1213. package/dist/runtime-api-B0fBYyFa.js +241 -0
  1214. package/dist/runtime-api-JdnJolgR.js +2484 -0
  1215. package/dist/runtime-discord-ops.runtime-Cc-Clbrs.js +26 -0
  1216. package/dist/runtime-embedded-pi.runtime-CAq8BTmS.js +2 -0
  1217. package/dist/runtime-env-CkoJ2p8u.js +9 -0
  1218. package/dist/runtime-forwarders-BwQHD11s.js +44 -0
  1219. package/dist/runtime-gaN3vB28.js +284 -0
  1220. package/dist/runtime-group-policy-BPxHuPda.js +59 -0
  1221. package/dist/runtime-guard-VWNtYR4l.js +70 -0
  1222. package/dist/runtime-media-understanding.runtime-BnfH3VZb.js +2 -0
  1223. package/dist/runtime-model-auth.runtime-Bd2GMW6W.js +2 -0
  1224. package/dist/runtime-parse-DFyJekfB.js +83 -0
  1225. package/dist/runtime-paths-C22j-CNR.js +333 -0
  1226. package/dist/runtime-schema-Bft9ccja.js +14524 -0
  1227. package/dist/runtime-slack-ops.runtime-qCe8vp_N.js +15 -0
  1228. package/dist/runtime-status-C7QK-Xow.js +109 -0
  1229. package/dist/runtime-status-SEjcftwu.js +15 -0
  1230. package/dist/runtime-store-j5RNDQBQ.js +22 -0
  1231. package/dist/runtime-tts.runtime-IxRggKLH.js +2 -0
  1232. package/dist/runtime-web-tools-Lf22Il6X.js +1891 -0
  1233. package/dist/runtime-whatsapp-boundary-BQeud5Kv.js +6 -0
  1234. package/dist/runtime-whatsapp-boundary-DbAJ9jGX.js +2 -0
  1235. package/dist/safe-regex-tLlDZYfM.js +244 -0
  1236. package/dist/safe-text-CRAu9RDR.js +16 -0
  1237. package/dist/sandbox-DxQGIkI1.js +2698 -0
  1238. package/dist/sandbox-cli-Bd8ECmMx.js +443 -0
  1239. package/dist/sandbox-paths-ui_vqw2W.js +146 -0
  1240. package/dist/sanitize-env-vars-DpPdECQ9.js +82 -0
  1241. package/dist/scan-paths-VhLKL5WT.js +28 -0
  1242. package/dist/scoped-expiring-id-cache-BmlyFPPR.js +35 -0
  1243. package/dist/scp-host-C5NgDe_6.js +62 -0
  1244. package/dist/secret-equal-fMR1DjSl.js +9 -0
  1245. package/dist/secret-file-COQ7QNO9.js +4 -0
  1246. package/dist/secret-file-Dv42g1FG.js +92 -0
  1247. package/dist/secret-input-CzbdxXxu.js +13 -0
  1248. package/dist/secret-input-DJ-sTcOE.js +38 -0
  1249. package/dist/secrets-cli-OoRkxItP.js +2112 -0
  1250. package/dist/secure-random-DJ9MB_Og.js +20 -0
  1251. package/dist/security-cli-CQ4HiQLb.js +477 -0
  1252. package/dist/security-runtime-CU_gbsBJ.js +51 -0
  1253. package/dist/semver-compare-aGN2MIqz.js +53 -0
  1254. package/dist/send-COItao1A.js +2473 -0
  1255. package/dist/send-deps-K4k6Myst.js +19 -0
  1256. package/dist/send-policy-B1t4c2Ab.js +60 -0
  1257. package/dist/server-BPOSwT-c.js +67 -0
  1258. package/dist/server-middleware-QGnAuw-H.js +108 -0
  1259. package/dist/server-node-events-CoM4XGHV.js +454 -0
  1260. package/dist/server-startup-matrix-migration-CMLAopuE.js +1255 -0
  1261. package/dist/service-8Ef_HfQd.js +2 -0
  1262. package/dist/service-DzXqyjgG.js +849 -0
  1263. package/dist/session-DNTpr0A7.js +50 -0
  1264. package/dist/session-archive.runtime-Bz20yPKg.js +2 -0
  1265. package/dist/session-binding-service-BqY1J7gs.js +421 -0
  1266. package/dist/session-context-D4ioj_ZC.js +23 -0
  1267. package/dist/session-conversation-D3BLZCjg.js +15 -0
  1268. package/dist/session-conversation-SDN1QbLK.js +135 -0
  1269. package/dist/session-cost-usage-5D6Kkthv.js +650 -0
  1270. package/dist/session-cost-usage-CqniZ9Q3.js +2 -0
  1271. package/dist/session-envelope-DdZaP6iS.js +18 -0
  1272. package/dist/session-file-SVifvwcV.js +120 -0
  1273. package/dist/session-fork.runtime-Bhgl-_lq.js +50 -0
  1274. package/dist/session-key-BIrdMs11.js +279 -0
  1275. package/dist/session-key-CCQ4ZS9B.js +53 -0
  1276. package/dist/session-key-normalization-DGxkxG3U.js +22 -0
  1277. package/dist/session-meta-5PkRqQxG.js +9 -0
  1278. package/dist/session-override-CqiOQ4Om.js +100 -0
  1279. package/dist/session-reset-model.runtime-DFL5rk1J.js +119 -0
  1280. package/dist/session-subagent-reactivation.runtime-DIIFdc6I.js +2 -0
  1281. package/dist/session-system-events-BrXQQl_c.js +62 -0
  1282. package/dist/session-transcript-files.fs-BltD5xvW.js +124 -0
  1283. package/dist/session-updates-Dd6r5vhZ.js +177 -0
  1284. package/dist/session-updates.runtime-CTmXpESa.js +2 -0
  1285. package/dist/session-utils-CYh1zGmy.js +1735 -0
  1286. package/dist/session-write-lock-D_1twm3Q.js +343 -0
  1287. package/dist/sessions-BBObTITM.js +2 -0
  1288. package/dist/sessions-BLL-TKEv.js +224 -0
  1289. package/dist/sessions-zgiFsm1E.js +381 -0
  1290. package/dist/setup-BnAbcoEP.js +15 -0
  1291. package/dist/setup-CDUb3AWu.js +427 -0
  1292. package/dist/setup-adapter-runtime-kV6aLMzB.js +2 -0
  1293. package/dist/setup-binary-C35NJX1i.js +2 -0
  1294. package/dist/setup-core-C-0ynF1r.js +256 -0
  1295. package/dist/setup-group-access-BrKTGyeK.js +70 -0
  1296. package/dist/setup-helpers-CNcOI9ct.js +390 -0
  1297. package/dist/setup-runtime-CZF60tJ1.js +4 -0
  1298. package/dist/setup-surface-BcZenSzA.js +237 -0
  1299. package/dist/setup-surface-BwZZukYI.js +97 -0
  1300. package/dist/setup-tools-DB-J75x8.js +4 -0
  1301. package/dist/setup-wizard-helpers-u8iQ-OcY.js +841 -0
  1302. package/dist/setup-wizard-proxy-DiI-Brmi.js +127 -0
  1303. package/dist/setup.finalize-L3P2sSFi.js +443 -0
  1304. package/dist/setup.gateway-config-ISaEE7wH.js +246 -0
  1305. package/dist/setup.secret-input-DCxgkYJ3.js +25 -0
  1306. package/dist/shared-B0P4kmoP.js +50 -0
  1307. package/dist/shared-BOaKRLRY.js +64 -0
  1308. package/dist/shared-BXUt8yQc.js +160 -0
  1309. package/dist/shared-BZ338OsD.js +64 -0
  1310. package/dist/shared-BjU08Pt_.js +54 -0
  1311. package/dist/shared-BsFd7tT-.js +136 -0
  1312. package/dist/shared-CvC-RYap.js +37 -0
  1313. package/dist/shared-dXZZGNhj.js +10 -0
  1314. package/dist/shared-rGax8vC3.js +221 -0
  1315. package/dist/shell-argv-Z5ptFecq.js +72 -0
  1316. package/dist/shell-env-BSJycHpS.js +181 -0
  1317. package/dist/signal-BSV2xBJt.js +46 -0
  1318. package/dist/signal-BZDASWHO.js +13 -0
  1319. package/dist/signal-CId8sMA8.js +6 -0
  1320. package/dist/signal-account-DcEiRyli.js +11 -0
  1321. package/dist/signal-cli-install-CzSdr2VM.js +188 -0
  1322. package/dist/signal-surface-DrUgouip.js +21 -0
  1323. package/dist/simple-completion-transport-BNMmn163.js +24 -0
  1324. package/dist/skill-commands-CZ_x2Cqy.js +77 -0
  1325. package/dist/skill-commands-base-wY_Bsohb.js +60 -0
  1326. package/dist/skill-commands.runtime-BV7uDCJx.js +2 -0
  1327. package/dist/skill-scanner-B27VLIIq.js +354 -0
  1328. package/dist/skills-BTiQjfVL.js +1310 -0
  1329. package/dist/skills-CIF8vVlP.js +3 -0
  1330. package/dist/skills-clawhub-BDym_41x.js +274 -0
  1331. package/dist/skills-cli-C8m1I_bL.js +369 -0
  1332. package/dist/skills-install-B_gFFO8I.js +818 -0
  1333. package/dist/skills-remote-QuF4recE.js +550 -0
  1334. package/dist/skills-status-BEZWIOBR.js +2 -0
  1335. package/dist/skills-status-Dm_Jhtes.js +169 -0
  1336. package/dist/slack-Cs63YrE6.js +6 -0
  1337. package/dist/slack-account-5pXdcCaK.js +11 -0
  1338. package/dist/slack-liv3adei.js +9 -0
  1339. package/dist/slack-runtime-surface-B5JYrWWf.js +18 -0
  1340. package/dist/slack-surface-DpNHDOit.js +44 -0
  1341. package/dist/slack-target-parser-CErq1YCw.js +12 -0
  1342. package/dist/slack-targets-xF6pth_v.js +45 -0
  1343. package/dist/slots-PFLvT1Kq.js +93 -0
  1344. package/dist/speech-BY_tUO7g.js +46 -0
  1345. package/dist/speech-provider-S9O0XAp5.js +154 -0
  1346. package/dist/speech-runtime-oxmNRw3Z.js +34 -0
  1347. package/dist/ssh-config-BDfMcgtS.js +77 -0
  1348. package/dist/ssh-tunnel-DG9ZYGsa.js +159 -0
  1349. package/dist/ssh-tunnel-D_XZfkBV.js +2 -0
  1350. package/dist/ssrf-BRA26Q75.js +246 -0
  1351. package/dist/ssrf-policy-BIG3iChD.js +69 -0
  1352. package/dist/ssrf-runtime-BPxpSyiW.js +5 -0
  1353. package/dist/stage-sandbox-media.runtime-DOOiTZkt.js +229 -0
  1354. package/dist/state-migrations-cqOvSXP-.js +845 -0
  1355. package/dist/state-paths-CudqznX-.js +2 -0
  1356. package/dist/status-B5sZUURG.js +3 -0
  1357. package/dist/status-BXjWA90V.js +608 -0
  1358. package/dist/status-Biw1EIdt.js +2 -0
  1359. package/dist/status-CgHjqeMn.js +650 -0
  1360. package/dist/status-DQZ0kLxk.js +44 -0
  1361. package/dist/status-VHq1HAMM.js +240 -0
  1362. package/dist/status-all-DhEDLGP9.js +798 -0
  1363. package/dist/status-helpers-B7-UgIy8.js +170 -0
  1364. package/dist/status-issues-BFrNHsVn.js +335 -0
  1365. package/dist/status-issues-BUaLeYpi.js +187 -0
  1366. package/dist/status-json-DOnh1xDZ.js +86 -0
  1367. package/dist/status.agent-local-CaYKjhhX.js +59 -0
  1368. package/dist/status.command.text-runtime-DsOhXWI5.js +18 -0
  1369. package/dist/status.daemon-CriBgB61.js +25 -0
  1370. package/dist/status.format-c9WFxqY6.js +44 -0
  1371. package/dist/status.gateway-probe-FD9wNXhY.js +15 -0
  1372. package/dist/status.link-channel-DYBN8KV3.js +35 -0
  1373. package/dist/status.node-mode-FwHcEfkE.js +2 -0
  1374. package/dist/status.node-mode-dPc3mfqx.js +32 -0
  1375. package/dist/status.scan-DTGuZcAs.js +264 -0
  1376. package/dist/status.scan.deps.runtime-BlestHMC.js +18 -0
  1377. package/dist/status.scan.fast-json-Co7nNA_T.js +97 -0
  1378. package/dist/status.scan.fast-json-DRsEwD_h.js +2 -0
  1379. package/dist/status.scan.json-core-DaBuCMzr.js +254 -0
  1380. package/dist/status.scan.runtime-Dp_UkjfG.js +9 -0
  1381. package/dist/status.service-summary-BmHN_sIt.js +32 -0
  1382. package/dist/status.summary-C0Jn9d8y.js +2 -0
  1383. package/dist/status.summary-C3KHSLR1.js +210 -0
  1384. package/dist/status.update-DiRYpvwE.js +2 -0
  1385. package/dist/status.update-DjXE_PsH.js +79 -0
  1386. package/dist/sticker-cache-kEcJqycr.js +1516 -0
  1387. package/dist/sticker-vision.runtime-DdnhPS7k.js +16 -0
  1388. package/dist/store-DKzOIKqx.js +1342 -0
  1389. package/dist/store-DwAEHdgR.js +749 -0
  1390. package/dist/store-HBHyNMRe.js +10 -0
  1391. package/dist/store-NoUggnB3.js +365 -0
  1392. package/dist/store-read-BHYG1WxT.js +16 -0
  1393. package/dist/store.runtime-jT-JoPV1.js +2 -0
  1394. package/dist/string-normalization-k4ilMPRu.js +19 -0
  1395. package/dist/string-sample-BIWt11jp.js +11 -0
  1396. package/dist/strip-inbound-meta-DuOzaKMB.js +665 -0
  1397. package/dist/subagent-orphan-recovery-BaGPnDpY.js +206 -0
  1398. package/dist/subagent-registry-runtime-C0hklxy4.js +2 -0
  1399. package/dist/subcli-descriptors-Ccul9RKX.js +151 -0
  1400. package/dist/subsystem-CpBs2R1c.js +582 -0
  1401. package/dist/supervisor-log.runtime-BbxSpWqa.js +8 -0
  1402. package/dist/system-cli-rGgbAbhD.js +58 -0
  1403. package/dist/system-events-CkTr2pVV.js +93 -0
  1404. package/dist/system-message-BwHVKRn-.js +16 -0
  1405. package/dist/system-run-command-CeFzgmkE.js +295 -0
  1406. package/dist/systemd-aS57J-tg.js +588 -0
  1407. package/dist/systemd-hints-DexZGkZU.js +325 -0
  1408. package/dist/systemd-linger-Dum_Ly5E.js +68 -0
  1409. package/dist/systemd-linger-a109c27V.js +2 -0
  1410. package/dist/table-BNAxmbtm.js +305 -0
  1411. package/dist/tables-AGjErT3Z.js +832 -0
  1412. package/dist/tailnet-CtCjQNPK.js +76 -0
  1413. package/dist/tailscale-IqBQ_JBD.js +232 -0
  1414. package/dist/tailscale-status-SUYxe8DO.js +71 -0
  1415. package/dist/target-errors-Dd5ygAn4.js +26 -0
  1416. package/dist/target-parsing-DsTnx9-F.js +14 -0
  1417. package/dist/target-registry-Je8d-VjB.js +1280 -0
  1418. package/dist/targets-B5CwzJUC.js +748 -0
  1419. package/dist/targets-CsuOrZri.js +269 -0
  1420. package/dist/targets-CwnVSfRA.js +70 -0
  1421. package/dist/targets-DuUFEzKS.js +78 -0
  1422. package/dist/task-registry-delivery-runtime-DqP8eooO.js +2 -0
  1423. package/dist/task-registry.audit.shared-C4RGABy7.js +18 -0
  1424. package/dist/task-registry.maintenance-Bu37anXR.js +281 -0
  1425. package/dist/task-registry.maintenance-DOsnDSZk.js +2 -0
  1426. package/dist/task-registry.summary-DxVk_l3y.js +44 -0
  1427. package/dist/tavily-search-provider-CJqkM2Pl.js +226 -0
  1428. package/dist/telegram/audit.js +2 -0
  1429. package/dist/telegram/token.js +2 -0
  1430. package/dist/telegram-DYAW3Sfk.js +23 -0
  1431. package/dist/telegram-account-BJWXAeS3.js +11 -0
  1432. package/dist/telegram-core-BB-oqWi1.js +6 -0
  1433. package/dist/temp-download-vS-txIoM.js +62 -0
  1434. package/dist/temp-path-DfCfU6WG.js +2 -0
  1435. package/dist/templating-NXIs4v5N.js +24 -0
  1436. package/dist/terminal-link-TU0E45HO.js +10 -0
  1437. package/dist/testing-BnS6kfoS.js +575 -0
  1438. package/dist/text-chunking-90VX7tgk.js +12 -0
  1439. package/dist/text-chunking-BVps1926.js +20 -0
  1440. package/dist/text-format-B1S_nIVb.js +8 -0
  1441. package/dist/text-runtime-vMYWZmQD.js +398 -0
  1442. package/dist/theme-BJIQPogA.js +34 -0
  1443. package/dist/theme-SO8WovMK.js +2 -0
  1444. package/dist/thinking-uI0siSaD.js +68 -0
  1445. package/dist/thinking.shared-C4SN38qn.js +243 -0
  1446. package/dist/thread-bindings-policy-BcpXmcKL.js +172 -0
  1447. package/dist/thread-bindings-u1VyUaZn.js +778 -0
  1448. package/dist/thread-bindings.discord-api-Cq6oEKwK.js +486 -0
  1449. package/dist/threading-helpers-PW95yLIC.js +14 -0
  1450. package/dist/timeouts-CTDvzc8O.js +72 -0
  1451. package/dist/tmp-vora-dir-D2qk7W45.js +102 -0
  1452. package/dist/token-CHFyaNO5.js +45 -0
  1453. package/dist/token-D6h_ZVJn.js +82 -0
  1454. package/dist/tokens-shGOmvyA.js +66 -0
  1455. package/dist/tool-display-DqKeDkdg.js +1607 -0
  1456. package/dist/tool-images-Dk60Ug5h.js +270 -0
  1457. package/dist/tool-policy-CQHL2-I3.js +515 -0
  1458. package/dist/tool-policy-match-DL8JY2vg.js +48 -0
  1459. package/dist/tool-send-hJCuDJfS.js +16 -0
  1460. package/dist/tools-effective-inventory-CWzIubjU.js +148 -0
  1461. package/dist/tools-pE9BlK9y.js +119 -0
  1462. package/dist/transcript-events-DRsDmwmp.js +29 -0
  1463. package/dist/transport-ready-f6mdQOwn.js +36 -0
  1464. package/dist/tts-B1m3C2Az.js +102 -0
  1465. package/dist/tts-DUrUS0mZ.js +85 -0
  1466. package/dist/tts-auto-mode-C8_kw3FV.js +14 -0
  1467. package/dist/tts.runtime-BoqipRLV.js +2 -0
  1468. package/dist/tui-CQLplrBK.js +3898 -0
  1469. package/dist/tui-cli-DT0FyMjs.js +31 -0
  1470. package/dist/typebox-DR5b98DT.js +22 -0
  1471. package/dist/types-CGCTcpfm.js +465 -0
  1472. package/dist/types-DDSZHm1L.js +12 -0
  1473. package/dist/types-KyI2zD1Y.js +83 -0
  1474. package/dist/types.secrets-CxoujPzV.js +80 -0
  1475. package/dist/types.tools-DbA37tJ5.js +22 -0
  1476. package/dist/typing-Dz7FaNst.js +68 -0
  1477. package/dist/typing-mode-D3dtTRFq.js +75 -0
  1478. package/dist/typing-policy-DNdXa4aP.js +11 -0
  1479. package/dist/typing-start-guard-Bd69zP69.js +73 -0
  1480. package/dist/ui-DBzDVf5Z.js +182 -0
  1481. package/dist/undici-global-dispatcher-jevw8Gzz.js +99 -0
  1482. package/dist/unhandled-rejections-D0HD8aaS.js +2 -0
  1483. package/dist/unhandled-rejections-yZafPL2A.js +241 -0
  1484. package/dist/update-Bof-SJAQ.js +1253 -0
  1485. package/dist/update-channels-d8te77R1.js +78 -0
  1486. package/dist/update-check-DK2tfDQH.js +354 -0
  1487. package/dist/update-cli-Ck2vsRAq.js +1446 -0
  1488. package/dist/update-offset-store-DzcRNELt.js +75 -0
  1489. package/dist/utils-BiWzD1kh.js +230 -0
  1490. package/dist/utils-QayXenI0.js +3 -0
  1491. package/dist/version-B8PcQo5n.js +79 -0
  1492. package/dist/version-DBzWIScg.js +2 -0
  1493. package/dist/vora-embedded-block-chunker-3yyZObTq.js +258 -0
  1494. package/dist/vora-embedded-helpers-CcpQ4UhE.js +1451 -0
  1495. package/dist/vora-embedded-runner-CtRc9sK4.js +35200 -0
  1496. package/dist/vora-embedded.runtime-DnQSqL4C.js +3 -0
  1497. package/dist/vora-exec-env-D4Xwhvu2.js +14 -0
  1498. package/dist/vora-root-LrpnxvkN.js +88 -0
  1499. package/dist/vora-tools.before-tool-call.runtime-DMDQZj3b.js +354 -0
  1500. package/dist/vora-tools.runtime-CRE3qINm.js +2 -0
  1501. package/dist/wait-DINWFDZY.js +7 -0
  1502. package/dist/warning-filter-SAevhKdH.js +57 -0
  1503. package/dist/web-media-xqpNAEze.js +630 -0
  1504. package/dist/web-search-providers-Dzq6HxbB.js +21 -0
  1505. package/dist/web-search-providers.runtime-CtA0c8j7.js +110 -0
  1506. package/dist/web-search-providers.shared-BDbtn1DP.js +404 -0
  1507. package/dist/webhook-ingress-VjrwfCEq.js +164 -0
  1508. package/dist/webhook-memory-guards-B-_GNMqp.js +129 -0
  1509. package/dist/webhook-path-KmDDjLxH.js +22 -0
  1510. package/dist/webhook-request-guards-RvZR0xOr.js +178 -0
  1511. package/dist/webhooks-cli-DW2licxV.js +325 -0
  1512. package/dist/whatsapp-BdBhDmjG.js +4 -0
  1513. package/dist/whatsapp-DrWLgII5.js +33 -0
  1514. package/dist/whatsapp-heartbeat-B9ic2dUo.js +114 -0
  1515. package/dist/whatsapp-shared-CCB6ISPU.js +56 -0
  1516. package/dist/whatsapp-surface-Dj75n55B.js +26 -0
  1517. package/dist/whatsapp-targets-DC3kH_Ao.js +13 -0
  1518. package/dist/widearea-dns-CQmUW5IF.js +125 -0
  1519. package/dist/windows-argv-Dp3PZAV0.js +345 -0
  1520. package/dist/windows-install-roots-XI3CvO9O.js +149 -0
  1521. package/dist/windows-spawn-Bo5J7nQU.js +154 -0
  1522. package/dist/with-timeout-82_4MKPJ.js +13 -0
  1523. package/dist/with-timeout-C9cQCRMB.js +215 -0
  1524. package/dist/workspace-Byy6tyA9.js +479 -0
  1525. package/dist/workspace-dirs-DD2rvoad.js +13 -0
  1526. package/dist/workspace-rZgvKsfA.js +306 -0
  1527. package/dist/ws-H_UxQmDV.js +11 -0
  1528. package/dist/ws-log-Colefm0_.js +289 -0
  1529. package/dist/wsl-Cja5t6Cg.js +57 -0
  1530. package/dist/xai-G_qBZ2Uy.js +27 -0
  1531. package/dist/zalo-setup-DhLwoxOU.js +14 -0
  1532. package/dist/zod-parse-CoS4Cf-k.js +14 -0
  1533. package/dist/zod-schema.agent-runtime-DvpP4fxf.js +602 -0
  1534. package/dist/zod-schema.channels-BAf89d5l.js +10 -0
  1535. package/dist/zod-schema.core-BTG8QVOn.js +514 -0
  1536. package/dist/zod-schema.providers-core-CBsF2dSN.js +1569 -0
  1537. package/dist/zod-schema.providers-whatsapp-BORKPdar.js +125 -0
  1538. package/dist/zod-schema.sensitive-bgI4eB_k.js +5 -0
  1539. package/docs/.i18n/README.md +31 -0
  1540. package/docs/.i18n/glossary.ja-JP.json +14 -0
  1541. package/docs/.i18n/glossary.zh-CN.json +306 -0
  1542. package/docs/.i18n/ja-JP.tm.jsonl +0 -0
  1543. package/docs/assets/install-script.svg +1 -0
  1544. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  1545. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  1546. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  1547. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  1548. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  1549. package/docs/assets/pixel-lobster.svg +60 -0
  1550. package/docs/assets/showcase/agents-ui.jpg +0 -0
  1551. package/docs/assets/showcase/bambu-cli.png +0 -0
  1552. package/docs/assets/showcase/codexmonitor.png +0 -0
  1553. package/docs/assets/showcase/gohome-grafana.png +0 -0
  1554. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  1555. package/docs/assets/showcase/oura-health.png +0 -0
  1556. package/docs/assets/showcase/padel-cli.svg +11 -0
  1557. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  1558. package/docs/assets/showcase/papla-tts.jpg +0 -0
  1559. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  1560. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  1561. package/docs/assets/showcase/roborock-status.svg +13 -0
  1562. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  1563. package/docs/assets/showcase/snag.png +0 -0
  1564. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  1565. package/docs/assets/showcase/wienerlinien.png +0 -0
  1566. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  1567. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  1568. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  1569. package/docs/assets/sponsors/blacksmith-light.svg +14 -0
  1570. package/docs/assets/sponsors/blacksmith.svg +14 -0
  1571. package/docs/assets/sponsors/convex-light.svg +16 -0
  1572. package/docs/assets/sponsors/convex.svg +16 -0
  1573. package/docs/assets/sponsors/nvidia-dark.svg +9 -0
  1574. package/docs/assets/sponsors/nvidia.svg +9 -0
  1575. package/docs/assets/sponsors/openai-light.svg +3 -0
  1576. package/docs/assets/sponsors/openai.svg +3 -0
  1577. package/docs/assets/sponsors/vercel-light.svg +5 -0
  1578. package/docs/assets/sponsors/vercel.svg +5 -0
  1579. package/docs/assets/vora-logo-text-dark.png +0 -0
  1580. package/docs/assets/vora-logo-text-dark.svg +418 -0
  1581. package/docs/assets/vora-logo-text.png +0 -0
  1582. package/docs/assets/vora-logo-text.svg +418 -0
  1583. package/docs/auth-credential-semantics.md +60 -0
  1584. package/docs/automation/auth-monitoring.md +44 -0
  1585. package/docs/automation/clawflow.md +109 -0
  1586. package/docs/automation/cron-jobs.md +744 -0
  1587. package/docs/automation/cron-vs-heartbeat.md +299 -0
  1588. package/docs/automation/gmail-pubsub.md +256 -0
  1589. package/docs/automation/hooks.md +1375 -0
  1590. package/docs/automation/index.md +69 -0
  1591. package/docs/automation/poll.md +86 -0
  1592. package/docs/automation/standing-orders.md +254 -0
  1593. package/docs/automation/tasks.md +247 -0
  1594. package/docs/automation/troubleshooting.md +122 -0
  1595. package/docs/automation/webhook.md +217 -0
  1596. package/docs/brave-search.md +93 -0
  1597. package/docs/channels/bluebubbles.md +430 -0
  1598. package/docs/channels/broadcast-groups.md +442 -0
  1599. package/docs/channels/channel-routing.md +139 -0
  1600. package/docs/channels/discord.md +1240 -0
  1601. package/docs/channels/feishu.md +760 -0
  1602. package/docs/channels/googlechat.md +270 -0
  1603. package/docs/channels/group-messages.md +84 -0
  1604. package/docs/channels/groups.md +385 -0
  1605. package/docs/channels/imessage.md +427 -0
  1606. package/docs/channels/index.md +50 -0
  1607. package/docs/channels/irc.md +250 -0
  1608. package/docs/channels/line.md +221 -0
  1609. package/docs/channels/location.md +56 -0
  1610. package/docs/channels/matrix.md +779 -0
  1611. package/docs/channels/mattermost.md +435 -0
  1612. package/docs/channels/msteams.md +802 -0
  1613. package/docs/channels/nextcloud-talk.md +146 -0
  1614. package/docs/channels/nostr.md +257 -0
  1615. package/docs/channels/pairing.md +114 -0
  1616. package/docs/channels/qqbot.md +193 -0
  1617. package/docs/channels/signal.md +337 -0
  1618. package/docs/channels/slack.md +607 -0
  1619. package/docs/channels/synology-chat.md +150 -0
  1620. package/docs/channels/telegram.md +991 -0
  1621. package/docs/channels/tlon.md +284 -0
  1622. package/docs/channels/troubleshooting.md +118 -0
  1623. package/docs/channels/twitch.md +387 -0
  1624. package/docs/channels/whatsapp.md +462 -0
  1625. package/docs/channels/zalo.md +251 -0
  1626. package/docs/channels/zalouser.md +189 -0
  1627. package/docs/ci.md +57 -0
  1628. package/docs/cli/acp.md +297 -0
  1629. package/docs/cli/agent.md +29 -0
  1630. package/docs/cli/agents.md +123 -0
  1631. package/docs/cli/approvals.md +50 -0
  1632. package/docs/cli/backup.md +76 -0
  1633. package/docs/cli/browser.md +127 -0
  1634. package/docs/cli/channels.md +102 -0
  1635. package/docs/cli/clawbot.md +21 -0
  1636. package/docs/cli/completion.md +35 -0
  1637. package/docs/cli/config.md +317 -0
  1638. package/docs/cli/configure.md +42 -0
  1639. package/docs/cli/cron.md +80 -0
  1640. package/docs/cli/daemon.md +55 -0
  1641. package/docs/cli/dashboard.md +22 -0
  1642. package/docs/cli/devices.md +139 -0
  1643. package/docs/cli/directory.md +63 -0
  1644. package/docs/cli/dns.md +23 -0
  1645. package/docs/cli/docs.md +15 -0
  1646. package/docs/cli/doctor.md +48 -0
  1647. package/docs/cli/flows.md +54 -0
  1648. package/docs/cli/gateway.md +238 -0
  1649. package/docs/cli/health.md +21 -0
  1650. package/docs/cli/hooks.md +330 -0
  1651. package/docs/cli/index.md +1239 -0
  1652. package/docs/cli/logs.md +28 -0
  1653. package/docs/cli/mcp.md +467 -0
  1654. package/docs/cli/memory.md +66 -0
  1655. package/docs/cli/message.md +280 -0
  1656. package/docs/cli/models.md +90 -0
  1657. package/docs/cli/node.md +132 -0
  1658. package/docs/cli/nodes.md +55 -0
  1659. package/docs/cli/onboard.md +160 -0
  1660. package/docs/cli/pairing.md +32 -0
  1661. package/docs/cli/plugins.md +229 -0
  1662. package/docs/cli/qr.md +46 -0
  1663. package/docs/cli/reset.md +20 -0
  1664. package/docs/cli/sandbox.md +197 -0
  1665. package/docs/cli/secrets.md +188 -0
  1666. package/docs/cli/security.md +79 -0
  1667. package/docs/cli/sessions.md +110 -0
  1668. package/docs/cli/setup.md +29 -0
  1669. package/docs/cli/skills.md +40 -0
  1670. package/docs/cli/status.md +30 -0
  1671. package/docs/cli/system.md +60 -0
  1672. package/docs/cli/tui.md +30 -0
  1673. package/docs/cli/uninstall.md +20 -0
  1674. package/docs/cli/update.md +103 -0
  1675. package/docs/cli/voicecall.md +34 -0
  1676. package/docs/cli/webhooks.md +25 -0
  1677. package/docs/concepts/agent-loop.md +166 -0
  1678. package/docs/concepts/agent-workspace.md +243 -0
  1679. package/docs/concepts/agent.md +122 -0
  1680. package/docs/concepts/architecture.md +144 -0
  1681. package/docs/concepts/compaction.md +93 -0
  1682. package/docs/concepts/context-engine.md +274 -0
  1683. package/docs/concepts/context.md +179 -0
  1684. package/docs/concepts/delegate-architecture.md +296 -0
  1685. package/docs/concepts/features.md +73 -0
  1686. package/docs/concepts/markdown-formatting.md +130 -0
  1687. package/docs/concepts/memory-builtin.md +105 -0
  1688. package/docs/concepts/memory-honcho.md +140 -0
  1689. package/docs/concepts/memory-qmd.md +163 -0
  1690. package/docs/concepts/memory-search.md +141 -0
  1691. package/docs/concepts/memory.md +102 -0
  1692. package/docs/concepts/messages.md +161 -0
  1693. package/docs/concepts/model-failover.md +160 -0
  1694. package/docs/concepts/model-providers.md +599 -0
  1695. package/docs/concepts/models.md +232 -0
  1696. package/docs/concepts/multi-agent.md +602 -0
  1697. package/docs/concepts/oauth.md +193 -0
  1698. package/docs/concepts/presence.md +102 -0
  1699. package/docs/concepts/queue.md +89 -0
  1700. package/docs/concepts/retry.md +69 -0
  1701. package/docs/concepts/session-pruning.md +80 -0
  1702. package/docs/concepts/session-tool.md +84 -0
  1703. package/docs/concepts/session.md +116 -0
  1704. package/docs/concepts/streaming.md +161 -0
  1705. package/docs/concepts/system-prompt.md +132 -0
  1706. package/docs/concepts/timezone.md +97 -0
  1707. package/docs/concepts/typebox.md +291 -0
  1708. package/docs/concepts/typing-indicators.md +68 -0
  1709. package/docs/concepts/usage-tracking.md +35 -0
  1710. package/docs/date-time.md +128 -0
  1711. package/docs/debug/node-issue.md +85 -0
  1712. package/docs/diagnostics/flags.md +91 -0
  1713. package/docs/docs.json +2143 -0
  1714. package/docs/gateway/authentication.md +204 -0
  1715. package/docs/gateway/background-process.md +97 -0
  1716. package/docs/gateway/bonjour.md +177 -0
  1717. package/docs/gateway/bridge-protocol.md +86 -0
  1718. package/docs/gateway/cli-backends.md +249 -0
  1719. package/docs/gateway/configuration-examples.md +652 -0
  1720. package/docs/gateway/configuration-reference.md +3384 -0
  1721. package/docs/gateway/configuration.md +633 -0
  1722. package/docs/gateway/discovery.md +127 -0
  1723. package/docs/gateway/doctor.md +463 -0
  1724. package/docs/gateway/gateway-lock.md +37 -0
  1725. package/docs/gateway/health.md +53 -0
  1726. package/docs/gateway/heartbeat.md +407 -0
  1727. package/docs/gateway/index.md +286 -0
  1728. package/docs/gateway/local-models.md +153 -0
  1729. package/docs/gateway/logging.md +113 -0
  1730. package/docs/gateway/multiple-gateways.md +112 -0
  1731. package/docs/gateway/network-model.md +24 -0
  1732. package/docs/gateway/openai-http-api.md +266 -0
  1733. package/docs/gateway/openresponses-http-api.md +322 -0
  1734. package/docs/gateway/openshell.md +307 -0
  1735. package/docs/gateway/pairing.md +99 -0
  1736. package/docs/gateway/protocol.md +280 -0
  1737. package/docs/gateway/remote-gateway-readme.md +160 -0
  1738. package/docs/gateway/remote.md +248 -0
  1739. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +134 -0
  1740. package/docs/gateway/sandboxing.md +469 -0
  1741. package/docs/gateway/secrets-plan-contract.md +116 -0
  1742. package/docs/gateway/secrets.md +541 -0
  1743. package/docs/gateway/security/index.md +1216 -0
  1744. package/docs/gateway/tailscale.md +132 -0
  1745. package/docs/gateway/tools-invoke-http-api.md +147 -0
  1746. package/docs/gateway/troubleshooting.md +382 -0
  1747. package/docs/gateway/trusted-proxy-auth.md +342 -0
  1748. package/docs/help/debugging.md +168 -0
  1749. package/docs/help/environment.md +163 -0
  1750. package/docs/help/faq.md +3002 -0
  1751. package/docs/help/index.md +28 -0
  1752. package/docs/help/scripts.md +28 -0
  1753. package/docs/help/testing.md +664 -0
  1754. package/docs/help/troubleshooting.md +352 -0
  1755. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  1756. package/docs/images/feishu-step2-create-app.png +0 -0
  1757. package/docs/images/feishu-step3-credentials.png +0 -0
  1758. package/docs/images/feishu-step4-permissions.png +0 -0
  1759. package/docs/images/feishu-step5-bot-capability.png +0 -0
  1760. package/docs/images/feishu-step6-event-subscription.png +0 -0
  1761. package/docs/images/feishu-verification-token.png +0 -0
  1762. package/docs/images/groups-flow.svg +52 -0
  1763. package/docs/images/mobile-ui-screenshot.png +0 -0
  1764. package/docs/index.md +196 -0
  1765. package/docs/install/ansible.md +230 -0
  1766. package/docs/install/azure.md +311 -0
  1767. package/docs/install/bun.md +55 -0
  1768. package/docs/install/clawdock.md +105 -0
  1769. package/docs/install/development-channels.md +120 -0
  1770. package/docs/install/digitalocean.md +129 -0
  1771. package/docs/install/docker-vm-runtime.md +142 -0
  1772. package/docs/install/docker.md +404 -0
  1773. package/docs/install/exe-dev.md +126 -0
  1774. package/docs/install/fly.md +501 -0
  1775. package/docs/install/gcp.md +402 -0
  1776. package/docs/install/hetzner.md +251 -0
  1777. package/docs/install/index.md +183 -0
  1778. package/docs/install/installer.md +421 -0
  1779. package/docs/install/kubernetes.md +191 -0
  1780. package/docs/install/macos-vm.md +281 -0
  1781. package/docs/install/migrating-matrix.md +346 -0
  1782. package/docs/install/migrating.md +110 -0
  1783. package/docs/install/nix.md +89 -0
  1784. package/docs/install/node.md +144 -0
  1785. package/docs/install/northflank.mdx +40 -0
  1786. package/docs/install/oracle.md +156 -0
  1787. package/docs/install/podman.md +269 -0
  1788. package/docs/install/railway.mdx +87 -0
  1789. package/docs/install/raspberry-pi.md +159 -0
  1790. package/docs/install/render.mdx +159 -0
  1791. package/docs/install/uninstall.md +128 -0
  1792. package/docs/install/updating.md +134 -0
  1793. package/docs/ja-JP/index.md +186 -0
  1794. package/docs/ja-JP/start/getting-started.md +125 -0
  1795. package/docs/ja-JP/start/wizard.md +77 -0
  1796. package/docs/logging.md +357 -0
  1797. package/docs/nav-tabs-underline.js +100 -0
  1798. package/docs/network.md +63 -0
  1799. package/docs/nodes/audio.md +187 -0
  1800. package/docs/nodes/camera.md +162 -0
  1801. package/docs/nodes/images.md +72 -0
  1802. package/docs/nodes/index.md +395 -0
  1803. package/docs/nodes/location-command.md +98 -0
  1804. package/docs/nodes/media-understanding.md +394 -0
  1805. package/docs/nodes/talk.md +92 -0
  1806. package/docs/nodes/troubleshooting.md +114 -0
  1807. package/docs/nodes/voicewake.md +66 -0
  1808. package/docs/perplexity.md +174 -0
  1809. package/docs/pi-dev.md +80 -0
  1810. package/docs/pi.md +567 -0
  1811. package/docs/platforms/android.md +168 -0
  1812. package/docs/platforms/digitalocean.md +266 -0
  1813. package/docs/platforms/index.md +54 -0
  1814. package/docs/platforms/ios.md +220 -0
  1815. package/docs/platforms/linux.md +94 -0
  1816. package/docs/platforms/mac/bundled-gateway.md +73 -0
  1817. package/docs/platforms/mac/canvas.md +125 -0
  1818. package/docs/platforms/mac/child-process.md +69 -0
  1819. package/docs/platforms/mac/dev-setup.md +104 -0
  1820. package/docs/platforms/mac/health.md +34 -0
  1821. package/docs/platforms/mac/icon.md +31 -0
  1822. package/docs/platforms/mac/logging.md +57 -0
  1823. package/docs/platforms/mac/menu-bar.md +81 -0
  1824. package/docs/platforms/mac/peekaboo.md +65 -0
  1825. package/docs/platforms/mac/permissions.md +50 -0
  1826. package/docs/platforms/mac/remote.md +84 -0
  1827. package/docs/platforms/mac/signing.md +47 -0
  1828. package/docs/platforms/mac/skills.md +34 -0
  1829. package/docs/platforms/mac/voice-overlay.md +60 -0
  1830. package/docs/platforms/mac/voicewake.md +67 -0
  1831. package/docs/platforms/mac/webchat.md +43 -0
  1832. package/docs/platforms/mac/xpc.md +61 -0
  1833. package/docs/platforms/macos.md +228 -0
  1834. package/docs/platforms/oracle.md +303 -0
  1835. package/docs/platforms/raspberry-pi.md +412 -0
  1836. package/docs/platforms/windows.md +241 -0
  1837. package/docs/plugins/agent-tools.md +10 -0
  1838. package/docs/plugins/architecture.md +1400 -0
  1839. package/docs/plugins/building-extensions.md +10 -0
  1840. package/docs/plugins/building-plugins.md +283 -0
  1841. package/docs/plugins/bundles.md +278 -0
  1842. package/docs/plugins/community.md +145 -0
  1843. package/docs/plugins/manifest.md +284 -0
  1844. package/docs/plugins/sdk-channel-plugins.md +419 -0
  1845. package/docs/plugins/sdk-entrypoints.md +184 -0
  1846. package/docs/plugins/sdk-migration.md +180 -0
  1847. package/docs/plugins/sdk-overview.md +287 -0
  1848. package/docs/plugins/sdk-provider-plugins.md +440 -0
  1849. package/docs/plugins/sdk-runtime.md +347 -0
  1850. package/docs/plugins/sdk-setup.md +365 -0
  1851. package/docs/plugins/sdk-testing.md +263 -0
  1852. package/docs/plugins/voice-call.md +397 -0
  1853. package/docs/plugins/zalouser.md +78 -0
  1854. package/docs/prose.md +134 -0
  1855. package/docs/providers/anthropic.md +375 -0
  1856. package/docs/providers/bedrock.md +217 -0
  1857. package/docs/providers/claude-max-api-proxy.md +154 -0
  1858. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  1859. package/docs/providers/deepgram.md +93 -0
  1860. package/docs/providers/deepseek.md +53 -0
  1861. package/docs/providers/github-copilot.md +72 -0
  1862. package/docs/providers/glm.md +43 -0
  1863. package/docs/providers/google.md +78 -0
  1864. package/docs/providers/groq.md +96 -0
  1865. package/docs/providers/huggingface.md +209 -0
  1866. package/docs/providers/index.md +72 -0
  1867. package/docs/providers/kilocode.md +74 -0
  1868. package/docs/providers/litellm.md +154 -0
  1869. package/docs/providers/minimax.md +183 -0
  1870. package/docs/providers/mistral.md +54 -0
  1871. package/docs/providers/models.md +45 -0
  1872. package/docs/providers/moonshot.md +175 -0
  1873. package/docs/providers/nvidia.md +55 -0
  1874. package/docs/providers/ollama.md +352 -0
  1875. package/docs/providers/openai.md +319 -0
  1876. package/docs/providers/opencode-go.md +45 -0
  1877. package/docs/providers/opencode.md +64 -0
  1878. package/docs/providers/openrouter.md +37 -0
  1879. package/docs/providers/perplexity-provider.md +62 -0
  1880. package/docs/providers/qianfan.md +38 -0
  1881. package/docs/providers/qwen.md +33 -0
  1882. package/docs/providers/qwen_modelstudio.md +85 -0
  1883. package/docs/providers/sglang.md +104 -0
  1884. package/docs/providers/synthetic.md +99 -0
  1885. package/docs/providers/together.md +66 -0
  1886. package/docs/providers/venice.md +282 -0
  1887. package/docs/providers/vercel-ai-gateway.md +60 -0
  1888. package/docs/providers/vllm.md +92 -0
  1889. package/docs/providers/volcengine.md +74 -0
  1890. package/docs/providers/xai.md +69 -0
  1891. package/docs/providers/xiaomi.md +86 -0
  1892. package/docs/providers/zai.md +46 -0
  1893. package/docs/reference/AGENTS.default.md +126 -0
  1894. package/docs/reference/RELEASING.md +80 -0
  1895. package/docs/reference/api-usage-costs.md +144 -0
  1896. package/docs/reference/credits.md +30 -0
  1897. package/docs/reference/device-models.md +47 -0
  1898. package/docs/reference/memory-config.md +370 -0
  1899. package/docs/reference/prompt-caching.md +195 -0
  1900. package/docs/reference/rpc.md +43 -0
  1901. package/docs/reference/secretref-credential-surface.md +137 -0
  1902. package/docs/reference/secretref-user-supplied-credentials-matrix.json +535 -0
  1903. package/docs/reference/session-management-compaction.md +326 -0
  1904. package/docs/reference/templates/AGENTS.dev.md +84 -0
  1905. package/docs/reference/templates/AGENTS.md +219 -0
  1906. package/docs/reference/templates/BOOT.md +11 -0
  1907. package/docs/reference/templates/BOOTSTRAP.md +62 -0
  1908. package/docs/reference/templates/HEARTBEAT.md +14 -0
  1909. package/docs/reference/templates/IDENTITY.dev.md +48 -0
  1910. package/docs/reference/templates/IDENTITY.md +30 -0
  1911. package/docs/reference/templates/SOUL.dev.md +77 -0
  1912. package/docs/reference/templates/SOUL.md +43 -0
  1913. package/docs/reference/templates/TOOLS.dev.md +25 -0
  1914. package/docs/reference/templates/TOOLS.md +47 -0
  1915. package/docs/reference/templates/USER.dev.md +19 -0
  1916. package/docs/reference/templates/USER.md +24 -0
  1917. package/docs/reference/test.md +120 -0
  1918. package/docs/reference/token-use.md +175 -0
  1919. package/docs/reference/transcript-hygiene.md +151 -0
  1920. package/docs/reference/wizard.md +235 -0
  1921. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
  1922. package/docs/security/THREAT-MODEL-ATLAS.md +608 -0
  1923. package/docs/security/formal-verification.md +167 -0
  1924. package/docs/snippets/plugin-publish/minimal-package.json +16 -0
  1925. package/docs/snippets/plugin-publish/minimal-vora.plugin.json +9 -0
  1926. package/docs/start/bootstrapping.md +41 -0
  1927. package/docs/start/docs-directory.md +66 -0
  1928. package/docs/start/getting-started.md +116 -0
  1929. package/docs/start/hubs.md +198 -0
  1930. package/docs/start/lore.md +219 -0
  1931. package/docs/start/onboarding-overview.md +67 -0
  1932. package/docs/start/onboarding.md +91 -0
  1933. package/docs/start/quickstart.md +22 -0
  1934. package/docs/start/setup.md +164 -0
  1935. package/docs/start/showcase.md +418 -0
  1936. package/docs/start/vora.md +224 -0
  1937. package/docs/start/wizard-cli-automation.md +215 -0
  1938. package/docs/start/wizard-cli-reference.md +302 -0
  1939. package/docs/start/wizard.md +125 -0
  1940. package/docs/style.css +37 -0
  1941. package/docs/tools/acp-agents.md +772 -0
  1942. package/docs/tools/agent-send.md +100 -0
  1943. package/docs/tools/apply-patch.md +52 -0
  1944. package/docs/tools/brave-search.md +97 -0
  1945. package/docs/tools/browser-linux-troubleshooting.md +138 -0
  1946. package/docs/tools/browser-login.md +73 -0
  1947. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +211 -0
  1948. package/docs/tools/browser.md +824 -0
  1949. package/docs/tools/btw.md +142 -0
  1950. package/docs/tools/capability-cookbook.md +119 -0
  1951. package/docs/tools/clawhub.md +336 -0
  1952. package/docs/tools/code-execution.md +90 -0
  1953. package/docs/tools/creating-skills.md +117 -0
  1954. package/docs/tools/diffs.md +388 -0
  1955. package/docs/tools/duckduckgo-search.md +101 -0
  1956. package/docs/tools/elevated.md +114 -0
  1957. package/docs/tools/exa-search.md +127 -0
  1958. package/docs/tools/exec-approvals.md +502 -0
  1959. package/docs/tools/exec.md +217 -0
  1960. package/docs/tools/firecrawl.md +144 -0
  1961. package/docs/tools/gemini-search.md +93 -0
  1962. package/docs/tools/grok-search.md +98 -0
  1963. package/docs/tools/image-generation.md +125 -0
  1964. package/docs/tools/index.md +140 -0
  1965. package/docs/tools/kimi-search.md +73 -0
  1966. package/docs/tools/llm-task.md +119 -0
  1967. package/docs/tools/lobster.md +348 -0
  1968. package/docs/tools/loop-detection.md +100 -0
  1969. package/docs/tools/multi-agent-sandbox-tools.md +364 -0
  1970. package/docs/tools/pdf.md +161 -0
  1971. package/docs/tools/perplexity-search.md +178 -0
  1972. package/docs/tools/plugin.md +291 -0
  1973. package/docs/tools/reactions.md +64 -0
  1974. package/docs/tools/skills-config.md +95 -0
  1975. package/docs/tools/skills.md +331 -0
  1976. package/docs/tools/slash-commands.md +315 -0
  1977. package/docs/tools/subagents.md +296 -0
  1978. package/docs/tools/tavily.md +129 -0
  1979. package/docs/tools/thinking.md +96 -0
  1980. package/docs/tools/tts.md +416 -0
  1981. package/docs/tools/web-fetch.md +135 -0
  1982. package/docs/tools/web.md +362 -0
  1983. package/docs/tts.md +416 -0
  1984. package/docs/vps.md +112 -0
  1985. package/docs/web/control-ui.md +285 -0
  1986. package/docs/web/dashboard.md +56 -0
  1987. package/docs/web/index.md +120 -0
  1988. package/docs/web/tui.md +175 -0
  1989. package/docs/web/webchat.md +65 -0
  1990. package/docs/whatsapp-vora-ai-zh.jpg +0 -0
  1991. package/docs/whatsapp-vora.jpg +0 -0
  1992. package/docs/zh-CN/AGENTS.md +61 -0
  1993. package/docs/zh-CN/automation/auth-monitoring.md +47 -0
  1994. package/docs/zh-CN/automation/cron-jobs.md +435 -0
  1995. package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
  1996. package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
  1997. package/docs/zh-CN/automation/hooks.md +1051 -0
  1998. package/docs/zh-CN/automation/poll.md +76 -0
  1999. package/docs/zh-CN/automation/troubleshooting.md +8 -0
  2000. package/docs/zh-CN/automation/webhook.md +163 -0
  2001. package/docs/zh-CN/brave-search.md +60 -0
  2002. package/docs/zh-CN/channels/bluebubbles.md +354 -0
  2003. package/docs/zh-CN/channels/broadcast-groups.md +449 -0
  2004. package/docs/zh-CN/channels/channel-routing.md +117 -0
  2005. package/docs/zh-CN/channels/discord.md +468 -0
  2006. package/docs/zh-CN/channels/feishu.md +728 -0
  2007. package/docs/zh-CN/channels/googlechat.md +257 -0
  2008. package/docs/zh-CN/channels/grammy.md +38 -0
  2009. package/docs/zh-CN/channels/group-messages.md +91 -0
  2010. package/docs/zh-CN/channels/groups.md +379 -0
  2011. package/docs/zh-CN/channels/imessage.md +302 -0
  2012. package/docs/zh-CN/channels/index.md +53 -0
  2013. package/docs/zh-CN/channels/line.md +180 -0
  2014. package/docs/zh-CN/channels/location.md +63 -0
  2015. package/docs/zh-CN/channels/matrix.md +221 -0
  2016. package/docs/zh-CN/channels/mattermost.md +144 -0
  2017. package/docs/zh-CN/channels/msteams.md +775 -0
  2018. package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
  2019. package/docs/zh-CN/channels/nostr.md +249 -0
  2020. package/docs/zh-CN/channels/pairing.md +89 -0
  2021. package/docs/zh-CN/channels/signal.md +209 -0
  2022. package/docs/zh-CN/channels/slack.md +531 -0
  2023. package/docs/zh-CN/channels/synology-chat.md +138 -0
  2024. package/docs/zh-CN/channels/telegram.md +751 -0
  2025. package/docs/zh-CN/channels/tlon.md +136 -0
  2026. package/docs/zh-CN/channels/troubleshooting.md +36 -0
  2027. package/docs/zh-CN/channels/twitch.md +385 -0
  2028. package/docs/zh-CN/channels/whatsapp.md +411 -0
  2029. package/docs/zh-CN/channels/zalo.md +196 -0
  2030. package/docs/zh-CN/channels/zalouser.md +147 -0
  2031. package/docs/zh-CN/cli/acp.md +173 -0
  2032. package/docs/zh-CN/cli/agent.md +30 -0
  2033. package/docs/zh-CN/cli/agents.md +82 -0
  2034. package/docs/zh-CN/cli/approvals.md +57 -0
  2035. package/docs/zh-CN/cli/browser.md +114 -0
  2036. package/docs/zh-CN/cli/channels.md +86 -0
  2037. package/docs/zh-CN/cli/config.md +57 -0
  2038. package/docs/zh-CN/cli/configure.md +38 -0
  2039. package/docs/zh-CN/cli/cron.md +43 -0
  2040. package/docs/zh-CN/cli/dashboard.md +23 -0
  2041. package/docs/zh-CN/cli/devices.md +74 -0
  2042. package/docs/zh-CN/cli/directory.md +70 -0
  2043. package/docs/zh-CN/cli/dns.md +30 -0
  2044. package/docs/zh-CN/cli/docs.md +22 -0
  2045. package/docs/zh-CN/cli/doctor.md +48 -0
  2046. package/docs/zh-CN/cli/gateway.md +206 -0
  2047. package/docs/zh-CN/cli/health.md +28 -0
  2048. package/docs/zh-CN/cli/hooks.md +298 -0
  2049. package/docs/zh-CN/cli/index.md +1142 -0
  2050. package/docs/zh-CN/cli/logs.md +31 -0
  2051. package/docs/zh-CN/cli/memory.md +52 -0
  2052. package/docs/zh-CN/cli/message.md +246 -0
  2053. package/docs/zh-CN/cli/models.md +85 -0
  2054. package/docs/zh-CN/cli/node.md +115 -0
  2055. package/docs/zh-CN/cli/nodes.md +62 -0
  2056. package/docs/zh-CN/cli/onboard.md +164 -0
  2057. package/docs/zh-CN/cli/pairing.md +28 -0
  2058. package/docs/zh-CN/cli/plugins.md +66 -0
  2059. package/docs/zh-CN/cli/reset.md +24 -0
  2060. package/docs/zh-CN/cli/sandbox.md +158 -0
  2061. package/docs/zh-CN/cli/security.md +33 -0
  2062. package/docs/zh-CN/cli/sessions.md +23 -0
  2063. package/docs/zh-CN/cli/setup.md +36 -0
  2064. package/docs/zh-CN/cli/skills.md +33 -0
  2065. package/docs/zh-CN/cli/status.md +33 -0
  2066. package/docs/zh-CN/cli/system.md +63 -0
  2067. package/docs/zh-CN/cli/tui.md +30 -0
  2068. package/docs/zh-CN/cli/uninstall.md +24 -0
  2069. package/docs/zh-CN/cli/update.md +101 -0
  2070. package/docs/zh-CN/cli/voicecall.md +41 -0
  2071. package/docs/zh-CN/cli/webhooks.md +32 -0
  2072. package/docs/zh-CN/concepts/agent-loop.md +146 -0
  2073. package/docs/zh-CN/concepts/agent-workspace.md +219 -0
  2074. package/docs/zh-CN/concepts/agent.md +115 -0
  2075. package/docs/zh-CN/concepts/architecture.md +123 -0
  2076. package/docs/zh-CN/concepts/compaction.md +67 -0
  2077. package/docs/zh-CN/concepts/context.md +168 -0
  2078. package/docs/zh-CN/concepts/features.md +59 -0
  2079. package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
  2080. package/docs/zh-CN/concepts/memory.md +412 -0
  2081. package/docs/zh-CN/concepts/messages.md +141 -0
  2082. package/docs/zh-CN/concepts/model-failover.md +145 -0
  2083. package/docs/zh-CN/concepts/model-providers.md +589 -0
  2084. package/docs/zh-CN/concepts/models.md +225 -0
  2085. package/docs/zh-CN/concepts/multi-agent.md +372 -0
  2086. package/docs/zh-CN/concepts/oauth.md +164 -0
  2087. package/docs/zh-CN/concepts/presence.md +99 -0
  2088. package/docs/zh-CN/concepts/queue.md +94 -0
  2089. package/docs/zh-CN/concepts/retry.md +76 -0
  2090. package/docs/zh-CN/concepts/session-pruning.md +129 -0
  2091. package/docs/zh-CN/concepts/session-tool.md +200 -0
  2092. package/docs/zh-CN/concepts/session.md +166 -0
  2093. package/docs/zh-CN/concepts/streaming.md +133 -0
  2094. package/docs/zh-CN/concepts/system-prompt.md +101 -0
  2095. package/docs/zh-CN/concepts/timezone.md +96 -0
  2096. package/docs/zh-CN/concepts/typebox.md +284 -0
  2097. package/docs/zh-CN/concepts/typing-indicators.md +74 -0
  2098. package/docs/zh-CN/concepts/usage-tracking.md +42 -0
  2099. package/docs/zh-CN/date-time.md +129 -0
  2100. package/docs/zh-CN/debug/node-issue.md +90 -0
  2101. package/docs/zh-CN/diagnostics/flags.md +98 -0
  2102. package/docs/zh-CN/gateway/authentication.md +184 -0
  2103. package/docs/zh-CN/gateway/background-process.md +100 -0
  2104. package/docs/zh-CN/gateway/bonjour.md +174 -0
  2105. package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
  2106. package/docs/zh-CN/gateway/cli-backends.md +213 -0
  2107. package/docs/zh-CN/gateway/configuration-examples.md +587 -0
  2108. package/docs/zh-CN/gateway/configuration-reference.md +3103 -0
  2109. package/docs/zh-CN/gateway/configuration.md +640 -0
  2110. package/docs/zh-CN/gateway/discovery.md +123 -0
  2111. package/docs/zh-CN/gateway/doctor.md +238 -0
  2112. package/docs/zh-CN/gateway/gateway-lock.md +41 -0
  2113. package/docs/zh-CN/gateway/health.md +42 -0
  2114. package/docs/zh-CN/gateway/heartbeat.md +274 -0
  2115. package/docs/zh-CN/gateway/index.md +335 -0
  2116. package/docs/zh-CN/gateway/local-models.md +159 -0
  2117. package/docs/zh-CN/gateway/logging.md +114 -0
  2118. package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
  2119. package/docs/zh-CN/gateway/network-model.md +23 -0
  2120. package/docs/zh-CN/gateway/openai-http-api.md +125 -0
  2121. package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
  2122. package/docs/zh-CN/gateway/pairing.md +99 -0
  2123. package/docs/zh-CN/gateway/protocol.md +220 -0
  2124. package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
  2125. package/docs/zh-CN/gateway/remote.md +133 -0
  2126. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
  2127. package/docs/zh-CN/gateway/sandboxing.md +188 -0
  2128. package/docs/zh-CN/gateway/security/index.md +777 -0
  2129. package/docs/zh-CN/gateway/tailscale.md +124 -0
  2130. package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
  2131. package/docs/zh-CN/gateway/troubleshooting.md +771 -0
  2132. package/docs/zh-CN/help/debugging.md +160 -0
  2133. package/docs/zh-CN/help/environment.md +88 -0
  2134. package/docs/zh-CN/help/faq.md +2640 -0
  2135. package/docs/zh-CN/help/index.md +28 -0
  2136. package/docs/zh-CN/help/scripts.md +35 -0
  2137. package/docs/zh-CN/help/testing.md +375 -0
  2138. package/docs/zh-CN/help/troubleshooting.md +104 -0
  2139. package/docs/zh-CN/index.md +186 -0
  2140. package/docs/zh-CN/install/ansible.md +215 -0
  2141. package/docs/zh-CN/install/bun.md +65 -0
  2142. package/docs/zh-CN/install/development-channels.md +81 -0
  2143. package/docs/zh-CN/install/docker.md +532 -0
  2144. package/docs/zh-CN/install/exe-dev.md +133 -0
  2145. package/docs/zh-CN/install/fly.md +490 -0
  2146. package/docs/zh-CN/install/gcp.md +510 -0
  2147. package/docs/zh-CN/install/hetzner.md +337 -0
  2148. package/docs/zh-CN/install/index.md +235 -0
  2149. package/docs/zh-CN/install/installer.md +422 -0
  2150. package/docs/zh-CN/install/macos-vm.md +288 -0
  2151. package/docs/zh-CN/install/migrating.md +199 -0
  2152. package/docs/zh-CN/install/nix.md +99 -0
  2153. package/docs/zh-CN/install/node.md +8 -0
  2154. package/docs/zh-CN/install/northflank.mdx +60 -0
  2155. package/docs/zh-CN/install/railway.mdx +106 -0
  2156. package/docs/zh-CN/install/render.mdx +169 -0
  2157. package/docs/zh-CN/install/uninstall.md +135 -0
  2158. package/docs/zh-CN/install/updating.md +233 -0
  2159. package/docs/zh-CN/logging.md +329 -0
  2160. package/docs/zh-CN/network.md +59 -0
  2161. package/docs/zh-CN/nodes/audio.md +120 -0
  2162. package/docs/zh-CN/nodes/camera.md +162 -0
  2163. package/docs/zh-CN/nodes/images.md +79 -0
  2164. package/docs/zh-CN/nodes/index.md +350 -0
  2165. package/docs/zh-CN/nodes/location-command.md +120 -0
  2166. package/docs/zh-CN/nodes/media-understanding.md +380 -0
  2167. package/docs/zh-CN/nodes/talk.md +97 -0
  2168. package/docs/zh-CN/nodes/troubleshooting.md +8 -0
  2169. package/docs/zh-CN/nodes/voicewake.md +72 -0
  2170. package/docs/zh-CN/perplexity.md +102 -0
  2171. package/docs/zh-CN/pi-dev.md +87 -0
  2172. package/docs/zh-CN/pi.md +571 -0
  2173. package/docs/zh-CN/platforms/android.md +155 -0
  2174. package/docs/zh-CN/platforms/digitalocean.md +273 -0
  2175. package/docs/zh-CN/platforms/index.md +60 -0
  2176. package/docs/zh-CN/platforms/ios.md +114 -0
  2177. package/docs/zh-CN/platforms/linux.md +100 -0
  2178. package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
  2179. package/docs/zh-CN/platforms/mac/canvas.md +128 -0
  2180. package/docs/zh-CN/platforms/mac/child-process.md +73 -0
  2181. package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
  2182. package/docs/zh-CN/platforms/mac/health.md +41 -0
  2183. package/docs/zh-CN/platforms/mac/icon.md +38 -0
  2184. package/docs/zh-CN/platforms/mac/logging.md +64 -0
  2185. package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
  2186. package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
  2187. package/docs/zh-CN/platforms/mac/permissions.md +46 -0
  2188. package/docs/zh-CN/platforms/mac/remote.md +90 -0
  2189. package/docs/zh-CN/platforms/mac/signing.md +54 -0
  2190. package/docs/zh-CN/platforms/mac/skills.md +40 -0
  2191. package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
  2192. package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
  2193. package/docs/zh-CN/platforms/mac/webchat.md +43 -0
  2194. package/docs/zh-CN/platforms/mac/xpc.md +68 -0
  2195. package/docs/zh-CN/platforms/macos.md +193 -0
  2196. package/docs/zh-CN/platforms/oracle.md +310 -0
  2197. package/docs/zh-CN/platforms/raspberry-pi.md +416 -0
  2198. package/docs/zh-CN/platforms/windows.md +247 -0
  2199. package/docs/zh-CN/plugins/agent-tools.md +99 -0
  2200. package/docs/zh-CN/plugins/manifest.md +68 -0
  2201. package/docs/zh-CN/plugins/voice-call.md +250 -0
  2202. package/docs/zh-CN/plugins/zalouser.md +88 -0
  2203. package/docs/zh-CN/prose.md +141 -0
  2204. package/docs/zh-CN/providers/anthropic.md +265 -0
  2205. package/docs/zh-CN/providers/bedrock.md +170 -0
  2206. package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
  2207. package/docs/zh-CN/providers/cloudflare-ai-gateway.md +78 -0
  2208. package/docs/zh-CN/providers/deepgram.md +97 -0
  2209. package/docs/zh-CN/providers/github-copilot.md +67 -0
  2210. package/docs/zh-CN/providers/glm.md +50 -0
  2211. package/docs/zh-CN/providers/huggingface.md +216 -0
  2212. package/docs/zh-CN/providers/index.md +69 -0
  2213. package/docs/zh-CN/providers/kilocode.md +80 -0
  2214. package/docs/zh-CN/providers/litellm.md +160 -0
  2215. package/docs/zh-CN/providers/minimax.md +222 -0
  2216. package/docs/zh-CN/providers/mistral.md +61 -0
  2217. package/docs/zh-CN/providers/models.md +51 -0
  2218. package/docs/zh-CN/providers/moonshot.md +182 -0
  2219. package/docs/zh-CN/providers/nvidia.md +62 -0
  2220. package/docs/zh-CN/providers/ollama.md +359 -0
  2221. package/docs/zh-CN/providers/openai.md +308 -0
  2222. package/docs/zh-CN/providers/opencode-go.md +52 -0
  2223. package/docs/zh-CN/providers/opencode.md +71 -0
  2224. package/docs/zh-CN/providers/openrouter.md +44 -0
  2225. package/docs/zh-CN/providers/qianfan.md +45 -0
  2226. package/docs/zh-CN/providers/qwen.md +36 -0
  2227. package/docs/zh-CN/providers/sglang.md +111 -0
  2228. package/docs/zh-CN/providers/synthetic.md +106 -0
  2229. package/docs/zh-CN/providers/together.md +72 -0
  2230. package/docs/zh-CN/providers/venice.md +289 -0
  2231. package/docs/zh-CN/providers/vercel-ai-gateway.md +66 -0
  2232. package/docs/zh-CN/providers/xiaomi.md +93 -0
  2233. package/docs/zh-CN/providers/zai.md +53 -0
  2234. package/docs/zh-CN/reference/AGENTS.default.md +131 -0
  2235. package/docs/zh-CN/reference/RELEASING.md +48 -0
  2236. package/docs/zh-CN/reference/api-usage-costs.md +141 -0
  2237. package/docs/zh-CN/reference/credits.md +34 -0
  2238. package/docs/zh-CN/reference/device-models.md +54 -0
  2239. package/docs/zh-CN/reference/rpc.md +48 -0
  2240. package/docs/zh-CN/reference/session-management-compaction.md +287 -0
  2241. package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
  2242. package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
  2243. package/docs/zh-CN/reference/templates/BOOT.md +17 -0
  2244. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
  2245. package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
  2246. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
  2247. package/docs/zh-CN/reference/templates/IDENTITY.md +36 -0
  2248. package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
  2249. package/docs/zh-CN/reference/templates/SOUL.md +49 -0
  2250. package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
  2251. package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
  2252. package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
  2253. package/docs/zh-CN/reference/templates/USER.md +30 -0
  2254. package/docs/zh-CN/reference/test.md +57 -0
  2255. package/docs/zh-CN/reference/token-use.md +119 -0
  2256. package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
  2257. package/docs/zh-CN/reference/wizard.md +242 -0
  2258. package/docs/zh-CN/security/formal-verification.md +171 -0
  2259. package/docs/zh-CN/start/bootstrapping.md +9 -0
  2260. package/docs/zh-CN/start/docs-directory.md +70 -0
  2261. package/docs/zh-CN/start/getting-started.md +143 -0
  2262. package/docs/zh-CN/start/hubs.md +194 -0
  2263. package/docs/zh-CN/start/lore.md +226 -0
  2264. package/docs/zh-CN/start/onboarding-overview.md +58 -0
  2265. package/docs/zh-CN/start/onboarding.md +105 -0
  2266. package/docs/zh-CN/start/quickstart.md +88 -0
  2267. package/docs/zh-CN/start/setup.md +153 -0
  2268. package/docs/zh-CN/start/showcase.md +423 -0
  2269. package/docs/zh-CN/start/vora.md +248 -0
  2270. package/docs/zh-CN/start/wizard-cli-automation.md +222 -0
  2271. package/docs/zh-CN/start/wizard-cli-reference.md +306 -0
  2272. package/docs/zh-CN/start/wizard.md +132 -0
  2273. package/docs/zh-CN/tools/agent-send.md +59 -0
  2274. package/docs/zh-CN/tools/apply-patch.md +57 -0
  2275. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
  2276. package/docs/zh-CN/tools/browser-login.md +75 -0
  2277. package/docs/zh-CN/tools/browser.md +553 -0
  2278. package/docs/zh-CN/tools/chrome-extension.md +183 -0
  2279. package/docs/zh-CN/tools/clawhub.md +225 -0
  2280. package/docs/zh-CN/tools/creating-skills.md +61 -0
  2281. package/docs/zh-CN/tools/diffs.md +393 -0
  2282. package/docs/zh-CN/tools/elevated.md +64 -0
  2283. package/docs/zh-CN/tools/exec-approvals.md +234 -0
  2284. package/docs/zh-CN/tools/exec.md +169 -0
  2285. package/docs/zh-CN/tools/firecrawl.md +68 -0
  2286. package/docs/zh-CN/tools/index.md +514 -0
  2287. package/docs/zh-CN/tools/llm-task.md +117 -0
  2288. package/docs/zh-CN/tools/lobster.md +349 -0
  2289. package/docs/zh-CN/tools/multi-agent-sandbox-tools.md +401 -0
  2290. package/docs/zh-CN/tools/plugin.md +1610 -0
  2291. package/docs/zh-CN/tools/reactions.md +29 -0
  2292. package/docs/zh-CN/tools/skills-config.md +78 -0
  2293. package/docs/zh-CN/tools/skills.md +279 -0
  2294. package/docs/zh-CN/tools/slash-commands.md +205 -0
  2295. package/docs/zh-CN/tools/subagents.md +167 -0
  2296. package/docs/zh-CN/tools/thinking.md +80 -0
  2297. package/docs/zh-CN/tools/web.md +289 -0
  2298. package/docs/zh-CN/tts.md +375 -0
  2299. package/docs/zh-CN/vps.md +47 -0
  2300. package/docs/zh-CN/web/control-ui.md +191 -0
  2301. package/docs/zh-CN/web/dashboard.md +53 -0
  2302. package/docs/zh-CN/web/index.md +118 -0
  2303. package/docs/zh-CN/web/tui.md +166 -0
  2304. package/docs/zh-CN/web/webchat.md +56 -0
  2305. package/package.json +1305 -0
  2306. package/scripts/postinstall-bundled-plugins.mjs +166 -0
  2307. package/skills/1password/SKILL.md +70 -0
  2308. package/skills/1password/references/cli-examples.md +29 -0
  2309. package/skills/1password/references/get-started.md +17 -0
  2310. package/skills/apple-notes/SKILL.md +77 -0
  2311. package/skills/apple-reminders/SKILL.md +118 -0
  2312. package/skills/bear-notes/SKILL.md +107 -0
  2313. package/skills/blogwatcher/SKILL.md +69 -0
  2314. package/skills/blucli/SKILL.md +47 -0
  2315. package/skills/bluebubbles/SKILL.md +131 -0
  2316. package/skills/camsnap/SKILL.md +45 -0
  2317. package/skills/canvas/SKILL.md +199 -0
  2318. package/skills/clawflow/SKILL.md +76 -0
  2319. package/skills/clawflow/examples/inbox-triage.lobster +33 -0
  2320. package/skills/clawflow/examples/pr-intake.lobster +32 -0
  2321. package/skills/clawflow-inbox-triage/SKILL.md +62 -0
  2322. package/skills/clawhub/SKILL.md +77 -0
  2323. package/skills/coding-agent/SKILL.md +316 -0
  2324. package/skills/discord/SKILL.md +197 -0
  2325. package/skills/eightctl/SKILL.md +50 -0
  2326. package/skills/gemini/SKILL.md +43 -0
  2327. package/skills/gh-issues/SKILL.md +885 -0
  2328. package/skills/gifgrep/SKILL.md +79 -0
  2329. package/skills/github/SKILL.md +163 -0
  2330. package/skills/gog/SKILL.md +116 -0
  2331. package/skills/goplaces/SKILL.md +52 -0
  2332. package/skills/healthcheck/SKILL.md +245 -0
  2333. package/skills/himalaya/SKILL.md +257 -0
  2334. package/skills/himalaya/references/configuration.md +184 -0
  2335. package/skills/himalaya/references/message-composition.md +199 -0
  2336. package/skills/imsg/SKILL.md +122 -0
  2337. package/skills/mcporter/SKILL.md +61 -0
  2338. package/skills/model-usage/SKILL.md +69 -0
  2339. package/skills/model-usage/references/codexbar-cli.md +33 -0
  2340. package/skills/model-usage/scripts/model_usage.py +320 -0
  2341. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  2342. package/skills/nano-pdf/SKILL.md +38 -0
  2343. package/skills/node-connect/SKILL.md +142 -0
  2344. package/skills/notion/SKILL.md +174 -0
  2345. package/skills/obsidian/SKILL.md +81 -0
  2346. package/skills/openai-whisper/SKILL.md +38 -0
  2347. package/skills/openai-whisper-api/SKILL.md +62 -0
  2348. package/skills/openai-whisper-api/scripts/transcribe.sh +88 -0
  2349. package/skills/openhue/SKILL.md +112 -0
  2350. package/skills/oracle/SKILL.md +125 -0
  2351. package/skills/ordercli/SKILL.md +78 -0
  2352. package/skills/peekaboo/SKILL.md +190 -0
  2353. package/skills/sag/SKILL.md +87 -0
  2354. package/skills/session-logs/SKILL.md +151 -0
  2355. package/skills/sherpa-onnx-tts/SKILL.md +109 -0
  2356. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  2357. package/skills/skill-creator/SKILL.md +372 -0
  2358. package/skills/skill-creator/license.txt +202 -0
  2359. package/skills/skill-creator/scripts/init_skill.py +378 -0
  2360. package/skills/skill-creator/scripts/package_skill.py +139 -0
  2361. package/skills/skill-creator/scripts/quick_validate.py +159 -0
  2362. package/skills/skill-creator/scripts/test_package_skill.py +160 -0
  2363. package/skills/skill-creator/scripts/test_quick_validate.py +72 -0
  2364. package/skills/slack/SKILL.md +144 -0
  2365. package/skills/songsee/SKILL.md +49 -0
  2366. package/skills/sonoscli/SKILL.md +65 -0
  2367. package/skills/spotify-player/SKILL.md +64 -0
  2368. package/skills/summarize/SKILL.md +87 -0
  2369. package/skills/things-mac/SKILL.md +86 -0
  2370. package/skills/tmux/SKILL.md +170 -0
  2371. package/skills/tmux/scripts/find-sessions.sh +112 -0
  2372. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  2373. package/skills/trello/SKILL.md +108 -0
  2374. package/skills/video-frames/SKILL.md +46 -0
  2375. package/skills/video-frames/scripts/frame.sh +81 -0
  2376. package/skills/voice-call/SKILL.md +45 -0
  2377. package/skills/wacli/SKILL.md +72 -0
  2378. package/skills/weather/SKILL.md +129 -0
  2379. package/skills/xurl/SKILL.md +461 -0
  2380. package/vora.mjs +183 -0
@@ -0,0 +1,2205 @@
1
+ import { n as defaultRuntime } from "./runtime-D0VpiCHi.js";
2
+ import { t as sanitizeForLog } from "./ansi-B_0KjIJj.js";
3
+ import "./defaults-DAt--D9n.js";
4
+ import { f as normalizeVerboseLevel, p as resolveResponseUsageMode } from "./thinking.shared-C4SN38qn.js";
5
+ import { r as logVerbose } from "./globals-DNhziPZz.js";
6
+ import { u as resolveAgentIdFromSessionKey } from "./session-key-BIrdMs11.js";
7
+ import { _ as resolveRunModelFallbacksOverride, v as resolveSessionAgentId } from "./agent-scope-BsqFyt8u.js";
8
+ import { s as isCliProvider } from "./model-selection-DLV9QudA.js";
9
+ import { c as loadConfig } from "./io-B07IaARR.js";
10
+ import "./config-CKbWnj3S.js";
11
+ import { o as isInternalMessageChannel, p as resolveMessageChannel, s as isMarkdownCapableMessageChannel } from "./message-channel-Di9LQZCg.js";
12
+ import { S as resolveGroupSessionKey, d as updateSessionStoreEntry, r as loadSessionStore, u as updateSessionStore } from "./store-DKzOIKqx.js";
13
+ import "./sessions-zgiFsm1E.js";
14
+ import { a as resolveSessionTranscriptPath, i as resolveSessionFilePathOptions, r as resolveSessionFilePath } from "./paths-dFp6bjkV.js";
15
+ import { a as resolveFreshSessionTotalTokens } from "./types-KyI2zD1Y.js";
16
+ import { a as isAudioFileName } from "./mime-CPj5mSwT.js";
17
+ import { a as isSilentReplyText, i as isSilentReplyPrefixText, n as SILENT_REPLY_TOKEN } from "./tokens-shGOmvyA.js";
18
+ import { a as stripHeartbeatToken } from "./heartbeat-C1Xvupsk.js";
19
+ import { u as resolveMemoryFlushPlan } from "./memory-state-BPOopEhZ.js";
20
+ import { B as buildFallbackClearedNotice, H as resolveFallbackTransition, Mt as isFallbackSummaryError, Nt as runWithModelFallback, Pt as LiveSessionModelSwitchError, V as buildFallbackNotice, Vt as queueEmbeddedPiMessage, l as compactEmbeddedPiSession, m as readPostCompactionContext, p as estimateMessagesTokens, t as runEmbeddedVoraAgent } from "./vora-embedded-runner-CtRc9sK4.js";
21
+ import { a as generateSecureUuid } from "./secure-random-DJ9MB_Og.js";
22
+ import { n as isDiagnosticsEnabled, t as emitDiagnosticEvent } from "./diagnostic-events-R6R0hsS8.js";
23
+ import { a as enqueueFollowupRun, c as scheduleFollowupDrain, l as refreshQueuedFollowupSession } from "./content-blocks-DdN51R-1.js";
24
+ import { o as resolveBootstrapWarningSignaturesSeen } from "./bootstrap-budget-lNGYv_xu.js";
25
+ import { F as isBillingErrorMessage, I as isOverloadedErrorMessage, L as isRateLimitErrorMessage, O as isLikelyContextOverflowError, P as sanitizeUserFacingText, T as isContextOverflowError, j as isTransientHttpError, m as BILLING_ERROR_USER_MESSAGE, w as isCompactionFailureError } from "./vora-embedded-helpers-CcpQ4UhE.js";
26
+ import { n as resolveSandboxConfigForAgent } from "./config-DUHgkJzn.js";
27
+ import { n as resolveSandboxRuntimeStatus } from "./runtime-status-C7QK-Xow.js";
28
+ import "./thinking-uI0siSaD.js";
29
+ import { s as resolveModelAuthMode } from "./model-auth-FAjaPIyj.js";
30
+ import { a as resolveSandboxedMediaSource, t as assertMediaNotDataUrl } from "./sandbox-paths-ui_vqw2W.js";
31
+ import { h as resolvePathFromInput, o as parseReplyDirectives, p as resolveEffectiveToolFsWorkspaceOnly } from "./deliver-NyzvqqW3.js";
32
+ import { r as enqueueSystemEvent } from "./system-events-CkTr2pVV.js";
33
+ import { a as ensureSandboxWorkspaceForSession } from "./sandbox-DxQGIkI1.js";
34
+ import { p as resolveSendableOutboundReplyParts, s as hasOutboundReplyContent } from "./reply-payload-D0XXyIHC.js";
35
+ import { i as isRenderablePayload, n as applyReplyThreading, o as createReplyToModeFilterForChannel, s as resolveReplyToMode, t as applyReplyTagsToPayload } from "./reply-payloads-DW1w7Ckr.js";
36
+ import { n as filterMessagingToolMediaDuplicates, r as shouldSuppressMessagingToolReplies, t as filterMessagingToolDuplicates } from "./reply-payloads-dedupe-BEPyuQQJ.js";
37
+ import { n as routeReply, t as isRoutableChannel } from "./route-reply-BhwCACur.js";
38
+ import { a as registerAgentRunContext, n as emitAgentEvent } from "./agent-events-DvBJWaR9.js";
39
+ import { _ as readSessionMessages } from "./session-utils-CYh1zGmy.js";
40
+ import { t as lookupContextTokens } from "./context-Bv7BKF9l.js";
41
+ import { c as hasNonzeroUsage, o as derivePromptTokens, s as deriveSessionTotalTokens, u as normalizeUsage } from "./chat-envelope-BKa8gVwt.js";
42
+ import { a as formatTokenCount, i as estimateUsageCost, o as formatUsd, s as resolveModelCostConfig } from "./strip-inbound-meta-DuOzaKMB.js";
43
+ import { r as resolveEffectiveBlockStreamingConfig } from "./block-streaming-irtDjCPX.js";
44
+ import { n as resolveOriginMessageProvider, r as resolveOriginMessageTo, t as resolveOriginAccountId } from "./origin-routing-IIB1gZNP.js";
45
+ import { t as createTypingSignaler } from "./typing-mode-D3dtTRFq.js";
46
+ import { n as resolveCronStorePath, t as loadCronStore } from "./store-HBHyNMRe.js";
47
+ import { a as setCliSessionId, i as setCliSessionBinding, r as getCliSessionBinding, t as runCliAgent } from "./cli-runner-rgKmST01.js";
48
+ import { a as resolveModelFallbackOptions, i as isBunFetchSocketError, o as resolveRunAuthProfile, r as formatBunFetchSocketError, t as buildEmbeddedRunExecutionParams } from "./agent-runner-utils-9OoCJtjv.js";
49
+ import { n as createBlockReplyContentKey, r as createBlockReplyPipeline, t as createAudioAsVoiceBuffer } from "./block-reply-pipeline-DOyiLrmk.js";
50
+ import { n as incrementCompactionCount } from "./session-updates-Dd6r5vhZ.js";
51
+ import fsSync from "node:fs";
52
+ import crypto from "node:crypto";
53
+ //#region src/auto-reply/reply/reply-delivery.ts
54
+ function normalizeReplyPayloadDirectives(params) {
55
+ const parseMode = params.parseMode ?? "always";
56
+ const silentToken = params.silentToken ?? "NO_REPLY";
57
+ const sourceText = params.payload.text ?? "";
58
+ const parsed = parseMode === "always" || parseMode === "auto" && (sourceText.includes("[[") || sourceText.includes("MEDIA:") || sourceText.includes(silentToken)) ? parseReplyDirectives(sourceText, {
59
+ currentMessageId: params.currentMessageId,
60
+ silentToken
61
+ }) : void 0;
62
+ let text = parsed ? parsed.text || void 0 : params.payload.text || void 0;
63
+ if (params.trimLeadingWhitespace && text) text = text.trimStart() || void 0;
64
+ const mediaUrls = params.payload.mediaUrls ?? parsed?.mediaUrls;
65
+ const mediaUrl = params.payload.mediaUrl ?? parsed?.mediaUrl ?? mediaUrls?.[0];
66
+ return {
67
+ payload: {
68
+ ...params.payload,
69
+ text,
70
+ mediaUrls,
71
+ mediaUrl,
72
+ replyToId: params.payload.replyToId ?? parsed?.replyToId,
73
+ replyToTag: params.payload.replyToTag || parsed?.replyToTag,
74
+ replyToCurrent: params.payload.replyToCurrent || parsed?.replyToCurrent,
75
+ audioAsVoice: Boolean(params.payload.audioAsVoice || parsed?.audioAsVoice)
76
+ },
77
+ isSilent: parsed?.isSilent ?? false
78
+ };
79
+ }
80
+ function createBlockReplyDeliveryHandler(params) {
81
+ return async (payload) => {
82
+ const { text, skip } = params.normalizeStreamingText(payload);
83
+ if (skip && !resolveSendableOutboundReplyParts(payload).hasMedia) return;
84
+ const taggedPayload = applyReplyTagsToPayload({
85
+ ...payload,
86
+ text,
87
+ mediaUrl: payload.mediaUrl ?? payload.mediaUrls?.[0],
88
+ replyToId: payload.replyToId ?? (payload.replyToCurrent === false ? void 0 : params.currentMessageId)
89
+ }, params.currentMessageId);
90
+ if (!isRenderablePayload(taggedPayload) && !payload.audioAsVoice) return;
91
+ const normalized = normalizeReplyPayloadDirectives({
92
+ payload: taggedPayload,
93
+ currentMessageId: params.currentMessageId,
94
+ silentToken: SILENT_REPLY_TOKEN,
95
+ trimLeadingWhitespace: true,
96
+ parseMode: "auto"
97
+ });
98
+ const mediaNormalizedPayload = params.normalizeMediaPaths ? await params.normalizeMediaPaths(normalized.payload) : normalized.payload;
99
+ const blockPayload = params.applyReplyToMode(mediaNormalizedPayload);
100
+ const blockHasMedia = resolveSendableOutboundReplyParts(blockPayload).hasMedia;
101
+ if (!blockPayload.text && !blockHasMedia && !blockPayload.audioAsVoice) return;
102
+ if (normalized.isSilent && !blockHasMedia) return;
103
+ if (blockPayload.text) params.typingSignals.signalTextDelta(blockPayload.text).catch((err) => {
104
+ logVerbose(`block reply typing signal failed: ${String(err)}`);
105
+ });
106
+ if (params.blockStreamingEnabled && params.blockReplyPipeline) params.blockReplyPipeline.enqueue(blockPayload);
107
+ else if (params.blockStreamingEnabled) {
108
+ params.directlySentBlockKeys.add(createBlockReplyContentKey(blockPayload));
109
+ await params.onBlockReply(blockPayload);
110
+ } else if (blockHasMedia) {
111
+ params.directlySentBlockKeys.add(createBlockReplyContentKey(blockPayload));
112
+ await params.onBlockReply({
113
+ ...blockPayload,
114
+ text: void 0
115
+ });
116
+ }
117
+ };
118
+ }
119
+ //#endregion
120
+ //#region src/auto-reply/reply/reply-media-paths.ts
121
+ const HTTP_URL_RE = /^https?:\/\//i;
122
+ const FILE_URL_RE = /^file:\/\//i;
123
+ const WINDOWS_DRIVE_RE = /^[a-zA-Z]:[\\/]/;
124
+ const SCHEME_RE = /^[a-zA-Z][a-zA-Z0-9+.-]*:/;
125
+ const HAS_FILE_EXT_RE = /\.\w{1,10}$/;
126
+ function isLikelyLocalMediaSource(media) {
127
+ return FILE_URL_RE.test(media) || media.startsWith("/") || media.startsWith("./") || media.startsWith("../") || media.startsWith("~") || WINDOWS_DRIVE_RE.test(media) || media.startsWith("\\\\") || !SCHEME_RE.test(media) && (media.includes("/") || media.includes("\\") || HAS_FILE_EXT_RE.test(media));
128
+ }
129
+ function getPayloadMediaList(payload) {
130
+ return resolveSendableOutboundReplyParts(payload).mediaUrls;
131
+ }
132
+ function createReplyMediaPathNormalizer(params) {
133
+ const agentId = params.sessionKey ? resolveSessionAgentId({
134
+ sessionKey: params.sessionKey,
135
+ config: params.cfg
136
+ }) : void 0;
137
+ const workspaceOnly = resolveEffectiveToolFsWorkspaceOnly({
138
+ cfg: params.cfg,
139
+ agentId
140
+ });
141
+ let sandboxRootPromise;
142
+ const resolveSandboxRoot = async () => {
143
+ if (!sandboxRootPromise) sandboxRootPromise = ensureSandboxWorkspaceForSession({
144
+ config: params.cfg,
145
+ sessionKey: params.sessionKey,
146
+ workspaceDir: params.workspaceDir
147
+ }).then((sandbox) => sandbox?.workspaceDir);
148
+ return await sandboxRootPromise;
149
+ };
150
+ const normalizeMediaSource = async (raw) => {
151
+ const media = raw.trim();
152
+ if (!media) return media;
153
+ assertMediaNotDataUrl(media);
154
+ if (HTTP_URL_RE.test(media)) return media;
155
+ const sandboxRoot = await resolveSandboxRoot();
156
+ if (sandboxRoot) try {
157
+ return await resolveSandboxedMediaSource({
158
+ media,
159
+ sandboxRoot
160
+ });
161
+ } catch (err) {
162
+ if (workspaceOnly || !isLikelyLocalMediaSource(media)) throw err;
163
+ if (FILE_URL_RE.test(media)) return media;
164
+ return resolvePathFromInput(media, params.workspaceDir);
165
+ }
166
+ if (!isLikelyLocalMediaSource(media)) return media;
167
+ if (FILE_URL_RE.test(media)) return media;
168
+ return resolvePathFromInput(media, params.workspaceDir);
169
+ };
170
+ return async (payload) => {
171
+ const mediaList = getPayloadMediaList(payload);
172
+ if (mediaList.length === 0) return payload;
173
+ const normalizedMedia = [];
174
+ const seen = /* @__PURE__ */ new Set();
175
+ for (const media of mediaList) {
176
+ const normalized = await normalizeMediaSource(media);
177
+ if (!normalized || seen.has(normalized)) continue;
178
+ seen.add(normalized);
179
+ normalizedMedia.push(normalized);
180
+ }
181
+ if (normalizedMedia.length === 0) return {
182
+ ...payload,
183
+ mediaUrl: void 0,
184
+ mediaUrls: void 0
185
+ };
186
+ return {
187
+ ...payload,
188
+ mediaUrl: normalizedMedia[0],
189
+ mediaUrls: normalizedMedia
190
+ };
191
+ };
192
+ }
193
+ /**
194
+ * Build a human-friendly rate-limit message from a FallbackSummaryError.
195
+ * Includes a countdown when the soonest cooldown expiry is known.
196
+ */
197
+ function buildRateLimitCooldownMessage(err) {
198
+ if (!isFallbackSummaryError(err)) return "⚠️ All models are temporarily rate-limited. Please try again in a few minutes.";
199
+ const expiry = err.soonestCooldownExpiry;
200
+ const now = Date.now();
201
+ if (typeof expiry === "number" && expiry > now) {
202
+ const secsLeft = Math.max(1, Math.ceil((expiry - now) / 1e3));
203
+ if (secsLeft <= 60) return `⚠️ Rate-limited — ready in ~${secsLeft}s. Please wait a moment.`;
204
+ return `⚠️ Rate-limited — ready in ~${Math.ceil(secsLeft / 60)} min. Please try again shortly.`;
205
+ }
206
+ return "⚠️ All models are temporarily rate-limited. Please try again in a few minutes.";
207
+ }
208
+ function isPureTransientRateLimitSummary(err) {
209
+ return isFallbackSummaryError(err) && err.attempts.length > 0 && err.attempts.every((attempt) => {
210
+ const reason = attempt.reason;
211
+ return reason === "rate_limit" || reason === "overloaded";
212
+ });
213
+ }
214
+ async function runAgentTurnWithFallback(params) {
215
+ const TRANSIENT_HTTP_RETRY_DELAY_MS = 2500;
216
+ let didLogHeartbeatStrip = false;
217
+ let autoCompactionCount = 0;
218
+ const directlySentBlockKeys = /* @__PURE__ */ new Set();
219
+ const runId = params.opts?.runId ?? crypto.randomUUID();
220
+ const normalizeReplyMediaPaths = createReplyMediaPathNormalizer({
221
+ cfg: params.followupRun.run.config,
222
+ sessionKey: params.sessionKey,
223
+ workspaceDir: params.followupRun.run.workspaceDir
224
+ });
225
+ let didNotifyAgentRunStart = false;
226
+ const notifyAgentRunStart = () => {
227
+ if (didNotifyAgentRunStart) return;
228
+ didNotifyAgentRunStart = true;
229
+ params.opts?.onAgentRunStart?.(runId);
230
+ };
231
+ const shouldSurfaceToControlUi = isInternalMessageChannel(params.followupRun.run.messageProvider ?? params.sessionCtx.Surface ?? params.sessionCtx.Provider);
232
+ if (params.sessionKey) registerAgentRunContext(runId, {
233
+ sessionKey: params.sessionKey,
234
+ verboseLevel: params.resolvedVerboseLevel,
235
+ isHeartbeat: params.isHeartbeat,
236
+ isControlUiVisible: shouldSurfaceToControlUi
237
+ });
238
+ let runResult;
239
+ let fallbackProvider = params.followupRun.run.provider;
240
+ let fallbackModel = params.followupRun.run.model;
241
+ let fallbackAttempts = [];
242
+ let didResetAfterCompactionFailure = false;
243
+ let didRetryTransientHttpError = false;
244
+ let liveModelSwitchRetries = 0;
245
+ let bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(params.getActiveSessionEntry()?.systemPromptReport);
246
+ while (true) try {
247
+ const normalizeStreamingText = (payload) => {
248
+ let text = payload.text;
249
+ const reply = resolveSendableOutboundReplyParts(payload);
250
+ if (params.followupRun.run.silentExpected) return { skip: true };
251
+ if (!params.isHeartbeat && text?.includes("HEARTBEAT_OK")) {
252
+ const stripped = stripHeartbeatToken(text, { mode: "message" });
253
+ if (stripped.didStrip && !didLogHeartbeatStrip) {
254
+ didLogHeartbeatStrip = true;
255
+ logVerbose("Stripped stray HEARTBEAT_OK token from reply");
256
+ }
257
+ if (stripped.shouldSkip && !reply.hasMedia) return { skip: true };
258
+ text = stripped.text;
259
+ }
260
+ if (isSilentReplyText(text, "NO_REPLY")) return { skip: true };
261
+ if (isSilentReplyPrefixText(text, "NO_REPLY") || isSilentReplyPrefixText(text, "HEARTBEAT_OK")) return { skip: true };
262
+ if (!text) {
263
+ if (reply.hasMedia) return {
264
+ text: void 0,
265
+ skip: false
266
+ };
267
+ return { skip: true };
268
+ }
269
+ const sanitized = sanitizeUserFacingText(text, { errorContext: Boolean(payload.isError) });
270
+ if (!sanitized.trim()) return { skip: true };
271
+ return {
272
+ text: sanitized,
273
+ skip: false
274
+ };
275
+ };
276
+ const handlePartialForTyping = async (payload) => {
277
+ if (isSilentReplyPrefixText(payload.text, "NO_REPLY")) return;
278
+ const { text, skip } = normalizeStreamingText(payload);
279
+ if (skip || !text) return;
280
+ await params.typingSignals.signalTextDelta(text);
281
+ return text;
282
+ };
283
+ const blockReplyPipeline = params.blockReplyPipeline;
284
+ const blockReplyHandler = params.opts?.onBlockReply ? createBlockReplyDeliveryHandler({
285
+ onBlockReply: params.opts.onBlockReply,
286
+ currentMessageId: params.sessionCtx.MessageSidFull ?? params.sessionCtx.MessageSid,
287
+ normalizeStreamingText,
288
+ applyReplyToMode: params.applyReplyToMode,
289
+ normalizeMediaPaths: normalizeReplyMediaPaths,
290
+ typingSignals: params.typingSignals,
291
+ blockStreamingEnabled: params.blockStreamingEnabled,
292
+ blockReplyPipeline,
293
+ directlySentBlockKeys
294
+ }) : void 0;
295
+ const onToolResult = params.opts?.onToolResult;
296
+ const fallbackResult = await runWithModelFallback({
297
+ ...resolveModelFallbackOptions(params.followupRun.run),
298
+ runId,
299
+ run: (provider, model, runOptions) => {
300
+ params.opts?.onModelSelected?.({
301
+ provider,
302
+ model,
303
+ thinkLevel: params.followupRun.run.thinkLevel
304
+ });
305
+ if (isCliProvider(provider, params.followupRun.run.config)) {
306
+ const startedAt = Date.now();
307
+ notifyAgentRunStart();
308
+ emitAgentEvent({
309
+ runId,
310
+ stream: "lifecycle",
311
+ data: {
312
+ phase: "start",
313
+ startedAt
314
+ }
315
+ });
316
+ const cliSessionBinding = getCliSessionBinding(params.getActiveSessionEntry(), provider);
317
+ const authProfileId = provider === params.followupRun.run.provider ? params.followupRun.run.authProfileId : void 0;
318
+ return (async () => {
319
+ let lifecycleTerminalEmitted = false;
320
+ try {
321
+ const result = await runCliAgent({
322
+ sessionId: params.followupRun.run.sessionId,
323
+ sessionKey: params.sessionKey,
324
+ agentId: params.followupRun.run.agentId,
325
+ sessionFile: params.followupRun.run.sessionFile,
326
+ workspaceDir: params.followupRun.run.workspaceDir,
327
+ config: params.followupRun.run.config,
328
+ prompt: params.commandBody,
329
+ provider,
330
+ model,
331
+ thinkLevel: params.followupRun.run.thinkLevel,
332
+ timeoutMs: params.followupRun.run.timeoutMs,
333
+ runId,
334
+ extraSystemPrompt: params.followupRun.run.extraSystemPrompt,
335
+ ownerNumbers: params.followupRun.run.ownerNumbers,
336
+ cliSessionId: cliSessionBinding?.sessionId,
337
+ cliSessionBinding,
338
+ authProfileId,
339
+ bootstrapPromptWarningSignaturesSeen,
340
+ bootstrapPromptWarningSignature: bootstrapPromptWarningSignaturesSeen[bootstrapPromptWarningSignaturesSeen.length - 1],
341
+ images: params.opts?.images,
342
+ imageOrder: params.opts?.imageOrder
343
+ });
344
+ bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(result.meta?.systemPromptReport);
345
+ const cliText = result.payloads?.[0]?.text?.trim();
346
+ if (cliText) emitAgentEvent({
347
+ runId,
348
+ stream: "assistant",
349
+ data: { text: cliText }
350
+ });
351
+ emitAgentEvent({
352
+ runId,
353
+ stream: "lifecycle",
354
+ data: {
355
+ phase: "end",
356
+ startedAt,
357
+ endedAt: Date.now()
358
+ }
359
+ });
360
+ lifecycleTerminalEmitted = true;
361
+ return result;
362
+ } catch (err) {
363
+ emitAgentEvent({
364
+ runId,
365
+ stream: "lifecycle",
366
+ data: {
367
+ phase: "error",
368
+ startedAt,
369
+ endedAt: Date.now(),
370
+ error: String(err)
371
+ }
372
+ });
373
+ lifecycleTerminalEmitted = true;
374
+ throw err;
375
+ } finally {
376
+ if (!lifecycleTerminalEmitted) emitAgentEvent({
377
+ runId,
378
+ stream: "lifecycle",
379
+ data: {
380
+ phase: "error",
381
+ startedAt,
382
+ endedAt: Date.now(),
383
+ error: "CLI run completed without lifecycle terminal event"
384
+ }
385
+ });
386
+ }
387
+ })();
388
+ }
389
+ const { embeddedContext, senderContext, runBaseParams } = buildEmbeddedRunExecutionParams({
390
+ run: params.followupRun.run,
391
+ sessionCtx: params.sessionCtx,
392
+ hasRepliedRef: params.opts?.hasRepliedRef,
393
+ provider,
394
+ runId,
395
+ allowTransientCooldownProbe: runOptions?.allowTransientCooldownProbe,
396
+ model
397
+ });
398
+ return (async () => {
399
+ let attemptCompactionCount = 0;
400
+ try {
401
+ const result = await runEmbeddedVoraAgent({
402
+ ...embeddedContext,
403
+ allowGatewaySubagentBinding: true,
404
+ trigger: params.isHeartbeat ? "heartbeat" : "user",
405
+ groupId: resolveGroupSessionKey(params.sessionCtx)?.id,
406
+ groupChannel: params.sessionCtx.GroupChannel?.trim() ?? params.sessionCtx.GroupSubject?.trim(),
407
+ groupSpace: params.sessionCtx.GroupSpace?.trim() ?? void 0,
408
+ ...senderContext,
409
+ ...runBaseParams,
410
+ prompt: params.commandBody,
411
+ extraSystemPrompt: params.followupRun.run.extraSystemPrompt,
412
+ toolResultFormat: (() => {
413
+ const channel = resolveMessageChannel(params.sessionCtx.Surface, params.sessionCtx.Provider);
414
+ if (!channel) return "markdown";
415
+ return isMarkdownCapableMessageChannel(channel) ? "markdown" : "plain";
416
+ })(),
417
+ suppressToolErrorWarnings: params.opts?.suppressToolErrorWarnings,
418
+ bootstrapContextMode: params.opts?.bootstrapContextMode,
419
+ bootstrapContextRunKind: params.opts?.isHeartbeat ? "heartbeat" : "default",
420
+ images: params.opts?.images,
421
+ imageOrder: params.opts?.imageOrder,
422
+ abortSignal: params.opts?.abortSignal,
423
+ blockReplyBreak: params.resolvedBlockStreamingBreak,
424
+ blockReplyChunking: params.blockReplyChunking,
425
+ onPartialReply: async (payload) => {
426
+ const textForTyping = await handlePartialForTyping(payload);
427
+ if (!params.opts?.onPartialReply || textForTyping === void 0) return;
428
+ await params.opts.onPartialReply({
429
+ text: textForTyping,
430
+ mediaUrls: payload.mediaUrls
431
+ });
432
+ },
433
+ onAssistantMessageStart: async () => {
434
+ await params.typingSignals.signalMessageStart();
435
+ await params.opts?.onAssistantMessageStart?.();
436
+ },
437
+ onReasoningStream: params.typingSignals.shouldStartOnReasoning || params.opts?.onReasoningStream ? async (payload) => {
438
+ if (params.followupRun.run.silentExpected) return;
439
+ await params.typingSignals.signalReasoningDelta();
440
+ await params.opts?.onReasoningStream?.({
441
+ text: payload.text,
442
+ mediaUrls: payload.mediaUrls
443
+ });
444
+ } : void 0,
445
+ onReasoningEnd: params.opts?.onReasoningEnd,
446
+ onAgentEvent: async (evt) => {
447
+ const hasLifecyclePhase = evt.stream === "lifecycle" && typeof evt.data.phase === "string";
448
+ if (evt.stream !== "lifecycle" || hasLifecyclePhase) notifyAgentRunStart();
449
+ if (evt.stream === "tool") {
450
+ const phase = typeof evt.data.phase === "string" ? evt.data.phase : "";
451
+ const name = typeof evt.data.name === "string" ? evt.data.name : void 0;
452
+ if (phase === "start" || phase === "update") {
453
+ await params.typingSignals.signalToolStart();
454
+ await params.opts?.onToolStart?.({
455
+ name,
456
+ phase
457
+ });
458
+ }
459
+ }
460
+ if (evt.stream === "compaction") {
461
+ const phase = typeof evt.data.phase === "string" ? evt.data.phase : "";
462
+ if (phase === "start") {
463
+ if (params.opts?.onCompactionStart) await params.opts.onCompactionStart();
464
+ else if (params.opts?.onBlockReply) {
465
+ const currentMessageId = params.sessionCtx.MessageSidFull ?? params.sessionCtx.MessageSid;
466
+ const noticePayload = params.applyReplyToMode({
467
+ text: "🧹 Compacting context...",
468
+ replyToId: currentMessageId,
469
+ replyToCurrent: true,
470
+ isCompactionNotice: true
471
+ });
472
+ try {
473
+ await params.opts.onBlockReply(noticePayload);
474
+ } catch (err) {
475
+ logVerbose(`compaction start notice delivery failed (non-fatal): ${String(err)}`);
476
+ }
477
+ }
478
+ }
479
+ const completed = evt.data?.completed === true;
480
+ if (phase === "end" && completed) {
481
+ attemptCompactionCount += 1;
482
+ await params.opts?.onCompactionEnd?.();
483
+ }
484
+ }
485
+ },
486
+ onBlockReply: blockReplyHandler,
487
+ onBlockReplyFlush: params.blockStreamingEnabled && blockReplyPipeline ? async () => {
488
+ await blockReplyPipeline.flush({ force: true });
489
+ } : void 0,
490
+ shouldEmitToolResult: params.shouldEmitToolResult,
491
+ shouldEmitToolOutput: params.shouldEmitToolOutput,
492
+ bootstrapPromptWarningSignaturesSeen,
493
+ bootstrapPromptWarningSignature: bootstrapPromptWarningSignaturesSeen[bootstrapPromptWarningSignaturesSeen.length - 1],
494
+ onToolResult: onToolResult ? (() => {
495
+ let toolResultChain = Promise.resolve();
496
+ return (payload) => {
497
+ toolResultChain = toolResultChain.then(async () => {
498
+ const { text, skip } = normalizeStreamingText(payload);
499
+ if (skip) return;
500
+ if (text !== void 0) await params.typingSignals.signalTextDelta(text);
501
+ await onToolResult({
502
+ ...payload,
503
+ text
504
+ });
505
+ }).catch((err) => {
506
+ logVerbose(`tool result delivery failed: ${String(err)}`);
507
+ });
508
+ const task = toolResultChain.finally(() => {
509
+ params.pendingToolTasks.delete(task);
510
+ });
511
+ params.pendingToolTasks.add(task);
512
+ };
513
+ })() : void 0
514
+ });
515
+ bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(result.meta?.systemPromptReport);
516
+ const resultCompactionCount = Math.max(0, result.meta?.agentMeta?.compactionCount ?? 0);
517
+ attemptCompactionCount = Math.max(attemptCompactionCount, resultCompactionCount);
518
+ return result;
519
+ } finally {
520
+ autoCompactionCount += attemptCompactionCount;
521
+ }
522
+ })();
523
+ }
524
+ });
525
+ runResult = fallbackResult.result;
526
+ fallbackProvider = fallbackResult.provider;
527
+ fallbackModel = fallbackResult.model;
528
+ fallbackAttempts = Array.isArray(fallbackResult.attempts) ? fallbackResult.attempts.map((attempt) => ({
529
+ provider: String(attempt.provider ?? ""),
530
+ model: String(attempt.model ?? ""),
531
+ error: String(attempt.error ?? ""),
532
+ reason: attempt.reason ? String(attempt.reason) : void 0,
533
+ status: typeof attempt.status === "number" ? attempt.status : void 0,
534
+ code: attempt.code ? String(attempt.code) : void 0
535
+ })) : [];
536
+ const embeddedError = runResult.meta?.error;
537
+ if (embeddedError && isContextOverflowError(embeddedError.message) && !didResetAfterCompactionFailure && await params.resetSessionAfterCompactionFailure(embeddedError.message)) {
538
+ didResetAfterCompactionFailure = true;
539
+ return {
540
+ kind: "final",
541
+ payload: { text: "⚠️ Context limit exceeded. I've reset our conversation to start fresh - please try again.\n\nTo prevent this, increase your compaction buffer by setting `agents.defaults.compaction.reserveTokensFloor` to 20000 or higher in your config." }
542
+ };
543
+ }
544
+ if (embeddedError?.kind === "role_ordering") {
545
+ if (await params.resetSessionAfterRoleOrderingConflict(embeddedError.message)) return {
546
+ kind: "final",
547
+ payload: { text: "⚠️ Message ordering conflict. I've reset the conversation - please try again." }
548
+ };
549
+ }
550
+ break;
551
+ } catch (err) {
552
+ if (err instanceof LiveSessionModelSwitchError) {
553
+ liveModelSwitchRetries += 1;
554
+ if (liveModelSwitchRetries > 2) {
555
+ defaultRuntime.error(`Live model switch failed after 2 retries (${sanitizeForLog(err.provider)}/${sanitizeForLog(err.model)}). The requested model may be unavailable.`);
556
+ return {
557
+ kind: "final",
558
+ payload: { text: shouldSurfaceToControlUi ? "⚠️ Agent failed before reply: model switch could not be completed. The requested model may be temporarily unavailable.\nLogs: vora logs --follow" : "⚠️ Agent failed before reply: model switch could not be completed. The requested model may be temporarily unavailable. Please try again shortly." }
559
+ };
560
+ }
561
+ params.followupRun.run.provider = err.provider;
562
+ params.followupRun.run.model = err.model;
563
+ params.followupRun.run.authProfileId = err.authProfileId;
564
+ params.followupRun.run.authProfileIdSource = err.authProfileId ? err.authProfileIdSource : void 0;
565
+ fallbackProvider = err.provider;
566
+ fallbackModel = err.model;
567
+ continue;
568
+ }
569
+ const message = err instanceof Error ? err.message : String(err);
570
+ const isBilling = isBillingErrorMessage(message);
571
+ const isContextOverflow = !isBilling && isLikelyContextOverflowError(message);
572
+ const isCompactionFailure = !isBilling && isCompactionFailureError(message);
573
+ const isSessionCorruption = /function call turn comes immediately after/i.test(message);
574
+ const isRoleOrderingError = /incorrect role information|roles must alternate/i.test(message);
575
+ const isTransientHttp = isTransientHttpError(message);
576
+ if (isCompactionFailure && !didResetAfterCompactionFailure && await params.resetSessionAfterCompactionFailure(message)) {
577
+ didResetAfterCompactionFailure = true;
578
+ return {
579
+ kind: "final",
580
+ payload: { text: "⚠️ Context limit exceeded during compaction. I've reset our conversation to start fresh - please try again.\n\nTo prevent this, increase your compaction buffer by setting `agents.defaults.compaction.reserveTokensFloor` to 20000 or higher in your config." }
581
+ };
582
+ }
583
+ if (isRoleOrderingError) {
584
+ if (await params.resetSessionAfterRoleOrderingConflict(message)) return {
585
+ kind: "final",
586
+ payload: { text: "⚠️ Message ordering conflict. I've reset the conversation - please try again." }
587
+ };
588
+ }
589
+ if (isSessionCorruption && params.sessionKey && params.activeSessionStore && params.storePath) {
590
+ const sessionKey = params.sessionKey;
591
+ const corruptedSessionId = params.getActiveSessionEntry()?.sessionId;
592
+ defaultRuntime.error(`Session history corrupted (Gemini function call ordering). Resetting session: ${params.sessionKey}`);
593
+ try {
594
+ if (corruptedSessionId) {
595
+ const transcriptPath = resolveSessionTranscriptPath(corruptedSessionId);
596
+ try {
597
+ fsSync.unlinkSync(transcriptPath);
598
+ } catch {}
599
+ }
600
+ delete params.activeSessionStore[sessionKey];
601
+ await updateSessionStore(params.storePath, (store) => {
602
+ delete store[sessionKey];
603
+ });
604
+ } catch (cleanupErr) {
605
+ defaultRuntime.error(`Failed to reset corrupted session ${params.sessionKey}: ${String(cleanupErr)}`);
606
+ }
607
+ return {
608
+ kind: "final",
609
+ payload: { text: "⚠️ Session history was corrupted. I've reset the conversation - please try again!" }
610
+ };
611
+ }
612
+ if (isTransientHttp && !didRetryTransientHttpError) {
613
+ didRetryTransientHttpError = true;
614
+ defaultRuntime.error(`Transient HTTP provider error before reply (${message}). Retrying once in ${TRANSIENT_HTTP_RETRY_DELAY_MS}ms.`);
615
+ await new Promise((resolve) => {
616
+ setTimeout(resolve, TRANSIENT_HTTP_RETRY_DELAY_MS);
617
+ });
618
+ continue;
619
+ }
620
+ defaultRuntime.error(`Embedded agent failed before reply: ${message}`);
621
+ const isRateLimit = isFallbackSummaryError(err) ? isPureTransientRateLimitSummary(err) : isRateLimitErrorMessage(message);
622
+ const trimmedMessage = (isTransientHttp ? sanitizeUserFacingText(message, { errorContext: true }) : message).replace(/\.\s*$/, "");
623
+ return {
624
+ kind: "final",
625
+ payload: { text: isBilling ? BILLING_ERROR_USER_MESSAGE : isRateLimit ? buildRateLimitCooldownMessage(err) : isContextOverflow ? "⚠️ Context overflow — prompt too large for this model. Try a shorter message or a larger-context model." : isRoleOrderingError ? "⚠️ Message ordering conflict - please try again. If this persists, use /new to start a fresh session." : `⚠️ Agent failed before reply: ${trimmedMessage}.\nLogs: vora logs --follow` }
626
+ };
627
+ }
628
+ const finalEmbeddedError = runResult?.meta?.error;
629
+ const hasPayloadText = runResult?.payloads?.some((p) => p.text?.trim());
630
+ if (finalEmbeddedError && !hasPayloadText) {
631
+ if (isContextOverflowError(finalEmbeddedError.message ?? "")) return {
632
+ kind: "final",
633
+ payload: { text: "⚠️ Context overflow — this conversation is too large for the model. Use /new to start a fresh session." }
634
+ };
635
+ }
636
+ if (runResult) {
637
+ if (!runResult.payloads?.some((p) => !p.isError && !p.isReasoning && hasOutboundReplyContent(p, { trimText: true }))) {
638
+ const metaErrorMsg = finalEmbeddedError?.message ?? "";
639
+ const rawErrorPayloadText = runResult.payloads?.find((p) => p.isError && p.text?.trim() && !p.text.startsWith("⚠️"))?.text ?? "";
640
+ const errorCandidate = metaErrorMsg || rawErrorPayloadText;
641
+ if (errorCandidate && (isRateLimitErrorMessage(errorCandidate) || isOverloadedErrorMessage(errorCandidate))) {
642
+ const isOverloaded = isOverloadedErrorMessage(errorCandidate);
643
+ runResult.payloads = [{
644
+ text: isOverloaded ? "⚠️ The AI service is temporarily overloaded. Please try again in a moment." : "⚠️ API rate limit reached — the model couldn't generate a response. Please try again in a moment.",
645
+ isError: true
646
+ }];
647
+ }
648
+ }
649
+ }
650
+ return {
651
+ kind: "success",
652
+ runId,
653
+ runResult,
654
+ fallbackProvider,
655
+ fallbackModel,
656
+ fallbackAttempts,
657
+ didLogHeartbeatStrip,
658
+ autoCompactionCount,
659
+ directlySentBlockKeys: directlySentBlockKeys.size > 0 ? directlySentBlockKeys : void 0
660
+ };
661
+ }
662
+ //#endregion
663
+ //#region src/auto-reply/reply/agent-runner-helpers.ts
664
+ const hasAudioMedia = (urls) => Boolean(urls?.some((url) => isAudioFileName(url)));
665
+ const isAudioPayload = (payload) => hasAudioMedia(resolveSendableOutboundReplyParts(payload).mediaUrls);
666
+ function resolveCurrentVerboseLevel(params) {
667
+ if (!params.sessionKey || !params.storePath) return;
668
+ try {
669
+ const entry = loadSessionStore(params.storePath)[params.sessionKey];
670
+ return normalizeVerboseLevel(String(entry?.verboseLevel ?? ""));
671
+ } catch {
672
+ return;
673
+ }
674
+ }
675
+ function createVerboseGate(params, shouldEmit) {
676
+ const fallbackVerbose = normalizeVerboseLevel(String(params.resolvedVerboseLevel ?? "")) ?? "off";
677
+ return () => {
678
+ return shouldEmit(resolveCurrentVerboseLevel(params) ?? fallbackVerbose);
679
+ };
680
+ }
681
+ const createShouldEmitToolResult = (params) => {
682
+ return createVerboseGate(params, (level) => level !== "off");
683
+ };
684
+ const createShouldEmitToolOutput = (params) => {
685
+ return createVerboseGate(params, (level) => level === "full");
686
+ };
687
+ const finalizeWithFollowup = (value, queueKey, runFollowupTurn) => {
688
+ scheduleFollowupDrain(queueKey, runFollowupTurn);
689
+ return value;
690
+ };
691
+ const signalTypingIfNeeded = async (payloads, typingSignals) => {
692
+ if (payloads.some((payload) => hasOutboundReplyContent(payload, { trimText: true }))) await typingSignals.signalRunStart();
693
+ };
694
+ //#endregion
695
+ //#region src/auto-reply/reply/memory-flush.ts
696
+ function resolveMemoryFlushContextWindowTokens(params) {
697
+ return lookupContextTokens(params.modelId, { allowAsyncLoad: false }) ?? params.agentCfgContextTokens ?? 2e5;
698
+ }
699
+ function resolvePositiveTokenCount(value) {
700
+ return typeof value === "number" && Number.isFinite(value) && value > 0 ? Math.floor(value) : void 0;
701
+ }
702
+ function resolveMemoryFlushGateState(params) {
703
+ if (!params.entry) return null;
704
+ const totalTokens = resolvePositiveTokenCount(params.tokenCount) ?? resolveFreshSessionTotalTokens(params.entry);
705
+ if (!totalTokens || totalTokens <= 0) return null;
706
+ const contextWindow = Math.max(1, Math.floor(params.contextWindowTokens));
707
+ const reserveTokens = Math.max(0, Math.floor(params.reserveTokensFloor));
708
+ const softThreshold = Math.max(0, Math.floor(params.softThresholdTokens));
709
+ const threshold = Math.max(0, contextWindow - reserveTokens - softThreshold);
710
+ if (threshold <= 0) return null;
711
+ return {
712
+ entry: params.entry,
713
+ totalTokens,
714
+ threshold
715
+ };
716
+ }
717
+ function shouldRunMemoryFlush(params) {
718
+ const state = resolveMemoryFlushGateState(params);
719
+ if (!state || state.totalTokens < state.threshold) return false;
720
+ if (hasAlreadyFlushedForCurrentCompaction(state.entry)) return false;
721
+ return true;
722
+ }
723
+ function shouldRunPreflightCompaction(params) {
724
+ const state = resolveMemoryFlushGateState(params);
725
+ return Boolean(state && state.totalTokens >= state.threshold);
726
+ }
727
+ /**
728
+ * Returns true when a memory flush has already been performed for the current
729
+ * compaction cycle. This prevents repeated flush runs within the same cycle —
730
+ * important for both the token-based and transcript-size–based trigger paths.
731
+ */
732
+ function hasAlreadyFlushedForCurrentCompaction(entry) {
733
+ const compactionCount = entry.compactionCount ?? 0;
734
+ const lastFlushAt = entry.memoryFlushCompactionCount;
735
+ return typeof lastFlushAt === "number" && lastFlushAt === compactionCount;
736
+ }
737
+ //#endregion
738
+ //#region src/auto-reply/reply/agent-runner-memory.ts
739
+ function estimatePromptTokensForMemoryFlush(prompt) {
740
+ const trimmed = prompt?.trim();
741
+ if (!trimmed) return;
742
+ const tokens = estimateMessagesTokens([{
743
+ role: "user",
744
+ content: trimmed,
745
+ timestamp: Date.now()
746
+ }]);
747
+ if (!Number.isFinite(tokens) || tokens <= 0) return;
748
+ return Math.ceil(tokens);
749
+ }
750
+ function resolveEffectivePromptTokens(basePromptTokens, lastOutputTokens, promptTokenEstimate) {
751
+ const base = Math.max(0, basePromptTokens ?? 0);
752
+ const output = Math.max(0, lastOutputTokens ?? 0);
753
+ const estimate = Math.max(0, promptTokenEstimate ?? 0);
754
+ return base + output + estimate;
755
+ }
756
+ const TRANSCRIPT_OUTPUT_READ_BUFFER_TOKENS = 8192;
757
+ const TRANSCRIPT_TAIL_CHUNK_BYTES = 64 * 1024;
758
+ function parseUsageFromTranscriptLine(line) {
759
+ const trimmed = line.trim();
760
+ if (!trimmed) return;
761
+ try {
762
+ const parsed = JSON.parse(trimmed);
763
+ const usage = normalizeUsage(parsed.message?.usage ?? parsed.usage);
764
+ if (usage && hasNonzeroUsage(usage)) return usage;
765
+ } catch {}
766
+ }
767
+ function resolveSessionLogPath(sessionId, sessionEntry, sessionKey, opts) {
768
+ if (!sessionId) return;
769
+ try {
770
+ const transcriptPath = sessionEntry?.transcriptPath?.trim();
771
+ const sessionFile = sessionEntry?.sessionFile?.trim() || transcriptPath;
772
+ const pathOpts = resolveSessionFilePathOptions({
773
+ agentId: resolveAgentIdFromSessionKey(sessionKey),
774
+ storePath: opts?.storePath
775
+ });
776
+ return resolveSessionFilePath(sessionId, sessionFile ? { sessionFile } : sessionEntry, pathOpts);
777
+ } catch {
778
+ return;
779
+ }
780
+ }
781
+ function deriveTranscriptUsageSnapshot(usage) {
782
+ if (!usage) return;
783
+ const promptTokens = derivePromptTokens(usage);
784
+ const outputRaw = usage.output;
785
+ const outputTokens = typeof outputRaw === "number" && Number.isFinite(outputRaw) && outputRaw > 0 ? outputRaw : void 0;
786
+ if (!(typeof promptTokens === "number") && !(typeof outputTokens === "number")) return;
787
+ return {
788
+ promptTokens,
789
+ outputTokens
790
+ };
791
+ }
792
+ async function appendPostCompactionRefreshPrompt(params) {
793
+ const refreshPrompt = await readPostCompactionContext(params.followupRun.run.workspaceDir, params.cfg);
794
+ if (!refreshPrompt) return;
795
+ const existingPrompt = params.followupRun.run.extraSystemPrompt?.trim();
796
+ if (existingPrompt?.includes(refreshPrompt)) return;
797
+ params.followupRun.run.extraSystemPrompt = [existingPrompt, refreshPrompt].filter(Boolean).join("\n\n");
798
+ }
799
+ async function readSessionLogSnapshot(params) {
800
+ const logPath = resolveSessionLogPath(params.sessionId, params.sessionEntry, params.sessionKey, params.opts);
801
+ if (!logPath) return {};
802
+ const snapshot = {};
803
+ if (params.includeByteSize) try {
804
+ const stat = await fsSync.promises.stat(logPath);
805
+ const size = Math.floor(stat.size);
806
+ snapshot.byteSize = Number.isFinite(size) && size >= 0 ? size : void 0;
807
+ } catch {
808
+ snapshot.byteSize = void 0;
809
+ }
810
+ if (params.includeUsage) try {
811
+ snapshot.usage = deriveTranscriptUsageSnapshot(await readLastNonzeroUsageFromSessionLog(logPath));
812
+ } catch {
813
+ snapshot.usage = void 0;
814
+ }
815
+ return snapshot;
816
+ }
817
+ async function readLastNonzeroUsageFromSessionLog(logPath) {
818
+ const handle = await fsSync.promises.open(logPath, "r");
819
+ try {
820
+ let position = (await handle.stat()).size;
821
+ let leadingPartial = "";
822
+ while (position > 0) {
823
+ const chunkSize = Math.min(TRANSCRIPT_TAIL_CHUNK_BYTES, position);
824
+ const start = position - chunkSize;
825
+ const buffer = Buffer.allocUnsafe(chunkSize);
826
+ const { bytesRead } = await handle.read(buffer, 0, chunkSize, start);
827
+ if (bytesRead <= 0) break;
828
+ const lines = `${buffer.toString("utf-8", 0, bytesRead)}${leadingPartial}`.split(/\n+/);
829
+ leadingPartial = lines.shift() ?? "";
830
+ for (let i = lines.length - 1; i >= 0; i -= 1) {
831
+ const usage = parseUsageFromTranscriptLine(lines[i] ?? "");
832
+ if (usage) return usage;
833
+ }
834
+ position = start;
835
+ }
836
+ return parseUsageFromTranscriptLine(leadingPartial);
837
+ } finally {
838
+ await handle.close();
839
+ }
840
+ }
841
+ function estimatePromptTokensFromSessionTranscript(params) {
842
+ const sessionId = params.sessionId?.trim();
843
+ if (!sessionId) return;
844
+ try {
845
+ const messages = readSessionMessages(sessionId, params.storePath, params.sessionFile);
846
+ if (messages.length === 0) return;
847
+ const estimatedTokens = estimateMessagesTokens(messages);
848
+ if (!Number.isFinite(estimatedTokens) || estimatedTokens <= 0) return;
849
+ return Math.ceil(estimatedTokens);
850
+ } catch {
851
+ return;
852
+ }
853
+ }
854
+ async function runPreflightCompactionIfNeeded(params) {
855
+ if (!params.sessionKey) return params.sessionEntry;
856
+ let entry = params.sessionEntry ?? (params.sessionKey ? params.sessionStore?.[params.sessionKey] : void 0);
857
+ if (!entry?.sessionId) return entry ?? params.sessionEntry;
858
+ const isCli = isCliProvider(params.followupRun.run.provider, params.cfg);
859
+ if (params.isHeartbeat || isCli) return entry ?? params.sessionEntry;
860
+ const contextWindowTokens = resolveMemoryFlushContextWindowTokens({
861
+ modelId: params.followupRun.run.model ?? params.defaultModel,
862
+ agentCfgContextTokens: params.agentCfgContextTokens
863
+ });
864
+ const memoryFlushPlan = resolveMemoryFlushPlan({ cfg: params.cfg });
865
+ const reserveTokensFloor = memoryFlushPlan?.reserveTokensFloor ?? params.cfg.agents?.defaults?.compaction?.reserveTokensFloor ?? 2e4;
866
+ const softThresholdTokens = memoryFlushPlan?.softThresholdTokens ?? 4e3;
867
+ const freshPersistedTokens = resolveFreshSessionTotalTokens(entry);
868
+ const persistedTotalTokens = entry.totalTokens;
869
+ const hasPersistedTotalTokens = typeof persistedTotalTokens === "number" && Number.isFinite(persistedTotalTokens) && persistedTotalTokens > 0;
870
+ if (!(entry.totalTokensFresh === false || !hasPersistedTotalTokens)) return entry ?? params.sessionEntry;
871
+ const promptTokenEstimate = estimatePromptTokensForMemoryFlush(params.promptForEstimate ?? params.followupRun.prompt);
872
+ const transcriptPromptTokens = typeof freshPersistedTokens === "number" ? void 0 : estimatePromptTokensFromSessionTranscript({
873
+ sessionId: entry.sessionId,
874
+ storePath: params.storePath,
875
+ sessionFile: entry.sessionFile ?? params.followupRun.run.sessionFile
876
+ });
877
+ const projectedTokenCount = typeof transcriptPromptTokens === "number" ? resolveEffectivePromptTokens(transcriptPromptTokens, void 0, promptTokenEstimate) : void 0;
878
+ const tokenCountForCompaction = typeof projectedTokenCount === "number" && Number.isFinite(projectedTokenCount) && projectedTokenCount > 0 ? projectedTokenCount : void 0;
879
+ const threshold = contextWindowTokens - reserveTokensFloor - softThresholdTokens;
880
+ logVerbose(`preflightCompaction check: sessionKey=${params.sessionKey} tokenCount=${tokenCountForCompaction ?? freshPersistedTokens ?? "undefined"} contextWindow=${contextWindowTokens} threshold=${threshold} isHeartbeat=${params.isHeartbeat} isCli=${isCli} persistedFresh=${entry?.totalTokensFresh === true} transcriptPromptTokens=${transcriptPromptTokens ?? "undefined"} promptTokensEst=${promptTokenEstimate ?? "undefined"}`);
881
+ if (!shouldRunPreflightCompaction({
882
+ entry,
883
+ tokenCount: tokenCountForCompaction,
884
+ contextWindowTokens,
885
+ reserveTokensFloor,
886
+ softThresholdTokens
887
+ })) return entry ?? params.sessionEntry;
888
+ logVerbose(`preflightCompaction triggered: sessionKey=${params.sessionKey} tokenCount=${tokenCountForCompaction ?? freshPersistedTokens ?? "undefined"} threshold=${threshold}`);
889
+ const sessionFile = resolveSessionLogPath(entry.sessionId, entry.sessionFile ? entry : {
890
+ ...entry,
891
+ sessionFile: params.followupRun.run.sessionFile
892
+ }, params.sessionKey ?? params.followupRun.run.sessionKey, { storePath: params.storePath });
893
+ const result = await compactEmbeddedPiSession({
894
+ sessionId: entry.sessionId,
895
+ sessionKey: params.sessionKey,
896
+ allowGatewaySubagentBinding: true,
897
+ messageChannel: params.followupRun.run.messageProvider,
898
+ groupId: entry.groupId ?? params.followupRun.run.groupId,
899
+ groupChannel: entry.groupChannel ?? params.followupRun.run.groupChannel,
900
+ groupSpace: entry.space ?? params.followupRun.run.groupSpace,
901
+ sessionFile: sessionFile ?? params.followupRun.run.sessionFile,
902
+ workspaceDir: params.followupRun.run.workspaceDir,
903
+ agentDir: params.followupRun.run.agentDir,
904
+ config: params.cfg,
905
+ skillsSnapshot: entry.skillsSnapshot ?? params.followupRun.run.skillsSnapshot,
906
+ provider: params.followupRun.run.provider,
907
+ model: params.followupRun.run.model,
908
+ thinkLevel: params.followupRun.run.thinkLevel,
909
+ bashElevated: params.followupRun.run.bashElevated,
910
+ trigger: "budget",
911
+ currentTokenCount: tokenCountForCompaction,
912
+ senderIsOwner: params.followupRun.run.senderIsOwner,
913
+ ownerNumbers: params.followupRun.run.ownerNumbers
914
+ });
915
+ if (!result?.ok || !result.compacted) {
916
+ logVerbose(`preflightCompaction skipped: sessionKey=${params.sessionKey} reason=${result?.reason ?? "not_compacted"}`);
917
+ return entry ?? params.sessionEntry;
918
+ }
919
+ await incrementCompactionCount({
920
+ sessionEntry: entry,
921
+ sessionStore: params.sessionStore,
922
+ sessionKey: params.sessionKey,
923
+ storePath: params.storePath,
924
+ tokensAfter: result.result?.tokensAfter
925
+ });
926
+ await appendPostCompactionRefreshPrompt({
927
+ cfg: params.cfg,
928
+ followupRun: params.followupRun
929
+ });
930
+ entry = params.sessionStore?.[params.sessionKey] ?? entry;
931
+ return entry ?? params.sessionEntry;
932
+ }
933
+ async function runMemoryFlushIfNeeded(params) {
934
+ const memoryFlushPlan = resolveMemoryFlushPlan({ cfg: params.cfg });
935
+ if (!memoryFlushPlan) return params.sessionEntry;
936
+ const memoryFlushWritable = (() => {
937
+ if (!params.sessionKey) return true;
938
+ const runtime = resolveSandboxRuntimeStatus({
939
+ cfg: params.cfg,
940
+ sessionKey: params.sessionKey
941
+ });
942
+ if (!runtime.sandboxed) return true;
943
+ return resolveSandboxConfigForAgent(params.cfg, runtime.agentId).workspaceAccess === "rw";
944
+ })();
945
+ const isCli = isCliProvider(params.followupRun.run.provider, params.cfg);
946
+ const canAttemptFlush = memoryFlushWritable && !params.isHeartbeat && !isCli;
947
+ let entry = params.sessionEntry ?? (params.sessionKey ? params.sessionStore?.[params.sessionKey] : void 0);
948
+ const contextWindowTokens = resolveMemoryFlushContextWindowTokens({
949
+ modelId: params.followupRun.run.model ?? params.defaultModel,
950
+ agentCfgContextTokens: params.agentCfgContextTokens
951
+ });
952
+ const promptTokenEstimate = estimatePromptTokensForMemoryFlush(params.promptForEstimate ?? params.followupRun.prompt);
953
+ const persistedPromptTokensRaw = entry?.totalTokens;
954
+ const persistedPromptTokens = typeof persistedPromptTokensRaw === "number" && Number.isFinite(persistedPromptTokensRaw) && persistedPromptTokensRaw > 0 ? persistedPromptTokensRaw : void 0;
955
+ const hasFreshPersistedPromptTokens = typeof persistedPromptTokens === "number" && entry?.totalTokensFresh === true;
956
+ const flushThreshold = contextWindowTokens - memoryFlushPlan.reserveTokensFloor - memoryFlushPlan.softThresholdTokens;
957
+ const shouldReadTranscriptForOutput = canAttemptFlush && entry && hasFreshPersistedPromptTokens && typeof promptTokenEstimate === "number" && Number.isFinite(promptTokenEstimate) && flushThreshold > 0 && (persistedPromptTokens ?? 0) + promptTokenEstimate >= flushThreshold - TRANSCRIPT_OUTPUT_READ_BUFFER_TOKENS;
958
+ const shouldReadTranscript = Boolean(canAttemptFlush && entry && (!hasFreshPersistedPromptTokens || shouldReadTranscriptForOutput));
959
+ const forceFlushTranscriptBytes = memoryFlushPlan.forceFlushTranscriptBytes;
960
+ const shouldCheckTranscriptSizeForForcedFlush = Boolean(canAttemptFlush && entry && Number.isFinite(forceFlushTranscriptBytes) && forceFlushTranscriptBytes > 0);
961
+ const sessionLogSnapshot = shouldReadTranscript || shouldCheckTranscriptSizeForForcedFlush ? await readSessionLogSnapshot({
962
+ sessionId: params.followupRun.run.sessionId,
963
+ sessionEntry: entry,
964
+ sessionKey: params.sessionKey ?? params.followupRun.run.sessionKey,
965
+ opts: { storePath: params.storePath },
966
+ includeByteSize: shouldCheckTranscriptSizeForForcedFlush,
967
+ includeUsage: shouldReadTranscript
968
+ }) : void 0;
969
+ const transcriptByteSize = sessionLogSnapshot?.byteSize;
970
+ const shouldForceFlushByTranscriptSize = typeof transcriptByteSize === "number" && transcriptByteSize >= forceFlushTranscriptBytes;
971
+ const transcriptUsageSnapshot = sessionLogSnapshot?.usage;
972
+ const transcriptPromptTokens = transcriptUsageSnapshot?.promptTokens;
973
+ const transcriptOutputTokens = transcriptUsageSnapshot?.outputTokens;
974
+ const hasReliableTranscriptPromptTokens = typeof transcriptPromptTokens === "number" && Number.isFinite(transcriptPromptTokens) && transcriptPromptTokens > 0;
975
+ if (entry && hasReliableTranscriptPromptTokens && (!hasFreshPersistedPromptTokens || (transcriptPromptTokens ?? 0) > (persistedPromptTokens ?? 0))) {
976
+ const nextEntry = {
977
+ ...entry,
978
+ totalTokens: transcriptPromptTokens,
979
+ totalTokensFresh: true
980
+ };
981
+ entry = nextEntry;
982
+ if (params.sessionKey && params.sessionStore) params.sessionStore[params.sessionKey] = nextEntry;
983
+ if (params.storePath && params.sessionKey) try {
984
+ const updatedEntry = await updateSessionStoreEntry({
985
+ storePath: params.storePath,
986
+ sessionKey: params.sessionKey,
987
+ update: async () => ({
988
+ totalTokens: transcriptPromptTokens,
989
+ totalTokensFresh: true
990
+ })
991
+ });
992
+ if (updatedEntry) {
993
+ entry = updatedEntry;
994
+ if (params.sessionStore) params.sessionStore[params.sessionKey] = updatedEntry;
995
+ }
996
+ } catch (err) {
997
+ logVerbose(`failed to persist derived prompt totalTokens: ${String(err)}`);
998
+ }
999
+ }
1000
+ const promptTokensSnapshot = Math.max(hasFreshPersistedPromptTokens ? persistedPromptTokens ?? 0 : 0, hasReliableTranscriptPromptTokens ? transcriptPromptTokens ?? 0 : 0);
1001
+ const projectedTokenCount = promptTokensSnapshot > 0 && (hasFreshPersistedPromptTokens || hasReliableTranscriptPromptTokens) ? resolveEffectivePromptTokens(promptTokensSnapshot, transcriptOutputTokens, promptTokenEstimate) : void 0;
1002
+ const tokenCountForFlush = typeof projectedTokenCount === "number" && Number.isFinite(projectedTokenCount) && projectedTokenCount > 0 ? projectedTokenCount : void 0;
1003
+ logVerbose(`memoryFlush check: sessionKey=${params.sessionKey} tokenCount=${tokenCountForFlush ?? "undefined"} contextWindow=${contextWindowTokens} threshold=${flushThreshold} isHeartbeat=${params.isHeartbeat} isCli=${isCli} memoryFlushWritable=${memoryFlushWritable} compactionCount=${entry?.compactionCount ?? 0} memoryFlushCompactionCount=${entry?.memoryFlushCompactionCount ?? "undefined"} persistedPromptTokens=${persistedPromptTokens ?? "undefined"} persistedFresh=${entry?.totalTokensFresh === true} promptTokensEst=${promptTokenEstimate ?? "undefined"} transcriptPromptTokens=${transcriptPromptTokens ?? "undefined"} transcriptOutputTokens=${transcriptOutputTokens ?? "undefined"} projectedTokenCount=${projectedTokenCount ?? "undefined"} transcriptBytes=${transcriptByteSize ?? "undefined"} forceFlushTranscriptBytes=${forceFlushTranscriptBytes} forceFlushByTranscriptSize=${shouldForceFlushByTranscriptSize}`);
1004
+ if (!(memoryFlushWritable && !params.isHeartbeat && !isCli && shouldRunMemoryFlush({
1005
+ entry,
1006
+ tokenCount: tokenCountForFlush,
1007
+ contextWindowTokens,
1008
+ reserveTokensFloor: memoryFlushPlan.reserveTokensFloor,
1009
+ softThresholdTokens: memoryFlushPlan.softThresholdTokens
1010
+ }) || shouldForceFlushByTranscriptSize && entry != null && !hasAlreadyFlushedForCurrentCompaction(entry))) return entry ?? params.sessionEntry;
1011
+ logVerbose(`memoryFlush triggered: sessionKey=${params.sessionKey} tokenCount=${tokenCountForFlush ?? "undefined"} threshold=${flushThreshold}`);
1012
+ let activeSessionEntry = entry ?? params.sessionEntry;
1013
+ const activeSessionStore = params.sessionStore;
1014
+ let bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(activeSessionEntry?.systemPromptReport ?? (params.sessionKey ? activeSessionStore?.[params.sessionKey]?.systemPromptReport : void 0));
1015
+ const flushRunId = crypto.randomUUID();
1016
+ if (params.sessionKey) registerAgentRunContext(flushRunId, {
1017
+ sessionKey: params.sessionKey,
1018
+ verboseLevel: params.resolvedVerboseLevel
1019
+ });
1020
+ let memoryCompactionCompleted = false;
1021
+ const memoryFlushNowMs = Date.now();
1022
+ const activeMemoryFlushPlan = resolveMemoryFlushPlan({
1023
+ cfg: params.cfg,
1024
+ nowMs: memoryFlushNowMs
1025
+ }) ?? memoryFlushPlan;
1026
+ const memoryFlushWritePath = activeMemoryFlushPlan.relativePath;
1027
+ const flushSystemPrompt = [params.followupRun.run.extraSystemPrompt, activeMemoryFlushPlan.systemPrompt].filter(Boolean).join("\n\n");
1028
+ let postCompactionSessionId;
1029
+ try {
1030
+ await runWithModelFallback({
1031
+ ...resolveModelFallbackOptions(params.followupRun.run),
1032
+ runId: flushRunId,
1033
+ run: async (provider, model, runOptions) => {
1034
+ const { embeddedContext, senderContext, runBaseParams } = buildEmbeddedRunExecutionParams({
1035
+ run: params.followupRun.run,
1036
+ sessionCtx: params.sessionCtx,
1037
+ hasRepliedRef: params.opts?.hasRepliedRef,
1038
+ provider,
1039
+ model,
1040
+ runId: flushRunId,
1041
+ allowTransientCooldownProbe: runOptions?.allowTransientCooldownProbe
1042
+ });
1043
+ const result = await runEmbeddedVoraAgent({
1044
+ ...embeddedContext,
1045
+ ...senderContext,
1046
+ ...runBaseParams,
1047
+ allowGatewaySubagentBinding: true,
1048
+ silentExpected: true,
1049
+ trigger: "memory",
1050
+ memoryFlushWritePath,
1051
+ prompt: activeMemoryFlushPlan.prompt,
1052
+ extraSystemPrompt: flushSystemPrompt,
1053
+ bootstrapPromptWarningSignaturesSeen,
1054
+ bootstrapPromptWarningSignature: bootstrapPromptWarningSignaturesSeen[bootstrapPromptWarningSignaturesSeen.length - 1],
1055
+ onAgentEvent: (evt) => {
1056
+ if (evt.stream === "compaction") {
1057
+ if ((typeof evt.data.phase === "string" ? evt.data.phase : "") === "end") memoryCompactionCompleted = true;
1058
+ }
1059
+ }
1060
+ });
1061
+ if (result.meta?.agentMeta?.sessionId) postCompactionSessionId = result.meta.agentMeta.sessionId;
1062
+ bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(result.meta?.systemPromptReport);
1063
+ return result;
1064
+ }
1065
+ });
1066
+ let memoryFlushCompactionCount = activeSessionEntry?.compactionCount ?? (params.sessionKey ? activeSessionStore?.[params.sessionKey]?.compactionCount : 0) ?? 0;
1067
+ if (memoryCompactionCompleted) {
1068
+ const previousSessionId = activeSessionEntry?.sessionId ?? params.followupRun.run.sessionId;
1069
+ const nextCount = await incrementCompactionCount({
1070
+ sessionEntry: activeSessionEntry,
1071
+ sessionStore: activeSessionStore,
1072
+ sessionKey: params.sessionKey,
1073
+ storePath: params.storePath,
1074
+ newSessionId: postCompactionSessionId
1075
+ });
1076
+ const updatedEntry = params.sessionKey ? activeSessionStore?.[params.sessionKey] : void 0;
1077
+ if (updatedEntry) {
1078
+ activeSessionEntry = updatedEntry;
1079
+ params.followupRun.run.sessionId = updatedEntry.sessionId;
1080
+ if (updatedEntry.sessionFile) params.followupRun.run.sessionFile = updatedEntry.sessionFile;
1081
+ const queueKey = params.followupRun.run.sessionKey ?? params.sessionKey;
1082
+ if (queueKey) refreshQueuedFollowupSession({
1083
+ key: queueKey,
1084
+ previousSessionId,
1085
+ nextSessionId: updatedEntry.sessionId,
1086
+ nextSessionFile: updatedEntry.sessionFile
1087
+ });
1088
+ }
1089
+ if (typeof nextCount === "number") memoryFlushCompactionCount = nextCount;
1090
+ }
1091
+ if (params.storePath && params.sessionKey) try {
1092
+ const updatedEntry = await updateSessionStoreEntry({
1093
+ storePath: params.storePath,
1094
+ sessionKey: params.sessionKey,
1095
+ update: async () => ({
1096
+ memoryFlushAt: Date.now(),
1097
+ memoryFlushCompactionCount
1098
+ })
1099
+ });
1100
+ if (updatedEntry) {
1101
+ activeSessionEntry = updatedEntry;
1102
+ params.followupRun.run.sessionId = updatedEntry.sessionId;
1103
+ if (updatedEntry.sessionFile) params.followupRun.run.sessionFile = updatedEntry.sessionFile;
1104
+ }
1105
+ } catch (err) {
1106
+ logVerbose(`failed to persist memory flush metadata: ${String(err)}`);
1107
+ }
1108
+ } catch (err) {
1109
+ logVerbose(`memory flush run failed: ${String(err)}`);
1110
+ }
1111
+ return activeSessionEntry;
1112
+ }
1113
+ //#endregion
1114
+ //#region src/auto-reply/reply/agent-runner-payloads.ts
1115
+ let replyPayloadsDedupeRuntimePromise = null;
1116
+ function loadReplyPayloadsDedupeRuntime() {
1117
+ replyPayloadsDedupeRuntimePromise ??= import("./reply-payloads-dedupe.runtime-ClraIPuB.js");
1118
+ return replyPayloadsDedupeRuntimePromise;
1119
+ }
1120
+ async function normalizeReplyPayloadMedia(params) {
1121
+ if (!params.normalizeMediaPaths || !resolveSendableOutboundReplyParts(params.payload).hasMedia) return params.payload;
1122
+ try {
1123
+ return await params.normalizeMediaPaths(params.payload);
1124
+ } catch (err) {
1125
+ logVerbose(`reply payload media normalization failed: ${String(err)}`);
1126
+ return {
1127
+ ...params.payload,
1128
+ mediaUrl: void 0,
1129
+ mediaUrls: void 0,
1130
+ audioAsVoice: false
1131
+ };
1132
+ }
1133
+ }
1134
+ async function normalizeSentMediaUrlsForDedupe(params) {
1135
+ if (params.sentMediaUrls.length === 0 || !params.normalizeMediaPaths) return params.sentMediaUrls;
1136
+ const normalizedUrls = [];
1137
+ const seen = /* @__PURE__ */ new Set();
1138
+ for (const raw of params.sentMediaUrls) {
1139
+ const trimmed = raw.trim();
1140
+ if (!trimmed) continue;
1141
+ if (!seen.has(trimmed)) {
1142
+ seen.add(trimmed);
1143
+ normalizedUrls.push(trimmed);
1144
+ }
1145
+ try {
1146
+ const normalizedMediaUrls = resolveSendableOutboundReplyParts(await params.normalizeMediaPaths({
1147
+ mediaUrl: trimmed,
1148
+ mediaUrls: [trimmed]
1149
+ })).mediaUrls;
1150
+ for (const mediaUrl of normalizedMediaUrls) {
1151
+ const candidate = mediaUrl.trim();
1152
+ if (!candidate || seen.has(candidate)) continue;
1153
+ seen.add(candidate);
1154
+ normalizedUrls.push(candidate);
1155
+ }
1156
+ } catch (err) {
1157
+ logVerbose(`messaging tool sent-media normalization failed: ${String(err)}`);
1158
+ }
1159
+ }
1160
+ return normalizedUrls;
1161
+ }
1162
+ async function buildReplyPayloads(params) {
1163
+ let didLogHeartbeatStrip = params.didLogHeartbeatStrip;
1164
+ const sanitizedPayloads = params.isHeartbeat ? params.payloads : params.payloads.flatMap((payload) => {
1165
+ let text = payload.text;
1166
+ if (payload.isError && text && isBunFetchSocketError(text)) text = formatBunFetchSocketError(text);
1167
+ if (!text || !text.includes("HEARTBEAT_OK")) return [{
1168
+ ...payload,
1169
+ text
1170
+ }];
1171
+ const stripped = stripHeartbeatToken(text, { mode: "message" });
1172
+ if (stripped.didStrip && !didLogHeartbeatStrip) {
1173
+ didLogHeartbeatStrip = true;
1174
+ logVerbose("Stripped stray HEARTBEAT_OK token from reply");
1175
+ }
1176
+ const hasMedia = resolveSendableOutboundReplyParts(payload).hasMedia;
1177
+ if (stripped.shouldSkip && !hasMedia) return [];
1178
+ return [{
1179
+ ...payload,
1180
+ text: stripped.text
1181
+ }];
1182
+ });
1183
+ const replyTaggedPayloads = (await Promise.all(applyReplyThreading({
1184
+ payloads: sanitizedPayloads,
1185
+ replyToMode: params.replyToMode,
1186
+ replyToChannel: params.replyToChannel,
1187
+ currentMessageId: params.currentMessageId
1188
+ }).map(async (payload) => {
1189
+ const parsed = normalizeReplyPayloadDirectives({
1190
+ payload,
1191
+ currentMessageId: params.currentMessageId,
1192
+ silentToken: SILENT_REPLY_TOKEN,
1193
+ parseMode: "always"
1194
+ }).payload;
1195
+ return await normalizeReplyPayloadMedia({
1196
+ payload: parsed,
1197
+ normalizeMediaPaths: params.normalizeMediaPaths
1198
+ });
1199
+ }))).filter(isRenderablePayload);
1200
+ const silentFilteredPayloads = params.silentExpected ? [] : replyTaggedPayloads;
1201
+ const shouldDropFinalPayloads = params.blockStreamingEnabled && Boolean(params.blockReplyPipeline?.didStream()) && !params.blockReplyPipeline?.isAborted();
1202
+ const messagingToolSentTexts = params.messagingToolSentTexts ?? [];
1203
+ const messagingToolSentTargets = params.messagingToolSentTargets ?? [];
1204
+ const dedupeRuntime = messagingToolSentTexts.length > 0 || (params.messagingToolSentMediaUrls?.length ?? 0) > 0 || messagingToolSentTargets.length > 0 ? await loadReplyPayloadsDedupeRuntime() : null;
1205
+ const suppressMessagingToolReplies = dedupeRuntime?.shouldSuppressMessagingToolReplies({
1206
+ messageProvider: resolveOriginMessageProvider({
1207
+ originatingChannel: params.originatingChannel,
1208
+ provider: params.messageProvider
1209
+ }),
1210
+ messagingToolSentTargets,
1211
+ originatingTo: resolveOriginMessageTo({ originatingTo: params.originatingTo }),
1212
+ accountId: resolveOriginAccountId({ originatingAccountId: params.accountId })
1213
+ }) ?? false;
1214
+ const dedupeMessagingToolPayloads = suppressMessagingToolReplies || messagingToolSentTargets.length === 0;
1215
+ const messagingToolSentMediaUrls = dedupeMessagingToolPayloads ? await normalizeSentMediaUrlsForDedupe({
1216
+ sentMediaUrls: params.messagingToolSentMediaUrls ?? [],
1217
+ normalizeMediaPaths: params.normalizeMediaPaths
1218
+ }) : params.messagingToolSentMediaUrls ?? [];
1219
+ const dedupedPayloads = dedupeMessagingToolPayloads ? (dedupeRuntime ?? await loadReplyPayloadsDedupeRuntime()).filterMessagingToolDuplicates({
1220
+ payloads: silentFilteredPayloads,
1221
+ sentTexts: messagingToolSentTexts
1222
+ }) : silentFilteredPayloads;
1223
+ const mediaFilteredPayloads = dedupeMessagingToolPayloads ? (dedupeRuntime ?? await loadReplyPayloadsDedupeRuntime()).filterMessagingToolMediaDuplicates({
1224
+ payloads: dedupedPayloads,
1225
+ sentMediaUrls: messagingToolSentMediaUrls
1226
+ }) : dedupedPayloads;
1227
+ const filteredPayloads = shouldDropFinalPayloads ? [] : params.blockStreamingEnabled ? mediaFilteredPayloads.filter((payload) => !params.blockReplyPipeline?.hasSentPayload(payload)) : params.directlySentBlockKeys?.size ? mediaFilteredPayloads.filter((payload) => !params.directlySentBlockKeys.has(createBlockReplyContentKey(payload))) : mediaFilteredPayloads;
1228
+ return {
1229
+ replyPayloads: suppressMessagingToolReplies ? [] : filteredPayloads,
1230
+ didLogHeartbeatStrip
1231
+ };
1232
+ }
1233
+ //#endregion
1234
+ //#region src/auto-reply/reply/agent-runner-reminder-guard.ts
1235
+ const UNSCHEDULED_REMINDER_NOTE = "Note: I did not schedule a reminder in this turn, so this will not trigger automatically.";
1236
+ const REMINDER_COMMITMENT_PATTERNS = [/\b(?:i\s*['’]?ll|i will)\s+(?:make sure to\s+)?(?:remember|remind|ping|follow up|follow-up|check back|circle back)\b/i, /\b(?:i\s*['’]?ll|i will)\s+(?:set|create|schedule)\s+(?:a\s+)?reminder\b/i];
1237
+ function hasUnbackedReminderCommitment(text) {
1238
+ const normalized = text.toLowerCase();
1239
+ if (!normalized.trim()) return false;
1240
+ if (normalized.includes("Note: I did not schedule a reminder in this turn, so this will not trigger automatically.".toLowerCase())) return false;
1241
+ return REMINDER_COMMITMENT_PATTERNS.some((pattern) => pattern.test(text));
1242
+ }
1243
+ /**
1244
+ * Returns true when the cron store has at least one enabled job that shares the
1245
+ * current session key. Used to suppress the "no reminder scheduled" guard note
1246
+ * when an existing cron (created in a prior turn) already covers the commitment.
1247
+ */
1248
+ async function hasSessionRelatedCronJobs(params) {
1249
+ try {
1250
+ const store = await loadCronStore(resolveCronStorePath(params.cronStorePath));
1251
+ if (store.jobs.length === 0) return false;
1252
+ if (params.sessionKey) return store.jobs.some((job) => job.enabled && job.sessionKey === params.sessionKey);
1253
+ return false;
1254
+ } catch {
1255
+ return false;
1256
+ }
1257
+ }
1258
+ function appendUnscheduledReminderNote(payloads) {
1259
+ let appended = false;
1260
+ return payloads.map((payload) => {
1261
+ if (appended || payload.isError || typeof payload.text !== "string") return payload;
1262
+ if (!hasUnbackedReminderCommitment(payload.text)) return payload;
1263
+ appended = true;
1264
+ const trimmed = payload.text.trimEnd();
1265
+ return {
1266
+ ...payload,
1267
+ text: `${trimmed}\n\n${UNSCHEDULED_REMINDER_NOTE}`
1268
+ };
1269
+ });
1270
+ }
1271
+ //#endregion
1272
+ //#region src/auto-reply/reply/agent-runner-usage-line.ts
1273
+ const formatResponseUsageLine = (params) => {
1274
+ const usage = params.usage;
1275
+ if (!usage) return null;
1276
+ const input = usage.input;
1277
+ const output = usage.output;
1278
+ if (typeof input !== "number" && typeof output !== "number") return null;
1279
+ const inputLabel = typeof input === "number" ? formatTokenCount(input) : "?";
1280
+ const outputLabel = typeof output === "number" ? formatTokenCount(output) : "?";
1281
+ const cost = params.showCost && typeof input === "number" && typeof output === "number" ? estimateUsageCost({
1282
+ usage: {
1283
+ input,
1284
+ output,
1285
+ cacheRead: usage.cacheRead,
1286
+ cacheWrite: usage.cacheWrite
1287
+ },
1288
+ cost: params.costConfig
1289
+ }) : void 0;
1290
+ const costLabel = params.showCost ? formatUsd(cost) : void 0;
1291
+ return `Usage: ${inputLabel} in / ${outputLabel} out${costLabel ? ` · est ${costLabel}` : ""}`;
1292
+ };
1293
+ const appendUsageLine = (payloads, line) => {
1294
+ let index = -1;
1295
+ for (let i = payloads.length - 1; i >= 0; i -= 1) if (payloads[i]?.text) {
1296
+ index = i;
1297
+ break;
1298
+ }
1299
+ if (index === -1) return [...payloads, { text: line }];
1300
+ const existing = payloads[index];
1301
+ const existingText = existing.text ?? "";
1302
+ const separator = existingText.endsWith("\n") ? "" : "\n";
1303
+ const next = {
1304
+ ...existing,
1305
+ text: `${existingText}${separator}${line}`
1306
+ };
1307
+ const updated = payloads.slice();
1308
+ updated[index] = next;
1309
+ return updated;
1310
+ };
1311
+ //#endregion
1312
+ //#region src/auto-reply/reply/session-usage.ts
1313
+ function applyCliSessionIdToSessionPatch(params, entry, patch) {
1314
+ const cliProvider = params.providerUsed ?? entry.modelProvider;
1315
+ if (params.cliSessionBinding && cliProvider) {
1316
+ const nextEntry = {
1317
+ ...entry,
1318
+ ...patch
1319
+ };
1320
+ setCliSessionBinding(nextEntry, cliProvider, params.cliSessionBinding);
1321
+ return {
1322
+ ...patch,
1323
+ cliSessionIds: nextEntry.cliSessionIds,
1324
+ cliSessionBindings: nextEntry.cliSessionBindings,
1325
+ claudeCliSessionId: nextEntry.claudeCliSessionId
1326
+ };
1327
+ }
1328
+ if (params.cliSessionId && cliProvider) {
1329
+ const nextEntry = {
1330
+ ...entry,
1331
+ ...patch
1332
+ };
1333
+ setCliSessionId(nextEntry, cliProvider, params.cliSessionId);
1334
+ return {
1335
+ ...patch,
1336
+ cliSessionIds: nextEntry.cliSessionIds,
1337
+ cliSessionBindings: nextEntry.cliSessionBindings,
1338
+ claudeCliSessionId: nextEntry.claudeCliSessionId
1339
+ };
1340
+ }
1341
+ return patch;
1342
+ }
1343
+ function resolveNonNegativeNumber(value) {
1344
+ return typeof value === "number" && Number.isFinite(value) && value >= 0 ? value : void 0;
1345
+ }
1346
+ function estimateSessionRunCostUsd(params) {
1347
+ if (!hasNonzeroUsage(params.usage)) return;
1348
+ const cost = resolveModelCostConfig({
1349
+ provider: params.providerUsed,
1350
+ model: params.modelUsed,
1351
+ config: params.cfg
1352
+ });
1353
+ return resolveNonNegativeNumber(estimateUsageCost({
1354
+ usage: params.usage,
1355
+ cost
1356
+ }));
1357
+ }
1358
+ async function persistSessionUsageUpdate(params) {
1359
+ const { storePath, sessionKey } = params;
1360
+ if (!storePath || !sessionKey) return;
1361
+ const label = params.logLabel ? `${params.logLabel} ` : "";
1362
+ const cfg = params.cfg ?? loadConfig();
1363
+ const hasUsage = hasNonzeroUsage(params.usage);
1364
+ const hasPromptTokens = typeof params.promptTokens === "number" && Number.isFinite(params.promptTokens) && params.promptTokens > 0;
1365
+ const hasFreshContextSnapshot = Boolean(params.lastCallUsage) || hasPromptTokens || params.usageIsContextSnapshot === true;
1366
+ if (hasUsage || hasFreshContextSnapshot) {
1367
+ try {
1368
+ await updateSessionStoreEntry({
1369
+ storePath,
1370
+ sessionKey,
1371
+ update: async (entry) => {
1372
+ const resolvedContextTokens = params.contextTokensUsed ?? entry.contextTokens;
1373
+ const usageForContext = params.lastCallUsage ?? (params.usageIsContextSnapshot === true ? params.usage : void 0);
1374
+ const totalTokens = hasFreshContextSnapshot ? deriveSessionTotalTokens({
1375
+ usage: usageForContext,
1376
+ contextTokens: resolvedContextTokens,
1377
+ promptTokens: params.promptTokens
1378
+ }) : void 0;
1379
+ const runEstimatedCostUsd = estimateSessionRunCostUsd({
1380
+ cfg,
1381
+ usage: params.usage,
1382
+ providerUsed: params.providerUsed ?? entry.modelProvider,
1383
+ modelUsed: params.modelUsed ?? entry.model
1384
+ });
1385
+ const existingEstimatedCostUsd = resolveNonNegativeNumber(entry.estimatedCostUsd) ?? 0;
1386
+ const patch = {
1387
+ modelProvider: params.providerUsed ?? entry.modelProvider,
1388
+ model: params.modelUsed ?? entry.model,
1389
+ contextTokens: resolvedContextTokens,
1390
+ systemPromptReport: params.systemPromptReport ?? entry.systemPromptReport,
1391
+ updatedAt: Date.now()
1392
+ };
1393
+ if (hasUsage) {
1394
+ patch.inputTokens = params.usage?.input ?? 0;
1395
+ patch.outputTokens = params.usage?.output ?? 0;
1396
+ const cacheUsage = params.lastCallUsage ?? params.usage;
1397
+ patch.cacheRead = cacheUsage?.cacheRead ?? 0;
1398
+ patch.cacheWrite = cacheUsage?.cacheWrite ?? 0;
1399
+ }
1400
+ if (runEstimatedCostUsd !== void 0) patch.estimatedCostUsd = existingEstimatedCostUsd + runEstimatedCostUsd;
1401
+ else if (entry.estimatedCostUsd !== void 0) patch.estimatedCostUsd = entry.estimatedCostUsd;
1402
+ patch.totalTokens = totalTokens;
1403
+ patch.totalTokensFresh = typeof totalTokens === "number";
1404
+ return applyCliSessionIdToSessionPatch(params, entry, patch);
1405
+ }
1406
+ });
1407
+ } catch (err) {
1408
+ logVerbose(`failed to persist ${label}usage update: ${String(err)}`);
1409
+ }
1410
+ return;
1411
+ }
1412
+ if (params.modelUsed || params.contextTokensUsed) try {
1413
+ await updateSessionStoreEntry({
1414
+ storePath,
1415
+ sessionKey,
1416
+ update: async (entry) => {
1417
+ return applyCliSessionIdToSessionPatch(params, entry, {
1418
+ modelProvider: params.providerUsed ?? entry.modelProvider,
1419
+ model: params.modelUsed ?? entry.model,
1420
+ contextTokens: params.contextTokensUsed ?? entry.contextTokens,
1421
+ systemPromptReport: params.systemPromptReport ?? entry.systemPromptReport,
1422
+ updatedAt: Date.now()
1423
+ });
1424
+ }
1425
+ });
1426
+ } catch (err) {
1427
+ logVerbose(`failed to persist ${label}model/context update: ${String(err)}`);
1428
+ }
1429
+ }
1430
+ //#endregion
1431
+ //#region src/auto-reply/reply/session-run-accounting.ts
1432
+ async function persistRunSessionUsage(params) {
1433
+ await persistSessionUsageUpdate(params);
1434
+ }
1435
+ async function incrementRunCompactionCount(params) {
1436
+ const tokensAfterCompaction = params.lastCallUsage ? deriveSessionTotalTokens({
1437
+ usage: params.lastCallUsage,
1438
+ contextTokens: params.contextTokensUsed
1439
+ }) : void 0;
1440
+ return incrementCompactionCount({
1441
+ sessionEntry: params.sessionEntry,
1442
+ sessionStore: params.sessionStore,
1443
+ sessionKey: params.sessionKey,
1444
+ storePath: params.storePath,
1445
+ amount: params.amount,
1446
+ tokensAfter: tokensAfterCompaction,
1447
+ newSessionId: params.newSessionId
1448
+ });
1449
+ }
1450
+ //#endregion
1451
+ //#region src/auto-reply/reply/followup-runner.ts
1452
+ function createFollowupRunner(params) {
1453
+ const { opts, typing, typingMode, sessionEntry, sessionStore, sessionKey, storePath, defaultModel, agentCfgContextTokens } = params;
1454
+ const typingSignals = createTypingSignaler({
1455
+ typing,
1456
+ mode: typingMode,
1457
+ isHeartbeat: opts?.isHeartbeat === true
1458
+ });
1459
+ /**
1460
+ * Sends followup payloads, routing to the originating channel if set.
1461
+ *
1462
+ * When originatingChannel/originatingTo are set on the queued run,
1463
+ * replies are routed directly to that provider instead of using the
1464
+ * session's current dispatcher. This ensures replies go back to
1465
+ * where the message originated.
1466
+ */
1467
+ const sendFollowupPayloads = async (payloads, queued) => {
1468
+ const { originatingChannel, originatingTo } = queued;
1469
+ const shouldRouteToOriginating = isRoutableChannel(originatingChannel) && originatingTo;
1470
+ if (!shouldRouteToOriginating && !opts?.onBlockReply) {
1471
+ logVerbose("followup queue: no onBlockReply handler; dropping payloads");
1472
+ return;
1473
+ }
1474
+ for (const payload of payloads) {
1475
+ if (!payload || !hasOutboundReplyContent(payload)) continue;
1476
+ if (isSilentReplyText(payload.text, "NO_REPLY") && !resolveSendableOutboundReplyParts(payload).hasMedia) continue;
1477
+ await typingSignals.signalTextDelta(payload.text);
1478
+ if (shouldRouteToOriginating) {
1479
+ const result = await routeReply({
1480
+ payload,
1481
+ channel: originatingChannel,
1482
+ to: originatingTo,
1483
+ sessionKey: queued.run.sessionKey,
1484
+ accountId: queued.originatingAccountId,
1485
+ threadId: queued.originatingThreadId,
1486
+ cfg: queued.run.config
1487
+ });
1488
+ if (!result.ok) {
1489
+ logVerbose(`followup queue: route-reply failed: ${result.error ?? "unknown error"}`);
1490
+ const provider = resolveOriginMessageProvider({ provider: queued.run.messageProvider });
1491
+ const origin = resolveOriginMessageProvider({ originatingChannel });
1492
+ if (opts?.onBlockReply && origin && origin === provider) await opts.onBlockReply(payload);
1493
+ }
1494
+ } else if (opts?.onBlockReply) await opts.onBlockReply(payload);
1495
+ }
1496
+ };
1497
+ return async (queued) => {
1498
+ try {
1499
+ const runId = crypto.randomUUID();
1500
+ const shouldSurfaceToControlUi = isInternalMessageChannel(resolveOriginMessageProvider({
1501
+ originatingChannel: queued.originatingChannel,
1502
+ provider: queued.run.messageProvider
1503
+ }));
1504
+ if (queued.run.sessionKey) registerAgentRunContext(runId, {
1505
+ sessionKey: queued.run.sessionKey,
1506
+ verboseLevel: queued.run.verboseLevel,
1507
+ isControlUiVisible: shouldSurfaceToControlUi
1508
+ });
1509
+ let autoCompactionCount = 0;
1510
+ let runResult;
1511
+ let fallbackProvider = queued.run.provider;
1512
+ let fallbackModel = queued.run.model;
1513
+ let activeSessionEntry = (sessionKey ? sessionStore?.[sessionKey] : void 0) ?? sessionEntry;
1514
+ activeSessionEntry = await runPreflightCompactionIfNeeded({
1515
+ cfg: queued.run.config,
1516
+ followupRun: queued,
1517
+ promptForEstimate: queued.prompt,
1518
+ defaultModel,
1519
+ agentCfgContextTokens,
1520
+ sessionEntry: activeSessionEntry,
1521
+ sessionStore,
1522
+ sessionKey,
1523
+ storePath,
1524
+ isHeartbeat: opts?.isHeartbeat === true
1525
+ });
1526
+ let bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(activeSessionEntry?.systemPromptReport);
1527
+ try {
1528
+ const fallbackResult = await runWithModelFallback({
1529
+ cfg: queued.run.config,
1530
+ provider: queued.run.provider,
1531
+ model: queued.run.model,
1532
+ runId,
1533
+ agentDir: queued.run.agentDir,
1534
+ fallbacksOverride: resolveRunModelFallbacksOverride({
1535
+ cfg: queued.run.config,
1536
+ agentId: queued.run.agentId,
1537
+ sessionKey: queued.run.sessionKey
1538
+ }),
1539
+ run: async (provider, model, runOptions) => {
1540
+ const authProfile = resolveRunAuthProfile(queued.run, provider);
1541
+ let attemptCompactionCount = 0;
1542
+ try {
1543
+ const result = await runEmbeddedVoraAgent({
1544
+ allowGatewaySubagentBinding: true,
1545
+ sessionId: queued.run.sessionId,
1546
+ sessionKey: queued.run.sessionKey,
1547
+ agentId: queued.run.agentId,
1548
+ trigger: "user",
1549
+ messageChannel: queued.originatingChannel ?? void 0,
1550
+ messageProvider: queued.run.messageProvider,
1551
+ agentAccountId: queued.run.agentAccountId,
1552
+ messageTo: queued.originatingTo,
1553
+ messageThreadId: queued.originatingThreadId,
1554
+ currentChannelId: queued.originatingTo,
1555
+ currentThreadTs: queued.originatingThreadId != null ? String(queued.originatingThreadId) : void 0,
1556
+ groupId: queued.run.groupId,
1557
+ groupChannel: queued.run.groupChannel,
1558
+ groupSpace: queued.run.groupSpace,
1559
+ senderId: queued.run.senderId,
1560
+ senderName: queued.run.senderName,
1561
+ senderUsername: queued.run.senderUsername,
1562
+ senderE164: queued.run.senderE164,
1563
+ senderIsOwner: queued.run.senderIsOwner,
1564
+ sessionFile: queued.run.sessionFile,
1565
+ agentDir: queued.run.agentDir,
1566
+ workspaceDir: queued.run.workspaceDir,
1567
+ config: queued.run.config,
1568
+ skillsSnapshot: queued.run.skillsSnapshot,
1569
+ prompt: queued.prompt,
1570
+ extraSystemPrompt: queued.run.extraSystemPrompt,
1571
+ ownerNumbers: queued.run.ownerNumbers,
1572
+ enforceFinalTag: queued.run.enforceFinalTag,
1573
+ provider,
1574
+ model,
1575
+ ...authProfile,
1576
+ thinkLevel: queued.run.thinkLevel,
1577
+ verboseLevel: queued.run.verboseLevel,
1578
+ reasoningLevel: queued.run.reasoningLevel,
1579
+ suppressToolErrorWarnings: opts?.suppressToolErrorWarnings,
1580
+ execOverrides: queued.run.execOverrides,
1581
+ bashElevated: queued.run.bashElevated,
1582
+ timeoutMs: queued.run.timeoutMs,
1583
+ runId,
1584
+ allowTransientCooldownProbe: runOptions?.allowTransientCooldownProbe,
1585
+ blockReplyBreak: queued.run.blockReplyBreak,
1586
+ bootstrapPromptWarningSignaturesSeen,
1587
+ bootstrapPromptWarningSignature: bootstrapPromptWarningSignaturesSeen[bootstrapPromptWarningSignaturesSeen.length - 1],
1588
+ onAgentEvent: (evt) => {
1589
+ if (evt.stream !== "compaction") return;
1590
+ const phase = typeof evt.data.phase === "string" ? evt.data.phase : "";
1591
+ const completed = evt.data?.completed === true;
1592
+ if (phase === "end" && completed) attemptCompactionCount += 1;
1593
+ }
1594
+ });
1595
+ bootstrapPromptWarningSignaturesSeen = resolveBootstrapWarningSignaturesSeen(result.meta?.systemPromptReport);
1596
+ const resultCompactionCount = Math.max(0, result.meta?.agentMeta?.compactionCount ?? 0);
1597
+ attemptCompactionCount = Math.max(attemptCompactionCount, resultCompactionCount);
1598
+ return result;
1599
+ } finally {
1600
+ autoCompactionCount += attemptCompactionCount;
1601
+ }
1602
+ }
1603
+ });
1604
+ runResult = fallbackResult.result;
1605
+ fallbackProvider = fallbackResult.provider;
1606
+ fallbackModel = fallbackResult.model;
1607
+ } catch (err) {
1608
+ const message = err instanceof Error ? err.message : String(err);
1609
+ defaultRuntime.error?.(`Followup agent failed before reply: ${message}`);
1610
+ return;
1611
+ }
1612
+ const usage = runResult.meta?.agentMeta?.usage;
1613
+ const promptTokens = runResult.meta?.agentMeta?.promptTokens;
1614
+ const modelUsed = runResult.meta?.agentMeta?.model ?? fallbackModel ?? defaultModel;
1615
+ const contextTokensUsed = agentCfgContextTokens ?? lookupContextTokens(modelUsed) ?? sessionEntry?.contextTokens ?? 2e5;
1616
+ if (storePath && sessionKey) await persistRunSessionUsage({
1617
+ storePath,
1618
+ sessionKey,
1619
+ cfg: queued.run.config,
1620
+ usage,
1621
+ lastCallUsage: runResult.meta?.agentMeta?.lastCallUsage,
1622
+ promptTokens,
1623
+ modelUsed,
1624
+ providerUsed: fallbackProvider,
1625
+ contextTokensUsed,
1626
+ systemPromptReport: runResult.meta?.systemPromptReport,
1627
+ cliSessionBinding: runResult.meta?.agentMeta?.cliSessionBinding,
1628
+ usageIsContextSnapshot: isCliProvider(fallbackProvider ?? queued.run.provider, queued.run.config),
1629
+ logLabel: "followup"
1630
+ });
1631
+ const payloadArray = runResult.payloads ?? [];
1632
+ if (payloadArray.length === 0) return;
1633
+ const sanitizedPayloads = payloadArray.flatMap((payload) => {
1634
+ const text = payload.text;
1635
+ if (!text || !text.includes("HEARTBEAT_OK")) return [payload];
1636
+ const stripped = stripHeartbeatToken(text, { mode: "message" });
1637
+ const hasMedia = resolveSendableOutboundReplyParts(payload).hasMedia;
1638
+ if (stripped.shouldSkip && !hasMedia) return [];
1639
+ return [{
1640
+ ...payload,
1641
+ text: stripped.text
1642
+ }];
1643
+ });
1644
+ const replyToChannel = resolveOriginMessageProvider({
1645
+ originatingChannel: queued.originatingChannel,
1646
+ provider: queued.run.messageProvider
1647
+ });
1648
+ const mediaFilteredPayloads = filterMessagingToolMediaDuplicates({
1649
+ payloads: filterMessagingToolDuplicates({
1650
+ payloads: applyReplyThreading({
1651
+ payloads: sanitizedPayloads,
1652
+ replyToMode: resolveReplyToMode(queued.run.config, replyToChannel, queued.originatingAccountId, queued.originatingChatType),
1653
+ replyToChannel
1654
+ }),
1655
+ sentTexts: runResult.messagingToolSentTexts ?? []
1656
+ }),
1657
+ sentMediaUrls: runResult.messagingToolSentMediaUrls ?? []
1658
+ });
1659
+ const finalPayloads = shouldSuppressMessagingToolReplies({
1660
+ messageProvider: resolveOriginMessageProvider({
1661
+ originatingChannel: queued.originatingChannel,
1662
+ provider: queued.run.messageProvider
1663
+ }),
1664
+ messagingToolSentTargets: runResult.messagingToolSentTargets,
1665
+ originatingTo: resolveOriginMessageTo({ originatingTo: queued.originatingTo }),
1666
+ accountId: resolveOriginAccountId({
1667
+ originatingAccountId: queued.originatingAccountId,
1668
+ accountId: queued.run.agentAccountId
1669
+ })
1670
+ }) ? [] : mediaFilteredPayloads;
1671
+ if (finalPayloads.length === 0) return;
1672
+ if (autoCompactionCount > 0) {
1673
+ const previousSessionId = queued.run.sessionId;
1674
+ const count = await incrementRunCompactionCount({
1675
+ sessionEntry,
1676
+ sessionStore,
1677
+ sessionKey,
1678
+ storePath,
1679
+ amount: autoCompactionCount,
1680
+ lastCallUsage: runResult.meta?.agentMeta?.lastCallUsage,
1681
+ contextTokensUsed,
1682
+ newSessionId: runResult.meta?.agentMeta?.sessionId
1683
+ });
1684
+ const refreshedSessionEntry = sessionKey && sessionStore ? sessionStore[sessionKey] : void 0;
1685
+ if (refreshedSessionEntry) {
1686
+ const queueKey = queued.run.sessionKey ?? sessionKey;
1687
+ if (queueKey) refreshQueuedFollowupSession({
1688
+ key: queueKey,
1689
+ previousSessionId,
1690
+ nextSessionId: refreshedSessionEntry.sessionId,
1691
+ nextSessionFile: refreshedSessionEntry.sessionFile
1692
+ });
1693
+ }
1694
+ if (queued.run.verboseLevel && queued.run.verboseLevel !== "off") {
1695
+ const suffix = typeof count === "number" ? ` (count ${count})` : "";
1696
+ finalPayloads.unshift({ text: `🧹 Auto-compaction complete${suffix}.` });
1697
+ }
1698
+ }
1699
+ await sendFollowupPayloads(finalPayloads, queued);
1700
+ } finally {
1701
+ typing.markRunComplete();
1702
+ typing.markDispatchIdle();
1703
+ }
1704
+ };
1705
+ }
1706
+ //#endregion
1707
+ //#region src/auto-reply/reply/queue-policy.ts
1708
+ function resolveActiveRunQueueAction(params) {
1709
+ if (!params.isActive) return "run-now";
1710
+ if (params.isHeartbeat) return "drop";
1711
+ if (params.shouldFollowup || params.queueMode === "steer") return "enqueue-followup";
1712
+ return "run-now";
1713
+ }
1714
+ //#endregion
1715
+ //#region src/auto-reply/reply/agent-runner.ts
1716
+ const BLOCK_REPLY_SEND_TIMEOUT_MS = 15e3;
1717
+ async function runReplyAgent(params) {
1718
+ const { commandBody, followupRun, queueKey, resolvedQueue, shouldSteer, shouldFollowup, isActive, isRunActive, isStreaming, opts, typing, sessionEntry, sessionStore, sessionKey, storePath, defaultModel, agentCfgContextTokens, resolvedVerboseLevel, isNewSession, blockStreamingEnabled, blockReplyChunking, resolvedBlockStreamingBreak, sessionCtx, shouldInjectGroupIntro, typingMode } = params;
1719
+ let activeSessionEntry = sessionEntry;
1720
+ const activeSessionStore = sessionStore;
1721
+ let activeIsNewSession = isNewSession;
1722
+ const isHeartbeat = opts?.isHeartbeat === true;
1723
+ const typingSignals = createTypingSignaler({
1724
+ typing,
1725
+ mode: typingMode,
1726
+ isHeartbeat
1727
+ });
1728
+ const shouldEmitToolResult = createShouldEmitToolResult({
1729
+ sessionKey,
1730
+ storePath,
1731
+ resolvedVerboseLevel
1732
+ });
1733
+ const shouldEmitToolOutput = createShouldEmitToolOutput({
1734
+ sessionKey,
1735
+ storePath,
1736
+ resolvedVerboseLevel
1737
+ });
1738
+ const pendingToolTasks = /* @__PURE__ */ new Set();
1739
+ const blockReplyTimeoutMs = opts?.blockReplyTimeoutMs ?? BLOCK_REPLY_SEND_TIMEOUT_MS;
1740
+ const replyToChannel = resolveOriginMessageProvider({
1741
+ originatingChannel: sessionCtx.OriginatingChannel,
1742
+ provider: sessionCtx.Surface ?? sessionCtx.Provider
1743
+ });
1744
+ const replyToMode = resolveReplyToMode(followupRun.run.config, replyToChannel, sessionCtx.AccountId, sessionCtx.ChatType);
1745
+ const applyReplyToMode = createReplyToModeFilterForChannel(replyToMode, replyToChannel);
1746
+ const cfg = followupRun.run.config;
1747
+ const normalizeReplyMediaPaths = createReplyMediaPathNormalizer({
1748
+ cfg,
1749
+ sessionKey,
1750
+ workspaceDir: followupRun.run.workspaceDir
1751
+ });
1752
+ const blockReplyCoalescing = blockStreamingEnabled && opts?.onBlockReply ? resolveEffectiveBlockStreamingConfig({
1753
+ cfg,
1754
+ provider: sessionCtx.Provider,
1755
+ accountId: sessionCtx.AccountId,
1756
+ chunking: blockReplyChunking
1757
+ }).coalescing : void 0;
1758
+ const blockReplyPipeline = blockStreamingEnabled && opts?.onBlockReply ? createBlockReplyPipeline({
1759
+ onBlockReply: opts.onBlockReply,
1760
+ timeoutMs: blockReplyTimeoutMs,
1761
+ coalescing: blockReplyCoalescing,
1762
+ buffer: createAudioAsVoiceBuffer({ isAudioPayload })
1763
+ }) : null;
1764
+ const touchActiveSessionEntry = async () => {
1765
+ if (!activeSessionEntry || !activeSessionStore || !sessionKey) return;
1766
+ const updatedAt = Date.now();
1767
+ activeSessionEntry.updatedAt = updatedAt;
1768
+ activeSessionStore[sessionKey] = activeSessionEntry;
1769
+ if (storePath) await updateSessionStoreEntry({
1770
+ storePath,
1771
+ sessionKey,
1772
+ update: async () => ({ updatedAt })
1773
+ });
1774
+ };
1775
+ if (shouldSteer && isStreaming) {
1776
+ if (queueEmbeddedPiMessage(followupRun.run.sessionId, followupRun.prompt) && !shouldFollowup) {
1777
+ await touchActiveSessionEntry();
1778
+ typing.cleanup();
1779
+ return;
1780
+ }
1781
+ }
1782
+ const activeRunQueueAction = resolveActiveRunQueueAction({
1783
+ isActive,
1784
+ isHeartbeat,
1785
+ shouldFollowup,
1786
+ queueMode: resolvedQueue.mode
1787
+ });
1788
+ const queuedRunFollowupTurn = createFollowupRunner({
1789
+ opts,
1790
+ typing,
1791
+ typingMode,
1792
+ sessionEntry: activeSessionEntry,
1793
+ sessionStore: activeSessionStore,
1794
+ sessionKey,
1795
+ storePath,
1796
+ defaultModel,
1797
+ agentCfgContextTokens
1798
+ });
1799
+ if (activeRunQueueAction === "drop") {
1800
+ typing.cleanup();
1801
+ return;
1802
+ }
1803
+ if (activeRunQueueAction === "enqueue-followup") {
1804
+ enqueueFollowupRun(queueKey, followupRun, resolvedQueue, "message-id", queuedRunFollowupTurn, false);
1805
+ if (!isRunActive?.()) finalizeWithFollowup(void 0, queueKey, queuedRunFollowupTurn);
1806
+ await touchActiveSessionEntry();
1807
+ typing.cleanup();
1808
+ return;
1809
+ }
1810
+ await typingSignals.signalRunStart();
1811
+ activeSessionEntry = await runPreflightCompactionIfNeeded({
1812
+ cfg,
1813
+ followupRun,
1814
+ promptForEstimate: followupRun.prompt,
1815
+ defaultModel,
1816
+ agentCfgContextTokens,
1817
+ sessionEntry: activeSessionEntry,
1818
+ sessionStore: activeSessionStore,
1819
+ sessionKey,
1820
+ storePath,
1821
+ isHeartbeat
1822
+ });
1823
+ activeSessionEntry = await runMemoryFlushIfNeeded({
1824
+ cfg,
1825
+ followupRun,
1826
+ promptForEstimate: followupRun.prompt,
1827
+ sessionCtx,
1828
+ opts,
1829
+ defaultModel,
1830
+ agentCfgContextTokens,
1831
+ resolvedVerboseLevel,
1832
+ sessionEntry: activeSessionEntry,
1833
+ sessionStore: activeSessionStore,
1834
+ sessionKey,
1835
+ storePath,
1836
+ isHeartbeat
1837
+ });
1838
+ const runFollowupTurn = createFollowupRunner({
1839
+ opts,
1840
+ typing,
1841
+ typingMode,
1842
+ sessionEntry: activeSessionEntry,
1843
+ sessionStore: activeSessionStore,
1844
+ sessionKey,
1845
+ storePath,
1846
+ defaultModel,
1847
+ agentCfgContextTokens
1848
+ });
1849
+ let responseUsageLine;
1850
+ const resetSession = async ({ failureLabel, buildLogMessage, cleanupTranscripts }) => {
1851
+ if (!sessionKey || !activeSessionStore || !storePath) return false;
1852
+ const prevEntry = activeSessionStore[sessionKey] ?? activeSessionEntry;
1853
+ if (!prevEntry) return false;
1854
+ const prevSessionId = cleanupTranscripts ? prevEntry.sessionId : void 0;
1855
+ const nextSessionId = generateSecureUuid();
1856
+ const nextEntry = {
1857
+ ...prevEntry,
1858
+ sessionId: nextSessionId,
1859
+ updatedAt: Date.now(),
1860
+ systemSent: false,
1861
+ abortedLastRun: false,
1862
+ modelProvider: void 0,
1863
+ model: void 0,
1864
+ inputTokens: void 0,
1865
+ outputTokens: void 0,
1866
+ totalTokens: void 0,
1867
+ totalTokensFresh: false,
1868
+ estimatedCostUsd: void 0,
1869
+ cacheRead: void 0,
1870
+ cacheWrite: void 0,
1871
+ contextTokens: void 0,
1872
+ systemPromptReport: void 0,
1873
+ fallbackNoticeSelectedModel: void 0,
1874
+ fallbackNoticeActiveModel: void 0,
1875
+ fallbackNoticeReason: void 0
1876
+ };
1877
+ const agentId = resolveAgentIdFromSessionKey(sessionKey);
1878
+ const nextSessionFile = resolveSessionTranscriptPath(nextSessionId, agentId, sessionCtx.MessageThreadId);
1879
+ nextEntry.sessionFile = nextSessionFile;
1880
+ activeSessionStore[sessionKey] = nextEntry;
1881
+ try {
1882
+ await updateSessionStore(storePath, (store) => {
1883
+ store[sessionKey] = nextEntry;
1884
+ });
1885
+ } catch (err) {
1886
+ defaultRuntime.error(`Failed to persist session reset after ${failureLabel} (${sessionKey}): ${String(err)}`);
1887
+ }
1888
+ followupRun.run.sessionId = nextSessionId;
1889
+ followupRun.run.sessionFile = nextSessionFile;
1890
+ refreshQueuedFollowupSession({
1891
+ key: queueKey,
1892
+ previousSessionId: prevEntry.sessionId,
1893
+ nextSessionId,
1894
+ nextSessionFile
1895
+ });
1896
+ activeSessionEntry = nextEntry;
1897
+ activeIsNewSession = true;
1898
+ defaultRuntime.error(buildLogMessage(nextSessionId));
1899
+ if (cleanupTranscripts && prevSessionId) {
1900
+ const transcriptCandidates = /* @__PURE__ */ new Set();
1901
+ const resolved = resolveSessionFilePath(prevSessionId, prevEntry, resolveSessionFilePathOptions({
1902
+ agentId,
1903
+ storePath
1904
+ }));
1905
+ if (resolved) transcriptCandidates.add(resolved);
1906
+ transcriptCandidates.add(resolveSessionTranscriptPath(prevSessionId, agentId));
1907
+ for (const candidate of transcriptCandidates) try {
1908
+ fsSync.unlinkSync(candidate);
1909
+ } catch {}
1910
+ }
1911
+ return true;
1912
+ };
1913
+ const resetSessionAfterCompactionFailure = async (reason) => resetSession({
1914
+ failureLabel: "compaction failure",
1915
+ buildLogMessage: (nextSessionId) => `Auto-compaction failed (${reason}). Restarting session ${sessionKey} -> ${nextSessionId} and retrying.`
1916
+ });
1917
+ const resetSessionAfterRoleOrderingConflict = async (reason) => resetSession({
1918
+ failureLabel: "role ordering conflict",
1919
+ buildLogMessage: (nextSessionId) => `Role ordering conflict (${reason}). Restarting session ${sessionKey} -> ${nextSessionId}.`,
1920
+ cleanupTranscripts: true
1921
+ });
1922
+ try {
1923
+ const runStartedAt = Date.now();
1924
+ const runOutcome = await runAgentTurnWithFallback({
1925
+ commandBody,
1926
+ followupRun,
1927
+ sessionCtx,
1928
+ opts,
1929
+ typingSignals,
1930
+ blockReplyPipeline,
1931
+ blockStreamingEnabled,
1932
+ blockReplyChunking,
1933
+ resolvedBlockStreamingBreak,
1934
+ applyReplyToMode,
1935
+ shouldEmitToolResult,
1936
+ shouldEmitToolOutput,
1937
+ pendingToolTasks,
1938
+ resetSessionAfterCompactionFailure,
1939
+ resetSessionAfterRoleOrderingConflict,
1940
+ isHeartbeat,
1941
+ sessionKey,
1942
+ getActiveSessionEntry: () => activeSessionEntry,
1943
+ activeSessionStore,
1944
+ storePath,
1945
+ resolvedVerboseLevel
1946
+ });
1947
+ if (runOutcome.kind === "final") return finalizeWithFollowup(runOutcome.payload, queueKey, runFollowupTurn);
1948
+ const { runId, runResult, fallbackProvider, fallbackModel, fallbackAttempts, directlySentBlockKeys } = runOutcome;
1949
+ let { didLogHeartbeatStrip, autoCompactionCount } = runOutcome;
1950
+ if (shouldInjectGroupIntro && activeSessionEntry && activeSessionStore && sessionKey && activeSessionEntry.groupActivationNeedsSystemIntro) {
1951
+ const updatedAt = Date.now();
1952
+ activeSessionEntry.groupActivationNeedsSystemIntro = false;
1953
+ activeSessionEntry.updatedAt = updatedAt;
1954
+ activeSessionStore[sessionKey] = activeSessionEntry;
1955
+ if (storePath) await updateSessionStoreEntry({
1956
+ storePath,
1957
+ sessionKey,
1958
+ update: async () => ({
1959
+ groupActivationNeedsSystemIntro: false,
1960
+ updatedAt
1961
+ })
1962
+ });
1963
+ }
1964
+ const payloadArray = runResult.payloads ?? [];
1965
+ if (blockReplyPipeline) {
1966
+ await blockReplyPipeline.flush({ force: true });
1967
+ blockReplyPipeline.stop();
1968
+ }
1969
+ if (pendingToolTasks.size > 0) await Promise.allSettled(pendingToolTasks);
1970
+ const usage = runResult.meta?.agentMeta?.usage;
1971
+ const promptTokens = runResult.meta?.agentMeta?.promptTokens;
1972
+ const modelUsed = runResult.meta?.agentMeta?.model ?? fallbackModel ?? defaultModel;
1973
+ const providerUsed = runResult.meta?.agentMeta?.provider ?? fallbackProvider ?? followupRun.run.provider;
1974
+ const verboseEnabled = resolvedVerboseLevel !== "off";
1975
+ const selectedProvider = followupRun.run.provider;
1976
+ const selectedModel = followupRun.run.model;
1977
+ const fallbackStateEntry = activeSessionEntry ?? (sessionKey ? activeSessionStore?.[sessionKey] : void 0);
1978
+ const fallbackTransition = resolveFallbackTransition({
1979
+ selectedProvider,
1980
+ selectedModel,
1981
+ activeProvider: providerUsed,
1982
+ activeModel: modelUsed,
1983
+ attempts: fallbackAttempts,
1984
+ state: fallbackStateEntry
1985
+ });
1986
+ if (fallbackTransition.stateChanged) {
1987
+ if (fallbackStateEntry) {
1988
+ fallbackStateEntry.fallbackNoticeSelectedModel = fallbackTransition.nextState.selectedModel;
1989
+ fallbackStateEntry.fallbackNoticeActiveModel = fallbackTransition.nextState.activeModel;
1990
+ fallbackStateEntry.fallbackNoticeReason = fallbackTransition.nextState.reason;
1991
+ fallbackStateEntry.updatedAt = Date.now();
1992
+ activeSessionEntry = fallbackStateEntry;
1993
+ }
1994
+ if (sessionKey && fallbackStateEntry && activeSessionStore) activeSessionStore[sessionKey] = fallbackStateEntry;
1995
+ if (sessionKey && storePath) await updateSessionStoreEntry({
1996
+ storePath,
1997
+ sessionKey,
1998
+ update: async () => ({
1999
+ fallbackNoticeSelectedModel: fallbackTransition.nextState.selectedModel,
2000
+ fallbackNoticeActiveModel: fallbackTransition.nextState.activeModel,
2001
+ fallbackNoticeReason: fallbackTransition.nextState.reason
2002
+ })
2003
+ });
2004
+ }
2005
+ const cliSessionId = isCliProvider(providerUsed, cfg) ? runResult.meta?.agentMeta?.sessionId?.trim() : void 0;
2006
+ const cliSessionBinding = isCliProvider(providerUsed, cfg) ? runResult.meta?.agentMeta?.cliSessionBinding : void 0;
2007
+ const contextTokensUsed = agentCfgContextTokens ?? lookupContextTokens(modelUsed) ?? activeSessionEntry?.contextTokens ?? 2e5;
2008
+ await persistRunSessionUsage({
2009
+ storePath,
2010
+ sessionKey,
2011
+ cfg,
2012
+ usage,
2013
+ lastCallUsage: runResult.meta?.agentMeta?.lastCallUsage,
2014
+ promptTokens,
2015
+ modelUsed,
2016
+ providerUsed,
2017
+ contextTokensUsed,
2018
+ systemPromptReport: runResult.meta?.systemPromptReport,
2019
+ cliSessionId,
2020
+ cliSessionBinding,
2021
+ usageIsContextSnapshot: isCliProvider(providerUsed, cfg)
2022
+ });
2023
+ if (payloadArray.length === 0) return finalizeWithFollowup(void 0, queueKey, runFollowupTurn);
2024
+ const payloadResult = await buildReplyPayloads({
2025
+ payloads: payloadArray,
2026
+ isHeartbeat,
2027
+ didLogHeartbeatStrip,
2028
+ silentExpected: followupRun.run.silentExpected,
2029
+ blockStreamingEnabled,
2030
+ blockReplyPipeline,
2031
+ directlySentBlockKeys,
2032
+ replyToMode,
2033
+ replyToChannel,
2034
+ currentMessageId: sessionCtx.MessageSidFull ?? sessionCtx.MessageSid,
2035
+ messageProvider: followupRun.run.messageProvider,
2036
+ messagingToolSentTexts: runResult.messagingToolSentTexts,
2037
+ messagingToolSentMediaUrls: runResult.messagingToolSentMediaUrls,
2038
+ messagingToolSentTargets: runResult.messagingToolSentTargets,
2039
+ originatingChannel: sessionCtx.OriginatingChannel,
2040
+ originatingTo: resolveOriginMessageTo({
2041
+ originatingTo: sessionCtx.OriginatingTo,
2042
+ to: sessionCtx.To
2043
+ }),
2044
+ accountId: sessionCtx.AccountId,
2045
+ normalizeMediaPaths: normalizeReplyMediaPaths
2046
+ });
2047
+ const { replyPayloads } = payloadResult;
2048
+ didLogHeartbeatStrip = payloadResult.didLogHeartbeatStrip;
2049
+ if (replyPayloads.length === 0) return finalizeWithFollowup(void 0, queueKey, runFollowupTurn);
2050
+ const successfulCronAdds = runResult.successfulCronAdds ?? 0;
2051
+ const hasReminderCommitment = replyPayloads.some((payload) => !payload.isError && typeof payload.text === "string" && hasUnbackedReminderCommitment(payload.text));
2052
+ const coveredByExistingCron = hasReminderCommitment && successfulCronAdds === 0 ? await hasSessionRelatedCronJobs({
2053
+ cronStorePath: cfg.cron?.store,
2054
+ sessionKey
2055
+ }) : false;
2056
+ const guardedReplyPayloads = hasReminderCommitment && successfulCronAdds === 0 && !coveredByExistingCron ? appendUnscheduledReminderNote(replyPayloads) : replyPayloads;
2057
+ await signalTypingIfNeeded(guardedReplyPayloads, typingSignals);
2058
+ if (isDiagnosticsEnabled(cfg) && hasNonzeroUsage(usage)) {
2059
+ const input = usage.input ?? 0;
2060
+ const output = usage.output ?? 0;
2061
+ const cacheRead = usage.cacheRead ?? 0;
2062
+ const cacheWrite = usage.cacheWrite ?? 0;
2063
+ const promptTokens = input + cacheRead + cacheWrite;
2064
+ const totalTokens = usage.total ?? promptTokens + output;
2065
+ const costUsd = estimateUsageCost({
2066
+ usage,
2067
+ cost: resolveModelCostConfig({
2068
+ provider: providerUsed,
2069
+ model: modelUsed,
2070
+ config: cfg
2071
+ })
2072
+ });
2073
+ emitDiagnosticEvent({
2074
+ type: "model.usage",
2075
+ sessionKey,
2076
+ sessionId: followupRun.run.sessionId,
2077
+ channel: replyToChannel,
2078
+ provider: providerUsed,
2079
+ model: modelUsed,
2080
+ usage: {
2081
+ input,
2082
+ output,
2083
+ cacheRead,
2084
+ cacheWrite,
2085
+ promptTokens,
2086
+ total: totalTokens
2087
+ },
2088
+ lastCallUsage: runResult.meta?.agentMeta?.lastCallUsage,
2089
+ context: {
2090
+ limit: contextTokensUsed,
2091
+ used: totalTokens
2092
+ },
2093
+ costUsd,
2094
+ durationMs: Date.now() - runStartedAt
2095
+ });
2096
+ }
2097
+ const responseUsageMode = resolveResponseUsageMode(activeSessionEntry?.responseUsage ?? (sessionKey ? activeSessionStore?.[sessionKey]?.responseUsage : void 0));
2098
+ if (responseUsageMode !== "off" && hasNonzeroUsage(usage)) {
2099
+ const showCost = resolveModelAuthMode(providerUsed, cfg) === "api-key";
2100
+ let formatted = formatResponseUsageLine({
2101
+ usage,
2102
+ showCost,
2103
+ costConfig: showCost ? resolveModelCostConfig({
2104
+ provider: providerUsed,
2105
+ model: modelUsed,
2106
+ config: cfg
2107
+ }) : void 0
2108
+ });
2109
+ if (formatted && responseUsageMode === "full" && sessionKey) formatted = `${formatted} · session \`${sessionKey}\``;
2110
+ if (formatted) responseUsageLine = formatted;
2111
+ }
2112
+ let finalPayloads = guardedReplyPayloads;
2113
+ const verboseNotices = [];
2114
+ if (verboseEnabled && activeIsNewSession) verboseNotices.push({ text: `🧭 New session: ${followupRun.run.sessionId}` });
2115
+ if (fallbackTransition.fallbackTransitioned) {
2116
+ emitAgentEvent({
2117
+ runId,
2118
+ sessionKey,
2119
+ stream: "lifecycle",
2120
+ data: {
2121
+ phase: "fallback",
2122
+ selectedProvider,
2123
+ selectedModel,
2124
+ activeProvider: providerUsed,
2125
+ activeModel: modelUsed,
2126
+ reasonSummary: fallbackTransition.reasonSummary,
2127
+ attemptSummaries: fallbackTransition.attemptSummaries,
2128
+ attempts: fallbackAttempts
2129
+ }
2130
+ });
2131
+ if (verboseEnabled) {
2132
+ const fallbackNotice = buildFallbackNotice({
2133
+ selectedProvider,
2134
+ selectedModel,
2135
+ activeProvider: providerUsed,
2136
+ activeModel: modelUsed,
2137
+ attempts: fallbackAttempts
2138
+ });
2139
+ if (fallbackNotice) verboseNotices.push({ text: fallbackNotice });
2140
+ }
2141
+ }
2142
+ if (fallbackTransition.fallbackCleared) {
2143
+ emitAgentEvent({
2144
+ runId,
2145
+ sessionKey,
2146
+ stream: "lifecycle",
2147
+ data: {
2148
+ phase: "fallback_cleared",
2149
+ selectedProvider,
2150
+ selectedModel,
2151
+ activeProvider: providerUsed,
2152
+ activeModel: modelUsed,
2153
+ previousActiveModel: fallbackTransition.previousState.activeModel
2154
+ }
2155
+ });
2156
+ if (verboseEnabled) verboseNotices.push({ text: buildFallbackClearedNotice({
2157
+ selectedProvider,
2158
+ selectedModel,
2159
+ previousActiveModel: fallbackTransition.previousState.activeModel
2160
+ }) });
2161
+ }
2162
+ if (autoCompactionCount > 0) {
2163
+ const previousSessionId = activeSessionEntry?.sessionId ?? followupRun.run.sessionId;
2164
+ const count = await incrementRunCompactionCount({
2165
+ sessionEntry: activeSessionEntry,
2166
+ sessionStore: activeSessionStore,
2167
+ sessionKey,
2168
+ storePath,
2169
+ amount: autoCompactionCount,
2170
+ lastCallUsage: runResult.meta?.agentMeta?.lastCallUsage,
2171
+ contextTokensUsed,
2172
+ newSessionId: runResult.meta?.agentMeta?.sessionId
2173
+ });
2174
+ const refreshedSessionEntry = sessionKey && activeSessionStore ? activeSessionStore[sessionKey] : void 0;
2175
+ if (refreshedSessionEntry) {
2176
+ activeSessionEntry = refreshedSessionEntry;
2177
+ refreshQueuedFollowupSession({
2178
+ key: queueKey,
2179
+ previousSessionId,
2180
+ nextSessionId: refreshedSessionEntry.sessionId,
2181
+ nextSessionFile: refreshedSessionEntry.sessionFile
2182
+ });
2183
+ }
2184
+ if (sessionKey) readPostCompactionContext(process.cwd(), cfg).then((contextContent) => {
2185
+ if (contextContent) enqueueSystemEvent(contextContent, { sessionKey });
2186
+ }).catch(() => {});
2187
+ if (verboseEnabled) {
2188
+ const suffix = typeof count === "number" ? ` (count ${count})` : "";
2189
+ verboseNotices.push({ text: `🧹 Auto-compaction complete${suffix}.` });
2190
+ }
2191
+ }
2192
+ if (verboseNotices.length > 0) finalPayloads = [...verboseNotices, ...finalPayloads];
2193
+ if (responseUsageLine) finalPayloads = appendUsageLine(finalPayloads, responseUsageLine);
2194
+ return finalizeWithFollowup(finalPayloads.length === 1 ? finalPayloads[0] : finalPayloads, queueKey, runFollowupTurn);
2195
+ } catch (error) {
2196
+ finalizeWithFollowup(void 0, queueKey, runFollowupTurn);
2197
+ throw error;
2198
+ } finally {
2199
+ blockReplyPipeline?.stop();
2200
+ typing.markRunComplete();
2201
+ typing.markDispatchIdle();
2202
+ }
2203
+ }
2204
+ //#endregion
2205
+ export { runReplyAgent };