winclaw 2026.3.21 → 2026.3.23

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 (201) hide show
  1. package/dist/{agents-_gcdm-kb.js → agents-Dc_S8rZ8.js} +4 -4
  2. package/dist/{agents.config-BkgsJJng.js → agents.config-BC6TW53i.js} +1 -1
  3. package/dist/{agents.config-Bw1hbsLj.js → agents.config-ZESYvAuZ.js} +1 -1
  4. package/dist/{auth-choice-sfRzFTug.js → auth-choice-CHCEiG_5.js} +1 -1
  5. package/dist/{auth-choice-i771W71t.js → auth-choice-CSZQYOpt.js} +1 -1
  6. package/dist/{banner-C-01b-if.js → banner-C3BSkrQk.js} +1 -1
  7. package/dist/build-info.json +2 -2
  8. package/dist/bundled/boot-md/handler.js +1 -1
  9. package/dist/bundled/session-memory/handler.js +1 -1
  10. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  11. package/dist/{channel-options-BAvRIwTX.js → channel-options-DG60shRM.js} +1 -1
  12. package/dist/{channel-options-it9Z3dNk.js → channel-options-XEKts1bm.js} +1 -1
  13. package/dist/{channel-web-BiIs0cCf.js → channel-web-XARrFQNi.js} +1 -1
  14. package/dist/{channel-web-CJ_jcZSw.js → channel-web-_2_SqIZ4.js} +1 -1
  15. package/dist/{channels-cli-CNbBNhlO.js → channels-cli-BEXYziVz.js} +6 -6
  16. package/dist/{channels-cli-miFqkj2-.js → channels-cli-ZssJjBmG.js} +6 -6
  17. package/dist/{cli-Da0pNyXg.js → cli-BZZG4J_j.js} +1 -1
  18. package/dist/{cli-BhZvhDWg.js → cli-CY_Senie.js} +1 -1
  19. package/dist/{command-registry-m8nfRV-J.js → command-registry-CWxe1f-O.js} +9 -9
  20. package/dist/{completion-cli-B-8mTxbh.js → completion-cli-BKoxA3-3.js} +2 -2
  21. package/dist/{completion-cli-c9ogb7DR.js → completion-cli-DisKMPGI.js} +1 -1
  22. package/dist/{config-cli-D2natFSq.js → config-cli-Bfwm9TCS.js} +1 -1
  23. package/dist/{config-cli-1ecjxVfC.js → config-cli-FMUUH4Ti.js} +1 -1
  24. package/dist/{configure-B-tOY-wa.js → configure-BJxly9Yt.js} +3 -3
  25. package/dist/{configure-BgqQPO5L.js → configure-DarTg7E_.js} +3 -3
  26. package/dist/{deps-send-whatsapp.runtime-BJV7VcRP.js → deps-send-whatsapp.runtime-CeFobiyN.js} +2 -2
  27. package/dist/{deps-send-whatsapp.runtime-DlmzDIzc.js → deps-send-whatsapp.runtime-D7OYrbTL.js} +2 -2
  28. package/dist/{deps-send-whatsapp.runtime-Dflrvnq-.js → deps-send-whatsapp.runtime-Dk3bVJzk.js} +3 -3
  29. package/dist/{deps-send-whatsapp.runtime-BHJLeHSL.js → deps-send-whatsapp.runtime-iiQJpw-8.js} +3 -3
  30. package/dist/{doctor-completion-DEdT-_9v.js → doctor-completion-BtQY4Eaa.js} +1 -1
  31. package/dist/{doctor-completion-C3SXIoSh.js → doctor-completion-t3rdrQev.js} +1 -1
  32. package/dist/entry.js +2 -2
  33. package/dist/extensionAPI.js +1 -1
  34. package/dist/{gateway-cli-C_4mlmOW.js → gateway-cli-BeABpkZ1.js} +11 -11
  35. package/dist/{gateway-cli-CL5LDNmu.js → gateway-cli-Juhp3APs.js} +11 -11
  36. package/dist/{health-C5a0wlfE.js → health-8quueFaP.js} +1 -1
  37. package/dist/{health-CqiwN5ZR.js → health-BoOzWD1m.js} +1 -1
  38. package/dist/{hooks-cli-C79J_WG7.js → hooks-cli-B475HcKz.js} +2 -2
  39. package/dist/{hooks-cli-DDWnA5Zx.js → hooks-cli-BcKW3j9V.js} +2 -2
  40. package/dist/index.js +6 -6
  41. package/dist/llm-slug-generator.js +1 -1
  42. package/dist/{models-Do96D4zT.js → models-FzoA9YFe.js} +2 -2
  43. package/dist/{models-cli-pblTciC_.js → models-cli-B9FoteUK.js} +3 -3
  44. package/dist/{models-cli-DOfsOmW1.js → models-cli-DPCSWjYD.js} +2 -2
  45. package/dist/{npm-resolution-Bd8dB7rI.js → npm-resolution-DUcSV3Er.js} +1 -1
  46. package/dist/{npm-resolution-DE7xcGkg.js → npm-resolution-Kay_MP5U.js} +1 -1
  47. package/dist/{onboard-CReGZ3G9.js → onboard-DSE0sFKG.js} +2 -2
  48. package/dist/{onboard-channels-DvpqJP6s.js → onboard-channels-DleZdwBe.js} +1 -1
  49. package/dist/{onboard-channels-ljMkIe7O.js → onboard-channels-DuQfbGvH.js} +1 -1
  50. package/dist/{onboard-CXyqQtlq.js → onboard-lgDkrSqS.js} +2 -2
  51. package/dist/{onboarding-BZWA8Nqq.js → onboarding-D713_nF-.js} +3 -3
  52. package/dist/{onboarding-CoH1hPY0.js → onboarding-tBrb0kFS.js} +3 -3
  53. package/dist/{onboarding.finalize-B1qRlV6H.js → onboarding.finalize-DenRnQtC.js} +5 -5
  54. package/dist/{onboarding.finalize-DzRWtkmA.js → onboarding.finalize-femvpEYf.js} +6 -6
  55. package/dist/{pi-embedded-DUO1eQ_J.js → pi-embedded-CPqoXbPh.js} +15 -15
  56. package/dist/{pi-embedded-xAf-RVi5.js → pi-embedded-yo67-7fx.js} +15 -15
  57. package/dist/{plugin-registry-DckyegZB.js → plugin-registry-ByrPvIy8.js} +1 -1
  58. package/dist/{plugin-registry-Cb_XRQUR.js → plugin-registry-C_HMboob.js} +1 -1
  59. package/dist/plugin-sdk/{channel-web-CfZNFYCV.js → channel-web-CZNn3YpA.js} +1 -1
  60. package/dist/plugin-sdk/{channel-web-D02gHjxz.js → channel-web-ut6coWO5.js} +1 -1
  61. package/dist/plugin-sdk/compat.js +50 -50
  62. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-DJlWl-wv.js → deps-send-whatsapp.runtime-7Y4jFeSR.js} +3 -3
  63. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-BxQ5tZO2.js → deps-send-whatsapp.runtime-BYqY0Q9J.js} +3 -3
  64. package/dist/plugin-sdk/imessage.js +2 -2
  65. package/dist/plugin-sdk/index.js +2 -2
  66. package/dist/plugin-sdk/{reply-BEBnUyG7.js → reply-CHTGOm7N.js} +15 -15
  67. package/dist/plugin-sdk/{reply-Cx_4UtvJ.js → reply-CbZPef0p.js} +15 -15
  68. package/dist/plugin-sdk/slack.js +2 -2
  69. package/dist/plugin-sdk/{slash-dispatch.runtime-C74v1zF9.js → slash-dispatch.runtime-CU94t3bC.js} +1 -1
  70. package/dist/plugin-sdk/{slash-dispatch.runtime-DN7TWAWh.js → slash-dispatch.runtime-fens4sxk.js} +1 -1
  71. package/dist/plugin-sdk/{subagent-registry-runtime-CprGCjIU.js → subagent-registry-runtime-CwlC6o7G.js} +1 -1
  72. package/dist/plugin-sdk/{subagent-registry-runtime-9CC9qb9s.js → subagent-registry-runtime-DE56KyD-.js} +1 -1
  73. package/dist/plugin-sdk/telegram.js +2 -2
  74. package/dist/plugin-sdk/{web-D9wJfMr_.js → web-DSbskSAb.js} +2 -2
  75. package/dist/plugin-sdk/{web-D0OZnnn7.js → web-Oo_Fd7RA.js} +2 -2
  76. package/dist/plugin-sdk/whatsapp.js +2 -2
  77. package/dist/plugin-sdk/zalouser.js +2 -2
  78. package/dist/{plugins-cli-BWCjQEMr.js → plugins-cli-CI8xpqVq.js} +2 -2
  79. package/dist/{plugins-cli-C6Oo9R6E.js → plugins-cli-DQCpV91t.js} +2 -2
  80. package/dist/{program-CEJ6CsoR.js → program-N2SbF1HK.js} +7 -7
  81. package/dist/{program-context-EXWtPjXg.js → program-context-DMg-_LjD.js} +17 -17
  82. package/dist/{prompt-select-styled-D-f3R2mt.js → prompt-select-styled-BehogMCm.js} +4 -4
  83. package/dist/{prompt-select-styled-B_AHrNLY.js → prompt-select-styled-pMhNy-Rt.js} +4 -4
  84. package/dist/{provider-auth-helpers-CN4iPBfs.js → provider-auth-helpers-4bL3VgNE.js} +1 -1
  85. package/dist/{provider-auth-helpers-CiXbjGH-.js → provider-auth-helpers-Rpp9Sh_y.js} +1 -1
  86. package/dist/{push-apns-D7Si-92v.js → push-apns-CGUAuXgJ.js} +1 -1
  87. package/dist/{push-apns-BEZdCQsM.js → push-apns-hyDzrrIU.js} +1 -1
  88. package/dist/{register.agent-BDosszM8.js → register.agent-CFrG4s6H.js} +6 -6
  89. package/dist/{register.agent-BjxrirHi.js → register.agent-CTNWQCtt.js} +7 -7
  90. package/dist/{register.configure-MduIRRMt.js → register.configure-DIKLgW8P.js} +7 -7
  91. package/dist/{register.configure-C0B9vKwT.js → register.configure-Di8Uh5GB.js} +7 -7
  92. package/dist/{register.maintenance-CfnzY1OX.js → register.maintenance-Cc675Yxz.js} +7 -7
  93. package/dist/{register.maintenance-BfdiJ7KX.js → register.maintenance-GewLmA3i.js} +8 -8
  94. package/dist/{register.message-D4VYaBqq.js → register.message-BI_R0TJs.js} +2 -2
  95. package/dist/{register.message-BszoJEBm.js → register.message-CtBJO09g.js} +2 -2
  96. package/dist/{register.onboard-CbJU4Y-3.js → register.onboard-45htf4DA.js} +2 -2
  97. package/dist/{register.onboard-CjuT9fKW.js → register.onboard-Jv--xCKB.js} +2 -2
  98. package/dist/{register.setup-DZzf7J04.js → register.setup-Bm99k2pm.js} +2 -2
  99. package/dist/{register.setup-BTTBsCT0.js → register.setup-CqrPLejH.js} +2 -2
  100. package/dist/{register.status-health-sessions-C3Ji8sqv.js → register.status-health-sessions-BBDVWYvb.js} +3 -3
  101. package/dist/{register.status-health-sessions-BKcFfUR6.js → register.status-health-sessions-BmpJln2_.js} +3 -3
  102. package/dist/{register.subclis-2iN-TxPh.js → register.subclis-4LlGcEld.js} +9 -9
  103. package/dist/{reply-KTubTl9h.js → reply-a2GVvnP2.js} +15 -15
  104. package/dist/{run-main-BEtPk_9z.js → run-main-B3eIQkhk.js} +14 -14
  105. package/dist/{server-node-events-BozhXo6J.js → server-node-events-Bn6C-kB6.js} +2 -2
  106. package/dist/{server-node-events-CFcRS-lD.js → server-node-events-CbUk95yd.js} +2 -2
  107. package/dist/{slash-dispatch.runtime-D5Cl7j1v.js → slash-dispatch.runtime-B4quYJn4.js} +1 -1
  108. package/dist/{slash-dispatch.runtime-B0OIPdp3.js → slash-dispatch.runtime-BBH2jQsL.js} +1 -1
  109. package/dist/{slash-dispatch.runtime-DDLolsGY.js → slash-dispatch.runtime-BLQZdvZW.js} +1 -1
  110. package/dist/{slash-dispatch.runtime-DtN2NmXJ.js → slash-dispatch.runtime-wBORF-o1.js} +1 -1
  111. package/dist/{status-B5hylgEQ.js → status-BqpyCRc4.js} +2 -2
  112. package/dist/{status-DClHhy30.js → status-DHIaRvxs.js} +2 -2
  113. package/dist/{subagent-registry-iD-ynHA9.js → subagent-registry-CRAr7csi.js} +15 -15
  114. package/dist/{subagent-registry-runtime-DfMDVaOY.js → subagent-registry-runtime-BfYm3d-n.js} +1 -1
  115. package/dist/{subagent-registry-runtime-CdEy9DKy.js → subagent-registry-runtime-CnPoAflv.js} +1 -1
  116. package/dist/{subagent-registry-runtime-Cv_Xt2cx.js → subagent-registry-runtime-DQb8qzq2.js} +1 -1
  117. package/dist/{subagent-registry-runtime-LH0OBaWN.js → subagent-registry-runtime-sMbEjW_q.js} +1 -1
  118. package/dist/{update-cli-C1nysDmM.js → update-cli-Bk3xkEPl.js} +8 -8
  119. package/dist/{update-cli-Dj_9Bokl.js → update-cli-G1w1hdg4.js} +7 -7
  120. package/dist/{update-runner-BpzbDTnQ.js → update-runner-CgS5D8t8.js} +1 -1
  121. package/dist/{update-runner-BUoHYjl8.js → update-runner-TyDM6-ms.js} +1 -1
  122. package/dist/{web-DxHq9RWt.js → web-7w_9CsnG.js} +2 -2
  123. package/dist/{web-Dbqs3hbC.js → web-B790MBdK.js} +1 -1
  124. package/dist/{web-CodV11ZY.js → web-BPiSo--I.js} +1 -1
  125. package/dist/{web-YBvuT4WS.js → web-BmYQFz4q.js} +2 -2
  126. package/package.json +1 -1
  127. package/dist/plugin-sdk/accounts-B71rIfIG.js +0 -35
  128. package/dist/plugin-sdk/accounts-Bh_CxVlh.js +0 -46
  129. package/dist/plugin-sdk/accounts-BoD7489q.js +0 -288
  130. package/dist/plugin-sdk/active-listener-6CPAmAh-.js +0 -50
  131. package/dist/plugin-sdk/api-key-rotation-DEDhmJAk.js +0 -181
  132. package/dist/plugin-sdk/audio-preflight-CMPZ9BXN.js +0 -69
  133. package/dist/plugin-sdk/audio-transcription-runner-CdADoJed.js +0 -2176
  134. package/dist/plugin-sdk/audit-membership-runtime-CxP2fdgS.js +0 -58
  135. package/dist/plugin-sdk/channel-activity-9ivqqvRB.js +0 -94
  136. package/dist/plugin-sdk/channel-web-CHDoy_Ex.js +0 -2256
  137. package/dist/plugin-sdk/chrome-B1yeIHRg.js +0 -2415
  138. package/dist/plugin-sdk/commands-registry-D-wyzYid.js +0 -1125
  139. package/dist/plugin-sdk/config-CmS6HzGU.js +0 -17959
  140. package/dist/plugin-sdk/deliver-Cy287pZ5.js +0 -1719
  141. package/dist/plugin-sdk/deliver-runtime-BH3fUFW1.js +0 -32
  142. package/dist/plugin-sdk/deps-send-discord.runtime-CLboFQJz.js +0 -23
  143. package/dist/plugin-sdk/deps-send-imessage.runtime-BVlGKP96.js +0 -22
  144. package/dist/plugin-sdk/deps-send-signal.runtime-0640YmBr.js +0 -21
  145. package/dist/plugin-sdk/deps-send-slack.runtime-BqbFKjcg.js +0 -19
  146. package/dist/plugin-sdk/deps-send-telegram.runtime-1a2RXcA2.js +0 -24
  147. package/dist/plugin-sdk/deps-send-whatsapp.runtime-CpOH0wYd.js +0 -57
  148. package/dist/plugin-sdk/diagnostic-DGt5TnqW.js +0 -319
  149. package/dist/plugin-sdk/errors-D7zDdduc.js +0 -54
  150. package/dist/plugin-sdk/fetch-guard-BsatETDz.js +0 -156
  151. package/dist/plugin-sdk/fs-safe-ynDN1AOr.js +0 -352
  152. package/dist/plugin-sdk/image-6No3eiOM.js +0 -2314
  153. package/dist/plugin-sdk/image-ops-CmFoHyKE.js +0 -584
  154. package/dist/plugin-sdk/image-runtime-D57a2W4s.js +0 -25
  155. package/dist/plugin-sdk/ir-CX1ZjDTn.js +0 -1296
  156. package/dist/plugin-sdk/local-roots-DnE8988Y.js +0 -186
  157. package/dist/plugin-sdk/logger-cN8CgKqt.js +0 -1163
  158. package/dist/plugin-sdk/login-hk6_2GSM.js +0 -57
  159. package/dist/plugin-sdk/login-qr-UaVS_Rce.js +0 -320
  160. package/dist/plugin-sdk/manager-CBP2ZQ5W.js +0 -3929
  161. package/dist/plugin-sdk/manager-runtime-3rKbDrJp.js +0 -15
  162. package/dist/plugin-sdk/outbound-B0Ab6CJM.js +0 -212
  163. package/dist/plugin-sdk/outbound-attachment-CktA053B.js +0 -19
  164. package/dist/plugin-sdk/path-alias-guards-WXu8eYZ3.js +0 -43
  165. package/dist/plugin-sdk/paths-Brta7ydd.js +0 -166
  166. package/dist/plugin-sdk/pi-embedded-helpers-BfbOXbe6.js +0 -9627
  167. package/dist/plugin-sdk/pi-model-discovery-ruarR-_j.js +0 -134
  168. package/dist/plugin-sdk/pi-model-discovery-runtime-26px0QfL.js +0 -8
  169. package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-VVLpfXqQ.js +0 -354
  170. package/dist/plugin-sdk/plugins-C995vsQz.js +0 -864
  171. package/dist/plugin-sdk/proxy-fetch-iSQrNgP-.js +0 -38
  172. package/dist/plugin-sdk/pw-ai-BJXHSS3q.js +0 -1938
  173. package/dist/plugin-sdk/qmd-manager-A7m15SeJ.js +0 -1448
  174. package/dist/plugin-sdk/query-expansion-DngcFbkC.js +0 -1011
  175. package/dist/plugin-sdk/redact-CIb5VTTO.js +0 -319
  176. package/dist/plugin-sdk/reply-vuWmM3Ra.js +0 -100211
  177. package/dist/plugin-sdk/resolve-outbound-target-CQ6hRY-h.js +0 -40
  178. package/dist/plugin-sdk/run-with-concurrency-BlfAoChN.js +0 -1994
  179. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-YsrzSsFL.js +0 -10
  180. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-DL6Ses5K.js +0 -19
  181. package/dist/plugin-sdk/send-BEy8EUzH.js +0 -414
  182. package/dist/plugin-sdk/send-CWP6COto.js +0 -3135
  183. package/dist/plugin-sdk/send-DQTgt3Cu.js +0 -540
  184. package/dist/plugin-sdk/send-DzpV-k17.js +0 -2587
  185. package/dist/plugin-sdk/send-HuIksBS6.js +0 -503
  186. package/dist/plugin-sdk/session-Cc3Y4mXL.js +0 -169
  187. package/dist/plugin-sdk/skill-commands-p8Zwjnwy.js +0 -353
  188. package/dist/plugin-sdk/skills-k8XpacZa.js +0 -1428
  189. package/dist/plugin-sdk/slash-commands.runtime-ynnr6oUR.js +0 -13
  190. package/dist/plugin-sdk/slash-dispatch.runtime-DOmMrwMj.js +0 -52
  191. package/dist/plugin-sdk/slash-skill-commands.runtime-eAk1jhVy.js +0 -16
  192. package/dist/plugin-sdk/ssrf-DZSsYJgJ.js +0 -202
  193. package/dist/plugin-sdk/store-Cn0oLCP4.js +0 -81
  194. package/dist/plugin-sdk/subagent-registry-runtime-CQ3m7TwQ.js +0 -52
  195. package/dist/plugin-sdk/tables-KWxXnbkq.js +0 -55
  196. package/dist/plugin-sdk/target-errors-Cr0q4o7K.js +0 -195
  197. package/dist/plugin-sdk/thinking-CfA6xbI_.js +0 -1206
  198. package/dist/plugin-sdk/tokens-B-D1YRTV.js +0 -52
  199. package/dist/plugin-sdk/tool-images-CVV7LNFW.js +0 -274
  200. package/dist/plugin-sdk/web-B1Svh1KM.js +0 -56
  201. package/dist/plugin-sdk/whatsapp-actions-CLNhBLJz.js +0 -80
