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,2112 @@
1
+ import { n as defaultRuntime } from "./runtime-D0VpiCHi.js";
2
+ import { t as formatDocsLink } from "./links-Dew9XRNK.js";
3
+ import { r as theme } from "./theme-BJIQPogA.js";
4
+ import { a as loadAuthProfileStoreForSecretsRuntime, d as resolveAuthStorePath } from "./store-DwAEHdgR.js";
5
+ import "./auth-profiles-DgsNxC4M.js";
6
+ import { r as normalizeProviderId } from "./provider-id-CTiEzT1T.js";
7
+ import { _ as resolveStateDir } from "./paths-voC5pD8X.js";
8
+ import { t as danger } from "./globals-DNhziPZz.js";
9
+ import { h as resolveConfigDir, v as resolveUserPath } from "./utils-BiWzD1kh.js";
10
+ import { t as isSafeExecutableValue } from "./exec-safety-FkFR1qf5.js";
11
+ import { d as resolveSecretInputRef, i as coerceSecretRef } from "./types.secrets-CxoujPzV.js";
12
+ import { a as formatExecSecretRefIdValidationMessage, c as isValidSecretProviderAlias, l as resolveDefaultSecretProviderAlias, o as isValidExecSecretRefId, u as secretRefKey } from "./ref-contract-D5ynmOGd.js";
13
+ import { C as SecretProviderSchema } from "./zod-schema.core-BTG8QVOn.js";
14
+ import { c as normalizeAgentId } from "./session-key-BIrdMs11.js";
15
+ import { a as resolveAgentDir, i as resolveAgentConfig, m as resolveDefaultAgentId, r as listAgentIds } from "./agent-scope-BsqFyt8u.js";
16
+ import "./model-selection-DLV9QudA.js";
17
+ import { i as createConfigIO } from "./io-B07IaARR.js";
18
+ import "./config-CKbWnj3S.js";
19
+ import { t as runTasksWithConcurrency } from "./run-with-concurrency-oNPuq9N9.js";
20
+ import { a as parseDotPath, c as writeTextFileAtomic, n as isNonEmptyString, o as parseEnvValue, r as isRecord, s as toDotPath, t as describeUnknownError } from "./shared-B0P4kmoP.js";
21
+ import { a as resolveSecretRefValue, o as resolveSecretRefValues, r as isProviderScopedSecretResolutionError } from "./resolve-BjvAwAfZ.js";
22
+ import { i as listKnownSecretEnvVarNames, n as getProviderEnvVars } from "./provider-env-vars-X-m-m1cR.js";
23
+ import { f as isSecretRefHeaderValueMarker, u as isNonSecretApiKeyMarker } from "./model-auth-markers-CAxoOhNr.js";
24
+ import { a as isKnownSecretTargetType, d as getPath, f as setPathCreateStrict, l as resolvePlanTargetAgainstRegistry, n as discoverConfigSecretTargets, o as listAuthProfileSecretTargetEntries, t as discoverAuthProfileSecretTargets, u as deletePathStrict } from "./target-registry-Je8d-VjB.js";
25
+ import { d as assertExpectedResolvedSecretValue, f as hasConfiguredPlaintextSecretValue, p as isExpectedResolvedSecretValue } from "./runtime-web-tools-Lf22Il6X.js";
26
+ import { a as prepareSecretsRuntimeSnapshot } from "./runtime-gaN3vB28.js";
27
+ import { n as callGatewayFromCli, t as addGatewayClientOptions } from "./gateway-rpc-EUERnNbW.js";
28
+ import fsSync from "node:fs";
29
+ import path from "node:path";
30
+ import os from "node:os";
31
+ import { isDeepStrictEqual } from "node:util";
32
+ import { confirm, select, text } from "@clack/prompts";
33
+ //#region src/secrets/auth-profiles-scan.ts
34
+ function getAuthProfileFieldName(pathPattern) {
35
+ const segments = pathPattern.split(".").filter(Boolean);
36
+ return segments[segments.length - 1] ?? "";
37
+ }
38
+ const AUTH_PROFILE_FIELD_SPEC_BY_TYPE = (() => {
39
+ const defaults = {
40
+ api_key: {
41
+ valueField: "key",
42
+ refField: "keyRef"
43
+ },
44
+ token: {
45
+ valueField: "token",
46
+ refField: "tokenRef"
47
+ }
48
+ };
49
+ for (const target of listAuthProfileSecretTargetEntries()) {
50
+ if (!target.authProfileType) continue;
51
+ defaults[target.authProfileType] = {
52
+ valueField: getAuthProfileFieldName(target.pathPattern),
53
+ refField: target.refPathPattern !== void 0 ? getAuthProfileFieldName(target.refPathPattern) : defaults[target.authProfileType].refField
54
+ };
55
+ }
56
+ return defaults;
57
+ })();
58
+ function getAuthProfileFieldSpec(type) {
59
+ return AUTH_PROFILE_FIELD_SPEC_BY_TYPE[type];
60
+ }
61
+ function toSecretCredentialVisit(params) {
62
+ const spec = getAuthProfileFieldSpec(params.kind);
63
+ return {
64
+ kind: params.kind,
65
+ profileId: params.profileId,
66
+ provider: params.provider,
67
+ profile: params.profile,
68
+ valueField: spec.valueField,
69
+ refField: spec.refField,
70
+ value: params.profile[spec.valueField],
71
+ refValue: params.profile[spec.refField]
72
+ };
73
+ }
74
+ function* iterateAuthProfileCredentials(profiles) {
75
+ for (const [profileId, value] of Object.entries(profiles)) {
76
+ if (!isRecord(value) || !isNonEmptyString(value.provider)) continue;
77
+ const provider = String(value.provider);
78
+ if (value.type === "api_key" || value.type === "token") {
79
+ yield toSecretCredentialVisit({
80
+ kind: value.type,
81
+ profileId,
82
+ provider,
83
+ profile: value
84
+ });
85
+ continue;
86
+ }
87
+ if (value.type === "oauth") yield {
88
+ kind: "oauth",
89
+ profileId,
90
+ provider,
91
+ profile: value,
92
+ hasAccess: isNonEmptyString(value.access),
93
+ hasRefresh: isNonEmptyString(value.refresh)
94
+ };
95
+ }
96
+ }
97
+ //#endregion
98
+ //#region src/secrets/config-io.ts
99
+ const silentConfigIoLogger = {
100
+ error: () => {},
101
+ warn: () => {}
102
+ };
103
+ function createSecretsConfigIO(params) {
104
+ return createConfigIO({
105
+ env: params.env,
106
+ logger: silentConfigIoLogger
107
+ });
108
+ }
109
+ //#endregion
110
+ //#region src/secrets/exec-resolution-policy.ts
111
+ function selectRefsForExecPolicy(params) {
112
+ const refsToResolve = [];
113
+ const skippedExecRefs = [];
114
+ for (const ref of params.refs) {
115
+ if (ref.source === "exec" && !params.allowExec) {
116
+ skippedExecRefs.push(ref);
117
+ continue;
118
+ }
119
+ refsToResolve.push(ref);
120
+ }
121
+ return {
122
+ refsToResolve,
123
+ skippedExecRefs
124
+ };
125
+ }
126
+ function getSkippedExecRefStaticError(params) {
127
+ const id = params.ref.id.trim();
128
+ const refLabel = `${params.ref.source}:${params.ref.provider}:${id}`;
129
+ if (!id) return "Error: Secret reference id is empty.";
130
+ if (!isValidExecSecretRefId(id)) return `Error: ${formatExecSecretRefIdValidationMessage()} (ref: ${refLabel}).`;
131
+ const providerConfig = params.config.secrets?.providers?.[params.ref.provider];
132
+ if (!providerConfig) return `Error: Secret provider "${params.ref.provider}" is not configured (ref: ${refLabel}).`;
133
+ if (providerConfig.source !== params.ref.source) return `Error: Secret provider "${params.ref.provider}" has source "${providerConfig.source}" but ref requests "${params.ref.source}".`;
134
+ return null;
135
+ }
136
+ //#endregion
137
+ //#region src/secrets/plan.ts
138
+ const FORBIDDEN_PATH_SEGMENTS = new Set([
139
+ "__proto__",
140
+ "prototype",
141
+ "constructor"
142
+ ]);
143
+ function isObjectRecord(value) {
144
+ return Boolean(value) && typeof value === "object" && !Array.isArray(value);
145
+ }
146
+ function isSecretProviderConfigShape(value) {
147
+ return SecretProviderSchema.safeParse(value).success;
148
+ }
149
+ function hasForbiddenPathSegment(segments) {
150
+ return segments.some((segment) => FORBIDDEN_PATH_SEGMENTS.has(segment));
151
+ }
152
+ function resolveValidatedPlanTarget(candidate) {
153
+ if (!isKnownSecretTargetType(candidate.type)) return null;
154
+ const path = typeof candidate.path === "string" ? candidate.path.trim() : "";
155
+ if (!path) return null;
156
+ const segments = Array.isArray(candidate.pathSegments) && candidate.pathSegments.length > 0 ? candidate.pathSegments.map((segment) => String(segment).trim()).filter(Boolean) : parseDotPath(path);
157
+ if (segments.length === 0 || hasForbiddenPathSegment(segments) || path !== toDotPath(segments)) return null;
158
+ return resolvePlanTargetAgainstRegistry({
159
+ type: candidate.type,
160
+ pathSegments: segments,
161
+ providerId: candidate.providerId,
162
+ accountId: candidate.accountId
163
+ });
164
+ }
165
+ function isSecretsApplyPlan(value) {
166
+ if (!value || typeof value !== "object" || Array.isArray(value)) return false;
167
+ const typed = value;
168
+ if (typed.version !== 1 || typed.protocolVersion !== 1 || !Array.isArray(typed.targets)) return false;
169
+ for (const target of typed.targets) {
170
+ if (!target || typeof target !== "object") return false;
171
+ const candidate = target;
172
+ const ref = candidate.ref;
173
+ const resolved = resolveValidatedPlanTarget({
174
+ type: candidate.type,
175
+ path: candidate.path,
176
+ pathSegments: candidate.pathSegments,
177
+ agentId: candidate.agentId,
178
+ providerId: candidate.providerId,
179
+ accountId: candidate.accountId,
180
+ authProfileProvider: candidate.authProfileProvider
181
+ });
182
+ if (!isKnownSecretTargetType(candidate.type) || typeof candidate.path !== "string" || !candidate.path.trim() || candidate.pathSegments !== void 0 && !Array.isArray(candidate.pathSegments) || !resolved || !ref || typeof ref !== "object" || ref.source !== "env" && ref.source !== "file" && ref.source !== "exec" || typeof ref.provider !== "string" || ref.provider.trim().length === 0 || typeof ref.id !== "string" || ref.id.trim().length === 0 || ref.source === "exec" && !isValidExecSecretRefId(ref.id)) return false;
183
+ if (resolved.entry.configFile === "auth-profiles.json") {
184
+ if (typeof candidate.agentId !== "string" || candidate.agentId.trim().length === 0) return false;
185
+ if (candidate.authProfileProvider !== void 0 && (typeof candidate.authProfileProvider !== "string" || candidate.authProfileProvider.trim().length === 0)) return false;
186
+ }
187
+ }
188
+ if (typed.providerUpserts !== void 0) {
189
+ if (!isObjectRecord(typed.providerUpserts)) return false;
190
+ for (const [providerAlias, providerValue] of Object.entries(typed.providerUpserts)) {
191
+ if (!isValidSecretProviderAlias(providerAlias)) return false;
192
+ if (!isSecretProviderConfigShape(providerValue)) return false;
193
+ }
194
+ }
195
+ if (typed.providerDeletes !== void 0) {
196
+ if (!Array.isArray(typed.providerDeletes) || typed.providerDeletes.some((providerAlias) => typeof providerAlias !== "string" || !isValidSecretProviderAlias(providerAlias))) return false;
197
+ }
198
+ return true;
199
+ }
200
+ function normalizeSecretsPlanOptions(options) {
201
+ return {
202
+ scrubEnv: options?.scrubEnv ?? true,
203
+ scrubAuthProfilesForProviderTargets: options?.scrubAuthProfilesForProviderTargets ?? true,
204
+ scrubLegacyAuthJson: options?.scrubLegacyAuthJson ?? true
205
+ };
206
+ }
207
+ //#endregion
208
+ //#region src/secrets/auth-store-paths.ts
209
+ function listAuthProfileStorePaths$1(config, stateDir) {
210
+ const paths = /* @__PURE__ */ new Set();
211
+ paths.add(path.join(resolveUserPath(stateDir), "agents", "main", "agent", "auth-profiles.json"));
212
+ const agentsRoot = path.join(resolveUserPath(stateDir), "agents");
213
+ if (fsSync.existsSync(agentsRoot)) for (const entry of fsSync.readdirSync(agentsRoot, { withFileTypes: true })) {
214
+ if (!entry.isDirectory()) continue;
215
+ paths.add(path.join(agentsRoot, entry.name, "agent", "auth-profiles.json"));
216
+ }
217
+ for (const agentId of listAgentIds(config)) {
218
+ if (agentId === "main") {
219
+ paths.add(path.join(resolveUserPath(stateDir), "agents", "main", "agent", "auth-profiles.json"));
220
+ continue;
221
+ }
222
+ const agentDir = resolveAgentDir(config, agentId);
223
+ paths.add(resolveUserPath(resolveAuthStorePath(agentDir)));
224
+ }
225
+ return [...paths];
226
+ }
227
+ //#endregion
228
+ //#region src/secrets/storage-scan.ts
229
+ function parseEnvAssignmentValue(raw) {
230
+ return parseEnvValue(raw);
231
+ }
232
+ function listAuthProfileStorePaths(config, stateDir) {
233
+ return listAuthProfileStorePaths$1(config, stateDir);
234
+ }
235
+ function listLegacyAuthJsonPaths(stateDir) {
236
+ const out = [];
237
+ const agentsRoot = path.join(resolveUserPath(stateDir), "agents");
238
+ if (!fsSync.existsSync(agentsRoot)) return out;
239
+ for (const entry of fsSync.readdirSync(agentsRoot, { withFileTypes: true })) {
240
+ if (!entry.isDirectory()) continue;
241
+ const candidate = path.join(agentsRoot, entry.name, "agent", "auth.json");
242
+ if (fsSync.existsSync(candidate)) out.push(candidate);
243
+ }
244
+ return out;
245
+ }
246
+ function resolveActiveAgentDir(stateDir, env = process.env) {
247
+ const override = env.VORA_AGENT_DIR?.trim() || env.PI_CODING_AGENT_DIR?.trim();
248
+ if (override) return resolveUserPath(override);
249
+ return path.join(resolveUserPath(stateDir), "agents", "main", "agent");
250
+ }
251
+ function listAgentModelsJsonPaths(config, stateDir, env = process.env) {
252
+ const resolvedStateDir = resolveUserPath(stateDir);
253
+ const paths = /* @__PURE__ */ new Set();
254
+ paths.add(path.join(resolvedStateDir, "agents", "main", "agent", "models.json"));
255
+ paths.add(path.join(resolveActiveAgentDir(stateDir, env), "models.json"));
256
+ const agentsRoot = path.join(resolvedStateDir, "agents");
257
+ if (fsSync.existsSync(agentsRoot)) for (const entry of fsSync.readdirSync(agentsRoot, { withFileTypes: true })) {
258
+ if (!entry.isDirectory()) continue;
259
+ paths.add(path.join(agentsRoot, entry.name, "agent", "models.json"));
260
+ }
261
+ for (const agentId of listAgentIds(config)) {
262
+ if (agentId === "main") {
263
+ paths.add(path.join(resolvedStateDir, "agents", "main", "agent", "models.json"));
264
+ continue;
265
+ }
266
+ const agentDir = resolveAgentDir(config, agentId);
267
+ paths.add(path.join(resolveUserPath(agentDir), "models.json"));
268
+ }
269
+ return [...paths];
270
+ }
271
+ function readJsonObjectIfExists(filePath, options = {}) {
272
+ if (!fsSync.existsSync(filePath)) return { value: null };
273
+ try {
274
+ const stats = fsSync.statSync(filePath);
275
+ if (options.requireRegularFile && !stats.isFile()) return {
276
+ value: null,
277
+ error: `Refusing to read non-regular file: ${filePath}`
278
+ };
279
+ if (typeof options.maxBytes === "number" && Number.isFinite(options.maxBytes) && options.maxBytes >= 0 && stats.size > options.maxBytes) return {
280
+ value: null,
281
+ error: `Refusing to read oversized JSON (${stats.size} bytes): ${filePath}`
282
+ };
283
+ const raw = fsSync.readFileSync(filePath, "utf8");
284
+ const parsed = JSON.parse(raw);
285
+ if (!parsed || typeof parsed !== "object" || Array.isArray(parsed)) return { value: null };
286
+ return { value: parsed };
287
+ } catch (err) {
288
+ return {
289
+ value: null,
290
+ error: err instanceof Error ? err.message : String(err)
291
+ };
292
+ }
293
+ }
294
+ //#endregion
295
+ //#region src/secrets/apply.ts
296
+ function planContainsExecReferences(plan) {
297
+ if (plan.targets.some((target) => target.ref.source === "exec")) return true;
298
+ return Object.values(plan.providerUpserts ?? {}).some((provider) => provider.source === "exec");
299
+ }
300
+ function resolveTarget(target) {
301
+ const resolved = resolveValidatedPlanTarget(target);
302
+ if (!resolved) throw new Error(`Invalid plan target path for ${target.type}: ${target.path}`);
303
+ return resolved;
304
+ }
305
+ function scrubEnvRaw(raw, migratedValues, allowedEnvKeys) {
306
+ if (migratedValues.size === 0 || allowedEnvKeys.size === 0) return {
307
+ nextRaw: raw,
308
+ removed: 0
309
+ };
310
+ const lines = raw.split(/\r?\n/);
311
+ const nextLines = [];
312
+ let removed = 0;
313
+ for (const line of lines) {
314
+ const match = line.match(/^\s*(?:export\s+)?([A-Za-z_][A-Za-z0-9_]*)\s*=\s*(.*)$/);
315
+ if (!match) {
316
+ nextLines.push(line);
317
+ continue;
318
+ }
319
+ const envKey = match[1] ?? "";
320
+ if (!allowedEnvKeys.has(envKey)) {
321
+ nextLines.push(line);
322
+ continue;
323
+ }
324
+ const parsedValue = parseEnvAssignmentValue(match[2] ?? "");
325
+ if (migratedValues.has(parsedValue)) {
326
+ removed += 1;
327
+ continue;
328
+ }
329
+ nextLines.push(line);
330
+ }
331
+ const hadTrailingNewline = raw.endsWith("\n");
332
+ const joined = nextLines.join("\n");
333
+ return {
334
+ nextRaw: hadTrailingNewline || joined.length === 0 ? `${joined}${joined.endsWith("\n") ? "" : "\n"}` : joined,
335
+ removed
336
+ };
337
+ }
338
+ function applyProviderPlanMutations(params) {
339
+ const currentProviders = isRecord(params.config.secrets?.providers) ? structuredClone(params.config.secrets?.providers) : {};
340
+ let changed = false;
341
+ for (const providerAlias of params.deletes ?? []) {
342
+ if (!Object.prototype.hasOwnProperty.call(currentProviders, providerAlias)) continue;
343
+ delete currentProviders[providerAlias];
344
+ changed = true;
345
+ }
346
+ for (const [providerAlias, providerConfig] of Object.entries(params.upserts ?? {})) {
347
+ const previous = currentProviders[providerAlias];
348
+ if (isDeepStrictEqual(previous, providerConfig)) continue;
349
+ currentProviders[providerAlias] = structuredClone(providerConfig);
350
+ changed = true;
351
+ }
352
+ if (!changed) return false;
353
+ params.config.secrets ??= {};
354
+ if (Object.keys(currentProviders).length === 0) {
355
+ if ("providers" in params.config.secrets) delete params.config.secrets.providers;
356
+ return true;
357
+ }
358
+ params.config.secrets.providers = currentProviders;
359
+ return true;
360
+ }
361
+ async function projectPlanState(params) {
362
+ const { snapshot, writeOptions } = await createSecretsConfigIO({ env: params.env }).readConfigFileSnapshotForWrite();
363
+ if (!snapshot.valid) throw new Error("Cannot apply secrets plan: config is invalid.");
364
+ const options = normalizeSecretsPlanOptions(params.plan.options);
365
+ const nextConfig = structuredClone(snapshot.config);
366
+ const stateDir = resolveStateDir(params.env, os.homedir);
367
+ const changedFiles = /* @__PURE__ */ new Set();
368
+ const warnings = [];
369
+ const configPath = resolveUserPath(snapshot.path);
370
+ if (applyProviderPlanMutations({
371
+ config: nextConfig,
372
+ upserts: params.plan.providerUpserts,
373
+ deletes: params.plan.providerDeletes
374
+ })) changedFiles.add(configPath);
375
+ const targetMutations = applyConfigTargetMutations({
376
+ planTargets: params.plan.targets,
377
+ nextConfig,
378
+ stateDir,
379
+ authStoreByPath: /* @__PURE__ */ new Map(),
380
+ changedFiles
381
+ });
382
+ if (targetMutations.configChanged) changedFiles.add(configPath);
383
+ const authStoreByPath = scrubAuthStoresForProviderTargets({
384
+ nextConfig,
385
+ stateDir,
386
+ providerTargets: targetMutations.providerTargets,
387
+ scrubbedValues: targetMutations.scrubbedValues,
388
+ authStoreByPath: targetMutations.authStoreByPath,
389
+ changedFiles,
390
+ warnings,
391
+ enabled: options.scrubAuthProfilesForProviderTargets
392
+ });
393
+ const authJsonByPath = scrubLegacyAuthJsonStores({
394
+ stateDir,
395
+ changedFiles,
396
+ enabled: options.scrubLegacyAuthJson
397
+ });
398
+ const envRawByPath = scrubEnvFiles({
399
+ env: params.env,
400
+ scrubbedValues: targetMutations.scrubbedValues,
401
+ changedFiles,
402
+ enabled: options.scrubEnv
403
+ });
404
+ const validation = await validateProjectedSecretsState({
405
+ env: params.env,
406
+ nextConfig,
407
+ resolvedTargets: targetMutations.resolvedTargets,
408
+ authStoreByPath,
409
+ write: params.write,
410
+ allowExecInDryRun: params.allowExecInDryRun
411
+ });
412
+ return {
413
+ nextConfig,
414
+ configPath,
415
+ configWriteOptions: writeOptions,
416
+ authStoreByPath,
417
+ authJsonByPath,
418
+ envRawByPath,
419
+ changedFiles,
420
+ warnings,
421
+ refsChecked: validation.refsChecked,
422
+ skippedExecRefs: validation.skippedExecRefs,
423
+ resolvabilityComplete: validation.resolvabilityComplete
424
+ };
425
+ }
426
+ function applyConfigTargetMutations(params) {
427
+ const resolvedTargets = params.planTargets.map((target) => ({
428
+ target,
429
+ resolved: resolveTarget(target)
430
+ }));
431
+ const scrubbedValues = /* @__PURE__ */ new Set();
432
+ const providerTargets = /* @__PURE__ */ new Set();
433
+ let configChanged = false;
434
+ for (const { target, resolved } of resolvedTargets) {
435
+ if (resolved.entry.configFile === "auth-profiles.json") {
436
+ if (applyAuthProfileTargetMutation({
437
+ target,
438
+ resolved,
439
+ nextConfig: params.nextConfig,
440
+ stateDir: params.stateDir,
441
+ authStoreByPath: params.authStoreByPath,
442
+ scrubbedValues
443
+ })) {
444
+ const agentId = String(target.agentId ?? "").trim();
445
+ if (!agentId) throw new Error(`Missing required agentId for auth-profiles target ${target.path}.`);
446
+ params.changedFiles.add(resolveAuthStorePathForAgent({
447
+ nextConfig: params.nextConfig,
448
+ stateDir: params.stateDir,
449
+ agentId
450
+ }));
451
+ }
452
+ continue;
453
+ }
454
+ const targetPathSegments = resolved.pathSegments;
455
+ if (resolved.entry.secretShape === "sibling_ref") {
456
+ const previous = getPath(params.nextConfig, targetPathSegments);
457
+ if (isNonEmptyString(previous)) scrubbedValues.add(previous.trim());
458
+ const refPathSegments = resolved.refPathSegments;
459
+ if (!refPathSegments) throw new Error(`Missing sibling ref path for target ${target.type}.`);
460
+ const wroteRef = setPathCreateStrict(params.nextConfig, refPathSegments, target.ref);
461
+ const deletedLegacy = deletePathStrict(params.nextConfig, targetPathSegments);
462
+ if (wroteRef || deletedLegacy) configChanged = true;
463
+ continue;
464
+ }
465
+ const previous = getPath(params.nextConfig, targetPathSegments);
466
+ if (isNonEmptyString(previous)) scrubbedValues.add(previous.trim());
467
+ if (setPathCreateStrict(params.nextConfig, targetPathSegments, target.ref)) configChanged = true;
468
+ if (resolved.entry.trackProviderShadowing && resolved.providerId) providerTargets.add(normalizeProviderId(resolved.providerId));
469
+ }
470
+ return {
471
+ resolvedTargets,
472
+ scrubbedValues,
473
+ providerTargets,
474
+ configChanged,
475
+ authStoreByPath: params.authStoreByPath
476
+ };
477
+ }
478
+ function scrubAuthStoresForProviderTargets(params) {
479
+ if (!params.enabled || params.providerTargets.size === 0) return params.authStoreByPath;
480
+ for (const authStorePath of listAuthProfileStorePaths(params.nextConfig, params.stateDir)) {
481
+ const parsed = params.authStoreByPath.get(authStorePath) ?? readJsonObjectIfExists(authStorePath).value;
482
+ if (!parsed || !isRecord(parsed.profiles)) continue;
483
+ const nextStore = structuredClone(parsed);
484
+ let mutated = false;
485
+ for (const profile of iterateAuthProfileCredentials(nextStore.profiles)) {
486
+ const provider = normalizeProviderId(profile.provider);
487
+ if (!params.providerTargets.has(provider)) continue;
488
+ if (profile.kind === "api_key" || profile.kind === "token") {
489
+ if (isNonEmptyString(profile.value)) params.scrubbedValues.add(profile.value.trim());
490
+ if (profile.valueField in profile.profile) {
491
+ delete profile.profile[profile.valueField];
492
+ mutated = true;
493
+ }
494
+ if (profile.refField in profile.profile) {
495
+ delete profile.profile[profile.refField];
496
+ mutated = true;
497
+ }
498
+ continue;
499
+ }
500
+ if (profile.kind === "oauth" && (profile.hasAccess || profile.hasRefresh)) params.warnings.push(`Provider "${provider}" has OAuth credentials in ${authStorePath}; those still take precedence and are out of scope for static SecretRef migration.`);
501
+ }
502
+ if (mutated) {
503
+ params.authStoreByPath.set(authStorePath, nextStore);
504
+ params.changedFiles.add(authStorePath);
505
+ }
506
+ }
507
+ return params.authStoreByPath;
508
+ }
509
+ function ensureMutableAuthStore(store) {
510
+ const next = store ? structuredClone(store) : {};
511
+ if (!isRecord(next.profiles)) next.profiles = {};
512
+ if (typeof next.version !== "number" || !Number.isFinite(next.version)) next.version = 1;
513
+ return next;
514
+ }
515
+ function resolveAuthStoreForTarget(params) {
516
+ const agentId = String(params.target.agentId ?? "").trim();
517
+ if (!agentId) throw new Error(`Missing required agentId for auth-profiles target ${params.target.path}.`);
518
+ const authStorePath = resolveAuthStorePathForAgent({
519
+ nextConfig: params.nextConfig,
520
+ stateDir: params.stateDir,
521
+ agentId
522
+ });
523
+ const loaded = params.authStoreByPath.get(authStorePath) ?? readJsonObjectIfExists(authStorePath).value;
524
+ const store = ensureMutableAuthStore(isRecord(loaded) ? loaded : void 0);
525
+ params.authStoreByPath.set(authStorePath, store);
526
+ return {
527
+ path: authStorePath,
528
+ store
529
+ };
530
+ }
531
+ function asConfigPathRoot(store) {
532
+ return store;
533
+ }
534
+ function resolveAuthStorePathForAgent(params) {
535
+ const normalizedAgentId = normalizeAgentId(params.agentId);
536
+ const configuredAgentDir = resolveAgentConfig(params.nextConfig, normalizedAgentId)?.agentDir?.trim();
537
+ if (configuredAgentDir) return resolveUserPath(resolveAuthStorePath(configuredAgentDir));
538
+ return path.join(resolveUserPath(params.stateDir), "agents", normalizedAgentId, "agent", "auth-profiles.json");
539
+ }
540
+ function ensureAuthProfileContainer(params) {
541
+ let changed = false;
542
+ const profilePathSegments = params.resolved.pathSegments.slice(0, 2);
543
+ const profileId = profilePathSegments[1];
544
+ if (!profileId) throw new Error(`Invalid auth profile target path: ${params.target.path}`);
545
+ const current = getPath(params.store, profilePathSegments);
546
+ const expectedType = params.resolved.entry.authProfileType;
547
+ if (isRecord(current)) {
548
+ if (expectedType && typeof current.type === "string" && current.type !== expectedType) throw new Error(`Auth profile "${profileId}" type mismatch for ${params.target.path}: expected "${expectedType}", got "${current.type}".`);
549
+ if (!isNonEmptyString(current.provider) && isNonEmptyString(params.target.authProfileProvider)) {
550
+ const wroteProvider = setPathCreateStrict(asConfigPathRoot(params.store), [...profilePathSegments, "provider"], params.target.authProfileProvider);
551
+ changed = changed || wroteProvider;
552
+ }
553
+ return changed;
554
+ }
555
+ if (!expectedType) throw new Error(`Auth profile target ${params.target.path} is missing auth profile type metadata.`);
556
+ const provider = String(params.target.authProfileProvider ?? "").trim();
557
+ if (!provider) throw new Error(`Cannot create auth profile "${profileId}" for ${params.target.path} without authProfileProvider.`);
558
+ const wroteProfile = setPathCreateStrict(asConfigPathRoot(params.store), profilePathSegments, {
559
+ type: expectedType,
560
+ provider
561
+ });
562
+ changed = changed || wroteProfile;
563
+ return changed;
564
+ }
565
+ function applyAuthProfileTargetMutation(params) {
566
+ if (params.resolved.entry.configFile !== "auth-profiles.json") return false;
567
+ const { store } = resolveAuthStoreForTarget({
568
+ target: params.target,
569
+ nextConfig: params.nextConfig,
570
+ stateDir: params.stateDir,
571
+ authStoreByPath: params.authStoreByPath
572
+ });
573
+ let changed = ensureAuthProfileContainer({
574
+ target: params.target,
575
+ resolved: params.resolved,
576
+ store
577
+ });
578
+ const targetPathSegments = params.resolved.pathSegments;
579
+ if (params.resolved.entry.secretShape === "sibling_ref") {
580
+ const previous = getPath(store, targetPathSegments);
581
+ if (isNonEmptyString(previous)) params.scrubbedValues.add(previous.trim());
582
+ const refPathSegments = params.resolved.refPathSegments;
583
+ if (!refPathSegments) throw new Error(`Missing sibling ref path for auth-profiles target ${params.target.path}.`);
584
+ const wroteRef = setPathCreateStrict(asConfigPathRoot(store), refPathSegments, params.target.ref);
585
+ const deletedPlaintext = deletePathStrict(asConfigPathRoot(store), targetPathSegments);
586
+ changed = changed || wroteRef || deletedPlaintext;
587
+ return changed;
588
+ }
589
+ const previous = getPath(store, targetPathSegments);
590
+ if (isNonEmptyString(previous)) params.scrubbedValues.add(previous.trim());
591
+ const wroteRef = setPathCreateStrict(asConfigPathRoot(store), targetPathSegments, params.target.ref);
592
+ changed = changed || wroteRef;
593
+ return changed;
594
+ }
595
+ function scrubLegacyAuthJsonStores(params) {
596
+ const authJsonByPath = /* @__PURE__ */ new Map();
597
+ if (!params.enabled) return authJsonByPath;
598
+ for (const authJsonPath of listLegacyAuthJsonPaths(params.stateDir)) {
599
+ const parsed = readJsonObjectIfExists(authJsonPath).value;
600
+ if (!parsed) continue;
601
+ let mutated = false;
602
+ const nextParsed = structuredClone(parsed);
603
+ for (const [providerId, value] of Object.entries(nextParsed)) {
604
+ if (!isRecord(value)) continue;
605
+ if (value.type === "api_key" && isNonEmptyString(value.key)) {
606
+ delete nextParsed[providerId];
607
+ mutated = true;
608
+ }
609
+ }
610
+ if (mutated) {
611
+ authJsonByPath.set(authJsonPath, nextParsed);
612
+ params.changedFiles.add(authJsonPath);
613
+ }
614
+ }
615
+ return authJsonByPath;
616
+ }
617
+ function scrubEnvFiles(params) {
618
+ const envRawByPath = /* @__PURE__ */ new Map();
619
+ if (!params.enabled || params.scrubbedValues.size === 0) return envRawByPath;
620
+ const envPath = path.join(resolveConfigDir(params.env, os.homedir), ".env");
621
+ if (!fsSync.existsSync(envPath)) return envRawByPath;
622
+ const current = fsSync.readFileSync(envPath, "utf8");
623
+ const scrubbed = scrubEnvRaw(current, params.scrubbedValues, new Set(listKnownSecretEnvVarNames()));
624
+ if (scrubbed.removed > 0 && scrubbed.nextRaw !== current) {
625
+ envRawByPath.set(envPath, scrubbed.nextRaw);
626
+ params.changedFiles.add(envPath);
627
+ }
628
+ return envRawByPath;
629
+ }
630
+ async function validateProjectedSecretsState(params) {
631
+ const cache = {};
632
+ let refsChecked = 0;
633
+ let skippedExecRefs = 0;
634
+ for (const { target, resolved: resolvedTarget } of params.resolvedTargets) {
635
+ if (!params.write && target.ref.source === "exec" && !params.allowExecInDryRun) {
636
+ skippedExecRefs += 1;
637
+ const staticError = getSkippedExecRefStaticError({
638
+ ref: target.ref,
639
+ config: params.nextConfig
640
+ });
641
+ if (staticError) throw new Error(staticError);
642
+ continue;
643
+ }
644
+ const resolved = await resolveSecretRefValue(target.ref, {
645
+ config: params.nextConfig,
646
+ env: params.env,
647
+ cache
648
+ });
649
+ refsChecked += 1;
650
+ assertExpectedResolvedSecretValue({
651
+ value: resolved,
652
+ expected: resolvedTarget.entry.expectedResolvedValue,
653
+ errorMessage: resolvedTarget.entry.expectedResolvedValue === "string" ? `Ref ${target.ref.source}:${target.ref.provider}:${target.ref.id} is not a non-empty string.` : `Ref ${target.ref.source}:${target.ref.provider}:${target.ref.id} is not string/object.`
654
+ });
655
+ }
656
+ const authStoreLookup = /* @__PURE__ */ new Map();
657
+ for (const [authStorePath, store] of params.authStoreByPath.entries()) authStoreLookup.set(resolveUserPath(authStorePath), store);
658
+ if (params.write || params.allowExecInDryRun) await prepareSecretsRuntimeSnapshot({
659
+ config: params.nextConfig,
660
+ env: params.env,
661
+ loadAuthStore: (agentDir) => {
662
+ const storePath = resolveUserPath(resolveAuthStorePath(agentDir));
663
+ const override = authStoreLookup.get(storePath);
664
+ if (override) return structuredClone(override);
665
+ return loadAuthProfileStoreForSecretsRuntime(agentDir);
666
+ }
667
+ });
668
+ return {
669
+ refsChecked,
670
+ skippedExecRefs,
671
+ resolvabilityComplete: params.write || params.allowExecInDryRun || skippedExecRefs === 0
672
+ };
673
+ }
674
+ function captureFileSnapshot(pathname) {
675
+ if (!fsSync.existsSync(pathname)) return {
676
+ existed: false,
677
+ content: "",
678
+ mode: 384
679
+ };
680
+ const stat = fsSync.statSync(pathname);
681
+ return {
682
+ existed: true,
683
+ content: fsSync.readFileSync(pathname, "utf8"),
684
+ mode: stat.mode & 511
685
+ };
686
+ }
687
+ function restoreFileSnapshot(pathname, snapshot) {
688
+ if (!snapshot.existed) {
689
+ if (fsSync.existsSync(pathname)) fsSync.rmSync(pathname, { force: true });
690
+ return;
691
+ }
692
+ writeTextFileAtomic(pathname, snapshot.content, snapshot.mode || 384);
693
+ }
694
+ function toJsonWrite(pathname, value) {
695
+ return {
696
+ path: pathname,
697
+ content: `${JSON.stringify(value, null, 2)}\n`,
698
+ mode: 384
699
+ };
700
+ }
701
+ async function runSecretsApply(params) {
702
+ const env = params.env ?? process.env;
703
+ const write = params.write === true;
704
+ const allowExec = Boolean(params.allowExec);
705
+ if (write && planContainsExecReferences(params.plan) && !allowExec) throw new Error("Plan contains exec SecretRefs/providers. Re-run with --allow-exec.");
706
+ const allowExecInDryRun = write ? true : allowExec;
707
+ const projected = await projectPlanState({
708
+ plan: params.plan,
709
+ env,
710
+ write,
711
+ allowExecInDryRun
712
+ });
713
+ const changedFiles = [...projected.changedFiles].toSorted();
714
+ if (!write) return {
715
+ mode: "dry-run",
716
+ changed: changedFiles.length > 0,
717
+ changedFiles,
718
+ checks: {
719
+ resolvability: true,
720
+ resolvabilityComplete: projected.resolvabilityComplete
721
+ },
722
+ refsChecked: projected.refsChecked,
723
+ skippedExecRefs: projected.skippedExecRefs,
724
+ warningCount: projected.warnings.length,
725
+ warnings: projected.warnings
726
+ };
727
+ if (changedFiles.length === 0) return {
728
+ mode: "write",
729
+ changed: false,
730
+ changedFiles: [],
731
+ checks: {
732
+ resolvability: true,
733
+ resolvabilityComplete: true
734
+ },
735
+ refsChecked: projected.refsChecked,
736
+ skippedExecRefs: 0,
737
+ warningCount: projected.warnings.length,
738
+ warnings: projected.warnings
739
+ };
740
+ const io = createSecretsConfigIO({ env });
741
+ const snapshots = /* @__PURE__ */ new Map();
742
+ const capture = (pathname) => {
743
+ if (!snapshots.has(pathname)) snapshots.set(pathname, captureFileSnapshot(pathname));
744
+ };
745
+ capture(projected.configPath);
746
+ const writes = [];
747
+ for (const [pathname, value] of projected.authStoreByPath.entries()) {
748
+ capture(pathname);
749
+ writes.push(toJsonWrite(pathname, value));
750
+ }
751
+ for (const [pathname, value] of projected.authJsonByPath.entries()) {
752
+ capture(pathname);
753
+ writes.push(toJsonWrite(pathname, value));
754
+ }
755
+ for (const [pathname, raw] of projected.envRawByPath.entries()) {
756
+ capture(pathname);
757
+ writes.push({
758
+ path: pathname,
759
+ content: raw,
760
+ mode: 384
761
+ });
762
+ }
763
+ try {
764
+ await io.writeConfigFile(projected.nextConfig, projected.configWriteOptions);
765
+ for (const write of writes) writeTextFileAtomic(write.path, write.content, write.mode);
766
+ } catch (err) {
767
+ for (const [pathname, snapshot] of snapshots.entries()) try {
768
+ restoreFileSnapshot(pathname, snapshot);
769
+ } catch {}
770
+ throw new Error(`Secrets apply failed: ${String(err)}`, { cause: err });
771
+ }
772
+ return {
773
+ mode: "write",
774
+ changed: changedFiles.length > 0,
775
+ changedFiles,
776
+ checks: {
777
+ resolvability: true,
778
+ resolvabilityComplete: true
779
+ },
780
+ refsChecked: projected.refsChecked,
781
+ skippedExecRefs: 0,
782
+ warningCount: projected.warnings.length,
783
+ warnings: projected.warnings
784
+ };
785
+ }
786
+ //#endregion
787
+ //#region src/secrets/audit.ts
788
+ const REF_RESOLVE_FALLBACK_CONCURRENCY = 8;
789
+ const MAX_AUDIT_MODELS_JSON_BYTES = 5 * 1024 * 1024;
790
+ const ALWAYS_SENSITIVE_MODEL_PROVIDER_HEADER_NAMES = new Set([
791
+ "authorization",
792
+ "proxy-authorization",
793
+ "x-api-key",
794
+ "api-key",
795
+ "apikey",
796
+ "x-auth-token",
797
+ "auth-token",
798
+ "x-access-token",
799
+ "access-token",
800
+ "x-secret-key",
801
+ "secret-key"
802
+ ]);
803
+ const SENSITIVE_MODEL_PROVIDER_HEADER_NAME_FRAGMENTS = [
804
+ "api-key",
805
+ "apikey",
806
+ "token",
807
+ "secret",
808
+ "password",
809
+ "credential"
810
+ ];
811
+ function isLikelySensitiveModelProviderHeaderName(value) {
812
+ const normalized = value.trim().toLowerCase();
813
+ if (!normalized) return false;
814
+ if (ALWAYS_SENSITIVE_MODEL_PROVIDER_HEADER_NAMES.has(normalized)) return true;
815
+ return SENSITIVE_MODEL_PROVIDER_HEADER_NAME_FRAGMENTS.some((fragment) => normalized.includes(fragment));
816
+ }
817
+ function addFinding(collector, finding) {
818
+ collector.findings.push(finding);
819
+ }
820
+ function collectProviderRefPath(collector, providerId, configPath) {
821
+ const key = normalizeProviderId(providerId);
822
+ const existing = collector.configProviderRefPaths.get(key);
823
+ if (existing) {
824
+ existing.push(configPath);
825
+ return;
826
+ }
827
+ collector.configProviderRefPaths.set(key, [configPath]);
828
+ }
829
+ function trackAuthProviderState(collector, provider, mode) {
830
+ const key = normalizeProviderId(provider);
831
+ const existing = collector.authProviderState.get(key);
832
+ if (existing) {
833
+ existing.hasUsableStaticOrOAuth = true;
834
+ existing.modes.add(mode);
835
+ return;
836
+ }
837
+ collector.authProviderState.set(key, {
838
+ hasUsableStaticOrOAuth: true,
839
+ modes: new Set([mode])
840
+ });
841
+ }
842
+ function collectEnvPlaintext(params) {
843
+ if (!fsSync.existsSync(params.envPath)) return;
844
+ params.collector.filesScanned.add(params.envPath);
845
+ const knownKeys = new Set(listKnownSecretEnvVarNames());
846
+ const lines = fsSync.readFileSync(params.envPath, "utf8").split(/\r?\n/);
847
+ for (const line of lines) {
848
+ const match = line.match(/^\s*(?:export\s+)?([A-Za-z_][A-Za-z0-9_]*)\s*=\s*(.*)$/);
849
+ if (!match) continue;
850
+ const key = match[1] ?? "";
851
+ if (!knownKeys.has(key)) continue;
852
+ if (!parseEnvAssignmentValue(match[2] ?? "")) continue;
853
+ addFinding(params.collector, {
854
+ code: "PLAINTEXT_FOUND",
855
+ severity: "warn",
856
+ file: params.envPath,
857
+ jsonPath: `$env.${key}`,
858
+ message: `Potential secret found in .env (${key}).`
859
+ });
860
+ }
861
+ }
862
+ function collectConfigSecrets(params) {
863
+ const defaults = params.config.secrets?.defaults;
864
+ for (const target of discoverConfigSecretTargets(params.config)) {
865
+ if (!target.entry.includeInAudit) continue;
866
+ const { ref } = resolveSecretInputRef({
867
+ value: target.value,
868
+ refValue: target.refValue,
869
+ defaults
870
+ });
871
+ if (ref) {
872
+ params.collector.refAssignments.push({
873
+ file: params.configPath,
874
+ path: target.path,
875
+ ref,
876
+ expected: target.entry.expectedResolvedValue,
877
+ provider: target.providerId
878
+ });
879
+ if (target.entry.trackProviderShadowing && target.providerId) collectProviderRefPath(params.collector, target.providerId, target.path);
880
+ continue;
881
+ }
882
+ const hasPlaintext = hasConfiguredPlaintextSecretValue(target.value, target.entry.expectedResolvedValue);
883
+ if (target.entry.id === "models.providers.*.headers.*" && !isLikelySensitiveModelProviderHeaderName(target.pathSegments.at(-1) ?? "")) continue;
884
+ if (!hasPlaintext) continue;
885
+ addFinding(params.collector, {
886
+ code: "PLAINTEXT_FOUND",
887
+ severity: "warn",
888
+ file: params.configPath,
889
+ jsonPath: target.path,
890
+ message: `${target.path} is stored as plaintext.`,
891
+ provider: target.providerId
892
+ });
893
+ }
894
+ }
895
+ function collectAuthStoreSecrets(params) {
896
+ if (!fsSync.existsSync(params.authStorePath)) return;
897
+ params.collector.filesScanned.add(params.authStorePath);
898
+ const parsedResult = readJsonObjectIfExists(params.authStorePath);
899
+ if (parsedResult.error) {
900
+ addFinding(params.collector, {
901
+ code: "REF_UNRESOLVED",
902
+ severity: "error",
903
+ file: params.authStorePath,
904
+ jsonPath: "<root>",
905
+ message: `Invalid JSON in auth-profiles store: ${parsedResult.error}`
906
+ });
907
+ return;
908
+ }
909
+ const parsed = parsedResult.value;
910
+ if (!parsed || !isRecord(parsed.profiles)) return;
911
+ for (const entry of iterateAuthProfileCredentials(parsed.profiles)) {
912
+ if (entry.kind === "api_key" || entry.kind === "token") {
913
+ const { ref } = resolveSecretInputRef({
914
+ value: entry.value,
915
+ refValue: entry.refValue,
916
+ defaults: params.defaults
917
+ });
918
+ if (ref) {
919
+ params.collector.refAssignments.push({
920
+ file: params.authStorePath,
921
+ path: `profiles.${entry.profileId}.${entry.valueField}`,
922
+ ref,
923
+ expected: "string",
924
+ provider: entry.provider
925
+ });
926
+ trackAuthProviderState(params.collector, entry.provider, entry.kind);
927
+ }
928
+ if (isNonEmptyString(entry.value)) {
929
+ addFinding(params.collector, {
930
+ code: "PLAINTEXT_FOUND",
931
+ severity: "warn",
932
+ file: params.authStorePath,
933
+ jsonPath: `profiles.${entry.profileId}.${entry.valueField}`,
934
+ message: entry.kind === "api_key" ? "Auth profile API key is stored as plaintext." : "Auth profile token is stored as plaintext.",
935
+ provider: entry.provider,
936
+ profileId: entry.profileId
937
+ });
938
+ trackAuthProviderState(params.collector, entry.provider, entry.kind);
939
+ }
940
+ continue;
941
+ }
942
+ if (entry.hasAccess || entry.hasRefresh) {
943
+ addFinding(params.collector, {
944
+ code: "LEGACY_RESIDUE",
945
+ severity: "info",
946
+ file: params.authStorePath,
947
+ jsonPath: `profiles.${entry.profileId}`,
948
+ message: "OAuth credentials are present (out of scope for static SecretRef migration).",
949
+ provider: entry.provider,
950
+ profileId: entry.profileId
951
+ });
952
+ trackAuthProviderState(params.collector, entry.provider, "oauth");
953
+ }
954
+ }
955
+ }
956
+ function collectAuthJsonResidue(params) {
957
+ for (const authJsonPath of listLegacyAuthJsonPaths(params.stateDir)) {
958
+ params.collector.filesScanned.add(authJsonPath);
959
+ const parsedResult = readJsonObjectIfExists(authJsonPath);
960
+ if (parsedResult.error) {
961
+ addFinding(params.collector, {
962
+ code: "REF_UNRESOLVED",
963
+ severity: "error",
964
+ file: authJsonPath,
965
+ jsonPath: "<root>",
966
+ message: `Invalid JSON in legacy auth.json: ${parsedResult.error}`
967
+ });
968
+ continue;
969
+ }
970
+ const parsed = parsedResult.value;
971
+ if (!parsed) continue;
972
+ for (const [providerId, value] of Object.entries(parsed)) {
973
+ if (!isRecord(value)) continue;
974
+ if (value.type === "api_key" && isNonEmptyString(value.key)) addFinding(params.collector, {
975
+ code: "LEGACY_RESIDUE",
976
+ severity: "warn",
977
+ file: authJsonPath,
978
+ jsonPath: providerId,
979
+ message: "Legacy auth.json contains static api_key credentials.",
980
+ provider: providerId
981
+ });
982
+ }
983
+ }
984
+ }
985
+ function collectModelsJsonSecrets(params) {
986
+ if (!fsSync.existsSync(params.modelsJsonPath)) return;
987
+ params.collector.filesScanned.add(params.modelsJsonPath);
988
+ const parsedResult = readJsonObjectIfExists(params.modelsJsonPath, {
989
+ requireRegularFile: true,
990
+ maxBytes: MAX_AUDIT_MODELS_JSON_BYTES
991
+ });
992
+ if (parsedResult.error) {
993
+ addFinding(params.collector, {
994
+ code: "REF_UNRESOLVED",
995
+ severity: "error",
996
+ file: params.modelsJsonPath,
997
+ jsonPath: "<root>",
998
+ message: `Invalid JSON in models.json: ${parsedResult.error}`
999
+ });
1000
+ return;
1001
+ }
1002
+ const parsed = parsedResult.value;
1003
+ if (!parsed || !isRecord(parsed.providers)) return;
1004
+ for (const [providerId, providerValue] of Object.entries(parsed.providers)) {
1005
+ if (!isRecord(providerValue)) continue;
1006
+ const apiKey = providerValue.apiKey;
1007
+ if (coerceSecretRef(apiKey)) addFinding(params.collector, {
1008
+ code: "REF_UNRESOLVED",
1009
+ severity: "error",
1010
+ file: params.modelsJsonPath,
1011
+ jsonPath: `providers.${providerId}.apiKey`,
1012
+ message: "models.json contains an unresolved SecretRef object; regenerate models.json.",
1013
+ provider: providerId
1014
+ });
1015
+ else if (isNonEmptyString(apiKey) && !isNonSecretApiKeyMarker(apiKey)) addFinding(params.collector, {
1016
+ code: "PLAINTEXT_FOUND",
1017
+ severity: "warn",
1018
+ file: params.modelsJsonPath,
1019
+ jsonPath: `providers.${providerId}.apiKey`,
1020
+ message: "models.json provider apiKey is stored as plaintext.",
1021
+ provider: providerId
1022
+ });
1023
+ const headers = isRecord(providerValue.headers) ? providerValue.headers : void 0;
1024
+ if (!headers) continue;
1025
+ for (const [headerKey, headerValue] of Object.entries(headers)) {
1026
+ const headerPath = `providers.${providerId}.headers.${headerKey}`;
1027
+ if (coerceSecretRef(headerValue)) {
1028
+ addFinding(params.collector, {
1029
+ code: "REF_UNRESOLVED",
1030
+ severity: "error",
1031
+ file: params.modelsJsonPath,
1032
+ jsonPath: headerPath,
1033
+ message: "models.json contains an unresolved SecretRef object for provider headers; regenerate models.json.",
1034
+ provider: providerId
1035
+ });
1036
+ continue;
1037
+ }
1038
+ if (!isNonEmptyString(headerValue)) continue;
1039
+ if (isSecretRefHeaderValueMarker(headerValue)) continue;
1040
+ if (!isLikelySensitiveModelProviderHeaderName(headerKey)) continue;
1041
+ addFinding(params.collector, {
1042
+ code: "PLAINTEXT_FOUND",
1043
+ severity: "warn",
1044
+ file: params.modelsJsonPath,
1045
+ jsonPath: headerPath,
1046
+ message: "models.json provider header value is stored as plaintext.",
1047
+ provider: providerId
1048
+ });
1049
+ }
1050
+ }
1051
+ }
1052
+ async function collectUnresolvedRefFindings(params) {
1053
+ const cache = {};
1054
+ const refsByProvider = /* @__PURE__ */ new Map();
1055
+ const skippedRefKeys = /* @__PURE__ */ new Set();
1056
+ let refsChecked = 0;
1057
+ let skippedExecRefs = 0;
1058
+ for (const assignment of params.collector.refAssignments) {
1059
+ const providerKey = `${assignment.ref.source}:${assignment.ref.provider}`;
1060
+ let refsForProvider = refsByProvider.get(providerKey);
1061
+ if (!refsForProvider) {
1062
+ refsForProvider = /* @__PURE__ */ new Map();
1063
+ refsByProvider.set(providerKey, refsForProvider);
1064
+ }
1065
+ refsForProvider.set(secretRefKey(assignment.ref), assignment.ref);
1066
+ }
1067
+ const resolvedByRefKey = /* @__PURE__ */ new Map();
1068
+ const errorsByRefKey = /* @__PURE__ */ new Map();
1069
+ for (const refsForProvider of refsByProvider.values()) {
1070
+ const refs = [...refsForProvider.values()];
1071
+ const selectedRefs = selectRefsForExecPolicy({
1072
+ refs,
1073
+ allowExec: params.allowExec
1074
+ });
1075
+ if (selectedRefs.skippedExecRefs.length > 0) {
1076
+ skippedExecRefs += selectedRefs.skippedExecRefs.length;
1077
+ for (const ref of selectedRefs.skippedExecRefs) {
1078
+ skippedRefKeys.add(secretRefKey(ref));
1079
+ const staticError = getSkippedExecRefStaticError({
1080
+ ref,
1081
+ config: params.config
1082
+ });
1083
+ if (staticError) errorsByRefKey.set(secretRefKey(ref), new Error(staticError));
1084
+ }
1085
+ }
1086
+ if (selectedRefs.refsToResolve.length === 0) continue;
1087
+ refsChecked += selectedRefs.refsToResolve.length;
1088
+ const provider = refs[0]?.provider;
1089
+ try {
1090
+ const resolved = await resolveSecretRefValues(selectedRefs.refsToResolve, {
1091
+ config: params.config,
1092
+ env: params.env,
1093
+ cache
1094
+ });
1095
+ for (const [key, value] of resolved.entries()) resolvedByRefKey.set(key, value);
1096
+ continue;
1097
+ } catch (err) {
1098
+ if (provider && isProviderScopedSecretResolutionError(err)) {
1099
+ for (const ref of selectedRefs.refsToResolve) errorsByRefKey.set(secretRefKey(ref), err);
1100
+ continue;
1101
+ }
1102
+ }
1103
+ const fallback = await runTasksWithConcurrency({
1104
+ tasks: selectedRefs.refsToResolve.map((ref) => async () => ({
1105
+ key: secretRefKey(ref),
1106
+ resolved: await resolveSecretRefValue(ref, {
1107
+ config: params.config,
1108
+ env: params.env,
1109
+ cache
1110
+ })
1111
+ })),
1112
+ limit: Math.min(REF_RESOLVE_FALLBACK_CONCURRENCY, selectedRefs.refsToResolve.length),
1113
+ errorMode: "continue",
1114
+ onTaskError: (error, index) => {
1115
+ const ref = selectedRefs.refsToResolve[index];
1116
+ if (!ref) return;
1117
+ errorsByRefKey.set(secretRefKey(ref), error);
1118
+ }
1119
+ });
1120
+ for (const result of fallback.results) {
1121
+ if (!result) continue;
1122
+ resolvedByRefKey.set(result.key, result.resolved);
1123
+ }
1124
+ }
1125
+ for (const assignment of params.collector.refAssignments) {
1126
+ const key = secretRefKey(assignment.ref);
1127
+ if (skippedRefKeys.has(key) && !errorsByRefKey.has(key)) continue;
1128
+ const resolveErr = errorsByRefKey.get(key);
1129
+ if (resolveErr) {
1130
+ addFinding(params.collector, {
1131
+ code: "REF_UNRESOLVED",
1132
+ severity: "error",
1133
+ file: assignment.file,
1134
+ jsonPath: assignment.path,
1135
+ message: `Failed to resolve ${assignment.ref.source}:${assignment.ref.provider}:${assignment.ref.id} (${describeUnknownError(resolveErr)}).`,
1136
+ provider: assignment.provider
1137
+ });
1138
+ continue;
1139
+ }
1140
+ if (!resolvedByRefKey.has(key)) {
1141
+ addFinding(params.collector, {
1142
+ code: "REF_UNRESOLVED",
1143
+ severity: "error",
1144
+ file: assignment.file,
1145
+ jsonPath: assignment.path,
1146
+ message: `Failed to resolve ${assignment.ref.source}:${assignment.ref.provider}:${assignment.ref.id} (resolved value is missing).`,
1147
+ provider: assignment.provider
1148
+ });
1149
+ continue;
1150
+ }
1151
+ if (!isExpectedResolvedSecretValue(resolvedByRefKey.get(key), assignment.expected)) addFinding(params.collector, {
1152
+ code: "REF_UNRESOLVED",
1153
+ severity: "error",
1154
+ file: assignment.file,
1155
+ jsonPath: assignment.path,
1156
+ message: assignment.expected === "string" ? `Failed to resolve ${assignment.ref.source}:${assignment.ref.provider}:${assignment.ref.id} (resolved value is not a non-empty string).` : `Failed to resolve ${assignment.ref.source}:${assignment.ref.provider}:${assignment.ref.id} (resolved value is not a string/object).`,
1157
+ provider: assignment.provider
1158
+ });
1159
+ }
1160
+ return {
1161
+ refsChecked,
1162
+ skippedExecRefs
1163
+ };
1164
+ }
1165
+ function collectShadowingFindings(collector) {
1166
+ for (const [provider, paths] of collector.configProviderRefPaths.entries()) {
1167
+ const authState = collector.authProviderState.get(provider);
1168
+ if (!authState?.hasUsableStaticOrOAuth) continue;
1169
+ const modeText = [...authState.modes].join("/");
1170
+ for (const configPath of paths) addFinding(collector, {
1171
+ code: "REF_SHADOWED",
1172
+ severity: "warn",
1173
+ file: "vora.json",
1174
+ jsonPath: configPath,
1175
+ message: `Auth profile credentials (${modeText}) take precedence for provider "${provider}", so this config ref may never be used.`,
1176
+ provider
1177
+ });
1178
+ }
1179
+ }
1180
+ function summarizeFindings(findings) {
1181
+ return {
1182
+ plaintextCount: findings.filter((entry) => entry.code === "PLAINTEXT_FOUND").length,
1183
+ unresolvedRefCount: findings.filter((entry) => entry.code === "REF_UNRESOLVED").length,
1184
+ shadowedRefCount: findings.filter((entry) => entry.code === "REF_SHADOWED").length,
1185
+ legacyResidueCount: findings.filter((entry) => entry.code === "LEGACY_RESIDUE").length
1186
+ };
1187
+ }
1188
+ async function runSecretsAudit(params = {}) {
1189
+ const env = params.env ?? process.env;
1190
+ const allowExec = Boolean(params.allowExec);
1191
+ const snapshot = await createSecretsConfigIO({ env }).readConfigFileSnapshot();
1192
+ const configPath = resolveUserPath(snapshot.path);
1193
+ const defaults = snapshot.valid ? snapshot.config.secrets?.defaults : void 0;
1194
+ const collector = {
1195
+ findings: [],
1196
+ refAssignments: [],
1197
+ configProviderRefPaths: /* @__PURE__ */ new Map(),
1198
+ authProviderState: /* @__PURE__ */ new Map(),
1199
+ filesScanned: new Set([configPath])
1200
+ };
1201
+ const stateDir = resolveStateDir(env, os.homedir);
1202
+ const envPath = path.join(resolveConfigDir(env, os.homedir), ".env");
1203
+ const config = snapshot.valid ? snapshot.config : {};
1204
+ let resolution = {
1205
+ refsChecked: 0,
1206
+ skippedExecRefs: 0,
1207
+ resolvabilityComplete: true
1208
+ };
1209
+ if (snapshot.valid) {
1210
+ collectConfigSecrets({
1211
+ config,
1212
+ configPath,
1213
+ collector
1214
+ });
1215
+ for (const authStorePath of listAuthProfileStorePaths(config, stateDir)) collectAuthStoreSecrets({
1216
+ authStorePath,
1217
+ collector,
1218
+ defaults
1219
+ });
1220
+ for (const modelsJsonPath of listAgentModelsJsonPaths(config, stateDir, env)) collectModelsJsonSecrets({
1221
+ modelsJsonPath,
1222
+ collector
1223
+ });
1224
+ const unresolvedRefResult = await collectUnresolvedRefFindings({
1225
+ collector,
1226
+ config,
1227
+ env,
1228
+ allowExec
1229
+ });
1230
+ resolution = {
1231
+ refsChecked: unresolvedRefResult.refsChecked,
1232
+ skippedExecRefs: unresolvedRefResult.skippedExecRefs,
1233
+ resolvabilityComplete: unresolvedRefResult.skippedExecRefs === 0
1234
+ };
1235
+ collectShadowingFindings(collector);
1236
+ } else addFinding(collector, {
1237
+ code: "REF_UNRESOLVED",
1238
+ severity: "error",
1239
+ file: configPath,
1240
+ jsonPath: "<root>",
1241
+ message: "Config is invalid; cannot validate secret references reliably."
1242
+ });
1243
+ collectEnvPlaintext({
1244
+ envPath,
1245
+ collector
1246
+ });
1247
+ collectAuthJsonResidue({
1248
+ stateDir,
1249
+ collector
1250
+ });
1251
+ const summary = summarizeFindings(collector.findings);
1252
+ return {
1253
+ version: 1,
1254
+ status: summary.unresolvedRefCount > 0 ? "unresolved" : collector.findings.length > 0 ? "findings" : "clean",
1255
+ resolution,
1256
+ filesScanned: [...collector.filesScanned].toSorted(),
1257
+ summary,
1258
+ findings: collector.findings
1259
+ };
1260
+ }
1261
+ function resolveSecretsAuditExitCode(report, check) {
1262
+ if (report.summary.unresolvedRefCount > 0) return 2;
1263
+ if (check && report.findings.length > 0) return 1;
1264
+ return 0;
1265
+ }
1266
+ //#endregion
1267
+ //#region src/secrets/configure-plan.ts
1268
+ function getSecretProviders$1(config) {
1269
+ if (!isRecord(config.secrets?.providers)) return {};
1270
+ return config.secrets.providers;
1271
+ }
1272
+ function configureCandidateSortKey(candidate) {
1273
+ if (candidate.configFile === "auth-profiles.json") return `auth-profiles:${candidate.agentId ?? ""}:${candidate.path}`;
1274
+ return `vora:${candidate.path}`;
1275
+ }
1276
+ function resolveAuthProfileProvider(store, pathSegments) {
1277
+ const profileId = pathSegments[1];
1278
+ if (!profileId) return;
1279
+ const profile = store.profiles?.[profileId];
1280
+ if (!isRecord(profile) || typeof profile.provider !== "string") return;
1281
+ const provider = profile.provider.trim();
1282
+ return provider.length > 0 ? provider : void 0;
1283
+ }
1284
+ function buildConfigureCandidatesForScope(params) {
1285
+ const authoredConfig = params.authoredVoraConfig ?? params.config;
1286
+ const hasPathInAuthoredConfig = (pathSegments) => hasPath(authoredConfig, pathSegments);
1287
+ const voraCandidates = discoverConfigSecretTargets(params.config).filter((entry) => entry.entry.includeInConfigure).map((entry) => {
1288
+ const resolved = resolveSecretInputRef({
1289
+ value: entry.value,
1290
+ refValue: entry.refValue,
1291
+ defaults: params.config.secrets?.defaults
1292
+ });
1293
+ const pathExists = hasPathInAuthoredConfig(entry.pathSegments);
1294
+ const refPathExists = entry.refPathSegments ? hasPathInAuthoredConfig(entry.refPathSegments) : false;
1295
+ return {
1296
+ type: entry.entry.targetType,
1297
+ path: entry.path,
1298
+ pathSegments: [...entry.pathSegments],
1299
+ label: entry.path,
1300
+ configFile: "vora.json",
1301
+ expectedResolvedValue: entry.entry.expectedResolvedValue,
1302
+ ...resolved.ref ? { existingRef: resolved.ref } : {},
1303
+ ...pathExists || refPathExists ? {} : { isDerived: true },
1304
+ ...entry.providerId ? { providerId: entry.providerId } : {},
1305
+ ...entry.accountId ? { accountId: entry.accountId } : {}
1306
+ };
1307
+ });
1308
+ const authCandidates = params.authProfiles === void 0 ? [] : discoverAuthProfileSecretTargets(params.authProfiles.store).filter((entry) => entry.entry.includeInConfigure).map((entry) => {
1309
+ const authProfiles = params.authProfiles;
1310
+ if (!authProfiles) throw new Error("Missing auth profile scope for configure candidate discovery.");
1311
+ const authProfileProvider = resolveAuthProfileProvider(authProfiles.store, entry.pathSegments);
1312
+ const resolved = resolveSecretInputRef({
1313
+ value: entry.value,
1314
+ refValue: entry.refValue,
1315
+ defaults: params.config.secrets?.defaults
1316
+ });
1317
+ return {
1318
+ type: entry.entry.targetType,
1319
+ path: entry.path,
1320
+ pathSegments: [...entry.pathSegments],
1321
+ label: `${entry.path} (auth profile, agent ${authProfiles.agentId})`,
1322
+ configFile: "auth-profiles.json",
1323
+ expectedResolvedValue: entry.entry.expectedResolvedValue,
1324
+ ...resolved.ref ? { existingRef: resolved.ref } : {},
1325
+ agentId: authProfiles.agentId,
1326
+ ...authProfileProvider ? { authProfileProvider } : {}
1327
+ };
1328
+ });
1329
+ return [...voraCandidates, ...authCandidates].toSorted((a, b) => configureCandidateSortKey(a).localeCompare(configureCandidateSortKey(b)));
1330
+ }
1331
+ function hasPath(root, segments) {
1332
+ if (segments.length === 0) return false;
1333
+ let cursor = root;
1334
+ for (let index = 0; index < segments.length; index += 1) {
1335
+ const segment = segments[index] ?? "";
1336
+ if (Array.isArray(cursor)) {
1337
+ if (!/^\d+$/.test(segment)) return false;
1338
+ const parsedIndex = Number.parseInt(segment, 10);
1339
+ if (!Number.isFinite(parsedIndex) || parsedIndex < 0 || parsedIndex >= cursor.length) return false;
1340
+ if (index === segments.length - 1) return true;
1341
+ cursor = cursor[parsedIndex];
1342
+ continue;
1343
+ }
1344
+ if (!isRecord(cursor)) return false;
1345
+ if (!Object.prototype.hasOwnProperty.call(cursor, segment)) return false;
1346
+ if (index === segments.length - 1) return true;
1347
+ cursor = cursor[segment];
1348
+ }
1349
+ return false;
1350
+ }
1351
+ function collectConfigureProviderChanges(params) {
1352
+ const originalProviders = getSecretProviders$1(params.original);
1353
+ const nextProviders = getSecretProviders$1(params.next);
1354
+ const upserts = {};
1355
+ const deletes = [];
1356
+ for (const [providerAlias, nextProviderConfig] of Object.entries(nextProviders)) {
1357
+ const current = originalProviders[providerAlias];
1358
+ if (isDeepStrictEqual(current, nextProviderConfig)) continue;
1359
+ upserts[providerAlias] = structuredClone(nextProviderConfig);
1360
+ }
1361
+ for (const providerAlias of Object.keys(originalProviders)) if (!Object.prototype.hasOwnProperty.call(nextProviders, providerAlias)) deletes.push(providerAlias);
1362
+ return {
1363
+ upserts,
1364
+ deletes: deletes.toSorted()
1365
+ };
1366
+ }
1367
+ function hasConfigurePlanChanges(params) {
1368
+ return params.selectedTargets.size > 0 || Object.keys(params.providerChanges.upserts).length > 0 || params.providerChanges.deletes.length > 0;
1369
+ }
1370
+ function buildSecretsConfigurePlan(params) {
1371
+ return {
1372
+ version: 1,
1373
+ protocolVersion: 1,
1374
+ generatedAt: params.generatedAt ?? (/* @__PURE__ */ new Date()).toISOString(),
1375
+ generatedBy: "vora secrets configure",
1376
+ targets: [...params.selectedTargets.values()].map((entry) => ({
1377
+ type: entry.type,
1378
+ path: entry.path,
1379
+ pathSegments: [...entry.pathSegments],
1380
+ ref: entry.ref,
1381
+ ...entry.agentId ? { agentId: entry.agentId } : {},
1382
+ ...entry.providerId ? { providerId: entry.providerId } : {},
1383
+ ...entry.accountId ? { accountId: entry.accountId } : {},
1384
+ ...entry.authProfileProvider ? { authProfileProvider: entry.authProfileProvider } : {}
1385
+ })),
1386
+ ...Object.keys(params.providerChanges.upserts).length > 0 ? { providerUpserts: params.providerChanges.upserts } : {},
1387
+ ...params.providerChanges.deletes.length > 0 ? { providerDeletes: params.providerChanges.deletes } : {},
1388
+ options: {
1389
+ scrubEnv: true,
1390
+ scrubAuthProfilesForProviderTargets: true,
1391
+ scrubLegacyAuthJson: true
1392
+ }
1393
+ };
1394
+ }
1395
+ //#endregion
1396
+ //#region src/secrets/configure.ts
1397
+ const ENV_NAME_PATTERN = /^[A-Z][A-Z0-9_]{0,127}$/;
1398
+ const WINDOWS_ABS_PATH_PATTERN = /^[A-Za-z]:[\\/]/;
1399
+ const WINDOWS_UNC_PATH_PATTERN = /^\\\\[^\\]+\\[^\\]+/;
1400
+ function isAbsolutePathValue(value) {
1401
+ return path.isAbsolute(value) || WINDOWS_ABS_PATH_PATTERN.test(value) || WINDOWS_UNC_PATH_PATTERN.test(value);
1402
+ }
1403
+ function parseCsv(value) {
1404
+ return value.split(",").map((entry) => entry.trim()).filter((entry) => entry.length > 0);
1405
+ }
1406
+ function parseOptionalPositiveInt(value, max) {
1407
+ const trimmed = value.trim();
1408
+ if (!trimmed) return;
1409
+ if (!/^\d+$/.test(trimmed)) return;
1410
+ const parsed = Number.parseInt(trimmed, 10);
1411
+ if (!Number.isFinite(parsed) || parsed <= 0 || parsed > max) return;
1412
+ return parsed;
1413
+ }
1414
+ function getSecretProviders(config) {
1415
+ if (!isRecord(config.secrets?.providers)) return {};
1416
+ return config.secrets.providers;
1417
+ }
1418
+ function setSecretProvider(config, providerAlias, providerConfig) {
1419
+ config.secrets ??= {};
1420
+ if (!isRecord(config.secrets.providers)) config.secrets.providers = {};
1421
+ config.secrets.providers[providerAlias] = providerConfig;
1422
+ }
1423
+ function removeSecretProvider(config, providerAlias) {
1424
+ if (!isRecord(config.secrets?.providers)) return false;
1425
+ const providers = config.secrets.providers;
1426
+ if (!Object.prototype.hasOwnProperty.call(providers, providerAlias)) return false;
1427
+ delete providers[providerAlias];
1428
+ if (Object.keys(providers).length === 0) delete config.secrets?.providers;
1429
+ if (isRecord(config.secrets?.defaults)) {
1430
+ const defaults = config.secrets.defaults;
1431
+ if (defaults?.env === providerAlias) delete defaults.env;
1432
+ if (defaults?.file === providerAlias) delete defaults.file;
1433
+ if (defaults?.exec === providerAlias) delete defaults.exec;
1434
+ if (defaults && defaults.env === void 0 && defaults.file === void 0 && defaults.exec === void 0) delete config.secrets?.defaults;
1435
+ }
1436
+ return true;
1437
+ }
1438
+ function providerHint(provider) {
1439
+ if (provider.source === "env") return provider.allowlist?.length ? `env (${provider.allowlist.length} allowlisted)` : "env";
1440
+ if (provider.source === "file") return `file (${provider.mode ?? "json"})`;
1441
+ return `exec (${provider.jsonOnly === false ? "json+text" : "json"})`;
1442
+ }
1443
+ function toSourceChoices(config) {
1444
+ const hasSource = (source) => Object.values(config.secrets?.providers ?? {}).some((provider) => provider?.source === source);
1445
+ const choices = [{
1446
+ value: "env",
1447
+ label: "env"
1448
+ }];
1449
+ if (hasSource("file")) choices.push({
1450
+ value: "file",
1451
+ label: "file"
1452
+ });
1453
+ if (hasSource("exec")) choices.push({
1454
+ value: "exec",
1455
+ label: "exec"
1456
+ });
1457
+ return choices;
1458
+ }
1459
+ function assertNoCancel(value, message) {
1460
+ if (typeof value === "symbol") throw new Error(message);
1461
+ return value;
1462
+ }
1463
+ const AUTH_PROFILE_ID_PATTERN = /^[A-Za-z0-9:_-]{1,128}$/;
1464
+ function validateEnvNameCsv(value) {
1465
+ const entries = parseCsv(value);
1466
+ for (const entry of entries) if (!ENV_NAME_PATTERN.test(entry)) return `Invalid env name: ${entry}`;
1467
+ }
1468
+ async function promptEnvNameCsv(params) {
1469
+ const raw = assertNoCancel(await text({
1470
+ message: params.message,
1471
+ initialValue: params.initialValue,
1472
+ validate: (value) => validateEnvNameCsv(String(value ?? ""))
1473
+ }), "Secrets configure cancelled.");
1474
+ return parseCsv(String(raw ?? ""));
1475
+ }
1476
+ async function promptOptionalPositiveInt(params) {
1477
+ const raw = assertNoCancel(await text({
1478
+ message: params.message,
1479
+ initialValue: params.initialValue === void 0 ? "" : String(params.initialValue),
1480
+ validate: (value) => {
1481
+ const trimmed = String(value ?? "").trim();
1482
+ if (!trimmed) return;
1483
+ if (parseOptionalPositiveInt(trimmed, params.max) === void 0) return `Must be an integer between 1 and ${params.max}`;
1484
+ }
1485
+ }), "Secrets configure cancelled.");
1486
+ return parseOptionalPositiveInt(String(raw ?? ""), params.max);
1487
+ }
1488
+ function configureCandidateKey(candidate) {
1489
+ if (candidate.configFile === "auth-profiles.json") return `auth-profiles:${String(candidate.agentId ?? "").trim()}:${candidate.path}`;
1490
+ return `vora:${candidate.path}`;
1491
+ }
1492
+ function hasSourceChoice(sourceChoices, source) {
1493
+ return sourceChoices.some((entry) => entry.value === source);
1494
+ }
1495
+ function resolveCandidateProviderHint(candidate) {
1496
+ if (typeof candidate.authProfileProvider === "string" && candidate.authProfileProvider.trim()) return candidate.authProfileProvider.trim().toLowerCase();
1497
+ if (typeof candidate.providerId === "string" && candidate.providerId.trim()) return candidate.providerId.trim().toLowerCase();
1498
+ }
1499
+ function resolveSuggestedEnvSecretId(candidate) {
1500
+ const hintedProvider = resolveCandidateProviderHint(candidate);
1501
+ if (!hintedProvider) return;
1502
+ const envCandidates = getProviderEnvVars(hintedProvider);
1503
+ if (!Array.isArray(envCandidates) || envCandidates.length === 0) return;
1504
+ return envCandidates[0];
1505
+ }
1506
+ function resolveConfigureAgentId(config, explicitAgentId) {
1507
+ const knownAgentIds = new Set(listAgentIds(config));
1508
+ if (!explicitAgentId) return resolveDefaultAgentId(config);
1509
+ const normalized = normalizeAgentId(explicitAgentId);
1510
+ if (knownAgentIds.has(normalized)) return normalized;
1511
+ const known = [...knownAgentIds].toSorted().join(", ");
1512
+ throw new Error(`Unknown agent id "${explicitAgentId}". Known agents: ${known || "none configured"}.`);
1513
+ }
1514
+ function normalizeAuthStoreForConfigure(raw, storePath) {
1515
+ if (!raw) return {
1516
+ version: 1,
1517
+ profiles: {}
1518
+ };
1519
+ if (!isRecord(raw.profiles)) throw new Error(`Cannot run interactive secrets configure because ${storePath} is invalid (missing "profiles" object).`);
1520
+ return {
1521
+ version: typeof raw.version === "number" && Number.isFinite(raw.version) ? raw.version : 1,
1522
+ profiles: raw.profiles,
1523
+ ...isRecord(raw.order) ? { order: raw.order } : {},
1524
+ ...isRecord(raw.lastGood) ? { lastGood: raw.lastGood } : {},
1525
+ ...isRecord(raw.usageStats) ? { usageStats: raw.usageStats } : {}
1526
+ };
1527
+ }
1528
+ function loadAuthProfileStoreForConfigure(params) {
1529
+ const storePath = resolveAuthStorePath(resolveAgentDir(params.config, params.agentId));
1530
+ const parsed = readJsonObjectIfExists(storePath);
1531
+ if (parsed.error) throw new Error(`Cannot run interactive secrets configure because ${storePath} could not be read: ${parsed.error}`);
1532
+ return normalizeAuthStoreForConfigure(parsed.value, storePath);
1533
+ }
1534
+ async function promptNewAuthProfileCandidate(agentId) {
1535
+ const profileId = assertNoCancel(await text({
1536
+ message: "Auth profile id",
1537
+ validate: (value) => {
1538
+ const trimmed = String(value ?? "").trim();
1539
+ if (!trimmed) return "Required";
1540
+ if (!AUTH_PROFILE_ID_PATTERN.test(trimmed)) return "Use letters/numbers/\":\"/\"_\"/\"-\" only.";
1541
+ }
1542
+ }), "Secrets configure cancelled.");
1543
+ const credentialType = assertNoCancel(await select({
1544
+ message: "Auth profile credential type",
1545
+ options: [{
1546
+ value: "api_key",
1547
+ label: "api_key (key/keyRef)"
1548
+ }, {
1549
+ value: "token",
1550
+ label: "token (token/tokenRef)"
1551
+ }]
1552
+ }), "Secrets configure cancelled.");
1553
+ const provider = assertNoCancel(await text({
1554
+ message: "Provider id",
1555
+ validate: (value) => String(value ?? "").trim().length > 0 ? void 0 : "Required"
1556
+ }), "Secrets configure cancelled.");
1557
+ const profileIdTrimmed = String(profileId).trim();
1558
+ const providerTrimmed = String(provider).trim();
1559
+ if (credentialType === "token") return {
1560
+ type: "auth-profiles.token.token",
1561
+ path: `profiles.${profileIdTrimmed}.token`,
1562
+ pathSegments: [
1563
+ "profiles",
1564
+ profileIdTrimmed,
1565
+ "token"
1566
+ ],
1567
+ label: `profiles.${profileIdTrimmed}.token (auth profile, agent ${agentId})`,
1568
+ configFile: "auth-profiles.json",
1569
+ agentId,
1570
+ authProfileProvider: providerTrimmed,
1571
+ expectedResolvedValue: "string"
1572
+ };
1573
+ return {
1574
+ type: "auth-profiles.api_key.key",
1575
+ path: `profiles.${profileIdTrimmed}.key`,
1576
+ pathSegments: [
1577
+ "profiles",
1578
+ profileIdTrimmed,
1579
+ "key"
1580
+ ],
1581
+ label: `profiles.${profileIdTrimmed}.key (auth profile, agent ${agentId})`,
1582
+ configFile: "auth-profiles.json",
1583
+ agentId,
1584
+ authProfileProvider: providerTrimmed,
1585
+ expectedResolvedValue: "string"
1586
+ };
1587
+ }
1588
+ async function promptProviderAlias(params) {
1589
+ const alias = assertNoCancel(await text({
1590
+ message: "Provider alias",
1591
+ initialValue: "default",
1592
+ validate: (value) => {
1593
+ const trimmed = String(value ?? "").trim();
1594
+ if (!trimmed) return "Required";
1595
+ if (!isValidSecretProviderAlias(trimmed)) return "Must match /^[a-z][a-z0-9_-]{0,63}$/";
1596
+ if (params.existingAliases.has(trimmed)) return "Alias already exists";
1597
+ }
1598
+ }), "Secrets configure cancelled.");
1599
+ return String(alias).trim();
1600
+ }
1601
+ async function promptProviderSource(initial) {
1602
+ return assertNoCancel(await select({
1603
+ message: "Provider source",
1604
+ options: [
1605
+ {
1606
+ value: "env",
1607
+ label: "env"
1608
+ },
1609
+ {
1610
+ value: "file",
1611
+ label: "file"
1612
+ },
1613
+ {
1614
+ value: "exec",
1615
+ label: "exec"
1616
+ }
1617
+ ],
1618
+ initialValue: initial
1619
+ }), "Secrets configure cancelled.");
1620
+ }
1621
+ async function promptEnvProvider(base) {
1622
+ const allowlist = await promptEnvNameCsv({
1623
+ message: "Env allowlist (comma-separated, blank for unrestricted)",
1624
+ initialValue: base?.allowlist?.join(",") ?? ""
1625
+ });
1626
+ return {
1627
+ source: "env",
1628
+ ...allowlist.length > 0 ? { allowlist } : {}
1629
+ };
1630
+ }
1631
+ async function promptFileProvider(base) {
1632
+ const filePath = assertNoCancel(await text({
1633
+ message: "File path (absolute)",
1634
+ initialValue: base?.path ?? "",
1635
+ validate: (value) => {
1636
+ const trimmed = String(value ?? "").trim();
1637
+ if (!trimmed) return "Required";
1638
+ if (!isAbsolutePathValue(trimmed)) return "Must be an absolute path";
1639
+ }
1640
+ }), "Secrets configure cancelled.");
1641
+ const mode = assertNoCancel(await select({
1642
+ message: "File mode",
1643
+ options: [{
1644
+ value: "json",
1645
+ label: "json"
1646
+ }, {
1647
+ value: "singleValue",
1648
+ label: "singleValue"
1649
+ }],
1650
+ initialValue: base?.mode ?? "json"
1651
+ }), "Secrets configure cancelled.");
1652
+ const timeoutMs = await promptOptionalPositiveInt({
1653
+ message: "Timeout ms (blank for default)",
1654
+ initialValue: base?.timeoutMs,
1655
+ max: 12e4
1656
+ });
1657
+ const maxBytes = await promptOptionalPositiveInt({
1658
+ message: "Max bytes (blank for default)",
1659
+ initialValue: base?.maxBytes,
1660
+ max: 20 * 1024 * 1024
1661
+ });
1662
+ return {
1663
+ source: "file",
1664
+ path: String(filePath).trim(),
1665
+ mode,
1666
+ ...timeoutMs ? { timeoutMs } : {},
1667
+ ...maxBytes ? { maxBytes } : {}
1668
+ };
1669
+ }
1670
+ async function parseArgsInput(rawValue) {
1671
+ const trimmed = rawValue.trim();
1672
+ if (!trimmed) return;
1673
+ const parsed = JSON.parse(trimmed);
1674
+ if (!Array.isArray(parsed) || !parsed.every((entry) => typeof entry === "string")) throw new Error("args must be a JSON array of strings");
1675
+ return parsed;
1676
+ }
1677
+ async function promptExecProvider(base) {
1678
+ const command = assertNoCancel(await text({
1679
+ message: "Command path (absolute)",
1680
+ initialValue: base?.command ?? "",
1681
+ validate: (value) => {
1682
+ const trimmed = String(value ?? "").trim();
1683
+ if (!trimmed) return "Required";
1684
+ if (!isAbsolutePathValue(trimmed)) return "Must be an absolute path";
1685
+ if (!isSafeExecutableValue(trimmed)) return "Command value is not allowed";
1686
+ }
1687
+ }), "Secrets configure cancelled.");
1688
+ const argsRaw = assertNoCancel(await text({
1689
+ message: "Args JSON array (blank for none)",
1690
+ initialValue: JSON.stringify(base?.args ?? []),
1691
+ validate: (value) => {
1692
+ const trimmed = String(value ?? "").trim();
1693
+ if (!trimmed) return;
1694
+ try {
1695
+ const parsed = JSON.parse(trimmed);
1696
+ if (!Array.isArray(parsed) || !parsed.every((entry) => typeof entry === "string")) return "Must be a JSON array of strings";
1697
+ return;
1698
+ } catch {
1699
+ return "Must be valid JSON";
1700
+ }
1701
+ }
1702
+ }), "Secrets configure cancelled.");
1703
+ const timeoutMs = await promptOptionalPositiveInt({
1704
+ message: "Timeout ms (blank for default)",
1705
+ initialValue: base?.timeoutMs,
1706
+ max: 12e4
1707
+ });
1708
+ const noOutputTimeoutMs = await promptOptionalPositiveInt({
1709
+ message: "No-output timeout ms (blank for default)",
1710
+ initialValue: base?.noOutputTimeoutMs,
1711
+ max: 12e4
1712
+ });
1713
+ const maxOutputBytes = await promptOptionalPositiveInt({
1714
+ message: "Max output bytes (blank for default)",
1715
+ initialValue: base?.maxOutputBytes,
1716
+ max: 20 * 1024 * 1024
1717
+ });
1718
+ const jsonOnly = assertNoCancel(await confirm({
1719
+ message: "Require JSON-only response?",
1720
+ initialValue: base?.jsonOnly ?? true
1721
+ }), "Secrets configure cancelled.");
1722
+ const passEnv = await promptEnvNameCsv({
1723
+ message: "Pass-through env vars (comma-separated, blank for none)",
1724
+ initialValue: base?.passEnv?.join(",") ?? ""
1725
+ });
1726
+ const trustedDirsRaw = assertNoCancel(await text({
1727
+ message: "Trusted dirs (comma-separated absolute paths, blank for none)",
1728
+ initialValue: base?.trustedDirs?.join(",") ?? "",
1729
+ validate: (value) => {
1730
+ const entries = parseCsv(String(value ?? ""));
1731
+ for (const entry of entries) if (!isAbsolutePathValue(entry)) return `Trusted dir must be absolute: ${entry}`;
1732
+ }
1733
+ }), "Secrets configure cancelled.");
1734
+ const allowInsecurePath = assertNoCancel(await confirm({
1735
+ message: "Allow insecure command path checks?",
1736
+ initialValue: base?.allowInsecurePath ?? false
1737
+ }), "Secrets configure cancelled.");
1738
+ const allowSymlinkCommand = assertNoCancel(await confirm({
1739
+ message: "Allow symlink command path?",
1740
+ initialValue: base?.allowSymlinkCommand ?? false
1741
+ }), "Secrets configure cancelled.");
1742
+ const args = await parseArgsInput(String(argsRaw ?? ""));
1743
+ const trustedDirs = parseCsv(String(trustedDirsRaw ?? ""));
1744
+ return {
1745
+ source: "exec",
1746
+ command: String(command).trim(),
1747
+ ...args && args.length > 0 ? { args } : {},
1748
+ ...timeoutMs ? { timeoutMs } : {},
1749
+ ...noOutputTimeoutMs ? { noOutputTimeoutMs } : {},
1750
+ ...maxOutputBytes ? { maxOutputBytes } : {},
1751
+ ...jsonOnly ? { jsonOnly } : { jsonOnly: false },
1752
+ ...passEnv.length > 0 ? { passEnv } : {},
1753
+ ...trustedDirs.length > 0 ? { trustedDirs } : {},
1754
+ ...allowInsecurePath ? { allowInsecurePath: true } : {},
1755
+ ...allowSymlinkCommand ? { allowSymlinkCommand: true } : {},
1756
+ ...isRecord(base?.env) ? { env: base.env } : {}
1757
+ };
1758
+ }
1759
+ async function promptProviderConfig(source, current) {
1760
+ if (source === "env") return await promptEnvProvider(current?.source === "env" ? current : void 0);
1761
+ if (source === "file") return await promptFileProvider(current?.source === "file" ? current : void 0);
1762
+ return await promptExecProvider(current?.source === "exec" ? current : void 0);
1763
+ }
1764
+ async function configureProvidersInteractive(config) {
1765
+ while (true) {
1766
+ const providers = getSecretProviders(config);
1767
+ const providerEntries = Object.entries(providers).toSorted(([left], [right]) => left.localeCompare(right));
1768
+ const actionOptions = [{
1769
+ value: "add",
1770
+ label: "Add provider",
1771
+ hint: "Define a new env/file/exec provider"
1772
+ }];
1773
+ if (providerEntries.length > 0) {
1774
+ actionOptions.push({
1775
+ value: "edit",
1776
+ label: "Edit provider",
1777
+ hint: "Update an existing provider"
1778
+ });
1779
+ actionOptions.push({
1780
+ value: "remove",
1781
+ label: "Remove provider",
1782
+ hint: "Delete a provider alias"
1783
+ });
1784
+ }
1785
+ actionOptions.push({
1786
+ value: "continue",
1787
+ label: "Continue",
1788
+ hint: "Move to credential mapping"
1789
+ });
1790
+ const action = assertNoCancel(await select({
1791
+ message: providerEntries.length > 0 ? "Configure secret providers" : "Configure secret providers (only env refs are available until file/exec providers are added)",
1792
+ options: actionOptions
1793
+ }), "Secrets configure cancelled.");
1794
+ if (action === "continue") return;
1795
+ if (action === "add") {
1796
+ const source = await promptProviderSource();
1797
+ setSecretProvider(config, await promptProviderAlias({ existingAliases: new Set(providerEntries.map(([providerAlias]) => providerAlias)) }), await promptProviderConfig(source));
1798
+ continue;
1799
+ }
1800
+ if (action === "edit") {
1801
+ const alias = assertNoCancel(await select({
1802
+ message: "Select provider to edit",
1803
+ options: providerEntries.map(([providerAlias, providerConfig]) => ({
1804
+ value: providerAlias,
1805
+ label: providerAlias,
1806
+ hint: providerHint(providerConfig)
1807
+ }))
1808
+ }), "Secrets configure cancelled.");
1809
+ const current = providers[alias];
1810
+ if (!current) continue;
1811
+ const nextProviderConfig = await promptProviderConfig(await promptProviderSource(current.source), current);
1812
+ if (!isDeepStrictEqual(current, nextProviderConfig)) setSecretProvider(config, alias, nextProviderConfig);
1813
+ continue;
1814
+ }
1815
+ if (action === "remove") {
1816
+ const alias = assertNoCancel(await select({
1817
+ message: "Select provider to remove",
1818
+ options: providerEntries.map(([providerAlias, providerConfig]) => ({
1819
+ value: providerAlias,
1820
+ label: providerAlias,
1821
+ hint: providerHint(providerConfig)
1822
+ }))
1823
+ }), "Secrets configure cancelled.");
1824
+ if (assertNoCancel(await confirm({
1825
+ message: `Remove provider "${alias}"?`,
1826
+ initialValue: false
1827
+ }), "Secrets configure cancelled.")) removeSecretProvider(config, alias);
1828
+ }
1829
+ }
1830
+ }
1831
+ async function runSecretsConfigureInteractive(params = {}) {
1832
+ if (!process.stdin.isTTY) throw new Error("secrets configure requires an interactive TTY.");
1833
+ if (params.providersOnly && params.skipProviderSetup) throw new Error("Cannot combine --providers-only with --skip-provider-setup.");
1834
+ const env = params.env ?? process.env;
1835
+ const allowExecInPreflight = Boolean(params.allowExecInPreflight);
1836
+ const { snapshot } = await createSecretsConfigIO({ env }).readConfigFileSnapshotForWrite();
1837
+ if (!snapshot.valid) throw new Error("Cannot run interactive secrets configure because config is invalid.");
1838
+ const stagedConfig = structuredClone(snapshot.config);
1839
+ if (!params.skipProviderSetup) await configureProvidersInteractive(stagedConfig);
1840
+ const providerChanges = collectConfigureProviderChanges({
1841
+ original: snapshot.config,
1842
+ next: stagedConfig
1843
+ });
1844
+ const selectedByPath = /* @__PURE__ */ new Map();
1845
+ if (!params.providersOnly) {
1846
+ const configureAgentId = resolveConfigureAgentId(snapshot.config, params.agentId);
1847
+ const authStore = loadAuthProfileStoreForConfigure({
1848
+ config: snapshot.config,
1849
+ agentId: configureAgentId
1850
+ });
1851
+ const candidates = buildConfigureCandidatesForScope({
1852
+ config: stagedConfig,
1853
+ authoredVoraConfig: snapshot.resolved,
1854
+ authProfiles: {
1855
+ agentId: configureAgentId,
1856
+ store: authStore
1857
+ }
1858
+ });
1859
+ if (candidates.length === 0) throw new Error("No configurable secret-bearing fields found for this agent scope.");
1860
+ const sourceChoices = toSourceChoices(stagedConfig);
1861
+ const hasDerivedCandidates = candidates.some((candidate) => candidate.isDerived === true);
1862
+ let showDerivedCandidates = false;
1863
+ while (true) {
1864
+ const visibleCandidates = showDerivedCandidates ? candidates : candidates.filter((candidate) => candidate.isDerived !== true);
1865
+ const options = visibleCandidates.map((candidate) => ({
1866
+ value: configureCandidateKey(candidate),
1867
+ label: candidate.label,
1868
+ hint: [candidate.configFile === "auth-profiles.json" ? "auth-profiles.json" : "vora.json", candidate.isDerived === true ? "derived" : void 0].filter(Boolean).join(" | ")
1869
+ }));
1870
+ options.push({
1871
+ value: "__create_auth_profile__",
1872
+ label: "Create auth profile mapping",
1873
+ hint: `Add a new auth-profiles target for agent ${configureAgentId}`
1874
+ });
1875
+ if (hasDerivedCandidates) options.push({
1876
+ value: "__toggle_derived__",
1877
+ label: showDerivedCandidates ? "Hide derived targets" : "Show derived targets",
1878
+ hint: showDerivedCandidates ? "Show only fields authored directly in config" : "Include normalized/derived aliases"
1879
+ });
1880
+ if (selectedByPath.size > 0) options.unshift({
1881
+ value: "__done__",
1882
+ label: "Done",
1883
+ hint: "Finish and run preflight"
1884
+ });
1885
+ const selectedPath = assertNoCancel(await select({
1886
+ message: "Select credential field",
1887
+ options
1888
+ }), "Secrets configure cancelled.");
1889
+ if (selectedPath === "__done__") break;
1890
+ if (selectedPath === "__create_auth_profile__") {
1891
+ const createdCandidate = await promptNewAuthProfileCandidate(configureAgentId);
1892
+ const key = configureCandidateKey(createdCandidate);
1893
+ const existingIndex = candidates.findIndex((entry) => configureCandidateKey(entry) === key);
1894
+ if (existingIndex >= 0) candidates[existingIndex] = createdCandidate;
1895
+ else candidates.push(createdCandidate);
1896
+ continue;
1897
+ }
1898
+ if (selectedPath === "__toggle_derived__") {
1899
+ showDerivedCandidates = !showDerivedCandidates;
1900
+ continue;
1901
+ }
1902
+ const candidate = visibleCandidates.find((entry) => configureCandidateKey(entry) === selectedPath);
1903
+ if (!candidate) throw new Error(`Unknown configure target: ${selectedPath}`);
1904
+ const candidateKey = configureCandidateKey(candidate);
1905
+ const existingRef = selectedByPath.get(candidateKey)?.ref ?? candidate.existingRef;
1906
+ const source = assertNoCancel(await select({
1907
+ message: "Secret source",
1908
+ options: sourceChoices,
1909
+ initialValue: existingRef && hasSourceChoice(sourceChoices, existingRef.source) ? existingRef.source : void 0
1910
+ }), "Secrets configure cancelled.");
1911
+ const defaultAlias = resolveDefaultSecretProviderAlias(stagedConfig, source, { preferFirstProviderForSource: true });
1912
+ const provider = assertNoCancel(await text({
1913
+ message: "Provider alias",
1914
+ initialValue: existingRef?.source === source ? existingRef.provider : defaultAlias,
1915
+ validate: (value) => {
1916
+ const trimmed = String(value ?? "").trim();
1917
+ if (!trimmed) return "Required";
1918
+ if (!isValidSecretProviderAlias(trimmed)) return "Must match /^[a-z][a-z0-9_-]{0,63}$/";
1919
+ }
1920
+ }), "Secrets configure cancelled.");
1921
+ const providerAlias = String(provider).trim();
1922
+ let suggestedId = existingRef?.source === source ? existingRef.id : void 0;
1923
+ if (!suggestedId && source === "env") suggestedId = resolveSuggestedEnvSecretId(candidate);
1924
+ if (!suggestedId && source === "file") {
1925
+ const configuredProvider = stagedConfig.secrets?.providers?.[providerAlias];
1926
+ if (configuredProvider?.source === "file" && configuredProvider.mode === "singleValue") suggestedId = "value";
1927
+ }
1928
+ const id = assertNoCancel(await text({
1929
+ message: "Secret id",
1930
+ initialValue: suggestedId,
1931
+ validate: (value) => {
1932
+ const trimmed = String(value ?? "").trim();
1933
+ if (!trimmed) return "Required";
1934
+ if (source === "exec" && !isValidExecSecretRefId(trimmed)) return formatExecSecretRefIdValidationMessage();
1935
+ }
1936
+ }), "Secrets configure cancelled.");
1937
+ const ref = {
1938
+ source,
1939
+ provider: providerAlias,
1940
+ id: String(id).trim()
1941
+ };
1942
+ if (ref.source === "exec" && !allowExecInPreflight) {
1943
+ const staticError = getSkippedExecRefStaticError({
1944
+ ref,
1945
+ config: stagedConfig
1946
+ });
1947
+ if (staticError) throw new Error(staticError);
1948
+ } else assertExpectedResolvedSecretValue({
1949
+ value: await resolveSecretRefValue(ref, {
1950
+ config: stagedConfig,
1951
+ env
1952
+ }),
1953
+ expected: candidate.expectedResolvedValue,
1954
+ errorMessage: candidate.expectedResolvedValue === "string" ? `Ref ${ref.source}:${ref.provider}:${ref.id} did not resolve to a non-empty string.` : `Ref ${ref.source}:${ref.provider}:${ref.id} did not resolve to a supported value type.`
1955
+ });
1956
+ const next = {
1957
+ ...candidate,
1958
+ ref
1959
+ };
1960
+ selectedByPath.set(candidateKey, next);
1961
+ if (!assertNoCancel(await confirm({
1962
+ message: "Configure another credential?",
1963
+ initialValue: true
1964
+ }), "Secrets configure cancelled.")) break;
1965
+ }
1966
+ }
1967
+ if (!hasConfigurePlanChanges({
1968
+ selectedTargets: selectedByPath,
1969
+ providerChanges
1970
+ })) throw new Error("No secrets changes were selected.");
1971
+ const plan = buildSecretsConfigurePlan({
1972
+ selectedTargets: selectedByPath,
1973
+ providerChanges
1974
+ });
1975
+ return {
1976
+ plan,
1977
+ preflight: await runSecretsApply({
1978
+ plan,
1979
+ env,
1980
+ write: false,
1981
+ allowExec: allowExecInPreflight
1982
+ })
1983
+ };
1984
+ }
1985
+ //#endregion
1986
+ //#region src/cli/secrets-cli.ts
1987
+ function readPlanFile(pathname) {
1988
+ const raw = fsSync.readFileSync(pathname, "utf8");
1989
+ const parsed = JSON.parse(raw);
1990
+ if (!isSecretsApplyPlan(parsed)) throw new Error(`Invalid secrets plan file: ${pathname}`);
1991
+ return parsed;
1992
+ }
1993
+ function registerSecretsCli(program) {
1994
+ const secrets = program.command("secrets").description("Secrets runtime controls").addHelpText("after", () => `\n${theme.muted("Docs:")} ${formatDocsLink("/gateway/security", "docs.vora.ai/gateway/security")}\n`);
1995
+ addGatewayClientOptions(secrets.command("reload").description("Re-resolve secret references and atomically swap runtime snapshot").option("--json", "Output JSON", false)).action(async (opts) => {
1996
+ try {
1997
+ const result = await callGatewayFromCli("secrets.reload", opts, void 0, { expectFinal: false });
1998
+ if (opts.json) {
1999
+ defaultRuntime.writeJson(result);
2000
+ return;
2001
+ }
2002
+ const warningCount = Number(result?.warningCount ?? 0);
2003
+ if (Number.isFinite(warningCount) && warningCount > 0) {
2004
+ defaultRuntime.log(`Secrets reloaded with ${warningCount} warning(s).`);
2005
+ return;
2006
+ }
2007
+ defaultRuntime.log("Secrets reloaded.");
2008
+ } catch (err) {
2009
+ defaultRuntime.error(danger(String(err)));
2010
+ defaultRuntime.exit(1);
2011
+ }
2012
+ });
2013
+ secrets.command("audit").description("Audit plaintext secrets, unresolved refs, and precedence drift").option("--check", "Exit non-zero when findings are present", false).option("--allow-exec", "Allow exec SecretRef resolution during audit (may execute provider commands)", false).option("--json", "Output JSON", false).action(async (opts) => {
2014
+ try {
2015
+ const report = await runSecretsAudit({ allowExec: Boolean(opts.allowExec) });
2016
+ if (opts.json) defaultRuntime.writeJson(report);
2017
+ else {
2018
+ defaultRuntime.log(`Secrets audit: ${report.status}. plaintext=${report.summary.plaintextCount}, unresolved=${report.summary.unresolvedRefCount}, shadowed=${report.summary.shadowedRefCount}, legacy=${report.summary.legacyResidueCount}.`);
2019
+ if (report.findings.length > 0) {
2020
+ for (const finding of report.findings.slice(0, 20)) defaultRuntime.log(`- [${finding.code}] ${finding.file}:${finding.jsonPath} ${finding.message}`);
2021
+ if (report.findings.length > 20) defaultRuntime.log(`... ${report.findings.length - 20} more finding(s).`);
2022
+ }
2023
+ if (report.resolution.skippedExecRefs > 0) defaultRuntime.log(`Audit note: skipped ${report.resolution.skippedExecRefs} exec SecretRef resolvability check(s). Re-run with --allow-exec to execute exec providers during audit.`);
2024
+ }
2025
+ const exitCode = resolveSecretsAuditExitCode(report, Boolean(opts.check));
2026
+ if (exitCode !== 0) defaultRuntime.exit(exitCode);
2027
+ } catch (err) {
2028
+ defaultRuntime.error(danger(String(err)));
2029
+ defaultRuntime.exit(2);
2030
+ }
2031
+ });
2032
+ secrets.command("configure").description("Interactive secrets helper (provider setup + SecretRef mapping + preflight)").option("--apply", "Apply changes immediately after preflight", false).option("--yes", "Skip apply confirmation prompt", false).option("--providers-only", "Configure secrets.providers only, skip credential mapping", false).option("--skip-provider-setup", "Skip provider setup and only map credential fields to existing providers", false).option("--agent <id>", "Agent id for auth-profiles targets (default: configured default agent)").option("--allow-exec", "Allow exec SecretRef preflight checks (may execute provider commands)", false).option("--plan-out <path>", "Write generated plan JSON to a file").option("--json", "Output JSON", false).action(async (opts) => {
2033
+ try {
2034
+ const configured = await runSecretsConfigureInteractive({
2035
+ providersOnly: Boolean(opts.providersOnly),
2036
+ skipProviderSetup: Boolean(opts.skipProviderSetup),
2037
+ agentId: typeof opts.agent === "string" ? opts.agent : void 0,
2038
+ allowExecInPreflight: Boolean(opts.allowExec)
2039
+ });
2040
+ if (opts.planOut) fsSync.writeFileSync(opts.planOut, `${JSON.stringify(configured.plan, null, 2)}\n`, "utf8");
2041
+ if (opts.json) defaultRuntime.writeJson({
2042
+ plan: configured.plan,
2043
+ preflight: configured.preflight
2044
+ });
2045
+ else {
2046
+ defaultRuntime.log(`Preflight: changed=${configured.preflight.changed}, files=${configured.preflight.changedFiles.length}, warnings=${configured.preflight.warningCount}.`);
2047
+ if (configured.preflight.warningCount > 0) for (const warning of configured.preflight.warnings) defaultRuntime.log(`- warning: ${warning}`);
2048
+ if (!configured.preflight.checks.resolvabilityComplete && configured.preflight.skippedExecRefs > 0) defaultRuntime.log(`Preflight note: skipped ${configured.preflight.skippedExecRefs} exec SecretRef resolvability check(s). Re-run with --allow-exec to execute exec providers during preflight.`);
2049
+ const providerUpserts = Object.keys(configured.plan.providerUpserts ?? {}).length;
2050
+ const providerDeletes = configured.plan.providerDeletes?.length ?? 0;
2051
+ defaultRuntime.log(`Plan: targets=${configured.plan.targets.length}, providerUpserts=${providerUpserts}, providerDeletes=${providerDeletes}.`);
2052
+ if (opts.planOut) defaultRuntime.log(`Plan written to ${opts.planOut}`);
2053
+ }
2054
+ let shouldApply = Boolean(opts.apply);
2055
+ if (!shouldApply && !opts.json) {
2056
+ const approved = await confirm({
2057
+ message: "Apply this plan now?",
2058
+ initialValue: true
2059
+ });
2060
+ if (typeof approved === "boolean") shouldApply = approved;
2061
+ }
2062
+ if (shouldApply) {
2063
+ if (Boolean(opts.apply) && !opts.yes && !opts.json) {
2064
+ if (await confirm({
2065
+ message: "This migration is one-way for migrated plaintext values. Continue with apply?",
2066
+ initialValue: true
2067
+ }) !== true) {
2068
+ defaultRuntime.log("Apply cancelled.");
2069
+ return;
2070
+ }
2071
+ }
2072
+ const result = await runSecretsApply({
2073
+ plan: configured.plan,
2074
+ write: true,
2075
+ allowExec: Boolean(opts.allowExec)
2076
+ });
2077
+ if (opts.json) {
2078
+ defaultRuntime.writeJson(result);
2079
+ return;
2080
+ }
2081
+ defaultRuntime.log(result.changed ? `Secrets applied. Updated ${result.changedFiles.length} file(s).` : "Secrets apply: no changes.");
2082
+ }
2083
+ } catch (err) {
2084
+ defaultRuntime.error(danger(String(err)));
2085
+ defaultRuntime.exit(1);
2086
+ }
2087
+ });
2088
+ secrets.command("apply").description("Apply a previously generated secrets plan").requiredOption("--from <path>", "Path to plan JSON").option("--dry-run", "Validate/preflight only", false).option("--allow-exec", "Allow exec SecretRef checks (may execute provider commands)", false).option("--json", "Output JSON", false).action(async (opts) => {
2089
+ try {
2090
+ const result = await runSecretsApply({
2091
+ plan: readPlanFile(opts.from),
2092
+ write: !opts.dryRun,
2093
+ allowExec: Boolean(opts.allowExec)
2094
+ });
2095
+ if (opts.json) {
2096
+ defaultRuntime.writeJson(result);
2097
+ return;
2098
+ }
2099
+ if (opts.dryRun) {
2100
+ defaultRuntime.log(result.changed ? `Secrets apply dry run: ${result.changedFiles.length} file(s) would change.` : "Secrets apply dry run: no changes.");
2101
+ if (!result.checks.resolvabilityComplete && result.skippedExecRefs > 0) defaultRuntime.log(`Secrets apply dry-run note: skipped ${result.skippedExecRefs} exec SecretRef resolvability check(s). Re-run with --allow-exec to execute exec providers during dry-run.`);
2102
+ return;
2103
+ }
2104
+ defaultRuntime.log(result.changed ? `Secrets applied. Updated ${result.changedFiles.length} file(s).` : "Secrets apply: no changes.");
2105
+ } catch (err) {
2106
+ defaultRuntime.error(danger(String(err)));
2107
+ defaultRuntime.exit(1);
2108
+ }
2109
+ });
2110
+ }
2111
+ //#endregion
2112
+ export { registerSecretsCli };