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,1891 @@
1
+ import { d as resolveSecretInputRef, i as coerceSecretRef } from "./types.secrets-CxoujPzV.js";
2
+ import { u as secretRefKey } from "./ref-contract-D5ynmOGd.js";
3
+ import { _ as normalizeAccountId } from "./session-key-BIrdMs11.js";
4
+ import { Wt as listBundledWebSearchPluginIds } from "./io-B07IaARR.js";
5
+ import { a as normalizePluginsConfig, s as resolveEnableState } from "./config-state-CiYvCzdZ.js";
6
+ import { n as isNonEmptyString, r as isRecord$1 } from "./shared-B0P4kmoP.js";
7
+ import { o as resolveSecretRefValues } from "./resolve-BjvAwAfZ.js";
8
+ import { n as normalizeSecretInput } from "./normalize-secret-input-Botsab7G.js";
9
+ import { t as createGatewayCredentialPlan } from "./credential-planner-B6V18E6X.js";
10
+ import { d as getPath, r as discoverConfigSecretTargetsByIds } from "./target-registry-Je8d-VjB.js";
11
+ import { n as getMatrixScopedEnvVarNames } from "./matrix-config-helpers-CXItIHIe.js";
12
+ import { r as sortWebSearchProvidersForAutoDetect, s as resolveBundledWebSearchPluginId } from "./web-search-providers.shared-BDbtn1DP.js";
13
+ import { t as resolveBundledPluginWebSearchProviders } from "./web-search-providers-Dzq6HxbB.js";
14
+ import { t as resolvePluginWebSearchProviders } from "./web-search-providers.runtime-CtA0c8j7.js";
15
+ //#region src/secrets/secret-value.ts
16
+ function isExpectedResolvedSecretValue(value, expected) {
17
+ if (expected === "string") return isNonEmptyString(value);
18
+ return isNonEmptyString(value) || isRecord$1(value);
19
+ }
20
+ function hasConfiguredPlaintextSecretValue(value, expected) {
21
+ if (expected === "string") return isNonEmptyString(value);
22
+ return isNonEmptyString(value) || isRecord$1(value) && Object.keys(value).length > 0;
23
+ }
24
+ function assertExpectedResolvedSecretValue(params) {
25
+ if (!isExpectedResolvedSecretValue(params.value, params.expected)) throw new Error(params.errorMessage);
26
+ }
27
+ //#endregion
28
+ //#region src/secrets/command-config.ts
29
+ function analyzeCommandSecretAssignmentsFromSnapshot(params) {
30
+ const defaults = params.sourceConfig.secrets?.defaults;
31
+ const assignments = [];
32
+ const diagnostics = [];
33
+ const unresolved = [];
34
+ const inactive = [];
35
+ for (const target of discoverConfigSecretTargetsByIds(params.sourceConfig, params.targetIds)) {
36
+ if (params.allowedPaths && !params.allowedPaths.has(target.path)) continue;
37
+ const { explicitRef, ref } = resolveSecretInputRef({
38
+ value: target.value,
39
+ refValue: target.refValue,
40
+ defaults
41
+ });
42
+ const inlineCandidateRef = explicitRef ? coerceSecretRef(target.value, defaults) : null;
43
+ if (!ref) continue;
44
+ const resolved = getPath(params.resolvedConfig, target.pathSegments);
45
+ if (!isExpectedResolvedSecretValue(resolved, target.entry.expectedResolvedValue)) {
46
+ if (params.inactiveRefPaths?.has(target.path)) {
47
+ diagnostics.push(`${target.path}: secret ref is configured on an inactive surface; skipping command-time assignment.`);
48
+ inactive.push({
49
+ path: target.path,
50
+ pathSegments: [...target.pathSegments]
51
+ });
52
+ continue;
53
+ }
54
+ unresolved.push({
55
+ path: target.path,
56
+ pathSegments: [...target.pathSegments]
57
+ });
58
+ continue;
59
+ }
60
+ assignments.push({
61
+ path: target.path,
62
+ pathSegments: [...target.pathSegments],
63
+ value: resolved
64
+ });
65
+ if (target.entry.secretShape === "sibling_ref" && explicitRef && inlineCandidateRef) diagnostics.push(`${target.path}: both inline and sibling ref were present; sibling ref took precedence.`);
66
+ }
67
+ return {
68
+ assignments,
69
+ diagnostics,
70
+ unresolved,
71
+ inactive
72
+ };
73
+ }
74
+ function collectCommandSecretAssignmentsFromSnapshot(params) {
75
+ const analyzed = analyzeCommandSecretAssignmentsFromSnapshot({
76
+ sourceConfig: params.sourceConfig,
77
+ resolvedConfig: params.resolvedConfig,
78
+ targetIds: params.targetIds,
79
+ inactiveRefPaths: params.inactiveRefPaths,
80
+ allowedPaths: params.allowedPaths
81
+ });
82
+ if (analyzed.unresolved.length > 0) throw new Error(`${params.commandName}: ${analyzed.unresolved[0]?.path ?? "target"} is unresolved in the active runtime snapshot.`);
83
+ return {
84
+ assignments: analyzed.assignments,
85
+ diagnostics: analyzed.diagnostics
86
+ };
87
+ }
88
+ //#endregion
89
+ //#region src/secrets/runtime-shared.ts
90
+ function createResolverContext(params) {
91
+ return {
92
+ sourceConfig: params.sourceConfig,
93
+ env: params.env,
94
+ cache: {},
95
+ warnings: [],
96
+ warningKeys: /* @__PURE__ */ new Set(),
97
+ assignments: []
98
+ };
99
+ }
100
+ function pushAssignment(context, assignment) {
101
+ context.assignments.push(assignment);
102
+ }
103
+ function pushWarning(context, warning) {
104
+ const warningKey = `${warning.code}:${warning.path}:${warning.message}`;
105
+ if (context.warningKeys.has(warningKey)) return;
106
+ context.warningKeys.add(warningKey);
107
+ context.warnings.push(warning);
108
+ }
109
+ function pushInactiveSurfaceWarning(params) {
110
+ pushWarning(params.context, {
111
+ code: "SECRETS_REF_IGNORED_INACTIVE_SURFACE",
112
+ path: params.path,
113
+ message: params.details && params.details.trim().length > 0 ? `${params.path}: ${params.details}` : `${params.path}: secret ref is configured on an inactive surface; skipping resolution until it becomes active.`
114
+ });
115
+ }
116
+ function collectSecretInputAssignment(params) {
117
+ const ref = coerceSecretRef(params.value, params.defaults);
118
+ if (!ref) return;
119
+ if (params.active === false) {
120
+ pushInactiveSurfaceWarning({
121
+ context: params.context,
122
+ path: params.path,
123
+ details: params.inactiveReason
124
+ });
125
+ return;
126
+ }
127
+ pushAssignment(params.context, {
128
+ ref,
129
+ path: params.path,
130
+ expected: params.expected,
131
+ apply: params.apply
132
+ });
133
+ }
134
+ function applyResolvedAssignments(params) {
135
+ for (const assignment of params.assignments) {
136
+ const key = secretRefKey(assignment.ref);
137
+ if (!params.resolved.has(key)) throw new Error(`Secret reference "${key}" resolved to no value.`);
138
+ const value = params.resolved.get(key);
139
+ assertExpectedResolvedSecretValue({
140
+ value,
141
+ expected: assignment.expected,
142
+ errorMessage: assignment.expected === "string" ? `${assignment.path} resolved to a non-string or empty value.` : `${assignment.path} resolved to an unsupported value type.`
143
+ });
144
+ assignment.apply(value);
145
+ }
146
+ }
147
+ function hasOwnProperty(record, key) {
148
+ return Object.prototype.hasOwnProperty.call(record, key);
149
+ }
150
+ function isEnabledFlag(value) {
151
+ if (!isRecord$1(value)) return true;
152
+ return value.enabled !== false;
153
+ }
154
+ function isChannelAccountEffectivelyEnabled(channel, account) {
155
+ return isEnabledFlag(channel) && isEnabledFlag(account);
156
+ }
157
+ //#endregion
158
+ //#region src/secrets/runtime-config-collectors-tts.ts
159
+ function collectProviderApiKeyAssignment(params) {
160
+ collectSecretInputAssignment({
161
+ value: params.providerConfig.apiKey,
162
+ path: `${params.pathPrefix}.providers.${params.providerId}.apiKey`,
163
+ expected: "string",
164
+ defaults: params.defaults,
165
+ context: params.context,
166
+ active: params.active,
167
+ inactiveReason: params.inactiveReason,
168
+ apply: (value) => {
169
+ params.providerConfig.apiKey = value;
170
+ }
171
+ });
172
+ }
173
+ function collectTtsApiKeyAssignments(params) {
174
+ const providers = params.tts.providers;
175
+ if (isRecord$1(providers)) {
176
+ for (const [providerId, providerConfig] of Object.entries(providers)) {
177
+ if (!isRecord$1(providerConfig)) continue;
178
+ collectProviderApiKeyAssignment({
179
+ providerId,
180
+ providerConfig,
181
+ pathPrefix: params.pathPrefix,
182
+ defaults: params.defaults,
183
+ context: params.context,
184
+ active: params.active,
185
+ inactiveReason: params.inactiveReason
186
+ });
187
+ }
188
+ return;
189
+ }
190
+ }
191
+ //#endregion
192
+ //#region src/secrets/runtime-config-collectors-channels.ts
193
+ function getChannelRecord(config, channelKey) {
194
+ const channels = config.channels;
195
+ if (!isRecord$1(channels)) return;
196
+ const channel = channels[channelKey];
197
+ return isRecord$1(channel) ? channel : void 0;
198
+ }
199
+ function getChannelSurface(config, channelKey) {
200
+ const channel = getChannelRecord(config, channelKey);
201
+ if (!channel) return null;
202
+ return {
203
+ channel,
204
+ surface: resolveChannelAccountSurface(channel)
205
+ };
206
+ }
207
+ function resolveChannelAccountSurface(channel) {
208
+ const channelEnabled = isEnabledFlag(channel);
209
+ const accounts = channel.accounts;
210
+ if (!isRecord$1(accounts) || Object.keys(accounts).length === 0) return {
211
+ hasExplicitAccounts: false,
212
+ channelEnabled,
213
+ accounts: [{
214
+ accountId: "default",
215
+ account: channel,
216
+ enabled: channelEnabled
217
+ }]
218
+ };
219
+ const accountEntries = [];
220
+ for (const [accountId, account] of Object.entries(accounts)) {
221
+ if (!isRecord$1(account)) continue;
222
+ accountEntries.push({
223
+ accountId,
224
+ account,
225
+ enabled: isChannelAccountEffectivelyEnabled(channel, account)
226
+ });
227
+ }
228
+ return {
229
+ hasExplicitAccounts: true,
230
+ channelEnabled,
231
+ accounts: accountEntries
232
+ };
233
+ }
234
+ function isBaseFieldActiveForChannelSurface(surface, rootKey) {
235
+ if (!surface.channelEnabled) return false;
236
+ if (!surface.hasExplicitAccounts) return true;
237
+ return surface.accounts.some(({ account, enabled }) => enabled && !hasOwnProperty(account, rootKey));
238
+ }
239
+ function normalizeSecretStringValue(value) {
240
+ return typeof value === "string" ? value.trim() : "";
241
+ }
242
+ function hasConfiguredSecretInputValue(value, defaults) {
243
+ return normalizeSecretStringValue(value).length > 0 || coerceSecretRef(value, defaults) !== null;
244
+ }
245
+ function collectSimpleChannelFieldAssignments(params) {
246
+ collectSecretInputAssignment({
247
+ value: params.channel[params.field],
248
+ path: `channels.${params.channelKey}.${params.field}`,
249
+ expected: "string",
250
+ defaults: params.defaults,
251
+ context: params.context,
252
+ active: isBaseFieldActiveForChannelSurface(params.surface, params.field),
253
+ inactiveReason: params.topInactiveReason,
254
+ apply: (value) => {
255
+ params.channel[params.field] = value;
256
+ }
257
+ });
258
+ if (!params.surface.hasExplicitAccounts) return;
259
+ for (const { accountId, account, enabled } of params.surface.accounts) {
260
+ if (!hasOwnProperty(account, params.field)) continue;
261
+ collectSecretInputAssignment({
262
+ value: account[params.field],
263
+ path: `channels.${params.channelKey}.accounts.${accountId}.${params.field}`,
264
+ expected: "string",
265
+ defaults: params.defaults,
266
+ context: params.context,
267
+ active: enabled,
268
+ inactiveReason: params.accountInactiveReason,
269
+ apply: (value) => {
270
+ account[params.field] = value;
271
+ }
272
+ });
273
+ }
274
+ }
275
+ function isConditionalTopLevelFieldActive(params) {
276
+ if (!params.surface.channelEnabled) return false;
277
+ if (!params.surface.hasExplicitAccounts) return params.activeWithoutAccounts;
278
+ return params.surface.accounts.some(params.inheritedAccountActive);
279
+ }
280
+ function collectConditionalChannelFieldAssignments(params) {
281
+ collectSecretInputAssignment({
282
+ value: params.channel[params.field],
283
+ path: `channels.${params.channelKey}.${params.field}`,
284
+ expected: "string",
285
+ defaults: params.defaults,
286
+ context: params.context,
287
+ active: isConditionalTopLevelFieldActive({
288
+ surface: params.surface,
289
+ activeWithoutAccounts: params.topLevelActiveWithoutAccounts,
290
+ inheritedAccountActive: params.topLevelInheritedAccountActive
291
+ }),
292
+ inactiveReason: params.topInactiveReason,
293
+ apply: (value) => {
294
+ params.channel[params.field] = value;
295
+ }
296
+ });
297
+ if (!params.surface.hasExplicitAccounts) return;
298
+ for (const entry of params.surface.accounts) {
299
+ if (!hasOwnProperty(entry.account, params.field)) continue;
300
+ collectSecretInputAssignment({
301
+ value: entry.account[params.field],
302
+ path: `channels.${params.channelKey}.accounts.${entry.accountId}.${params.field}`,
303
+ expected: "string",
304
+ defaults: params.defaults,
305
+ context: params.context,
306
+ active: params.accountActive(entry),
307
+ inactiveReason: typeof params.accountInactiveReason === "function" ? params.accountInactiveReason(entry) : params.accountInactiveReason,
308
+ apply: (value) => {
309
+ entry.account[params.field] = value;
310
+ }
311
+ });
312
+ }
313
+ }
314
+ function collectNestedChannelFieldAssignments(params) {
315
+ const topLevelNested = params.channel[params.nestedKey];
316
+ if (isRecord$1(topLevelNested)) collectSecretInputAssignment({
317
+ value: topLevelNested[params.field],
318
+ path: `channels.${params.channelKey}.${params.nestedKey}.${params.field}`,
319
+ expected: "string",
320
+ defaults: params.defaults,
321
+ context: params.context,
322
+ active: params.topLevelActive,
323
+ inactiveReason: params.topInactiveReason,
324
+ apply: (value) => {
325
+ topLevelNested[params.field] = value;
326
+ }
327
+ });
328
+ if (!params.surface.hasExplicitAccounts) return;
329
+ for (const entry of params.surface.accounts) {
330
+ const nested = entry.account[params.nestedKey];
331
+ if (!isRecord$1(nested)) continue;
332
+ collectSecretInputAssignment({
333
+ value: nested[params.field],
334
+ path: `channels.${params.channelKey}.accounts.${entry.accountId}.${params.nestedKey}.${params.field}`,
335
+ expected: "string",
336
+ defaults: params.defaults,
337
+ context: params.context,
338
+ active: params.accountActive(entry),
339
+ inactiveReason: typeof params.accountInactiveReason === "function" ? params.accountInactiveReason(entry) : params.accountInactiveReason,
340
+ apply: (value) => {
341
+ nested[params.field] = value;
342
+ }
343
+ });
344
+ }
345
+ }
346
+ function collectNestedChannelTtsAssignments(params) {
347
+ const topLevelNested = params.channel[params.nestedKey];
348
+ if (isRecord$1(topLevelNested) && isRecord$1(topLevelNested.tts)) collectTtsApiKeyAssignments({
349
+ tts: topLevelNested.tts,
350
+ pathPrefix: `channels.${params.channelKey}.${params.nestedKey}.tts`,
351
+ defaults: params.defaults,
352
+ context: params.context,
353
+ active: params.topLevelActive,
354
+ inactiveReason: params.topInactiveReason
355
+ });
356
+ if (!params.surface.hasExplicitAccounts) return;
357
+ for (const entry of params.surface.accounts) {
358
+ const nested = entry.account[params.nestedKey];
359
+ if (!isRecord$1(nested) || !isRecord$1(nested.tts)) continue;
360
+ collectTtsApiKeyAssignments({
361
+ tts: nested.tts,
362
+ pathPrefix: `channels.${params.channelKey}.accounts.${entry.accountId}.${params.nestedKey}.tts`,
363
+ defaults: params.defaults,
364
+ context: params.context,
365
+ active: params.accountActive(entry),
366
+ inactiveReason: typeof params.accountInactiveReason === "function" ? params.accountInactiveReason(entry) : params.accountInactiveReason
367
+ });
368
+ }
369
+ }
370
+ function collectTelegramAssignments(params) {
371
+ const resolved = getChannelSurface(params.config, "telegram");
372
+ if (!resolved) return;
373
+ const { channel: telegram, surface } = resolved;
374
+ const baseTokenFile = typeof telegram.tokenFile === "string" ? telegram.tokenFile.trim() : "";
375
+ const accountTokenFile = (account) => typeof account.tokenFile === "string" ? account.tokenFile.trim() : "";
376
+ collectConditionalChannelFieldAssignments({
377
+ channelKey: "telegram",
378
+ field: "botToken",
379
+ channel: telegram,
380
+ surface,
381
+ defaults: params.defaults,
382
+ context: params.context,
383
+ topLevelActiveWithoutAccounts: baseTokenFile.length === 0,
384
+ topLevelInheritedAccountActive: ({ account, enabled }) => {
385
+ if (!enabled || baseTokenFile.length > 0) return false;
386
+ return !hasConfiguredSecretInputValue(account.botToken, params.defaults) && accountTokenFile(account).length === 0;
387
+ },
388
+ accountActive: ({ account, enabled }) => enabled && accountTokenFile(account).length === 0,
389
+ topInactiveReason: "no enabled Telegram surface inherits this top-level botToken (tokenFile is configured).",
390
+ accountInactiveReason: "Telegram account is disabled or tokenFile is configured."
391
+ });
392
+ const baseWebhookUrl = typeof telegram.webhookUrl === "string" ? telegram.webhookUrl.trim() : "";
393
+ const accountWebhookUrl = (account) => hasOwnProperty(account, "webhookUrl") ? typeof account.webhookUrl === "string" ? account.webhookUrl.trim() : "" : baseWebhookUrl;
394
+ collectConditionalChannelFieldAssignments({
395
+ channelKey: "telegram",
396
+ field: "webhookSecret",
397
+ channel: telegram,
398
+ surface,
399
+ defaults: params.defaults,
400
+ context: params.context,
401
+ topLevelActiveWithoutAccounts: baseWebhookUrl.length > 0,
402
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "webhookSecret") && accountWebhookUrl(account).length > 0,
403
+ accountActive: ({ account, enabled }) => enabled && accountWebhookUrl(account).length > 0,
404
+ topInactiveReason: "no enabled Telegram webhook surface inherits this top-level webhookSecret (webhook mode is not active).",
405
+ accountInactiveReason: "Telegram account is disabled or webhook mode is not active for this account."
406
+ });
407
+ }
408
+ function collectSlackAssignments(params) {
409
+ const resolved = getChannelSurface(params.config, "slack");
410
+ if (!resolved) return;
411
+ const { channel: slack, surface } = resolved;
412
+ const baseMode = slack.mode === "http" || slack.mode === "socket" ? slack.mode : "socket";
413
+ for (const field of ["botToken", "userToken"]) collectSimpleChannelFieldAssignments({
414
+ channelKey: "slack",
415
+ field,
416
+ channel: slack,
417
+ surface,
418
+ defaults: params.defaults,
419
+ context: params.context,
420
+ topInactiveReason: `no enabled account inherits this top-level Slack ${field}.`,
421
+ accountInactiveReason: "Slack account is disabled."
422
+ });
423
+ const resolveAccountMode = (account) => account.mode === "http" || account.mode === "socket" ? account.mode : baseMode;
424
+ collectConditionalChannelFieldAssignments({
425
+ channelKey: "slack",
426
+ field: "appToken",
427
+ channel: slack,
428
+ surface,
429
+ defaults: params.defaults,
430
+ context: params.context,
431
+ topLevelActiveWithoutAccounts: baseMode !== "http",
432
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "appToken") && resolveAccountMode(account) !== "http",
433
+ accountActive: ({ account, enabled }) => enabled && resolveAccountMode(account) !== "http",
434
+ topInactiveReason: "no enabled Slack socket-mode surface inherits this top-level appToken.",
435
+ accountInactiveReason: "Slack account is disabled or not running in socket mode."
436
+ });
437
+ collectConditionalChannelFieldAssignments({
438
+ channelKey: "slack",
439
+ field: "signingSecret",
440
+ channel: slack,
441
+ surface,
442
+ defaults: params.defaults,
443
+ context: params.context,
444
+ topLevelActiveWithoutAccounts: baseMode === "http",
445
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "signingSecret") && resolveAccountMode(account) === "http",
446
+ accountActive: ({ account, enabled }) => enabled && resolveAccountMode(account) === "http",
447
+ topInactiveReason: "no enabled Slack HTTP-mode surface inherits this top-level signingSecret.",
448
+ accountInactiveReason: "Slack account is disabled or not running in HTTP mode."
449
+ });
450
+ }
451
+ function collectDiscordAssignments(params) {
452
+ const resolved = getChannelSurface(params.config, "discord");
453
+ if (!resolved) return;
454
+ const { channel: discord, surface } = resolved;
455
+ collectSimpleChannelFieldAssignments({
456
+ channelKey: "discord",
457
+ field: "token",
458
+ channel: discord,
459
+ surface,
460
+ defaults: params.defaults,
461
+ context: params.context,
462
+ topInactiveReason: "no enabled account inherits this top-level Discord token.",
463
+ accountInactiveReason: "Discord account is disabled."
464
+ });
465
+ collectNestedChannelFieldAssignments({
466
+ channelKey: "discord",
467
+ nestedKey: "pluralkit",
468
+ field: "token",
469
+ channel: discord,
470
+ surface,
471
+ defaults: params.defaults,
472
+ context: params.context,
473
+ topLevelActive: isBaseFieldActiveForChannelSurface(surface, "pluralkit") && isRecord$1(discord.pluralkit) && isEnabledFlag(discord.pluralkit),
474
+ topInactiveReason: "no enabled Discord surface inherits this top-level PluralKit config or PluralKit is disabled.",
475
+ accountActive: ({ account, enabled }) => enabled && isRecord$1(account.pluralkit) && isEnabledFlag(account.pluralkit),
476
+ accountInactiveReason: "Discord account is disabled or PluralKit is disabled for this account."
477
+ });
478
+ collectNestedChannelTtsAssignments({
479
+ channelKey: "discord",
480
+ nestedKey: "voice",
481
+ channel: discord,
482
+ surface,
483
+ defaults: params.defaults,
484
+ context: params.context,
485
+ topLevelActive: isBaseFieldActiveForChannelSurface(surface, "voice") && isRecord$1(discord.voice) && isEnabledFlag(discord.voice),
486
+ topInactiveReason: "no enabled Discord surface inherits this top-level voice config or voice is disabled.",
487
+ accountActive: ({ account, enabled }) => enabled && isRecord$1(account.voice) && isEnabledFlag(account.voice),
488
+ accountInactiveReason: "Discord account is disabled or voice is disabled for this account."
489
+ });
490
+ }
491
+ function collectIrcAssignments(params) {
492
+ const resolved = getChannelSurface(params.config, "irc");
493
+ if (!resolved) return;
494
+ const { channel: irc, surface } = resolved;
495
+ collectSimpleChannelFieldAssignments({
496
+ channelKey: "irc",
497
+ field: "password",
498
+ channel: irc,
499
+ surface,
500
+ defaults: params.defaults,
501
+ context: params.context,
502
+ topInactiveReason: "no enabled account inherits this top-level IRC password.",
503
+ accountInactiveReason: "IRC account is disabled."
504
+ });
505
+ collectNestedChannelFieldAssignments({
506
+ channelKey: "irc",
507
+ nestedKey: "nickserv",
508
+ field: "password",
509
+ channel: irc,
510
+ surface,
511
+ defaults: params.defaults,
512
+ context: params.context,
513
+ topLevelActive: isBaseFieldActiveForChannelSurface(surface, "nickserv") && isRecord$1(irc.nickserv) && isEnabledFlag(irc.nickserv),
514
+ topInactiveReason: "no enabled account inherits this top-level IRC nickserv config or NickServ is disabled.",
515
+ accountActive: ({ account, enabled }) => enabled && isRecord$1(account.nickserv) && isEnabledFlag(account.nickserv),
516
+ accountInactiveReason: "IRC account is disabled or NickServ is disabled for this account."
517
+ });
518
+ }
519
+ function collectBlueBubblesAssignments(params) {
520
+ const resolved = getChannelSurface(params.config, "bluebubbles");
521
+ if (!resolved) return;
522
+ const { channel: bluebubbles, surface } = resolved;
523
+ collectSimpleChannelFieldAssignments({
524
+ channelKey: "bluebubbles",
525
+ field: "password",
526
+ channel: bluebubbles,
527
+ surface,
528
+ defaults: params.defaults,
529
+ context: params.context,
530
+ topInactiveReason: "no enabled account inherits this top-level BlueBubbles password.",
531
+ accountInactiveReason: "BlueBubbles account is disabled."
532
+ });
533
+ }
534
+ function collectMSTeamsAssignments(params) {
535
+ const msteams = getChannelRecord(params.config, "msteams");
536
+ if (!msteams) return;
537
+ collectSecretInputAssignment({
538
+ value: msteams.appPassword,
539
+ path: "channels.msteams.appPassword",
540
+ expected: "string",
541
+ defaults: params.defaults,
542
+ context: params.context,
543
+ active: msteams.enabled !== false,
544
+ inactiveReason: "Microsoft Teams channel is disabled.",
545
+ apply: (value) => {
546
+ msteams.appPassword = value;
547
+ }
548
+ });
549
+ }
550
+ function collectMattermostAssignments(params) {
551
+ const resolved = getChannelSurface(params.config, "mattermost");
552
+ if (!resolved) return;
553
+ const { channel: mattermost, surface } = resolved;
554
+ collectSimpleChannelFieldAssignments({
555
+ channelKey: "mattermost",
556
+ field: "botToken",
557
+ channel: mattermost,
558
+ surface,
559
+ defaults: params.defaults,
560
+ context: params.context,
561
+ topInactiveReason: "no enabled account inherits this top-level Mattermost botToken.",
562
+ accountInactiveReason: "Mattermost account is disabled."
563
+ });
564
+ }
565
+ function collectMatrixAssignments(params) {
566
+ const resolved = getChannelSurface(params.config, "matrix");
567
+ if (!resolved) return;
568
+ const { channel: matrix, surface } = resolved;
569
+ const envAccessTokenConfigured = normalizeSecretStringValue(params.context.env.MATRIX_ACCESS_TOKEN).length > 0;
570
+ const defaultScopedAccessTokenConfigured = normalizeSecretStringValue(params.context.env[getMatrixScopedEnvVarNames("default").accessToken]).length > 0;
571
+ const defaultAccountAccessTokenConfigured = surface.accounts.some(({ accountId, account }) => normalizeAccountId(accountId) === "default" && hasConfiguredSecretInputValue(account.accessToken, params.defaults));
572
+ const baseAccessTokenConfigured = hasConfiguredSecretInputValue(matrix.accessToken, params.defaults);
573
+ collectSecretInputAssignment({
574
+ value: matrix.accessToken,
575
+ path: "channels.matrix.accessToken",
576
+ expected: "string",
577
+ defaults: params.defaults,
578
+ context: params.context,
579
+ active: surface.channelEnabled,
580
+ inactiveReason: "Matrix channel is disabled.",
581
+ apply: (value) => {
582
+ matrix.accessToken = value;
583
+ }
584
+ });
585
+ collectSecretInputAssignment({
586
+ value: matrix.password,
587
+ path: "channels.matrix.password",
588
+ expected: "string",
589
+ defaults: params.defaults,
590
+ context: params.context,
591
+ active: surface.channelEnabled && !(baseAccessTokenConfigured || envAccessTokenConfigured || defaultScopedAccessTokenConfigured || defaultAccountAccessTokenConfigured),
592
+ inactiveReason: "Matrix channel is disabled or access-token auth is configured for the default Matrix account.",
593
+ apply: (value) => {
594
+ matrix.password = value;
595
+ }
596
+ });
597
+ if (!surface.hasExplicitAccounts) return;
598
+ for (const { accountId, account, enabled } of surface.accounts) {
599
+ if (hasOwnProperty(account, "accessToken")) collectSecretInputAssignment({
600
+ value: account.accessToken,
601
+ path: `channels.matrix.accounts.${accountId}.accessToken`,
602
+ expected: "string",
603
+ defaults: params.defaults,
604
+ context: params.context,
605
+ active: enabled,
606
+ inactiveReason: "Matrix account is disabled.",
607
+ apply: (value) => {
608
+ account.accessToken = value;
609
+ }
610
+ });
611
+ if (!hasOwnProperty(account, "password")) continue;
612
+ const accountAccessTokenConfigured = hasConfiguredSecretInputValue(account.accessToken, params.defaults);
613
+ const scopedEnvAccessTokenConfigured = normalizeSecretStringValue(params.context.env[getMatrixScopedEnvVarNames(accountId).accessToken]).length > 0;
614
+ const inheritedDefaultAccountAccessTokenConfigured = normalizeAccountId(accountId) === "default" && (baseAccessTokenConfigured || envAccessTokenConfigured);
615
+ collectSecretInputAssignment({
616
+ value: account.password,
617
+ path: `channels.matrix.accounts.${accountId}.password`,
618
+ expected: "string",
619
+ defaults: params.defaults,
620
+ context: params.context,
621
+ active: enabled && !(accountAccessTokenConfigured || scopedEnvAccessTokenConfigured || inheritedDefaultAccountAccessTokenConfigured),
622
+ inactiveReason: "Matrix account is disabled or this account has an accessToken configured.",
623
+ apply: (value) => {
624
+ account.password = value;
625
+ }
626
+ });
627
+ }
628
+ }
629
+ function collectZaloAssignments(params) {
630
+ const resolved = getChannelSurface(params.config, "zalo");
631
+ if (!resolved) return;
632
+ const { channel: zalo, surface } = resolved;
633
+ collectConditionalChannelFieldAssignments({
634
+ channelKey: "zalo",
635
+ field: "botToken",
636
+ channel: zalo,
637
+ surface,
638
+ defaults: params.defaults,
639
+ context: params.context,
640
+ topLevelActiveWithoutAccounts: true,
641
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "botToken"),
642
+ accountActive: ({ enabled }) => enabled,
643
+ topInactiveReason: "no enabled Zalo surface inherits this top-level botToken.",
644
+ accountInactiveReason: "Zalo account is disabled."
645
+ });
646
+ const baseWebhookUrl = normalizeSecretStringValue(zalo.webhookUrl);
647
+ const resolveAccountWebhookUrl = (account) => hasOwnProperty(account, "webhookUrl") ? normalizeSecretStringValue(account.webhookUrl) : baseWebhookUrl;
648
+ collectConditionalChannelFieldAssignments({
649
+ channelKey: "zalo",
650
+ field: "webhookSecret",
651
+ channel: zalo,
652
+ surface,
653
+ defaults: params.defaults,
654
+ context: params.context,
655
+ topLevelActiveWithoutAccounts: baseWebhookUrl.length > 0,
656
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "webhookSecret") && resolveAccountWebhookUrl(account).length > 0,
657
+ accountActive: ({ account, enabled }) => enabled && resolveAccountWebhookUrl(account).length > 0,
658
+ topInactiveReason: "no enabled Zalo webhook surface inherits this top-level webhookSecret (webhook mode is not active).",
659
+ accountInactiveReason: "Zalo account is disabled or webhook mode is not active for this account."
660
+ });
661
+ }
662
+ function collectFeishuAssignments(params) {
663
+ const resolved = getChannelSurface(params.config, "feishu");
664
+ if (!resolved) return;
665
+ const { channel: feishu, surface } = resolved;
666
+ collectSimpleChannelFieldAssignments({
667
+ channelKey: "feishu",
668
+ field: "appSecret",
669
+ channel: feishu,
670
+ surface,
671
+ defaults: params.defaults,
672
+ context: params.context,
673
+ topInactiveReason: "no enabled account inherits this top-level Feishu appSecret.",
674
+ accountInactiveReason: "Feishu account is disabled."
675
+ });
676
+ const baseConnectionMode = normalizeSecretStringValue(feishu.connectionMode) === "webhook" ? "webhook" : "websocket";
677
+ const resolveAccountMode = (account) => hasOwnProperty(account, "connectionMode") ? normalizeSecretStringValue(account.connectionMode) : baseConnectionMode;
678
+ collectConditionalChannelFieldAssignments({
679
+ channelKey: "feishu",
680
+ field: "encryptKey",
681
+ channel: feishu,
682
+ surface,
683
+ defaults: params.defaults,
684
+ context: params.context,
685
+ topLevelActiveWithoutAccounts: baseConnectionMode === "webhook",
686
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "encryptKey") && resolveAccountMode(account) === "webhook",
687
+ accountActive: ({ account, enabled }) => enabled && resolveAccountMode(account) === "webhook",
688
+ topInactiveReason: "no enabled Feishu webhook-mode surface inherits this top-level encryptKey.",
689
+ accountInactiveReason: "Feishu account is disabled or not running in webhook mode."
690
+ });
691
+ collectConditionalChannelFieldAssignments({
692
+ channelKey: "feishu",
693
+ field: "verificationToken",
694
+ channel: feishu,
695
+ surface,
696
+ defaults: params.defaults,
697
+ context: params.context,
698
+ topLevelActiveWithoutAccounts: baseConnectionMode === "webhook",
699
+ topLevelInheritedAccountActive: ({ account, enabled }) => enabled && !hasOwnProperty(account, "verificationToken") && resolveAccountMode(account) === "webhook",
700
+ accountActive: ({ account, enabled }) => enabled && resolveAccountMode(account) === "webhook",
701
+ topInactiveReason: "no enabled Feishu webhook-mode surface inherits this top-level verificationToken.",
702
+ accountInactiveReason: "Feishu account is disabled or not running in webhook mode."
703
+ });
704
+ }
705
+ function collectNextcloudTalkAssignments(params) {
706
+ const resolved = getChannelSurface(params.config, "nextcloud-talk");
707
+ if (!resolved) return;
708
+ const { channel: nextcloudTalk, surface } = resolved;
709
+ const inheritsField = (field) => ({ account, enabled }) => enabled && !hasOwnProperty(account, field);
710
+ collectConditionalChannelFieldAssignments({
711
+ channelKey: "nextcloud-talk",
712
+ field: "botSecret",
713
+ channel: nextcloudTalk,
714
+ surface,
715
+ defaults: params.defaults,
716
+ context: params.context,
717
+ topLevelActiveWithoutAccounts: true,
718
+ topLevelInheritedAccountActive: inheritsField("botSecret"),
719
+ accountActive: ({ enabled }) => enabled,
720
+ topInactiveReason: "no enabled Nextcloud Talk surface inherits this top-level botSecret.",
721
+ accountInactiveReason: "Nextcloud Talk account is disabled."
722
+ });
723
+ collectConditionalChannelFieldAssignments({
724
+ channelKey: "nextcloud-talk",
725
+ field: "apiPassword",
726
+ channel: nextcloudTalk,
727
+ surface,
728
+ defaults: params.defaults,
729
+ context: params.context,
730
+ topLevelActiveWithoutAccounts: true,
731
+ topLevelInheritedAccountActive: inheritsField("apiPassword"),
732
+ accountActive: ({ enabled }) => enabled,
733
+ topInactiveReason: "no enabled Nextcloud Talk surface inherits this top-level apiPassword.",
734
+ accountInactiveReason: "Nextcloud Talk account is disabled."
735
+ });
736
+ }
737
+ function collectGoogleChatAccountAssignment(params) {
738
+ const { explicitRef, ref } = resolveSecretInputRef({
739
+ value: params.target.serviceAccount,
740
+ refValue: params.target.serviceAccountRef,
741
+ defaults: params.defaults
742
+ });
743
+ if (!ref) return;
744
+ if (params.active === false) {
745
+ pushInactiveSurfaceWarning({
746
+ context: params.context,
747
+ path: `${params.path}.serviceAccount`,
748
+ details: params.inactiveReason
749
+ });
750
+ return;
751
+ }
752
+ if (explicitRef && params.target.serviceAccount !== void 0 && !coerceSecretRef(params.target.serviceAccount, params.defaults)) pushWarning(params.context, {
753
+ code: "SECRETS_REF_OVERRIDES_PLAINTEXT",
754
+ path: params.path,
755
+ message: `${params.path}: serviceAccountRef is set; runtime will ignore plaintext serviceAccount.`
756
+ });
757
+ pushAssignment(params.context, {
758
+ ref,
759
+ path: `${params.path}.serviceAccount`,
760
+ expected: "string-or-object",
761
+ apply: (value) => {
762
+ params.target.serviceAccount = value;
763
+ }
764
+ });
765
+ }
766
+ function collectGoogleChatAssignments(params) {
767
+ const googleChatRecord = params.googleChat;
768
+ const surface = resolveChannelAccountSurface(googleChatRecord);
769
+ const topLevelServiceAccountActive = !surface.channelEnabled ? false : !surface.hasExplicitAccounts ? true : surface.accounts.some(({ account, enabled }) => enabled && !hasOwnProperty(account, "serviceAccount") && !hasOwnProperty(account, "serviceAccountRef"));
770
+ collectGoogleChatAccountAssignment({
771
+ target: params.googleChat,
772
+ path: "channels.googlechat",
773
+ defaults: params.defaults,
774
+ context: params.context,
775
+ active: topLevelServiceAccountActive,
776
+ inactiveReason: "no enabled account inherits this top-level Google Chat serviceAccount."
777
+ });
778
+ if (!surface.hasExplicitAccounts) return;
779
+ for (const { accountId, account, enabled } of surface.accounts) {
780
+ if (!hasOwnProperty(account, "serviceAccount") && !hasOwnProperty(account, "serviceAccountRef")) continue;
781
+ collectGoogleChatAccountAssignment({
782
+ target: account,
783
+ path: `channels.googlechat.accounts.${accountId}`,
784
+ defaults: params.defaults,
785
+ context: params.context,
786
+ active: enabled,
787
+ inactiveReason: "Google Chat account is disabled."
788
+ });
789
+ }
790
+ }
791
+ function collectChannelConfigAssignments(params) {
792
+ const googleChat = getChannelRecord(params.config, "googlechat");
793
+ if (googleChat) collectGoogleChatAssignments({
794
+ googleChat,
795
+ defaults: params.defaults,
796
+ context: params.context
797
+ });
798
+ collectTelegramAssignments(params);
799
+ collectSlackAssignments(params);
800
+ collectDiscordAssignments(params);
801
+ collectIrcAssignments(params);
802
+ collectBlueBubblesAssignments(params);
803
+ collectMattermostAssignments(params);
804
+ collectMatrixAssignments(params);
805
+ collectMSTeamsAssignments(params);
806
+ collectNextcloudTalkAssignments(params);
807
+ collectFeishuAssignments(params);
808
+ collectZaloAssignments(params);
809
+ }
810
+ //#endregion
811
+ //#region src/secrets/runtime-gateway-auth-surfaces.ts
812
+ const GATEWAY_AUTH_SURFACE_PATHS = [
813
+ "gateway.auth.token",
814
+ "gateway.auth.password",
815
+ "gateway.remote.token",
816
+ "gateway.remote.password"
817
+ ];
818
+ function formatAuthMode(mode) {
819
+ return mode ?? "unset";
820
+ }
821
+ function describeRemoteConfiguredSurface(parts) {
822
+ const reasons = [];
823
+ if (parts.remoteMode) reasons.push("gateway.mode is \"remote\"");
824
+ if (parts.remoteUrlConfigured) reasons.push("gateway.remote.url is configured");
825
+ if (parts.tailscaleRemoteExposure) reasons.push("gateway.tailscale.mode is \"serve\" or \"funnel\"");
826
+ return reasons.join("; ");
827
+ }
828
+ function createState(params) {
829
+ return {
830
+ path: params.path,
831
+ active: params.active,
832
+ reason: params.reason,
833
+ hasSecretRef: params.hasSecretRef
834
+ };
835
+ }
836
+ function evaluateGatewayAuthSurfaceStates(params) {
837
+ const gateway = params.config.gateway;
838
+ if (!isRecord$1(gateway)) return {
839
+ "gateway.auth.token": createState({
840
+ path: "gateway.auth.token",
841
+ active: false,
842
+ reason: "gateway configuration is not set.",
843
+ hasSecretRef: false
844
+ }),
845
+ "gateway.auth.password": createState({
846
+ path: "gateway.auth.password",
847
+ active: false,
848
+ reason: "gateway configuration is not set.",
849
+ hasSecretRef: false
850
+ }),
851
+ "gateway.remote.token": createState({
852
+ path: "gateway.remote.token",
853
+ active: false,
854
+ reason: "gateway configuration is not set.",
855
+ hasSecretRef: false
856
+ }),
857
+ "gateway.remote.password": createState({
858
+ path: "gateway.remote.password",
859
+ active: false,
860
+ reason: "gateway configuration is not set.",
861
+ hasSecretRef: false
862
+ })
863
+ };
864
+ const auth = isRecord$1(gateway?.auth) ? gateway.auth : void 0;
865
+ const remote = isRecord$1(gateway?.remote) ? gateway.remote : void 0;
866
+ const plan = createGatewayCredentialPlan({
867
+ config: params.config,
868
+ env: params.env,
869
+ defaults: params.defaults
870
+ });
871
+ const authPasswordReason = (() => {
872
+ if (!auth) return "gateway.auth is not configured.";
873
+ if (plan.passwordCanWin) return plan.authMode === "password" ? "gateway.auth.mode is \"password\"." : "no token source can win, so password auth can win.";
874
+ if (plan.authMode === "token" || plan.authMode === "none" || plan.authMode === "trusted-proxy") return `gateway.auth.mode is "${plan.authMode}".`;
875
+ if (plan.envToken) return "gateway token env var is configured.";
876
+ if (plan.localToken.configured) return "gateway.auth.token is configured.";
877
+ if (plan.remoteToken.configured) return "gateway.remote.token is configured.";
878
+ return "token auth can win.";
879
+ })();
880
+ const authTokenReason = (() => {
881
+ if (!auth) return "gateway.auth is not configured.";
882
+ if (plan.authMode === "token") return plan.envToken ? "gateway token env var is configured." : "gateway.auth.mode is \"token\".";
883
+ if (plan.authMode === "password" || plan.authMode === "none" || plan.authMode === "trusted-proxy") return `gateway.auth.mode is "${plan.authMode}".`;
884
+ if (plan.envToken) return "gateway token env var is configured.";
885
+ if (plan.envPassword) return "gateway password env var is configured.";
886
+ if (plan.localPassword.configured) return "gateway.auth.password is configured.";
887
+ return "token auth can win (mode is unset and no password source is configured).";
888
+ })();
889
+ const remoteSurfaceReason = describeRemoteConfiguredSurface({
890
+ remoteMode: plan.remoteMode,
891
+ remoteUrlConfigured: plan.remoteUrlConfigured,
892
+ tailscaleRemoteExposure: plan.tailscaleRemoteExposure
893
+ });
894
+ const remoteTokenReason = (() => {
895
+ if (!remote) return "gateway.remote is not configured.";
896
+ if (plan.remoteConfiguredSurface) return `remote surface is active: ${remoteSurfaceReason}.`;
897
+ if (plan.remoteTokenFallbackActive) return "local token auth can win and no env/auth token is configured.";
898
+ if (!plan.localTokenCanWin) return `token auth cannot win with gateway.auth.mode="${formatAuthMode(plan.authMode)}".`;
899
+ if (plan.envToken) return "gateway token env var is configured.";
900
+ if (plan.localToken.configured) return "gateway.auth.token is configured.";
901
+ return "remote token fallback is not active.";
902
+ })();
903
+ const remotePasswordReason = (() => {
904
+ if (!remote) return "gateway.remote is not configured.";
905
+ if (plan.remoteConfiguredSurface) return `remote surface is active: ${remoteSurfaceReason}.`;
906
+ if (plan.remotePasswordFallbackActive) return "password auth can win and no env/auth password is configured.";
907
+ if (!plan.passwordCanWin) {
908
+ if (plan.authMode === "token" || plan.authMode === "none" || plan.authMode === "trusted-proxy") return `password auth cannot win with gateway.auth.mode="${plan.authMode}".`;
909
+ return "a token source can win, so password auth cannot win.";
910
+ }
911
+ if (plan.envPassword) return "gateway password env var is configured.";
912
+ if (plan.localPassword.configured) return "gateway.auth.password is configured.";
913
+ return "remote password fallback is not active.";
914
+ })();
915
+ return {
916
+ "gateway.auth.token": createState({
917
+ path: "gateway.auth.token",
918
+ active: plan.localTokenSurfaceActive,
919
+ reason: authTokenReason,
920
+ hasSecretRef: plan.localToken.hasSecretRef
921
+ }),
922
+ "gateway.auth.password": createState({
923
+ path: "gateway.auth.password",
924
+ active: plan.passwordCanWin,
925
+ reason: authPasswordReason,
926
+ hasSecretRef: plan.localPassword.hasSecretRef
927
+ }),
928
+ "gateway.remote.token": createState({
929
+ path: "gateway.remote.token",
930
+ active: plan.remoteTokenActive,
931
+ reason: remoteTokenReason,
932
+ hasSecretRef: plan.remoteToken.hasSecretRef
933
+ }),
934
+ "gateway.remote.password": createState({
935
+ path: "gateway.remote.password",
936
+ active: plan.remotePasswordActive,
937
+ reason: remotePasswordReason,
938
+ hasSecretRef: plan.remotePassword.hasSecretRef
939
+ })
940
+ };
941
+ }
942
+ //#endregion
943
+ //#region src/secrets/runtime-config-collectors-core.ts
944
+ function collectModelProviderAssignments(params) {
945
+ for (const [providerId, provider] of Object.entries(params.providers)) {
946
+ const providerIsActive = provider.enabled !== false;
947
+ collectSecretInputAssignment({
948
+ value: provider.apiKey,
949
+ path: `models.providers.${providerId}.apiKey`,
950
+ expected: "string",
951
+ defaults: params.defaults,
952
+ context: params.context,
953
+ active: providerIsActive,
954
+ inactiveReason: "provider is disabled.",
955
+ apply: (value) => {
956
+ provider.apiKey = value;
957
+ }
958
+ });
959
+ const headers = isRecord$1(provider.headers) ? provider.headers : void 0;
960
+ if (!headers) continue;
961
+ for (const [headerKey, headerValue] of Object.entries(headers)) collectSecretInputAssignment({
962
+ value: headerValue,
963
+ path: `models.providers.${providerId}.headers.${headerKey}`,
964
+ expected: "string",
965
+ defaults: params.defaults,
966
+ context: params.context,
967
+ active: providerIsActive,
968
+ inactiveReason: "provider is disabled.",
969
+ apply: (value) => {
970
+ headers[headerKey] = value;
971
+ }
972
+ });
973
+ }
974
+ }
975
+ function collectSkillAssignments(params) {
976
+ for (const [skillKey, entry] of Object.entries(params.entries)) collectSecretInputAssignment({
977
+ value: entry.apiKey,
978
+ path: `skills.entries.${skillKey}.apiKey`,
979
+ expected: "string",
980
+ defaults: params.defaults,
981
+ context: params.context,
982
+ active: entry.enabled !== false,
983
+ inactiveReason: "skill entry is disabled.",
984
+ apply: (value) => {
985
+ entry.apiKey = value;
986
+ }
987
+ });
988
+ }
989
+ function collectAgentMemorySearchAssignments(params) {
990
+ const agents = params.config.agents;
991
+ if (!isRecord$1(agents)) return;
992
+ const defaultsConfig = isRecord$1(agents.defaults) ? agents.defaults : void 0;
993
+ const defaultsMemorySearch = isRecord$1(defaultsConfig?.memorySearch) ? defaultsConfig.memorySearch : void 0;
994
+ const defaultsEnabled = defaultsMemorySearch?.enabled !== false;
995
+ const list = Array.isArray(agents.list) ? agents.list : [];
996
+ let hasEnabledAgentWithoutOverride = false;
997
+ for (const rawAgent of list) {
998
+ if (!isRecord$1(rawAgent)) continue;
999
+ if (rawAgent.enabled === false) continue;
1000
+ const memorySearch = isRecord$1(rawAgent.memorySearch) ? rawAgent.memorySearch : void 0;
1001
+ if (memorySearch?.enabled === false) continue;
1002
+ if (!memorySearch || !Object.prototype.hasOwnProperty.call(memorySearch, "remote")) {
1003
+ hasEnabledAgentWithoutOverride = true;
1004
+ continue;
1005
+ }
1006
+ const remote = isRecord$1(memorySearch.remote) ? memorySearch.remote : void 0;
1007
+ if (!remote || !Object.prototype.hasOwnProperty.call(remote, "apiKey")) {
1008
+ hasEnabledAgentWithoutOverride = true;
1009
+ continue;
1010
+ }
1011
+ }
1012
+ if (defaultsMemorySearch && isRecord$1(defaultsMemorySearch.remote)) {
1013
+ const remote = defaultsMemorySearch.remote;
1014
+ collectSecretInputAssignment({
1015
+ value: remote.apiKey,
1016
+ path: "agents.defaults.memorySearch.remote.apiKey",
1017
+ expected: "string",
1018
+ defaults: params.defaults,
1019
+ context: params.context,
1020
+ active: defaultsEnabled && (hasEnabledAgentWithoutOverride || list.length === 0),
1021
+ inactiveReason: hasEnabledAgentWithoutOverride ? void 0 : "all enabled agents override memorySearch.remote.apiKey.",
1022
+ apply: (value) => {
1023
+ remote.apiKey = value;
1024
+ }
1025
+ });
1026
+ }
1027
+ list.forEach((rawAgent, index) => {
1028
+ if (!isRecord$1(rawAgent)) return;
1029
+ const memorySearch = isRecord$1(rawAgent.memorySearch) ? rawAgent.memorySearch : void 0;
1030
+ if (!memorySearch) return;
1031
+ const remote = isRecord$1(memorySearch.remote) ? memorySearch.remote : void 0;
1032
+ if (!remote || !Object.prototype.hasOwnProperty.call(remote, "apiKey")) return;
1033
+ const enabled = rawAgent.enabled !== false && memorySearch.enabled !== false;
1034
+ collectSecretInputAssignment({
1035
+ value: remote.apiKey,
1036
+ path: `agents.list.${index}.memorySearch.remote.apiKey`,
1037
+ expected: "string",
1038
+ defaults: params.defaults,
1039
+ context: params.context,
1040
+ active: enabled,
1041
+ inactiveReason: "agent or memorySearch override is disabled.",
1042
+ apply: (value) => {
1043
+ remote.apiKey = value;
1044
+ }
1045
+ });
1046
+ });
1047
+ }
1048
+ function collectTalkAssignments(params) {
1049
+ const talk = params.config.talk;
1050
+ if (!isRecord$1(talk)) return;
1051
+ collectSecretInputAssignment({
1052
+ value: talk.apiKey,
1053
+ path: "talk.apiKey",
1054
+ expected: "string",
1055
+ defaults: params.defaults,
1056
+ context: params.context,
1057
+ apply: (value) => {
1058
+ talk.apiKey = value;
1059
+ }
1060
+ });
1061
+ const providers = talk.providers;
1062
+ if (!isRecord$1(providers)) return;
1063
+ for (const [providerId, providerConfig] of Object.entries(providers)) {
1064
+ if (!isRecord$1(providerConfig)) continue;
1065
+ collectSecretInputAssignment({
1066
+ value: providerConfig.apiKey,
1067
+ path: `talk.providers.${providerId}.apiKey`,
1068
+ expected: "string",
1069
+ defaults: params.defaults,
1070
+ context: params.context,
1071
+ apply: (value) => {
1072
+ providerConfig.apiKey = value;
1073
+ }
1074
+ });
1075
+ }
1076
+ }
1077
+ function collectGatewayAssignments(params) {
1078
+ const gateway = params.config.gateway;
1079
+ if (!isRecord$1(gateway)) return;
1080
+ const auth = isRecord$1(gateway.auth) ? gateway.auth : void 0;
1081
+ const remote = isRecord$1(gateway.remote) ? gateway.remote : void 0;
1082
+ const gatewaySurfaceStates = evaluateGatewayAuthSurfaceStates({
1083
+ config: params.config,
1084
+ env: params.context.env,
1085
+ defaults: params.defaults
1086
+ });
1087
+ if (auth) {
1088
+ collectSecretInputAssignment({
1089
+ value: auth.token,
1090
+ path: "gateway.auth.token",
1091
+ expected: "string",
1092
+ defaults: params.defaults,
1093
+ context: params.context,
1094
+ active: gatewaySurfaceStates["gateway.auth.token"].active,
1095
+ inactiveReason: gatewaySurfaceStates["gateway.auth.token"].reason,
1096
+ apply: (value) => {
1097
+ auth.token = value;
1098
+ }
1099
+ });
1100
+ collectSecretInputAssignment({
1101
+ value: auth.password,
1102
+ path: "gateway.auth.password",
1103
+ expected: "string",
1104
+ defaults: params.defaults,
1105
+ context: params.context,
1106
+ active: gatewaySurfaceStates["gateway.auth.password"].active,
1107
+ inactiveReason: gatewaySurfaceStates["gateway.auth.password"].reason,
1108
+ apply: (value) => {
1109
+ auth.password = value;
1110
+ }
1111
+ });
1112
+ }
1113
+ if (remote) {
1114
+ collectSecretInputAssignment({
1115
+ value: remote.token,
1116
+ path: "gateway.remote.token",
1117
+ expected: "string",
1118
+ defaults: params.defaults,
1119
+ context: params.context,
1120
+ active: gatewaySurfaceStates["gateway.remote.token"].active,
1121
+ inactiveReason: gatewaySurfaceStates["gateway.remote.token"].reason,
1122
+ apply: (value) => {
1123
+ remote.token = value;
1124
+ }
1125
+ });
1126
+ collectSecretInputAssignment({
1127
+ value: remote.password,
1128
+ path: "gateway.remote.password",
1129
+ expected: "string",
1130
+ defaults: params.defaults,
1131
+ context: params.context,
1132
+ active: gatewaySurfaceStates["gateway.remote.password"].active,
1133
+ inactiveReason: gatewaySurfaceStates["gateway.remote.password"].reason,
1134
+ apply: (value) => {
1135
+ remote.password = value;
1136
+ }
1137
+ });
1138
+ }
1139
+ }
1140
+ function collectMessagesTtsAssignments(params) {
1141
+ const messages = params.config.messages;
1142
+ if (!isRecord$1(messages) || !isRecord$1(messages.tts)) return;
1143
+ collectTtsApiKeyAssignments({
1144
+ tts: messages.tts,
1145
+ pathPrefix: "messages.tts",
1146
+ defaults: params.defaults,
1147
+ context: params.context
1148
+ });
1149
+ }
1150
+ function collectCronAssignments(params) {
1151
+ const cron = params.config.cron;
1152
+ if (!isRecord$1(cron)) return;
1153
+ collectSecretInputAssignment({
1154
+ value: cron.webhookToken,
1155
+ path: "cron.webhookToken",
1156
+ expected: "string",
1157
+ defaults: params.defaults,
1158
+ context: params.context,
1159
+ apply: (value) => {
1160
+ cron.webhookToken = value;
1161
+ }
1162
+ });
1163
+ }
1164
+ function collectSandboxSshAssignments(params) {
1165
+ const agents = isRecord$1(params.config.agents) ? params.config.agents : void 0;
1166
+ if (!agents) return;
1167
+ const defaultsAgent = isRecord$1(agents.defaults) ? agents.defaults : void 0;
1168
+ const defaultsSandbox = isRecord$1(defaultsAgent?.sandbox) ? defaultsAgent.sandbox : void 0;
1169
+ const defaultsSsh = isRecord$1(defaultsSandbox?.ssh) ? defaultsSandbox.ssh : void 0;
1170
+ const defaultsBackend = typeof defaultsSandbox?.backend === "string" ? defaultsSandbox.backend : void 0;
1171
+ const defaultsMode = typeof defaultsSandbox?.mode === "string" ? defaultsSandbox.mode : void 0;
1172
+ const inheritedDefaultsUsage = {
1173
+ identityData: false,
1174
+ certificateData: false,
1175
+ knownHostsData: false
1176
+ };
1177
+ (Array.isArray(agents.list) ? agents.list : []).forEach((rawAgent, index) => {
1178
+ const agentRecord = isRecord$1(rawAgent) ? rawAgent : null;
1179
+ if (!agentRecord || agentRecord.enabled === false) return;
1180
+ const sandbox = isRecord$1(agentRecord.sandbox) ? agentRecord.sandbox : void 0;
1181
+ const ssh = isRecord$1(sandbox?.ssh) ? sandbox.ssh : void 0;
1182
+ const effectiveBackend = (typeof sandbox?.backend === "string" ? sandbox.backend : void 0) ?? defaultsBackend ?? "docker";
1183
+ const effectiveMode = (typeof sandbox?.mode === "string" ? sandbox.mode : void 0) ?? defaultsMode ?? "off";
1184
+ const active = effectiveBackend.trim().toLowerCase() === "ssh" && effectiveMode !== "off";
1185
+ for (const key of [
1186
+ "identityData",
1187
+ "certificateData",
1188
+ "knownHostsData"
1189
+ ]) if (ssh && Object.prototype.hasOwnProperty.call(ssh, key)) collectSecretInputAssignment({
1190
+ value: ssh[key],
1191
+ path: `agents.list.${index}.sandbox.ssh.${key}`,
1192
+ expected: "string",
1193
+ defaults: params.defaults,
1194
+ context: params.context,
1195
+ active,
1196
+ inactiveReason: "sandbox SSH backend is not active for this agent.",
1197
+ apply: (value) => {
1198
+ ssh[key] = value;
1199
+ }
1200
+ });
1201
+ else if (active) inheritedDefaultsUsage[key] = true;
1202
+ });
1203
+ if (!defaultsSsh) return;
1204
+ const defaultsActive = defaultsBackend?.trim().toLowerCase() === "ssh" && defaultsMode !== "off" || inheritedDefaultsUsage.identityData || inheritedDefaultsUsage.certificateData || inheritedDefaultsUsage.knownHostsData;
1205
+ for (const key of [
1206
+ "identityData",
1207
+ "certificateData",
1208
+ "knownHostsData"
1209
+ ]) collectSecretInputAssignment({
1210
+ value: defaultsSsh[key],
1211
+ path: `agents.defaults.sandbox.ssh.${key}`,
1212
+ expected: "string",
1213
+ defaults: params.defaults,
1214
+ context: params.context,
1215
+ active: defaultsActive || inheritedDefaultsUsage[key],
1216
+ inactiveReason: "sandbox SSH backend is not active.",
1217
+ apply: (value) => {
1218
+ defaultsSsh[key] = value;
1219
+ }
1220
+ });
1221
+ }
1222
+ function collectCoreConfigAssignments(params) {
1223
+ const providers = params.config.models?.providers;
1224
+ if (providers) collectModelProviderAssignments({
1225
+ providers,
1226
+ defaults: params.defaults,
1227
+ context: params.context
1228
+ });
1229
+ const skillEntries = params.config.skills?.entries;
1230
+ if (skillEntries) collectSkillAssignments({
1231
+ entries: skillEntries,
1232
+ defaults: params.defaults,
1233
+ context: params.context
1234
+ });
1235
+ collectAgentMemorySearchAssignments(params);
1236
+ collectTalkAssignments(params);
1237
+ collectGatewayAssignments(params);
1238
+ collectSandboxSshAssignments(params);
1239
+ collectMessagesTtsAssignments(params);
1240
+ collectCronAssignments(params);
1241
+ }
1242
+ //#endregion
1243
+ //#region src/secrets/runtime-config-collectors-plugins.ts
1244
+ const ACPX_PLUGIN_ID = "acpx";
1245
+ /**
1246
+ * Walk plugin config entries and collect SecretRef assignments for MCP server
1247
+ * env vars. Without this, SecretRefs in paths like
1248
+ * `plugins.entries.acpx.config.mcpServers.*.env.*` are never resolved and
1249
+ * remain as raw objects at runtime.
1250
+ *
1251
+ * This surface is intentionally scoped to ACPX. Third-party plugins may define
1252
+ * their own `mcpServers`-shaped config, but that is not a documented SecretRef
1253
+ * surface and should not be rewritten here.
1254
+ *
1255
+ * When `loadablePluginOrigins` is provided, entries whose ID is not in the map
1256
+ * are treated as inactive (stale config entries for plugins that are no longer
1257
+ * installed). This prevents resolution failures for SecretRefs belonging to
1258
+ * non-loadable plugins from blocking startup or preflight validation.
1259
+ */
1260
+ function collectPluginConfigAssignments(params) {
1261
+ const entries = params.config.plugins?.entries;
1262
+ if (!isRecord$1(entries)) return;
1263
+ const normalizedConfig = normalizePluginsConfig(params.config.plugins);
1264
+ for (const [pluginId, entry] of Object.entries(entries)) {
1265
+ if (pluginId !== ACPX_PLUGIN_ID) continue;
1266
+ if (!isRecord$1(entry)) continue;
1267
+ const pluginConfig = entry.config;
1268
+ if (!isRecord$1(pluginConfig)) continue;
1269
+ const pluginOrigin = params.loadablePluginOrigins?.get(pluginId);
1270
+ if (params.loadablePluginOrigins && !pluginOrigin) {
1271
+ collectMcpServerEnvAssignments({
1272
+ pluginId,
1273
+ pluginConfig,
1274
+ active: false,
1275
+ inactiveReason: "plugin is not loadable (stale config entry).",
1276
+ defaults: params.defaults,
1277
+ context: params.context
1278
+ });
1279
+ continue;
1280
+ }
1281
+ const enableState = resolveEnableState(pluginId, pluginOrigin ?? "config", normalizedConfig);
1282
+ collectMcpServerEnvAssignments({
1283
+ pluginId,
1284
+ pluginConfig,
1285
+ active: enableState.enabled,
1286
+ inactiveReason: enableState.reason ?? "plugin is disabled.",
1287
+ defaults: params.defaults,
1288
+ context: params.context
1289
+ });
1290
+ }
1291
+ }
1292
+ function collectMcpServerEnvAssignments(params) {
1293
+ const mcpServers = params.pluginConfig.mcpServers;
1294
+ if (!isRecord$1(mcpServers)) return;
1295
+ for (const [serverName, serverConfig] of Object.entries(mcpServers)) {
1296
+ if (!isRecord$1(serverConfig)) continue;
1297
+ const env = serverConfig.env;
1298
+ if (!isRecord$1(env)) continue;
1299
+ for (const [envKey, envValue] of Object.entries(env)) collectSecretInputAssignment({
1300
+ value: envValue,
1301
+ path: `plugins.entries.${params.pluginId}.config.mcpServers.${serverName}.env.${envKey}`,
1302
+ expected: "string",
1303
+ defaults: params.defaults,
1304
+ context: params.context,
1305
+ active: params.active,
1306
+ inactiveReason: `plugin "${params.pluginId}": ${params.inactiveReason}`,
1307
+ apply: (value) => {
1308
+ env[envKey] = value;
1309
+ }
1310
+ });
1311
+ }
1312
+ }
1313
+ //#endregion
1314
+ //#region src/secrets/runtime-config-collectors.ts
1315
+ function collectConfigAssignments(params) {
1316
+ const defaults = params.context.sourceConfig.secrets?.defaults;
1317
+ collectCoreConfigAssignments({
1318
+ config: params.config,
1319
+ defaults,
1320
+ context: params.context
1321
+ });
1322
+ collectChannelConfigAssignments({
1323
+ config: params.config,
1324
+ defaults,
1325
+ context: params.context
1326
+ });
1327
+ collectPluginConfigAssignments({
1328
+ config: params.config,
1329
+ defaults,
1330
+ context: params.context,
1331
+ loadablePluginOrigins: params.loadablePluginOrigins
1332
+ });
1333
+ }
1334
+ //#endregion
1335
+ //#region src/secrets/runtime-web-tools.ts
1336
+ function isRecord(value) {
1337
+ return typeof value === "object" && value !== null && !Array.isArray(value);
1338
+ }
1339
+ function normalizeProvider(value, providers) {
1340
+ if (typeof value !== "string") return;
1341
+ const normalized = value.trim().toLowerCase();
1342
+ if (providers.some((provider) => provider.id === normalized)) return normalized;
1343
+ }
1344
+ function hasCustomWebSearchPluginRisk(config) {
1345
+ const plugins = config.plugins;
1346
+ if (!plugins) return false;
1347
+ if (Array.isArray(plugins.load?.paths) && plugins.load.paths.length > 0) return true;
1348
+ if (plugins.installs && Object.keys(plugins.installs).length > 0) return true;
1349
+ const bundledPluginIds = new Set(listBundledWebSearchPluginIds());
1350
+ const hasNonBundledPluginId = (pluginId) => !bundledPluginIds.has(pluginId.trim());
1351
+ if (Array.isArray(plugins.allow) && plugins.allow.some(hasNonBundledPluginId)) return true;
1352
+ if (Array.isArray(plugins.deny) && plugins.deny.some(hasNonBundledPluginId)) return true;
1353
+ if (plugins.entries && Object.keys(plugins.entries).some(hasNonBundledPluginId)) return true;
1354
+ return false;
1355
+ }
1356
+ function readNonEmptyEnvValue(env, names) {
1357
+ for (const envVar of names) {
1358
+ const value = normalizeSecretInput(env[envVar]);
1359
+ if (value) return {
1360
+ value,
1361
+ envVar
1362
+ };
1363
+ }
1364
+ return {};
1365
+ }
1366
+ function buildUnresolvedReason(params) {
1367
+ if (params.kind === "non-string") return `${params.path} SecretRef resolved to a non-string value.`;
1368
+ if (params.kind === "empty") return `${params.path} SecretRef resolved to an empty value.`;
1369
+ return `${params.path} SecretRef is unresolved (${params.refLabel}).`;
1370
+ }
1371
+ async function resolveSecretInputWithEnvFallback(params) {
1372
+ const { ref } = resolveSecretInputRef({
1373
+ value: params.value,
1374
+ defaults: params.defaults
1375
+ });
1376
+ if (!ref) {
1377
+ const configValue = normalizeSecretInput(params.value);
1378
+ if (configValue) return {
1379
+ value: configValue,
1380
+ source: "config",
1381
+ secretRefConfigured: false,
1382
+ fallbackUsedAfterRefFailure: false
1383
+ };
1384
+ const fallback = readNonEmptyEnvValue(params.context.env, params.envVars);
1385
+ if (fallback.value) return {
1386
+ value: fallback.value,
1387
+ source: "env",
1388
+ fallbackEnvVar: fallback.envVar,
1389
+ secretRefConfigured: false,
1390
+ fallbackUsedAfterRefFailure: false
1391
+ };
1392
+ return {
1393
+ source: "missing",
1394
+ secretRefConfigured: false,
1395
+ fallbackUsedAfterRefFailure: false
1396
+ };
1397
+ }
1398
+ const refLabel = `${ref.source}:${ref.provider}:${ref.id}`;
1399
+ let resolvedFromRef;
1400
+ let unresolvedRefReason;
1401
+ try {
1402
+ const resolvedValue = (await resolveSecretRefValues([ref], {
1403
+ config: params.sourceConfig,
1404
+ env: params.context.env,
1405
+ cache: params.context.cache
1406
+ })).get(secretRefKey(ref));
1407
+ if (typeof resolvedValue !== "string") unresolvedRefReason = buildUnresolvedReason({
1408
+ path: params.path,
1409
+ kind: "non-string",
1410
+ refLabel
1411
+ });
1412
+ else {
1413
+ resolvedFromRef = normalizeSecretInput(resolvedValue);
1414
+ if (!resolvedFromRef) unresolvedRefReason = buildUnresolvedReason({
1415
+ path: params.path,
1416
+ kind: "empty",
1417
+ refLabel
1418
+ });
1419
+ }
1420
+ } catch {
1421
+ unresolvedRefReason = buildUnresolvedReason({
1422
+ path: params.path,
1423
+ kind: "unresolved",
1424
+ refLabel
1425
+ });
1426
+ }
1427
+ if (resolvedFromRef) return {
1428
+ value: resolvedFromRef,
1429
+ source: "secretRef",
1430
+ secretRefConfigured: true,
1431
+ fallbackUsedAfterRefFailure: false
1432
+ };
1433
+ const fallback = readNonEmptyEnvValue(params.context.env, params.envVars);
1434
+ if (fallback.value) return {
1435
+ value: fallback.value,
1436
+ source: "env",
1437
+ fallbackEnvVar: fallback.envVar,
1438
+ unresolvedRefReason,
1439
+ secretRefConfigured: true,
1440
+ fallbackUsedAfterRefFailure: true
1441
+ };
1442
+ return {
1443
+ source: "missing",
1444
+ unresolvedRefReason,
1445
+ secretRefConfigured: true,
1446
+ fallbackUsedAfterRefFailure: false
1447
+ };
1448
+ }
1449
+ function ensureObject(target, key) {
1450
+ const current = target[key];
1451
+ if (isRecord(current)) return current;
1452
+ const next = {};
1453
+ target[key] = next;
1454
+ return next;
1455
+ }
1456
+ function setResolvedWebSearchApiKey(params) {
1457
+ const search = ensureObject(ensureObject(ensureObject(params.resolvedConfig, "tools"), "web"), "search");
1458
+ if (params.provider.setConfiguredCredentialValue) {
1459
+ params.provider.setConfiguredCredentialValue(params.resolvedConfig, params.value);
1460
+ if (params.provider.id !== "brave") return;
1461
+ }
1462
+ params.provider.setCredentialValue(search, params.value);
1463
+ }
1464
+ function setResolvedFirecrawlApiKey(params) {
1465
+ const firecrawl = ensureObject(ensureObject(ensureObject(ensureObject(params.resolvedConfig, "tools"), "web"), "fetch"), "firecrawl");
1466
+ firecrawl.apiKey = params.value;
1467
+ }
1468
+ function setResolvedXSearchApiKey(params) {
1469
+ const xSearch = ensureObject(ensureObject(ensureObject(params.resolvedConfig, "tools"), "web"), "x_search");
1470
+ xSearch.apiKey = params.value;
1471
+ }
1472
+ function keyPathForProvider(provider) {
1473
+ return provider.credentialPath;
1474
+ }
1475
+ function readConfiguredProviderCredential(params) {
1476
+ return params.provider.getConfiguredCredentialValue?.(params.config) ?? (params.provider.id === "brave" ? params.provider.getCredentialValue(params.search) : void 0);
1477
+ }
1478
+ function inactivePathsForProvider(provider) {
1479
+ if (provider.requiresCredential === false) return [];
1480
+ return provider.inactiveSecretPaths?.length ? provider.inactiveSecretPaths : [provider.credentialPath];
1481
+ }
1482
+ function hasConfiguredSecretRef(value, defaults) {
1483
+ return Boolean(resolveSecretInputRef({
1484
+ value,
1485
+ defaults
1486
+ }).ref);
1487
+ }
1488
+ async function resolveRuntimeWebTools(params) {
1489
+ const defaults = params.sourceConfig.secrets?.defaults;
1490
+ const diagnostics = [];
1491
+ const tools = isRecord(params.sourceConfig.tools) ? params.sourceConfig.tools : void 0;
1492
+ const web = isRecord(tools?.web) ? tools.web : void 0;
1493
+ const search = isRecord(web?.search) ? web.search : void 0;
1494
+ const rawProvider = typeof search?.provider === "string" ? search.provider.trim().toLowerCase() : "";
1495
+ const configuredBundledPluginId = resolveBundledWebSearchPluginId(rawProvider);
1496
+ const searchMetadata = {
1497
+ providerSource: "none",
1498
+ diagnostics: []
1499
+ };
1500
+ const searchConfigured = Boolean(search);
1501
+ const searchEnabled = searchConfigured && search?.enabled !== false;
1502
+ const providers = sortWebSearchProvidersForAutoDetect(searchConfigured ? configuredBundledPluginId ? resolveBundledPluginWebSearchProviders({
1503
+ config: params.sourceConfig,
1504
+ env: {
1505
+ ...process.env,
1506
+ ...params.context.env
1507
+ },
1508
+ bundledAllowlistCompat: true,
1509
+ onlyPluginIds: [configuredBundledPluginId]
1510
+ }) : !hasCustomWebSearchPluginRisk(params.sourceConfig) ? resolveBundledPluginWebSearchProviders({
1511
+ config: params.sourceConfig,
1512
+ env: {
1513
+ ...process.env,
1514
+ ...params.context.env
1515
+ },
1516
+ bundledAllowlistCompat: true
1517
+ }) : resolvePluginWebSearchProviders({
1518
+ config: params.sourceConfig,
1519
+ env: {
1520
+ ...process.env,
1521
+ ...params.context.env
1522
+ },
1523
+ bundledAllowlistCompat: true
1524
+ }) : []);
1525
+ const configuredProvider = normalizeProvider(rawProvider, providers);
1526
+ if (rawProvider && !configuredProvider) {
1527
+ const diagnostic = {
1528
+ code: "WEB_SEARCH_PROVIDER_INVALID_AUTODETECT",
1529
+ message: `tools.web.search.provider is "${rawProvider}". Falling back to auto-detect precedence.`,
1530
+ path: "tools.web.search.provider"
1531
+ };
1532
+ diagnostics.push(diagnostic);
1533
+ searchMetadata.diagnostics.push(diagnostic);
1534
+ pushWarning(params.context, {
1535
+ code: "WEB_SEARCH_PROVIDER_INVALID_AUTODETECT",
1536
+ path: "tools.web.search.provider",
1537
+ message: diagnostic.message
1538
+ });
1539
+ }
1540
+ if (configuredProvider) {
1541
+ searchMetadata.providerConfigured = configuredProvider;
1542
+ searchMetadata.providerSource = "configured";
1543
+ }
1544
+ if (searchEnabled) {
1545
+ const candidates = configuredProvider ? providers.filter((provider) => provider.id === configuredProvider) : providers;
1546
+ const unresolvedWithoutFallback = [];
1547
+ let selectedProvider;
1548
+ let selectedResolution;
1549
+ let keylessFallbackProvider;
1550
+ for (const provider of candidates) {
1551
+ if (provider.requiresCredential === false) {
1552
+ if (!keylessFallbackProvider) keylessFallbackProvider = provider;
1553
+ if (configuredProvider) {
1554
+ selectedProvider = provider.id;
1555
+ break;
1556
+ }
1557
+ continue;
1558
+ }
1559
+ const path = keyPathForProvider(provider);
1560
+ const value = readConfiguredProviderCredential({
1561
+ provider,
1562
+ config: params.sourceConfig,
1563
+ search
1564
+ });
1565
+ const resolution = await resolveSecretInputWithEnvFallback({
1566
+ sourceConfig: params.sourceConfig,
1567
+ context: params.context,
1568
+ defaults,
1569
+ value,
1570
+ path,
1571
+ envVars: provider.envVars
1572
+ });
1573
+ if (resolution.secretRefConfigured && resolution.fallbackUsedAfterRefFailure) {
1574
+ const diagnostic = {
1575
+ code: "WEB_SEARCH_KEY_UNRESOLVED_FALLBACK_USED",
1576
+ message: `${path} SecretRef could not be resolved; using ${resolution.fallbackEnvVar ?? "env fallback"}. ` + (resolution.unresolvedRefReason ?? "").trim(),
1577
+ path
1578
+ };
1579
+ diagnostics.push(diagnostic);
1580
+ searchMetadata.diagnostics.push(diagnostic);
1581
+ pushWarning(params.context, {
1582
+ code: "WEB_SEARCH_KEY_UNRESOLVED_FALLBACK_USED",
1583
+ path,
1584
+ message: diagnostic.message
1585
+ });
1586
+ }
1587
+ if (resolution.secretRefConfigured && !resolution.value && resolution.unresolvedRefReason) unresolvedWithoutFallback.push({
1588
+ provider: provider.id,
1589
+ path,
1590
+ reason: resolution.unresolvedRefReason
1591
+ });
1592
+ if (configuredProvider) {
1593
+ selectedProvider = provider.id;
1594
+ selectedResolution = resolution;
1595
+ if (resolution.value) setResolvedWebSearchApiKey({
1596
+ resolvedConfig: params.resolvedConfig,
1597
+ provider,
1598
+ value: resolution.value
1599
+ });
1600
+ break;
1601
+ }
1602
+ if (resolution.value) {
1603
+ selectedProvider = provider.id;
1604
+ selectedResolution = resolution;
1605
+ setResolvedWebSearchApiKey({
1606
+ resolvedConfig: params.resolvedConfig,
1607
+ provider,
1608
+ value: resolution.value
1609
+ });
1610
+ break;
1611
+ }
1612
+ }
1613
+ if (!selectedProvider && keylessFallbackProvider) {
1614
+ selectedProvider = keylessFallbackProvider.id;
1615
+ selectedResolution = {
1616
+ source: "missing",
1617
+ secretRefConfigured: false,
1618
+ fallbackUsedAfterRefFailure: false
1619
+ };
1620
+ }
1621
+ const failUnresolvedSearchNoFallback = (unresolved) => {
1622
+ const diagnostic = {
1623
+ code: "WEB_SEARCH_KEY_UNRESOLVED_NO_FALLBACK",
1624
+ message: unresolved.reason,
1625
+ path: unresolved.path
1626
+ };
1627
+ diagnostics.push(diagnostic);
1628
+ searchMetadata.diagnostics.push(diagnostic);
1629
+ pushWarning(params.context, {
1630
+ code: "WEB_SEARCH_KEY_UNRESOLVED_NO_FALLBACK",
1631
+ path: unresolved.path,
1632
+ message: unresolved.reason
1633
+ });
1634
+ throw new Error(`[WEB_SEARCH_KEY_UNRESOLVED_NO_FALLBACK] ${unresolved.reason}`);
1635
+ };
1636
+ if (configuredProvider) {
1637
+ const unresolved = unresolvedWithoutFallback[0];
1638
+ if (unresolved) failUnresolvedSearchNoFallback(unresolved);
1639
+ } else {
1640
+ if (!selectedProvider && unresolvedWithoutFallback.length > 0) failUnresolvedSearchNoFallback(unresolvedWithoutFallback[0]);
1641
+ if (selectedProvider) {
1642
+ const diagnostic = {
1643
+ code: "WEB_SEARCH_AUTODETECT_SELECTED",
1644
+ message: providers.find((entry) => entry.id === selectedProvider)?.requiresCredential === false ? `tools.web.search auto-detected keyless provider "${selectedProvider}" as the default fallback.` : `tools.web.search auto-detected provider "${selectedProvider}" from available credentials.`,
1645
+ path: "tools.web.search.provider"
1646
+ };
1647
+ diagnostics.push(diagnostic);
1648
+ searchMetadata.diagnostics.push(diagnostic);
1649
+ }
1650
+ }
1651
+ if (selectedProvider) {
1652
+ searchMetadata.selectedProvider = selectedProvider;
1653
+ searchMetadata.selectedProviderKeySource = selectedResolution?.source;
1654
+ if (!configuredProvider) searchMetadata.providerSource = "auto-detect";
1655
+ const provider = providers.find((entry) => entry.id === selectedProvider);
1656
+ if (provider?.resolveRuntimeMetadata) Object.assign(searchMetadata, await provider.resolveRuntimeMetadata({
1657
+ config: params.sourceConfig,
1658
+ searchConfig: search,
1659
+ runtimeMetadata: searchMetadata,
1660
+ resolvedCredential: selectedResolution ? {
1661
+ value: selectedResolution.value,
1662
+ source: selectedResolution.source,
1663
+ fallbackEnvVar: selectedResolution.fallbackEnvVar
1664
+ } : void 0
1665
+ }));
1666
+ }
1667
+ }
1668
+ if (searchEnabled && !configuredProvider && searchMetadata.selectedProvider) for (const provider of providers) {
1669
+ if (provider.id === searchMetadata.selectedProvider) continue;
1670
+ if (!hasConfiguredSecretRef(readConfiguredProviderCredential({
1671
+ provider,
1672
+ config: params.sourceConfig,
1673
+ search
1674
+ }), defaults)) continue;
1675
+ for (const path of inactivePathsForProvider(provider)) pushInactiveSurfaceWarning({
1676
+ context: params.context,
1677
+ path,
1678
+ details: `tools.web.search auto-detected provider is "${searchMetadata.selectedProvider}".`
1679
+ });
1680
+ }
1681
+ else if (search && !searchEnabled) for (const provider of providers) {
1682
+ if (!hasConfiguredSecretRef(readConfiguredProviderCredential({
1683
+ provider,
1684
+ config: params.sourceConfig,
1685
+ search
1686
+ }), defaults)) continue;
1687
+ for (const path of inactivePathsForProvider(provider)) pushInactiveSurfaceWarning({
1688
+ context: params.context,
1689
+ path,
1690
+ details: "tools.web.search is disabled."
1691
+ });
1692
+ }
1693
+ if (searchEnabled && search && configuredProvider) for (const provider of providers) {
1694
+ if (provider.id === configuredProvider) continue;
1695
+ if (!hasConfiguredSecretRef(readConfiguredProviderCredential({
1696
+ provider,
1697
+ config: params.sourceConfig,
1698
+ search
1699
+ }), defaults)) continue;
1700
+ for (const path of inactivePathsForProvider(provider)) pushInactiveSurfaceWarning({
1701
+ context: params.context,
1702
+ path,
1703
+ details: `tools.web.search.provider is "${configuredProvider}".`
1704
+ });
1705
+ }
1706
+ const xSearch = isRecord(web?.x_search) ? web.x_search : void 0;
1707
+ const xSearchEnabled = xSearch?.enabled !== false;
1708
+ const xSearchPath = "tools.web.x_search.apiKey";
1709
+ let xSearchResolution = {
1710
+ source: "missing",
1711
+ secretRefConfigured: false,
1712
+ fallbackUsedAfterRefFailure: false
1713
+ };
1714
+ const xSearchDiagnostics = [];
1715
+ if (xSearchEnabled) {
1716
+ xSearchResolution = await resolveSecretInputWithEnvFallback({
1717
+ sourceConfig: params.sourceConfig,
1718
+ context: params.context,
1719
+ defaults,
1720
+ value: xSearch?.apiKey,
1721
+ path: xSearchPath,
1722
+ envVars: ["XAI_API_KEY"]
1723
+ });
1724
+ if (xSearchResolution.value) setResolvedXSearchApiKey({
1725
+ resolvedConfig: params.resolvedConfig,
1726
+ value: xSearchResolution.value
1727
+ });
1728
+ if (xSearchResolution.secretRefConfigured) {
1729
+ if (xSearchResolution.fallbackUsedAfterRefFailure) {
1730
+ const diagnostic = {
1731
+ code: "WEB_X_SEARCH_KEY_UNRESOLVED_FALLBACK_USED",
1732
+ message: `${xSearchPath} SecretRef could not be resolved; using ${xSearchResolution.fallbackEnvVar ?? "env fallback"}. ` + (xSearchResolution.unresolvedRefReason ?? "").trim(),
1733
+ path: xSearchPath
1734
+ };
1735
+ diagnostics.push(diagnostic);
1736
+ xSearchDiagnostics.push(diagnostic);
1737
+ pushWarning(params.context, {
1738
+ code: "WEB_X_SEARCH_KEY_UNRESOLVED_FALLBACK_USED",
1739
+ path: xSearchPath,
1740
+ message: diagnostic.message
1741
+ });
1742
+ }
1743
+ if (!xSearchResolution.value && xSearchResolution.unresolvedRefReason) {
1744
+ const diagnostic = {
1745
+ code: "WEB_X_SEARCH_KEY_UNRESOLVED_NO_FALLBACK",
1746
+ message: xSearchResolution.unresolvedRefReason,
1747
+ path: xSearchPath
1748
+ };
1749
+ diagnostics.push(diagnostic);
1750
+ xSearchDiagnostics.push(diagnostic);
1751
+ pushWarning(params.context, {
1752
+ code: "WEB_X_SEARCH_KEY_UNRESOLVED_NO_FALLBACK",
1753
+ path: xSearchPath,
1754
+ message: xSearchResolution.unresolvedRefReason
1755
+ });
1756
+ throw new Error(`[WEB_X_SEARCH_KEY_UNRESOLVED_NO_FALLBACK] ${xSearchResolution.unresolvedRefReason}`);
1757
+ }
1758
+ }
1759
+ } else if (hasConfiguredSecretRef(xSearch?.apiKey, defaults)) {
1760
+ pushInactiveSurfaceWarning({
1761
+ context: params.context,
1762
+ path: xSearchPath,
1763
+ details: "tools.web.x_search is disabled."
1764
+ });
1765
+ xSearchResolution = {
1766
+ source: "secretRef",
1767
+ secretRefConfigured: true,
1768
+ fallbackUsedAfterRefFailure: false
1769
+ };
1770
+ } else {
1771
+ const configuredInlineValue = normalizeSecretInput(xSearch?.apiKey);
1772
+ if (configuredInlineValue) xSearchResolution = {
1773
+ value: configuredInlineValue,
1774
+ source: "config",
1775
+ secretRefConfigured: false,
1776
+ fallbackUsedAfterRefFailure: false
1777
+ };
1778
+ else {
1779
+ const envFallback = readNonEmptyEnvValue(params.context.env, ["XAI_API_KEY"]);
1780
+ if (envFallback.value) xSearchResolution = {
1781
+ value: envFallback.value,
1782
+ source: "env",
1783
+ fallbackEnvVar: envFallback.envVar,
1784
+ secretRefConfigured: false,
1785
+ fallbackUsedAfterRefFailure: false
1786
+ };
1787
+ }
1788
+ }
1789
+ const fetch = isRecord(web?.fetch) ? web.fetch : void 0;
1790
+ const firecrawl = isRecord(fetch?.firecrawl) ? fetch.firecrawl : void 0;
1791
+ const fetchEnabled = fetch?.enabled !== false;
1792
+ const firecrawlEnabled = firecrawl?.enabled !== false;
1793
+ const firecrawlActive = Boolean(fetchEnabled && firecrawlEnabled);
1794
+ const firecrawlPath = "tools.web.fetch.firecrawl.apiKey";
1795
+ let firecrawlResolution = {
1796
+ source: "missing",
1797
+ secretRefConfigured: false,
1798
+ fallbackUsedAfterRefFailure: false
1799
+ };
1800
+ const firecrawlDiagnostics = [];
1801
+ if (firecrawlActive) {
1802
+ firecrawlResolution = await resolveSecretInputWithEnvFallback({
1803
+ sourceConfig: params.sourceConfig,
1804
+ context: params.context,
1805
+ defaults,
1806
+ value: firecrawl?.apiKey,
1807
+ path: firecrawlPath,
1808
+ envVars: ["FIRECRAWL_API_KEY"]
1809
+ });
1810
+ if (firecrawlResolution.value) setResolvedFirecrawlApiKey({
1811
+ resolvedConfig: params.resolvedConfig,
1812
+ value: firecrawlResolution.value
1813
+ });
1814
+ if (firecrawlResolution.secretRefConfigured) {
1815
+ if (firecrawlResolution.fallbackUsedAfterRefFailure) {
1816
+ const diagnostic = {
1817
+ code: "WEB_FETCH_FIRECRAWL_KEY_UNRESOLVED_FALLBACK_USED",
1818
+ message: `${firecrawlPath} SecretRef could not be resolved; using ${firecrawlResolution.fallbackEnvVar ?? "env fallback"}. ` + (firecrawlResolution.unresolvedRefReason ?? "").trim(),
1819
+ path: firecrawlPath
1820
+ };
1821
+ diagnostics.push(diagnostic);
1822
+ firecrawlDiagnostics.push(diagnostic);
1823
+ pushWarning(params.context, {
1824
+ code: "WEB_FETCH_FIRECRAWL_KEY_UNRESOLVED_FALLBACK_USED",
1825
+ path: firecrawlPath,
1826
+ message: diagnostic.message
1827
+ });
1828
+ }
1829
+ if (!firecrawlResolution.value && firecrawlResolution.unresolvedRefReason) {
1830
+ const diagnostic = {
1831
+ code: "WEB_FETCH_FIRECRAWL_KEY_UNRESOLVED_NO_FALLBACK",
1832
+ message: firecrawlResolution.unresolvedRefReason,
1833
+ path: firecrawlPath
1834
+ };
1835
+ diagnostics.push(diagnostic);
1836
+ firecrawlDiagnostics.push(diagnostic);
1837
+ pushWarning(params.context, {
1838
+ code: "WEB_FETCH_FIRECRAWL_KEY_UNRESOLVED_NO_FALLBACK",
1839
+ path: firecrawlPath,
1840
+ message: firecrawlResolution.unresolvedRefReason
1841
+ });
1842
+ throw new Error(`[WEB_FETCH_FIRECRAWL_KEY_UNRESOLVED_NO_FALLBACK] ${firecrawlResolution.unresolvedRefReason}`);
1843
+ }
1844
+ }
1845
+ } else if (hasConfiguredSecretRef(firecrawl?.apiKey, defaults)) {
1846
+ pushInactiveSurfaceWarning({
1847
+ context: params.context,
1848
+ path: firecrawlPath,
1849
+ details: !fetchEnabled ? "tools.web.fetch is disabled." : "tools.web.fetch.firecrawl.enabled is false."
1850
+ });
1851
+ firecrawlResolution = {
1852
+ source: "secretRef",
1853
+ secretRefConfigured: true,
1854
+ fallbackUsedAfterRefFailure: false
1855
+ };
1856
+ } else {
1857
+ const configuredInlineValue = normalizeSecretInput(firecrawl?.apiKey);
1858
+ if (configuredInlineValue) firecrawlResolution = {
1859
+ value: configuredInlineValue,
1860
+ source: "config",
1861
+ secretRefConfigured: false,
1862
+ fallbackUsedAfterRefFailure: false
1863
+ };
1864
+ else {
1865
+ const envFallback = readNonEmptyEnvValue(params.context.env, ["FIRECRAWL_API_KEY"]);
1866
+ if (envFallback.value) firecrawlResolution = {
1867
+ value: envFallback.value,
1868
+ source: "env",
1869
+ fallbackEnvVar: envFallback.envVar,
1870
+ secretRefConfigured: false,
1871
+ fallbackUsedAfterRefFailure: false
1872
+ };
1873
+ }
1874
+ }
1875
+ return {
1876
+ search: searchMetadata,
1877
+ xSearch: {
1878
+ active: Boolean(xSearchEnabled && xSearchResolution.value),
1879
+ apiKeySource: xSearchResolution.source,
1880
+ diagnostics: xSearchDiagnostics
1881
+ },
1882
+ fetch: { firecrawl: {
1883
+ active: firecrawlActive,
1884
+ apiKeySource: firecrawlResolution.source,
1885
+ diagnostics: firecrawlDiagnostics
1886
+ } },
1887
+ diagnostics
1888
+ };
1889
+ }
1890
+ //#endregion
1891
+ export { applyResolvedAssignments as a, pushWarning as c, assertExpectedResolvedSecretValue as d, hasConfiguredPlaintextSecretValue as f, evaluateGatewayAuthSurfaceStates as i, analyzeCommandSecretAssignmentsFromSnapshot as l, collectConfigAssignments as n, createResolverContext as o, isExpectedResolvedSecretValue as p, GATEWAY_AUTH_SURFACE_PATHS as r, pushAssignment as s, resolveRuntimeWebTools as t, collectCommandSecretAssignmentsFromSnapshot as u };