@noxsoft/anima 2.0.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 (1570) hide show
  1. package/CHANGELOG.md +2065 -0
  2. package/LICENSE +23 -0
  3. package/README.md +47 -0
  4. package/anima.mjs +56 -0
  5. package/dist/accounts-Cc5E4IDO.js +260 -0
  6. package/dist/accounts-CcVrwKqv.js +259 -0
  7. package/dist/acp-cli-BbvR4dNz.js +1081 -0
  8. package/dist/acp-cli-CePIi7gD.js +1084 -0
  9. package/dist/agent-CSrGrAg1.js +725 -0
  10. package/dist/agent-NgeWEcBM.js +725 -0
  11. package/dist/agent-events-UF0DxwKS.js +182 -0
  12. package/dist/agent-scope-BVf4aSwY.js +112 -0
  13. package/dist/agent-scope-OZi7lb8S.js +452 -0
  14. package/dist/agent-scope-V1bi9OYL.js +452 -0
  15. package/dist/agents-Bw06WthM.js +809 -0
  16. package/dist/agents.config-Dvo2ULxs.js +182 -0
  17. package/dist/agents.config-d6H0_3oj.js +182 -0
  18. package/dist/argv-DqUHKf0o.js +73 -0
  19. package/dist/audit-Buja3mbS.js +2401 -0
  20. package/dist/audit-CWIz6mM7.js +2401 -0
  21. package/dist/auth-91o2YM96.js +648 -0
  22. package/dist/auth-choice-7dFCqblU.js +2681 -0
  23. package/dist/auth-choice-S_0K9gpl.js +2681 -0
  24. package/dist/auth-health-CctpRTdC.js +149 -0
  25. package/dist/auth-health-DoHai4eD.js +149 -0
  26. package/dist/auth-lZ26wsbN.js +639 -0
  27. package/dist/auth-profiles-Cz2rxrav.js +2690 -0
  28. package/dist/auth-profiles-_5BsNObq.js +1565 -0
  29. package/dist/banner-ieAUufx9.js +294 -0
  30. package/dist/boolean-Ce2-qkSB.js +30 -0
  31. package/dist/boolean-Wzu0-e0P.js +30 -0
  32. package/dist/brew-CVZkr0GU.js +46 -0
  33. package/dist/brew-DAdyX1_1.js +46 -0
  34. package/dist/browser-cli-D_qgYDik.js +1679 -0
  35. package/dist/browser-cli-DldrdaCW.js +1676 -0
  36. package/dist/budget-ChKARYPY.js +132 -0
  37. package/dist/budget-Dspr6N_e.js +132 -0
  38. package/dist/build-info.json +5 -0
  39. package/dist/bundled/boot-md/HOOK.md +19 -0
  40. package/dist/bundled/boot-md/handler.js +861 -0
  41. package/dist/bundled/bootstrap-extra-files/HOOK.md +53 -0
  42. package/dist/bundled/bootstrap-extra-files/handler.js +39 -0
  43. package/dist/bundled/command-logger/HOOK.md +122 -0
  44. package/dist/bundled/command-logger/handler.js +55 -0
  45. package/dist/bundled/session-memory/HOOK.md +109 -0
  46. package/dist/bundled/session-memory/handler.js +128 -0
  47. package/dist/call-DPzNR_Qi.js +282 -0
  48. package/dist/call-ktoEhkOQ.js +282 -0
  49. package/dist/canvas-host/a2ui/.bundle.hash +1 -0
  50. package/dist/canvas-host/a2ui/a2ui.bundle.js +19040 -0
  51. package/dist/canvas-host/a2ui/index.html +307 -0
  52. package/dist/catalog-BAayBt1L.js +185 -0
  53. package/dist/catalog-BNsf97BM.js +185 -0
  54. package/dist/channel-options-C3GV4Fgg.js +33 -0
  55. package/dist/channel-options-DJ4GNfwk.js +32 -0
  56. package/dist/channel-selection-CujyiWGM.js +51 -0
  57. package/dist/channel-selection-DfGpCyh2.js +51 -0
  58. package/dist/channel-web-D42mzlCJ.js +2162 -0
  59. package/dist/channels-cli-BAtARz4A.js +1306 -0
  60. package/dist/channels-cli-Ddo_tIRR.js +1304 -0
  61. package/dist/channels-status-issues-DBc1pU_R.js +18 -0
  62. package/dist/channels-status-issues-DjO9MHIG.js +18 -0
  63. package/dist/chrome-Bi6iZ5sG.js +1601 -0
  64. package/dist/chrome-DNSv7Cpy.js +1629 -0
  65. package/dist/chrome-DScZx4Lk.js +1601 -0
  66. package/dist/chunk-mxPVo000.js +348 -0
  67. package/dist/clack-prompter-B0kl7shw.js +92 -0
  68. package/dist/clack-prompter-B1YxZdRy.js +92 -0
  69. package/dist/cli/daemon-cli.js +9 -0
  70. package/dist/cli-D3hUnL_G.js +101 -0
  71. package/dist/cli-DDwD6VgH.js +99 -0
  72. package/dist/cli-session-CP7ZH2-6.js +5463 -0
  73. package/dist/cli-session-oXJQpenl.js +5408 -0
  74. package/dist/cli-utils-BTBABPX9.js +40 -0
  75. package/dist/cli-utils-DtAxdCte.js +40 -0
  76. package/dist/client-C1avc0vD.js +1692 -0
  77. package/dist/client-CC94YZrT.js +1692 -0
  78. package/dist/clipboard-B2fBy8tG.js +31 -0
  79. package/dist/clipboard-BbGnZskJ.js +31 -0
  80. package/dist/command-format-Clp46jkj.js +38 -0
  81. package/dist/command-format-DELazozB.js +52 -0
  82. package/dist/command-format-SkzzRqR1.js +52 -0
  83. package/dist/command-options-CSbuuqHr.js +8 -0
  84. package/dist/command-options-Cp1tf96a.js +8 -0
  85. package/dist/command-registry-DDGudZEQ.js +248 -0
  86. package/dist/commands-CRcFD5MO.js +509 -0
  87. package/dist/commands-Dh40OpQL.js +509 -0
  88. package/dist/commands-registry-Bd0xbvwG.js +766 -0
  89. package/dist/commands-registry-DYfRSVF3.js +766 -0
  90. package/dist/common-D6bu0zHC.js +287 -0
  91. package/dist/common-zW9Y2P1B.js +287 -0
  92. package/dist/completion-cli-B9Cn374l.js +431 -0
  93. package/dist/completion-cli-BEHghUFx.js +432 -0
  94. package/dist/config-Bmm8tmZF.js +6523 -0
  95. package/dist/config-CHc5qzaI.js +5704 -0
  96. package/dist/config-Co6UXXF5.js +11 -0
  97. package/dist/config-Xm0j9LUa.js +5705 -0
  98. package/dist/config-cli-9ZbCHoV8.js +247 -0
  99. package/dist/config-cli-sxuGl29N.js +244 -0
  100. package/dist/config-guard-BwRD-b9Z.js +93 -0
  101. package/dist/config-guard-Dy7wyhAX.js +76 -0
  102. package/dist/config-sync-Bllc1TJ4.js +89 -0
  103. package/dist/config-sync-mfuOoGHl.js +89 -0
  104. package/dist/configure-CCyVzQZ7.js +1006 -0
  105. package/dist/configure-Nntbxt4t.js +1008 -0
  106. package/dist/constants-BwBn5CGe.js +65 -0
  107. package/dist/constants-O8yBqCBv.js +65 -0
  108. package/dist/context-DKaQYnCH.js +60 -0
  109. package/dist/control-service-BeOtZCCS.js +72 -0
  110. package/dist/control-service-vyKJ-XUp.js +72 -0
  111. package/dist/cron-cli-BasqtsJ0.js +451 -0
  112. package/dist/cron-cli-C8XzIpyX.js +448 -0
  113. package/dist/daemon-cli-cwL2GI5i.js +565 -0
  114. package/dist/daemon-cli-sjDh2xbf.js +566 -0
  115. package/dist/daemon-cli.js +13117 -0
  116. package/dist/daemon-runtime-BuMT6nck.js +460 -0
  117. package/dist/daemon-runtime-CTvi3m4D.js +460 -0
  118. package/dist/dangerous-tools-5ObDWy1N.js +32 -0
  119. package/dist/dangerous-tools-Jwr7jqNw.js +32 -0
  120. package/dist/deliver-D6cdhg5m.js +1097 -0
  121. package/dist/deliver-DlNDKlA4.js +1162 -0
  122. package/dist/deliver-bC6iI_rv.js +1097 -0
  123. package/dist/delivery-queue-B6IHz4Ry.js +220 -0
  124. package/dist/delivery-queue-TnQykYsg.js +220 -0
  125. package/dist/deps-C9kDG-Ru.js +42 -0
  126. package/dist/devices-cli-BE-Nib4Y.js +198 -0
  127. package/dist/devices-cli-GyPlNRyd.js +195 -0
  128. package/dist/diagnostics-Dj75aEHN.js +35 -0
  129. package/dist/diagnostics-DlIw6fqD.js +35 -0
  130. package/dist/directory-cli-BEaIvWkc.js +246 -0
  131. package/dist/directory-cli-CZ_-DP5Z.js +243 -0
  132. package/dist/dispatcher-Bkcui7jz.js +100 -0
  133. package/dist/dispatcher-C1B6cT_7.js +100 -0
  134. package/dist/display-A8k-mxv8.js +171 -0
  135. package/dist/display-BDOsXu8F.js +171 -0
  136. package/dist/dns-cli-BUzpVoMv.js +200 -0
  137. package/dist/dns-cli-DstQOMQt.js +197 -0
  138. package/dist/dock-DbxBBv30.js +753 -0
  139. package/dist/dock-cPBY4qGl.js +753 -0
  140. package/dist/docs-cli-BWp6p-Tq.js +161 -0
  141. package/dist/docs-cli-x22FnZfL.js +159 -0
  142. package/dist/doctor-B5HFw-nC.js +1813 -0
  143. package/dist/doctor-DnEyqGcQ.js +1815 -0
  144. package/dist/doctor-completion-BMEPXgVg.js +92 -0
  145. package/dist/doctor-completion-usPeH2ol.js +92 -0
  146. package/dist/doctor-config-flow-CS0WFnjL.js +1232 -0
  147. package/dist/doctor-config-flow-Cs4O_Kmq.js +1232 -0
  148. package/dist/engine-DgK9s3lk.js +561 -0
  149. package/dist/engine-ZSd5I5JN.js +561 -0
  150. package/dist/entry.js +1560 -0
  151. package/dist/env-0lJfCPsw.js +32 -0
  152. package/dist/errors-A_GqUU6B.js +26 -0
  153. package/dist/errors-CHow2wtt.js +37 -0
  154. package/dist/errors-Cojm0Kl7.js +37 -0
  155. package/dist/exec-BenD3A5l.js +1167 -0
  156. package/dist/exec-BizYYQgP.js +255 -0
  157. package/dist/exec-Bv3pyjeM.js +255 -0
  158. package/dist/exec-approvals-BP9AhCSw.js +1221 -0
  159. package/dist/exec-approvals-CdLmKX2R.js +1221 -0
  160. package/dist/exec-approvals-cli-25CGlFNw.js +368 -0
  161. package/dist/exec-approvals-cli-BXZ-hOlT.js +371 -0
  162. package/dist/extensionAPI.js +8542 -0
  163. package/dist/format-CjKG6raZ.js +20 -0
  164. package/dist/format-Mq6iU0_5.js +20 -0
  165. package/dist/format-duration-Cm3xh8xz.js +58 -0
  166. package/dist/format-duration-DhWzz_5b.js +58 -0
  167. package/dist/format-relative-C6kUHuOj.js +55 -0
  168. package/dist/format-relative-sy9iviQN.js +55 -0
  169. package/dist/frontmatter-YijVi0FQ.js +204 -0
  170. package/dist/gateway-cli-B9uc0RCI.js +19971 -0
  171. package/dist/gateway-cli-D8Qz7kCf.js +19972 -0
  172. package/dist/gateway-rpc-Ch9mCYEB.js +28 -0
  173. package/dist/gateway-rpc-DBhcdLFs.js +28 -0
  174. package/dist/github-copilot-auth-D6ZErYqa.js +1418 -0
  175. package/dist/github-copilot-auth-DGmyWJms.js +1418 -0
  176. package/dist/gmail-setup-utils-BPo_LkKI.js +428 -0
  177. package/dist/gmail-setup-utils-D3Yqgor7.js +428 -0
  178. package/dist/health-DsTZaAzV.js +1258 -0
  179. package/dist/health-V6dGthLA.js +1253 -0
  180. package/dist/health-format-CdP99j3Y.js +208 -0
  181. package/dist/health-format-JEChH08S.js +208 -0
  182. package/dist/heartbeat-visibility-CkL00WRR.js +98 -0
  183. package/dist/heartbeat-visibility-Cmni9671.js +98 -0
  184. package/dist/help-format-DUBI91Ti.js +17 -0
  185. package/dist/help-format-Dl4bsrLI.js +17 -0
  186. package/dist/helpers-9N2Q5aZj.js +25 -0
  187. package/dist/helpers-DLgbkcEn.js +25 -0
  188. package/dist/helpers-ZKNRexvX.js +10 -0
  189. package/dist/helpers-eJFa4K6r.js +10 -0
  190. package/dist/hooks-cli-Cu0D0fPS.js +993 -0
  191. package/dist/hooks-cli-E63uffR6.js +991 -0
  192. package/dist/hooks-status-B-e96dZj.js +356 -0
  193. package/dist/hooks-status-C_9sE0ox.js +356 -0
  194. package/dist/image-ops-Dlt3T7th.js +541 -0
  195. package/dist/image-ops-omlvdfah.js +541 -0
  196. package/dist/index.js +499 -0
  197. package/dist/init-Bm04RagW.js +122 -0
  198. package/dist/init-CaJBf4p1.js +122 -0
  199. package/dist/input-provenance-BgwBljRz.js +35 -0
  200. package/dist/input-provenance-DJBdpeKk.js +35 -0
  201. package/dist/input-provenance-iu26y0GH.js +35 -0
  202. package/dist/installs-C2iMRBVz.js +383 -0
  203. package/dist/installs-D-cPGdCw.js +383 -0
  204. package/dist/internal-hooks-DFTIurVM.js +77 -0
  205. package/dist/ipv4-C5QxzriV.js +1964 -0
  206. package/dist/ipv4-TxR9wQCQ.js +1964 -0
  207. package/dist/is-main-Dt9DTcH1.js +25 -0
  208. package/dist/is-main-cB3p7uob.js +25 -0
  209. package/dist/lanes-CNxj3tit.js +232 -0
  210. package/dist/legacy-names-CKU7tKQR.js +8 -0
  211. package/dist/lifecycle-core-B_7XRcvF.js +388 -0
  212. package/dist/lifecycle-core-By83PVAK.js +387 -0
  213. package/dist/links-BfjHVTB_.js +15 -0
  214. package/dist/links-DPGe0OHw.js +15 -0
  215. package/dist/llm-slug-generator.js +62 -0
  216. package/dist/loader-6Qkyybg1.js +87 -0
  217. package/dist/loader-Dmc0KyQK.js +87 -0
  218. package/dist/logging-54nXj81z.js +1 -0
  219. package/dist/logging-BdnOSVPD.js +1 -0
  220. package/dist/logging-DB6BQmhi.js +15 -0
  221. package/dist/logging-mcb66J0p.js +15 -0
  222. package/dist/login--8D8kyRy.js +61 -0
  223. package/dist/login-C-ugYHKt.js +61 -0
  224. package/dist/login-CX5Q2fYl.js +59 -0
  225. package/dist/login-qr-BLmGvITg.js +321 -0
  226. package/dist/login-qr-BNtuXLKL.js +323 -0
  227. package/dist/login-qr-PcyTC7Ra.js +326 -0
  228. package/dist/logs-cli-BEQVkiXp.js +245 -0
  229. package/dist/logs-cli-CIqiVMkY.js +242 -0
  230. package/dist/manager-Bsy9ifug.js +3244 -0
  231. package/dist/manager-CDgcZ51c.js +3246 -0
  232. package/dist/manager-D7QQ5XrE.js +3244 -0
  233. package/dist/manifest-registry-CW1zCyRF.js +748 -0
  234. package/dist/manifest-registry-D4lM2RdV.js +748 -0
  235. package/dist/markdown-tables-BT1X6jqH.js +347 -0
  236. package/dist/markdown-tables-DHgOK2vI.js +348 -0
  237. package/dist/media-THyainiE.js +1342 -0
  238. package/dist/memory-cli-BmIyAOZm.js +869 -0
  239. package/dist/memory-cli-BoXdfCLT.js +868 -0
  240. package/dist/message-channel-dSTVVCyX.js +110 -0
  241. package/dist/message-channel-w4F2b2F6.js +110 -0
  242. package/dist/migrate-BR6iAIjO.js +157 -0
  243. package/dist/migrate-D0EcMs0f.js +157 -0
  244. package/dist/mime-B1ZoR53M.js +145 -0
  245. package/dist/mime-Bm1xTtpY.js +145 -0
  246. package/dist/mime-C1RlpUSs.js +145 -0
  247. package/dist/model-param-b-C4BL7w0Z.js +16 -0
  248. package/dist/model-param-b-DPwyNGn8.js +16 -0
  249. package/dist/model-selection-BnEobs_z.js +2692 -0
  250. package/dist/models-KLd8Evmq.js +2545 -0
  251. package/dist/models-cli-D4UFQLid.js +258 -0
  252. package/dist/models-cli-DJHs5rJF.js +2739 -0
  253. package/dist/net-B5lXhYLV.js +218 -0
  254. package/dist/net-CDi_lJMH.js +88 -0
  255. package/dist/node-cli-BNCJUkgA.js +1319 -0
  256. package/dist/node-cli-C7S0vk0_.js +1322 -0
  257. package/dist/node-match-8XZnaid6.js +34 -0
  258. package/dist/node-match-B3Osv-5C.js +34 -0
  259. package/dist/node-service-BFxHJsno.js +67 -0
  260. package/dist/node-service-DUnan4uK.js +67 -0
  261. package/dist/nodes-cli-DOXhYgc8.js +1200 -0
  262. package/dist/nodes-cli-wvPZ3HwH.js +1197 -0
  263. package/dist/nodes-screen-1YiLkqr5.js +234 -0
  264. package/dist/nodes-screen-DZeD8hE5.js +234 -0
  265. package/dist/normalize-Dlcj9D3K.js +52 -0
  266. package/dist/normalize-GDK8JTNW.js +52 -0
  267. package/dist/note-Bi8Wb8DV.js +73 -0
  268. package/dist/note-uiuPxhyX.js +73 -0
  269. package/dist/npm-registry-spec-B-XIShkB.js +351 -0
  270. package/dist/npm-registry-spec-za3itb5Y.js +351 -0
  271. package/dist/onboard-DiTRW6CH.js +1165 -0
  272. package/dist/onboard-channels-BgruIpyg.js +672 -0
  273. package/dist/onboard-channels-gyq0VHHp.js +672 -0
  274. package/dist/onboard-helpers-BEaUind0.js +365 -0
  275. package/dist/onboard-helpers-f5Zprayl.js +365 -0
  276. package/dist/onboard-lH3XPWAK.js +1166 -0
  277. package/dist/onboarding-D0FOkXGt.js +910 -0
  278. package/dist/onboarding-kQVgbiIR.js +911 -0
  279. package/dist/openclaw-root-0yHXtO35.js +88 -0
  280. package/dist/openclaw-root-C85WMnVV.js +88 -0
  281. package/dist/orchestrator-CYTk7mq6.js +355 -0
  282. package/dist/orchestrator-J6ELnJXl.js +355 -0
  283. package/dist/outbound-BEq0qbPR.js +214 -0
  284. package/dist/outbound-BSVD-rjk.js +2062 -0
  285. package/dist/outbound-DXijk0db.js +214 -0
  286. package/dist/outbound-send-deps-ANnAhImn.js +14 -0
  287. package/dist/outbound-send-deps-BNGPU7jV.js +55 -0
  288. package/dist/pairing-cli-DKUyb6eK.js +118 -0
  289. package/dist/pairing-cli-ET2p_mXH.js +121 -0
  290. package/dist/pairing-store-CGYSwICJ.js +388 -0
  291. package/dist/pairing-store-DqQPqRMe.js +388 -0
  292. package/dist/parse-6-2MDhdT.js +23 -0
  293. package/dist/parse-CpunmTOS.js +23 -0
  294. package/dist/parse-log-line-Bqh1SSzC.js +44 -0
  295. package/dist/parse-log-line-DUZCjXbl.js +44 -0
  296. package/dist/parse-port-BKB9Exlg.js +12 -0
  297. package/dist/parse-port-DrfvwwiL.js +12 -0
  298. package/dist/parse-timeout-Di_tcEmi.js +16 -0
  299. package/dist/parse-timeout-vVlESvju.js +16 -0
  300. package/dist/path-env-Bu6k0jDQ.js +89 -0
  301. package/dist/path-env-C0zQSjw8.js +89 -0
  302. package/dist/paths-BTc4nk-6.js +126 -0
  303. package/dist/paths-BgUi2Z2G.js +54 -0
  304. package/dist/paths-C6VCWKo3.js +238 -0
  305. package/dist/paths-CCxa0o9c.js +222 -0
  306. package/dist/paths-CxRf2rBG.js +129 -0
  307. package/dist/paths-DcVEkYX5.js +54 -0
  308. package/dist/paths-hcX1Gqg5.js +129 -0
  309. package/dist/pi-auth-json-BzX-qyRo.js +82 -0
  310. package/dist/pi-auth-json-eesA38iW.js +78 -0
  311. package/dist/pi-auth-json-uEDdgg8K.js +80 -0
  312. package/dist/pi-embedded-C1Nl7L89.js +22 -0
  313. package/dist/pi-model-discovery-BkqhoPls.js +20 -0
  314. package/dist/pi-model-discovery-CQOWUAmK.js +3 -0
  315. package/dist/pi-model-discovery-DsRqYJLy.js +20 -0
  316. package/dist/pi-tools.policy-D9AUlreI.js +200 -0
  317. package/dist/pi-tools.policy-DRDm3v-2.js +200 -0
  318. package/dist/plugin-auto-enable-C-JwYMlZ.js +282 -0
  319. package/dist/plugin-auto-enable-DLIDBBfi.js +282 -0
  320. package/dist/plugin-registry-Bp8mivr-.js +32 -0
  321. package/dist/plugin-registry-CP7KgCvC.js +32 -0
  322. package/dist/plugin-sdk/account-id.d.ts +1 -0
  323. package/dist/plugin-sdk/account-id.js +15 -0
  324. package/dist/plugin-sdk/agents/agent-paths.d.ts +6 -0
  325. package/dist/plugin-sdk/agents/agent-scope.d.ts +37 -0
  326. package/dist/plugin-sdk/agents/anima-tools.d.ts +1 -0
  327. package/dist/plugin-sdk/agents/apply-patch-update.d.ts +10 -0
  328. package/dist/plugin-sdk/agents/apply-patch.d.ts +35 -0
  329. package/dist/plugin-sdk/agents/auth-profiles/constants.d.ts +20 -0
  330. package/dist/plugin-sdk/agents/auth-profiles/display.d.ts +7 -0
  331. package/dist/plugin-sdk/agents/auth-profiles/doctor.d.ts +8 -0
  332. package/dist/plugin-sdk/agents/auth-profiles/external-cli-sync.d.ts +7 -0
  333. package/dist/plugin-sdk/agents/auth-profiles/oauth.d.ts +12 -0
  334. package/dist/plugin-sdk/agents/auth-profiles/order.d.ts +8 -0
  335. package/dist/plugin-sdk/agents/auth-profiles/paths.d.ts +4 -0
  336. package/dist/plugin-sdk/agents/auth-profiles/profiles.d.ts +23 -0
  337. package/dist/plugin-sdk/agents/auth-profiles/repair.d.ts +14 -0
  338. package/dist/plugin-sdk/agents/auth-profiles/session-override.d.ts +18 -0
  339. package/dist/plugin-sdk/agents/auth-profiles/store.d.ts +10 -0
  340. package/dist/plugin-sdk/agents/auth-profiles/types.d.ts +60 -0
  341. package/dist/plugin-sdk/agents/auth-profiles/usage.d.ts +47 -0
  342. package/dist/plugin-sdk/agents/auth-profiles.d.ts +11 -0
  343. package/dist/plugin-sdk/agents/bash-process-registry.d.ts +70 -0
  344. package/dist/plugin-sdk/agents/bash-tools.d.ts +4 -0
  345. package/dist/plugin-sdk/agents/bash-tools.exec-runtime.d.ts +73 -0
  346. package/dist/plugin-sdk/agents/bash-tools.exec.d.ts +55 -0
  347. package/dist/plugin-sdk/agents/bash-tools.process.d.ts +7 -0
  348. package/dist/plugin-sdk/agents/bash-tools.shared.d.ts +48 -0
  349. package/dist/plugin-sdk/agents/bedrock-discovery.d.ts +9 -0
  350. package/dist/plugin-sdk/agents/bootstrap-files.d.ts +25 -0
  351. package/dist/plugin-sdk/agents/bootstrap-hooks.d.ts +10 -0
  352. package/dist/plugin-sdk/agents/channel-tools.d.ts +27 -0
  353. package/dist/plugin-sdk/agents/chutes-oauth.d.ts +46 -0
  354. package/dist/plugin-sdk/agents/cli-backends.d.ts +8 -0
  355. package/dist/plugin-sdk/agents/cli-credentials.d.ts +83 -0
  356. package/dist/plugin-sdk/agents/cli-runner/helpers.d.ts +76 -0
  357. package/dist/plugin-sdk/agents/cli-runner.d.ts +41 -0
  358. package/dist/plugin-sdk/agents/cli-session.d.ts +3 -0
  359. package/dist/plugin-sdk/agents/cloudflare-ai-gateway.d.ts +22 -0
  360. package/dist/plugin-sdk/agents/context.d.ts +1 -0
  361. package/dist/plugin-sdk/agents/current-time.d.ts +17 -0
  362. package/dist/plugin-sdk/agents/date-time.d.ts +13 -0
  363. package/dist/plugin-sdk/agents/defaults.d.ts +3 -0
  364. package/dist/plugin-sdk/agents/docs-path.d.ts +6 -0
  365. package/dist/plugin-sdk/agents/failover-error.d.ts +33 -0
  366. package/dist/plugin-sdk/agents/glob-pattern.d.ts +18 -0
  367. package/dist/plugin-sdk/agents/huggingface-models.d.ts +17 -0
  368. package/dist/plugin-sdk/agents/identity-avatar.d.ts +15 -0
  369. package/dist/plugin-sdk/agents/identity-file.d.ts +12 -0
  370. package/dist/plugin-sdk/agents/identity.d.ts +25 -0
  371. package/dist/plugin-sdk/agents/lanes.d.ts +3 -0
  372. package/dist/plugin-sdk/agents/memory-search.d.ts +66 -0
  373. package/dist/plugin-sdk/agents/minimax-vlm.d.ts +7 -0
  374. package/dist/plugin-sdk/agents/model-alias-lines.d.ts +2 -0
  375. package/dist/plugin-sdk/agents/model-auth.d.ts +36 -0
  376. package/dist/plugin-sdk/agents/model-catalog.d.ts +25 -0
  377. package/dist/plugin-sdk/agents/model-fallback.d.ts +40 -0
  378. package/dist/plugin-sdk/agents/model-selection.d.ts +94 -0
  379. package/dist/plugin-sdk/agents/models-config.d.ts +13 -0
  380. package/dist/plugin-sdk/agents/models-config.providers.d.ts +37 -0
  381. package/dist/plugin-sdk/agents/ollama-stream.d.ts +45 -0
  382. package/dist/plugin-sdk/agents/openclaw-tools.d.ts +46 -0
  383. package/dist/plugin-sdk/agents/pi-auth-json.d.ts +14 -0
  384. package/dist/plugin-sdk/agents/pi-embedded-helpers.d.ts +7 -0
  385. package/dist/plugin-sdk/agents/pi-embedded-runner/model.d.ts +1 -0
  386. package/dist/plugin-sdk/agents/pi-embedded-runner/run/params.d.ts +5 -0
  387. package/dist/plugin-sdk/agents/pi-embedded-runner.d.ts +25 -0
  388. package/dist/plugin-sdk/agents/pi-embedded-utils.d.ts +7 -0
  389. package/dist/plugin-sdk/agents/pi-embedded.d.ts +25 -0
  390. package/dist/plugin-sdk/agents/pi-model-discovery.d.ts +4 -0
  391. package/dist/plugin-sdk/agents/pi-settings.d.ts +19 -0
  392. package/dist/plugin-sdk/agents/pi-tools.abort.d.ts +2 -0
  393. package/dist/plugin-sdk/agents/pi-tools.before-tool-call.d.ts +29 -0
  394. package/dist/plugin-sdk/agents/pi-tools.d.ts +69 -0
  395. package/dist/plugin-sdk/agents/pi-tools.policy.d.ts +37 -0
  396. package/dist/plugin-sdk/agents/pi-tools.read.d.ts +44 -0
  397. package/dist/plugin-sdk/agents/pi-tools.schema.d.ts +3 -0
  398. package/dist/plugin-sdk/agents/pi-tools.types.d.ts +2 -0
  399. package/dist/plugin-sdk/agents/pty-dsr.d.ts +5 -0
  400. package/dist/plugin-sdk/agents/pty-keys.d.ts +13 -0
  401. package/dist/plugin-sdk/agents/sandbox/browser-bridges.d.ts +7 -0
  402. package/dist/plugin-sdk/agents/sandbox/browser.d.ts +12 -0
  403. package/dist/plugin-sdk/agents/sandbox/config-hash.d.ts +17 -0
  404. package/dist/plugin-sdk/agents/sandbox/config.d.ts +26 -0
  405. package/dist/plugin-sdk/agents/sandbox/constants.d.ts +19 -0
  406. package/dist/plugin-sdk/agents/sandbox/context.d.ts +12 -0
  407. package/dist/plugin-sdk/agents/sandbox/docker.d.ts +40 -0
  408. package/dist/plugin-sdk/agents/sandbox/fs-bridge.d.ts +56 -0
  409. package/dist/plugin-sdk/agents/sandbox/fs-paths.d.ts +28 -0
  410. package/dist/plugin-sdk/agents/sandbox/manage.d.ts +13 -0
  411. package/dist/plugin-sdk/agents/sandbox/prune.d.ts +3 -0
  412. package/dist/plugin-sdk/agents/sandbox/registry.d.ts +31 -0
  413. package/dist/plugin-sdk/agents/sandbox/runtime-status.d.ts +18 -0
  414. package/dist/plugin-sdk/agents/sandbox/shared.d.ts +4 -0
  415. package/dist/plugin-sdk/agents/sandbox/tool-policy.d.ts +4 -0
  416. package/dist/plugin-sdk/agents/sandbox/types.d.ts +76 -0
  417. package/dist/plugin-sdk/agents/sandbox/types.docker.d.ts +25 -0
  418. package/dist/plugin-sdk/agents/sandbox/workspace.d.ts +1 -0
  419. package/dist/plugin-sdk/agents/sandbox-paths.d.ts +23 -0
  420. package/dist/plugin-sdk/agents/sandbox.d.ts +8 -0
  421. package/dist/plugin-sdk/agents/schema/clean-for-gemini.d.ts +2 -0
  422. package/dist/plugin-sdk/agents/schema/typebox.d.ts +14 -0
  423. package/dist/plugin-sdk/agents/session-slug.d.ts +1 -0
  424. package/dist/plugin-sdk/agents/session-write-lock.d.ts +21 -0
  425. package/dist/plugin-sdk/agents/shell-utils.d.ts +7 -0
  426. package/dist/plugin-sdk/agents/skills/bundled-dir.d.ts +7 -0
  427. package/dist/plugin-sdk/agents/skills/config.d.ts +13 -0
  428. package/dist/plugin-sdk/agents/skills/env-overrides.d.ts +10 -0
  429. package/dist/plugin-sdk/agents/skills/frontmatter.d.ts +6 -0
  430. package/dist/plugin-sdk/agents/skills/plugin-skills.d.ts +5 -0
  431. package/dist/plugin-sdk/agents/skills/refresh.d.ts +19 -0
  432. package/dist/plugin-sdk/agents/skills/serialize.d.ts +1 -0
  433. package/dist/plugin-sdk/agents/skills/types.d.ts +80 -0
  434. package/dist/plugin-sdk/agents/skills/workspace.d.ts +49 -0
  435. package/dist/plugin-sdk/agents/skills.d.ts +7 -0
  436. package/dist/plugin-sdk/agents/subagent-announce-queue.d.ts +23 -0
  437. package/dist/plugin-sdk/agents/subagent-announce.d.ts +34 -0
  438. package/dist/plugin-sdk/agents/subagent-depth.d.ts +11 -0
  439. package/dist/plugin-sdk/agents/subagent-registry.d.ts +62 -0
  440. package/dist/plugin-sdk/agents/subagent-registry.store.d.ts +5 -0
  441. package/dist/plugin-sdk/agents/synthetic-models.d.ts +160 -0
  442. package/dist/plugin-sdk/agents/system-prompt-params.d.ts +30 -0
  443. package/dist/plugin-sdk/agents/system-prompt-report.d.ts +20 -0
  444. package/dist/plugin-sdk/agents/system-prompt.d.ts +78 -0
  445. package/dist/plugin-sdk/agents/timeout.d.ts +8 -0
  446. package/dist/plugin-sdk/agents/together-models.d.ts +4 -0
  447. package/dist/plugin-sdk/agents/tool-images.d.ts +19 -0
  448. package/dist/plugin-sdk/agents/tool-policy-pipeline.d.ts +27 -0
  449. package/dist/plugin-sdk/agents/tool-policy.d.ts +39 -0
  450. package/dist/plugin-sdk/agents/tool-summaries.d.ts +2 -0
  451. package/dist/plugin-sdk/agents/tools/agent-step.d.ts +15 -0
  452. package/dist/plugin-sdk/agents/tools/agents-list-tool.d.ts +6 -0
  453. package/dist/plugin-sdk/agents/tools/browser-tool.d.ts +5 -0
  454. package/dist/plugin-sdk/agents/tools/browser-tool.schema.d.ts +50 -0
  455. package/dist/plugin-sdk/agents/tools/canvas-tool.d.ts +2 -0
  456. package/dist/plugin-sdk/agents/tools/common.d.ts +56 -0
  457. package/dist/plugin-sdk/agents/tools/cron-tool.d.ts +6 -0
  458. package/dist/plugin-sdk/agents/tools/discord-actions-guild.d.ts +4 -0
  459. package/dist/plugin-sdk/agents/tools/discord-actions-messaging.d.ts +4 -0
  460. package/dist/plugin-sdk/agents/tools/discord-actions-moderation.d.ts +4 -0
  461. package/dist/plugin-sdk/agents/tools/discord-actions-presence.d.ts +4 -0
  462. package/dist/plugin-sdk/agents/tools/discord-actions.d.ts +3 -0
  463. package/dist/plugin-sdk/agents/tools/gateway-tool.d.ts +6 -0
  464. package/dist/plugin-sdk/agents/tools/gateway.d.ts +14 -0
  465. package/dist/plugin-sdk/agents/tools/image-tool.d.ts +35 -0
  466. package/dist/plugin-sdk/agents/tools/image-tool.helpers.d.ts +21 -0
  467. package/dist/plugin-sdk/agents/tools/memory-tool.d.ts +10 -0
  468. package/dist/plugin-sdk/agents/tools/message-tool.d.ts +18 -0
  469. package/dist/plugin-sdk/agents/tools/nodes-tool.d.ts +6 -0
  470. package/dist/plugin-sdk/agents/tools/nodes-utils.d.ts +20 -0
  471. package/dist/plugin-sdk/agents/tools/session-status-tool.d.ts +6 -0
  472. package/dist/plugin-sdk/agents/tools/sessions-announce-target.d.ts +5 -0
  473. package/dist/plugin-sdk/agents/tools/sessions-helpers.d.ts +90 -0
  474. package/dist/plugin-sdk/agents/tools/sessions-history-tool.d.ts +5 -0
  475. package/dist/plugin-sdk/agents/tools/sessions-list-tool.d.ts +5 -0
  476. package/dist/plugin-sdk/agents/tools/sessions-send-helpers.d.ts +34 -0
  477. package/dist/plugin-sdk/agents/tools/sessions-send-tool.a2a.d.ts +12 -0
  478. package/dist/plugin-sdk/agents/tools/sessions-send-tool.d.ts +7 -0
  479. package/dist/plugin-sdk/agents/tools/sessions-spawn-tool.d.ts +15 -0
  480. package/dist/plugin-sdk/agents/tools/slack-actions.d.ts +15 -0
  481. package/dist/plugin-sdk/agents/tools/subagents-tool.d.ts +4 -0
  482. package/dist/plugin-sdk/agents/tools/telegram-actions.d.ts +9 -0
  483. package/dist/plugin-sdk/agents/tools/tts-tool.d.ts +7 -0
  484. package/dist/plugin-sdk/agents/tools/web-fetch-utils.d.ts +18 -0
  485. package/dist/plugin-sdk/agents/tools/web-fetch.d.ts +25 -0
  486. package/dist/plugin-sdk/agents/tools/web-search.d.ts +71 -0
  487. package/dist/plugin-sdk/agents/tools/web-shared.d.ts +17 -0
  488. package/dist/plugin-sdk/agents/tools/web-tools.d.ts +2 -0
  489. package/dist/plugin-sdk/agents/tools/whatsapp-actions.d.ts +3 -0
  490. package/dist/plugin-sdk/agents/usage.d.ts +45 -0
  491. package/dist/plugin-sdk/agents/venice-models.d.ts +238 -0
  492. package/dist/plugin-sdk/agents/workspace-dir.d.ts +2 -0
  493. package/dist/plugin-sdk/agents/workspace-run.d.ts +18 -0
  494. package/dist/plugin-sdk/agents/workspace-templates.d.ts +6 -0
  495. package/dist/plugin-sdk/agents/workspace.d.ts +34 -0
  496. package/dist/plugin-sdk/auto-reply/chunk.d.ts +45 -0
  497. package/dist/plugin-sdk/auto-reply/command-auth.d.ts +17 -0
  498. package/dist/plugin-sdk/auto-reply/command-detection.d.ts +13 -0
  499. package/dist/plugin-sdk/auto-reply/commands-args.d.ts +3 -0
  500. package/dist/plugin-sdk/auto-reply/commands-registry.d.ts +54 -0
  501. package/dist/plugin-sdk/auto-reply/commands-registry.data.d.ts +3 -0
  502. package/dist/plugin-sdk/auto-reply/commands-registry.types.d.ts +66 -0
  503. package/dist/plugin-sdk/auto-reply/dispatch.d.ts +32 -0
  504. package/dist/plugin-sdk/auto-reply/envelope.d.ts +58 -0
  505. package/dist/plugin-sdk/auto-reply/group-activation.d.ts +6 -0
  506. package/dist/plugin-sdk/auto-reply/heartbeat-reply-payload.d.ts +2 -0
  507. package/dist/plugin-sdk/auto-reply/heartbeat.d.ts +26 -0
  508. package/dist/plugin-sdk/auto-reply/inbound-debounce.d.ts +16 -0
  509. package/dist/plugin-sdk/auto-reply/media-note.d.ts +2 -0
  510. package/dist/plugin-sdk/auto-reply/model.d.ts +8 -0
  511. package/dist/plugin-sdk/auto-reply/reply/abort.d.ts +22 -0
  512. package/dist/plugin-sdk/auto-reply/reply/agent-runner-execution.d.ts +49 -0
  513. package/dist/plugin-sdk/auto-reply/reply/agent-runner-helpers.d.ts +17 -0
  514. package/dist/plugin-sdk/auto-reply/reply/agent-runner-memory.d.ts +20 -0
  515. package/dist/plugin-sdk/auto-reply/reply/agent-runner-payloads.d.ts +25 -0
  516. package/dist/plugin-sdk/auto-reply/reply/agent-runner-utils.d.ts +30 -0
  517. package/dist/plugin-sdk/auto-reply/reply/agent-runner.d.ts +38 -0
  518. package/dist/plugin-sdk/auto-reply/reply/bash-command.d.ts +19 -0
  519. package/dist/plugin-sdk/auto-reply/reply/block-reply-coalescer.d.ts +15 -0
  520. package/dist/plugin-sdk/auto-reply/reply/block-reply-pipeline.d.ts +31 -0
  521. package/dist/plugin-sdk/auto-reply/reply/block-streaming.d.ts +22 -0
  522. package/dist/plugin-sdk/auto-reply/reply/body.d.ts +10 -0
  523. package/dist/plugin-sdk/auto-reply/reply/commands-allowlist.d.ts +2 -0
  524. package/dist/plugin-sdk/auto-reply/reply/commands-approve.d.ts +2 -0
  525. package/dist/plugin-sdk/auto-reply/reply/commands-bash.d.ts +2 -0
  526. package/dist/plugin-sdk/auto-reply/reply/commands-compact.d.ts +2 -0
  527. package/dist/plugin-sdk/auto-reply/reply/commands-config.d.ts +3 -0
  528. package/dist/plugin-sdk/auto-reply/reply/commands-context-report.d.ts +3 -0
  529. package/dist/plugin-sdk/auto-reply/reply/commands-context.d.ts +12 -0
  530. package/dist/plugin-sdk/auto-reply/reply/commands-core.d.ts +2 -0
  531. package/dist/plugin-sdk/auto-reply/reply/commands-info.d.ts +10 -0
  532. package/dist/plugin-sdk/auto-reply/reply/commands-models.d.ts +23 -0
  533. package/dist/plugin-sdk/auto-reply/reply/commands-plugin.d.ts +13 -0
  534. package/dist/plugin-sdk/auto-reply/reply/commands-session.d.ts +7 -0
  535. package/dist/plugin-sdk/auto-reply/reply/commands-status.d.ts +25 -0
  536. package/dist/plugin-sdk/auto-reply/reply/commands-subagents.d.ts +13 -0
  537. package/dist/plugin-sdk/auto-reply/reply/commands-tts.d.ts +2 -0
  538. package/dist/plugin-sdk/auto-reply/reply/commands-types.d.ts +60 -0
  539. package/dist/plugin-sdk/auto-reply/reply/commands.d.ts +4 -0
  540. package/dist/plugin-sdk/auto-reply/reply/config-commands.d.ts +15 -0
  541. package/dist/plugin-sdk/auto-reply/reply/config-value.d.ts +4 -0
  542. package/dist/plugin-sdk/auto-reply/reply/debug-commands.d.ts +16 -0
  543. package/dist/plugin-sdk/auto-reply/reply/directive-handling.auth.d.ts +19 -0
  544. package/dist/plugin-sdk/auto-reply/reply/directive-handling.d.ts +6 -0
  545. package/dist/plugin-sdk/auto-reply/reply/directive-handling.fast-lane.d.ts +7 -0
  546. package/dist/plugin-sdk/auto-reply/reply/directive-handling.impl.d.ts +3 -0
  547. package/dist/plugin-sdk/auto-reply/reply/directive-handling.model-picker.d.ts +13 -0
  548. package/dist/plugin-sdk/auto-reply/reply/directive-handling.model.d.ts +42 -0
  549. package/dist/plugin-sdk/auto-reply/reply/directive-handling.params.d.ts +51 -0
  550. package/dist/plugin-sdk/auto-reply/reply/directive-handling.parse.d.ts +62 -0
  551. package/dist/plugin-sdk/auto-reply/reply/directive-handling.persist.d.ts +37 -0
  552. package/dist/plugin-sdk/auto-reply/reply/directive-handling.queue-validation.d.ts +10 -0
  553. package/dist/plugin-sdk/auto-reply/reply/directive-handling.shared.d.ts +16 -0
  554. package/dist/plugin-sdk/auto-reply/reply/directive-parsing.d.ts +5 -0
  555. package/dist/plugin-sdk/auto-reply/reply/directives.d.ts +38 -0
  556. package/dist/plugin-sdk/auto-reply/reply/dispatch-from-config.d.ts +16 -0
  557. package/dist/plugin-sdk/auto-reply/reply/dispatcher-registry.d.ts +24 -0
  558. package/dist/plugin-sdk/auto-reply/reply/elevated-unavailable.d.ts +8 -0
  559. package/dist/plugin-sdk/auto-reply/reply/exec/directive.d.ts +20 -0
  560. package/dist/plugin-sdk/auto-reply/reply/exec.d.ts +1 -0
  561. package/dist/plugin-sdk/auto-reply/reply/followup-runner.d.ts +16 -0
  562. package/dist/plugin-sdk/auto-reply/reply/get-reply-directives-apply.d.ts +64 -0
  563. package/dist/plugin-sdk/auto-reply/reply/get-reply-directives-utils.d.ts +2 -0
  564. package/dist/plugin-sdk/auto-reply/reply/get-reply-directives.d.ts +92 -0
  565. package/dist/plugin-sdk/auto-reply/reply/get-reply-inline-actions.d.ts +59 -0
  566. package/dist/plugin-sdk/auto-reply/reply/get-reply-run.d.ts +69 -0
  567. package/dist/plugin-sdk/auto-reply/reply/get-reply.d.ts +4 -0
  568. package/dist/plugin-sdk/auto-reply/reply/groups.d.ts +26 -0
  569. package/dist/plugin-sdk/auto-reply/reply/history.d.ts +72 -0
  570. package/dist/plugin-sdk/auto-reply/reply/inbound-context.d.ts +8 -0
  571. package/dist/plugin-sdk/auto-reply/reply/inbound-dedupe.d.ts +8 -0
  572. package/dist/plugin-sdk/auto-reply/reply/inbound-meta.d.ts +3 -0
  573. package/dist/plugin-sdk/auto-reply/reply/inbound-text.d.ts +1 -0
  574. package/dist/plugin-sdk/auto-reply/reply/line-directives.d.ts +22 -0
  575. package/dist/plugin-sdk/auto-reply/reply/memory-flush.d.ts +23 -0
  576. package/dist/plugin-sdk/auto-reply/reply/mentions.d.ts +19 -0
  577. package/dist/plugin-sdk/auto-reply/reply/model-selection.d.ts +64 -0
  578. package/dist/plugin-sdk/auto-reply/reply/normalize-reply.d.ts +13 -0
  579. package/dist/plugin-sdk/auto-reply/reply/provider-dispatcher.d.ts +19 -0
  580. package/dist/plugin-sdk/auto-reply/reply/queue/cleanup.d.ts +6 -0
  581. package/dist/plugin-sdk/auto-reply/reply/queue/directive.d.ts +15 -0
  582. package/dist/plugin-sdk/auto-reply/reply/queue/drain.d.ts +2 -0
  583. package/dist/plugin-sdk/auto-reply/reply/queue/enqueue.d.ts +3 -0
  584. package/dist/plugin-sdk/auto-reply/reply/queue/normalize.d.ts +3 -0
  585. package/dist/plugin-sdk/auto-reply/reply/queue/settings.d.ts +2 -0
  586. package/dist/plugin-sdk/auto-reply/reply/queue/state.d.ts +19 -0
  587. package/dist/plugin-sdk/auto-reply/reply/queue/types.d.ts +84 -0
  588. package/dist/plugin-sdk/auto-reply/reply/queue.d.ts +8 -0
  589. package/dist/plugin-sdk/auto-reply/reply/reply-delivery.d.ts +27 -0
  590. package/dist/plugin-sdk/auto-reply/reply/reply-directives.d.ts +14 -0
  591. package/dist/plugin-sdk/auto-reply/reply/reply-dispatcher.d.ts +52 -0
  592. package/dist/plugin-sdk/auto-reply/reply/reply-elevated.d.ts +16 -0
  593. package/dist/plugin-sdk/auto-reply/reply/reply-inline.d.ts +8 -0
  594. package/dist/plugin-sdk/auto-reply/reply/reply-payloads.d.ts +22 -0
  595. package/dist/plugin-sdk/auto-reply/reply/reply-tags.d.ts +6 -0
  596. package/dist/plugin-sdk/auto-reply/reply/reply-threading.d.ts +9 -0
  597. package/dist/plugin-sdk/auto-reply/reply/response-prefix-template.d.ts +51 -0
  598. package/dist/plugin-sdk/auto-reply/reply/route-reply.d.ts +56 -0
  599. package/dist/plugin-sdk/auto-reply/reply/session-reset-model.d.ts +24 -0
  600. package/dist/plugin-sdk/auto-reply/reply/session-reset-prompt.d.ts +1 -0
  601. package/dist/plugin-sdk/auto-reply/reply/session-run-accounting.d.ts +11 -0
  602. package/dist/plugin-sdk/auto-reply/reply/session-updates.d.ts +34 -0
  603. package/dist/plugin-sdk/auto-reply/reply/session-usage.d.ts +21 -0
  604. package/dist/plugin-sdk/auto-reply/reply/session.d.ts +26 -0
  605. package/dist/plugin-sdk/auto-reply/reply/stage-sandbox-media.d.ts +9 -0
  606. package/dist/plugin-sdk/auto-reply/reply/subagents-utils.d.ts +7 -0
  607. package/dist/plugin-sdk/auto-reply/reply/typing-mode.d.ts +27 -0
  608. package/dist/plugin-sdk/auto-reply/reply/typing.d.ts +18 -0
  609. package/dist/plugin-sdk/auto-reply/reply/untrusted-context.d.ts +1 -0
  610. package/dist/plugin-sdk/auto-reply/reply.d.ts +6 -0
  611. package/dist/plugin-sdk/auto-reply/send-policy.d.ts +6 -0
  612. package/dist/plugin-sdk/auto-reply/skill-commands.d.ts +18 -0
  613. package/dist/plugin-sdk/auto-reply/status.d.ts +55 -0
  614. package/dist/plugin-sdk/auto-reply/templating.d.ts +152 -0
  615. package/dist/plugin-sdk/auto-reply/thinking.d.ts +22 -0
  616. package/dist/plugin-sdk/auto-reply/tokens.d.ts +3 -0
  617. package/dist/plugin-sdk/auto-reply/types.d.ts +61 -0
  618. package/dist/plugin-sdk/browser/bridge-auth-registry.d.ts +8 -0
  619. package/dist/plugin-sdk/browser/bridge-server.d.ts +18 -0
  620. package/dist/plugin-sdk/browser/cdp.d.ts +123 -0
  621. package/dist/plugin-sdk/browser/cdp.helpers.d.ts +13 -0
  622. package/dist/plugin-sdk/browser/chrome.d.ts +20 -0
  623. package/dist/plugin-sdk/browser/chrome.executables.d.ts +9 -0
  624. package/dist/plugin-sdk/browser/chrome.profile-decoration.d.ts +10 -0
  625. package/dist/plugin-sdk/browser/client-actions-core.d.ts +144 -0
  626. package/dist/plugin-sdk/browser/client-actions-observe.d.ts +68 -0
  627. package/dist/plugin-sdk/browser/client-actions-state.d.ts +90 -0
  628. package/dist/plugin-sdk/browser/client-actions-types.d.ts +18 -0
  629. package/dist/plugin-sdk/browser/client-actions.d.ts +4 -0
  630. package/dist/plugin-sdk/browser/client-fetch.d.ts +20 -0
  631. package/dist/plugin-sdk/browser/client.d.ts +147 -0
  632. package/dist/plugin-sdk/browser/config.d.ts +39 -0
  633. package/dist/plugin-sdk/browser/constants.d.ts +8 -0
  634. package/dist/plugin-sdk/browser/control-auth.d.ts +13 -0
  635. package/dist/plugin-sdk/browser/control-service.d.ts +5 -0
  636. package/dist/plugin-sdk/browser/csrf.d.ts +8 -0
  637. package/dist/plugin-sdk/browser/extension-relay.d.ts +15 -0
  638. package/dist/plugin-sdk/browser/http-auth.d.ts +5 -0
  639. package/dist/plugin-sdk/browser/paths.d.ts +27 -0
  640. package/dist/plugin-sdk/browser/profiles-service.d.ts +25 -0
  641. package/dist/plugin-sdk/browser/profiles.d.ts +30 -0
  642. package/dist/plugin-sdk/browser/proxy-files.d.ts +7 -0
  643. package/dist/plugin-sdk/browser/pw-ai-module.d.ts +6 -0
  644. package/dist/plugin-sdk/browser/pw-ai-state.d.ts +2 -0
  645. package/dist/plugin-sdk/browser/pw-ai.d.ts +2 -0
  646. package/dist/plugin-sdk/browser/pw-role-snapshot.d.ts +35 -0
  647. package/dist/plugin-sdk/browser/pw-session.d.ts +160 -0
  648. package/dist/plugin-sdk/browser/pw-tools-core.activity.d.ts +21 -0
  649. package/dist/plugin-sdk/browser/pw-tools-core.d.ts +8 -0
  650. package/dist/plugin-sdk/browser/pw-tools-core.downloads.d.ts +34 -0
  651. package/dist/plugin-sdk/browser/pw-tools-core.interactions.d.ts +114 -0
  652. package/dist/plugin-sdk/browser/pw-tools-core.responses.d.ts +13 -0
  653. package/dist/plugin-sdk/browser/pw-tools-core.shared.d.ts +6 -0
  654. package/dist/plugin-sdk/browser/pw-tools-core.snapshot.d.ts +64 -0
  655. package/dist/plugin-sdk/browser/pw-tools-core.state.d.ts +46 -0
  656. package/dist/plugin-sdk/browser/pw-tools-core.storage.d.ts +47 -0
  657. package/dist/plugin-sdk/browser/pw-tools-core.trace.d.ts +12 -0
  658. package/dist/plugin-sdk/browser/resolved-config-refresh.d.ts +12 -0
  659. package/dist/plugin-sdk/browser/routes/agent.act.d.ts +3 -0
  660. package/dist/plugin-sdk/browser/routes/agent.act.shared.d.ts +10 -0
  661. package/dist/plugin-sdk/browser/routes/agent.d.ts +3 -0
  662. package/dist/plugin-sdk/browser/routes/agent.debug.d.ts +3 -0
  663. package/dist/plugin-sdk/browser/routes/agent.shared.d.ts +9 -0
  664. package/dist/plugin-sdk/browser/routes/agent.snapshot.d.ts +3 -0
  665. package/dist/plugin-sdk/browser/routes/agent.storage.d.ts +3 -0
  666. package/dist/plugin-sdk/browser/routes/basic.d.ts +3 -0
  667. package/dist/plugin-sdk/browser/routes/dispatcher.d.ts +16 -0
  668. package/dist/plugin-sdk/browser/routes/index.d.ts +3 -0
  669. package/dist/plugin-sdk/browser/routes/path-output.d.ts +1 -0
  670. package/dist/plugin-sdk/browser/routes/tabs.d.ts +3 -0
  671. package/dist/plugin-sdk/browser/routes/types.d.ts +20 -0
  672. package/dist/plugin-sdk/browser/routes/utils.d.ts +15 -0
  673. package/dist/plugin-sdk/browser/screenshot.d.ts +9 -0
  674. package/dist/plugin-sdk/browser/server-context.d.ts +4 -0
  675. package/dist/plugin-sdk/browser/server-context.types.d.ts +79 -0
  676. package/dist/plugin-sdk/browser/server-middleware.d.ts +6 -0
  677. package/dist/plugin-sdk/browser/target-id.d.ts +11 -0
  678. package/dist/plugin-sdk/browser/trash.d.ts +1 -0
  679. package/dist/plugin-sdk/channel-web.d.ts +6 -0
  680. package/dist/plugin-sdk/channels/account-summary.d.ts +17 -0
  681. package/dist/plugin-sdk/channels/ack-reactions.d.ts +29 -0
  682. package/dist/plugin-sdk/channels/allowlist-match.d.ts +15 -0
  683. package/dist/plugin-sdk/channels/allowlists/resolve-utils.d.ts +20 -0
  684. package/dist/plugin-sdk/channels/channel-config.d.ts +39 -0
  685. package/dist/plugin-sdk/channels/chat-type.d.ts +2 -0
  686. package/dist/plugin-sdk/channels/command-gating.d.ts +20 -0
  687. package/dist/plugin-sdk/channels/conversation-label.d.ts +2 -0
  688. package/dist/plugin-sdk/channels/dock.d.ts +36 -0
  689. package/dist/plugin-sdk/channels/location.d.ts +21 -0
  690. package/dist/plugin-sdk/channels/logging.d.ts +20 -0
  691. package/dist/plugin-sdk/channels/mention-gating.d.ts +27 -0
  692. package/dist/plugin-sdk/channels/plugins/actions/discord/handle-action.d.ts +3 -0
  693. package/dist/plugin-sdk/channels/plugins/actions/discord/handle-action.guild-admin.d.ts +9 -0
  694. package/dist/plugin-sdk/channels/plugins/actions/discord.d.ts +2 -0
  695. package/dist/plugin-sdk/channels/plugins/actions/signal.d.ts +2 -0
  696. package/dist/plugin-sdk/channels/plugins/actions/telegram.d.ts +2 -0
  697. package/dist/plugin-sdk/channels/plugins/agent-tools/whatsapp-login.d.ts +2 -0
  698. package/dist/plugin-sdk/channels/plugins/allowlist-match.d.ts +2 -0
  699. package/dist/plugin-sdk/channels/plugins/bluebubbles-actions.d.ts +48 -0
  700. package/dist/plugin-sdk/channels/plugins/channel-config.d.ts +2 -0
  701. package/dist/plugin-sdk/channels/plugins/config-helpers.d.ts +14 -0
  702. package/dist/plugin-sdk/channels/plugins/config-schema.d.ts +3 -0
  703. package/dist/plugin-sdk/channels/plugins/config-writes.d.ts +7 -0
  704. package/dist/plugin-sdk/channels/plugins/directory-config.d.ts +16 -0
  705. package/dist/plugin-sdk/channels/plugins/group-mentions.d.ts +28 -0
  706. package/dist/plugin-sdk/channels/plugins/helpers.d.ts +8 -0
  707. package/dist/plugin-sdk/channels/plugins/index.d.ts +8 -0
  708. package/dist/plugin-sdk/channels/plugins/media-limits.d.ts +9 -0
  709. package/dist/plugin-sdk/channels/plugins/message-action-names.d.ts +2 -0
  710. package/dist/plugin-sdk/channels/plugins/message-actions.d.ts +7 -0
  711. package/dist/plugin-sdk/channels/plugins/normalize/discord.d.ts +2 -0
  712. package/dist/plugin-sdk/channels/plugins/normalize/imessage.d.ts +2 -0
  713. package/dist/plugin-sdk/channels/plugins/normalize/signal.d.ts +2 -0
  714. package/dist/plugin-sdk/channels/plugins/normalize/slack.d.ts +2 -0
  715. package/dist/plugin-sdk/channels/plugins/normalize/telegram.d.ts +2 -0
  716. package/dist/plugin-sdk/channels/plugins/normalize/whatsapp.d.ts +2 -0
  717. package/dist/plugin-sdk/channels/plugins/onboarding/channel-access.d.ts +31 -0
  718. package/dist/plugin-sdk/channels/plugins/onboarding/discord.d.ts +2 -0
  719. package/dist/plugin-sdk/channels/plugins/onboarding/helpers.d.ts +3 -0
  720. package/dist/plugin-sdk/channels/plugins/onboarding/imessage.d.ts +2 -0
  721. package/dist/plugin-sdk/channels/plugins/onboarding/signal.d.ts +3 -0
  722. package/dist/plugin-sdk/channels/plugins/onboarding/slack.d.ts +2 -0
  723. package/dist/plugin-sdk/channels/plugins/onboarding/telegram.d.ts +2 -0
  724. package/dist/plugin-sdk/channels/plugins/onboarding/whatsapp.d.ts +2 -0
  725. package/dist/plugin-sdk/channels/plugins/onboarding-types.d.ts +77 -0
  726. package/dist/plugin-sdk/channels/plugins/outbound/load.d.ts +2 -0
  727. package/dist/plugin-sdk/channels/plugins/pairing-message.d.ts +1 -0
  728. package/dist/plugin-sdk/channels/plugins/pairing.d.ts +16 -0
  729. package/dist/plugin-sdk/channels/plugins/setup-helpers.d.ts +13 -0
  730. package/dist/plugin-sdk/channels/plugins/status-issues/bluebubbles.d.ts +2 -0
  731. package/dist/plugin-sdk/channels/plugins/status-issues/discord.d.ts +2 -0
  732. package/dist/plugin-sdk/channels/plugins/status-issues/shared.d.ts +11 -0
  733. package/dist/plugin-sdk/channels/plugins/status-issues/telegram.d.ts +2 -0
  734. package/dist/plugin-sdk/channels/plugins/status-issues/whatsapp.d.ts +2 -0
  735. package/dist/plugin-sdk/channels/plugins/types.adapters.d.ts +297 -0
  736. package/dist/plugin-sdk/channels/plugins/types.core.d.ts +329 -0
  737. package/dist/plugin-sdk/channels/plugins/types.d.ts +6 -0
  738. package/dist/plugin-sdk/channels/plugins/types.plugin.d.ts +53 -0
  739. package/dist/plugin-sdk/channels/plugins/whatsapp-heartbeat.d.ts +11 -0
  740. package/dist/plugin-sdk/channels/registry.d.ts +16 -0
  741. package/dist/plugin-sdk/channels/reply-prefix.d.ts +24 -0
  742. package/dist/plugin-sdk/channels/sender-label.d.ts +9 -0
  743. package/dist/plugin-sdk/channels/session.d.ts +18 -0
  744. package/dist/plugin-sdk/channels/typing.d.ts +12 -0
  745. package/dist/plugin-sdk/channels/web/index.d.ts +1 -0
  746. package/dist/plugin-sdk/cli/cli-name.d.ts +3 -0
  747. package/dist/plugin-sdk/cli/cli-utils.d.ts +19 -0
  748. package/dist/plugin-sdk/cli/command-format.d.ts +1 -0
  749. package/dist/plugin-sdk/cli/deps.d.ts +18 -0
  750. package/dist/plugin-sdk/cli/memory-cli.d.ts +12 -0
  751. package/dist/plugin-sdk/cli/nodes-camera.d.ts +32 -0
  752. package/dist/plugin-sdk/cli/nodes-canvas.d.ts +10 -0
  753. package/dist/plugin-sdk/cli/nodes-run.d.ts +3 -0
  754. package/dist/plugin-sdk/cli/nodes-screen.d.ts +18 -0
  755. package/dist/plugin-sdk/cli/parse-bytes.d.ts +4 -0
  756. package/dist/plugin-sdk/cli/parse-duration.d.ts +4 -0
  757. package/dist/plugin-sdk/cli/parse-timeout.d.ts +1 -0
  758. package/dist/plugin-sdk/cli/profile-utils.d.ts +2 -0
  759. package/dist/plugin-sdk/cli/progress.d.ts +24 -0
  760. package/dist/plugin-sdk/cli/prompt.d.ts +1 -0
  761. package/dist/plugin-sdk/cli/wait.d.ts +1 -0
  762. package/dist/plugin-sdk/commands/agent/types.d.ts +77 -0
  763. package/dist/plugin-sdk/commands/daemon-runtime.d.ts +8 -0
  764. package/dist/plugin-sdk/commands/health.d.ts +63 -0
  765. package/dist/plugin-sdk/commands/oauth-flow.d.ts +21 -0
  766. package/dist/plugin-sdk/commands/onboard-helpers.d.ts +82 -0
  767. package/dist/plugin-sdk/commands/onboard-types.d.ts +76 -0
  768. package/dist/plugin-sdk/commands/signal-install.d.ts +30 -0
  769. package/dist/plugin-sdk/compat/legacy-names.d.ts +8 -0
  770. package/dist/plugin-sdk/config/agent-dirs.d.ts +14 -0
  771. package/dist/plugin-sdk/config/agent-limits.d.ts +5 -0
  772. package/dist/plugin-sdk/config/backup-rotation.d.ts +5 -0
  773. package/dist/plugin-sdk/config/cache-utils.d.ts +6 -0
  774. package/dist/plugin-sdk/config/config-paths.d.ts +10 -0
  775. package/dist/plugin-sdk/config/config.d.ts +7 -0
  776. package/dist/plugin-sdk/config/defaults.d.ts +18 -0
  777. package/dist/plugin-sdk/config/env-preserve.d.ts +25 -0
  778. package/dist/plugin-sdk/config/env-substitution.d.ts +36 -0
  779. package/dist/plugin-sdk/config/env-vars.d.ts +3 -0
  780. package/dist/plugin-sdk/config/group-policy.d.ts +47 -0
  781. package/dist/plugin-sdk/config/includes.d.ts +32 -0
  782. package/dist/plugin-sdk/config/io.d.ts +55 -0
  783. package/dist/plugin-sdk/config/legacy-migrate.d.ts +5 -0
  784. package/dist/plugin-sdk/config/legacy.d.ts +6 -0
  785. package/dist/plugin-sdk/config/legacy.migrations.d.ts +1 -0
  786. package/dist/plugin-sdk/config/legacy.migrations.part-1.d.ts +2 -0
  787. package/dist/plugin-sdk/config/legacy.migrations.part-2.d.ts +2 -0
  788. package/dist/plugin-sdk/config/legacy.migrations.part-3.d.ts +2 -0
  789. package/dist/plugin-sdk/config/legacy.rules.d.ts +2 -0
  790. package/dist/plugin-sdk/config/legacy.shared.d.ts +19 -0
  791. package/dist/plugin-sdk/config/markdown-tables.d.ts +7 -0
  792. package/dist/plugin-sdk/config/merge-config.d.ts +7 -0
  793. package/dist/plugin-sdk/config/merge-patch.d.ts +5 -0
  794. package/dist/plugin-sdk/config/normalize-paths.d.ts +8 -0
  795. package/dist/plugin-sdk/config/paths.d.ts +57 -0
  796. package/dist/plugin-sdk/config/port-defaults.d.ts +13 -0
  797. package/dist/plugin-sdk/config/runtime-overrides.d.ts +15 -0
  798. package/dist/plugin-sdk/config/sessions/delivery-info.d.ts +12 -0
  799. package/dist/plugin-sdk/config/sessions/group.d.ts +11 -0
  800. package/dist/plugin-sdk/config/sessions/main-session.d.ts +43 -0
  801. package/dist/plugin-sdk/config/sessions/metadata.d.ts +16 -0
  802. package/dist/plugin-sdk/config/sessions/paths.d.ts +21 -0
  803. package/dist/plugin-sdk/config/sessions/reset.d.ts +43 -0
  804. package/dist/plugin-sdk/config/sessions/session-key.d.ts +8 -0
  805. package/dist/plugin-sdk/config/sessions/store.d.ts +99 -0
  806. package/dist/plugin-sdk/config/sessions/transcript.d.ts +18 -0
  807. package/dist/plugin-sdk/config/sessions/types.d.ts +156 -0
  808. package/dist/plugin-sdk/config/sessions.d.ts +10 -0
  809. package/dist/plugin-sdk/config/talk.d.ts +11 -0
  810. package/dist/plugin-sdk/config/telegram-custom-commands.d.ts +24 -0
  811. package/dist/plugin-sdk/config/types.agent-defaults.d.ts +260 -0
  812. package/dist/plugin-sdk/config/types.agents.d.ts +80 -0
  813. package/dist/plugin-sdk/config/types.anima.d.ts +1 -0
  814. package/dist/plugin-sdk/config/types.approvals.d.ts +26 -0
  815. package/dist/plugin-sdk/config/types.auth.d.ts +28 -0
  816. package/dist/plugin-sdk/config/types.base.d.ts +172 -0
  817. package/dist/plugin-sdk/config/types.browser.d.ts +41 -0
  818. package/dist/plugin-sdk/config/types.channels.d.ts +48 -0
  819. package/dist/plugin-sdk/config/types.cron.d.ts +11 -0
  820. package/dist/plugin-sdk/config/types.d.ts +30 -0
  821. package/dist/plugin-sdk/config/types.discord.d.ts +188 -0
  822. package/dist/plugin-sdk/config/types.gateway.d.ts +288 -0
  823. package/dist/plugin-sdk/config/types.googlechat.d.ts +100 -0
  824. package/dist/plugin-sdk/config/types.hooks.d.ts +128 -0
  825. package/dist/plugin-sdk/config/types.imessage.d.ts +71 -0
  826. package/dist/plugin-sdk/config/types.irc.d.ts +96 -0
  827. package/dist/plugin-sdk/config/types.memory.d.ts +45 -0
  828. package/dist/plugin-sdk/config/types.messages.d.ts +121 -0
  829. package/dist/plugin-sdk/config/types.models.d.ts +54 -0
  830. package/dist/plugin-sdk/config/types.msteams.d.ts +101 -0
  831. package/dist/plugin-sdk/config/types.node-host.d.ts +10 -0
  832. package/dist/plugin-sdk/config/types.openclaw.d.ts +114 -0
  833. package/dist/plugin-sdk/config/types.plugins.d.ts +32 -0
  834. package/dist/plugin-sdk/config/types.queue.d.ts +14 -0
  835. package/dist/plugin-sdk/config/types.sandbox.d.ts +78 -0
  836. package/dist/plugin-sdk/config/types.signal.d.ts +86 -0
  837. package/dist/plugin-sdk/config/types.skills.d.ts +28 -0
  838. package/dist/plugin-sdk/config/types.slack.d.ts +150 -0
  839. package/dist/plugin-sdk/config/types.telegram.d.ts +163 -0
  840. package/dist/plugin-sdk/config/types.tools.d.ts +467 -0
  841. package/dist/plugin-sdk/config/types.tts.d.ts +78 -0
  842. package/dist/plugin-sdk/config/types.whatsapp.d.ts +142 -0
  843. package/dist/plugin-sdk/config/validation.d.ts +37 -0
  844. package/dist/plugin-sdk/config/version.d.ts +8 -0
  845. package/dist/plugin-sdk/config/zod-schema.agent-defaults.d.ts +249 -0
  846. package/dist/plugin-sdk/config/zod-schema.agent-runtime.d.ts +856 -0
  847. package/dist/plugin-sdk/config/zod-schema.agents.d.ts +504 -0
  848. package/dist/plugin-sdk/config/zod-schema.allowdeny.d.ts +13 -0
  849. package/dist/plugin-sdk/config/zod-schema.approvals.d.ts +15 -0
  850. package/dist/plugin-sdk/config/zod-schema.channels.d.ts +6 -0
  851. package/dist/plugin-sdk/config/zod-schema.core.d.ts +683 -0
  852. package/dist/plugin-sdk/config/zod-schema.d.ts +3401 -0
  853. package/dist/plugin-sdk/config/zod-schema.hooks.d.ts +79 -0
  854. package/dist/plugin-sdk/config/zod-schema.providers-core.d.ts +3233 -0
  855. package/dist/plugin-sdk/config/zod-schema.providers-whatsapp.d.ts +231 -0
  856. package/dist/plugin-sdk/config/zod-schema.providers.d.ts +1900 -0
  857. package/dist/plugin-sdk/config/zod-schema.sensitive.d.ts +2 -0
  858. package/dist/plugin-sdk/config/zod-schema.session.d.ts +203 -0
  859. package/dist/plugin-sdk/cron/delivery.d.ts +9 -0
  860. package/dist/plugin-sdk/cron/normalize.d.ts +9 -0
  861. package/dist/plugin-sdk/cron/parse.d.ts +1 -0
  862. package/dist/plugin-sdk/cron/payload-migration.d.ts +3 -0
  863. package/dist/plugin-sdk/cron/schedule.d.ts +2 -0
  864. package/dist/plugin-sdk/cron/service/jobs.d.ts +21 -0
  865. package/dist/plugin-sdk/cron/service/locked.d.ts +2 -0
  866. package/dist/plugin-sdk/cron/service/normalize.d.ts +17 -0
  867. package/dist/plugin-sdk/cron/service/ops.d.ts +43 -0
  868. package/dist/plugin-sdk/cron/service/state.d.ts +121 -0
  869. package/dist/plugin-sdk/cron/service/store.d.ts +9 -0
  870. package/dist/plugin-sdk/cron/service/timer.d.ts +25 -0
  871. package/dist/plugin-sdk/cron/service.d.ts +48 -0
  872. package/dist/plugin-sdk/cron/session-reaper.d.ts +35 -0
  873. package/dist/plugin-sdk/cron/store.d.ts +6 -0
  874. package/dist/plugin-sdk/cron/types.d.ts +95 -0
  875. package/dist/plugin-sdk/daemon/constants.d.ts +30 -0
  876. package/dist/plugin-sdk/discord/accounts.d.ts +9 -0
  877. package/dist/plugin-sdk/discord/audit.d.ts +2 -0
  878. package/dist/plugin-sdk/discord/directory-live.d.ts +4 -0
  879. package/dist/plugin-sdk/discord/monitor/allow-list.d.ts +1 -0
  880. package/dist/plugin-sdk/discord/monitor/gateway-registry.d.ts +3 -0
  881. package/dist/plugin-sdk/discord/monitor/presence-cache.d.ts +1 -0
  882. package/dist/plugin-sdk/discord/monitor.d.ts +3 -0
  883. package/dist/plugin-sdk/discord/pluralkit.d.ts +1 -0
  884. package/dist/plugin-sdk/discord/probe.d.ts +3 -0
  885. package/dist/plugin-sdk/discord/resolve-channels.d.ts +1 -0
  886. package/dist/plugin-sdk/discord/resolve-users.d.ts +1 -0
  887. package/dist/plugin-sdk/discord/send.d.ts +6 -0
  888. package/dist/plugin-sdk/discord/targets.d.ts +2 -0
  889. package/dist/plugin-sdk/gateway/auth-rate-limit.d.ts +59 -0
  890. package/dist/plugin-sdk/gateway/auth.d.ts +48 -0
  891. package/dist/plugin-sdk/gateway/call.d.ts +51 -0
  892. package/dist/plugin-sdk/gateway/chat-abort.d.ts +44 -0
  893. package/dist/plugin-sdk/gateway/chat-sanitize.d.ts +4 -0
  894. package/dist/plugin-sdk/gateway/client.d.ts +63 -0
  895. package/dist/plugin-sdk/gateway/control-ui-shared.d.ts +9 -0
  896. package/dist/plugin-sdk/gateway/device-auth.d.ts +12 -0
  897. package/dist/plugin-sdk/gateway/exec-approval-manager.d.ts +44 -0
  898. package/dist/plugin-sdk/gateway/net.d.ts +57 -0
  899. package/dist/plugin-sdk/gateway/node-registry.d.ts +60 -0
  900. package/dist/plugin-sdk/gateway/protocol/client-info.d.ts +58 -0
  901. package/dist/plugin-sdk/gateway/protocol/index.d.ts +661 -0
  902. package/dist/plugin-sdk/gateway/protocol/schema/agent.d.ts +86 -0
  903. package/dist/plugin-sdk/gateway/protocol/schema/agents-models-skills.d.ts +152 -0
  904. package/dist/plugin-sdk/gateway/protocol/schema/channels.d.ts +126 -0
  905. package/dist/plugin-sdk/gateway/protocol/schema/config.d.ts +51 -0
  906. package/dist/plugin-sdk/gateway/protocol/schema/cron.d.ts +353 -0
  907. package/dist/plugin-sdk/gateway/protocol/schema/devices.d.ts +38 -0
  908. package/dist/plugin-sdk/gateway/protocol/schema/error-codes.d.ts +14 -0
  909. package/dist/plugin-sdk/gateway/protocol/schema/exec-approvals.d.ts +163 -0
  910. package/dist/plugin-sdk/gateway/protocol/schema/frames.d.ts +164 -0
  911. package/dist/plugin-sdk/gateway/protocol/schema/logs-chat.d.ts +45 -0
  912. package/dist/plugin-sdk/gateway/protocol/schema/nodes.d.ts +64 -0
  913. package/dist/plugin-sdk/gateway/protocol/schema/primitives.d.ts +4 -0
  914. package/dist/plugin-sdk/gateway/protocol/schema/protocol-schemas.d.ts +3 -0
  915. package/dist/plugin-sdk/gateway/protocol/schema/sessions.d.ts +76 -0
  916. package/dist/plugin-sdk/gateway/protocol/schema/snapshot.d.ts +64 -0
  917. package/dist/plugin-sdk/gateway/protocol/schema/types.d.ts +124 -0
  918. package/dist/plugin-sdk/gateway/protocol/schema/wizard.d.ts +86 -0
  919. package/dist/plugin-sdk/gateway/protocol/schema.d.ts +16 -0
  920. package/dist/plugin-sdk/gateway/server/ws-types.d.ts +9 -0
  921. package/dist/plugin-sdk/gateway/server-channels.d.ts +24 -0
  922. package/dist/plugin-sdk/gateway/server-methods/types.d.ts +98 -0
  923. package/dist/plugin-sdk/gateway/server-shared.d.ts +7 -0
  924. package/dist/plugin-sdk/gateway/session-utils.d.ts +71 -0
  925. package/dist/plugin-sdk/gateway/session-utils.fs.d.ts +33 -0
  926. package/dist/plugin-sdk/gateway/session-utils.types.d.ts +84 -0
  927. package/dist/plugin-sdk/globals.d.ts +11 -0
  928. package/dist/plugin-sdk/hooks/internal-hooks.d.ts +95 -0
  929. package/dist/plugin-sdk/hooks/types.d.ts +62 -0
  930. package/dist/plugin-sdk/imessage/accounts.d.ts +8 -0
  931. package/dist/plugin-sdk/imessage/monitor.d.ts +3 -0
  932. package/dist/plugin-sdk/imessage/probe.d.ts +3 -0
  933. package/dist/plugin-sdk/imessage/send.d.ts +1 -0
  934. package/dist/plugin-sdk/imessage/target-parsing-helpers.d.ts +4 -0
  935. package/dist/plugin-sdk/imessage/targets.d.ts +2 -0
  936. package/dist/plugin-sdk/index.d.ts +1 -0
  937. package/dist/plugin-sdk/index.js +27570 -0
  938. package/dist/plugin-sdk/infra/agent-events.d.ts +21 -0
  939. package/dist/plugin-sdk/infra/anima-root.d.ts +1 -0
  940. package/dist/plugin-sdk/infra/archive.d.ts +41 -0
  941. package/dist/plugin-sdk/infra/backoff.d.ts +8 -0
  942. package/dist/plugin-sdk/infra/binaries.d.ts +3 -0
  943. package/dist/plugin-sdk/infra/brew.d.ts +8 -0
  944. package/dist/plugin-sdk/infra/channel-activity.d.ts +18 -0
  945. package/dist/plugin-sdk/infra/channel-summary.d.ts +6 -0
  946. package/dist/plugin-sdk/infra/dedupe.d.ts +11 -0
  947. package/dist/plugin-sdk/infra/device-auth-store.d.ts +18 -0
  948. package/dist/plugin-sdk/infra/device-identity.d.ts +11 -0
  949. package/dist/plugin-sdk/infra/device-pairing.d.ts +96 -0
  950. package/dist/plugin-sdk/infra/diagnostic-events.d.ts +121 -0
  951. package/dist/plugin-sdk/infra/dotenv.d.ts +3 -0
  952. package/dist/plugin-sdk/infra/env.d.ts +11 -0
  953. package/dist/plugin-sdk/infra/errors.d.ts +11 -0
  954. package/dist/plugin-sdk/infra/exec-approvals-allowlist.d.ts +45 -0
  955. package/dist/plugin-sdk/infra/exec-approvals-analysis.d.ts +78 -0
  956. package/dist/plugin-sdk/infra/exec-approvals.d.ts +107 -0
  957. package/dist/plugin-sdk/infra/exec-safety.d.ts +1 -0
  958. package/dist/plugin-sdk/infra/fetch.d.ts +2 -0
  959. package/dist/plugin-sdk/infra/file-lock.d.ts +2 -0
  960. package/dist/plugin-sdk/infra/format-time/format-datetime.d.ts +35 -0
  961. package/dist/plugin-sdk/infra/format-time/format-duration.d.ts +23 -0
  962. package/dist/plugin-sdk/infra/format-time/format-relative.d.ts +39 -0
  963. package/dist/plugin-sdk/infra/git-commit.d.ts +4 -0
  964. package/dist/plugin-sdk/infra/heartbeat-active-hours.d.ts +5 -0
  965. package/dist/plugin-sdk/infra/heartbeat-events-filter.d.ts +3 -0
  966. package/dist/plugin-sdk/infra/heartbeat-events.d.ts +21 -0
  967. package/dist/plugin-sdk/infra/heartbeat-runner.d.ts +45 -0
  968. package/dist/plugin-sdk/infra/heartbeat-visibility.d.ts +17 -0
  969. package/dist/plugin-sdk/infra/heartbeat-wake.d.ts +27 -0
  970. package/dist/plugin-sdk/infra/home-dir.d.ts +7 -0
  971. package/dist/plugin-sdk/infra/http-body.d.ts +46 -0
  972. package/dist/plugin-sdk/infra/json-file.d.ts +2 -0
  973. package/dist/plugin-sdk/infra/net/fetch-guard.d.ts +21 -0
  974. package/dist/plugin-sdk/infra/net/ssrf.d.ts +32 -0
  975. package/dist/plugin-sdk/infra/node-pairing.d.ts +62 -0
  976. package/dist/plugin-sdk/infra/node-shell.d.ts +1 -0
  977. package/dist/plugin-sdk/infra/openclaw-root.d.ts +10 -0
  978. package/dist/plugin-sdk/infra/outbound/abort.d.ts +8 -0
  979. package/dist/plugin-sdk/infra/outbound/channel-adapters.d.ts +6 -0
  980. package/dist/plugin-sdk/infra/outbound/channel-selection.d.ts +11 -0
  981. package/dist/plugin-sdk/infra/outbound/channel-target.d.ts +6 -0
  982. package/dist/plugin-sdk/infra/outbound/deliver.d.ts +77 -0
  983. package/dist/plugin-sdk/infra/outbound/delivery-queue.d.ts +103 -0
  984. package/dist/plugin-sdk/infra/outbound/directory-cache.d.ts +24 -0
  985. package/dist/plugin-sdk/infra/outbound/identity.d.ts +8 -0
  986. package/dist/plugin-sdk/infra/outbound/message-action-params.d.ts +47 -0
  987. package/dist/plugin-sdk/infra/outbound/message-action-runner.d.ts +74 -0
  988. package/dist/plugin-sdk/infra/outbound/message-action-spec.d.ts +5 -0
  989. package/dist/plugin-sdk/infra/outbound/message.d.ts +85 -0
  990. package/dist/plugin-sdk/infra/outbound/outbound-policy.d.ts +31 -0
  991. package/dist/plugin-sdk/infra/outbound/outbound-send-service.d.ts +64 -0
  992. package/dist/plugin-sdk/infra/outbound/outbound-session.d.ts +31 -0
  993. package/dist/plugin-sdk/infra/outbound/payloads.d.ts +16 -0
  994. package/dist/plugin-sdk/infra/outbound/target-errors.d.ts +6 -0
  995. package/dist/plugin-sdk/infra/outbound/target-normalization.d.ts +4 -0
  996. package/dist/plugin-sdk/infra/outbound/target-resolver.d.ts +53 -0
  997. package/dist/plugin-sdk/infra/outbound/targets.d.ts +65 -0
  998. package/dist/plugin-sdk/infra/outbound/tool-payload.d.ts +2 -0
  999. package/dist/plugin-sdk/infra/pairing-files.d.ts +11 -0
  1000. package/dist/plugin-sdk/infra/pairing-token.d.ts +3 -0
  1001. package/dist/plugin-sdk/infra/path-prepend.d.ts +5 -0
  1002. package/dist/plugin-sdk/infra/ports-format.d.ts +5 -0
  1003. package/dist/plugin-sdk/infra/ports-inspect.d.ts +2 -0
  1004. package/dist/plugin-sdk/infra/ports-lsof.d.ts +2 -0
  1005. package/dist/plugin-sdk/infra/ports-types.d.ts +17 -0
  1006. package/dist/plugin-sdk/infra/ports.d.ts +14 -0
  1007. package/dist/plugin-sdk/infra/provider-usage.auth.d.ts +11 -0
  1008. package/dist/plugin-sdk/infra/provider-usage.d.ts +4 -0
  1009. package/dist/plugin-sdk/infra/provider-usage.fetch.antigravity.d.ts +2 -0
  1010. package/dist/plugin-sdk/infra/provider-usage.fetch.claude.d.ts +2 -0
  1011. package/dist/plugin-sdk/infra/provider-usage.fetch.codex.d.ts +2 -0
  1012. package/dist/plugin-sdk/infra/provider-usage.fetch.copilot.d.ts +2 -0
  1013. package/dist/plugin-sdk/infra/provider-usage.fetch.d.ts +7 -0
  1014. package/dist/plugin-sdk/infra/provider-usage.fetch.gemini.d.ts +2 -0
  1015. package/dist/plugin-sdk/infra/provider-usage.fetch.minimax.d.ts +2 -0
  1016. package/dist/plugin-sdk/infra/provider-usage.fetch.shared.d.ts +1 -0
  1017. package/dist/plugin-sdk/infra/provider-usage.fetch.zai.d.ts +2 -0
  1018. package/dist/plugin-sdk/infra/provider-usage.format.d.ts +13 -0
  1019. package/dist/plugin-sdk/infra/provider-usage.load.d.ts +12 -0
  1020. package/dist/plugin-sdk/infra/provider-usage.shared.d.ts +8 -0
  1021. package/dist/plugin-sdk/infra/provider-usage.types.d.ts +17 -0
  1022. package/dist/plugin-sdk/infra/restart-sentinel.d.ts +50 -0
  1023. package/dist/plugin-sdk/infra/restart.d.ts +61 -0
  1024. package/dist/plugin-sdk/infra/retry.d.ts +21 -0
  1025. package/dist/plugin-sdk/infra/session-cost-usage.d.ts +45 -0
  1026. package/dist/plugin-sdk/infra/session-cost-usage.types.d.ts +153 -0
  1027. package/dist/plugin-sdk/infra/session-maintenance-warning.d.ts +10 -0
  1028. package/dist/plugin-sdk/infra/shell-env.d.ts +33 -0
  1029. package/dist/plugin-sdk/infra/skills-remote.d.ts +25 -0
  1030. package/dist/plugin-sdk/infra/system-events.d.ts +18 -0
  1031. package/dist/plugin-sdk/infra/tailnet.d.ts +7 -0
  1032. package/dist/plugin-sdk/infra/tailscale.d.ts +34 -0
  1033. package/dist/plugin-sdk/infra/tls/fingerprint.d.ts +1 -0
  1034. package/dist/plugin-sdk/infra/tls/gateway.d.ts +16 -0
  1035. package/dist/plugin-sdk/infra/tmp-anima-dir.d.ts +1 -0
  1036. package/dist/plugin-sdk/infra/tmp-openclaw-dir.d.ts +18 -0
  1037. package/dist/plugin-sdk/infra/unhandled-rejections.d.ts +15 -0
  1038. package/dist/plugin-sdk/infra/warning-filter.d.ts +7 -0
  1039. package/dist/plugin-sdk/infra/ws.d.ts +2 -0
  1040. package/dist/plugin-sdk/infra/wsl.d.ts +11 -0
  1041. package/dist/plugin-sdk/line/accounts.d.ts +9 -0
  1042. package/dist/plugin-sdk/line/config-schema.d.ts +1 -0
  1043. package/dist/plugin-sdk/line/flex-templates.d.ts +14 -0
  1044. package/dist/plugin-sdk/line/markdown-to-line.d.ts +6 -0
  1045. package/dist/plugin-sdk/line/monitor.d.ts +3 -0
  1046. package/dist/plugin-sdk/line/probe.d.ts +3 -0
  1047. package/dist/plugin-sdk/line/send.d.ts +14 -0
  1048. package/dist/plugin-sdk/line/template-messages.d.ts +1 -0
  1049. package/dist/plugin-sdk/line/types.d.ts +6 -0
  1050. package/dist/plugin-sdk/link-understanding/apply.d.ts +10 -0
  1051. package/dist/plugin-sdk/link-understanding/defaults.d.ts +2 -0
  1052. package/dist/plugin-sdk/link-understanding/detect.d.ts +3 -0
  1053. package/dist/plugin-sdk/link-understanding/format.d.ts +4 -0
  1054. package/dist/plugin-sdk/link-understanding/runner.d.ts +11 -0
  1055. package/dist/plugin-sdk/logger.d.ts +6 -0
  1056. package/dist/plugin-sdk/logging/config.d.ts +4 -0
  1057. package/dist/plugin-sdk/logging/console.d.ts +23 -0
  1058. package/dist/plugin-sdk/logging/diagnostic-session-state.d.ts +17 -0
  1059. package/dist/plugin-sdk/logging/diagnostic.d.ts +56 -0
  1060. package/dist/plugin-sdk/logging/levels.d.ts +4 -0
  1061. package/dist/plugin-sdk/logging/logger.d.ts +42 -0
  1062. package/dist/plugin-sdk/logging/redact-identifier.d.ts +4 -0
  1063. package/dist/plugin-sdk/logging/redact.d.ts +9 -0
  1064. package/dist/plugin-sdk/logging/state.d.ts +18 -0
  1065. package/dist/plugin-sdk/logging/subsystem.d.ts +18 -0
  1066. package/dist/plugin-sdk/logging.d.ts +10 -0
  1067. package/dist/plugin-sdk/markdown/fences.d.ts +10 -0
  1068. package/dist/plugin-sdk/markdown/frontmatter.d.ts +2 -0
  1069. package/dist/plugin-sdk/markdown/ir.d.ts +32 -0
  1070. package/dist/plugin-sdk/markdown/render.d.ts +18 -0
  1071. package/dist/plugin-sdk/markdown/tables.d.ts +2 -0
  1072. package/dist/plugin-sdk/markdown/whatsapp.d.ts +14 -0
  1073. package/dist/plugin-sdk/media/audio-tags.d.ts +10 -0
  1074. package/dist/plugin-sdk/media/audio.d.ts +19 -0
  1075. package/dist/plugin-sdk/media/base64.d.ts +1 -0
  1076. package/dist/plugin-sdk/media/constants.d.ts +7 -0
  1077. package/dist/plugin-sdk/media/fetch.d.ts +23 -0
  1078. package/dist/plugin-sdk/media/image-ops.d.ts +39 -0
  1079. package/dist/plugin-sdk/media/input-files.d.ts +81 -0
  1080. package/dist/plugin-sdk/media/mime.d.ts +16 -0
  1081. package/dist/plugin-sdk/media/parse.d.ts +8 -0
  1082. package/dist/plugin-sdk/media/png-encode.d.ts +8 -0
  1083. package/dist/plugin-sdk/media/read-response-with-limit.d.ts +7 -0
  1084. package/dist/plugin-sdk/media/sniff-mime-from-base64.d.ts +1 -0
  1085. package/dist/plugin-sdk/media/store.d.ts +28 -0
  1086. package/dist/plugin-sdk/media-understanding/apply.d.ts +19 -0
  1087. package/dist/plugin-sdk/media-understanding/attachments.d.ts +43 -0
  1088. package/dist/plugin-sdk/media-understanding/concurrency.d.ts +1 -0
  1089. package/dist/plugin-sdk/media-understanding/defaults.d.ts +14 -0
  1090. package/dist/plugin-sdk/media-understanding/errors.d.ts +6 -0
  1091. package/dist/plugin-sdk/media-understanding/format.d.ts +7 -0
  1092. package/dist/plugin-sdk/media-understanding/output-extract.d.ts +2 -0
  1093. package/dist/plugin-sdk/media-understanding/providers/image.d.ts +1 -0
  1094. package/dist/plugin-sdk/media-understanding/providers/index.d.ts +8 -0
  1095. package/dist/plugin-sdk/media-understanding/providers/shared.d.ts +4 -0
  1096. package/dist/plugin-sdk/media-understanding/resolve.d.ts +44 -0
  1097. package/dist/plugin-sdk/media-understanding/runner.d.ts +35 -0
  1098. package/dist/plugin-sdk/media-understanding/runner.entries.d.ts +33 -0
  1099. package/dist/plugin-sdk/media-understanding/scope.d.ts +9 -0
  1100. package/dist/plugin-sdk/media-understanding/types.d.ts +93 -0
  1101. package/dist/plugin-sdk/media-understanding/video.d.ts +2 -0
  1102. package/dist/plugin-sdk/memory/backend-config.d.ts +49 -0
  1103. package/dist/plugin-sdk/memory/batch-gemini.d.ts +55 -0
  1104. package/dist/plugin-sdk/memory/batch-http.d.ts +6 -0
  1105. package/dist/plugin-sdk/memory/batch-openai.d.ts +45 -0
  1106. package/dist/plugin-sdk/memory/batch-output.d.ts +23 -0
  1107. package/dist/plugin-sdk/memory/batch-voyage.d.ts +46 -0
  1108. package/dist/plugin-sdk/memory/embedding-chunk-limits.d.ts +3 -0
  1109. package/dist/plugin-sdk/memory/embedding-input-limits.d.ts +2 -0
  1110. package/dist/plugin-sdk/memory/embedding-model-limits.d.ts +2 -0
  1111. package/dist/plugin-sdk/memory/embeddings-gemini.d.ts +13 -0
  1112. package/dist/plugin-sdk/memory/embeddings-openai.d.ts +13 -0
  1113. package/dist/plugin-sdk/memory/embeddings-voyage.d.ts +13 -0
  1114. package/dist/plugin-sdk/memory/embeddings.d.ts +44 -0
  1115. package/dist/plugin-sdk/memory/hybrid.d.ts +34 -0
  1116. package/dist/plugin-sdk/memory/index.d.ts +3 -0
  1117. package/dist/plugin-sdk/memory/internal.d.ts +38 -0
  1118. package/dist/plugin-sdk/memory/manager-embedding-ops.d.ts +32 -0
  1119. package/dist/plugin-sdk/memory/manager-search.d.ts +60 -0
  1120. package/dist/plugin-sdk/memory/manager-sync-ops.d.ts +40 -0
  1121. package/dist/plugin-sdk/memory/manager.d.ts +75 -0
  1122. package/dist/plugin-sdk/memory/memory-schema.d.ts +10 -0
  1123. package/dist/plugin-sdk/memory/node-llama.d.ts +8 -0
  1124. package/dist/plugin-sdk/memory/qmd-manager.d.ts +109 -0
  1125. package/dist/plugin-sdk/memory/qmd-query-parser.d.ts +8 -0
  1126. package/dist/plugin-sdk/memory/qmd-scope.d.ts +4 -0
  1127. package/dist/plugin-sdk/memory/search-manager.d.ts +11 -0
  1128. package/dist/plugin-sdk/memory/session-files.d.ts +14 -0
  1129. package/dist/plugin-sdk/memory/sqlite-vec.d.ts +9 -0
  1130. package/dist/plugin-sdk/memory/sqlite.d.ts +1 -0
  1131. package/dist/plugin-sdk/memory/types.d.ts +94 -0
  1132. package/dist/plugin-sdk/pairing/pairing-messages.d.ts +6 -0
  1133. package/dist/plugin-sdk/pairing/pairing-store.d.ts +46 -0
  1134. package/dist/plugin-sdk/pi-model-discovery-Dw3A6oXH.js +37 -0
  1135. package/dist/plugin-sdk/plugin-sdk/account-id.d.ts +1 -0
  1136. package/dist/plugin-sdk/plugin-sdk/allow-from.d.ts +4 -0
  1137. package/dist/plugin-sdk/plugin-sdk/config-paths.d.ts +6 -0
  1138. package/dist/plugin-sdk/plugin-sdk/file-lock.d.ts +16 -0
  1139. package/dist/plugin-sdk/plugin-sdk/index.d.ts +123 -0
  1140. package/dist/plugin-sdk/plugin-sdk/onboarding.d.ts +11 -0
  1141. package/dist/plugin-sdk/plugin-sdk/text-chunking.d.ts +1 -0
  1142. package/dist/plugin-sdk/plugins/bundled-dir.d.ts +1 -0
  1143. package/dist/plugin-sdk/plugins/commands.d.ts +83 -0
  1144. package/dist/plugin-sdk/plugins/config-schema.d.ts +2 -0
  1145. package/dist/plugin-sdk/plugins/config-state.d.ts +33 -0
  1146. package/dist/plugin-sdk/plugins/discovery.d.ts +22 -0
  1147. package/dist/plugin-sdk/plugins/hook-runner-global.d.ts +37 -0
  1148. package/dist/plugin-sdk/plugins/hooks.d.ts +42 -0
  1149. package/dist/plugin-sdk/plugins/http-path.d.ts +1 -0
  1150. package/dist/plugin-sdk/plugins/http-registry.d.ts +13 -0
  1151. package/dist/plugin-sdk/plugins/loader.d.ts +14 -0
  1152. package/dist/plugin-sdk/plugins/manifest-registry.d.ts +33 -0
  1153. package/dist/plugin-sdk/plugins/manifest.d.ts +64 -0
  1154. package/dist/plugin-sdk/plugins/registry.d.ts +130 -0
  1155. package/dist/plugin-sdk/plugins/runtime/index.d.ts +3 -0
  1156. package/dist/plugin-sdk/plugins/runtime/native-deps.d.ts +8 -0
  1157. package/dist/plugin-sdk/plugins/runtime/types.d.ts +317 -0
  1158. package/dist/plugin-sdk/plugins/runtime.d.ts +5 -0
  1159. package/dist/plugin-sdk/plugins/schema-validator.d.ts +10 -0
  1160. package/dist/plugin-sdk/plugins/slots.d.ts +24 -0
  1161. package/dist/plugin-sdk/plugins/tools.d.ts +13 -0
  1162. package/dist/plugin-sdk/plugins/types.d.ts +411 -0
  1163. package/dist/plugin-sdk/polls.d.ts +31 -0
  1164. package/dist/plugin-sdk/process/command-queue.d.ts +51 -0
  1165. package/dist/plugin-sdk/process/exec.d.ts +26 -0
  1166. package/dist/plugin-sdk/process/lanes.d.ts +6 -0
  1167. package/dist/plugin-sdk/process/spawn-utils.d.ts +26 -0
  1168. package/dist/plugin-sdk/providers/github-copilot-token.d.ts +8 -0
  1169. package/dist/plugin-sdk/providers/qwen-portal-oauth.d.ts +8 -0
  1170. package/dist/plugin-sdk/routing/bindings.d.ts +11 -0
  1171. package/dist/plugin-sdk/routing/resolve-route.d.ts +42 -0
  1172. package/dist/plugin-sdk/routing/session-key.d.ts +48 -0
  1173. package/dist/plugin-sdk/runtime.d.ts +7 -0
  1174. package/dist/plugin-sdk/security/external-content.d.ts +67 -0
  1175. package/dist/plugin-sdk/security/secret-equal.d.ts +1 -0
  1176. package/dist/plugin-sdk/sessions/input-provenance.d.ts +16 -0
  1177. package/dist/plugin-sdk/sessions/level-overrides.d.ts +10 -0
  1178. package/dist/plugin-sdk/sessions/model-overrides.d.ts +14 -0
  1179. package/dist/plugin-sdk/sessions/send-policy.d.ts +11 -0
  1180. package/dist/plugin-sdk/sessions/session-key-utils.d.ts +11 -0
  1181. package/dist/plugin-sdk/sessions/session-label.d.ts +9 -0
  1182. package/dist/plugin-sdk/sessions/transcript-events.d.ts +7 -0
  1183. package/dist/plugin-sdk/shared/chat-envelope.d.ts +2 -0
  1184. package/dist/plugin-sdk/shared/config-eval.d.ts +5 -0
  1185. package/dist/plugin-sdk/shared/device-auth.d.ts +13 -0
  1186. package/dist/plugin-sdk/shared/frontmatter.d.ts +7 -0
  1187. package/dist/plugin-sdk/shared/node-match.d.ts +8 -0
  1188. package/dist/plugin-sdk/shared/subagents-format.d.ts +15 -0
  1189. package/dist/plugin-sdk/shared/text/reasoning-tags.d.ts +6 -0
  1190. package/dist/plugin-sdk/signal/accounts.d.ts +9 -0
  1191. package/dist/plugin-sdk/signal/format.d.ts +9 -0
  1192. package/dist/plugin-sdk/signal/identity.d.ts +3 -0
  1193. package/dist/plugin-sdk/signal/index.d.ts +3 -0
  1194. package/dist/plugin-sdk/signal/probe.d.ts +3 -0
  1195. package/dist/plugin-sdk/signal/reaction-level.d.ts +1 -0
  1196. package/dist/plugin-sdk/signal/send-reactions.d.ts +2 -0
  1197. package/dist/plugin-sdk/signal/send.d.ts +1 -0
  1198. package/dist/plugin-sdk/slack/accounts.d.ts +11 -0
  1199. package/dist/plugin-sdk/slack/actions.d.ts +17 -0
  1200. package/dist/plugin-sdk/slack/client.d.ts +1 -0
  1201. package/dist/plugin-sdk/slack/directory-live.d.ts +4 -0
  1202. package/dist/plugin-sdk/slack/index.d.ts +3 -0
  1203. package/dist/plugin-sdk/slack/message-actions.d.ts +2 -0
  1204. package/dist/plugin-sdk/slack/monitor/allow-list.d.ts +1 -0
  1205. package/dist/plugin-sdk/slack/probe.d.ts +3 -0
  1206. package/dist/plugin-sdk/slack/resolve-channels.d.ts +1 -0
  1207. package/dist/plugin-sdk/slack/resolve-users.d.ts +1 -0
  1208. package/dist/plugin-sdk/slack/send.d.ts +5 -0
  1209. package/dist/plugin-sdk/slack/targets.d.ts +2 -0
  1210. package/dist/plugin-sdk/slack/threading-tool-context.d.ts +1 -0
  1211. package/dist/plugin-sdk/telegram/accounts.d.ts +9 -0
  1212. package/dist/plugin-sdk/telegram/audit.d.ts +4 -0
  1213. package/dist/plugin-sdk/telegram/bot/helpers.d.ts +1 -0
  1214. package/dist/plugin-sdk/telegram/bot/types.d.ts +5 -0
  1215. package/dist/plugin-sdk/telegram/inline-buttons.d.ts +2 -0
  1216. package/dist/plugin-sdk/telegram/model-buttons.d.ts +5 -0
  1217. package/dist/plugin-sdk/telegram/monitor.d.ts +3 -0
  1218. package/dist/plugin-sdk/telegram/outbound-params.d.ts +2 -0
  1219. package/dist/plugin-sdk/telegram/probe.d.ts +6 -0
  1220. package/dist/plugin-sdk/telegram/reaction-level.d.ts +1 -0
  1221. package/dist/plugin-sdk/telegram/send.d.ts +10 -0
  1222. package/dist/plugin-sdk/telegram/sticker-cache.d.ts +2 -0
  1223. package/dist/plugin-sdk/telegram/targets.d.ts +1 -0
  1224. package/dist/plugin-sdk/telegram/token.d.ts +1 -0
  1225. package/dist/plugin-sdk/terminal/ansi.d.ts +2 -0
  1226. package/dist/plugin-sdk/terminal/health-style.d.ts +1 -0
  1227. package/dist/plugin-sdk/terminal/links.d.ts +6 -0
  1228. package/dist/plugin-sdk/terminal/palette.d.ts +10 -0
  1229. package/dist/plugin-sdk/terminal/progress-line.d.ts +3 -0
  1230. package/dist/plugin-sdk/terminal/prompt-style.d.ts +3 -0
  1231. package/dist/plugin-sdk/terminal/restore.d.ts +17 -0
  1232. package/dist/plugin-sdk/terminal/theme.d.ts +15 -0
  1233. package/dist/plugin-sdk/tts/tts-core.d.ts +52 -0
  1234. package/dist/plugin-sdk/tts/tts.d.ts +179 -0
  1235. package/dist/plugin-sdk/utils/account-id.d.ts +1 -0
  1236. package/dist/plugin-sdk/utils/boolean.d.ts +5 -0
  1237. package/dist/plugin-sdk/utils/delivery-context.d.ts +29 -0
  1238. package/dist/plugin-sdk/utils/directive-tags.d.ts +16 -0
  1239. package/dist/plugin-sdk/utils/fetch-timeout.d.ts +13 -0
  1240. package/dist/plugin-sdk/utils/message-channel.d.ts +27 -0
  1241. package/dist/plugin-sdk/utils/normalize-secret-input.d.ts +11 -0
  1242. package/dist/plugin-sdk/utils/provider-utils.d.ts +9 -0
  1243. package/dist/plugin-sdk/utils/queue-helpers.d.ts +41 -0
  1244. package/dist/plugin-sdk/utils/shell-argv.d.ts +1 -0
  1245. package/dist/plugin-sdk/utils/transcript-tools.d.ts +8 -0
  1246. package/dist/plugin-sdk/utils/usage-format.d.ts +26 -0
  1247. package/dist/plugin-sdk/utils.d.ts +67 -0
  1248. package/dist/plugin-sdk/version.d.ts +4 -0
  1249. package/dist/plugin-sdk/web/accounts.d.ts +39 -0
  1250. package/dist/plugin-sdk/web/active-listener.d.ts +25 -0
  1251. package/dist/plugin-sdk/web/auth-store.d.ts +25 -0
  1252. package/dist/plugin-sdk/web/auto-reply/constants.d.ts +1 -0
  1253. package/dist/plugin-sdk/web/auto-reply/deliver-reply.d.ts +18 -0
  1254. package/dist/plugin-sdk/web/auto-reply/heartbeat-runner.d.ts +20 -0
  1255. package/dist/plugin-sdk/web/auto-reply/loggers.d.ts +4 -0
  1256. package/dist/plugin-sdk/web/auto-reply/mentions.d.ts +19 -0
  1257. package/dist/plugin-sdk/web/auto-reply/monitor/ack-reaction.d.ts +13 -0
  1258. package/dist/plugin-sdk/web/auto-reply/monitor/broadcast.d.ts +16 -0
  1259. package/dist/plugin-sdk/web/auto-reply/monitor/commands.d.ts +2 -0
  1260. package/dist/plugin-sdk/web/auto-reply/monitor/echo.d.ts +17 -0
  1261. package/dist/plugin-sdk/web/auto-reply/monitor/group-activation.d.ts +9 -0
  1262. package/dist/plugin-sdk/web/auto-reply/monitor/group-gating.d.ts +29 -0
  1263. package/dist/plugin-sdk/web/auto-reply/monitor/group-members.d.ts +6 -0
  1264. package/dist/plugin-sdk/web/auto-reply/monitor/last-route.d.ts +15 -0
  1265. package/dist/plugin-sdk/web/auto-reply/monitor/message-line.d.ts +11 -0
  1266. package/dist/plugin-sdk/web/auto-reply/monitor/on-message.d.ts +24 -0
  1267. package/dist/plugin-sdk/web/auto-reply/monitor/peer.d.ts +2 -0
  1268. package/dist/plugin-sdk/web/auto-reply/monitor/process-message.d.ts +40 -0
  1269. package/dist/plugin-sdk/web/auto-reply/monitor.d.ts +5 -0
  1270. package/dist/plugin-sdk/web/auto-reply/session-snapshot.d.ts +17 -0
  1271. package/dist/plugin-sdk/web/auto-reply/types.d.ts +28 -0
  1272. package/dist/plugin-sdk/web/auto-reply/util.d.ts +2 -0
  1273. package/dist/plugin-sdk/web/auto-reply.d.ts +1 -0
  1274. package/dist/plugin-sdk/web/auto-reply.impl.d.ts +6 -0
  1275. package/dist/plugin-sdk/web/inbound/access-control.d.ts +24 -0
  1276. package/dist/plugin-sdk/web/inbound/dedupe.d.ts +2 -0
  1277. package/dist/plugin-sdk/web/inbound/extract.d.ts +13 -0
  1278. package/dist/plugin-sdk/web/inbound/media.d.ts +7 -0
  1279. package/dist/plugin-sdk/web/inbound/monitor.d.ts +30 -0
  1280. package/dist/plugin-sdk/web/inbound/send-api.d.ts +22 -0
  1281. package/dist/plugin-sdk/web/inbound/types.d.ts +41 -0
  1282. package/dist/plugin-sdk/web/inbound.d.ts +4 -0
  1283. package/dist/plugin-sdk/web/login-qr.d.ts +19 -0
  1284. package/dist/plugin-sdk/web/login.d.ts +3 -0
  1285. package/dist/plugin-sdk/web/media.d.ts +38 -0
  1286. package/dist/plugin-sdk/web/outbound.d.ts +23 -0
  1287. package/dist/plugin-sdk/web/qr-image.d.ts +4 -0
  1288. package/dist/plugin-sdk/web/reconnect.d.ts +12 -0
  1289. package/dist/plugin-sdk/web/session.d.ts +14 -0
  1290. package/dist/plugin-sdk/web/vcard.d.ts +6 -0
  1291. package/dist/plugin-sdk/whatsapp/normalize.d.ts +2 -0
  1292. package/dist/plugin-sdk/whatsapp/resolve-outbound-target.d.ts +1 -0
  1293. package/dist/plugin-sdk/wizard/prompts.d.ts +42 -0
  1294. package/dist/plugin-sdk/wizard/session.d.ts +42 -0
  1295. package/dist/plugins-B362e77G.js +168 -0
  1296. package/dist/plugins-CDJw924T.js +38 -0
  1297. package/dist/plugins-CmSUIUNi.js +38 -0
  1298. package/dist/plugins-cli-CtFRTC2I.js +734 -0
  1299. package/dist/plugins-cli-D1lvqLG9.js +736 -0
  1300. package/dist/polls-CItfB1H8.js +1343 -0
  1301. package/dist/ports-BVLMN1Sr.js +96 -0
  1302. package/dist/ports-CqLSlU6Z.js +317 -0
  1303. package/dist/ports-D94CwCrv.js +344 -0
  1304. package/dist/ports-D_NHthOz.js +96 -0
  1305. package/dist/program-Bve7k4jO.js +176 -0
  1306. package/dist/program-context-8lqacY-M.js +496 -0
  1307. package/dist/program-context-Bvn8046-.js +17 -0
  1308. package/dist/progress-Bek_GyWS.js +133 -0
  1309. package/dist/progress-CbZ2D53A.js +133 -0
  1310. package/dist/prompt-style-DKy6qQxR.js +9 -0
  1311. package/dist/prompt-style-lu0clOOE.js +9 -0
  1312. package/dist/prompts-BI__va99.js +10 -0
  1313. package/dist/prompts-_dDWkCAz.js +10 -0
  1314. package/dist/pw-ai-BLVMuSLv.js +1867 -0
  1315. package/dist/pw-ai-DZJWEF_f.js +1865 -0
  1316. package/dist/pw-ai-dzf-ptcn.js +1868 -0
  1317. package/dist/qmd-manager-B0FWDi1x.js +938 -0
  1318. package/dist/qmd-manager-CrDrpgh3.js +937 -0
  1319. package/dist/qmd-manager-DepEoASu.js +935 -0
  1320. package/dist/queue-2CW7pnm1.js +209 -0
  1321. package/dist/queue-DhjMEG_Q.js +209 -0
  1322. package/dist/redact-BHmk44DI.js +97 -0
  1323. package/dist/redact-ClVwO7Nn.js +97 -0
  1324. package/dist/register.agent-CE_8JbTE.js +265 -0
  1325. package/dist/register.agent-CGRdcftb.js +1003 -0
  1326. package/dist/register.anima-B4NPeesF.js +167 -0
  1327. package/dist/register.anima-hNCtQ_jl.js +167 -0
  1328. package/dist/register.configure-3prVPXwx.js +101 -0
  1329. package/dist/register.configure-Dqm2IveL.js +103 -0
  1330. package/dist/register.maintenance-BSIx4eNS.js +543 -0
  1331. package/dist/register.maintenance-DDeG6CHa.js +543 -0
  1332. package/dist/register.message-DcYPDzYr.js +657 -0
  1333. package/dist/register.message-RbFrjbch.js +660 -0
  1334. package/dist/register.onboard-BBJK_0_C.js +170 -0
  1335. package/dist/register.onboard-BrcWHC9j.js +170 -0
  1336. package/dist/register.setup-ByvEHxYQ.js +175 -0
  1337. package/dist/register.setup-CNwO5Yq3.js +175 -0
  1338. package/dist/register.status-health-sessions-CGT7bn4C.js +142 -0
  1339. package/dist/register.status-health-sessions-QK6iQSJc.js +313 -0
  1340. package/dist/register.subclis-Bd8eE94r.js +255 -0
  1341. package/dist/registry-BiekeB9q.js +116 -0
  1342. package/dist/registry-qI6V4gqU.js +116 -0
  1343. package/dist/reply-Clj5jcM5.js +32212 -0
  1344. package/dist/reply-DnH1Ueoz.js +32212 -0
  1345. package/dist/reply-prefix-D2NxVzGZ.js +100 -0
  1346. package/dist/reply-prefix-DPpz_mEi.js +100 -0
  1347. package/dist/requirements-BzZxj2Wu.js +107 -0
  1348. package/dist/requirements-DIW1svgA.js +107 -0
  1349. package/dist/rolldown-runtime-Cbj13DAv.js +20 -0
  1350. package/dist/routes-CXpne1-p.js +1820 -0
  1351. package/dist/routes-DtRwwTy6.js +1820 -0
  1352. package/dist/rpc-BBB_Fbes.js +70 -0
  1353. package/dist/rpc-CMEWfcci.js +70 -0
  1354. package/dist/run-main-DOXNrnL2.js +371 -0
  1355. package/dist/runtime-guard-BSUFiAQV.js +60 -0
  1356. package/dist/runtime-guard-DeOXA_86.js +60 -0
  1357. package/dist/sandbox-Bk0ZXcag.js +859 -0
  1358. package/dist/sandbox-D3CFkNeF.js +858 -0
  1359. package/dist/sandbox-cli-BCnnmQ03.js +458 -0
  1360. package/dist/sandbox-cli-Ctpa2Isy.js +461 -0
  1361. package/dist/secret-equal-B268kALC.js +13 -0
  1362. package/dist/secret-equal-Dghy3xsA.js +13 -0
  1363. package/dist/security-cli-BiiLLcQV.js +462 -0
  1364. package/dist/security-cli-DOZmLENS.js +465 -0
  1365. package/dist/send-BTA6qupx.js +10 -0
  1366. package/dist/send-BhAfdGII.js +10 -0
  1367. package/dist/send-C2t9xpXI.js +10 -0
  1368. package/dist/send-C6ccOW_U.js +10 -0
  1369. package/dist/send-CP74DxzJ.js +28 -0
  1370. package/dist/send-CS3G_YWr.js +10 -0
  1371. package/dist/send-D5JnqErc.js +10 -0
  1372. package/dist/send-DEMhcauI.js +32 -0
  1373. package/dist/send-DF8KJImx.js +28 -0
  1374. package/dist/send-DVW0CcHX.js +32 -0
  1375. package/dist/send-DigO-i9j.js +28 -0
  1376. package/dist/send-DqMLjD9Z.js +10 -0
  1377. package/dist/send-Dz2BDHll.js +32 -0
  1378. package/dist/send-ga9udK1_.js +10 -0
  1379. package/dist/send-oDz9NATu.js +10 -0
  1380. package/dist/server-context-BznDS2td.js +824 -0
  1381. package/dist/server-context-CXnE2F7d.js +824 -0
  1382. package/dist/server-node-events-Cu6Qkjor.js +231 -0
  1383. package/dist/server-node-events-Cv8MuF1g.js +233 -0
  1384. package/dist/service-BNVpYcQe.js +642 -0
  1385. package/dist/service-D56aMXUB.js +642 -0
  1386. package/dist/service-audit-DBsygs7y.js +488 -0
  1387. package/dist/service-audit-DKWJcTu4.js +488 -0
  1388. package/dist/session-CXcl3Xrp.js +181 -0
  1389. package/dist/session-DUFuU29j.js +179 -0
  1390. package/dist/session-M_uCxF0U.js +181 -0
  1391. package/dist/session-cost-usage-BwiTZuKl.js +600 -0
  1392. package/dist/session-cost-usage-DT9YNXTJ.js +600 -0
  1393. package/dist/session-key-BGiG_JcT.js +198 -0
  1394. package/dist/session-key-DxcgHezu.js +198 -0
  1395. package/dist/sessions-B8GUAiF6.js +1296 -0
  1396. package/dist/sessions-D0Zd1CND.js +1296 -0
  1397. package/dist/sessions-D0spLCm7.js +187 -0
  1398. package/dist/sessions-XvkHLXt4.js +2038 -0
  1399. package/dist/shared-CEHU0exQ.js +77 -0
  1400. package/dist/shared-Cgly1vPb.js +66 -0
  1401. package/dist/shared-DAHxpviD.js +77 -0
  1402. package/dist/shared-JOo05hST.js +66 -0
  1403. package/dist/shell-argv-CAq1mLa2.js +72 -0
  1404. package/dist/shell-argv-Ce41guJv.js +72 -0
  1405. package/dist/skill-scanner-CkaVLABv.js +263 -0
  1406. package/dist/skill-scanner-Coo4QoCd.js +263 -0
  1407. package/dist/skills-B-G7UHOa.js +808 -0
  1408. package/dist/skills-B5LQx4lT.js +807 -0
  1409. package/dist/skills-cli-DF9XJ2_0.js +286 -0
  1410. package/dist/skills-cli-eLBluVoD.js +289 -0
  1411. package/dist/skills-status-Clq9ZnYu.js +166 -0
  1412. package/dist/skills-status-JQluhU-P.js +166 -0
  1413. package/dist/sqlite-BukcjdJa.js +321 -0
  1414. package/dist/sqlite-CGcOZZ0C.js +368 -0
  1415. package/dist/sqlite-Ck6f9KWc.js +453 -0
  1416. package/dist/start-BvsoGNHJ.js +354 -0
  1417. package/dist/start-CF_Cp6YC.js +353 -0
  1418. package/dist/status-BKGJ7VPQ.js +27 -0
  1419. package/dist/status-BZip7mx9.js +27 -0
  1420. package/dist/status-BqYq_J5J.js +2132 -0
  1421. package/dist/status-CMnlcBVc.js +21 -0
  1422. package/dist/status-CXQrTLri.js +2137 -0
  1423. package/dist/status-tDZPwewW.js +21 -0
  1424. package/dist/status.update-CWiod7o_.js +79 -0
  1425. package/dist/status.update-D1PyrhoB.js +79 -0
  1426. package/dist/subagent-registry-CpSZ2RSO.js +2760 -0
  1427. package/dist/subagent-registry-DkCXRdwf.js +2759 -0
  1428. package/dist/subagent-registry-MPrTYaEB.js +14 -0
  1429. package/dist/subsystem-Dowf8fSU.js +860 -0
  1430. package/dist/system-cli-4Urk9KV1.js +79 -0
  1431. package/dist/system-cli-CgMzkg8R.js +82 -0
  1432. package/dist/system-run-command-DGk7dwQP.js +93 -0
  1433. package/dist/system-run-command-X9lDJIy0.js +93 -0
  1434. package/dist/systemd-BSrHDyeU.js +452 -0
  1435. package/dist/systemd-By5xdSB4.js +452 -0
  1436. package/dist/systemd-hints-BtjL_5Rh.js +36 -0
  1437. package/dist/systemd-hints-sJmr6cjb.js +36 -0
  1438. package/dist/systemd-linger-BNz8PXPF.js +75 -0
  1439. package/dist/systemd-linger-D5vLilKH.js +75 -0
  1440. package/dist/table-BL0lJzsm.js +279 -0
  1441. package/dist/table-DoiRPsn0.js +279 -0
  1442. package/dist/tailnet-CuiNECdL.js +42 -0
  1443. package/dist/tailnet-__ODlBOT.js +42 -0
  1444. package/dist/templates-DJ0ii6X2.js +47 -0
  1445. package/dist/templates-DPTs18po.js +47 -0
  1446. package/dist/thinking-BLU0jXR8.js +204 -0
  1447. package/dist/thinking-BXEswx1X.js +204 -0
  1448. package/dist/timeout-CswI_K-U.js +232 -0
  1449. package/dist/tokens-C-X7wDKj.js +14 -0
  1450. package/dist/tokens-DkvqA72p.js +14 -0
  1451. package/dist/transcript-events-C1hdue6u.js +17 -0
  1452. package/dist/transcript-events-C8Tqw4td.js +17 -0
  1453. package/dist/transcript-events-DW_H__a1.js +17 -0
  1454. package/dist/transcript-tools-DtE5di1q.js +108 -0
  1455. package/dist/transcript-tools-DuyYOkUq.js +108 -0
  1456. package/dist/trash-BJLK1vMn.js +23 -0
  1457. package/dist/trash-_x5UZ94k.js +23 -0
  1458. package/dist/tui-Cj25a9wc.js +3894 -0
  1459. package/dist/tui-Iv4T-9gg.js +3894 -0
  1460. package/dist/tui-cli-BkJxFa_n.js +50 -0
  1461. package/dist/tui-cli-DeFmBtZ7.js +47 -0
  1462. package/dist/update-DZRKbMjq.js +317 -0
  1463. package/dist/update-LFgxHHPd.js +317 -0
  1464. package/dist/update-check-CWc7YXmc.js +400 -0
  1465. package/dist/update-check-IhlWaui6.js +400 -0
  1466. package/dist/update-cli-qGGlL5Lg.js +1105 -0
  1467. package/dist/update-cli-rMqhSUMc.js +1105 -0
  1468. package/dist/update-runner-BT77y3bz.js +894 -0
  1469. package/dist/update-runner-DvzFqFJf.js +894 -0
  1470. package/dist/usage-BeZuVAY4.js +4516 -0
  1471. package/dist/usage-format-BAirWUSO.js +36 -0
  1472. package/dist/usage-format-CpORtVCG.js +36 -0
  1473. package/dist/utils-Bsw__U-F.js +243 -0
  1474. package/dist/utils-C9sj30YY.js +239 -0
  1475. package/dist/warning-filter.js +48 -0
  1476. package/dist/web-DEx7MMYq.js +2203 -0
  1477. package/dist/web-DHSoj6bL.js +46842 -0
  1478. package/dist/web-DI0g5K4c.js +63 -0
  1479. package/dist/webhooks-cli-sfLRE89X.js +319 -0
  1480. package/dist/webhooks-cli-xtZBlaD1.js +316 -0
  1481. package/dist/whatsapp-actions-DIREhxrq.js +49 -0
  1482. package/dist/whatsapp-actions-TGHl9p4i.js +45 -0
  1483. package/dist/whatsapp-actions-dBHozeuk.js +53 -0
  1484. package/dist/widearea-dns-B6ocX23x.js +127 -0
  1485. package/dist/widearea-dns-NsEUNYwz.js +127 -0
  1486. package/dist/workspace-Dcfoy5JJ.js +649 -0
  1487. package/dist/ws-COSqlEPx.js +218 -0
  1488. package/dist/ws-log-N8R5MvGE.js +267 -0
  1489. package/dist/ws-log-gwFxPxj5.js +267 -0
  1490. package/dist/wsl-CqyuRvtM.js +26 -0
  1491. package/dist/wsl-ymJYvc9Q.js +26 -0
  1492. package/package.json +209 -0
  1493. package/skills/1password/SKILL.md +70 -0
  1494. package/skills/1password/references/cli-examples.md +29 -0
  1495. package/skills/1password/references/get-started.md +17 -0
  1496. package/skills/animahub/SKILL.md +77 -0
  1497. package/skills/apple-notes/SKILL.md +77 -0
  1498. package/skills/apple-reminders/SKILL.md +96 -0
  1499. package/skills/audit/SKILL.md +68 -0
  1500. package/skills/bear-notes/SKILL.md +107 -0
  1501. package/skills/blogwatcher/SKILL.md +69 -0
  1502. package/skills/blucli/SKILL.md +47 -0
  1503. package/skills/bluebubbles/SKILL.md +131 -0
  1504. package/skills/camsnap/SKILL.md +45 -0
  1505. package/skills/canvas/SKILL.md +198 -0
  1506. package/skills/coding-agent/SKILL.md +284 -0
  1507. package/skills/deploy/SKILL.md +45 -0
  1508. package/skills/discord/SKILL.md +160 -0
  1509. package/skills/eightctl/SKILL.md +50 -0
  1510. package/skills/food-order/SKILL.md +48 -0
  1511. package/skills/gemini/SKILL.md +43 -0
  1512. package/skills/gifgrep/SKILL.md +79 -0
  1513. package/skills/github/SKILL.md +77 -0
  1514. package/skills/gog/SKILL.md +116 -0
  1515. package/skills/goplaces/SKILL.md +52 -0
  1516. package/skills/healthcheck/SKILL.md +245 -0
  1517. package/skills/himalaya/SKILL.md +257 -0
  1518. package/skills/himalaya/references/configuration.md +184 -0
  1519. package/skills/himalaya/references/message-composition.md +199 -0
  1520. package/skills/imsg/SKILL.md +74 -0
  1521. package/skills/mcporter/SKILL.md +61 -0
  1522. package/skills/model-usage/SKILL.md +69 -0
  1523. package/skills/model-usage/references/codexbar-cli.md +33 -0
  1524. package/skills/model-usage/scripts/model_usage.py +310 -0
  1525. package/skills/nano-banana-pro/SKILL.md +58 -0
  1526. package/skills/nano-banana-pro/scripts/generate_image.py +184 -0
  1527. package/skills/nano-pdf/SKILL.md +38 -0
  1528. package/skills/notion/SKILL.md +172 -0
  1529. package/skills/obsidian/SKILL.md +81 -0
  1530. package/skills/openai-image-gen/SKILL.md +89 -0
  1531. package/skills/openai-image-gen/scripts/gen.py +240 -0
  1532. package/skills/openai-whisper/SKILL.md +38 -0
  1533. package/skills/openai-whisper-api/SKILL.md +52 -0
  1534. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  1535. package/skills/openhue/SKILL.md +51 -0
  1536. package/skills/oracle/SKILL.md +125 -0
  1537. package/skills/ordercli/SKILL.md +78 -0
  1538. package/skills/peekaboo/SKILL.md +190 -0
  1539. package/skills/review/SKILL.md +58 -0
  1540. package/skills/sag/SKILL.md +87 -0
  1541. package/skills/session-logs/SKILL.md +115 -0
  1542. package/skills/sherpa-onnx-tts/SKILL.md +103 -0
  1543. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  1544. package/skills/skill-creator/SKILL.md +370 -0
  1545. package/skills/skill-creator/license.txt +202 -0
  1546. package/skills/skill-creator/scripts/init_skill.py +378 -0
  1547. package/skills/skill-creator/scripts/package_skill.py +111 -0
  1548. package/skills/skill-creator/scripts/quick_validate.py +101 -0
  1549. package/skills/slack/SKILL.md +144 -0
  1550. package/skills/songsee/SKILL.md +49 -0
  1551. package/skills/sonoscli/SKILL.md +46 -0
  1552. package/skills/spotify-player/SKILL.md +64 -0
  1553. package/skills/summarize/SKILL.md +87 -0
  1554. package/skills/things-mac/SKILL.md +86 -0
  1555. package/skills/tmux/SKILL.md +135 -0
  1556. package/skills/tmux/scripts/find-sessions.sh +112 -0
  1557. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  1558. package/skills/trello/SKILL.md +95 -0
  1559. package/skills/video-frames/SKILL.md +46 -0
  1560. package/skills/video-frames/scripts/frame.sh +81 -0
  1561. package/skills/voice-call/SKILL.md +45 -0
  1562. package/skills/wacli/SKILL.md +72 -0
  1563. package/skills/weather/SKILL.md +54 -0
  1564. package/templates/BRAIN.md +65 -0
  1565. package/templates/GUT.md +44 -0
  1566. package/templates/HEART.md +51 -0
  1567. package/templates/MEMORY.md +66 -0
  1568. package/templates/SHADOW.md +68 -0
  1569. package/templates/SOUL.md +38 -0
  1570. package/templates/SPIRIT.md +43 -0