@@ -1,181 +0,0 @@
1
- import { jn as normalizeProviderId } from "./config-CmS6HzGU.js";
2
- import { r as formatErrorMessage } from "./errors-D7zDdduc.js";
3
-
4
- //#region src/infra/gemini-auth.ts
5
- /**
6
- * Shared Gemini authentication utilities.
7
- *
8
- * Supports both traditional API keys and OAuth JSON format.
9
- */
10
- /**
11
- * Parse Gemini API key and return appropriate auth headers.
12
- *
13
- * OAuth format: `{"token": "...", "projectId": "..."}`
14
- *
15
- * @param apiKey - Either a traditional API key string or OAuth JSON
16
- * @returns Headers object with appropriate authentication
17
- */
18
- function parseGeminiAuth(apiKey) {
19
- if (apiKey.startsWith("{")) try {
20
- const parsed = JSON.parse(apiKey);
21
- if (typeof parsed.token === "string" && parsed.token) return { headers: {
22
- Authorization: `Bearer ${parsed.token}`,
23
- "Content-Type": "application/json"
24
- } };
25
- } catch {}
26
- return { headers: {
27
- "x-goog-api-key": apiKey,
28
- "Content-Type": "application/json"
29
- } };
30
- }
31
-
32
- //#endregion
33
- //#region src/agents/live-auth-keys.ts
34
- const KEY_SPLIT_RE = /[\s,;]+/g;
35
- const GOOGLE_LIVE_SINGLE_KEY = "WINCLAW_LIVE_GEMINI_KEY";
36
- const PROVIDER_PREFIX_OVERRIDES = {
37
- google: "GEMINI",
38
- "google-vertex": "GEMINI"
39
- };
40
- const PROVIDER_API_KEY_CONFIG = {
41
- anthropic: {
42
- liveSingle: "WINCLAW_LIVE_ANTHROPIC_KEY",
43
- listVar: "WINCLAW_LIVE_ANTHROPIC_KEYS",
44
- primaryVar: "ANTHROPIC_API_KEY",
45
- prefixedVar: "ANTHROPIC_API_KEY_"
46
- },
47
- google: {
48
- liveSingle: GOOGLE_LIVE_SINGLE_KEY,
49
- listVar: "GEMINI_API_KEYS",
50
- primaryVar: "GEMINI_API_KEY",
51
- prefixedVar: "GEMINI_API_KEY_"
52
- },
53
- "google-vertex": {
54
- liveSingle: GOOGLE_LIVE_SINGLE_KEY,
55
- listVar: "GEMINI_API_KEYS",
56
- primaryVar: "GEMINI_API_KEY",
57
- prefixedVar: "GEMINI_API_KEY_"
58
- },
59
- openai: {
60
- liveSingle: "WINCLAW_LIVE_OPENAI_KEY",
61
- listVar: "OPENAI_API_KEYS",
62
- primaryVar: "OPENAI_API_KEY",
63
- prefixedVar: "OPENAI_API_KEY_"
64
- }
65
- };
66
- function parseKeyList(raw) {
67
- if (!raw) return [];
68
- return raw.split(KEY_SPLIT_RE).map((value) => value.trim()).filter(Boolean);
69
- }
70
- function collectEnvPrefixedKeys(prefix) {
71
- const keys = [];
72
- for (const [name, value] of Object.entries(process.env)) {
73
- if (!name.startsWith(prefix)) continue;
74
- const trimmed = value?.trim();
75
- if (!trimmed) continue;
76
- keys.push(trimmed);
77
- }
78
- return keys;
79
- }
80
- function resolveProviderApiKeyConfig(provider) {
81
- const normalized = normalizeProviderId(provider);
82
- const custom = PROVIDER_API_KEY_CONFIG[normalized];
83
- const base = PROVIDER_PREFIX_OVERRIDES[normalized] ?? normalized.toUpperCase().replace(/-/g, "_");
84
- const liveSingle = custom?.liveSingle ?? `WINCLAW_LIVE_${base}_KEY`;
85
- const listVar = custom?.listVar ?? `${base}_API_KEYS`;
86
- const primaryVar = custom?.primaryVar ?? `${base}_API_KEY`;
87
- const prefixedVar = custom?.prefixedVar ?? `${base}_API_KEY_`;
88
- if (normalized === "google" || normalized === "google-vertex") return {
89
- liveSingle,
90
- listVar,
91
- primaryVar,
92
- prefixedVar,
93
- fallbackVars: ["GOOGLE_API_KEY"]
94
- };
95
- return {
96
- liveSingle,
97
- listVar,
98
- primaryVar,
99
- prefixedVar,
100
- fallbackVars: []
101
- };
102
- }
103
- function collectProviderApiKeys(provider) {
104
- const config = resolveProviderApiKeyConfig(provider);
105
- const forcedSingle = config.liveSingle ? process.env[config.liveSingle]?.trim() : void 0;
106
- if (forcedSingle) return [forcedSingle];
107
- const fromList = parseKeyList(config.listVar ? process.env[config.listVar] : void 0);
108
- const primary = config.primaryVar ? process.env[config.primaryVar]?.trim() : void 0;
109
- const fromPrefixed = config.prefixedVar ? collectEnvPrefixedKeys(config.prefixedVar) : [];
110
- const fallback = config.fallbackVars.map((envVar) => process.env[envVar]?.trim()).filter(Boolean);
111
- const seen = /* @__PURE__ */ new Set();
112
- const add = (value) => {
113
- if (!value) return;
114
- if (seen.has(value)) return;
115
- seen.add(value);
116
- };
117
- for (const value of fromList) add(value);
118
- add(primary);
119
- for (const value of fromPrefixed) add(value);
120
- for (const value of fallback) add(value);
121
- return Array.from(seen);
122
- }
123
- function isApiKeyRateLimitError(message) {
124
- const lower = message.toLowerCase();
125
- if (lower.includes("rate_limit")) return true;
126
- if (lower.includes("rate limit")) return true;
127
- if (lower.includes("429")) return true;
128
- if (lower.includes("quota exceeded") || lower.includes("quota_exceeded")) return true;
129
- if (lower.includes("resource exhausted") || lower.includes("resource_exhausted")) return true;
130
- if (lower.includes("too many requests")) return true;
131
- return false;
132
- }
133
-
134
- //#endregion
135
- //#region src/agents/api-key-rotation.ts
136
- function dedupeApiKeys(raw) {
137
- const seen = /* @__PURE__ */ new Set();
138
- const keys = [];
139
- for (const value of raw) {
140
- const apiKey = value.trim();
141
- if (!apiKey || seen.has(apiKey)) continue;
142
- seen.add(apiKey);
143
- keys.push(apiKey);
144
- }
145
- return keys;
146
- }
147
- function collectProviderApiKeysForExecution(params) {
148
- const { primaryApiKey, provider } = params;
149
- return dedupeApiKeys([primaryApiKey?.trim() ?? "", ...collectProviderApiKeys(provider)]);
150
- }
151
- async function executeWithApiKeyRotation(params) {
152
- const keys = dedupeApiKeys(params.apiKeys);
153
- if (keys.length === 0) throw new Error(`No API keys configured for provider "${params.provider}".`);
154
- let lastError;
155
- for (let attempt = 0; attempt < keys.length; attempt += 1) {
156
- const apiKey = keys[attempt];
157
- try {
158
- return await params.execute(apiKey);
159
- } catch (error) {
160
- lastError = error;
161
- const message = formatErrorMessage(error);
162
- if (!(params.shouldRetry ? params.shouldRetry({
163
- apiKey,
164
- error,
165
- attempt,
166
- message
167
- }) : isApiKeyRateLimitError(message)) || attempt + 1 >= keys.length) break;
168
- params.onRetry?.({
169
- apiKey,
170
- error,
171
- attempt,
172
- message
173
- });
174
- }
175
- }
176
- if (lastError === void 0) throw new Error(`Failed to run API request for ${params.provider}.`);
177
- throw lastError;
178
- }
179
-
180
- //#endregion
181
- export { executeWithApiKeyRotation as n, parseGeminiAuth as r, collectProviderApiKeysForExecution as t };
@@ -1,69 +0,0 @@
1
- import "./run-with-concurrency-BlfAoChN.js";
2
- import "./accounts-BoD7489q.js";
3
- import "./paths-BEfQqXwE.js";
4
- import "./github-copilot-token-BCc3snHh.js";
5
- import "./config-CmS6HzGU.js";
6
- import { L as logVerbose, z as shouldLogVerbose } from "./logger-cN8CgKqt.js";
7
- import "./thinking-CfA6xbI_.js";
8
- import "./image-ops-CmFoHyKE.js";
9
- import "./pi-embedded-helpers-BfbOXbe6.js";
10
- import "./plugins-C995vsQz.js";
11
- import "./accounts-B71rIfIG.js";
12
- import "./accounts-Bh_CxVlh.js";
13
- import "./paths-Brta7ydd.js";
14
- import "./redact-CIb5VTTO.js";
15
- import "./errors-D7zDdduc.js";
16
- import "./path-alias-guards-WXu8eYZ3.js";
17
- import "./fs-safe-ynDN1AOr.js";
18
- import "./ssrf-DZSsYJgJ.js";
19
- import "./fetch-guard-BsatETDz.js";
20
- import "./local-roots-DnE8988Y.js";
21
- import "./tool-images-CVV7LNFW.js";
22
- import { f as isAudioAttachment, i as normalizeMediaAttachments, o as resolveMediaAttachmentLocalRoots, t as runAudioTranscription } from "./audio-transcription-runner-CdADoJed.js";
23
- import "./skills-k8XpacZa.js";
24
- import "./chrome-B1yeIHRg.js";
25
- import "./store-Cn0oLCP4.js";
26
- import "./image-6No3eiOM.js";
27
- import "./api-key-rotation-DEDhmJAk.js";
28
- import "./proxy-fetch-iSQrNgP-.js";
29
-
30
- //#region src/media-understanding/audio-preflight.ts
31
- /**
32
- * Transcribes the first audio attachment BEFORE mention checking.
33
- * This allows voice notes to be processed in group chats with requireMention: true.
34
- * Returns the transcript or undefined if transcription fails or no audio is found.
35
- */
36
- async function transcribeFirstAudio(params) {
37
- const { ctx, cfg } = params;
38
- const audioConfig = cfg.tools?.media?.audio;
39
- if (!audioConfig || audioConfig.enabled === false) return;
40
- const attachments = normalizeMediaAttachments(ctx);
41
- if (!attachments || attachments.length === 0) return;
42
- const firstAudio = attachments.find((att) => att && isAudioAttachment(att) && !att.alreadyTranscribed);
43
- if (!firstAudio) return;
44
- if (shouldLogVerbose()) logVerbose(`audio-preflight: transcribing attachment ${firstAudio.index} for mention check`);
45
- try {
46
- const { transcript } = await runAudioTranscription({
47
- ctx,
48
- cfg,
49
- attachments,
50
- agentDir: params.agentDir,
51
- providers: params.providers,
52
- activeModel: params.activeModel,
53
- localPathRoots: resolveMediaAttachmentLocalRoots({
54
- cfg,
55
- ctx
56
- })
57
- });
58
- if (!transcript) return;
59
- firstAudio.alreadyTranscribed = true;
60
- if (shouldLogVerbose()) logVerbose(`audio-preflight: transcribed ${transcript.length} chars from attachment ${firstAudio.index}`);
61
- return transcript;
62
- } catch (err) {
63
- if (shouldLogVerbose()) logVerbose(`audio-preflight: transcription failed: ${String(err)}`);
64
- return;
65
- }
66
- }
67
-
68
- //#endregion
69
- export { transcribeFirstAudio };