@@ -0,0 +1,2690 @@
1
+ import { t as __exportAll } from "./rolldown-runtime-Cbj13DAv.js";
2
+ import { $ as resolveStateDir, Q as resolveOAuthPath, n as isTruthyEnvValue, o as createSubsystemLogger } from "./entry.js";
3
+ import { t as formatCliCommand } from "./command-format-Clp46jkj.js";
4
+ import { n as DEFAULT_AGENT_ID } from "./session-key-BGiG_JcT.js";
5
+ import { y as resolveUserPath } from "./utils-C9sj30YY.js";
6
+ import { a as resolveAgentModelPrimary } from "./agent-scope-OZi7lb8S.js";
7
+ import { execFileSync, execSync } from "node:child_process";
8
+ import path from "node:path";
9
+ import fs from "node:fs";
10
+ import fs$1 from "node:fs/promises";
11
+ import "@aws-sdk/client-bedrock";
12
+ import { getEnvApiKey, getOAuthApiKey, getOAuthProviders } from "@mariozechner/pi-ai";
13
+ import { createHash, randomBytes, randomUUID } from "node:crypto";
14
+
15
+ //#region src/agents/auth-profiles/constants.ts
16
+ const AUTH_STORE_VERSION = 1;
17
+ const AUTH_PROFILE_FILENAME = "auth-profiles.json";
18
+ const LEGACY_AUTH_FILENAME = "auth.json";
19
+ const CLAUDE_CLI_PROFILE_ID = "anthropic:claude-cli";
20
+ const CODEX_CLI_PROFILE_ID = "openai-codex:codex-cli";
21
+ const QWEN_CLI_PROFILE_ID = "qwen-portal:qwen-cli";
22
+ const MINIMAX_CLI_PROFILE_ID = "minimax-portal:minimax-cli";
23
+ const AUTH_STORE_LOCK_OPTIONS = {
24
+ retries: {
25
+ retries: 10,
26
+ factor: 2,
27
+ minTimeout: 100,
28
+ maxTimeout: 1e4,
29
+ randomize: true
30
+ },
31
+ stale: 3e4
32
+ };
33
+ const EXTERNAL_CLI_SYNC_TTL_MS = 900 * 1e3;
34
+ const EXTERNAL_CLI_NEAR_EXPIRY_MS = 600 * 1e3;
35
+ const log$1 = createSubsystemLogger("agents/auth-profiles");
36
+
37
+ //#endregion
38
+ //#region src/agents/auth-profiles/display.ts
39
+ function resolveAuthProfileDisplayLabel(params) {
40
+ const { cfg, store, profileId } = params;
41
+ const profile = store.profiles[profileId];
42
+ const email = cfg?.auth?.profiles?.[profileId]?.email?.trim() || (profile && "email" in profile ? profile.email?.trim() : void 0);
43
+ if (email) return `${profileId} (${email})`;
44
+ return profileId;
45
+ }
46
+
47
+ //#endregion
48
+ //#region src/agents/defaults.ts
49
+ const DEFAULT_PROVIDER = "anthropic";
50
+ const DEFAULT_MODEL = "claude-opus-4-6";
51
+ const DEFAULT_CONTEXT_TOKENS = 2e5;
52
+
53
+ //#endregion
54
+ //#region src/agents/cloudflare-ai-gateway.ts
55
+ const CLOUDFLARE_AI_GATEWAY_PROVIDER_ID = "cloudflare-ai-gateway";
56
+ const CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_ID = "claude-sonnet-4-5";
57
+ const CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF = `${CLOUDFLARE_AI_GATEWAY_PROVIDER_ID}/${CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_ID}`;
58
+ const CLOUDFLARE_AI_GATEWAY_DEFAULT_CONTEXT_WINDOW = 2e5;
59
+ const CLOUDFLARE_AI_GATEWAY_DEFAULT_MAX_TOKENS = 64e3;
60
+ const CLOUDFLARE_AI_GATEWAY_DEFAULT_COST = {
61
+ input: 3,
62
+ output: 15,
63
+ cacheRead: .3,
64
+ cacheWrite: 3.75
65
+ };
66
+ function buildCloudflareAiGatewayModelDefinition(params) {
67
+ return {
68
+ id: params?.id?.trim() || CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_ID,
69
+ name: params?.name ?? "Claude Sonnet 4.5",
70
+ reasoning: params?.reasoning ?? true,
71
+ input: params?.input ?? ["text", "image"],
72
+ cost: CLOUDFLARE_AI_GATEWAY_DEFAULT_COST,
73
+ contextWindow: CLOUDFLARE_AI_GATEWAY_DEFAULT_CONTEXT_WINDOW,
74
+ maxTokens: CLOUDFLARE_AI_GATEWAY_DEFAULT_MAX_TOKENS
75
+ };
76
+ }
77
+ function resolveCloudflareAiGatewayBaseUrl(params) {
78
+ const accountId = params.accountId.trim();
79
+ const gatewayId = params.gatewayId.trim();
80
+ if (!accountId || !gatewayId) return "";
81
+ return `https://gateway.ai.cloudflare.com/v1/${accountId}/${gatewayId}/anthropic`;
82
+ }
83
+
84
+ //#endregion
85
+ //#region src/agents/huggingface-models.ts
86
+ /** Hugging Face Inference Providers (router) — OpenAI-compatible chat completions. */
87
+ const HUGGINGFACE_BASE_URL = "https://router.huggingface.co/v1";
88
+ /** Router policy suffixes: router picks backend by cost or speed; no specific provider selection. */
89
+ const HUGGINGFACE_POLICY_SUFFIXES = ["cheapest", "fastest"];
90
+ /**
91
+ * True when the model ref uses :cheapest or :fastest. When true, provider choice is locked
92
+ * (router decides); do not show an interactive "prefer specific backend" option.
93
+ */
94
+ function isHuggingfacePolicyLocked(modelRef) {
95
+ const ref = String(modelRef).trim();
96
+ return HUGGINGFACE_POLICY_SUFFIXES.some((s) => ref.endsWith(`:${s}`) || ref === s);
97
+ }
98
+ /** Default cost when not in static catalog (HF pricing varies by provider). */
99
+ const HUGGINGFACE_DEFAULT_COST = {
100
+ input: 0,
101
+ output: 0,
102
+ cacheRead: 0,
103
+ cacheWrite: 0
104
+ };
105
+ /** Defaults for models discovered from GET /v1/models. */
106
+ const HUGGINGFACE_DEFAULT_CONTEXT_WINDOW = 131072;
107
+ const HUGGINGFACE_DEFAULT_MAX_TOKENS = 8192;
108
+ const HUGGINGFACE_MODEL_CATALOG = [
109
+ {
110
+ id: "deepseek-ai/DeepSeek-R1",
111
+ name: "DeepSeek R1",
112
+ reasoning: true,
113
+ input: ["text"],
114
+ contextWindow: 131072,
115
+ maxTokens: 8192,
116
+ cost: {
117
+ input: 3,
118
+ output: 7,
119
+ cacheRead: 3,
120
+ cacheWrite: 3
121
+ }
122
+ },
123
+ {
124
+ id: "deepseek-ai/DeepSeek-V3.1",
125
+ name: "DeepSeek V3.1",
126
+ reasoning: false,
127
+ input: ["text"],
128
+ contextWindow: 131072,
129
+ maxTokens: 8192,
130
+ cost: {
131
+ input: .6,
132
+ output: 1.25,
133
+ cacheRead: .6,
134
+ cacheWrite: .6
135
+ }
136
+ },
137
+ {
138
+ id: "meta-llama/Llama-3.3-70B-Instruct-Turbo",
139
+ name: "Llama 3.3 70B Instruct Turbo",
140
+ reasoning: false,
141
+ input: ["text"],
142
+ contextWindow: 131072,
143
+ maxTokens: 8192,
144
+ cost: {
145
+ input: .88,
146
+ output: .88,
147
+ cacheRead: .88,
148
+ cacheWrite: .88
149
+ }
150
+ },
151
+ {
152
+ id: "openai/gpt-oss-120b",
153
+ name: "GPT-OSS 120B",
154
+ reasoning: false,
155
+ input: ["text"],
156
+ contextWindow: 131072,
157
+ maxTokens: 8192,
158
+ cost: {
159
+ input: 0,
160
+ output: 0,
161
+ cacheRead: 0,
162
+ cacheWrite: 0
163
+ }
164
+ }
165
+ ];
166
+ function buildHuggingfaceModelDefinition(model) {
167
+ return {
168
+ id: model.id,
169
+ name: model.name,
170
+ reasoning: model.reasoning,
171
+ input: model.input,
172
+ cost: model.cost,
173
+ contextWindow: model.contextWindow,
174
+ maxTokens: model.maxTokens
175
+ };
176
+ }
177
+ /**
178
+ * Infer reasoning and display name from Hub-style model id (e.g. "deepseek-ai/DeepSeek-R1").
179
+ */
180
+ function inferredMetaFromModelId(id) {
181
+ const base = id.split("/").pop() ?? id;
182
+ const reasoning = /r1|reasoning|thinking|reason/i.test(id) || /-\d+[tb]?-thinking/i.test(base);
183
+ return {
184
+ name: base.replace(/-/g, " ").replace(/\b(\w)/g, (c) => c.toUpperCase()),
185
+ reasoning
186
+ };
187
+ }
188
+ /** Prefer API-supplied display name, then owned_by/id, then inferred from id. */
189
+ function displayNameFromApiEntry(entry, inferredName) {
190
+ const fromApi = typeof entry.name === "string" && entry.name.trim() || typeof entry.title === "string" && entry.title.trim() || typeof entry.display_name === "string" && entry.display_name.trim();
191
+ if (fromApi) return fromApi;
192
+ if (typeof entry.owned_by === "string" && entry.owned_by.trim()) {
193
+ const base = entry.id.split("/").pop() ?? entry.id;
194
+ return `${entry.owned_by.trim()}/${base}`;
195
+ }
196
+ return inferredName;
197
+ }
198
+ /**
199
+ * Discover chat-completion models from Hugging Face Inference Providers (GET /v1/models).
200
+ * Requires a valid HF token. Falls back to static catalog on failure or in test env.
201
+ */
202
+ async function discoverHuggingfaceModels(apiKey) {
203
+ if (process.env.VITEST === "true" || false) return HUGGINGFACE_MODEL_CATALOG.map(buildHuggingfaceModelDefinition);
204
+ const trimmedKey = apiKey?.trim();
205
+ if (!trimmedKey) return HUGGINGFACE_MODEL_CATALOG.map(buildHuggingfaceModelDefinition);
206
+ try {
207
+ const response = await fetch(`${HUGGINGFACE_BASE_URL}/models`, {
208
+ signal: AbortSignal.timeout(1e4),
209
+ headers: {
210
+ Authorization: `Bearer ${trimmedKey}`,
211
+ "Content-Type": "application/json"
212
+ }
213
+ });
214
+ if (!response.ok) {
215
+ console.warn(`[huggingface-models] GET /v1/models failed: HTTP ${response.status}, using static catalog`);
216
+ return HUGGINGFACE_MODEL_CATALOG.map(buildHuggingfaceModelDefinition);
217
+ }
218
+ const data = (await response.json())?.data;
219
+ if (!Array.isArray(data) || data.length === 0) {
220
+ console.warn("[huggingface-models] No models in response, using static catalog");
221
+ return HUGGINGFACE_MODEL_CATALOG.map(buildHuggingfaceModelDefinition);
222
+ }
223
+ const catalogById = new Map(HUGGINGFACE_MODEL_CATALOG.map((m) => [m.id, m]));
224
+ const seen = /* @__PURE__ */ new Set();
225
+ const models = [];
226
+ for (const entry of data) {
227
+ const id = typeof entry?.id === "string" ? entry.id.trim() : "";
228
+ if (!id || seen.has(id)) continue;
229
+ seen.add(id);
230
+ const catalogEntry = catalogById.get(id);
231
+ if (catalogEntry) models.push(buildHuggingfaceModelDefinition(catalogEntry));
232
+ else {
233
+ const inferred = inferredMetaFromModelId(id);
234
+ const name = displayNameFromApiEntry(entry, inferred.name);
235
+ const modalities = entry.architecture?.input_modalities;
236
+ const input = Array.isArray(modalities) && modalities.includes("image") ? ["text", "image"] : ["text"];
237
+ const contextLength = (Array.isArray(entry.providers) ? entry.providers : []).find((p) => typeof p?.context_length === "number" && p.context_length > 0)?.context_length ?? HUGGINGFACE_DEFAULT_CONTEXT_WINDOW;
238
+ models.push({
239
+ id,
240
+ name,
241
+ reasoning: inferred.reasoning,
242
+ input,
243
+ cost: HUGGINGFACE_DEFAULT_COST,
244
+ contextWindow: contextLength,
245
+ maxTokens: HUGGINGFACE_DEFAULT_MAX_TOKENS
246
+ });
247
+ }
248
+ }
249
+ return models.length > 0 ? models : HUGGINGFACE_MODEL_CATALOG.map(buildHuggingfaceModelDefinition);
250
+ } catch (error) {
251
+ console.warn(`[huggingface-models] Discovery failed: ${String(error)}, using static catalog`);
252
+ return HUGGINGFACE_MODEL_CATALOG.map(buildHuggingfaceModelDefinition);
253
+ }
254
+ }
255
+
256
+ //#endregion
257
+ //#region src/infra/shell-env.ts
258
+ const DEFAULT_TIMEOUT_MS = 15e3;
259
+ const DEFAULT_MAX_BUFFER_BYTES = 2 * 1024 * 1024;
260
+ let lastAppliedKeys = [];
261
+ let cachedShellPath;
262
+ function resolveShell(env) {
263
+ const shell = env.SHELL?.trim();
264
+ return shell && shell.length > 0 ? shell : "/bin/sh";
265
+ }
266
+ function parseShellEnv(stdout) {
267
+ const shellEnv = /* @__PURE__ */ new Map();
268
+ const parts = stdout.toString("utf8").split("\0");
269
+ for (const part of parts) {
270
+ if (!part) continue;
271
+ const eq = part.indexOf("=");
272
+ if (eq <= 0) continue;
273
+ const key = part.slice(0, eq);
274
+ const value = part.slice(eq + 1);
275
+ if (!key) continue;
276
+ shellEnv.set(key, value);
277
+ }
278
+ return shellEnv;
279
+ }
280
+ function loadShellEnvFallback(opts) {
281
+ const logger = opts.logger ?? console;
282
+ const exec = opts.exec ?? execFileSync;
283
+ if (!opts.enabled) {
284
+ lastAppliedKeys = [];
285
+ return {
286
+ ok: true,
287
+ applied: [],
288
+ skippedReason: "disabled"
289
+ };
290
+ }
291
+ if (opts.expectedKeys.some((key) => Boolean(opts.env[key]?.trim()))) {
292
+ lastAppliedKeys = [];
293
+ return {
294
+ ok: true,
295
+ applied: [],
296
+ skippedReason: "already-has-keys"
297
+ };
298
+ }
299
+ const timeoutMs = typeof opts.timeoutMs === "number" && Number.isFinite(opts.timeoutMs) ? Math.max(0, opts.timeoutMs) : DEFAULT_TIMEOUT_MS;
300
+ const shell = resolveShell(opts.env);
301
+ let stdout;
302
+ try {
303
+ stdout = exec(shell, [
304
+ "-l",
305
+ "-c",
306
+ "env -0"
307
+ ], {
308
+ encoding: "buffer",
309
+ timeout: timeoutMs,
310
+ maxBuffer: DEFAULT_MAX_BUFFER_BYTES,
311
+ env: opts.env,
312
+ stdio: [
313
+ "ignore",
314
+ "pipe",
315
+ "pipe"
316
+ ]
317
+ });
318
+ } catch (err) {
319
+ const msg = err instanceof Error ? err.message : String(err);
320
+ logger.warn(`[anima] shell env fallback failed: ${msg}`);
321
+ lastAppliedKeys = [];
322
+ return {
323
+ ok: false,
324
+ error: msg,
325
+ applied: []
326
+ };
327
+ }
328
+ const shellEnv = parseShellEnv(stdout);
329
+ const applied = [];
330
+ for (const key of opts.expectedKeys) {
331
+ if (opts.env[key]?.trim()) continue;
332
+ const value = shellEnv.get(key);
333
+ if (!value?.trim()) continue;
334
+ opts.env[key] = value;
335
+ applied.push(key);
336
+ }
337
+ lastAppliedKeys = applied;
338
+ return {
339
+ ok: true,
340
+ applied
341
+ };
342
+ }
343
+ function shouldEnableShellEnvFallback(env) {
344
+ return isTruthyEnvValue(env.ANIMA_LOAD_SHELL_ENV);
345
+ }
346
+ function shouldDeferShellEnvFallback(env) {
347
+ return isTruthyEnvValue(env.ANIMA_DEFER_SHELL_ENV_FALLBACK);
348
+ }
349
+ function resolveShellEnvFallbackTimeoutMs(env) {
350
+ const raw = env.ANIMA_SHELL_ENV_TIMEOUT_MS?.trim();
351
+ if (!raw) return DEFAULT_TIMEOUT_MS;
352
+ const parsed = Number.parseInt(raw, 10);
353
+ if (!Number.isFinite(parsed)) return DEFAULT_TIMEOUT_MS;
354
+ return Math.max(0, parsed);
355
+ }
356
+ function getShellPathFromLoginShell(opts) {
357
+ if (cachedShellPath !== void 0) return cachedShellPath;
358
+ if (process.platform === "win32") {
359
+ cachedShellPath = null;
360
+ return cachedShellPath;
361
+ }
362
+ const exec = opts.exec ?? execFileSync;
363
+ const timeoutMs = typeof opts.timeoutMs === "number" && Number.isFinite(opts.timeoutMs) ? Math.max(0, opts.timeoutMs) : DEFAULT_TIMEOUT_MS;
364
+ const shell = resolveShell(opts.env);
365
+ let stdout;
366
+ try {
367
+ stdout = exec(shell, [
368
+ "-l",
369
+ "-c",
370
+ "env -0"
371
+ ], {
372
+ encoding: "buffer",
373
+ timeout: timeoutMs,
374
+ maxBuffer: DEFAULT_MAX_BUFFER_BYTES,
375
+ env: opts.env,
376
+ stdio: [
377
+ "ignore",
378
+ "pipe",
379
+ "pipe"
380
+ ]
381
+ });
382
+ } catch {
383
+ cachedShellPath = null;
384
+ return cachedShellPath;
385
+ }
386
+ const shellPath = parseShellEnv(stdout).get("PATH")?.trim();
387
+ cachedShellPath = shellPath && shellPath.length > 0 ? shellPath : null;
388
+ return cachedShellPath;
389
+ }
390
+ function getShellEnvAppliedKeys() {
391
+ return [...lastAppliedKeys];
392
+ }
393
+
394
+ //#endregion
395
+ //#region src/utils/normalize-secret-input.ts
396
+ /**
397
+ * Secret normalization for copy/pasted credentials.
398
+ *
399
+ * Common footgun: line breaks (especially `\r`) embedded in API keys/tokens.
400
+ * We strip line breaks anywhere, then trim whitespace at the ends.
401
+ *
402
+ * Intentionally does NOT remove ordinary spaces inside the string to avoid
403
+ * silently altering "Bearer <token>" style values.
404
+ */
405
+ function normalizeSecretInput(value) {
406
+ if (typeof value !== "string") return "";
407
+ return value.replace(/[\r\n\u2028\u2029]+/g, "").trim();
408
+ }
409
+ function normalizeOptionalSecretInput(value) {
410
+ const normalized = normalizeSecretInput(value);
411
+ return normalized ? normalized : void 0;
412
+ }
413
+
414
+ //#endregion
415
+ //#region src/agents/model-auth.ts
416
+ const AWS_BEARER_ENV = "AWS_BEARER_TOKEN_BEDROCK";
417
+ const AWS_ACCESS_KEY_ENV = "AWS_ACCESS_KEY_ID";
418
+ const AWS_SECRET_KEY_ENV = "AWS_SECRET_ACCESS_KEY";
419
+ const AWS_PROFILE_ENV = "AWS_PROFILE";
420
+ function resolveProviderConfig(cfg, provider) {
421
+ const providers = cfg?.models?.providers ?? {};
422
+ const direct = providers[provider];
423
+ if (direct) return direct;
424
+ const normalized = normalizeProviderId(provider);
425
+ if (normalized === provider) return Object.entries(providers).find(([key]) => normalizeProviderId(key) === normalized)?.[1];
426
+ return providers[normalized] ?? Object.entries(providers).find(([key]) => normalizeProviderId(key) === normalized)?.[1];
427
+ }
428
+ function getCustomProviderApiKey(cfg, provider) {
429
+ return normalizeOptionalSecretInput(resolveProviderConfig(cfg, provider)?.apiKey);
430
+ }
431
+ function resolveProviderAuthOverride(cfg, provider) {
432
+ const auth = resolveProviderConfig(cfg, provider)?.auth;
433
+ if (auth === "api-key" || auth === "aws-sdk" || auth === "oauth" || auth === "token") return auth;
434
+ }
435
+ function resolveEnvSourceLabel(params) {
436
+ return `${params.envVars.some((envVar) => params.applied.has(envVar)) ? "shell env: " : "env: "}${params.label}`;
437
+ }
438
+ function resolveAwsSdkEnvVarName(env = process.env) {
439
+ if (env[AWS_BEARER_ENV]?.trim()) return AWS_BEARER_ENV;
440
+ if (env[AWS_ACCESS_KEY_ENV]?.trim() && env[AWS_SECRET_KEY_ENV]?.trim()) return AWS_ACCESS_KEY_ENV;
441
+ if (env[AWS_PROFILE_ENV]?.trim()) return AWS_PROFILE_ENV;
442
+ }
443
+ function resolveAwsSdkAuthInfo() {
444
+ const applied = new Set(getShellEnvAppliedKeys());
445
+ if (process.env[AWS_BEARER_ENV]?.trim()) return {
446
+ mode: "aws-sdk",
447
+ source: resolveEnvSourceLabel({
448
+ applied,
449
+ envVars: [AWS_BEARER_ENV],
450
+ label: AWS_BEARER_ENV
451
+ })
452
+ };
453
+ if (process.env[AWS_ACCESS_KEY_ENV]?.trim() && process.env[AWS_SECRET_KEY_ENV]?.trim()) return {
454
+ mode: "aws-sdk",
455
+ source: resolveEnvSourceLabel({
456
+ applied,
457
+ envVars: [AWS_ACCESS_KEY_ENV, AWS_SECRET_KEY_ENV],
458
+ label: `${AWS_ACCESS_KEY_ENV} + ${AWS_SECRET_KEY_ENV}`
459
+ })
460
+ };
461
+ if (process.env[AWS_PROFILE_ENV]?.trim()) return {
462
+ mode: "aws-sdk",
463
+ source: resolveEnvSourceLabel({
464
+ applied,
465
+ envVars: [AWS_PROFILE_ENV],
466
+ label: AWS_PROFILE_ENV
467
+ })
468
+ };
469
+ return {
470
+ mode: "aws-sdk",
471
+ source: "aws-sdk default chain"
472
+ };
473
+ }
474
+ async function resolveApiKeyForProvider(params) {
475
+ const { provider, cfg, profileId, preferredProfile } = params;
476
+ const store = params.store ?? ensureAuthProfileStore(params.agentDir);
477
+ if (profileId) {
478
+ const resolved = await resolveApiKeyForProfile({
479
+ cfg,
480
+ store,
481
+ profileId,
482
+ agentDir: params.agentDir
483
+ });
484
+ if (!resolved) throw new Error(`No credentials found for profile "${profileId}".`);
485
+ const mode = store.profiles[profileId]?.type;
486
+ return {
487
+ apiKey: resolved.apiKey,
488
+ profileId,
489
+ source: `profile:${profileId}`,
490
+ mode: mode === "oauth" ? "oauth" : mode === "token" ? "token" : "api-key"
491
+ };
492
+ }
493
+ const authOverride = resolveProviderAuthOverride(cfg, provider);
494
+ if (authOverride === "aws-sdk") return resolveAwsSdkAuthInfo();
495
+ const order = resolveAuthProfileOrder({
496
+ cfg,
497
+ store,
498
+ provider,
499
+ preferredProfile
500
+ });
501
+ for (const candidate of order) try {
502
+ const resolved = await resolveApiKeyForProfile({
503
+ cfg,
504
+ store,
505
+ profileId: candidate,
506
+ agentDir: params.agentDir
507
+ });
508
+ if (resolved) {
509
+ const mode = store.profiles[candidate]?.type;
510
+ return {
511
+ apiKey: resolved.apiKey,
512
+ profileId: candidate,
513
+ source: `profile:${candidate}`,
514
+ mode: mode === "oauth" ? "oauth" : mode === "token" ? "token" : "api-key"
515
+ };
516
+ }
517
+ } catch {}
518
+ const envResolved = resolveEnvApiKey(provider);
519
+ if (envResolved) return {
520
+ apiKey: envResolved.apiKey,
521
+ source: envResolved.source,
522
+ mode: envResolved.source.includes("OAUTH_TOKEN") ? "oauth" : "api-key"
523
+ };
524
+ const customKey = getCustomProviderApiKey(cfg, provider);
525
+ if (customKey) return {
526
+ apiKey: customKey,
527
+ source: "models.json",
528
+ mode: "api-key"
529
+ };
530
+ const normalized = normalizeProviderId(provider);
531
+ if (authOverride === void 0 && normalized === "amazon-bedrock") return resolveAwsSdkAuthInfo();
532
+ if (provider === "openai") {
533
+ if (listProfilesForProvider(store, "openai-codex").length > 0) throw new Error("No API key found for provider \"openai\". You are authenticated with OpenAI Codex OAuth. Use openai-codex/gpt-5.3-codex (OAuth) or set OPENAI_API_KEY to use openai/gpt-5.1-codex.");
534
+ }
535
+ const authStorePath = resolveAuthStorePathForDisplay(params.agentDir);
536
+ const resolvedAgentDir = path.dirname(authStorePath);
537
+ throw new Error([
538
+ `No API key found for provider "${provider}".`,
539
+ `Auth store: ${authStorePath} (agentDir: ${resolvedAgentDir}).`,
540
+ `Configure auth for this agent (${formatCliCommand("anima agents add <id>")}) or copy auth-profiles.json from the main agentDir.`
541
+ ].join(" "));
542
+ }
543
+ function resolveEnvApiKey(provider) {
544
+ const normalized = normalizeProviderId(provider);
545
+ const applied = new Set(getShellEnvAppliedKeys());
546
+ const pick = (envVar) => {
547
+ const value = normalizeOptionalSecretInput(process.env[envVar]);
548
+ if (!value) return null;
549
+ return {
550
+ apiKey: value,
551
+ source: applied.has(envVar) ? `shell env: ${envVar}` : `env: ${envVar}`
552
+ };
553
+ };
554
+ if (normalized === "github-copilot") return pick("COPILOT_GITHUB_TOKEN") ?? pick("GH_TOKEN") ?? pick("GITHUB_TOKEN");
555
+ if (normalized === "anthropic") return pick("ANTHROPIC_OAUTH_TOKEN") ?? pick("ANTHROPIC_API_KEY");
556
+ if (normalized === "chutes") return pick("CHUTES_OAUTH_TOKEN") ?? pick("CHUTES_API_KEY");
557
+ if (normalized === "zai") return pick("ZAI_API_KEY") ?? pick("Z_AI_API_KEY");
558
+ if (normalized === "google-vertex") {
559
+ const envKey = getEnvApiKey(normalized);
560
+ if (!envKey) return null;
561
+ return {
562
+ apiKey: envKey,
563
+ source: "gcloud adc"
564
+ };
565
+ }
566
+ if (normalized === "opencode") return pick("OPENCODE_API_KEY") ?? pick("OPENCODE_ZEN_API_KEY");
567
+ if (normalized === "qwen-portal") return pick("QWEN_OAUTH_TOKEN") ?? pick("QWEN_PORTAL_API_KEY");
568
+ if (normalized === "minimax-portal") return pick("MINIMAX_OAUTH_TOKEN") ?? pick("MINIMAX_API_KEY");
569
+ if (normalized === "kimi-coding") return pick("KIMI_API_KEY") ?? pick("KIMICODE_API_KEY");
570
+ if (normalized === "huggingface") return pick("HUGGINGFACE_HUB_TOKEN") ?? pick("HF_TOKEN");
571
+ const envVar = {
572
+ openai: "OPENAI_API_KEY",
573
+ google: "GEMINI_API_KEY",
574
+ voyage: "VOYAGE_API_KEY",
575
+ groq: "GROQ_API_KEY",
576
+ deepgram: "DEEPGRAM_API_KEY",
577
+ cerebras: "CEREBRAS_API_KEY",
578
+ xai: "XAI_API_KEY",
579
+ openrouter: "OPENROUTER_API_KEY",
580
+ litellm: "LITELLM_API_KEY",
581
+ "vercel-ai-gateway": "AI_GATEWAY_API_KEY",
582
+ "cloudflare-ai-gateway": "CLOUDFLARE_AI_GATEWAY_API_KEY",
583
+ moonshot: "MOONSHOT_API_KEY",
584
+ minimax: "MINIMAX_API_KEY",
585
+ nvidia: "NVIDIA_API_KEY",
586
+ xiaomi: "XIAOMI_API_KEY",
587
+ synthetic: "SYNTHETIC_API_KEY",
588
+ venice: "VENICE_API_KEY",
589
+ mistral: "MISTRAL_API_KEY",
590
+ opencode: "OPENCODE_API_KEY",
591
+ together: "TOGETHER_API_KEY",
592
+ qianfan: "QIANFAN_API_KEY",
593
+ ollama: "OLLAMA_API_KEY",
594
+ vllm: "VLLM_API_KEY"
595
+ }[normalized];
596
+ if (!envVar) return null;
597
+ return pick(envVar);
598
+ }
599
+ function resolveModelAuthMode(provider, cfg, store) {
600
+ const resolved = provider?.trim();
601
+ if (!resolved) return;
602
+ const authOverride = resolveProviderAuthOverride(cfg, resolved);
603
+ if (authOverride === "aws-sdk") return "aws-sdk";
604
+ const authStore = store ?? ensureAuthProfileStore();
605
+ const profiles = listProfilesForProvider(authStore, resolved);
606
+ if (profiles.length > 0) {
607
+ const modes = new Set(profiles.map((id) => authStore.profiles[id]?.type).filter((mode) => Boolean(mode)));
608
+ if ([
609
+ "oauth",
610
+ "token",
611
+ "api_key"
612
+ ].filter((k) => modes.has(k)).length >= 2) return "mixed";
613
+ if (modes.has("oauth")) return "oauth";
614
+ if (modes.has("token")) return "token";
615
+ if (modes.has("api_key")) return "api-key";
616
+ }
617
+ if (authOverride === void 0 && normalizeProviderId(resolved) === "amazon-bedrock") return "aws-sdk";
618
+ const envKey = resolveEnvApiKey(resolved);
619
+ if (envKey?.apiKey) return envKey.source.includes("OAUTH_TOKEN") ? "oauth" : "api-key";
620
+ if (getCustomProviderApiKey(cfg, resolved)) return "api-key";
621
+ return "unknown";
622
+ }
623
+ async function getApiKeyForModel(params) {
624
+ return resolveApiKeyForProvider({
625
+ provider: params.model.provider,
626
+ cfg: params.cfg,
627
+ profileId: params.profileId,
628
+ preferredProfile: params.preferredProfile,
629
+ store: params.store,
630
+ agentDir: params.agentDir
631
+ });
632
+ }
633
+ function requireApiKey(auth, provider) {
634
+ const key = normalizeSecretInput(auth.apiKey);
635
+ if (key) return key;
636
+ throw new Error(`No API key resolved for provider "${provider}" (auth mode: ${auth.mode}).`);
637
+ }
638
+
639
+ //#endregion
640
+ //#region src/agents/synthetic-models.ts
641
+ const SYNTHETIC_BASE_URL = "https://api.synthetic.new/anthropic";
642
+ const SYNTHETIC_DEFAULT_MODEL_ID = "hf:MiniMaxAI/MiniMax-M2.1";
643
+ const SYNTHETIC_DEFAULT_MODEL_REF = `synthetic/${SYNTHETIC_DEFAULT_MODEL_ID}`;
644
+ const SYNTHETIC_DEFAULT_COST = {
645
+ input: 0,
646
+ output: 0,
647
+ cacheRead: 0,
648
+ cacheWrite: 0
649
+ };
650
+ const SYNTHETIC_MODEL_CATALOG = [
651
+ {
652
+ id: SYNTHETIC_DEFAULT_MODEL_ID,
653
+ name: "MiniMax M2.1",
654
+ reasoning: false,
655
+ input: ["text"],
656
+ contextWindow: 192e3,
657
+ maxTokens: 65536
658
+ },
659
+ {
660
+ id: "hf:moonshotai/Kimi-K2-Thinking",
661
+ name: "Kimi K2 Thinking",
662
+ reasoning: true,
663
+ input: ["text"],
664
+ contextWindow: 256e3,
665
+ maxTokens: 8192
666
+ },
667
+ {
668
+ id: "hf:zai-org/GLM-4.7",
669
+ name: "GLM-4.7",
670
+ reasoning: false,
671
+ input: ["text"],
672
+ contextWindow: 198e3,
673
+ maxTokens: 128e3
674
+ },
675
+ {
676
+ id: "hf:deepseek-ai/DeepSeek-R1-0528",
677
+ name: "DeepSeek R1 0528",
678
+ reasoning: false,
679
+ input: ["text"],
680
+ contextWindow: 128e3,
681
+ maxTokens: 8192
682
+ },
683
+ {
684
+ id: "hf:deepseek-ai/DeepSeek-V3-0324",
685
+ name: "DeepSeek V3 0324",
686
+ reasoning: false,
687
+ input: ["text"],
688
+ contextWindow: 128e3,
689
+ maxTokens: 8192
690
+ },
691
+ {
692
+ id: "hf:deepseek-ai/DeepSeek-V3.1",
693
+ name: "DeepSeek V3.1",
694
+ reasoning: false,
695
+ input: ["text"],
696
+ contextWindow: 128e3,
697
+ maxTokens: 8192
698
+ },
699
+ {
700
+ id: "hf:deepseek-ai/DeepSeek-V3.1-Terminus",
701
+ name: "DeepSeek V3.1 Terminus",
702
+ reasoning: false,
703
+ input: ["text"],
704
+ contextWindow: 128e3,
705
+ maxTokens: 8192
706
+ },
707
+ {
708
+ id: "hf:deepseek-ai/DeepSeek-V3.2",
709
+ name: "DeepSeek V3.2",
710
+ reasoning: false,
711
+ input: ["text"],
712
+ contextWindow: 159e3,
713
+ maxTokens: 8192
714
+ },
715
+ {
716
+ id: "hf:meta-llama/Llama-3.3-70B-Instruct",
717
+ name: "Llama 3.3 70B Instruct",
718
+ reasoning: false,
719
+ input: ["text"],
720
+ contextWindow: 128e3,
721
+ maxTokens: 8192
722
+ },
723
+ {
724
+ id: "hf:meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",
725
+ name: "Llama 4 Maverick 17B 128E Instruct FP8",
726
+ reasoning: false,
727
+ input: ["text"],
728
+ contextWindow: 524e3,
729
+ maxTokens: 8192
730
+ },
731
+ {
732
+ id: "hf:moonshotai/Kimi-K2-Instruct-0905",
733
+ name: "Kimi K2 Instruct 0905",
734
+ reasoning: false,
735
+ input: ["text"],
736
+ contextWindow: 256e3,
737
+ maxTokens: 8192
738
+ },
739
+ {
740
+ id: "hf:moonshotai/Kimi-K2.5",
741
+ name: "Kimi K2.5",
742
+ reasoning: true,
743
+ input: ["text"],
744
+ contextWindow: 256e3,
745
+ maxTokens: 8192
746
+ },
747
+ {
748
+ id: "hf:openai/gpt-oss-120b",
749
+ name: "GPT OSS 120B",
750
+ reasoning: false,
751
+ input: ["text"],
752
+ contextWindow: 128e3,
753
+ maxTokens: 8192
754
+ },
755
+ {
756
+ id: "hf:Qwen/Qwen3-235B-A22B-Instruct-2507",
757
+ name: "Qwen3 235B A22B Instruct 2507",
758
+ reasoning: false,
759
+ input: ["text"],
760
+ contextWindow: 256e3,
761
+ maxTokens: 8192
762
+ },
763
+ {
764
+ id: "hf:Qwen/Qwen3-Coder-480B-A35B-Instruct",
765
+ name: "Qwen3 Coder 480B A35B Instruct",
766
+ reasoning: false,
767
+ input: ["text"],
768
+ contextWindow: 256e3,
769
+ maxTokens: 8192
770
+ },
771
+ {
772
+ id: "hf:Qwen/Qwen3-VL-235B-A22B-Instruct",
773
+ name: "Qwen3 VL 235B A22B Instruct",
774
+ reasoning: false,
775
+ input: ["text", "image"],
776
+ contextWindow: 25e4,
777
+ maxTokens: 8192
778
+ },
779
+ {
780
+ id: "hf:zai-org/GLM-4.5",
781
+ name: "GLM-4.5",
782
+ reasoning: false,
783
+ input: ["text"],
784
+ contextWindow: 128e3,
785
+ maxTokens: 128e3
786
+ },
787
+ {
788
+ id: "hf:zai-org/GLM-4.6",
789
+ name: "GLM-4.6",
790
+ reasoning: false,
791
+ input: ["text"],
792
+ contextWindow: 198e3,
793
+ maxTokens: 128e3
794
+ },
795
+ {
796
+ id: "hf:zai-org/GLM-5",
797
+ name: "GLM-5",
798
+ reasoning: true,
799
+ input: ["text", "image"],
800
+ contextWindow: 256e3,
801
+ maxTokens: 128e3
802
+ },
803
+ {
804
+ id: "hf:deepseek-ai/DeepSeek-V3",
805
+ name: "DeepSeek V3",
806
+ reasoning: false,
807
+ input: ["text"],
808
+ contextWindow: 128e3,
809
+ maxTokens: 8192
810
+ },
811
+ {
812
+ id: "hf:Qwen/Qwen3-235B-A22B-Thinking-2507",
813
+ name: "Qwen3 235B A22B Thinking 2507",
814
+ reasoning: true,
815
+ input: ["text"],
816
+ contextWindow: 256e3,
817
+ maxTokens: 8192
818
+ }
819
+ ];
820
+ function buildSyntheticModelDefinition(entry) {
821
+ return {
822
+ id: entry.id,
823
+ name: entry.name,
824
+ reasoning: entry.reasoning,
825
+ input: [...entry.input],
826
+ cost: SYNTHETIC_DEFAULT_COST,
827
+ contextWindow: entry.contextWindow,
828
+ maxTokens: entry.maxTokens
829
+ };
830
+ }
831
+
832
+ //#endregion
833
+ //#region src/agents/together-models.ts
834
+ const TOGETHER_BASE_URL = "https://api.together.xyz/v1";
835
+ const TOGETHER_MODEL_CATALOG = [
836
+ {
837
+ id: "zai-org/GLM-4.7",
838
+ name: "GLM 4.7 Fp8",
839
+ reasoning: false,
840
+ input: ["text"],
841
+ contextWindow: 202752,
842
+ maxTokens: 8192,
843
+ cost: {
844
+ input: .45,
845
+ output: 2,
846
+ cacheRead: .45,
847
+ cacheWrite: 2
848
+ }
849
+ },
850
+ {
851
+ id: "moonshotai/Kimi-K2.5",
852
+ name: "Kimi K2.5",
853
+ reasoning: true,
854
+ input: ["text", "image"],
855
+ cost: {
856
+ input: .5,
857
+ output: 2.8,
858
+ cacheRead: .5,
859
+ cacheWrite: 2.8
860
+ },
861
+ contextWindow: 262144,
862
+ maxTokens: 32768
863
+ },
864
+ {
865
+ id: "meta-llama/Llama-3.3-70B-Instruct-Turbo",
866
+ name: "Llama 3.3 70B Instruct Turbo",
867
+ reasoning: false,
868
+ input: ["text"],
869
+ contextWindow: 131072,
870
+ maxTokens: 8192,
871
+ cost: {
872
+ input: .88,
873
+ output: .88,
874
+ cacheRead: .88,
875
+ cacheWrite: .88
876
+ }
877
+ },
878
+ {
879
+ id: "meta-llama/Llama-4-Scout-17B-16E-Instruct",
880
+ name: "Llama 4 Scout 17B 16E Instruct",
881
+ reasoning: false,
882
+ input: ["text", "image"],
883
+ contextWindow: 1e7,
884
+ maxTokens: 32768,
885
+ cost: {
886
+ input: .18,
887
+ output: .59,
888
+ cacheRead: .18,
889
+ cacheWrite: .18
890
+ }
891
+ },
892
+ {
893
+ id: "meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",
894
+ name: "Llama 4 Maverick 17B 128E Instruct FP8",
895
+ reasoning: false,
896
+ input: ["text", "image"],
897
+ contextWindow: 2e7,
898
+ maxTokens: 32768,
899
+ cost: {
900
+ input: .27,
901
+ output: .85,
902
+ cacheRead: .27,
903
+ cacheWrite: .27
904
+ }
905
+ },
906
+ {
907
+ id: "deepseek-ai/DeepSeek-V3.1",
908
+ name: "DeepSeek V3.1",
909
+ reasoning: false,
910
+ input: ["text"],
911
+ contextWindow: 131072,
912
+ maxTokens: 8192,
913
+ cost: {
914
+ input: .6,
915
+ output: 1.25,
916
+ cacheRead: .6,
917
+ cacheWrite: .6
918
+ }
919
+ },
920
+ {
921
+ id: "deepseek-ai/DeepSeek-R1",
922
+ name: "DeepSeek R1",
923
+ reasoning: true,
924
+ input: ["text"],
925
+ contextWindow: 131072,
926
+ maxTokens: 8192,
927
+ cost: {
928
+ input: 3,
929
+ output: 7,
930
+ cacheRead: 3,
931
+ cacheWrite: 3
932
+ }
933
+ },
934
+ {
935
+ id: "moonshotai/Kimi-K2-Instruct-0905",
936
+ name: "Kimi K2-Instruct 0905",
937
+ reasoning: false,
938
+ input: ["text"],
939
+ contextWindow: 262144,
940
+ maxTokens: 8192,
941
+ cost: {
942
+ input: 1,
943
+ output: 3,
944
+ cacheRead: 1,
945
+ cacheWrite: 3
946
+ }
947
+ }
948
+ ];
949
+ function buildTogetherModelDefinition(model) {
950
+ return {
951
+ id: model.id,
952
+ name: model.name,
953
+ api: "openai-completions",
954
+ reasoning: model.reasoning,
955
+ input: model.input,
956
+ cost: model.cost,
957
+ contextWindow: model.contextWindow,
958
+ maxTokens: model.maxTokens
959
+ };
960
+ }
961
+
962
+ //#endregion
963
+ //#region src/agents/venice-models.ts
964
+ const VENICE_BASE_URL = "https://api.venice.ai/api/v1";
965
+ const VENICE_DEFAULT_MODEL_ID = "llama-3.3-70b";
966
+ const VENICE_DEFAULT_MODEL_REF = `venice/${VENICE_DEFAULT_MODEL_ID}`;
967
+ const VENICE_DEFAULT_COST = {
968
+ input: 0,
969
+ output: 0,
970
+ cacheRead: 0,
971
+ cacheWrite: 0
972
+ };
973
+ /**
974
+ * Complete catalog of Venice AI models.
975
+ *
976
+ * Venice provides two privacy modes:
977
+ * - "private": Fully private inference, no logging, ephemeral
978
+ * - "anonymized": Proxied through Venice with metadata stripped (for proprietary models)
979
+ *
980
+ * Note: The `privacy` field is included for documentation purposes but is not
981
+ * propagated to ModelDefinitionConfig as it's not part of the core model schema.
982
+ * Privacy mode is determined by the model itself, not configurable at runtime.
983
+ *
984
+ * This catalog serves as a fallback when the Venice API is unreachable.
985
+ */
986
+ const VENICE_MODEL_CATALOG = [
987
+ {
988
+ id: "llama-3.3-70b",
989
+ name: "Llama 3.3 70B",
990
+ reasoning: false,
991
+ input: ["text"],
992
+ contextWindow: 131072,
993
+ maxTokens: 8192,
994
+ privacy: "private"
995
+ },
996
+ {
997
+ id: "llama-3.2-3b",
998
+ name: "Llama 3.2 3B",
999
+ reasoning: false,
1000
+ input: ["text"],
1001
+ contextWindow: 131072,
1002
+ maxTokens: 8192,
1003
+ privacy: "private"
1004
+ },
1005
+ {
1006
+ id: "hermes-3-llama-3.1-405b",
1007
+ name: "Hermes 3 Llama 3.1 405B",
1008
+ reasoning: false,
1009
+ input: ["text"],
1010
+ contextWindow: 131072,
1011
+ maxTokens: 8192,
1012
+ privacy: "private"
1013
+ },
1014
+ {
1015
+ id: "qwen3-235b-a22b-thinking-2507",
1016
+ name: "Qwen3 235B Thinking",
1017
+ reasoning: true,
1018
+ input: ["text"],
1019
+ contextWindow: 131072,
1020
+ maxTokens: 8192,
1021
+ privacy: "private"
1022
+ },
1023
+ {
1024
+ id: "qwen3-235b-a22b-instruct-2507",
1025
+ name: "Qwen3 235B Instruct",
1026
+ reasoning: false,
1027
+ input: ["text"],
1028
+ contextWindow: 131072,
1029
+ maxTokens: 8192,
1030
+ privacy: "private"
1031
+ },
1032
+ {
1033
+ id: "qwen3-coder-480b-a35b-instruct",
1034
+ name: "Qwen3 Coder 480B",
1035
+ reasoning: false,
1036
+ input: ["text"],
1037
+ contextWindow: 262144,
1038
+ maxTokens: 8192,
1039
+ privacy: "private"
1040
+ },
1041
+ {
1042
+ id: "qwen3-next-80b",
1043
+ name: "Qwen3 Next 80B",
1044
+ reasoning: false,
1045
+ input: ["text"],
1046
+ contextWindow: 262144,
1047
+ maxTokens: 8192,
1048
+ privacy: "private"
1049
+ },
1050
+ {
1051
+ id: "qwen3-vl-235b-a22b",
1052
+ name: "Qwen3 VL 235B (Vision)",
1053
+ reasoning: false,
1054
+ input: ["text", "image"],
1055
+ contextWindow: 262144,
1056
+ maxTokens: 8192,
1057
+ privacy: "private"
1058
+ },
1059
+ {
1060
+ id: "qwen3-4b",
1061
+ name: "Venice Small (Qwen3 4B)",
1062
+ reasoning: true,
1063
+ input: ["text"],
1064
+ contextWindow: 32768,
1065
+ maxTokens: 8192,
1066
+ privacy: "private"
1067
+ },
1068
+ {
1069
+ id: "deepseek-v3.2",
1070
+ name: "DeepSeek V3.2",
1071
+ reasoning: true,
1072
+ input: ["text"],
1073
+ contextWindow: 163840,
1074
+ maxTokens: 8192,
1075
+ privacy: "private"
1076
+ },
1077
+ {
1078
+ id: "venice-uncensored",
1079
+ name: "Venice Uncensored (Dolphin-Mistral)",
1080
+ reasoning: false,
1081
+ input: ["text"],
1082
+ contextWindow: 32768,
1083
+ maxTokens: 8192,
1084
+ privacy: "private"
1085
+ },
1086
+ {
1087
+ id: "mistral-31-24b",
1088
+ name: "Venice Medium (Mistral)",
1089
+ reasoning: false,
1090
+ input: ["text", "image"],
1091
+ contextWindow: 131072,
1092
+ maxTokens: 8192,
1093
+ privacy: "private"
1094
+ },
1095
+ {
1096
+ id: "google-gemma-3-27b-it",
1097
+ name: "Google Gemma 3 27B Instruct",
1098
+ reasoning: false,
1099
+ input: ["text", "image"],
1100
+ contextWindow: 202752,
1101
+ maxTokens: 8192,
1102
+ privacy: "private"
1103
+ },
1104
+ {
1105
+ id: "openai-gpt-oss-120b",
1106
+ name: "OpenAI GPT OSS 120B",
1107
+ reasoning: false,
1108
+ input: ["text"],
1109
+ contextWindow: 131072,
1110
+ maxTokens: 8192,
1111
+ privacy: "private"
1112
+ },
1113
+ {
1114
+ id: "zai-org-glm-4.7",
1115
+ name: "GLM 4.7",
1116
+ reasoning: true,
1117
+ input: ["text"],
1118
+ contextWindow: 202752,
1119
+ maxTokens: 8192,
1120
+ privacy: "private"
1121
+ },
1122
+ {
1123
+ id: "claude-opus-45",
1124
+ name: "Claude Opus 4.5 (via Venice)",
1125
+ reasoning: true,
1126
+ input: ["text", "image"],
1127
+ contextWindow: 202752,
1128
+ maxTokens: 8192,
1129
+ privacy: "anonymized"
1130
+ },
1131
+ {
1132
+ id: "claude-sonnet-45",
1133
+ name: "Claude Sonnet 4.5 (via Venice)",
1134
+ reasoning: true,
1135
+ input: ["text", "image"],
1136
+ contextWindow: 202752,
1137
+ maxTokens: 8192,
1138
+ privacy: "anonymized"
1139
+ },
1140
+ {
1141
+ id: "openai-gpt-52",
1142
+ name: "GPT-5.2 (via Venice)",
1143
+ reasoning: true,
1144
+ input: ["text"],
1145
+ contextWindow: 262144,
1146
+ maxTokens: 8192,
1147
+ privacy: "anonymized"
1148
+ },
1149
+ {
1150
+ id: "openai-gpt-52-codex",
1151
+ name: "GPT-5.2 Codex (via Venice)",
1152
+ reasoning: true,
1153
+ input: ["text", "image"],
1154
+ contextWindow: 262144,
1155
+ maxTokens: 8192,
1156
+ privacy: "anonymized"
1157
+ },
1158
+ {
1159
+ id: "gemini-3-pro-preview",
1160
+ name: "Gemini 3 Pro (via Venice)",
1161
+ reasoning: true,
1162
+ input: ["text", "image"],
1163
+ contextWindow: 202752,
1164
+ maxTokens: 8192,
1165
+ privacy: "anonymized"
1166
+ },
1167
+ {
1168
+ id: "gemini-3-flash-preview",
1169
+ name: "Gemini 3 Flash (via Venice)",
1170
+ reasoning: true,
1171
+ input: ["text", "image"],
1172
+ contextWindow: 262144,
1173
+ maxTokens: 8192,
1174
+ privacy: "anonymized"
1175
+ },
1176
+ {
1177
+ id: "grok-41-fast",
1178
+ name: "Grok 4.1 Fast (via Venice)",
1179
+ reasoning: true,
1180
+ input: ["text", "image"],
1181
+ contextWindow: 262144,
1182
+ maxTokens: 8192,
1183
+ privacy: "anonymized"
1184
+ },
1185
+ {
1186
+ id: "grok-code-fast-1",
1187
+ name: "Grok Code Fast 1 (via Venice)",
1188
+ reasoning: true,
1189
+ input: ["text"],
1190
+ contextWindow: 262144,
1191
+ maxTokens: 8192,
1192
+ privacy: "anonymized"
1193
+ },
1194
+ {
1195
+ id: "kimi-k2-thinking",
1196
+ name: "Kimi K2 Thinking (via Venice)",
1197
+ reasoning: true,
1198
+ input: ["text"],
1199
+ contextWindow: 262144,
1200
+ maxTokens: 8192,
1201
+ privacy: "anonymized"
1202
+ },
1203
+ {
1204
+ id: "minimax-m21",
1205
+ name: "MiniMax M2.1 (via Venice)",
1206
+ reasoning: true,
1207
+ input: ["text"],
1208
+ contextWindow: 202752,
1209
+ maxTokens: 8192,
1210
+ privacy: "anonymized"
1211
+ }
1212
+ ];
1213
+ /**
1214
+ * Build a ModelDefinitionConfig from a Venice catalog entry.
1215
+ *
1216
+ * Note: The `privacy` field from the catalog is not included in the output
1217
+ * as ModelDefinitionConfig doesn't support custom metadata fields. Privacy
1218
+ * mode is inherent to each model and documented in the catalog/docs.
1219
+ */
1220
+ function buildVeniceModelDefinition(entry) {
1221
+ return {
1222
+ id: entry.id,
1223
+ name: entry.name,
1224
+ reasoning: entry.reasoning,
1225
+ input: [...entry.input],
1226
+ cost: VENICE_DEFAULT_COST,
1227
+ contextWindow: entry.contextWindow,
1228
+ maxTokens: entry.maxTokens,
1229
+ compat: { supportsUsageInStreaming: false }
1230
+ };
1231
+ }
1232
+
1233
+ //#endregion
1234
+ //#region src/agents/models-config.providers.ts
1235
+ const XIAOMI_BASE_URL = "https://api.xiaomimimo.com/anthropic";
1236
+ const XIAOMI_DEFAULT_MODEL_ID = "mimo-v2-flash";
1237
+ const XIAOMI_DEFAULT_CONTEXT_WINDOW = 262144;
1238
+ const XIAOMI_DEFAULT_MAX_TOKENS = 8192;
1239
+ const XIAOMI_DEFAULT_COST = {
1240
+ input: 0,
1241
+ output: 0,
1242
+ cacheRead: 0,
1243
+ cacheWrite: 0
1244
+ };
1245
+ const QIANFAN_BASE_URL = "https://qianfan.baidubce.com/v2";
1246
+ const QIANFAN_DEFAULT_MODEL_ID = "deepseek-v3.2";
1247
+ const QIANFAN_DEFAULT_CONTEXT_WINDOW = 98304;
1248
+ const QIANFAN_DEFAULT_MAX_TOKENS = 32768;
1249
+ const QIANFAN_DEFAULT_COST = {
1250
+ input: 0,
1251
+ output: 0,
1252
+ cacheRead: 0,
1253
+ cacheWrite: 0
1254
+ };
1255
+ function normalizeGoogleModelId(id) {
1256
+ if (id === "gemini-3-pro") return "gemini-3-pro-preview";
1257
+ if (id === "gemini-3-flash") return "gemini-3-flash-preview";
1258
+ return id;
1259
+ }
1260
+ function buildXiaomiProvider() {
1261
+ return {
1262
+ baseUrl: XIAOMI_BASE_URL,
1263
+ api: "anthropic-messages",
1264
+ models: [{
1265
+ id: XIAOMI_DEFAULT_MODEL_ID,
1266
+ name: "Xiaomi MiMo V2 Flash",
1267
+ reasoning: false,
1268
+ input: ["text"],
1269
+ cost: XIAOMI_DEFAULT_COST,
1270
+ contextWindow: XIAOMI_DEFAULT_CONTEXT_WINDOW,
1271
+ maxTokens: XIAOMI_DEFAULT_MAX_TOKENS
1272
+ }]
1273
+ };
1274
+ }
1275
+ function buildQianfanProvider() {
1276
+ return {
1277
+ baseUrl: QIANFAN_BASE_URL,
1278
+ api: "openai-completions",
1279
+ models: [{
1280
+ id: QIANFAN_DEFAULT_MODEL_ID,
1281
+ name: "DEEPSEEK V3.2",
1282
+ reasoning: true,
1283
+ input: ["text"],
1284
+ cost: QIANFAN_DEFAULT_COST,
1285
+ contextWindow: QIANFAN_DEFAULT_CONTEXT_WINDOW,
1286
+ maxTokens: QIANFAN_DEFAULT_MAX_TOKENS
1287
+ }, {
1288
+ id: "ernie-5.0-thinking-preview",
1289
+ name: "ERNIE-5.0-Thinking-Preview",
1290
+ reasoning: true,
1291
+ input: ["text", "image"],
1292
+ cost: QIANFAN_DEFAULT_COST,
1293
+ contextWindow: 119e3,
1294
+ maxTokens: 64e3
1295
+ }]
1296
+ };
1297
+ }
1298
+
1299
+ //#endregion
1300
+ //#region src/agents/model-selection.ts
1301
+ const ANTHROPIC_MODEL_ALIASES = {
1302
+ "opus-4.6": "claude-opus-4-6",
1303
+ "opus-4.5": "claude-opus-4-5",
1304
+ "sonnet-4.5": "claude-sonnet-4-5"
1305
+ };
1306
+ const OPENAI_CODEX_OAUTH_MODEL_PREFIXES = ["gpt-5.3-codex"];
1307
+ function normalizeAliasKey(value) {
1308
+ return value.trim().toLowerCase();
1309
+ }
1310
+ function modelKey(provider, model) {
1311
+ return `${provider}/${model}`;
1312
+ }
1313
+ function normalizeProviderId(provider) {
1314
+ const normalized = provider.trim().toLowerCase();
1315
+ if (normalized === "z.ai" || normalized === "z-ai") return "zai";
1316
+ if (normalized === "opencode-zen") return "opencode";
1317
+ if (normalized === "qwen") return "qwen-portal";
1318
+ if (normalized === "kimi-code") return "kimi-coding";
1319
+ return normalized;
1320
+ }
1321
+ function isCliProvider(provider, cfg) {
1322
+ const normalized = normalizeProviderId(provider);
1323
+ if (normalized === "claude-cli") return true;
1324
+ if (normalized === "codex-cli") return true;
1325
+ const backends = cfg?.agents?.defaults?.cliBackends ?? {};
1326
+ return Object.keys(backends).some((key) => normalizeProviderId(key) === normalized);
1327
+ }
1328
+ function normalizeAnthropicModelId(model) {
1329
+ const trimmed = model.trim();
1330
+ if (!trimmed) return trimmed;
1331
+ return ANTHROPIC_MODEL_ALIASES[trimmed.toLowerCase()] ?? trimmed;
1332
+ }
1333
+ function normalizeProviderModelId(provider, model) {
1334
+ if (provider === "anthropic") return normalizeAnthropicModelId(model);
1335
+ if (provider === "google") return normalizeGoogleModelId(model);
1336
+ return model;
1337
+ }
1338
+ function shouldUseOpenAICodexProvider(provider, model) {
1339
+ if (provider !== "openai") return false;
1340
+ const normalized = model.trim().toLowerCase();
1341
+ if (!normalized) return false;
1342
+ return OPENAI_CODEX_OAUTH_MODEL_PREFIXES.some((prefix) => normalized === prefix || normalized.startsWith(`${prefix}-`));
1343
+ }
1344
+ function normalizeModelRef(provider, model) {
1345
+ const normalizedProvider = normalizeProviderId(provider);
1346
+ const normalizedModel = normalizeProviderModelId(normalizedProvider, model.trim());
1347
+ if (shouldUseOpenAICodexProvider(normalizedProvider, normalizedModel)) return {
1348
+ provider: "openai-codex",
1349
+ model: normalizedModel
1350
+ };
1351
+ return {
1352
+ provider: normalizedProvider,
1353
+ model: normalizedModel
1354
+ };
1355
+ }
1356
+ function parseModelRef(raw, defaultProvider) {
1357
+ const trimmed = raw.trim();
1358
+ if (!trimmed) return null;
1359
+ const slash = trimmed.indexOf("/");
1360
+ if (slash === -1) return normalizeModelRef(defaultProvider, trimmed);
1361
+ const providerRaw = trimmed.slice(0, slash).trim();
1362
+ const model = trimmed.slice(slash + 1).trim();
1363
+ if (!providerRaw || !model) return null;
1364
+ return normalizeModelRef(providerRaw, model);
1365
+ }
1366
+ function resolveAllowlistModelKey(raw, defaultProvider) {
1367
+ const parsed = parseModelRef(raw, defaultProvider);
1368
+ if (!parsed) return null;
1369
+ return modelKey(parsed.provider, parsed.model);
1370
+ }
1371
+ function buildConfiguredAllowlistKeys(params) {
1372
+ const rawAllowlist = Object.keys(params.cfg?.agents?.defaults?.models ?? {});
1373
+ if (rawAllowlist.length === 0) return null;
1374
+ const keys = /* @__PURE__ */ new Set();
1375
+ for (const raw of rawAllowlist) {
1376
+ const key = resolveAllowlistModelKey(String(raw ?? ""), params.defaultProvider);
1377
+ if (key) keys.add(key);
1378
+ }
1379
+ return keys.size > 0 ? keys : null;
1380
+ }
1381
+ function buildModelAliasIndex(params) {
1382
+ const byAlias = /* @__PURE__ */ new Map();
1383
+ const byKey = /* @__PURE__ */ new Map();
1384
+ const rawModels = params.cfg.agents?.defaults?.models ?? {};
1385
+ for (const [keyRaw, entryRaw] of Object.entries(rawModels)) {
1386
+ const parsed = parseModelRef(String(keyRaw ?? ""), params.defaultProvider);
1387
+ if (!parsed) continue;
1388
+ const alias = String(entryRaw?.alias ?? "").trim();
1389
+ if (!alias) continue;
1390
+ const aliasKey = normalizeAliasKey(alias);
1391
+ byAlias.set(aliasKey, {
1392
+ alias,
1393
+ ref: parsed
1394
+ });
1395
+ const key = modelKey(parsed.provider, parsed.model);
1396
+ const existing = byKey.get(key) ?? [];
1397
+ existing.push(alias);
1398
+ byKey.set(key, existing);
1399
+ }
1400
+ return {
1401
+ byAlias,
1402
+ byKey
1403
+ };
1404
+ }
1405
+ function resolveModelRefFromString(params) {
1406
+ const trimmed = params.raw.trim();
1407
+ if (!trimmed) return null;
1408
+ if (!trimmed.includes("/")) {
1409
+ const aliasKey = normalizeAliasKey(trimmed);
1410
+ const aliasMatch = params.aliasIndex?.byAlias.get(aliasKey);
1411
+ if (aliasMatch) return {
1412
+ ref: aliasMatch.ref,
1413
+ alias: aliasMatch.alias
1414
+ };
1415
+ }
1416
+ const parsed = parseModelRef(trimmed, params.defaultProvider);
1417
+ if (!parsed) return null;
1418
+ return { ref: parsed };
1419
+ }
1420
+ function resolveConfiguredModelRef(params) {
1421
+ const rawModel = (() => {
1422
+ const raw = params.cfg.agents?.defaults?.model;
1423
+ if (typeof raw === "string") return raw.trim();
1424
+ return raw?.primary?.trim() ?? "";
1425
+ })();
1426
+ if (rawModel) {
1427
+ const trimmed = rawModel.trim();
1428
+ const aliasIndex = buildModelAliasIndex({
1429
+ cfg: params.cfg,
1430
+ defaultProvider: params.defaultProvider
1431
+ });
1432
+ if (!trimmed.includes("/")) {
1433
+ const aliasKey = normalizeAliasKey(trimmed);
1434
+ const aliasMatch = aliasIndex.byAlias.get(aliasKey);
1435
+ if (aliasMatch) return aliasMatch.ref;
1436
+ console.warn(`[anima] Model "${trimmed}" specified without provider. Falling back to "anthropic/${trimmed}". Please use "anthropic/${trimmed}" in your config.`);
1437
+ return {
1438
+ provider: "anthropic",
1439
+ model: trimmed
1440
+ };
1441
+ }
1442
+ const resolved = resolveModelRefFromString({
1443
+ raw: trimmed,
1444
+ defaultProvider: params.defaultProvider,
1445
+ aliasIndex
1446
+ });
1447
+ if (resolved) return resolved.ref;
1448
+ }
1449
+ return {
1450
+ provider: params.defaultProvider,
1451
+ model: params.defaultModel
1452
+ };
1453
+ }
1454
+ function resolveDefaultModelForAgent(params) {
1455
+ const agentModelOverride = params.agentId ? resolveAgentModelPrimary(params.cfg, params.agentId) : void 0;
1456
+ return resolveConfiguredModelRef({
1457
+ cfg: agentModelOverride && agentModelOverride.length > 0 ? {
1458
+ ...params.cfg,
1459
+ agents: {
1460
+ ...params.cfg.agents,
1461
+ defaults: {
1462
+ ...params.cfg.agents?.defaults,
1463
+ model: {
1464
+ ...typeof params.cfg.agents?.defaults?.model === "object" ? params.cfg.agents.defaults.model : void 0,
1465
+ primary: agentModelOverride
1466
+ }
1467
+ }
1468
+ }
1469
+ } : params.cfg,
1470
+ defaultProvider: DEFAULT_PROVIDER,
1471
+ defaultModel: DEFAULT_MODEL
1472
+ });
1473
+ }
1474
+ function buildAllowedModelSet(params) {
1475
+ const rawAllowlist = (() => {
1476
+ const modelMap = params.cfg.agents?.defaults?.models ?? {};
1477
+ return Object.keys(modelMap);
1478
+ })();
1479
+ const allowAny = rawAllowlist.length === 0;
1480
+ const defaultModel = params.defaultModel?.trim();
1481
+ const defaultKey = defaultModel && params.defaultProvider ? modelKey(params.defaultProvider, defaultModel) : void 0;
1482
+ const catalogKeys = new Set(params.catalog.map((entry) => modelKey(entry.provider, entry.id)));
1483
+ if (allowAny) {
1484
+ if (defaultKey) catalogKeys.add(defaultKey);
1485
+ return {
1486
+ allowAny: true,
1487
+ allowedCatalog: params.catalog,
1488
+ allowedKeys: catalogKeys
1489
+ };
1490
+ }
1491
+ const allowedKeys = /* @__PURE__ */ new Set();
1492
+ const configuredProviders = params.cfg.models?.providers ?? {};
1493
+ for (const raw of rawAllowlist) {
1494
+ const parsed = parseModelRef(String(raw), params.defaultProvider);
1495
+ if (!parsed) continue;
1496
+ const key = modelKey(parsed.provider, parsed.model);
1497
+ const providerKey = normalizeProviderId(parsed.provider);
1498
+ if (isCliProvider(parsed.provider, params.cfg)) allowedKeys.add(key);
1499
+ else if (catalogKeys.has(key)) allowedKeys.add(key);
1500
+ else if (configuredProviders[providerKey] != null) allowedKeys.add(key);
1501
+ }
1502
+ if (defaultKey) allowedKeys.add(defaultKey);
1503
+ const allowedCatalog = params.catalog.filter((entry) => allowedKeys.has(modelKey(entry.provider, entry.id)));
1504
+ if (allowedCatalog.length === 0 && allowedKeys.size === 0) {
1505
+ if (defaultKey) catalogKeys.add(defaultKey);
1506
+ return {
1507
+ allowAny: true,
1508
+ allowedCatalog: params.catalog,
1509
+ allowedKeys: catalogKeys
1510
+ };
1511
+ }
1512
+ return {
1513
+ allowAny: false,
1514
+ allowedCatalog,
1515
+ allowedKeys
1516
+ };
1517
+ }
1518
+ function getModelRefStatus(params) {
1519
+ const allowed = buildAllowedModelSet({
1520
+ cfg: params.cfg,
1521
+ catalog: params.catalog,
1522
+ defaultProvider: params.defaultProvider,
1523
+ defaultModel: params.defaultModel
1524
+ });
1525
+ const key = modelKey(params.ref.provider, params.ref.model);
1526
+ return {
1527
+ key,
1528
+ inCatalog: params.catalog.some((entry) => modelKey(entry.provider, entry.id) === key),
1529
+ allowAny: allowed.allowAny,
1530
+ allowed: allowed.allowAny || allowed.allowedKeys.has(key)
1531
+ };
1532
+ }
1533
+ function resolveAllowedModelRef(params) {
1534
+ const trimmed = params.raw.trim();
1535
+ if (!trimmed) return { error: "invalid model: empty" };
1536
+ const aliasIndex = buildModelAliasIndex({
1537
+ cfg: params.cfg,
1538
+ defaultProvider: params.defaultProvider
1539
+ });
1540
+ const resolved = resolveModelRefFromString({
1541
+ raw: trimmed,
1542
+ defaultProvider: params.defaultProvider,
1543
+ aliasIndex
1544
+ });
1545
+ if (!resolved) return { error: `invalid model: ${trimmed}` };
1546
+ const status = getModelRefStatus({
1547
+ cfg: params.cfg,
1548
+ catalog: params.catalog,
1549
+ ref: resolved.ref,
1550
+ defaultProvider: params.defaultProvider,
1551
+ defaultModel: params.defaultModel
1552
+ });
1553
+ if (!status.allowed) return { error: `model not allowed: ${status.key}` };
1554
+ return {
1555
+ ref: resolved.ref,
1556
+ key: status.key
1557
+ };
1558
+ }
1559
+ function resolveThinkingDefault(params) {
1560
+ const configured = params.cfg.agents?.defaults?.thinkingDefault;
1561
+ if (configured) return configured;
1562
+ if ((params.catalog?.find((entry) => entry.provider === params.provider && entry.id === params.model))?.reasoning) return "low";
1563
+ return "off";
1564
+ }
1565
+ /**
1566
+ * Resolve the model configured for Gmail hook processing.
1567
+ * Returns null if hooks.gmail.model is not set.
1568
+ */
1569
+ function resolveHooksGmailModel(params) {
1570
+ const hooksModel = params.cfg.hooks?.gmail?.model;
1571
+ if (!hooksModel?.trim()) return null;
1572
+ const aliasIndex = buildModelAliasIndex({
1573
+ cfg: params.cfg,
1574
+ defaultProvider: params.defaultProvider
1575
+ });
1576
+ return resolveModelRefFromString({
1577
+ raw: hooksModel,
1578
+ defaultProvider: params.defaultProvider,
1579
+ aliasIndex
1580
+ })?.ref ?? null;
1581
+ }
1582
+
1583
+ //#endregion
1584
+ //#region src/plugin-sdk/file-lock.ts
1585
+ const HELD_LOCKS_KEY = Symbol.for("anima.fileLockHeldLocks");
1586
+ function resolveHeldLocks() {
1587
+ const proc = process;
1588
+ if (!proc[HELD_LOCKS_KEY]) proc[HELD_LOCKS_KEY] = /* @__PURE__ */ new Map();
1589
+ return proc[HELD_LOCKS_KEY];
1590
+ }
1591
+ const HELD_LOCKS = resolveHeldLocks();
1592
+ function isAlive(pid) {
1593
+ if (!Number.isFinite(pid) || pid <= 0) return false;
1594
+ try {
1595
+ process.kill(pid, 0);
1596
+ return true;
1597
+ } catch {
1598
+ return false;
1599
+ }
1600
+ }
1601
+ function computeDelayMs(retries, attempt) {
1602
+ const base = Math.min(retries.maxTimeout, Math.max(retries.minTimeout, retries.minTimeout * retries.factor ** attempt));
1603
+ const jitter = retries.randomize ? 1 + Math.random() : 1;
1604
+ return Math.min(retries.maxTimeout, Math.round(base * jitter));
1605
+ }
1606
+ async function readLockPayload(lockPath) {
1607
+ try {
1608
+ const raw = await fs$1.readFile(lockPath, "utf8");
1609
+ const parsed = JSON.parse(raw);
1610
+ if (typeof parsed.pid !== "number" || typeof parsed.createdAt !== "string") return null;
1611
+ return {
1612
+ pid: parsed.pid,
1613
+ createdAt: parsed.createdAt
1614
+ };
1615
+ } catch {
1616
+ return null;
1617
+ }
1618
+ }
1619
+ async function resolveNormalizedFilePath(filePath) {
1620
+ const resolved = path.resolve(filePath);
1621
+ const dir = path.dirname(resolved);
1622
+ await fs$1.mkdir(dir, { recursive: true });
1623
+ try {
1624
+ const realDir = await fs$1.realpath(dir);
1625
+ return path.join(realDir, path.basename(resolved));
1626
+ } catch {
1627
+ return resolved;
1628
+ }
1629
+ }
1630
+ async function isStaleLock(lockPath, staleMs) {
1631
+ const payload = await readLockPayload(lockPath);
1632
+ if (payload?.pid && !isAlive(payload.pid)) return true;
1633
+ if (payload?.createdAt) {
1634
+ const createdAt = Date.parse(payload.createdAt);
1635
+ if (!Number.isFinite(createdAt) || Date.now() - createdAt > staleMs) return true;
1636
+ }
1637
+ try {
1638
+ const stat = await fs$1.stat(lockPath);
1639
+ return Date.now() - stat.mtimeMs > staleMs;
1640
+ } catch {
1641
+ return true;
1642
+ }
1643
+ }
1644
+ async function acquireFileLock(filePath, options) {
1645
+ const normalizedFile = await resolveNormalizedFilePath(filePath);
1646
+ const lockPath = `${normalizedFile}.lock`;
1647
+ const held = HELD_LOCKS.get(normalizedFile);
1648
+ if (held) {
1649
+ held.count += 1;
1650
+ return {
1651
+ lockPath,
1652
+ release: async () => {
1653
+ const current = HELD_LOCKS.get(normalizedFile);
1654
+ if (!current) return;
1655
+ current.count -= 1;
1656
+ if (current.count > 0) return;
1657
+ HELD_LOCKS.delete(normalizedFile);
1658
+ await current.handle.close().catch(() => void 0);
1659
+ await fs$1.rm(current.lockPath, { force: true }).catch(() => void 0);
1660
+ }
1661
+ };
1662
+ }
1663
+ const attempts = Math.max(1, options.retries.retries + 1);
1664
+ for (let attempt = 0; attempt < attempts; attempt += 1) try {
1665
+ const handle = await fs$1.open(lockPath, "wx");
1666
+ await handle.writeFile(JSON.stringify({
1667
+ pid: process.pid,
1668
+ createdAt: (/* @__PURE__ */ new Date()).toISOString()
1669
+ }, null, 2), "utf8");
1670
+ HELD_LOCKS.set(normalizedFile, {
1671
+ count: 1,
1672
+ handle,
1673
+ lockPath
1674
+ });
1675
+ return {
1676
+ lockPath,
1677
+ release: async () => {
1678
+ const current = HELD_LOCKS.get(normalizedFile);
1679
+ if (!current) return;
1680
+ current.count -= 1;
1681
+ if (current.count > 0) return;
1682
+ HELD_LOCKS.delete(normalizedFile);
1683
+ await current.handle.close().catch(() => void 0);
1684
+ await fs$1.rm(current.lockPath, { force: true }).catch(() => void 0);
1685
+ }
1686
+ };
1687
+ } catch (err) {
1688
+ if (err.code !== "EEXIST") throw err;
1689
+ if (await isStaleLock(lockPath, options.stale)) {
1690
+ await fs$1.rm(lockPath, { force: true }).catch(() => void 0);
1691
+ continue;
1692
+ }
1693
+ if (attempt >= attempts - 1) break;
1694
+ await new Promise((resolve) => setTimeout(resolve, computeDelayMs(options.retries, attempt)));
1695
+ }
1696
+ throw new Error(`file lock timeout for ${normalizedFile}`);
1697
+ }
1698
+ async function withFileLock(filePath, options, fn) {
1699
+ const lock = await acquireFileLock(filePath, options);
1700
+ try {
1701
+ return await fn();
1702
+ } finally {
1703
+ await lock.release();
1704
+ }
1705
+ }
1706
+
1707
+ //#endregion
1708
+ //#region src/infra/json-file.ts
1709
+ function loadJsonFile(pathname) {
1710
+ try {
1711
+ if (!fs.existsSync(pathname)) return;
1712
+ const raw = fs.readFileSync(pathname, "utf8");
1713
+ return JSON.parse(raw);
1714
+ } catch {
1715
+ return;
1716
+ }
1717
+ }
1718
+ function saveJsonFile(pathname, data) {
1719
+ const dir = path.dirname(pathname);
1720
+ if (!fs.existsSync(dir)) fs.mkdirSync(dir, {
1721
+ recursive: true,
1722
+ mode: 448
1723
+ });
1724
+ fs.writeFileSync(pathname, `${JSON.stringify(data, null, 2)}\n`, "utf8");
1725
+ fs.chmodSync(pathname, 384);
1726
+ }
1727
+
1728
+ //#endregion
1729
+ //#region src/agents/cli-credentials.ts
1730
+ const log = createSubsystemLogger("agents/auth-profiles");
1731
+ const QWEN_CLI_CREDENTIALS_RELATIVE_PATH = ".qwen/oauth_creds.json";
1732
+ const MINIMAX_CLI_CREDENTIALS_RELATIVE_PATH = ".minimax/oauth_creds.json";
1733
+ let qwenCliCache = null;
1734
+ let minimaxCliCache = null;
1735
+ function resolveQwenCliCredentialsPath(homeDir) {
1736
+ const baseDir = homeDir ?? resolveUserPath("~");
1737
+ return path.join(baseDir, QWEN_CLI_CREDENTIALS_RELATIVE_PATH);
1738
+ }
1739
+ function resolveMiniMaxCliCredentialsPath(homeDir) {
1740
+ const baseDir = homeDir ?? resolveUserPath("~");
1741
+ return path.join(baseDir, MINIMAX_CLI_CREDENTIALS_RELATIVE_PATH);
1742
+ }
1743
+ function readQwenCliCredentials(options) {
1744
+ return readPortalCliOauthCredentials(resolveQwenCliCredentialsPath(options?.homeDir), "qwen-portal");
1745
+ }
1746
+ function readPortalCliOauthCredentials(credPath, provider) {
1747
+ const raw = loadJsonFile(credPath);
1748
+ if (!raw || typeof raw !== "object") return null;
1749
+ const data = raw;
1750
+ const accessToken = data.access_token;
1751
+ const refreshToken = data.refresh_token;
1752
+ const expiresAt = data.expiry_date;
1753
+ if (typeof accessToken !== "string" || !accessToken) return null;
1754
+ if (typeof refreshToken !== "string" || !refreshToken) return null;
1755
+ if (typeof expiresAt !== "number" || !Number.isFinite(expiresAt)) return null;
1756
+ return {
1757
+ type: "oauth",
1758
+ provider,
1759
+ access: accessToken,
1760
+ refresh: refreshToken,
1761
+ expires: expiresAt
1762
+ };
1763
+ }
1764
+ function readMiniMaxCliCredentials(options) {
1765
+ return readPortalCliOauthCredentials(resolveMiniMaxCliCredentialsPath(options?.homeDir), "minimax-portal");
1766
+ }
1767
+ function readQwenCliCredentialsCached(options) {
1768
+ const ttlMs = options?.ttlMs ?? 0;
1769
+ const now = Date.now();
1770
+ const cacheKey = resolveQwenCliCredentialsPath(options?.homeDir);
1771
+ if (ttlMs > 0 && qwenCliCache && qwenCliCache.cacheKey === cacheKey && now - qwenCliCache.readAt < ttlMs) return qwenCliCache.value;
1772
+ const value = readQwenCliCredentials({ homeDir: options?.homeDir });
1773
+ if (ttlMs > 0) qwenCliCache = {
1774
+ value,
1775
+ readAt: now,
1776
+ cacheKey
1777
+ };
1778
+ return value;
1779
+ }
1780
+ function readMiniMaxCliCredentialsCached(options) {
1781
+ const ttlMs = options?.ttlMs ?? 0;
1782
+ const now = Date.now();
1783
+ const cacheKey = resolveMiniMaxCliCredentialsPath(options?.homeDir);
1784
+ if (ttlMs > 0 && minimaxCliCache && minimaxCliCache.cacheKey === cacheKey && now - minimaxCliCache.readAt < ttlMs) return minimaxCliCache.value;
1785
+ const value = readMiniMaxCliCredentials({ homeDir: options?.homeDir });
1786
+ if (ttlMs > 0) minimaxCliCache = {
1787
+ value,
1788
+ readAt: now,
1789
+ cacheKey
1790
+ };
1791
+ return value;
1792
+ }
1793
+
1794
+ //#endregion
1795
+ //#region src/agents/auth-profiles/external-cli-sync.ts
1796
+ function shallowEqualOAuthCredentials(a, b) {
1797
+ if (!a) return false;
1798
+ if (a.type !== "oauth") return false;
1799
+ return a.provider === b.provider && a.access === b.access && a.refresh === b.refresh && a.expires === b.expires && a.email === b.email && a.enterpriseUrl === b.enterpriseUrl && a.projectId === b.projectId && a.accountId === b.accountId;
1800
+ }
1801
+ function isExternalProfileFresh(cred, now) {
1802
+ if (!cred) return false;
1803
+ if (cred.type !== "oauth" && cred.type !== "token") return false;
1804
+ if (cred.provider !== "qwen-portal" && cred.provider !== "minimax-portal") return false;
1805
+ if (typeof cred.expires !== "number") return true;
1806
+ return cred.expires > now + EXTERNAL_CLI_NEAR_EXPIRY_MS;
1807
+ }
1808
+ /** Sync external CLI credentials into the store for a given provider. */
1809
+ function syncExternalCliCredentialsForProvider(store, profileId, provider, readCredentials, now) {
1810
+ const existing = store.profiles[profileId];
1811
+ const creds = !existing || existing.provider !== provider || !isExternalProfileFresh(existing, now) ? readCredentials() : null;
1812
+ if (!creds) return false;
1813
+ const existingOAuth = existing?.type === "oauth" ? existing : void 0;
1814
+ if ((!existingOAuth || existingOAuth.provider !== provider || existingOAuth.expires <= now || creds.expires > existingOAuth.expires) && !shallowEqualOAuthCredentials(existingOAuth, creds)) {
1815
+ store.profiles[profileId] = creds;
1816
+ log$1.info(`synced ${provider} credentials from external cli`, {
1817
+ profileId,
1818
+ expires: new Date(creds.expires).toISOString()
1819
+ });
1820
+ return true;
1821
+ }
1822
+ return false;
1823
+ }
1824
+ /**
1825
+ * Sync OAuth credentials from external CLI tools (Qwen Code CLI, MiniMax CLI) into the store.
1826
+ *
1827
+ * Returns true if any credentials were updated.
1828
+ */
1829
+ function syncExternalCliCredentials(store) {
1830
+ let mutated = false;
1831
+ const now = Date.now();
1832
+ const existingQwen = store.profiles[QWEN_CLI_PROFILE_ID];
1833
+ const qwenCreds = !existingQwen || existingQwen.provider !== "qwen-portal" || !isExternalProfileFresh(existingQwen, now) ? readQwenCliCredentialsCached({ ttlMs: EXTERNAL_CLI_SYNC_TTL_MS }) : null;
1834
+ if (qwenCreds) {
1835
+ const existing = store.profiles[QWEN_CLI_PROFILE_ID];
1836
+ const existingOAuth = existing?.type === "oauth" ? existing : void 0;
1837
+ if ((!existingOAuth || existingOAuth.provider !== "qwen-portal" || existingOAuth.expires <= now || qwenCreds.expires > existingOAuth.expires) && !shallowEqualOAuthCredentials(existingOAuth, qwenCreds)) {
1838
+ store.profiles[QWEN_CLI_PROFILE_ID] = qwenCreds;
1839
+ mutated = true;
1840
+ log$1.info("synced qwen credentials from qwen cli", {
1841
+ profileId: QWEN_CLI_PROFILE_ID,
1842
+ expires: new Date(qwenCreds.expires).toISOString()
1843
+ });
1844
+ }
1845
+ }
1846
+ if (syncExternalCliCredentialsForProvider(store, MINIMAX_CLI_PROFILE_ID, "minimax-portal", () => readMiniMaxCliCredentialsCached({ ttlMs: EXTERNAL_CLI_SYNC_TTL_MS }), now)) mutated = true;
1847
+ return mutated;
1848
+ }
1849
+
1850
+ //#endregion
1851
+ //#region src/agents/agent-paths.ts
1852
+ function resolveAnimaAgentDir() {
1853
+ const override = process.env.ANIMA_AGENT_DIR?.trim() || process.env.OPENCLAW_AGENT_DIR?.trim() || process.env.PI_CODING_AGENT_DIR?.trim();
1854
+ if (override) return resolveUserPath(override);
1855
+ return resolveUserPath(path.join(resolveStateDir(), "agents", DEFAULT_AGENT_ID, "agent"));
1856
+ }
1857
+
1858
+ //#endregion
1859
+ //#region src/agents/auth-profiles/paths.ts
1860
+ function resolveAuthStorePath(agentDir) {
1861
+ const resolved = resolveUserPath(agentDir ?? resolveAnimaAgentDir());
1862
+ return path.join(resolved, AUTH_PROFILE_FILENAME);
1863
+ }
1864
+ function resolveLegacyAuthStorePath(agentDir) {
1865
+ const resolved = resolveUserPath(agentDir ?? resolveAnimaAgentDir());
1866
+ return path.join(resolved, LEGACY_AUTH_FILENAME);
1867
+ }
1868
+ function resolveAuthStorePathForDisplay(agentDir) {
1869
+ const pathname = resolveAuthStorePath(agentDir);
1870
+ return pathname.startsWith("~") ? pathname : resolveUserPath(pathname);
1871
+ }
1872
+ function ensureAuthStoreFile(pathname) {
1873
+ if (fs.existsSync(pathname)) return;
1874
+ saveJsonFile(pathname, {
1875
+ version: AUTH_STORE_VERSION,
1876
+ profiles: {}
1877
+ });
1878
+ }
1879
+
1880
+ //#endregion
1881
+ //#region src/agents/auth-profiles/store.ts
1882
+ async function updateAuthProfileStoreWithLock(params) {
1883
+ const authPath = resolveAuthStorePath(params.agentDir);
1884
+ ensureAuthStoreFile(authPath);
1885
+ try {
1886
+ return await withFileLock(authPath, AUTH_STORE_LOCK_OPTIONS, async () => {
1887
+ const store = ensureAuthProfileStore(params.agentDir);
1888
+ if (params.updater(store)) saveAuthProfileStore(store, params.agentDir);
1889
+ return store;
1890
+ });
1891
+ } catch {
1892
+ return null;
1893
+ }
1894
+ }
1895
+ function coerceLegacyStore(raw) {
1896
+ if (!raw || typeof raw !== "object") return null;
1897
+ const record = raw;
1898
+ if ("profiles" in record) return null;
1899
+ const entries = {};
1900
+ for (const [key, value] of Object.entries(record)) {
1901
+ if (!value || typeof value !== "object") continue;
1902
+ const typed = value;
1903
+ if (typed.type !== "api_key" && typed.type !== "oauth" && typed.type !== "token") continue;
1904
+ entries[key] = {
1905
+ ...typed,
1906
+ provider: String(typed.provider ?? key)
1907
+ };
1908
+ }
1909
+ return Object.keys(entries).length > 0 ? entries : null;
1910
+ }
1911
+ function coerceAuthStore(raw) {
1912
+ if (!raw || typeof raw !== "object") return null;
1913
+ const record = raw;
1914
+ if (!record.profiles || typeof record.profiles !== "object") return null;
1915
+ const profiles = record.profiles;
1916
+ const normalized = {};
1917
+ for (const [key, value] of Object.entries(profiles)) {
1918
+ if (!value || typeof value !== "object") continue;
1919
+ const typed = value;
1920
+ if (typed.type !== "api_key" && typed.type !== "oauth" && typed.type !== "token") continue;
1921
+ if (!typed.provider) continue;
1922
+ normalized[key] = typed;
1923
+ }
1924
+ const order = record.order && typeof record.order === "object" ? Object.entries(record.order).reduce((acc, [provider, value]) => {
1925
+ if (!Array.isArray(value)) return acc;
1926
+ const list = value.map((entry) => typeof entry === "string" ? entry.trim() : "").filter(Boolean);
1927
+ if (list.length === 0) return acc;
1928
+ acc[provider] = list;
1929
+ return acc;
1930
+ }, {}) : void 0;
1931
+ return {
1932
+ version: Number(record.version ?? AUTH_STORE_VERSION),
1933
+ profiles: normalized,
1934
+ order,
1935
+ lastGood: record.lastGood && typeof record.lastGood === "object" ? record.lastGood : void 0,
1936
+ usageStats: record.usageStats && typeof record.usageStats === "object" ? record.usageStats : void 0
1937
+ };
1938
+ }
1939
+ function mergeRecord(base, override) {
1940
+ if (!base && !override) return;
1941
+ if (!base) return { ...override };
1942
+ if (!override) return { ...base };
1943
+ return {
1944
+ ...base,
1945
+ ...override
1946
+ };
1947
+ }
1948
+ function mergeAuthProfileStores(base, override) {
1949
+ if (Object.keys(override.profiles).length === 0 && !override.order && !override.lastGood && !override.usageStats) return base;
1950
+ return {
1951
+ version: Math.max(base.version, override.version ?? base.version),
1952
+ profiles: {
1953
+ ...base.profiles,
1954
+ ...override.profiles
1955
+ },
1956
+ order: mergeRecord(base.order, override.order),
1957
+ lastGood: mergeRecord(base.lastGood, override.lastGood),
1958
+ usageStats: mergeRecord(base.usageStats, override.usageStats)
1959
+ };
1960
+ }
1961
+ function mergeOAuthFileIntoStore(store) {
1962
+ const oauthRaw = loadJsonFile(resolveOAuthPath());
1963
+ if (!oauthRaw || typeof oauthRaw !== "object") return false;
1964
+ const oauthEntries = oauthRaw;
1965
+ let mutated = false;
1966
+ for (const [provider, creds] of Object.entries(oauthEntries)) {
1967
+ if (!creds || typeof creds !== "object") continue;
1968
+ const profileId = `${provider}:default`;
1969
+ if (store.profiles[profileId]) continue;
1970
+ store.profiles[profileId] = {
1971
+ type: "oauth",
1972
+ provider,
1973
+ ...creds
1974
+ };
1975
+ mutated = true;
1976
+ }
1977
+ return mutated;
1978
+ }
1979
+ function applyLegacyStore(store, legacy) {
1980
+ for (const [provider, cred] of Object.entries(legacy)) {
1981
+ const profileId = `${provider}:default`;
1982
+ if (cred.type === "api_key") {
1983
+ store.profiles[profileId] = {
1984
+ type: "api_key",
1985
+ provider: String(cred.provider ?? provider),
1986
+ key: cred.key,
1987
+ ...cred.email ? { email: cred.email } : {}
1988
+ };
1989
+ continue;
1990
+ }
1991
+ if (cred.type === "token") {
1992
+ store.profiles[profileId] = {
1993
+ type: "token",
1994
+ provider: String(cred.provider ?? provider),
1995
+ token: cred.token,
1996
+ ...typeof cred.expires === "number" ? { expires: cred.expires } : {},
1997
+ ...cred.email ? { email: cred.email } : {}
1998
+ };
1999
+ continue;
2000
+ }
2001
+ store.profiles[profileId] = {
2002
+ type: "oauth",
2003
+ provider: String(cred.provider ?? provider),
2004
+ access: cred.access,
2005
+ refresh: cred.refresh,
2006
+ expires: cred.expires,
2007
+ ...cred.enterpriseUrl ? { enterpriseUrl: cred.enterpriseUrl } : {},
2008
+ ...cred.projectId ? { projectId: cred.projectId } : {},
2009
+ ...cred.accountId ? { accountId: cred.accountId } : {},
2010
+ ...cred.email ? { email: cred.email } : {}
2011
+ };
2012
+ }
2013
+ }
2014
+ function loadAuthProfileStore() {
2015
+ const authPath = resolveAuthStorePath();
2016
+ const asStore = coerceAuthStore(loadJsonFile(authPath));
2017
+ if (asStore) {
2018
+ if (syncExternalCliCredentials(asStore)) saveJsonFile(authPath, asStore);
2019
+ return asStore;
2020
+ }
2021
+ const legacy = coerceLegacyStore(loadJsonFile(resolveLegacyAuthStorePath()));
2022
+ if (legacy) {
2023
+ const store = {
2024
+ version: AUTH_STORE_VERSION,
2025
+ profiles: {}
2026
+ };
2027
+ applyLegacyStore(store, legacy);
2028
+ syncExternalCliCredentials(store);
2029
+ return store;
2030
+ }
2031
+ const store = {
2032
+ version: AUTH_STORE_VERSION,
2033
+ profiles: {}
2034
+ };
2035
+ syncExternalCliCredentials(store);
2036
+ return store;
2037
+ }
2038
+ function loadAuthProfileStoreForAgent(agentDir, _options) {
2039
+ const authPath = resolveAuthStorePath(agentDir);
2040
+ const asStore = coerceAuthStore(loadJsonFile(authPath));
2041
+ if (asStore) {
2042
+ if (syncExternalCliCredentials(asStore)) saveJsonFile(authPath, asStore);
2043
+ return asStore;
2044
+ }
2045
+ if (agentDir) {
2046
+ const mainStore = coerceAuthStore(loadJsonFile(resolveAuthStorePath()));
2047
+ if (mainStore && Object.keys(mainStore.profiles).length > 0) {
2048
+ saveJsonFile(authPath, mainStore);
2049
+ log$1.info("inherited auth-profiles from main agent", { agentDir });
2050
+ return mainStore;
2051
+ }
2052
+ }
2053
+ const legacy = coerceLegacyStore(loadJsonFile(resolveLegacyAuthStorePath(agentDir)));
2054
+ const store = {
2055
+ version: AUTH_STORE_VERSION,
2056
+ profiles: {}
2057
+ };
2058
+ if (legacy) applyLegacyStore(store, legacy);
2059
+ const mergedOAuth = mergeOAuthFileIntoStore(store);
2060
+ const syncedCli = syncExternalCliCredentials(store);
2061
+ const shouldWrite = legacy !== null || mergedOAuth || syncedCli;
2062
+ if (shouldWrite) saveJsonFile(authPath, store);
2063
+ if (shouldWrite && legacy !== null) {
2064
+ const legacyPath = resolveLegacyAuthStorePath(agentDir);
2065
+ try {
2066
+ fs.unlinkSync(legacyPath);
2067
+ } catch (err) {
2068
+ if (err?.code !== "ENOENT") log$1.warn("failed to delete legacy auth.json after migration", {
2069
+ err,
2070
+ legacyPath
2071
+ });
2072
+ }
2073
+ }
2074
+ return store;
2075
+ }
2076
+ function ensureAuthProfileStore(agentDir, options) {
2077
+ const store = loadAuthProfileStoreForAgent(agentDir, options);
2078
+ const authPath = resolveAuthStorePath(agentDir);
2079
+ const mainAuthPath = resolveAuthStorePath();
2080
+ if (!agentDir || authPath === mainAuthPath) return store;
2081
+ return mergeAuthProfileStores(loadAuthProfileStoreForAgent(void 0, options), store);
2082
+ }
2083
+ function saveAuthProfileStore(store, agentDir) {
2084
+ saveJsonFile(resolveAuthStorePath(agentDir), {
2085
+ version: AUTH_STORE_VERSION,
2086
+ profiles: store.profiles,
2087
+ order: store.order ?? void 0,
2088
+ lastGood: store.lastGood ?? void 0,
2089
+ usageStats: store.usageStats ?? void 0
2090
+ });
2091
+ }
2092
+
2093
+ //#endregion
2094
+ //#region src/agents/auth-profiles/profiles.ts
2095
+ async function setAuthProfileOrder(params) {
2096
+ const providerKey = normalizeProviderId(params.provider);
2097
+ const sanitized = params.order && Array.isArray(params.order) ? params.order.map((entry) => String(entry).trim()).filter(Boolean) : [];
2098
+ const deduped = [];
2099
+ for (const entry of sanitized) if (!deduped.includes(entry)) deduped.push(entry);
2100
+ return await updateAuthProfileStoreWithLock({
2101
+ agentDir: params.agentDir,
2102
+ updater: (store) => {
2103
+ store.order = store.order ?? {};
2104
+ if (deduped.length === 0) {
2105
+ if (!store.order[providerKey]) return false;
2106
+ delete store.order[providerKey];
2107
+ if (Object.keys(store.order).length === 0) store.order = void 0;
2108
+ return true;
2109
+ }
2110
+ store.order[providerKey] = deduped;
2111
+ return true;
2112
+ }
2113
+ });
2114
+ }
2115
+ function upsertAuthProfile(params) {
2116
+ const credential = params.credential.type === "api_key" ? {
2117
+ ...params.credential,
2118
+ ...typeof params.credential.key === "string" ? { key: normalizeSecretInput(params.credential.key) } : {}
2119
+ } : params.credential.type === "token" ? {
2120
+ ...params.credential,
2121
+ token: normalizeSecretInput(params.credential.token)
2122
+ } : params.credential;
2123
+ const store = ensureAuthProfileStore(params.agentDir);
2124
+ store.profiles[params.profileId] = credential;
2125
+ saveAuthProfileStore(store, params.agentDir);
2126
+ }
2127
+ async function upsertAuthProfileWithLock(params) {
2128
+ return await updateAuthProfileStoreWithLock({
2129
+ agentDir: params.agentDir,
2130
+ updater: (store) => {
2131
+ store.profiles[params.profileId] = params.credential;
2132
+ return true;
2133
+ }
2134
+ });
2135
+ }
2136
+ function listProfilesForProvider(store, provider) {
2137
+ const providerKey = normalizeProviderId(provider);
2138
+ return Object.entries(store.profiles).filter(([, cred]) => normalizeProviderId(cred.provider) === providerKey).map(([id]) => id);
2139
+ }
2140
+
2141
+ //#endregion
2142
+ //#region src/agents/auth-profiles/repair.ts
2143
+ function getProfileSuffix(profileId) {
2144
+ const idx = profileId.indexOf(":");
2145
+ if (idx < 0) return "";
2146
+ return profileId.slice(idx + 1);
2147
+ }
2148
+ function isEmailLike(value) {
2149
+ const trimmed = value.trim();
2150
+ if (!trimmed) return false;
2151
+ return trimmed.includes("@") && trimmed.includes(".");
2152
+ }
2153
+ function suggestOAuthProfileIdForLegacyDefault(params) {
2154
+ const providerKey = normalizeProviderId(params.provider);
2155
+ if (getProfileSuffix(params.legacyProfileId) !== "default") return null;
2156
+ const legacyCfg = params.cfg?.auth?.profiles?.[params.legacyProfileId];
2157
+ if (legacyCfg && normalizeProviderId(legacyCfg.provider) === providerKey && legacyCfg.mode !== "oauth") return null;
2158
+ const oauthProfiles = listProfilesForProvider(params.store, providerKey).filter((id) => params.store.profiles[id]?.type === "oauth");
2159
+ if (oauthProfiles.length === 0) return null;
2160
+ const configuredEmail = legacyCfg?.email?.trim();
2161
+ if (configuredEmail) {
2162
+ const byEmail = oauthProfiles.find((id) => {
2163
+ const cred = params.store.profiles[id];
2164
+ if (!cred || cred.type !== "oauth") return false;
2165
+ return cred.email?.trim() === configuredEmail || id === `${providerKey}:${configuredEmail}`;
2166
+ });
2167
+ if (byEmail) return byEmail;
2168
+ }
2169
+ const lastGood = params.store.lastGood?.[providerKey] ?? params.store.lastGood?.[params.provider];
2170
+ if (lastGood && oauthProfiles.includes(lastGood)) return lastGood;
2171
+ const nonLegacy = oauthProfiles.filter((id) => id !== params.legacyProfileId);
2172
+ if (nonLegacy.length === 1) return nonLegacy[0] ?? null;
2173
+ const emailLike = nonLegacy.filter((id) => isEmailLike(getProfileSuffix(id)));
2174
+ if (emailLike.length === 1) return emailLike[0] ?? null;
2175
+ return null;
2176
+ }
2177
+ function repairOAuthProfileIdMismatch(params) {
2178
+ const legacyProfileId = params.legacyProfileId ?? `${normalizeProviderId(params.provider)}:default`;
2179
+ const legacyCfg = params.cfg.auth?.profiles?.[legacyProfileId];
2180
+ if (!legacyCfg) return {
2181
+ config: params.cfg,
2182
+ changes: [],
2183
+ migrated: false
2184
+ };
2185
+ if (legacyCfg.mode !== "oauth") return {
2186
+ config: params.cfg,
2187
+ changes: [],
2188
+ migrated: false
2189
+ };
2190
+ if (normalizeProviderId(legacyCfg.provider) !== normalizeProviderId(params.provider)) return {
2191
+ config: params.cfg,
2192
+ changes: [],
2193
+ migrated: false
2194
+ };
2195
+ const toProfileId = suggestOAuthProfileIdForLegacyDefault({
2196
+ cfg: params.cfg,
2197
+ store: params.store,
2198
+ provider: params.provider,
2199
+ legacyProfileId
2200
+ });
2201
+ if (!toProfileId || toProfileId === legacyProfileId) return {
2202
+ config: params.cfg,
2203
+ changes: [],
2204
+ migrated: false
2205
+ };
2206
+ const toCred = params.store.profiles[toProfileId];
2207
+ const toEmail = toCred?.type === "oauth" ? toCred.email?.trim() : void 0;
2208
+ const nextProfiles = { ...params.cfg.auth?.profiles };
2209
+ delete nextProfiles[legacyProfileId];
2210
+ nextProfiles[toProfileId] = {
2211
+ ...legacyCfg,
2212
+ ...toEmail ? { email: toEmail } : {}
2213
+ };
2214
+ const providerKey = normalizeProviderId(params.provider);
2215
+ const nextOrder = (() => {
2216
+ const order = params.cfg.auth?.order;
2217
+ if (!order) return;
2218
+ const resolvedKey = Object.keys(order).find((key) => normalizeProviderId(key) === providerKey);
2219
+ if (!resolvedKey) return order;
2220
+ const existing = order[resolvedKey];
2221
+ if (!Array.isArray(existing)) return order;
2222
+ const replaced = existing.map((id) => id === legacyProfileId ? toProfileId : id).filter((id) => typeof id === "string" && id.trim().length > 0);
2223
+ const deduped = [];
2224
+ for (const entry of replaced) if (!deduped.includes(entry)) deduped.push(entry);
2225
+ return {
2226
+ ...order,
2227
+ [resolvedKey]: deduped
2228
+ };
2229
+ })();
2230
+ return {
2231
+ config: {
2232
+ ...params.cfg,
2233
+ auth: {
2234
+ ...params.cfg.auth,
2235
+ profiles: nextProfiles,
2236
+ ...nextOrder ? { order: nextOrder } : {}
2237
+ }
2238
+ },
2239
+ changes: [`Auth: migrate ${legacyProfileId} → ${toProfileId} (OAuth profile id)`],
2240
+ migrated: true,
2241
+ fromProfileId: legacyProfileId,
2242
+ toProfileId
2243
+ };
2244
+ }
2245
+
2246
+ //#endregion
2247
+ //#region src/agents/auth-profiles/doctor.ts
2248
+ function formatAuthDoctorHint(params) {
2249
+ const providerKey = normalizeProviderId(params.provider);
2250
+ if (providerKey !== "anthropic") return "";
2251
+ const legacyProfileId = params.profileId ?? "anthropic:default";
2252
+ const suggested = suggestOAuthProfileIdForLegacyDefault({
2253
+ cfg: params.cfg,
2254
+ store: params.store,
2255
+ provider: providerKey,
2256
+ legacyProfileId
2257
+ });
2258
+ if (!suggested || suggested === legacyProfileId) return "";
2259
+ const storeOauthProfiles = listProfilesForProvider(params.store, providerKey).filter((id) => params.store.profiles[id]?.type === "oauth").join(", ");
2260
+ const cfgMode = params.cfg?.auth?.profiles?.[legacyProfileId]?.mode;
2261
+ const cfgProvider = params.cfg?.auth?.profiles?.[legacyProfileId]?.provider;
2262
+ return [
2263
+ "Doctor hint (for GitHub issue):",
2264
+ `- provider: ${providerKey}`,
2265
+ `- config: ${legacyProfileId}${cfgProvider || cfgMode ? ` (provider=${cfgProvider ?? "?"}, mode=${cfgMode ?? "?"})` : ""}`,
2266
+ `- auth store oauth profiles: ${storeOauthProfiles || "(none)"}`,
2267
+ `- suggested profile: ${suggested}`,
2268
+ `Fix: run "${formatCliCommand("anima doctor --yes")}"`
2269
+ ].join("\n");
2270
+ }
2271
+
2272
+ //#endregion
2273
+ //#region src/providers/qwen-portal-oauth.ts
2274
+ async function refreshQwenPortalCredentials(_opts) {
2275
+ return null;
2276
+ }
2277
+
2278
+ //#endregion
2279
+ //#region src/agents/chutes-oauth.ts
2280
+ const CHUTES_OAUTH_ISSUER = "https://api.chutes.ai";
2281
+ const CHUTES_AUTHORIZE_ENDPOINT = `${CHUTES_OAUTH_ISSUER}/idp/authorize`;
2282
+ const CHUTES_TOKEN_ENDPOINT = `${CHUTES_OAUTH_ISSUER}/idp/token`;
2283
+ const CHUTES_USERINFO_ENDPOINT = `${CHUTES_OAUTH_ISSUER}/idp/userinfo`;
2284
+ const DEFAULT_EXPIRES_BUFFER_MS = 300 * 1e3;
2285
+ function generateChutesPkce() {
2286
+ const verifier = randomBytes(32).toString("hex");
2287
+ return {
2288
+ verifier,
2289
+ challenge: createHash("sha256").update(verifier).digest("base64url")
2290
+ };
2291
+ }
2292
+ function parseOAuthCallbackInput(input, expectedState) {
2293
+ const trimmed = input.trim();
2294
+ if (!trimmed) return { error: "No input provided" };
2295
+ let url;
2296
+ try {
2297
+ url = new URL(trimmed);
2298
+ } catch {
2299
+ if (!/\s/.test(trimmed) && !trimmed.includes("://") && !trimmed.includes("?") && !trimmed.includes("=")) return { error: "Paste the full redirect URL (must include code + state)." };
2300
+ const qs = trimmed.startsWith("?") ? trimmed : `?${trimmed}`;
2301
+ try {
2302
+ url = new URL(`http://localhost/${qs}`);
2303
+ } catch {
2304
+ return { error: "Paste the full redirect URL (must include code + state)." };
2305
+ }
2306
+ }
2307
+ const code = url.searchParams.get("code")?.trim();
2308
+ const state = url.searchParams.get("state")?.trim();
2309
+ if (!code) return { error: "Missing 'code' parameter in URL" };
2310
+ if (!state) return { error: "Missing 'state' parameter. Paste the full redirect URL." };
2311
+ if (state !== expectedState) return { error: "OAuth state mismatch - possible CSRF attack. Please retry login." };
2312
+ return {
2313
+ code,
2314
+ state
2315
+ };
2316
+ }
2317
+ function coerceExpiresAt(expiresInSeconds, now) {
2318
+ const value = now + Math.max(0, Math.floor(expiresInSeconds)) * 1e3 - DEFAULT_EXPIRES_BUFFER_MS;
2319
+ return Math.max(value, now + 3e4);
2320
+ }
2321
+ async function fetchChutesUserInfo(params) {
2322
+ const response = await (params.fetchFn ?? fetch)(CHUTES_USERINFO_ENDPOINT, { headers: { Authorization: `Bearer ${params.accessToken}` } });
2323
+ if (!response.ok) return null;
2324
+ const data = await response.json();
2325
+ if (!data || typeof data !== "object") return null;
2326
+ return data;
2327
+ }
2328
+ async function exchangeChutesCodeForTokens(params) {
2329
+ const fetchFn = params.fetchFn ?? fetch;
2330
+ const now = params.now ?? Date.now();
2331
+ const body = new URLSearchParams({
2332
+ grant_type: "authorization_code",
2333
+ client_id: params.app.clientId,
2334
+ code: params.code,
2335
+ redirect_uri: params.app.redirectUri,
2336
+ code_verifier: params.codeVerifier
2337
+ });
2338
+ if (params.app.clientSecret) body.set("client_secret", params.app.clientSecret);
2339
+ const response = await fetchFn(CHUTES_TOKEN_ENDPOINT, {
2340
+ method: "POST",
2341
+ headers: { "Content-Type": "application/x-www-form-urlencoded" },
2342
+ body
2343
+ });
2344
+ if (!response.ok) {
2345
+ const text = await response.text();
2346
+ throw new Error(`Chutes token exchange failed: ${text}`);
2347
+ }
2348
+ const data = await response.json();
2349
+ const access = data.access_token?.trim();
2350
+ const refresh = data.refresh_token?.trim();
2351
+ const expiresIn = data.expires_in ?? 0;
2352
+ if (!access) throw new Error("Chutes token exchange returned no access_token");
2353
+ if (!refresh) throw new Error("Chutes token exchange returned no refresh_token");
2354
+ const info = await fetchChutesUserInfo({
2355
+ accessToken: access,
2356
+ fetchFn
2357
+ });
2358
+ return {
2359
+ access,
2360
+ refresh,
2361
+ expires: coerceExpiresAt(expiresIn, now),
2362
+ email: info?.username,
2363
+ accountId: info?.sub,
2364
+ clientId: params.app.clientId
2365
+ };
2366
+ }
2367
+ async function refreshChutesTokens(params) {
2368
+ const fetchFn = params.fetchFn ?? fetch;
2369
+ const now = params.now ?? Date.now();
2370
+ const refreshToken = params.credential.refresh?.trim();
2371
+ if (!refreshToken) throw new Error("Chutes OAuth credential is missing refresh token");
2372
+ const clientId = params.credential.clientId?.trim() ?? process.env.CHUTES_CLIENT_ID?.trim();
2373
+ if (!clientId) throw new Error("Missing CHUTES_CLIENT_ID for Chutes OAuth refresh (set env var or re-auth).");
2374
+ const clientSecret = process.env.CHUTES_CLIENT_SECRET?.trim() || void 0;
2375
+ const body = new URLSearchParams({
2376
+ grant_type: "refresh_token",
2377
+ client_id: clientId,
2378
+ refresh_token: refreshToken
2379
+ });
2380
+ if (clientSecret) body.set("client_secret", clientSecret);
2381
+ const response = await fetchFn(CHUTES_TOKEN_ENDPOINT, {
2382
+ method: "POST",
2383
+ headers: { "Content-Type": "application/x-www-form-urlencoded" },
2384
+ body
2385
+ });
2386
+ if (!response.ok) {
2387
+ const text = await response.text();
2388
+ throw new Error(`Chutes token refresh failed: ${text}`);
2389
+ }
2390
+ const data = await response.json();
2391
+ const access = data.access_token?.trim();
2392
+ const newRefresh = data.refresh_token?.trim();
2393
+ const expiresIn = data.expires_in ?? 0;
2394
+ if (!access) throw new Error("Chutes token refresh returned no access_token");
2395
+ return {
2396
+ ...params.credential,
2397
+ access,
2398
+ refresh: newRefresh || refreshToken,
2399
+ expires: coerceExpiresAt(expiresIn, now),
2400
+ clientId
2401
+ };
2402
+ }
2403
+
2404
+ //#endregion
2405
+ //#region src/agents/auth-profiles/oauth.ts
2406
+ const OAUTH_PROVIDER_IDS = new Set(getOAuthProviders().map((provider) => provider.id));
2407
+ const isOAuthProvider = (provider) => OAUTH_PROVIDER_IDS.has(provider);
2408
+ const resolveOAuthProvider = (provider) => isOAuthProvider(provider) ? provider : null;
2409
+ function buildOAuthApiKey(provider, credentials) {
2410
+ return provider === "google-gemini-cli" || provider === "google-antigravity" ? JSON.stringify({
2411
+ token: credentials.access,
2412
+ projectId: credentials.projectId
2413
+ }) : credentials.access;
2414
+ }
2415
+ async function refreshOAuthTokenWithLock(params) {
2416
+ const authPath = resolveAuthStorePath(params.agentDir);
2417
+ ensureAuthStoreFile(authPath);
2418
+ return await withFileLock(authPath, AUTH_STORE_LOCK_OPTIONS, async () => {
2419
+ const store = ensureAuthProfileStore(params.agentDir);
2420
+ const cred = store.profiles[params.profileId];
2421
+ if (!cred || cred.type !== "oauth") return null;
2422
+ if (Date.now() < cred.expires) return {
2423
+ apiKey: buildOAuthApiKey(cred.provider, cred),
2424
+ newCredentials: cred
2425
+ };
2426
+ const oauthCreds = { [cred.provider]: cred };
2427
+ const result = String(cred.provider) === "chutes" ? await (async () => {
2428
+ const newCredentials = await refreshChutesTokens({ credential: cred });
2429
+ return {
2430
+ apiKey: newCredentials.access,
2431
+ newCredentials
2432
+ };
2433
+ })() : String(cred.provider) === "qwen-portal" ? await (async () => {
2434
+ const newCredentials = await refreshQwenPortalCredentials(cred);
2435
+ return {
2436
+ apiKey: newCredentials.access,
2437
+ newCredentials
2438
+ };
2439
+ })() : await (async () => {
2440
+ const oauthProvider = resolveOAuthProvider(cred.provider);
2441
+ if (!oauthProvider) return null;
2442
+ return await getOAuthApiKey(oauthProvider, oauthCreds);
2443
+ })();
2444
+ if (!result) return null;
2445
+ store.profiles[params.profileId] = {
2446
+ ...cred,
2447
+ ...result.newCredentials,
2448
+ type: "oauth"
2449
+ };
2450
+ saveAuthProfileStore(store, params.agentDir);
2451
+ return result;
2452
+ });
2453
+ }
2454
+ async function tryResolveOAuthProfile(params) {
2455
+ const { cfg, store, profileId } = params;
2456
+ const cred = store.profiles[profileId];
2457
+ if (!cred || cred.type !== "oauth") return null;
2458
+ const profileConfig = cfg?.auth?.profiles?.[profileId];
2459
+ if (profileConfig && profileConfig.provider !== cred.provider) return null;
2460
+ if (profileConfig && profileConfig.mode !== cred.type) return null;
2461
+ if (Date.now() < cred.expires) return {
2462
+ apiKey: buildOAuthApiKey(cred.provider, cred),
2463
+ provider: cred.provider,
2464
+ email: cred.email
2465
+ };
2466
+ const refreshed = await refreshOAuthTokenWithLock({
2467
+ profileId,
2468
+ agentDir: params.agentDir
2469
+ });
2470
+ if (!refreshed) return null;
2471
+ return {
2472
+ apiKey: refreshed.apiKey,
2473
+ provider: cred.provider,
2474
+ email: cred.email
2475
+ };
2476
+ }
2477
+ async function resolveApiKeyForProfile(params) {
2478
+ const { cfg, store, profileId } = params;
2479
+ const cred = store.profiles[profileId];
2480
+ if (!cred) return null;
2481
+ const profileConfig = cfg?.auth?.profiles?.[profileId];
2482
+ if (profileConfig && profileConfig.provider !== cred.provider) return null;
2483
+ if (profileConfig && profileConfig.mode !== cred.type) {
2484
+ if (!(profileConfig.mode === "oauth" && cred.type === "token")) return null;
2485
+ }
2486
+ if (cred.type === "api_key") {
2487
+ const key = cred.key?.trim();
2488
+ if (!key) return null;
2489
+ return {
2490
+ apiKey: key,
2491
+ provider: cred.provider,
2492
+ email: cred.email
2493
+ };
2494
+ }
2495
+ if (cred.type === "token") {
2496
+ const token = cred.token?.trim();
2497
+ if (!token) return null;
2498
+ if (typeof cred.expires === "number" && Number.isFinite(cred.expires) && cred.expires > 0 && Date.now() >= cred.expires) return null;
2499
+ return {
2500
+ apiKey: token,
2501
+ provider: cred.provider,
2502
+ email: cred.email
2503
+ };
2504
+ }
2505
+ if (Date.now() < cred.expires) return {
2506
+ apiKey: buildOAuthApiKey(cred.provider, cred),
2507
+ provider: cred.provider,
2508
+ email: cred.email
2509
+ };
2510
+ try {
2511
+ const result = await refreshOAuthTokenWithLock({
2512
+ profileId,
2513
+ agentDir: params.agentDir
2514
+ });
2515
+ if (!result) return null;
2516
+ return {
2517
+ apiKey: result.apiKey,
2518
+ provider: cred.provider,
2519
+ email: cred.email
2520
+ };
2521
+ } catch (error) {
2522
+ const refreshedStore = ensureAuthProfileStore(params.agentDir);
2523
+ const refreshed = refreshedStore.profiles[profileId];
2524
+ if (refreshed?.type === "oauth" && Date.now() < refreshed.expires) return {
2525
+ apiKey: buildOAuthApiKey(refreshed.provider, refreshed),
2526
+ provider: refreshed.provider,
2527
+ email: refreshed.email ?? cred.email
2528
+ };
2529
+ const fallbackProfileId = suggestOAuthProfileIdForLegacyDefault({
2530
+ cfg,
2531
+ store: refreshedStore,
2532
+ provider: cred.provider,
2533
+ legacyProfileId: profileId
2534
+ });
2535
+ if (fallbackProfileId && fallbackProfileId !== profileId) try {
2536
+ const fallbackResolved = await tryResolveOAuthProfile({
2537
+ cfg,
2538
+ store: refreshedStore,
2539
+ profileId: fallbackProfileId,
2540
+ agentDir: params.agentDir
2541
+ });
2542
+ if (fallbackResolved) return fallbackResolved;
2543
+ } catch {}
2544
+ if (params.agentDir) try {
2545
+ const mainCred = ensureAuthProfileStore(void 0).profiles[profileId];
2546
+ if (mainCred?.type === "oauth" && Date.now() < mainCred.expires) {
2547
+ refreshedStore.profiles[profileId] = { ...mainCred };
2548
+ saveAuthProfileStore(refreshedStore, params.agentDir);
2549
+ log$1.info("inherited fresh OAuth credentials from main agent", {
2550
+ profileId,
2551
+ agentDir: params.agentDir,
2552
+ expires: new Date(mainCred.expires).toISOString()
2553
+ });
2554
+ return {
2555
+ apiKey: buildOAuthApiKey(mainCred.provider, mainCred),
2556
+ provider: mainCred.provider,
2557
+ email: mainCred.email
2558
+ };
2559
+ }
2560
+ } catch {}
2561
+ const message = error instanceof Error ? error.message : String(error);
2562
+ const hint = formatAuthDoctorHint({
2563
+ cfg,
2564
+ store: refreshedStore,
2565
+ provider: cred.provider,
2566
+ profileId
2567
+ });
2568
+ throw new Error(`OAuth token refresh failed for ${cred.provider}: ${message}. Please try again or re-authenticate.` + (hint ? `\n\n${hint}` : ""), { cause: error });
2569
+ }
2570
+ }
2571
+
2572
+ //#endregion
2573
+ //#region src/agents/auth-profiles/usage.ts
2574
+ function resolveProfileUnusableUntil$1(stats) {
2575
+ const values = [stats.cooldownUntil, stats.disabledUntil].filter((value) => typeof value === "number").filter((value) => Number.isFinite(value) && value > 0);
2576
+ if (values.length === 0) return null;
2577
+ return Math.max(...values);
2578
+ }
2579
+ /**
2580
+ * Check if a profile is currently in cooldown (due to rate limiting or errors).
2581
+ */
2582
+ function isProfileInCooldown(store, profileId) {
2583
+ const stats = store.usageStats?.[profileId];
2584
+ if (!stats) return false;
2585
+ const unusableUntil = resolveProfileUnusableUntil$1(stats);
2586
+ return unusableUntil ? Date.now() < unusableUntil : false;
2587
+ }
2588
+ function resolveProfileUnusableUntilForDisplay(store, profileId) {
2589
+ const stats = store.usageStats?.[profileId];
2590
+ if (!stats) return null;
2591
+ return resolveProfileUnusableUntil$1(stats);
2592
+ }
2593
+
2594
+ //#endregion
2595
+ //#region src/agents/auth-profiles/order.ts
2596
+ function resolveProfileUnusableUntil(stats) {
2597
+ const values = [stats.cooldownUntil, stats.disabledUntil].filter((value) => typeof value === "number").filter((value) => Number.isFinite(value) && value > 0);
2598
+ if (values.length === 0) return null;
2599
+ return Math.max(...values);
2600
+ }
2601
+ function resolveAuthProfileOrder(params) {
2602
+ const { cfg, store, provider, preferredProfile } = params;
2603
+ const providerKey = normalizeProviderId(provider);
2604
+ const now = Date.now();
2605
+ const storedOrder = (() => {
2606
+ const order = store.order;
2607
+ if (!order) return;
2608
+ for (const [key, value] of Object.entries(order)) if (normalizeProviderId(key) === providerKey) return value;
2609
+ })();
2610
+ const configuredOrder = (() => {
2611
+ const order = cfg?.auth?.order;
2612
+ if (!order) return;
2613
+ for (const [key, value] of Object.entries(order)) if (normalizeProviderId(key) === providerKey) return value;
2614
+ })();
2615
+ const explicitOrder = storedOrder ?? configuredOrder;
2616
+ const explicitProfiles = cfg?.auth?.profiles ? Object.entries(cfg.auth.profiles).filter(([, profile]) => normalizeProviderId(profile.provider) === providerKey).map(([profileId]) => profileId) : [];
2617
+ const baseOrder = explicitOrder ?? (explicitProfiles.length > 0 ? explicitProfiles : listProfilesForProvider(store, providerKey));
2618
+ if (baseOrder.length === 0) return [];
2619
+ const filtered = baseOrder.filter((profileId) => {
2620
+ const cred = store.profiles[profileId];
2621
+ if (!cred) return false;
2622
+ if (normalizeProviderId(cred.provider) !== providerKey) return false;
2623
+ const profileConfig = cfg?.auth?.profiles?.[profileId];
2624
+ if (profileConfig) {
2625
+ if (normalizeProviderId(profileConfig.provider) !== providerKey) return false;
2626
+ if (profileConfig.mode !== cred.type) {
2627
+ if (!(profileConfig.mode === "oauth" && cred.type === "token")) return false;
2628
+ }
2629
+ }
2630
+ if (cred.type === "api_key") return Boolean(cred.key?.trim());
2631
+ if (cred.type === "token") {
2632
+ if (!cred.token?.trim()) return false;
2633
+ if (typeof cred.expires === "number" && Number.isFinite(cred.expires) && cred.expires > 0 && now >= cred.expires) return false;
2634
+ return true;
2635
+ }
2636
+ if (cred.type === "oauth") return Boolean(cred.access?.trim() || cred.refresh?.trim());
2637
+ return false;
2638
+ });
2639
+ const deduped = [];
2640
+ for (const entry of filtered) if (!deduped.includes(entry)) deduped.push(entry);
2641
+ if (explicitOrder && explicitOrder.length > 0) {
2642
+ const available = [];
2643
+ const inCooldown = [];
2644
+ for (const profileId of deduped) {
2645
+ const cooldownUntil = resolveProfileUnusableUntil(store.usageStats?.[profileId] ?? {}) ?? 0;
2646
+ if (typeof cooldownUntil === "number" && Number.isFinite(cooldownUntil) && cooldownUntil > 0 && now < cooldownUntil) inCooldown.push({
2647
+ profileId,
2648
+ cooldownUntil
2649
+ });
2650
+ else available.push(profileId);
2651
+ }
2652
+ const cooldownSorted = inCooldown.toSorted((a, b) => a.cooldownUntil - b.cooldownUntil).map((entry) => entry.profileId);
2653
+ const ordered = [...available, ...cooldownSorted];
2654
+ if (preferredProfile && ordered.includes(preferredProfile)) return [preferredProfile, ...ordered.filter((e) => e !== preferredProfile)];
2655
+ return ordered;
2656
+ }
2657
+ const sorted = orderProfilesByMode(deduped, store);
2658
+ if (preferredProfile && sorted.includes(preferredProfile)) return [preferredProfile, ...sorted.filter((e) => e !== preferredProfile)];
2659
+ return sorted;
2660
+ }
2661
+ function orderProfilesByMode(order, store) {
2662
+ const now = Date.now();
2663
+ const available = [];
2664
+ const inCooldown = [];
2665
+ for (const profileId of order) if (isProfileInCooldown(store, profileId)) inCooldown.push(profileId);
2666
+ else available.push(profileId);
2667
+ const sorted = available.map((profileId) => {
2668
+ const type = store.profiles[profileId]?.type;
2669
+ return {
2670
+ profileId,
2671
+ typeScore: type === "oauth" ? 0 : type === "token" ? 1 : type === "api_key" ? 2 : 3,
2672
+ lastUsed: store.usageStats?.[profileId]?.lastUsed ?? 0
2673
+ };
2674
+ }).toSorted((a, b) => {
2675
+ if (a.typeScore !== b.typeScore) return a.typeScore - b.typeScore;
2676
+ return a.lastUsed - b.lastUsed;
2677
+ }).map((entry) => entry.profileId);
2678
+ const cooldownSorted = inCooldown.map((profileId) => ({
2679
+ profileId,
2680
+ cooldownUntil: resolveProfileUnusableUntil(store.usageStats?.[profileId] ?? {}) ?? now
2681
+ })).toSorted((a, b) => a.cooldownUntil - b.cooldownUntil).map((entry) => entry.profileId);
2682
+ return [...sorted, ...cooldownSorted];
2683
+ }
2684
+
2685
+ //#endregion
2686
+ //#region src/agents/auth-profiles.ts
2687
+ var auth_profiles_exports = /* @__PURE__ */ __exportAll({ ensureAuthProfileStore: () => ensureAuthProfileStore });
2688
+
2689
+ //#endregion
2690
+ export { SYNTHETIC_DEFAULT_MODEL_REF as $, normalizeModelRef as A, CODEX_CLI_PROFILE_ID as At, QIANFAN_BASE_URL as B, withFileLock as C, buildCloudflareAiGatewayModelDefinition as Ct, getModelRefStatus as D, DEFAULT_PROVIDER as Dt, buildModelAliasIndex as E, DEFAULT_MODEL as Et, resolveConfiguredModelRef as F, VENICE_BASE_URL as G, XIAOMI_DEFAULT_MODEL_ID as H, resolveDefaultModelForAgent as I, buildVeniceModelDefinition as J, VENICE_DEFAULT_MODEL_REF as K, resolveHooksGmailModel as L, parseModelRef as M, resolveAllowedModelRef as N, isCliProvider as O, resolveAuthProfileDisplayLabel as Ot, resolveAllowlistModelKey as P, SYNTHETIC_BASE_URL as Q, resolveModelRefFromString as R, saveJsonFile as S, CLOUDFLARE_AI_GATEWAY_DEFAULT_MODEL_REF as St, buildConfiguredAllowlistKeys as T, DEFAULT_CONTEXT_TOKENS as Tt, buildQianfanProvider as U, QIANFAN_DEFAULT_MODEL_ID as V, buildXiaomiProvider as W, TOGETHER_MODEL_CATALOG as X, TOGETHER_BASE_URL as Y, buildTogetherModelDefinition as Z, updateAuthProfileStoreWithLock as _, HUGGINGFACE_BASE_URL as _t, resolveApiKeyForProfile as a, resolveApiKeyForProvider as at, resolveAnimaAgentDir as b, discoverHuggingfaceModels as bt, generateChutesPkce as c, resolveModelAuthMode as ct, listProfilesForProvider as d, getShellEnvAppliedKeys as dt, SYNTHETIC_MODEL_CATALOG as et, setAuthProfileOrder as f, getShellPathFromLoginShell as ft, loadAuthProfileStore as g, shouldEnableShellEnvFallback as gt, ensureAuthProfileStore as h, shouldDeferShellEnvFallback as ht, resolveProfileUnusableUntilForDisplay as i, requireApiKey as it, normalizeProviderId as j, modelKey as k, CLAUDE_CLI_PROFILE_ID as kt, parseOAuthCallbackInput as l, normalizeOptionalSecretInput as lt, upsertAuthProfileWithLock as m, resolveShellEnvFallbackTimeoutMs as mt, resolveAuthProfileOrder as n, getApiKeyForModel as nt, CHUTES_AUTHORIZE_ENDPOINT as o, resolveAwsSdkEnvVarName as ot, upsertAuthProfile as p, loadShellEnvFallback as pt, VENICE_MODEL_CATALOG as q, isProfileInCooldown as r, getCustomProviderApiKey as rt, exchangeChutesCodeForTokens as s, resolveEnvApiKey as st, auth_profiles_exports as t, buildSyntheticModelDefinition as tt, repairOAuthProfileIdMismatch as u, normalizeSecretInput as ut, resolveAuthStorePath as v, HUGGINGFACE_MODEL_CATALOG as vt, buildAllowedModelSet as w, resolveCloudflareAiGatewayBaseUrl as wt, loadJsonFile as x, isHuggingfacePolicyLocked as xt, resolveAuthStorePathForDisplay as y, buildHuggingfaceModelDefinition as yt, resolveThinkingDefault as z };