omniroute 1.6.2 → 1.6.3

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 (442) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +47 -47
  3. package/app/.next/build-manifest.json +3 -3
  4. package/app/.next/prerender-manifest.json +3 -3
  5. package/app/.next/required-server-files.json +4 -4
  6. package/app/.next/server/app/(dashboard)/dashboard/analytics/page.js +2 -2
  7. package/app/.next/server/app/(dashboard)/dashboard/analytics/page.js.nft.json +1 -1
  8. package/app/.next/server/app/(dashboard)/dashboard/analytics/page_client-reference-manifest.js +1 -1
  9. package/app/.next/server/app/(dashboard)/dashboard/api-manager/page.js +2 -2
  10. package/app/.next/server/app/(dashboard)/dashboard/api-manager/page.js.nft.json +1 -1
  11. package/app/.next/server/app/(dashboard)/dashboard/api-manager/page_client-reference-manifest.js +1 -1
  12. package/app/.next/server/app/(dashboard)/dashboard/audit-log/page.js +2 -2
  13. package/app/.next/server/app/(dashboard)/dashboard/audit-log/page.js.nft.json +1 -1
  14. package/app/.next/server/app/(dashboard)/dashboard/audit-log/page_client-reference-manifest.js +1 -1
  15. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js +3 -3
  16. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js.nft.json +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  18. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js +2 -2
  19. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js.nft.json +1 -1
  20. package/app/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  21. package/app/.next/server/app/(dashboard)/dashboard/costs/page.js +2 -2
  22. package/app/.next/server/app/(dashboard)/dashboard/costs/page.js.nft.json +1 -1
  23. package/app/.next/server/app/(dashboard)/dashboard/costs/page_client-reference-manifest.js +1 -1
  24. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js +2 -2
  25. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js.nft.json +1 -1
  26. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  27. package/app/.next/server/app/(dashboard)/dashboard/health/page.js +2 -2
  28. package/app/.next/server/app/(dashboard)/dashboard/health/page.js.nft.json +1 -1
  29. package/app/.next/server/app/(dashboard)/dashboard/health/page_client-reference-manifest.js +1 -1
  30. package/app/.next/server/app/(dashboard)/dashboard/limits/page.js +2 -2
  31. package/app/.next/server/app/(dashboard)/dashboard/limits/page.js.nft.json +1 -1
  32. package/app/.next/server/app/(dashboard)/dashboard/limits/page_client-reference-manifest.js +1 -1
  33. package/app/.next/server/app/(dashboard)/dashboard/logs/page.js +2 -2
  34. package/app/.next/server/app/(dashboard)/dashboard/logs/page.js.nft.json +1 -1
  35. package/app/.next/server/app/(dashboard)/dashboard/logs/page_client-reference-manifest.js +1 -1
  36. package/app/.next/server/app/(dashboard)/dashboard/onboarding/page.js +2 -2
  37. package/app/.next/server/app/(dashboard)/dashboard/onboarding/page.js.nft.json +1 -1
  38. package/app/.next/server/app/(dashboard)/dashboard/onboarding/page_client-reference-manifest.js +1 -1
  39. package/app/.next/server/app/(dashboard)/dashboard/page.js +2 -2
  40. package/app/.next/server/app/(dashboard)/dashboard/page.js.nft.json +1 -1
  41. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  42. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js +2 -2
  43. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js.nft.json +1 -1
  44. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  45. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +2 -2
  46. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js.nft.json +1 -1
  47. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  48. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js +2 -2
  49. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js.nft.json +1 -1
  50. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  51. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js +2 -2
  52. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js.nft.json +1 -1
  53. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  54. package/app/.next/server/app/(dashboard)/dashboard/settings/page.js +2 -2
  55. package/app/.next/server/app/(dashboard)/dashboard/settings/page.js.nft.json +1 -1
  56. package/app/.next/server/app/(dashboard)/dashboard/settings/page_client-reference-manifest.js +1 -1
  57. package/app/.next/server/app/(dashboard)/dashboard/settings/pricing/page.js +2 -2
  58. package/app/.next/server/app/(dashboard)/dashboard/settings/pricing/page.js.nft.json +1 -1
  59. package/app/.next/server/app/(dashboard)/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  60. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js +3 -3
  61. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js.nft.json +1 -1
  62. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  63. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js +2 -2
  64. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js.nft.json +1 -1
  65. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  66. package/app/.next/server/app/_global-error/page.js +3 -3
  67. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  68. package/app/.next/server/app/_global-error.html +2 -2
  69. package/app/.next/server/app/_global-error.rsc +4 -4
  70. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +4 -4
  71. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  72. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  73. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  74. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
  75. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  76. package/app/.next/server/app/_not-found/page.js +2 -2
  77. package/app/.next/server/app/_not-found/page.js.nft.json +1 -1
  78. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  79. package/app/.next/server/app/api/auth/login/route.js +1 -1
  80. package/app/.next/server/app/api/auth/login/route_client-reference-manifest.js +1 -1
  81. package/app/.next/server/app/api/auth/logout/route.js +1 -1
  82. package/app/.next/server/app/api/auth/logout/route_client-reference-manifest.js +1 -1
  83. package/app/.next/server/app/api/auth/status/route.js +1 -1
  84. package/app/.next/server/app/api/auth/status/route_client-reference-manifest.js +1 -1
  85. package/app/.next/server/app/api/cache/route.js +1 -1
  86. package/app/.next/server/app/api/cache/route_client-reference-manifest.js +1 -1
  87. package/app/.next/server/app/api/cache/stats/route.js +1 -1
  88. package/app/.next/server/app/api/cache/stats/route_client-reference-manifest.js +1 -1
  89. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
  90. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route_client-reference-manifest.js +1 -1
  91. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +3 -3
  92. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route_client-reference-manifest.js +1 -1
  93. package/app/.next/server/app/api/cli-tools/backups/route.js +2 -2
  94. package/app/.next/server/app/api/cli-tools/backups/route_client-reference-manifest.js +1 -1
  95. package/app/.next/server/app/api/cli-tools/claude-settings/route.js +1 -1
  96. package/app/.next/server/app/api/cli-tools/claude-settings/route_client-reference-manifest.js +1 -1
  97. package/app/.next/server/app/api/cli-tools/cline-settings/route.js +2 -2
  98. package/app/.next/server/app/api/cli-tools/cline-settings/route_client-reference-manifest.js +1 -1
  99. package/app/.next/server/app/api/cli-tools/codex-profiles/route.js +2 -2
  100. package/app/.next/server/app/api/cli-tools/codex-profiles/route_client-reference-manifest.js +1 -1
  101. package/app/.next/server/app/api/cli-tools/codex-settings/route.js +1 -1
  102. package/app/.next/server/app/api/cli-tools/codex-settings/route_client-reference-manifest.js +1 -1
  103. package/app/.next/server/app/api/cli-tools/droid-settings/route.js +2 -2
  104. package/app/.next/server/app/api/cli-tools/droid-settings/route_client-reference-manifest.js +1 -1
  105. package/app/.next/server/app/api/cli-tools/guide-settings/[toolId]/route.js +1 -1
  106. package/app/.next/server/app/api/cli-tools/guide-settings/[toolId]/route_client-reference-manifest.js +1 -1
  107. package/app/.next/server/app/api/cli-tools/kilo-settings/route.js +2 -2
  108. package/app/.next/server/app/api/cli-tools/kilo-settings/route_client-reference-manifest.js +1 -1
  109. package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js +1 -1
  110. package/app/.next/server/app/api/cli-tools/openclaw-settings/route_client-reference-manifest.js +1 -1
  111. package/app/.next/server/app/api/cli-tools/runtime/[toolId]/route.js +2 -2
  112. package/app/.next/server/app/api/cli-tools/runtime/[toolId]/route_client-reference-manifest.js +1 -1
  113. package/app/.next/server/app/api/cli-tools/status/route.js +2 -2
  114. package/app/.next/server/app/api/cli-tools/status/route_client-reference-manifest.js +1 -1
  115. package/app/.next/server/app/api/cloud/auth/route.js +1 -1
  116. package/app/.next/server/app/api/cloud/auth/route_client-reference-manifest.js +1 -1
  117. package/app/.next/server/app/api/cloud/credentials/update/route.js +1 -1
  118. package/app/.next/server/app/api/cloud/credentials/update/route_client-reference-manifest.js +1 -1
  119. package/app/.next/server/app/api/cloud/model/resolve/route.js +1 -1
  120. package/app/.next/server/app/api/cloud/model/resolve/route_client-reference-manifest.js +1 -1
  121. package/app/.next/server/app/api/cloud/models/alias/route.js +1 -1
  122. package/app/.next/server/app/api/cloud/models/alias/route_client-reference-manifest.js +1 -1
  123. package/app/.next/server/app/api/combos/[id]/route.js +1 -1
  124. package/app/.next/server/app/api/combos/[id]/route_client-reference-manifest.js +1 -1
  125. package/app/.next/server/app/api/combos/metrics/route.js +1 -1
  126. package/app/.next/server/app/api/combos/metrics/route_client-reference-manifest.js +1 -1
  127. package/app/.next/server/app/api/combos/route.js +1 -1
  128. package/app/.next/server/app/api/combos/route_client-reference-manifest.js +1 -1
  129. package/app/.next/server/app/api/combos/test/route.js +1 -1
  130. package/app/.next/server/app/api/combos/test/route_client-reference-manifest.js +1 -1
  131. package/app/.next/server/app/api/compliance/audit-log/route.js +1 -1
  132. package/app/.next/server/app/api/compliance/audit-log/route_client-reference-manifest.js +1 -1
  133. package/app/.next/server/app/api/db-backups/export/route.js +1 -1
  134. package/app/.next/server/app/api/db-backups/export/route_client-reference-manifest.js +1 -1
  135. package/app/.next/server/app/api/db-backups/exportAll/route.js +1 -1
  136. package/app/.next/server/app/api/db-backups/exportAll/route_client-reference-manifest.js +1 -1
  137. package/app/.next/server/app/api/db-backups/import/route.js +1 -1
  138. package/app/.next/server/app/api/db-backups/import/route_client-reference-manifest.js +1 -1
  139. package/app/.next/server/app/api/db-backups/route.js +1 -1
  140. package/app/.next/server/app/api/db-backups/route_client-reference-manifest.js +1 -1
  141. package/app/.next/server/app/api/evals/[suiteId]/route.js +1 -1
  142. package/app/.next/server/app/api/evals/[suiteId]/route_client-reference-manifest.js +1 -1
  143. package/app/.next/server/app/api/evals/route.js +1 -1
  144. package/app/.next/server/app/api/evals/route_client-reference-manifest.js +1 -1
  145. package/app/.next/server/app/api/fallback/chains/route.js +2 -2
  146. package/app/.next/server/app/api/fallback/chains/route_client-reference-manifest.js +1 -1
  147. package/app/.next/server/app/api/init/route.js +1 -1
  148. package/app/.next/server/app/api/init/route_client-reference-manifest.js +1 -1
  149. package/app/.next/server/app/api/keys/[id]/route.js +1 -1
  150. package/app/.next/server/app/api/keys/[id]/route_client-reference-manifest.js +1 -1
  151. package/app/.next/server/app/api/keys/route.js +1 -1
  152. package/app/.next/server/app/api/keys/route_client-reference-manifest.js +1 -1
  153. package/app/.next/server/app/api/logs/console/route.js +1 -1
  154. package/app/.next/server/app/api/logs/console/route.js.nft.json +1 -1
  155. package/app/.next/server/app/api/logs/console/route_client-reference-manifest.js +1 -1
  156. package/app/.next/server/app/api/models/alias/route.js +1 -1
  157. package/app/.next/server/app/api/models/alias/route_client-reference-manifest.js +1 -1
  158. package/app/.next/server/app/api/models/availability/route.js +1 -1
  159. package/app/.next/server/app/api/models/availability/route_client-reference-manifest.js +1 -1
  160. package/app/.next/server/app/api/models/catalog/route.js +2 -2
  161. package/app/.next/server/app/api/models/catalog/route_client-reference-manifest.js +1 -1
  162. package/app/.next/server/app/api/models/route.js +2 -2
  163. package/app/.next/server/app/api/models/route_client-reference-manifest.js +1 -1
  164. package/app/.next/server/app/api/monitoring/health/route.js +2 -2
  165. package/app/.next/server/app/api/monitoring/health/route_client-reference-manifest.js +1 -1
  166. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js +2 -2
  167. package/app/.next/server/app/api/oauth/[provider]/[action]/route_client-reference-manifest.js +1 -1
  168. package/app/.next/server/app/api/oauth/cursor/auto-import/route.js +1 -1
  169. package/app/.next/server/app/api/oauth/cursor/auto-import/route_client-reference-manifest.js +1 -1
  170. package/app/.next/server/app/api/oauth/cursor/import/route.js +1 -1
  171. package/app/.next/server/app/api/oauth/cursor/import/route_client-reference-manifest.js +1 -1
  172. package/app/.next/server/app/api/oauth/kiro/auto-import/route.js +1 -1
  173. package/app/.next/server/app/api/oauth/kiro/auto-import/route_client-reference-manifest.js +1 -1
  174. package/app/.next/server/app/api/oauth/kiro/import/route.js +1 -1
  175. package/app/.next/server/app/api/oauth/kiro/import/route_client-reference-manifest.js +1 -1
  176. package/app/.next/server/app/api/oauth/kiro/social-authorize/route.js +1 -1
  177. package/app/.next/server/app/api/oauth/kiro/social-authorize/route_client-reference-manifest.js +1 -1
  178. package/app/.next/server/app/api/oauth/kiro/social-exchange/route.js +1 -1
  179. package/app/.next/server/app/api/oauth/kiro/social-exchange/route_client-reference-manifest.js +1 -1
  180. package/app/.next/server/app/api/policies/route.js +2 -2
  181. package/app/.next/server/app/api/policies/route_client-reference-manifest.js +1 -1
  182. package/app/.next/server/app/api/pricing/defaults/route.js +1 -1
  183. package/app/.next/server/app/api/pricing/defaults/route_client-reference-manifest.js +1 -1
  184. package/app/.next/server/app/api/pricing/models/route.js +1 -1
  185. package/app/.next/server/app/api/pricing/models/route_client-reference-manifest.js +1 -1
  186. package/app/.next/server/app/api/pricing/route.js +1 -1
  187. package/app/.next/server/app/api/pricing/route_client-reference-manifest.js +1 -1
  188. package/app/.next/server/app/api/provider-metrics/route.js +2 -2
  189. package/app/.next/server/app/api/provider-metrics/route_client-reference-manifest.js +1 -1
  190. package/app/.next/server/app/api/provider-models/route.js +1 -1
  191. package/app/.next/server/app/api/provider-models/route_client-reference-manifest.js +1 -1
  192. package/app/.next/server/app/api/provider-nodes/[id]/route.js +1 -1
  193. package/app/.next/server/app/api/provider-nodes/[id]/route_client-reference-manifest.js +1 -1
  194. package/app/.next/server/app/api/provider-nodes/route.js +2 -2
  195. package/app/.next/server/app/api/provider-nodes/route_client-reference-manifest.js +1 -1
  196. package/app/.next/server/app/api/provider-nodes/validate/route.js +1 -1
  197. package/app/.next/server/app/api/provider-nodes/validate/route_client-reference-manifest.js +1 -1
  198. package/app/.next/server/app/api/providers/[id]/models/route.js +2 -2
  199. package/app/.next/server/app/api/providers/[id]/models/route_client-reference-manifest.js +1 -1
  200. package/app/.next/server/app/api/providers/[id]/route.js +1 -1
  201. package/app/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -1
  202. package/app/.next/server/app/api/providers/[id]/test/route.js +1 -1
  203. package/app/.next/server/app/api/providers/[id]/test/route_client-reference-manifest.js +1 -1
  204. package/app/.next/server/app/api/providers/client/route.js +1 -1
  205. package/app/.next/server/app/api/providers/client/route_client-reference-manifest.js +1 -1
  206. package/app/.next/server/app/api/providers/route.js +2 -2
  207. package/app/.next/server/app/api/providers/route_client-reference-manifest.js +1 -1
  208. package/app/.next/server/app/api/providers/test-batch/route.js +1 -1
  209. package/app/.next/server/app/api/providers/test-batch/route_client-reference-manifest.js +1 -1
  210. package/app/.next/server/app/api/providers/validate/route.js +1 -1
  211. package/app/.next/server/app/api/providers/validate/route_client-reference-manifest.js +1 -1
  212. package/app/.next/server/app/api/rate-limit/route.js +1 -1
  213. package/app/.next/server/app/api/rate-limit/route_client-reference-manifest.js +1 -1
  214. package/app/.next/server/app/api/rate-limits/route.js +1 -1
  215. package/app/.next/server/app/api/rate-limits/route_client-reference-manifest.js +1 -1
  216. package/app/.next/server/app/api/resilience/reset/route.js +1 -1
  217. package/app/.next/server/app/api/resilience/reset/route_client-reference-manifest.js +1 -1
  218. package/app/.next/server/app/api/resilience/route.js +1 -1
  219. package/app/.next/server/app/api/resilience/route_client-reference-manifest.js +1 -1
  220. package/app/.next/server/app/api/restart/route.js +1 -1
  221. package/app/.next/server/app/api/restart/route_client-reference-manifest.js +1 -1
  222. package/app/.next/server/app/api/sessions/route.js +1 -1
  223. package/app/.next/server/app/api/sessions/route_client-reference-manifest.js +1 -1
  224. package/app/.next/server/app/api/settings/combo-defaults/route.js +1 -1
  225. package/app/.next/server/app/api/settings/combo-defaults/route_client-reference-manifest.js +1 -1
  226. package/app/.next/server/app/api/settings/ip-filter/route.js +1 -1
  227. package/app/.next/server/app/api/settings/ip-filter/route_client-reference-manifest.js +1 -1
  228. package/app/.next/server/app/api/settings/proxy/route.js +1 -1
  229. package/app/.next/server/app/api/settings/proxy/route_client-reference-manifest.js +1 -1
  230. package/app/.next/server/app/api/settings/proxy/test/route.js +1 -1
  231. package/app/.next/server/app/api/settings/proxy/test/route_client-reference-manifest.js +1 -1
  232. package/app/.next/server/app/api/settings/require-login/route.js +1 -1
  233. package/app/.next/server/app/api/settings/require-login/route_client-reference-manifest.js +1 -1
  234. package/app/.next/server/app/api/settings/route.js +1 -1
  235. package/app/.next/server/app/api/settings/route_client-reference-manifest.js +1 -1
  236. package/app/.next/server/app/api/settings/system-prompt/route.js +1 -1
  237. package/app/.next/server/app/api/settings/system-prompt/route_client-reference-manifest.js +1 -1
  238. package/app/.next/server/app/api/settings/thinking-budget/route.js +1 -1
  239. package/app/.next/server/app/api/settings/thinking-budget/route_client-reference-manifest.js +1 -1
  240. package/app/.next/server/app/api/shutdown/route.js +1 -1
  241. package/app/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  242. package/app/.next/server/app/api/storage/health/route.js +1 -1
  243. package/app/.next/server/app/api/storage/health/route_client-reference-manifest.js +1 -1
  244. package/app/.next/server/app/api/sync/cloud/route.js +1 -1
  245. package/app/.next/server/app/api/sync/cloud/route_client-reference-manifest.js +1 -1
  246. package/app/.next/server/app/api/sync/initialize/route.js +1 -1
  247. package/app/.next/server/app/api/sync/initialize/route_client-reference-manifest.js +1 -1
  248. package/app/.next/server/app/api/tags/route.js +1 -1
  249. package/app/.next/server/app/api/tags/route_client-reference-manifest.js +1 -1
  250. package/app/.next/server/app/api/telemetry/summary/route.js +1 -1
  251. package/app/.next/server/app/api/telemetry/summary/route_client-reference-manifest.js +1 -1
  252. package/app/.next/server/app/api/token-health/route.js +1 -1
  253. package/app/.next/server/app/api/token-health/route_client-reference-manifest.js +1 -1
  254. package/app/.next/server/app/api/translator/detect/route.js +1 -1
  255. package/app/.next/server/app/api/translator/detect/route_client-reference-manifest.js +1 -1
  256. package/app/.next/server/app/api/translator/history/route.js +1 -1
  257. package/app/.next/server/app/api/translator/history/route_client-reference-manifest.js +1 -1
  258. package/app/.next/server/app/api/translator/load/route.js +1 -1
  259. package/app/.next/server/app/api/translator/load/route_client-reference-manifest.js +1 -1
  260. package/app/.next/server/app/api/translator/save/route.js +1 -1
  261. package/app/.next/server/app/api/translator/save/route_client-reference-manifest.js +1 -1
  262. package/app/.next/server/app/api/translator/send/route.js +1 -1
  263. package/app/.next/server/app/api/translator/send/route_client-reference-manifest.js +1 -1
  264. package/app/.next/server/app/api/translator/translate/route.js +1 -1
  265. package/app/.next/server/app/api/translator/translate/route_client-reference-manifest.js +1 -1
  266. package/app/.next/server/app/api/usage/[connectionId]/route.js +1 -1
  267. package/app/.next/server/app/api/usage/[connectionId]/route_client-reference-manifest.js +1 -1
  268. package/app/.next/server/app/api/usage/analytics/route.js +1 -1
  269. package/app/.next/server/app/api/usage/analytics/route_client-reference-manifest.js +1 -1
  270. package/app/.next/server/app/api/usage/budget/route.js +2 -2
  271. package/app/.next/server/app/api/usage/budget/route_client-reference-manifest.js +1 -1
  272. package/app/.next/server/app/api/usage/call-logs/[id]/route.js +1 -1
  273. package/app/.next/server/app/api/usage/call-logs/[id]/route_client-reference-manifest.js +1 -1
  274. package/app/.next/server/app/api/usage/call-logs/route.js +1 -1
  275. package/app/.next/server/app/api/usage/call-logs/route_client-reference-manifest.js +1 -1
  276. package/app/.next/server/app/api/usage/history/route.js +1 -1
  277. package/app/.next/server/app/api/usage/history/route_client-reference-manifest.js +1 -1
  278. package/app/.next/server/app/api/usage/logs/route.js +1 -1
  279. package/app/.next/server/app/api/usage/logs/route_client-reference-manifest.js +1 -1
  280. package/app/.next/server/app/api/usage/proxy-logs/route.js +1 -1
  281. package/app/.next/server/app/api/usage/proxy-logs/route_client-reference-manifest.js +1 -1
  282. package/app/.next/server/app/api/usage/request-logs/route.js +1 -1
  283. package/app/.next/server/app/api/usage/request-logs/route_client-reference-manifest.js +1 -1
  284. package/app/.next/server/app/api/v1/api/chat/route.js +1 -1
  285. package/app/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
  286. package/app/.next/server/app/api/v1/api/chat/route_client-reference-manifest.js +1 -1
  287. package/app/.next/server/app/api/v1/audio/speech/route.js +1 -1
  288. package/app/.next/server/app/api/v1/audio/speech/route.js.nft.json +1 -1
  289. package/app/.next/server/app/api/v1/audio/speech/route_client-reference-manifest.js +1 -1
  290. package/app/.next/server/app/api/v1/audio/transcriptions/route.js +1 -1
  291. package/app/.next/server/app/api/v1/audio/transcriptions/route.js.nft.json +1 -1
  292. package/app/.next/server/app/api/v1/audio/transcriptions/route_client-reference-manifest.js +1 -1
  293. package/app/.next/server/app/api/v1/chat/completions/route.js +1 -1
  294. package/app/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
  295. package/app/.next/server/app/api/v1/chat/completions/route_client-reference-manifest.js +1 -1
  296. package/app/.next/server/app/api/v1/embeddings/route.js +1 -1
  297. package/app/.next/server/app/api/v1/embeddings/route.js.nft.json +1 -1
  298. package/app/.next/server/app/api/v1/embeddings/route_client-reference-manifest.js +1 -1
  299. package/app/.next/server/app/api/v1/images/generations/route.js +1 -1
  300. package/app/.next/server/app/api/v1/images/generations/route.js.nft.json +1 -1
  301. package/app/.next/server/app/api/v1/images/generations/route_client-reference-manifest.js +1 -1
  302. package/app/.next/server/app/api/v1/messages/count_tokens/route.js +1 -1
  303. package/app/.next/server/app/api/v1/messages/count_tokens/route_client-reference-manifest.js +1 -1
  304. package/app/.next/server/app/api/v1/messages/route.js +1 -1
  305. package/app/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
  306. package/app/.next/server/app/api/v1/messages/route_client-reference-manifest.js +1 -1
  307. package/app/.next/server/app/api/v1/models/route.js +2 -2
  308. package/app/.next/server/app/api/v1/models/route_client-reference-manifest.js +1 -1
  309. package/app/.next/server/app/api/v1/moderations/route.js +1 -1
  310. package/app/.next/server/app/api/v1/moderations/route.js.nft.json +1 -1
  311. package/app/.next/server/app/api/v1/moderations/route_client-reference-manifest.js +1 -1
  312. package/app/.next/server/app/api/v1/providers/[provider]/chat/completions/route.js +1 -1
  313. package/app/.next/server/app/api/v1/providers/[provider]/chat/completions/route.js.nft.json +1 -1
  314. package/app/.next/server/app/api/v1/providers/[provider]/chat/completions/route_client-reference-manifest.js +1 -1
  315. package/app/.next/server/app/api/v1/providers/[provider]/embeddings/route.js +1 -1
  316. package/app/.next/server/app/api/v1/providers/[provider]/embeddings/route.js.nft.json +1 -1
  317. package/app/.next/server/app/api/v1/providers/[provider]/embeddings/route_client-reference-manifest.js +1 -1
  318. package/app/.next/server/app/api/v1/providers/[provider]/images/generations/route.js +1 -1
  319. package/app/.next/server/app/api/v1/providers/[provider]/images/generations/route.js.nft.json +1 -1
  320. package/app/.next/server/app/api/v1/providers/[provider]/images/generations/route_client-reference-manifest.js +1 -1
  321. package/app/.next/server/app/api/v1/rerank/route.js +1 -1
  322. package/app/.next/server/app/api/v1/rerank/route.js.nft.json +1 -1
  323. package/app/.next/server/app/api/v1/rerank/route_client-reference-manifest.js +1 -1
  324. package/app/.next/server/app/api/v1/responses/route.js +1 -1
  325. package/app/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
  326. package/app/.next/server/app/api/v1/responses/route_client-reference-manifest.js +1 -1
  327. package/app/.next/server/app/api/v1/route.js +1 -1
  328. package/app/.next/server/app/api/v1/route_client-reference-manifest.js +1 -1
  329. package/app/.next/server/app/api/v1beta/models/[...path]/route.js +1 -1
  330. package/app/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
  331. package/app/.next/server/app/api/v1beta/models/[...path]/route_client-reference-manifest.js +1 -1
  332. package/app/.next/server/app/api/v1beta/models/route.js +2 -2
  333. package/app/.next/server/app/api/v1beta/models/route_client-reference-manifest.js +1 -1
  334. package/app/.next/server/app/callback/page.js +2 -2
  335. package/app/.next/server/app/callback/page.js.nft.json +1 -1
  336. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  337. package/app/.next/server/app/docs/page.js +3 -3
  338. package/app/.next/server/app/docs/page.js.nft.json +1 -1
  339. package/app/.next/server/app/docs/page_client-reference-manifest.js +1 -1
  340. package/app/.next/server/app/forbidden/page.js +2 -2
  341. package/app/.next/server/app/forbidden/page.js.nft.json +1 -1
  342. package/app/.next/server/app/forbidden/page_client-reference-manifest.js +1 -1
  343. package/app/.next/server/app/forgot-password/page.js +2 -2
  344. package/app/.next/server/app/forgot-password/page.js.nft.json +1 -1
  345. package/app/.next/server/app/forgot-password/page_client-reference-manifest.js +1 -1
  346. package/app/.next/server/app/landing/page.js +2 -2
  347. package/app/.next/server/app/landing/page.js.nft.json +1 -1
  348. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  349. package/app/.next/server/app/login/page.js +2 -2
  350. package/app/.next/server/app/login/page.js.nft.json +1 -1
  351. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  352. package/app/.next/server/app/page.js +2 -2
  353. package/app/.next/server/app/page.js.nft.json +1 -1
  354. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  355. package/app/.next/server/app/privacy/page.js +2 -2
  356. package/app/.next/server/app/privacy/page.js.nft.json +1 -1
  357. package/app/.next/server/app/privacy/page_client-reference-manifest.js +1 -1
  358. package/app/.next/server/app/terms/page.js +2 -2
  359. package/app/.next/server/app/terms/page.js.nft.json +1 -1
  360. package/app/.next/server/app/terms/page_client-reference-manifest.js +1 -1
  361. package/app/.next/server/app-paths-manifest.json +47 -47
  362. package/app/.next/server/chunks/2180.js +2 -2
  363. package/app/.next/server/chunks/2767.js +10 -10
  364. package/app/.next/server/chunks/2910.js +2 -2
  365. package/app/.next/server/chunks/3498.js +1 -1
  366. package/app/.next/server/chunks/4488.js +2 -2
  367. package/app/.next/server/chunks/5248.js +1 -0
  368. package/app/.next/server/chunks/5393.js +2 -0
  369. package/app/.next/server/chunks/7109.js +1 -1
  370. package/app/.next/server/chunks/8020.js +3 -3
  371. package/app/.next/server/chunks/9824.js +2 -2
  372. package/app/.next/server/middleware-build-manifest.js +1 -1
  373. package/app/.next/server/middleware.js +4 -4
  374. package/app/.next/server/next-font-manifest.js +1 -1
  375. package/app/.next/server/next-font-manifest.json +1 -1
  376. package/app/.next/server/pages/500.html +2 -2
  377. package/app/.next/server/server-reference-manifest.js +1 -1
  378. package/app/.next/server/server-reference-manifest.json +1 -1
  379. package/app/.next/static/chunks/{5846-dc83396127b87ed7.js → 5846-8360aca41de8628b.js} +1 -1
  380. package/app/.next/static/chunks/{993-95359de84711765c.js → 993-8fccc90073c1451f.js} +2 -2
  381. package/app/.next/static/chunks/app/(dashboard)/dashboard/analytics/loading-6f1750506292c630.js +1 -0
  382. package/app/.next/static/chunks/app/(dashboard)/dashboard/analytics/{page-20786f2c7fdbab57.js → page-52f76c7c91444ec2.js} +1 -1
  383. package/app/.next/static/chunks/app/(dashboard)/dashboard/api-manager/page-1dd4d0c348a7b0a6.js +1 -0
  384. package/app/.next/static/chunks/app/(dashboard)/dashboard/audit-log/page-e5bf8955e7b9a4f5.js +1 -0
  385. package/app/.next/static/chunks/app/(dashboard)/dashboard/cli-tools/page-11e68927df2ceb77.js +15 -0
  386. package/app/.next/static/chunks/app/(dashboard)/dashboard/combos/{page-85a3e6a423aceded.js → page-3dce7fccfcf177dd.js} +1 -1
  387. package/app/.next/static/chunks/app/(dashboard)/dashboard/costs/{page-cdb8071441476da9.js → page-3ed2a7685adf9b91.js} +1 -1
  388. package/app/.next/static/chunks/app/(dashboard)/dashboard/endpoint/page-1420c3ca376f1585.js +1 -0
  389. package/app/.next/static/chunks/app/(dashboard)/dashboard/health/{page-b480b3cb318782d7.js → page-9a6519bf1468f16e.js} +1 -1
  390. package/app/.next/static/chunks/app/(dashboard)/dashboard/limits/page-f4a2d6d07df5ddc4.js +1 -0
  391. package/app/.next/static/chunks/app/(dashboard)/dashboard/logs/{page-ffdc1dcf074c7528.js → page-833d24f322a20f5a.js} +1 -1
  392. package/app/.next/static/chunks/app/(dashboard)/dashboard/onboarding/{page-5378e9473a20cd6a.js → page-d424641c7e428be9.js} +1 -1
  393. package/app/.next/static/chunks/app/(dashboard)/dashboard/page-388840686801f3f5.js +1 -0
  394. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-9c8ffb212f855704.js +1 -0
  395. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/{error-f0730d6d62d02e82.js → error-2f0177a2197dd556.js} +1 -1
  396. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/{loading-59cbccd6d5185ca9.js → loading-99ab4d478260d53b.js} +1 -1
  397. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/new/page-31cdb6e15134d8c2.js +1 -0
  398. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/{page-40dc5ac82df708e9.js → page-1f022385b812b987.js} +1 -1
  399. package/app/.next/static/chunks/app/(dashboard)/dashboard/settings/{error-cc85c3ff1f63aea6.js → error-e844916e39172c8b.js} +1 -1
  400. package/app/.next/static/chunks/app/(dashboard)/dashboard/settings/{loading-19fc771a287bcb4c.js → loading-bb068659ee679ff4.js} +1 -1
  401. package/app/.next/static/chunks/app/(dashboard)/dashboard/settings/page-1393d4935fc087cf.js +1 -0
  402. package/app/.next/static/chunks/app/(dashboard)/dashboard/settings/pricing/{page-cbe9b21b62bbc2bd.js → page-f10a8d4bb8236913.js} +1 -1
  403. package/app/.next/static/chunks/app/(dashboard)/dashboard/translator/{page-534e13a69cb60a4f.js → page-83b07523f81d6282.js} +1 -1
  404. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/{page-86a076d820931a30.js → page-9cc99ab874fc36e7.js} +1 -1
  405. package/app/.next/static/chunks/app/(dashboard)/{layout-16302e54f9ef3d0e.js → layout-00d5d56af65098a9.js} +1 -1
  406. package/app/.next/static/chunks/app/callback/{page-0f0ebc0820dd18a5.js → page-585a53f7dc6a30f1.js} +1 -1
  407. package/app/.next/static/chunks/app/docs/{page-3658b3f15df3a19e.js → page-2fe9dcbeb3f738c0.js} +1 -1
  408. package/app/.next/static/chunks/app/{error-f918d9961a2368d3.js → error-0d59fc4efafbc38c.js} +1 -1
  409. package/app/.next/static/chunks/app/forbidden/page-df886dfa2d5bd9fa.js +1 -0
  410. package/app/.next/static/chunks/app/forgot-password/page-2a495f0b0c653ab4.js +1 -0
  411. package/app/.next/static/chunks/app/global-error-41eef2a698918fc1.js +1 -0
  412. package/app/.next/static/chunks/app/landing/page-9d540ab1716f8e3e.js +1 -0
  413. package/app/.next/static/chunks/app/{layout-070972eb026af319.js → layout-108592eafb959363.js} +1 -1
  414. package/app/.next/static/chunks/app/login/{page-6c769465e407368f.js → page-121c612ee459e7c2.js} +1 -1
  415. package/app/.next/static/chunks/app/not-found-1dbd8c3e506fe00f.js +1 -0
  416. package/app/.next/static/chunks/app/privacy/{page-3658b3f15df3a19e.js → page-2fe9dcbeb3f738c0.js} +1 -1
  417. package/app/.next/static/chunks/app/terms/{page-3658b3f15df3a19e.js → page-2fe9dcbeb3f738c0.js} +1 -1
  418. package/app/.next/static/chunks/{main-app-ae230f6bf51a5edb.js → main-app-c9da11a8061df107.js} +1 -1
  419. package/app/package.json +1 -1
  420. package/app/server.js +1 -1
  421. package/package.json +1 -1
  422. package/app/.env +0 -110
  423. package/app/.next/server/chunks/3801.js +0 -2
  424. package/app/.next/server/chunks/9548.js +0 -1
  425. package/app/.next/static/chunks/app/(dashboard)/dashboard/analytics/loading-ce5214cdf489c9df.js +0 -1
  426. package/app/.next/static/chunks/app/(dashboard)/dashboard/api-manager/page-12d772841a253032.js +0 -1
  427. package/app/.next/static/chunks/app/(dashboard)/dashboard/audit-log/page-c9b98846b8479f3f.js +0 -1
  428. package/app/.next/static/chunks/app/(dashboard)/dashboard/cli-tools/page-6453cc8ebb7db016.js +0 -15
  429. package/app/.next/static/chunks/app/(dashboard)/dashboard/endpoint/page-ef0038a40cb26943.js +0 -1
  430. package/app/.next/static/chunks/app/(dashboard)/dashboard/limits/page-0ae1d6cc5fc4671f.js +0 -1
  431. package/app/.next/static/chunks/app/(dashboard)/dashboard/page-5c87e49261a22fd5.js +0 -1
  432. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-b38f2d03bae8166a.js +0 -1
  433. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/new/page-a7fb36872be60fe0.js +0 -1
  434. package/app/.next/static/chunks/app/(dashboard)/dashboard/settings/page-085a5e0a1d0de919.js +0 -1
  435. package/app/.next/static/chunks/app/forbidden/page-77657dfa95e61cd8.js +0 -1
  436. package/app/.next/static/chunks/app/forgot-password/page-be3bacc125c30a6b.js +0 -1
  437. package/app/.next/static/chunks/app/global-error-504ff9093e2a997d.js +0 -1
  438. package/app/.next/static/chunks/app/landing/page-75b0c988db383cfc.js +0 -1
  439. package/app/.next/static/chunks/app/not-found-11b712c853d93172.js +0 -1
  440. package/app/logs/application/app.log +0 -6685
  441. /package/app/.next/static/{GhECt_DwDldLWyCh-8168 → iqSCUTEzH78lajJjqTmE_}/_buildManifest.js +0 -0
  442. /package/app/.next/static/{GhECt_DwDldLWyCh-8168 → iqSCUTEzH78lajJjqTmE_}/_ssgManifest.js +0 -0
@@ -1,5 +1,12 @@
1
1
  "use strict";exports.id=2767,exports.ids=[2767],exports.modules={1308:(a,b,c)=>{c.d(b,{$E:()=>n,Kr:()=>t,UE:()=>u,YO:()=>p,getAllRateLimitStatus:()=>v,mg:()=>m,rh:()=>l});var d=c(57217),e=c.n(d);c(74163);var f=c(83596),g=c(60293);let h=new Map,i=new Set,j=!1,k={maxConcurrent:10,minTime:0,reservoir:null,reservoirRefreshAmount:null,reservoirRefreshInterval:null};async function l(){if(!j){j=!0;try{let{getProviderConnections:a}=await Promise.resolve().then(c.bind(c,22901)),b=await a(),d=0,j=0;for(let a of b)if(a.rateLimitProtection)i.add(a.id),d++;else if(a.provider&&"apikey"===(0,f.oQ)(a.provider)&&a.isActive){i.add(a.id),j++;let b=`${a.provider}:${a.id}`;h.has(b)||h.set(b,new(e())({maxConcurrent:g.DEFAULT_API_LIMITS.concurrentRequests,minTime:g.DEFAULT_API_LIMITS.minTimeBetweenRequests,reservoir:g.DEFAULT_API_LIMITS.requestsPerMinute,reservoirRefreshAmount:g.DEFAULT_API_LIMITS.requestsPerMinute,reservoirRefreshInterval:6e4,id:b}))}(d>0||j>0)&&console.log(`🛡️ [RATE-LIMIT] Loaded ${d} explicit + ${j} auto-enabled (API key) protection(s)`)}catch(a){console.error("[RATE-LIMIT] Failed to load settings:",a.message)}}}function m(a){i.add(a)}function n(a){for(let[b]of(i.delete(a),h))if(b.includes(a)){let a=h.get(b);a?.disconnect(),h.delete(b)}}function o(a,b,c=null){let d=c?`${a}:${b}:${c}`:`${a}:${b}`;if(!h.has(d)){let a=new(e())({...k,id:d});a.on("queued",()=>{let b=a.counts();b.QUEUED>0&&console.log(`⏳ [RATE-LIMIT] ${d} — ${b.QUEUED} request(s) queued, ${b.RUNNING} running`)}),h.set(d,a)}return h.get(d)}async function p(a,b,c,d){return i.has(b)?o(a,b,null).schedule(d):d()}let q={limit:"x-ratelimit-limit-requests",remaining:"x-ratelimit-remaining-requests",reset:"x-ratelimit-reset-requests",limitTokens:"x-ratelimit-limit-tokens",remainingTokens:"x-ratelimit-remaining-tokens",resetTokens:"x-ratelimit-reset-tokens",retryAfter:"retry-after",overLimit:"x-ratelimit-over-limit"},r={limit:"anthropic-ratelimit-requests-limit",remaining:"anthropic-ratelimit-requests-remaining",reset:"anthropic-ratelimit-requests-reset",limitTokens:"anthropic-ratelimit-input-tokens-limit",remainingTokens:"anthropic-ratelimit-input-tokens-remaining",resetTokens:"anthropic-ratelimit-input-tokens-reset",retryAfter:"retry-after"};function s(a){if(!a)return null;let b=a.match(/^(?:(\d+)h)?(?:(\d+)m(?!s))?(?:(\d+)s)?(?:(\d+)ms)?$/);if(b){let[,a,c,d,e]=b;return(3600*parseInt(a||0)+60*parseInt(c||0)+parseInt(d||0))*1e3+parseInt(e||0)}let c=parseFloat(a);if(!isNaN(c)&&c>0)return c>17e8?Math.max(0,1e3*c-Date.now()):1e3*c;try{let b=new Date(a);if(!isNaN(b.getTime()))return Math.max(0,b.getTime()-Date.now())}catch{}return null}function t(a,b,c,d,e=null){if(!i.has(b)||!c)return;let f=o(a,b,null),g="claude"===a||"anthropic"===a?r:q,h=a=>"function"==typeof c.get?c.get(a):c[a]||null,j=parseInt(h(g.limit)),k=parseInt(h(g.remaining)),l=h(g.reset),m=h(g.retryAfter),n=h(q.overLimit);if(429===d){let c=s(m)||6e4;console.log(`🚫 [RATE-LIMIT] ${a}:${b.slice(0,8)} — 429 received, pausing for ${Math.ceil(c/1e3)}s`),f.updateSettings({reservoir:0,reservoirRefreshAmount:j||60,reservoirRefreshInterval:c});return}if("yes"===n){console.log(`⚠️ [RATE-LIMIT] ${a}:${b.slice(0,8)} — near capacity, slowing down`),f.updateSettings({minTime:200});return}if(!isNaN(j)&&j>0){let c=s(l)||6e4,d={minTime:Math.max(0,Math.floor(6e4/j)-10)};!isNaN(k)&&(k<.1*j?(d.reservoir=k,d.reservoirRefreshAmount=j,d.reservoirRefreshInterval=c,console.log(`⚠️ [RATE-LIMIT] ${a}:${b.slice(0,8)} — ${k}/${j} remaining, throttling`)):k>.5*j&&(d.minTime=0,d.reservoir=null,d.reservoirRefreshAmount=null,d.reservoirRefreshInterval=null)),f.updateSettings(d)}}function u(a,b){let c=`${a}:${b}`,d=h.get(c);if(!d)return{enabled:i.has(b),active:!1,queued:0,running:0};let e=d.counts();return{enabled:i.has(b),active:!0,queued:e.QUEUED||0,running:e.RUNNING||0,executing:e.EXECUTING||0,done:e.DONE||0}}function v(){let a={};for(let[b,c]of h){let d=c.counts();a[b]={queued:d.QUEUED||0,running:d.RUNNING||0,executing:d.EXECUTING||0}}return a}},6327:(a,b,c)=>{function d({onDisconnect:a,log:b,provider:c,model:e}={}){let f=new AbortController,g=Date.now(),h=!1,i=null,j=a=>{let b=Date.now()-g,d=c?.toUpperCase()||"UNKNOWN";console.log(`[${new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit",second:"2-digit"})}] 🌊 [STREAM] ${d} | ${e||"unknown"} | ${b}ms | ${a}`)};return{signal:f.signal,startTime:g,isConnected:()=>!h,handleDisconnect:(b="client_closed")=>{h||(h=!0,j(`disconnect: ${b}`),i=setTimeout(()=>{f.abort()},500),a?.({reason:b,duration:Date.now()-g}))},handleComplete:()=>{!h&&(h=!0,j("complete"),i&&(clearTimeout(i),i=null))},handleError:a=>{(i&&(clearTimeout(i),i=null),"AbortError"===a.name)?j("aborted"):j(`error: ${a.message}`)},abort:()=>f.abort()}}function e(a,b,c){var d;let e,f;return d={readable:a.body.pipeThrough(b),writable:{getWriter:()=>({abort:()=>{}})}},e=d.readable.getReader(),f=d.writable.getWriter(),new ReadableStream({async pull(a){if(!c.isConnected())return void a.close();try{let{done:b,value:d}=await e.read();if(b){c.handleComplete(),a.close();return}a.enqueue(d)}catch(b){c.handleError(b),a.error(b)}},cancel(a){c.handleDisconnect(a||"cancelled"),e.cancel(),f.abort()}})}c.d(b,{Jb:()=>e,jd:()=>d})},8550:(a,b,c)=>{c.d(b,{M:()=>d});function d(a,b){if(!a||"object"!=typeof a)return null;if(a.usage&&"object"==typeof a.usage&&void 0!==a.usage.prompt_tokens)return{prompt_tokens:a.usage.prompt_tokens||0,completion_tokens:a.usage.completion_tokens||0,cached_tokens:a.usage.prompt_tokens_details?.cached_tokens,reasoning_tokens:a.usage.completion_tokens_details?.reasoning_tokens};let c=a.response?.usage||a.usage;return c&&"object"==typeof c&&(void 0!==c.input_tokens||void 0!==c.output_tokens)?{prompt_tokens:c.input_tokens||0,completion_tokens:c.output_tokens||0,cached_tokens:c.cache_read_input_tokens,cache_creation_input_tokens:c.cache_creation_input_tokens,reasoning_tokens:c.reasoning_tokens||c.output_tokens_details?.reasoning_tokens}:a.usage&&"object"==typeof a.usage&&(void 0!==a.usage.input_tokens||void 0!==a.usage.output_tokens)?{prompt_tokens:a.usage.input_tokens||0,completion_tokens:a.usage.output_tokens||0,cache_read_input_tokens:a.usage.cache_read_input_tokens,cache_creation_input_tokens:a.usage.cache_creation_input_tokens}:a.usageMetadata&&"object"==typeof a.usageMetadata?{prompt_tokens:a.usageMetadata.promptTokenCount||0,completion_tokens:a.usageMetadata.candidatesTokenCount||0,reasoning_tokens:a.usageMetadata.thoughtsTokenCount}:null}},9315:(a,b,c)=>{let d;c.d(b,{Cb:()=>l,IL:()=>o,QS:()=>p,RE:()=>n,TZ:()=>q,gR:()=>k,yv:()=>m});var e=c(77598),f=c.n(e),g=c(44594),h=c(42910);let i={hits:0,misses:0,tokensSaved:0};function j(){return d||(d=new g.q({maxSize:parseInt(process.env.SEMANTIC_CACHE_MAX_SIZE||"500",10),defaultTTL:parseInt(process.env.SEMANTIC_CACHE_TTL_MS||"3600000",10)})),d}function k(a,b,c=0,d=1){var e;let g=JSON.stringify({model:a,messages:Array.isArray(e=b)?e.map(a=>({role:a.role||"user",content:"string"==typeof a.content?a.content:JSON.stringify(a.content)})):[],temperature:c,top_p:d});return f().createHash("sha256").update(g).digest("hex")}function l(a){let b=j().get(a);if(b)return i.hits++,i.tokensSaved+=b.tokensSaved||0,b.response;try{let b=(0,h.sm)(),c=b.prepare("SELECT response, tokens_saved FROM semantic_cache WHERE signature = ? AND expires_at > datetime('now')").get(a);if(c){let d=JSON.parse(c.response);return j().set(a,{response:d,tokensSaved:c.tokens_saved}),b.prepare("UPDATE semantic_cache SET hit_count = hit_count + 1 WHERE signature = ?").run(a),i.hits++,i.tokensSaved+=c.tokens_saved||0,d}}catch{}return i.misses++,null}function m(a,b,c,d=0,e=36e5){let g=parseInt(process.env.SEMANTIC_CACHE_TTL_MS||String(e),10);j().set(a,{response:c,tokensSaved:d},g);try{let e=(0,h.sm)(),i=f().randomUUID(),j=a.slice(0,16),k=new Date().toISOString(),l=new Date(Date.now()+g).toISOString();e.prepare(`INSERT OR REPLACE INTO semantic_cache (id, signature, model, prompt_hash, response, tokens_saved, hit_count, created_at, expires_at)
2
- VALUES (?, ?, ?, ?, ?, ?, 0, ?, ?)`).run(i,a,b,j,JSON.stringify(c),d,k,l)}catch{}}function n(){try{return(0,h.sm)().prepare("DELETE FROM semantic_cache WHERE expires_at <= datetime('now')").run().changes}catch{return 0}}function o(){j().clear();try{(0,h.sm)().prepare("DELETE FROM semantic_cache").run()}catch{}i={hits:0,misses:0,tokensSaved:0}}function p(){let a=j().getStats(),b=0;try{let a=(0,h.sm)().prepare("SELECT COUNT(*) as count FROM semantic_cache WHERE expires_at > datetime('now')").get();b=a?.count||0}catch{}let c=i.hits+i.misses;return{memoryEntries:a.size,dbEntries:b,hits:i.hits,misses:i.misses,hitRate:c>0?(i.hits/c*100).toFixed(1):"0.0",tokensSaved:i.tokensSaved}}function q(a,b){return b?.get?.("x-omniroute-no-cache")!=="true"&&!1===a.stream&&(a.temperature??0)===0}},9686:(a,b,c)=>{c.d(b,{eU:()=>i,vN:()=>h});var d=c(83779),e=c(22901),f=c(87068);let g=f.oD;async function h(a,b){try{let c={};b.accessToken&&(c.accessToken=b.accessToken),b.refreshToken&&(c.refreshToken=b.refreshToken),b.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*b.expiresIn).toISOString(),c.expiresIn=b.expiresIn),b.providerSpecificData&&(c.providerSpecificData=b.providerSpecificData);let f=await (0,e.rj)(a,c);return d.info("TOKEN_REFRESH","Credentials updated in localDb",{connectionId:a,success:!!f}),!!f}catch(b){return d.error("TOKEN_REFRESH","Error updating credentials in localDb",{connectionId:a,error:b.message}),!1}}async function i(a,b){let c={...b};if(c.expiresAt){let b=new Date(c.expiresAt).getTime(),e=Date.now();if(b-e<g){let g;d.info("TOKEN_REFRESH","Token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round((b-e)/1e3)});let i=await (g=c,(0,f.iD)(a,g,d));i&&i.accessToken&&(await h(c.connectionId,i),c={...c,accessToken:i.accessToken,refreshToken:i.refreshToken||c.refreshToken,expiresAt:i.expiresIn?new Date(Date.now()+1e3*i.expiresIn).toISOString():c.expiresAt})}}if("github"===a&&c.providerSpecificData?.copilotTokenExpiresAt){let b=1e3*c.providerSpecificData.copilotTokenExpiresAt,e=Date.now();if(b-e<g){let g;d.info("TOKEN_REFRESH","Copilot token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round((b-e)/1e3)});let i=await (g=c.accessToken,(0,f.jR)(g,d));i&&(await h(c.connectionId,{providerSpecificData:{...c.providerSpecificData,copilotToken:i.token,copilotTokenExpiresAt:i.expiresAt}}),c.providerSpecificData={...c.providerSpecificData,copilotToken:i.token,copilotTokenExpiresAt:i.expiresAt})}}return c}},12767:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{P:()=>A});var e=c(21020),f=c(13961),g=c(32113),h=c(69590),i=c(71861),j=c(17669),k=c(60293),l=c(23969),m=c(76340),n=c(83779),o=c(9686),p=c(22901),q=c(34493),r=c(26510),s=c(77458),t=c(12620),u=c(20864),v=c(44057),w=c(59545),x=c(78790),y=c(70884),z=a([h]);async function A(a,b=null){let c,d=(0,w.KZ)(),g=new v.TT(d);try{g.startPhase("parse"),c=await a.json(),g.endPhase()}catch{return n.warn("CHAT","Invalid JSON body"),(0,i.yj)(k.gx.BAD_REQUEST,"Invalid JSON body")}g.startPhase("validate");let h=(0,s.Jh)(c,n);if(h.blocked)return n.warn("SANITIZER","Request blocked due to prompt injection",{detections:h.detections}),(0,i.yj)(k.gx.BAD_REQUEST,"Request rejected: suspicious content detected");h.modified&&h.sanitizedBody&&(c=h.sanitizedBody),g.endPhase(),b||(b={endpoint:new URL(a.url).pathname,body:c,headers:Object.fromEntries(a.headers.entries())});let l=new URL(a.url),m=c.model,o=c.messages?.length||c.input?.length||0,q=c.tools?.length||0,r=c.reasoning_effort||c.reasoning?.effort||null;n.request("POST",`${l.pathname} | ${m} | ${o} msgs${q?` | ${q} tools`:""}${r?` | effort=${r}`:""}`);let t=a.headers.get("Authorization"),x=(0,e.Tr)(a);if(t&&x?n.debug("AUTH",`API Key: ${n.maskKey(x)}`):n.debug("AUTH","No API key provided (local mode)"),"true"===process.env.REQUIRE_API_KEY){if(!x)return n.warn("AUTH","Missing API key while REQUIRE_API_KEY=true"),(0,i.yj)(k.gx.UNAUTHORIZED,"Missing API key");if(!await (0,e.kI)(x))return n.warn("AUTH","Invalid API key while REQUIRE_API_KEY=true"),(0,i.yj)(k.gx.UNAUTHORIZED,"Invalid API key")}if(!m)return n.warn("CHAT","Missing model"),(0,i.yj)(k.gx.BAD_REQUEST,"Missing model");g.startPhase("policy");let z=await (0,y.S)(a,m);if(z.rejection)return n.warn("POLICY",`API key policy rejected: ${m} (key=${z.apiKeyInfo?.id||"unknown"})`),z.rejection;let C=z.apiKeyInfo;g.endPhase(),g.startPhase("resolve");let D=await (0,f.$m)(m);if(D){n.info("CHAT",`Combo "${m}" [${D.strategy||"priority"}] with ${D.models.length} models`);let d=async a=>{let b=await (0,f.mA)(a),c=b.provider;if(!c)return!0;if(!(0,u.fj)(c,b.model||a))return n.debug("AVAILABILITY",`${c}/${b.model} in cooldown, skipping`),!1;let d=await (0,e.c1)(c);return!!d&&!d.allRateLimited},[h,i]=await Promise.all([(0,p.V7)().catch(()=>({})),(0,p.Uv)().catch(()=>[])]);g.endPhase();let k=await (0,j.Pr)({body:c,combo:D,handleSingleModel:(c,d)=>B(c,d,b,a,D.name,C,g),isModelAvailable:d,log:n,settings:h,allCombos:i});return(0,v.N3)(g),k}g.endPhase();let E=await B(c,m,b,a,null,C,g);return(0,v.N3)(g),E}async function B(a,b,c=null,d=null,f=null,g=null,h=null){var j,l;let m=await C(b,a);if(m.error)return m.error;let{provider:p,model:s,sourceFormat:v,targetFormat:w}=m,y=(j=p,l=s,(0,u.fj)(j,l)?(0,t.getCircuitBreaker)(j,{failureThreshold:5,resetTimeout:3e4,onStateChange:(a,b,c)=>n.info("CIRCUIT",`${a}: ${b} → ${c}`)}).canExecute()?null:(n.warn("CIRCUIT",`Circuit breaker OPEN for ${j}, rejecting request`),(0,i.wO)(k.gx.SERVICE_UNAVAILABLE,`Provider ${j} circuit breaker is open`,30)):(n.warn("AVAILABILITY",`${j}/${l} is in cooldown, rejecting request`),(0,i.wO)(k.gx.SERVICE_UNAVAILABLE,`Model ${j}/${l} is temporarily unavailable (cooldown)`,30)));if(y)return y;let z=(0,t.getCircuitBreaker)(p,{failureThreshold:5,resetTimeout:3e4,onStateChange:(a,b,c)=>n.info("CIRCUIT",`${a}: ${b} → ${c}`)}),A=d?.headers?.get("user-agent")||"",F=null,G=null,H=null;for(;;){let b=await (0,e.c1)(p,F);if(!b||b.allRateLimited)return function(a,b,c,d,e,f){if(a?.allRateLimited){let b=e||a.lastError||"Unavailable",g=f||Number(a.lastErrorCode)||k.gx.SERVICE_UNAVAILABLE;return n.warn("CHAT",`[${c}/${d}] ${b} (${a.retryAfterHuman})`),(0,i.wO)(g,`[${c}/${d}] ${b}`,a.retryAfter,a.retryAfterHuman)}return b?(n.warn("CHAT","No more accounts available",{provider:c}),(0,i.yj)(f||k.gx.SERVICE_UNAVAILABLE,e||"All accounts unavailable")):(n.error("AUTH",`No credentials for provider: ${c}`),(0,i.yj)(k.gx.BAD_REQUEST,`No credentials for provider: ${c}`))}(b,F,p,s,G,H);let d=b.connectionId.slice(0,8);n.info("AUTH",`Using ${p} account: ${d}...`);let j=await (0,o.eU)(p,b),l=await E(b.connectionId),m=Date.now();h&&h.startPhase("connect");let{result:t,tlsFingerprintUsed:y}=await D({breaker:z,body:a,provider:p,model:s,refreshedCredentials:j,proxyInfo:l,log:n,clientRawRequest:c,credentials:b,apiKeyInfo:g,userAgent:A,comboName:f});h&&h.endPhase();let B=Date.now()-m;if(function({result:a,proxyInfo:b,proxyLatency:c,provider:d,model:e,sourceFormat:f,targetFormat:g,credentials:h,comboName:i,clientRawRequest:j,tlsFingerprintUsed:k=!1}){try{(0,q.pq)({status:a.success?"success":408===a.status||504===a.status?"timeout":"error",proxy:b?.proxy||null,level:b?.level||"direct",levelId:b?.levelId||null,provider:d,targetUrl:`${d}/${e}`,latencyMs:c,error:a.success?null:a.error||null,connectionId:h.connectionId,comboId:i||null,account:h.connectionId?.slice(0,8)||null,tlsFingerprint:k})}catch{}try{(0,r.MR)({provider:d,model:e,sourceFormat:f,targetFormat:g,status:a.success?"success":"error",statusCode:a.success?200:a.status||500,latency:c,endpoint:j?.endpoint||"/v1/chat/completions",connectionId:h.connectionId||null,comboName:i||null})}catch{}}({result:t,proxyInfo:l,proxyLatency:B,provider:p,model:s,sourceFormat:v,targetFormat:w,credentials:b,comboName:f,clientRawRequest:c,tlsFingerprintUsed:y}),t.success)return function(a,b){if(a?.id)try{let c=b.usage||{},d=((c.prompt_tokens||0)+(c.completion_tokens||0))*1e-6;d>0&&(0,x.n5)(a.id,d)}catch{}}(g,t),h&&h.startPhase("finalize"),h&&h.endPhase(),t.response;(429===t.status||503===t.status)&&((0,u.gC)(p,s,6e4,`HTTP ${t.status}`),n.info("AVAILABILITY",`${p}/${s} marked unavailable for 60s (HTTP ${t.status})`));let{shouldFallback:C}=await (0,e.vk)(b.connectionId,t.status,t.error,p);if(C){n.warn("AUTH",`Account ${d}... unavailable (${t.status}), trying fallback`),F=b.connectionId,G=t.error,H=t.status;continue}return t.response}}async function C(a,b){let c=await (0,f.mA)(a);if(!c.provider){if("ambiguous_model"===c.errorType){let b=c.errorMessage||`Ambiguous model '${a}'. Use provider/model prefix (ex: gh/${a} or cc/${a}).`;return n.warn("CHAT",b,{model:a,candidates:c.candidateAliases||c.candidateProviders||[]}),{error:(0,i.yj)(k.gx.BAD_REQUEST,b)}}return n.warn("CHAT","Invalid model format",{model:a}),{error:(0,i.yj)(k.gx.BAD_REQUEST,"Invalid model format")}}let{provider:d,model:e}=c,h=(0,g.Tz)(b),j=l.PROVIDER_ID_TO_ALIAS[d]||d,m=(0,l.ux)(j,e)||(0,g.jJ)(d);return a!==`${d}/${e}`?n.info("ROUTING",`${a} → ${d}/${e}`):n.info("ROUTING",`Provider: ${d}, Model: ${e}`),{provider:d,model:e,sourceFormat:h,targetFormat:m}}async function D({breaker:a,body:b,provider:c,model:d,refreshedCredentials:f,proxyInfo:g,log:j,clientRawRequest:l,credentials:p,apiKeyInfo:q,userAgent:r,comboName:s}){try{let i=()=>(0,m.jf)(g?.proxy||null,()=>(0,h.w)({body:{...b,model:`${c}/${d}`},modelInfo:{provider:c,model:d},credentials:f,log:j,clientRawRequest:l,connectionId:p.connectionId,apiKeyInfo:q,userAgent:r,comboName:s,onCredentialsRefreshed:async a=>{await (0,o.vN)(p.connectionId,{accessToken:a.accessToken,refreshToken:a.refreshToken,providerSpecificData:a.providerSpecificData,testStatus:"active"})},onRequestSuccess:async()=>{await (0,e.Pt)(p.connectionId,p)}}));if(!g?.proxy&&(0,m.Wk)()){let b=await a.execute(async()=>(0,m.qT)(i));return{result:b.result,tlsFingerprintUsed:b.tlsFingerprintUsed}}return{result:await a.execute(i),tlsFingerprintUsed:!1}}catch(a){if(a instanceof t.ez)return n.warn("CIRCUIT",`${c} circuit open during retry: ${a.message}`),{result:{success:!1,response:(0,i.wO)(k.gx.SERVICE_UNAVAILABLE,`Provider ${c} circuit breaker is open`,Math.ceil(a.retryAfterMs/1e3)),status:k.gx.SERVICE_UNAVAILABLE},tlsFingerprintUsed:!1};throw a}}async function E(a){try{return await (0,p.YD)(a)}catch(a){return n.debug("PROXY",`Failed to resolve proxy: ${a.message}`),null}}h=(z.then?(await z)():z)[0],d()}catch(a){d(a)}})},13961:(a,b,c)=>{c.d(b,{$m:()=>g,mA:()=>f});var d=c(22901),e=c(99939);async function f(a){let b=(0,e.Xh)(a);if(b.providerAlias||b.provider){let a=b.providerAlias||b.provider,c=(await (0,d.Fh)({type:"openai-compatible"})).find(b=>b.prefix===a);if(c)return{provider:c.id,model:b.model};let e=(await (0,d.Fh)({type:"anthropic-compatible"})).find(b=>b.prefix===a);if(e)return{provider:e.id,model:b.model}}return b.isAlias?(0,e.js)(a,d.OM):(0,e.js)(a,null)}async function g(a){let b=await (0,d.Dj)(a);return b&&b.models&&b.models.length>0?b:null}},20864:(a,b,c)=>{c.d(b,{DQ:()=>h,GX:()=>j,Wj:()=>i,fj:()=>f,gC:()=>g});let d=new Map;function e(a,b){return`${a}::${b}`}function f(a,b){let c=e(a,b),f=d.get(c);return!f||Date.now()-f.unavailableSince>=f.cooldownMs&&(d.delete(c),!0)}function g(a,b,c=6e4,f){let h=e(a,b);d.set(h,{provider:a,model:b,unavailableSince:Date.now(),cooldownMs:c,reason:f||"unknown"})}function h(a,b){return d.delete(e(a,b))}function i(){let a=Date.now(),b=[];for(let[c,e]of d.entries()){let f=a-e.unavailableSince;if(f>=e.cooldownMs){d.delete(c);continue}b.push({provider:e.provider,model:e.model,reason:e.reason||"unknown",remainingMs:e.cooldownMs-f,unavailableSince:new Date(e.unavailableSince).toISOString()})}return b}function j(){return i(),d.size}},26510:(a,b,c)=>{function d(){return globalThis.__translatorEvents||(globalThis.__translatorEvents=[]),globalThis.__translatorEvents}function e(a){if(!a||"object"!=typeof a)return;let b=d();b.unshift({id:`evt_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,timestamp:new Date().toISOString(),...a}),b.length>200&&(b.length=200)}function f(a=50){let b=Number(a),c=Number.isFinite(b)&&b>0?Math.min(Math.floor(b),200):50,e=d();return{events:e.slice(0,c),total:e.length}}c.d(b,{MR:()=>e,zS:()=>f})},26695:(a,b,c)=>{c.d(b,{lm:()=>g.lm,l2:()=>q,i5:()=>p,v8:()=>j});var d=c(89575),e=c(55120),f=c(27230),g=c(50101);function h(a){if(!a)return null;let b=a.trimStart();if(!b||100!==b.charCodeAt(0))return null;let c=b.slice(5).trim();if("[DONE]"===c)return{done:!0};try{return JSON.parse(c)}catch(a){return c.length>0&&console.log(`[WARN] Failed to parse SSE line (${c.length} chars): ${c.substring(0,200)}...`),null}}function i(a,b){if(b===e.h.OPENAI&&a.choices?.[0]?.delta){let b=a.choices[0].delta;return b.content&&""!==b.content||b.reasoning_content&&""!==b.reasoning_content||b.tool_calls&&b.tool_calls.length>0||a.choices[0].finish_reason||b.role}if(b===e.h.CLAUDE){let b="content_block_delta"===a.type,c=a.delta?.text&&""!==a.delta.text,d=a.delta?.thinking&&""!==a.delta.thinking,e=a.delta?.partial_json&&""!==a.delta.partial_json;return!b||!!c||!!d||!!e}if(b===e.h.GEMINI&&a.candidates?.[0]){let b=a.candidates[0];if(b.finishReason)return!0;let c=b.content?.parts;return!!c&&0!==c.length&&c.some(a=>a.text&&""!==a.text||a.functionCall||a.executableCode)}return!0}function j(a,b){return null==a?"data: null\n\n":a&&a.done?"data: [DONE]\n\n":a&&a.event&&a.data?`event: ${a.event}
2
+ VALUES (?, ?, ?, ?, ?, ?, 0, ?, ?)`).run(i,a,b,j,JSON.stringify(c),d,k,l)}catch{}}function n(){try{return(0,h.sm)().prepare("DELETE FROM semantic_cache WHERE expires_at <= datetime('now')").run().changes}catch{return 0}}function o(){j().clear();try{(0,h.sm)().prepare("DELETE FROM semantic_cache").run()}catch{}i={hits:0,misses:0,tokensSaved:0}}function p(){let a=j().getStats(),b=0;try{let a=(0,h.sm)().prepare("SELECT COUNT(*) as count FROM semantic_cache WHERE expires_at > datetime('now')").get();b=a?.count||0}catch{}let c=i.hits+i.misses;return{memoryEntries:a.size,dbEntries:b,hits:i.hits,misses:i.misses,hitRate:c>0?(i.hits/c*100).toFixed(1):"0.0",tokensSaved:i.tokensSaved}}function q(a,b){return b?.get?.("x-omniroute-no-cache")!=="true"&&!1===a.stream&&(a.temperature??0)===0}},9686:(a,b,c)=>{c.d(b,{eU:()=>i,vN:()=>h});var d=c(83779),e=c(22901),f=c(87068);let g=f.oD;async function h(a,b){try{let c={};b.accessToken&&(c.accessToken=b.accessToken),b.refreshToken&&(c.refreshToken=b.refreshToken),b.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*b.expiresIn).toISOString(),c.expiresIn=b.expiresIn),b.providerSpecificData&&(c.providerSpecificData=b.providerSpecificData);let f=await (0,e.rj)(a,c);return d.info("TOKEN_REFRESH","Credentials updated in localDb",{connectionId:a,success:!!f}),!!f}catch(b){return d.error("TOKEN_REFRESH","Error updating credentials in localDb",{connectionId:a,error:b.message}),!1}}async function i(a,b){let c={...b};if(c.expiresAt){let b=new Date(c.expiresAt).getTime(),e=Date.now();if(b-e<g){let g;d.info("TOKEN_REFRESH","Token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round((b-e)/1e3)});let i=await (g=c,(0,f.iD)(a,g,d));i&&i.accessToken&&(await h(c.connectionId,i),c={...c,accessToken:i.accessToken,refreshToken:i.refreshToken||c.refreshToken,expiresAt:i.expiresIn?new Date(Date.now()+1e3*i.expiresIn).toISOString():c.expiresAt})}}if("github"===a&&c.providerSpecificData?.copilotTokenExpiresAt){let b=1e3*c.providerSpecificData.copilotTokenExpiresAt,e=Date.now();if(b-e<g){let g;d.info("TOKEN_REFRESH","Copilot token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round((b-e)/1e3)});let i=await (g=c.accessToken,(0,f.jR)(g,d));i&&(await h(c.connectionId,{providerSpecificData:{...c.providerSpecificData,copilotToken:i.token,copilotTokenExpiresAt:i.expiresAt}}),c.providerSpecificData={...c.providerSpecificData,copilotToken:i.token,copilotTokenExpiresAt:i.expiresAt})}}return c}},12767:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{P:()=>A});var e=c(21020),f=c(13961),g=c(32113),h=c(69590),i=c(71861),j=c(17669),k=c(60293),l=c(23969),m=c(76340),n=c(83779),o=c(9686),p=c(22901),q=c(34493),r=c(26510),s=c(77458),t=c(12620),u=c(20864),v=c(44057),w=c(59545),x=c(78790),y=c(70884),z=a([h]);async function A(a,b=null){let c,d=(0,w.KZ)(),g=new v.TT(d);try{g.startPhase("parse"),c=await a.json(),g.endPhase()}catch{return n.warn("CHAT","Invalid JSON body"),(0,i.yj)(k.gx.BAD_REQUEST,"Invalid JSON body")}g.startPhase("validate");let h=(0,s.Jh)(c,n);if(h.blocked)return n.warn("SANITIZER","Request blocked due to prompt injection",{detections:h.detections}),(0,i.yj)(k.gx.BAD_REQUEST,"Request rejected: suspicious content detected");h.modified&&h.sanitizedBody&&(c=h.sanitizedBody),g.endPhase(),b||(b={endpoint:new URL(a.url).pathname,body:c,headers:Object.fromEntries(a.headers.entries())});let l=new URL(a.url),m=c.model,o=c.messages?.length||c.input?.length||0,q=c.tools?.length||0,r=c.reasoning_effort||c.reasoning?.effort||null;n.request("POST",`${l.pathname} | ${m} | ${o} msgs${q?` | ${q} tools`:""}${r?` | effort=${r}`:""}`);let t=a.headers.get("Authorization"),x=(0,e.Tr)(a);if(t&&x?n.debug("AUTH",`API Key: ${n.maskKey(x)}`):n.debug("AUTH","No API key provided (local mode)"),"true"===process.env.REQUIRE_API_KEY){if(!x)return n.warn("AUTH","Missing API key while REQUIRE_API_KEY=true"),(0,i.yj)(k.gx.UNAUTHORIZED,"Missing API key");if(!await (0,e.kI)(x))return n.warn("AUTH","Invalid API key while REQUIRE_API_KEY=true"),(0,i.yj)(k.gx.UNAUTHORIZED,"Invalid API key")}if(!m)return n.warn("CHAT","Missing model"),(0,i.yj)(k.gx.BAD_REQUEST,"Missing model");g.startPhase("policy");let z=await (0,y.S)(a,m);if(z.rejection)return n.warn("POLICY",`API key policy rejected: ${m} (key=${z.apiKeyInfo?.id||"unknown"})`),z.rejection;let C=z.apiKeyInfo;g.endPhase(),g.startPhase("resolve");let D=await (0,f.$m)(m);if(D){n.info("CHAT",`Combo "${m}" [${D.strategy||"priority"}] with ${D.models.length} models`);let d=async a=>{let b=await (0,f.mA)(a),c=b.provider;if(!c)return!0;if(!(0,u.fj)(c,b.model||a))return n.debug("AVAILABILITY",`${c}/${b.model} in cooldown, skipping`),!1;let d=await (0,e.c1)(c);return!!d&&!d.allRateLimited},[h,i]=await Promise.all([(0,p.V7)().catch(()=>({})),(0,p.Uv)().catch(()=>[])]);g.endPhase();let k=await (0,j.Pr)({body:c,combo:D,handleSingleModel:(c,d)=>B(c,d,b,a,D.name,C,g),isModelAvailable:d,log:n,settings:h,allCombos:i});return(0,v.N3)(g),k}g.endPhase();let E=await B(c,m,b,a,null,C,g);return(0,v.N3)(g),E}async function B(a,b,c=null,d=null,f=null,g=null,h=null){var j,l;let m=await C(b,a);if(m.error)return m.error;let{provider:p,model:s,sourceFormat:v,targetFormat:w}=m,y=(j=p,l=s,(0,u.fj)(j,l)?(0,t.getCircuitBreaker)(j,{failureThreshold:5,resetTimeout:3e4,onStateChange:(a,b,c)=>n.info("CIRCUIT",`${a}: ${b} → ${c}`)}).canExecute()?null:(n.warn("CIRCUIT",`Circuit breaker OPEN for ${j}, rejecting request`),(0,i.wO)(k.gx.SERVICE_UNAVAILABLE,`Provider ${j} circuit breaker is open`,30)):(n.warn("AVAILABILITY",`${j}/${l} is in cooldown, rejecting request`),(0,i.wO)(k.gx.SERVICE_UNAVAILABLE,`Model ${j}/${l} is temporarily unavailable (cooldown)`,30)));if(y)return y;let z=(0,t.getCircuitBreaker)(p,{failureThreshold:5,resetTimeout:3e4,onStateChange:(a,b,c)=>n.info("CIRCUIT",`${a}: ${b} → ${c}`)}),A=d?.headers?.get("user-agent")||"",F=null,G=null,H=null;for(;;){let b=await (0,e.c1)(p,F);if(!b||b.allRateLimited)return function(a,b,c,d,e,f){if(a?.allRateLimited){let b=e||a.lastError||"Unavailable",g=f||Number(a.lastErrorCode)||k.gx.SERVICE_UNAVAILABLE;return n.warn("CHAT",`[${c}/${d}] ${b} (${a.retryAfterHuman})`),(0,i.wO)(g,`[${c}/${d}] ${b}`,a.retryAfter,a.retryAfterHuman)}return b?(n.warn("CHAT","No more accounts available",{provider:c}),(0,i.yj)(f||k.gx.SERVICE_UNAVAILABLE,e||"All accounts unavailable")):(n.error("AUTH",`No credentials for provider: ${c}`),(0,i.yj)(k.gx.BAD_REQUEST,`No credentials for provider: ${c}`))}(b,F,p,s,G,H);let d=b.connectionId.slice(0,8);n.info("AUTH",`Using ${p} account: ${d}...`);let j=await (0,o.eU)(p,b),l=await E(b.connectionId),m=Date.now();h&&h.startPhase("connect");let{result:t,tlsFingerprintUsed:y}=await D({breaker:z,body:a,provider:p,model:s,refreshedCredentials:j,proxyInfo:l,log:n,clientRawRequest:c,credentials:b,apiKeyInfo:g,userAgent:A,comboName:f});h&&h.endPhase();let B=Date.now()-m;if(function({result:a,proxyInfo:b,proxyLatency:c,provider:d,model:e,sourceFormat:f,targetFormat:g,credentials:h,comboName:i,clientRawRequest:j,tlsFingerprintUsed:k=!1}){try{(0,q.pq)({status:a.success?"success":408===a.status||504===a.status?"timeout":"error",proxy:b?.proxy||null,level:b?.level||"direct",levelId:b?.levelId||null,provider:d,targetUrl:`${d}/${e}`,latencyMs:c,error:a.success?null:a.error||null,connectionId:h.connectionId,comboId:i||null,account:h.connectionId?.slice(0,8)||null,tlsFingerprint:k})}catch{}try{(0,r.MR)({provider:d,model:e,sourceFormat:f,targetFormat:g,status:a.success?"success":"error",statusCode:a.success?200:a.status||500,latency:c,endpoint:j?.endpoint||"/v1/chat/completions",connectionId:h.connectionId||null,comboName:i||null})}catch{}}({result:t,proxyInfo:l,proxyLatency:B,provider:p,model:s,sourceFormat:v,targetFormat:w,credentials:b,comboName:f,clientRawRequest:c,tlsFingerprintUsed:y}),t.success)return function(a,b){if(a?.id)try{let c=b.usage||{},d=((c.prompt_tokens||0)+(c.completion_tokens||0))*1e-6;d>0&&(0,x.n5)(a.id,d)}catch{}}(g,t),h&&h.startPhase("finalize"),h&&h.endPhase(),t.response;(429===t.status||503===t.status)&&((0,u.gC)(p,s,6e4,`HTTP ${t.status}`),n.info("AVAILABILITY",`${p}/${s} marked unavailable for 60s (HTTP ${t.status})`));let{shouldFallback:C}=await (0,e.vk)(b.connectionId,t.status,t.error,p);if(C){n.warn("AUTH",`Account ${d}... unavailable (${t.status}), trying fallback`),F=b.connectionId,G=t.error,H=t.status;continue}return t.response}}async function C(a,b){let c=await (0,f.mA)(a);if(!c.provider){if("ambiguous_model"===c.errorType){let b=c.errorMessage||`Ambiguous model '${a}'. Use provider/model prefix (ex: gh/${a} or cc/${a}).`;return n.warn("CHAT",b,{model:a,candidates:c.candidateAliases||c.candidateProviders||[]}),{error:(0,i.yj)(k.gx.BAD_REQUEST,b)}}return n.warn("CHAT","Invalid model format",{model:a}),{error:(0,i.yj)(k.gx.BAD_REQUEST,"Invalid model format")}}let{provider:d,model:e}=c,h=(0,g.Tz)(b),j=l.PROVIDER_ID_TO_ALIAS[d]||d,m=(0,l.ux)(j,e)||(0,g.jJ)(d);return a!==`${d}/${e}`?n.info("ROUTING",`${a} → ${d}/${e}`):n.info("ROUTING",`Provider: ${d}, Model: ${e}`),{provider:d,model:e,sourceFormat:h,targetFormat:m}}async function D({breaker:a,body:b,provider:c,model:d,refreshedCredentials:f,proxyInfo:g,log:j,clientRawRequest:l,credentials:p,apiKeyInfo:q,userAgent:r,comboName:s}){try{let i=()=>(0,m.jf)(g?.proxy||null,()=>(0,h.w)({body:{...b,model:`${c}/${d}`},modelInfo:{provider:c,model:d},credentials:f,log:j,clientRawRequest:l,connectionId:p.connectionId,apiKeyInfo:q,userAgent:r,comboName:s,onCredentialsRefreshed:async a=>{await (0,o.vN)(p.connectionId,{accessToken:a.accessToken,refreshToken:a.refreshToken,providerSpecificData:a.providerSpecificData,testStatus:"active"})},onRequestSuccess:async()=>{await (0,e.Pt)(p.connectionId,p)}}));if(!g?.proxy&&(0,m.Wk)()){let b=await a.execute(async()=>(0,m.qT)(i));return{result:b.result,tlsFingerprintUsed:b.tlsFingerprintUsed}}return{result:await a.execute(i),tlsFingerprintUsed:!1}}catch(a){if(a instanceof t.ez)return n.warn("CIRCUIT",`${c} circuit open during retry: ${a.message}`),{result:{success:!1,response:(0,i.wO)(k.gx.SERVICE_UNAVAILABLE,`Provider ${c} circuit breaker is open`,Math.ceil(a.retryAfterMs/1e3)),status:k.gx.SERVICE_UNAVAILABLE},tlsFingerprintUsed:!1};throw a}}async function E(a){try{return await (0,p.YD)(a)}catch(a){return n.debug("PROXY",`Failed to resolve proxy: ${a.message}`),null}}h=(z.then?(await z)():z)[0],d()}catch(a){d(a)}})},13961:(a,b,c)=>{c.d(b,{$m:()=>g,mA:()=>f});var d=c(22901),e=c(99939);async function f(a){let b=(0,e.Xh)(a);if(b.providerAlias||b.provider){let a=b.providerAlias||b.provider,c=(await (0,d.Fh)({type:"openai-compatible"})).find(b=>b.prefix===a);if(c)return{provider:c.id,model:b.model};let e=(await (0,d.Fh)({type:"anthropic-compatible"})).find(b=>b.prefix===a);if(e)return{provider:e.id,model:b.model}}return b.isAlias?(0,e.js)(a,d.OM):(0,e.js)(a,null)}async function g(a){let b=await (0,d.Dj)(a);return b&&b.models&&b.models.length>0?b:null}},20864:(a,b,c)=>{c.d(b,{DQ:()=>h,GX:()=>j,Wj:()=>i,fj:()=>f,gC:()=>g});let d=new Map;function e(a,b){return`${a}::${b}`}function f(a,b){let c=e(a,b),f=d.get(c);return!f||Date.now()-f.unavailableSince>=f.cooldownMs&&(d.delete(c),!0)}function g(a,b,c=6e4,f){let h=e(a,b);d.set(h,{provider:a,model:b,unavailableSince:Date.now(),cooldownMs:c,reason:f||"unknown"})}function h(a,b){return d.delete(e(a,b))}function i(){let a=Date.now(),b=[];for(let[c,e]of d.entries()){let f=a-e.unavailableSince;if(f>=e.cooldownMs){d.delete(c);continue}b.push({provider:e.provider,model:e.model,reason:e.reason||"unknown",remainingMs:e.cooldownMs-f,unavailableSince:new Date(e.unavailableSince).toISOString()})}return b}function j(){return i(),d.size}},26510:(a,b,c)=>{function d(){return globalThis.__translatorEvents||(globalThis.__translatorEvents=[]),globalThis.__translatorEvents}function e(a){if(!a||"object"!=typeof a)return;let b=d();b.unshift({id:`evt_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,timestamp:new Date().toISOString(),...a}),b.length>200&&(b.length=200)}function f(a=50){let b=Number(a),c=Number.isFinite(b)&&b>0?Math.min(Math.floor(b),200):50,e=d();return{events:e.slice(0,c),total:e.length}}c.d(b,{MR:()=>e,zS:()=>f})},34493:(a,b,c)=>{c.d(b,{GL:()=>i,XT:()=>j,pq:()=>h});var d=c(94755),e=c(42910);let f=!e.m1&&!e.I8,g=[];if(f)try{for(let a of(0,e.sm)().prepare("SELECT * FROM proxy_logs ORDER BY timestamp DESC LIMIT ?").all(500))g.push({id:a.id,timestamp:a.timestamp,status:a.status||"success",proxy:a.proxy_host?{type:a.proxy_type,host:a.proxy_host,port:a.proxy_port}:null,level:a.level||"direct",levelId:a.level_id||null,provider:a.provider||null,targetUrl:a.target_url||null,publicIp:a.public_ip||null,latencyMs:a.latency_ms||0,error:a.error||null,connectionId:a.connection_id||null,comboId:a.combo_id||null,account:a.account||null,tlsFingerprint:1===a.tls_fingerprint});g.length>0&&console.log(`[proxyLogger] Loaded ${g.length} proxy logs from SQLite`)}catch(a){console.warn("[proxyLogger] Failed to load from DB:",a.message)}function h(a){let b={id:(0,d.A)(),timestamp:new Date().toISOString(),status:a.status||"success",proxy:a.proxy||null,level:a.level||"direct",levelId:a.levelId||null,provider:a.provider||null,targetUrl:a.targetUrl||null,publicIp:a.publicIp||null,latencyMs:a.latencyMs||0,error:a.error||null,connectionId:a.connectionId||null,comboId:a.comboId||null,account:a.account||null,tlsFingerprint:a.tlsFingerprint||!1};if(g.unshift(b),g.length>500&&(g.length=500),f)try{let a=(0,e.sm)();a.prepare(`INSERT INTO proxy_logs (id, timestamp, status, proxy_type, proxy_host, proxy_port,
3
+ level, level_id, provider, target_url, public_ip, latency_ms, error,
4
+ connection_id, combo_id, account, tls_fingerprint)
5
+ VALUES (@id, @timestamp, @status, @proxyType, @proxyHost, @proxyPort,
6
+ @level, @levelId, @provider, @targetUrl, @publicIp, @latencyMs, @error,
7
+ @connectionId, @comboId, @account, @tlsFingerprint)`).run({id:b.id,timestamp:b.timestamp,status:b.status,proxyType:b.proxy?.type||null,proxyHost:b.proxy?.host||null,proxyPort:b.proxy?.port||null,level:b.level,levelId:b.levelId,provider:b.provider,targetUrl:b.targetUrl,publicIp:b.publicIp,latencyMs:b.latencyMs,error:b.error,connectionId:b.connectionId,comboId:b.comboId,account:b.account,tlsFingerprint:+!!b.tlsFingerprint});let c=a.prepare("SELECT COUNT(*) as cnt FROM proxy_logs").get()?.cnt||0;c>500&&a.prepare(`DELETE FROM proxy_logs WHERE id IN (
8
+ SELECT id FROM proxy_logs ORDER BY timestamp ASC LIMIT ?
9
+ )`).run(c-500)}catch(a){console.warn("[proxyLogger] Failed to persist:",a.message)}return b}function i(a={}){let b=[...g];if(a.status&&(b="ok"===a.status?b.filter(a=>"success"===a.status):b.filter(b=>b.status===a.status)),a.type&&(b=b.filter(b=>b.proxy?.type===a.type)),a.provider&&(b=b.filter(b=>b.provider===a.provider)),a.level&&(b=b.filter(b=>b.level===a.level)),a.search){let c=a.search.toLowerCase();b=b.filter(a=>(a.proxy?.host||"").toLowerCase().includes(c)||(a.provider||"").toLowerCase().includes(c)||(a.targetUrl||"").toLowerCase().includes(c)||(a.publicIp||"").toLowerCase().includes(c)||(a.level||"").toLowerCase().includes(c)||(a.error||"").toLowerCase().includes(c)||(a.account||"").toLowerCase().includes(c))}let c=a.limit||300;return b.slice(0,c)}function j(){if(g.length=0,f)try{(0,e.sm)().prepare("DELETE FROM proxy_logs").run()}catch(a){console.warn("[proxyLogger] Failed to clear DB:",a.message)}}},44057:(a,b,c)=>{c.d(b,{N3:()=>g,TT:()=>e,ci:()=>i});let d=["parse","validate","policy","resolve","connect","stream","finalize"];class e{constructor(a){this.requestId=a,this.startTime=Date.now(),this.phases=[],this._currentPhase=null,this._phaseStart=null}startPhase(a){this._currentPhase&&this.endPhase(),this._currentPhase=a,this._phaseStart=Date.now()}endPhase(a={}){if(!this._currentPhase)return;let b=Date.now();this.phases.push({phase:this._currentPhase,startMs:this._phaseStart-this.startTime,endMs:b-this.startTime,durationMs:b-this._phaseStart,...a}),this._currentPhase=null,this._phaseStart=null}async measure(a,b){this.startPhase(a);try{let a=await b();return this.endPhase(),a}catch(a){throw this.endPhase({error:a.message}),a}}getSummary(){return this._currentPhase&&this.endPhase(),{requestId:this.requestId,totalMs:Date.now()-this.startTime,phases:[...this.phases]}}}let f=[];function g(a){let b=a.getSummary();for(b.recordedAt=Date.now(),f.push(b);f.length>1e3;)f.shift()}function h(a,b){if(0===a.length)return 0;let c=Math.ceil(b/100*a.length)-1;return a[Math.max(0,c)]}function i(a=3e5){let b=Date.now()-a,c=f.filter(a=>(a.recordedAt||0)>=b);if(0===c.length)return{count:0,p50:0,p95:0,p99:0,phaseBreakdown:{}};let e=c.map(a=>a.totalMs).sort((a,b)=>a-b),g={};for(let a of d){let b=c.flatMap(b=>b.phases.filter(b=>b.phase===a).map(a=>a.durationMs)).sort((a,b)=>a-b);b.length>0&&(g[a]={count:b.length,p50:h(b,50),p95:h(b,95),avg:Math.round(b.reduce((a,b)=>a+b,0)/b.length)})}return{count:c.length,p50:h(e,50),p95:h(e,95),p99:h(e,99),phaseBreakdown:g}}},44594:(a,b,c)=>{let d;c.d(b,{X:()=>h,q:()=>g});var e=c(77598),f=c.n(e);class g{#a;#b;#c;#d;#e;constructor(a={}){this.#a=new Map,this.#d=0,this.#e={hits:0,misses:0,evictions:0},this.#b=a.maxSize??100,this.#c=a.defaultTTL??3e5}static generateKey(a){let b=JSON.stringify(a,Object.keys(a).sort());return f().createHash("sha256").update(b).digest("hex").slice(0,16)}get(a){let b=this.#a.get(a);if(!b)return void this.#e.misses++;if(Date.now()-b.createdAt>b.ttl){this.#a.delete(a),this.#d--,this.#e.misses++;return}return this.#a.delete(a),b.hits++,this.#a.set(a,b),this.#e.hits++,b.value}set(a,b,c){for(this.#a.has(a)&&(this.#a.delete(a),this.#d--);this.#d>=this.#b;){let a=this.#a.keys().next().value;this.#a.delete(a),this.#d--,this.#e.evictions++}let d={key:a,value:b,createdAt:Date.now(),ttl:c??this.#c,size:JSON.stringify(b).length,hits:0};this.#a.set(a,d),this.#d++}has(a){let b=this.#a.get(a);return!!b&&(!(Date.now()-b.createdAt>b.ttl)||(this.#a.delete(a),this.#d--,!1))}delete(a){return!!this.#a.has(a)&&(this.#a.delete(a),this.#d--,!0)}clear(){this.#a.clear(),this.#d=0}getStats(){let a=this.#e.hits+this.#e.misses;return{size:this.#d,maxSize:this.#b,...this.#e,hitRate:a>0?this.#e.hits/a*100:0}}}function h(a){return d||(d=new g({maxSize:parseInt(process.env.PROMPT_CACHE_MAX_SIZE||"200",10),defaultTTL:parseInt(process.env.PROMPT_CACHE_TTL_MS||"600000",10),...a})),d}},49076:(a,b,c)=>{c.d(b,{lm:()=>g.lm,l2:()=>q,i5:()=>p,v8:()=>j});var d=c(89575),e=c(55120),f=c(27230),g=c(50101);function h(a){if(!a)return null;let b=a.trimStart();if(!b||100!==b.charCodeAt(0))return null;let c=b.slice(5).trim();if("[DONE]"===c)return{done:!0};try{return JSON.parse(c)}catch(a){return c.length>0&&console.log(`[WARN] Failed to parse SSE line (${c.length} chars): ${c.substring(0,200)}...`),null}}function i(a,b){if(b===e.h.OPENAI&&a.choices?.[0]?.delta){let b=a.choices[0].delta;return b.content&&""!==b.content||b.reasoning_content&&""!==b.reasoning_content||b.tool_calls&&b.tool_calls.length>0||a.choices[0].finish_reason||b.role}if(b===e.h.CLAUDE){let b="content_block_delta"===a.type,c=a.delta?.text&&""!==a.delta.text,d=a.delta?.thinking&&""!==a.delta.thinking,e=a.delta?.partial_json&&""!==a.delta.partial_json;return!b||!!c||!!d||!!e}if(b===e.h.GEMINI&&a.candidates?.[0]){let b=a.candidates[0];if(b.finishReason)return!0;let c=b.content?.parts;return!!c&&0!==c.length&&c.some(a=>a.text&&""!==a.text||a.functionCall||a.executableCode)}return!0}function j(a,b){return null==a?"data: null\n\n":a&&a.done?"data: [DONE]\n\n":a&&a.event&&a.data?`event: ${a.event}
3
10
  data: ${JSON.stringify(a.data)}
4
11
 
5
12
  `:(a=function(a){if(a?.usage&&"object"==typeof a.usage&&null===a.usage.perf_metrics){let{perf_metrics:b,...c}=a.usage;return{...a,usage:c}}return a}(a),b===e.h.CLAUDE&&a&&a.type)?`event: ${a.type}
@@ -10,17 +17,10 @@ data: ${JSON.stringify(a)}
10
17
  `}var k=c(60293),l=c(92937);let m="translate",n="passthrough";function o(a={}){let{mode:b=m,targetFormat:c,sourceFormat:p,provider:q=null,reqLogger:r=null,toolNameMap:s=null,model:t=null,connectionId:u=null,apiKeyInfo:v=null,body:w=null,onComplete:x=null}=a,y="",z=null,A=b===m?{...(0,d.Ws)(p),provider:q,toolNameMap:s}:null,B=0,C=!1,D=new TextDecoder,E=new TextEncoder,F=Date.now(),G=null,H=!1;return new TransformStream({start(a){k.TH>0&&(G=setInterval(()=>{if(!H&&Date.now()-F>k.TH){H=!0,clearInterval(G),G=null;let b=`[STREAM] Idle timeout: no data from ${q||"provider"} for ${k.TH}ms (model: ${t||"unknown"})`;console.warn(b),(0,f.uw)(t,q,u,!1),(0,f.E5)({model:t,provider:q,connectionId:u,status:`FAILED ${k.gx.GATEWAY_TIMEOUT}`}).catch(()=>{});let c=Error(b);c.name="StreamIdleTimeoutError",a.error(c)}},1e4))},transform(a,f){if(H)return;F=Date.now();let k=D.decode(a,{stream:!0});y+=k,r?.appendProviderChunk?.(k);let m=y.split("\n");for(let a of(y=m.pop()||"",m)){let k=a.trim();if(b===n){let b,c=!1;if(k.startsWith("data:")&&"[DONE]"!==k.slice(5).trim())try{let a=JSON.parse(k.slice(5).trim());a=(0,l.LM)(a);let d=function(a){if(a.id&&("chat"===a.id||"completion"===a.id||a.id.length<8)){let b=a.extend_fields?.requestId||a.extend_fields?.traceId||Date.now().toString(36);return a.id=`chatcmpl-${b}`,!0}return!1}(a);if(!i(a,e.h.OPENAI))continue;let f=a.choices?.[0]?.delta;if(f?.content&&"string"==typeof f.content){let{content:a,thinking:b}=(0,l.Zb)(f.content);f.content=a,b&&!f.reasoning_content&&(f.reasoning_content=b)}let h=f?.content||f?.reasoning_content;h&&"string"==typeof h&&(B+=h.length);let j=(0,g.f5)(a);j&&(z=j);let m=a.choices?.[0]?.finish_reason;if(m&&!(0,g.Gh)(a.usage)){let d=(0,g.OF)(w,B,e.h.OPENAI);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
11
18
  `,z=d,c=!0}else if(m&&z){let d=(0,g.O9)(z);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
12
19
  `,c=!0}else d&&(b=`data: ${JSON.stringify(a)}
13
- `,c=!0)}catch{}c||(b=a.startsWith("data:")&&!a.startsWith("data: ")?"data: "+a.slice(5)+"\n":a+"\n"),r?.appendConvertedChunk?.(b),f.enqueue(E.encode(b));continue}if(!k)continue;let m=h(k);if(!m)continue;if(m&&m.done){if(!C){C=!0;let a="data: [DONE]\n\n";r?.appendConvertedChunk?.(a),f.enqueue(E.encode(a))}continue}if(m.delta?.text&&(B+=m.delta.text.length),m.delta?.thinking&&(B+=m.delta.thinking.length),m.choices?.[0]?.delta?.content&&(B+=m.choices[0].delta.content.length),m.choices?.[0]?.delta?.reasoning_content&&(B+=m.choices[0].delta.reasoning_content.length),m.candidates?.[0]?.content?.parts)for(let a of m.candidates[0].content.parts)a.text&&"string"==typeof a.text&&(B+=a.text.length);let o=(0,g.f5)(m);o&&(A.usage=o);let q=(0,d.Y8)(c,p,m,A);if(q?._openaiIntermediate)for(let a of q._openaiIntermediate){let b=j(a,e.h.OPENAI);r?.appendOpenAIChunk?.(b)}if(q?.length>0)for(let a of q){if(!i(a,p))continue;let b="message_delta"===a.type||a.choices?.[0]?.finish_reason;if(A.finishReason&&b&&!(0,g.Gh)(a.usage)&&B>0){let b=(0,g.OF)(w,B,p);a.usage=(0,g.WL)(b,p),A.usage=b}else if(A.finishReason&&b&&A.usage){let b=(0,g.O9)(A.usage);a.usage=(0,g.WL)(b,p)}let c=j(a,p);r?.appendConvertedChunk?.(c),f.enqueue(E.encode(c))}}},flush(a){if(G&&(clearInterval(G),G=null),!H){(0,f.uw)(t,q,u,!1);try{let i=D.decode();if(i&&(y+=i),b===n){if(y){let b=y;y.startsWith("data:")&&!y.startsWith("data: ")&&(b="data: "+y.slice(5)),r?.appendConvertedChunk?.(b),a.enqueue(E.encode(b))}if(!(0,g.Gh)(z)&&B>0&&(z=(0,g.OF)(w,B,e.h.OPENAI)),(0,g.Gh)(z)?(0,g.IF)(q,z,t,u,v):(0,f.E5)({model:t,provider:q,connectionId:u,tokens:null,status:"200 OK"}).catch(()=>{}),x)try{x({status:200,usage:z})}catch{}return}if(y.trim()){let b=h(y.trim());if(b&&!b.done){let f=(0,d.Y8)(c,p,b,A);if(f?._openaiIntermediate)for(let a of f._openaiIntermediate){let b=j(a,e.h.OPENAI);r?.appendOpenAIChunk?.(b)}if(f?.length>0)for(let b of f){let c=j(b,p);r?.appendConvertedChunk?.(c),a.enqueue(E.encode(c))}}}let k=(0,d.Y8)(c,p,null,A);if(k?._openaiIntermediate)for(let a of k._openaiIntermediate){let b=j(a,e.h.OPENAI);r?.appendOpenAIChunk?.(b)}if(k?.length>0)for(let b of k){let c=j(b,p);r?.appendConvertedChunk?.(c),a.enqueue(E.encode(c))}if(!C){C=!0;let b="data: [DONE]\n\n";r?.appendConvertedChunk?.(b),a.enqueue(E.encode(b))}if(!(0,g.Gh)(A?.usage)&&B>0&&(A.usage=(0,g.OF)(w,B,p)),(0,g.Gh)(A?.usage)?(0,g.IF)(A.provider||c,A.usage,t,u,v):(0,f.E5)({model:t,provider:q,connectionId:u,tokens:null,status:"200 OK"}).catch(()=>{}),x)try{x({status:200,usage:A?.usage})}catch{}}catch(a){console.log(`[STREAM] Error in flush (${t||"unknown"}):`,a.message||a)}}}},{highWaterMark:16},{highWaterMark:16})}function p(a,b,c=null,d=null,e=null,f=null,g=null,h=null,i=null,j=null){return o({mode:m,targetFormat:a,sourceFormat:b,provider:c,reqLogger:d,toolNameMap:e,model:f,connectionId:g,apiKeyInfo:j,body:h,onComplete:i})}function q(a=null,b=null,c=null,d=null,e=null,f=null,g=null){return o({mode:n,provider:a,reqLogger:b,model:c,connectionId:d,apiKeyInfo:g,body:e,onComplete:f})}},34493:(a,b,c)=>{c.d(b,{GL:()=>i,XT:()=>j,pq:()=>h});var d=c(94755),e=c(42910);let f=!e.m1&&!e.I8,g=[];if(f)try{for(let a of(0,e.sm)().prepare("SELECT * FROM proxy_logs ORDER BY timestamp DESC LIMIT ?").all(500))g.push({id:a.id,timestamp:a.timestamp,status:a.status||"success",proxy:a.proxy_host?{type:a.proxy_type,host:a.proxy_host,port:a.proxy_port}:null,level:a.level||"direct",levelId:a.level_id||null,provider:a.provider||null,targetUrl:a.target_url||null,publicIp:a.public_ip||null,latencyMs:a.latency_ms||0,error:a.error||null,connectionId:a.connection_id||null,comboId:a.combo_id||null,account:a.account||null,tlsFingerprint:1===a.tls_fingerprint});g.length>0&&console.log(`[proxyLogger] Loaded ${g.length} proxy logs from SQLite`)}catch(a){console.warn("[proxyLogger] Failed to load from DB:",a.message)}function h(a){let b={id:(0,d.A)(),timestamp:new Date().toISOString(),status:a.status||"success",proxy:a.proxy||null,level:a.level||"direct",levelId:a.levelId||null,provider:a.provider||null,targetUrl:a.targetUrl||null,publicIp:a.publicIp||null,latencyMs:a.latencyMs||0,error:a.error||null,connectionId:a.connectionId||null,comboId:a.comboId||null,account:a.account||null,tlsFingerprint:a.tlsFingerprint||!1};if(g.unshift(b),g.length>500&&(g.length=500),f)try{let a=(0,e.sm)();a.prepare(`INSERT INTO proxy_logs (id, timestamp, status, proxy_type, proxy_host, proxy_port,
14
- level, level_id, provider, target_url, public_ip, latency_ms, error,
15
- connection_id, combo_id, account, tls_fingerprint)
16
- VALUES (@id, @timestamp, @status, @proxyType, @proxyHost, @proxyPort,
17
- @level, @levelId, @provider, @targetUrl, @publicIp, @latencyMs, @error,
18
- @connectionId, @comboId, @account, @tlsFingerprint)`).run({id:b.id,timestamp:b.timestamp,status:b.status,proxyType:b.proxy?.type||null,proxyHost:b.proxy?.host||null,proxyPort:b.proxy?.port||null,level:b.level,levelId:b.levelId,provider:b.provider,targetUrl:b.targetUrl,publicIp:b.publicIp,latencyMs:b.latencyMs,error:b.error,connectionId:b.connectionId,comboId:b.comboId,account:b.account,tlsFingerprint:+!!b.tlsFingerprint});let c=a.prepare("SELECT COUNT(*) as cnt FROM proxy_logs").get()?.cnt||0;c>500&&a.prepare(`DELETE FROM proxy_logs WHERE id IN (
19
- SELECT id FROM proxy_logs ORDER BY timestamp ASC LIMIT ?
20
- )`).run(c-500)}catch(a){console.warn("[proxyLogger] Failed to persist:",a.message)}return b}function i(a={}){let b=[...g];if(a.status&&(b="ok"===a.status?b.filter(a=>"success"===a.status):b.filter(b=>b.status===a.status)),a.type&&(b=b.filter(b=>b.proxy?.type===a.type)),a.provider&&(b=b.filter(b=>b.provider===a.provider)),a.level&&(b=b.filter(b=>b.level===a.level)),a.search){let c=a.search.toLowerCase();b=b.filter(a=>(a.proxy?.host||"").toLowerCase().includes(c)||(a.provider||"").toLowerCase().includes(c)||(a.targetUrl||"").toLowerCase().includes(c)||(a.publicIp||"").toLowerCase().includes(c)||(a.level||"").toLowerCase().includes(c)||(a.error||"").toLowerCase().includes(c)||(a.account||"").toLowerCase().includes(c))}let c=a.limit||300;return b.slice(0,c)}function j(){if(g.length=0,f)try{(0,e.sm)().prepare("DELETE FROM proxy_logs").run()}catch(a){console.warn("[proxyLogger] Failed to clear DB:",a.message)}}},44057:(a,b,c)=>{c.d(b,{N3:()=>g,TT:()=>e,ci:()=>i});let d=["parse","validate","policy","resolve","connect","stream","finalize"];class e{constructor(a){this.requestId=a,this.startTime=Date.now(),this.phases=[],this._currentPhase=null,this._phaseStart=null}startPhase(a){this._currentPhase&&this.endPhase(),this._currentPhase=a,this._phaseStart=Date.now()}endPhase(a={}){if(!this._currentPhase)return;let b=Date.now();this.phases.push({phase:this._currentPhase,startMs:this._phaseStart-this.startTime,endMs:b-this.startTime,durationMs:b-this._phaseStart,...a}),this._currentPhase=null,this._phaseStart=null}async measure(a,b){this.startPhase(a);try{let a=await b();return this.endPhase(),a}catch(a){throw this.endPhase({error:a.message}),a}}getSummary(){return this._currentPhase&&this.endPhase(),{requestId:this.requestId,totalMs:Date.now()-this.startTime,phases:[...this.phases]}}}let f=[];function g(a){let b=a.getSummary();for(b.recordedAt=Date.now(),f.push(b);f.length>1e3;)f.shift()}function h(a,b){if(0===a.length)return 0;let c=Math.ceil(b/100*a.length)-1;return a[Math.max(0,c)]}function i(a=3e5){let b=Date.now()-a,c=f.filter(a=>(a.recordedAt||0)>=b);if(0===c.length)return{count:0,p50:0,p95:0,p99:0,phaseBreakdown:{}};let e=c.map(a=>a.totalMs).sort((a,b)=>a-b),g={};for(let a of d){let b=c.flatMap(b=>b.phases.filter(b=>b.phase===a).map(a=>a.durationMs)).sort((a,b)=>a-b);b.length>0&&(g[a]={count:b.length,p50:h(b,50),p95:h(b,95),avg:Math.round(b.reduce((a,b)=>a+b,0)/b.length)})}return{count:c.length,p50:h(e,50),p95:h(e,95),p99:h(e,99),phaseBreakdown:g}}},44594:(a,b,c)=>{let d;c.d(b,{X:()=>h,q:()=>g});var e=c(77598),f=c.n(e);class g{#a;#b;#c;#d;#e;constructor(a={}){this.#a=new Map,this.#d=0,this.#e={hits:0,misses:0,evictions:0},this.#b=a.maxSize??100,this.#c=a.defaultTTL??3e5}static generateKey(a){let b=JSON.stringify(a,Object.keys(a).sort());return f().createHash("sha256").update(b).digest("hex").slice(0,16)}get(a){let b=this.#a.get(a);if(!b)return void this.#e.misses++;if(Date.now()-b.createdAt>b.ttl){this.#a.delete(a),this.#d--,this.#e.misses++;return}return this.#a.delete(a),b.hits++,this.#a.set(a,b),this.#e.hits++,b.value}set(a,b,c){for(this.#a.has(a)&&(this.#a.delete(a),this.#d--);this.#d>=this.#b;){let a=this.#a.keys().next().value;this.#a.delete(a),this.#d--,this.#e.evictions++}let d={key:a,value:b,createdAt:Date.now(),ttl:c??this.#c,size:JSON.stringify(b).length,hits:0};this.#a.set(a,d),this.#d++}has(a){let b=this.#a.get(a);return!!b&&(!(Date.now()-b.createdAt>b.ttl)||(this.#a.delete(a),this.#d--,!1))}delete(a){return!!this.#a.has(a)&&(this.#a.delete(a),this.#d--,!0)}clear(){this.#a.clear(),this.#d=0}getStats(){let a=this.#e.hits+this.#e.misses;return{size:this.#d,maxSize:this.#b,...this.#e,hitRate:a>0?this.#e.hits/a*100:0}}}function h(a){return d||(d=new g({maxSize:parseInt(process.env.PROMPT_CACHE_MAX_SIZE||"200",10),defaultTTL:parseInt(process.env.PROMPT_CACHE_TTL_MS||"600000",10),...a})),d}},50498:(a,b,c)=>{c.d(b,{l:()=>e});var d=c(55120);function e(a,b,c){if(b===c||b===d.h.OPENAI)return a;if(b===d.h.OPENAI_RESPONSES){let b=a?.object==="response"?a:a?.response||a,c=Array.isArray(b?.output)?b.output:[],d=b?.usage||a?.usage,e="",f="",g=[];for(let a of c)if(a&&"object"==typeof a){if("message"===a.type&&Array.isArray(a.content))for(let b of a.content)b&&"object"==typeof b&&("output_text"===b.type&&"string"==typeof b.text?e+=b.text:"summary_text"===b.type&&"string"==typeof b.text&&(f+=b.text));else if("reasoning"===a.type&&Array.isArray(a.summary))for(let b of a.summary)b?.type==="summary_text"&&"string"==typeof b.text&&(f+=b.text);else if("function_call"===a.type){let b=a.call_id||a.id||`call_${Date.now()}_${g.length}`,c="string"==typeof a.arguments?a.arguments:JSON.stringify(a.arguments||{});g.push({id:b,type:"function",function:{name:a.name||"",arguments:c}})}}let h={role:"assistant"};e&&(h.content=e),f&&(h.reasoning_content=f),g.length>0&&(h.tool_calls=g),h.content||h.tool_calls||(h.content="");let i=Number(b?.created_at)||Math.floor(Date.now()/1e3),j=b?.model||a?.model||"openai-responses",k=g.length>0?"tool_calls":"stop",l={id:`chatcmpl-${b?.id||Date.now()}`,object:"chat.completion",created:i,model:j,choices:[{index:0,message:h,finish_reason:k}]};if(d&&"object"==typeof d){let a=d.input_tokens||0,b=d.output_tokens||0;l.usage={prompt_tokens:a,completion_tokens:b,total_tokens:a+b},d.reasoning_tokens>0&&(l.usage.completion_tokens_details={reasoning_tokens:d.reasoning_tokens}),(d.cache_read_input_tokens>0||d.cache_creation_input_tokens>0)&&(l.usage.prompt_tokens_details={},d.cache_read_input_tokens>0&&(l.usage.prompt_tokens_details.cached_tokens=d.cache_read_input_tokens),d.cache_creation_input_tokens>0&&(l.usage.prompt_tokens_details.cache_creation_tokens=d.cache_creation_input_tokens))}return l}if(b===d.h.GEMINI||b===d.h.ANTIGRAVITY||b===d.h.GEMINI_CLI){let b=a.response||a;if(!b?.candidates?.[0])return a;let c=b.candidates[0],d=c.content,e=b.usageMetadata||a.usageMetadata,f="",g=[],h="";if(d?.parts)for(let a of d.parts)!0===a.thought&&a.text?h+=a.text:void 0!==a.text&&(f+=a.text),a.functionCall&&g.push({id:`call_${a.functionCall.name}_${Date.now()}_${g.length}`,type:"function",function:{name:a.functionCall.name,arguments:JSON.stringify(a.functionCall.args||{})}});let i={role:"assistant"};f&&(i.content=f),h&&(i.reasoning_content=h),g.length>0&&(i.tool_calls=g),i.content||i.tool_calls||(i.content="");let j=(c.finishReason||"stop").toLowerCase();"stop"===j&&g.length>0&&(j="tool_calls");let k={id:`chatcmpl-${b.responseId||Date.now()}`,object:"chat.completion",created:Math.floor(new Date(b.createTime||Date.now()).getTime()/1e3),model:b.modelVersion||"gemini",choices:[{index:0,message:i,finish_reason:j}]};return e&&(k.usage={prompt_tokens:(e.promptTokenCount||0)+(e.thoughtsTokenCount||0),completion_tokens:e.candidatesTokenCount||0,total_tokens:e.totalTokenCount||0},e.thoughtsTokenCount>0&&(k.usage.completion_tokens_details={reasoning_tokens:e.thoughtsTokenCount})),k}if(b===d.h.CLAUDE){if(!a.content)return a;let b="",c="",d=[];for(let e of a.content)"text"===e.type?b+=e.text:"thinking"===e.type?c+=e.thinking||"":"tool_use"===e.type&&d.push({id:e.id,type:"function",function:{name:e.name,arguments:JSON.stringify(e.input||{})}});let e={role:"assistant"};b&&(e.content=b),c&&(e.reasoning_content=c),d.length>0&&(e.tool_calls=d),e.content||e.tool_calls||(e.content="");let f=a.stop_reason||"stop";"end_turn"===f&&(f="stop"),"tool_use"===f&&(f="tool_calls");let g={id:`chatcmpl-${a.id||Date.now()}`,object:"chat.completion",created:Math.floor(Date.now()/1e3),model:a.model||"claude",choices:[{index:0,message:e,finish_reason:f}]};return a.usage&&(g.usage={prompt_tokens:a.usage.input_tokens||0,completion_tokens:a.usage.output_tokens||0,total_tokens:(a.usage.input_tokens||0)+(a.usage.output_tokens||0)}),g}return a}},54745:(a,b,c)=>{function d(a,b){let c=String(a||"").split("\n"),d=[];for(let a of c){let b=a.trim();if(!b.startsWith("data:"))continue;let c=b.slice(5).trim();if(c&&"[DONE]"!==c)try{d.push(JSON.parse(c))}catch{}}if(0===d.length)return null;let e=d[0],f=[],g=[],h="stop",i=null;for(let a of d){let b=a?.choices?.[0],c=b?.delta||{};"string"==typeof c.content&&c.content.length>0&&f.push(c.content),"string"==typeof c.reasoning_content&&c.reasoning_content.length>0&&g.push(c.reasoning_content),b?.finish_reason&&(h=b.finish_reason),a?.usage&&"object"==typeof a.usage&&(i=a.usage)}let j={role:"assistant",content:f.join("")};g.length>0&&(j.reasoning_content=g.join(""));let k={id:e.id||`chatcmpl-${Date.now()}`,object:"chat.completion",created:e.created||Math.floor(Date.now()/1e3),model:e.model||b||"unknown",choices:[{index:0,message:j,finish_reason:h}]};return i&&(k.usage=i),k}function e(a,b){let c=String(a||"").split("\n"),d=[];for(let a of c){let b=a.trim();if(!b.startsWith("data:"))continue;let c=b.slice(5).trim();if(c&&"[DONE]"!==c)try{d.push(JSON.parse(c))}catch{}}if(0===d.length)return null;let e=null,f=null;for(let a of d)a?.type==="response.completed"&&a.response&&(e=a.response),a?.response&&"object"==typeof a.response?f=a.response:a?.object==="response"&&(f=a);let g=e||f;return g&&"object"==typeof g?{id:g.id||`resp_${Date.now()}`,object:"response",model:g.model||b||"unknown",output:Array.isArray(g.output)?g.output:[],usage:g.usage||null,status:g.status||(e?"completed":"in_progress"),created_at:g.created_at||Math.floor(Date.now()/1e3),metadata:g.metadata||{}}:null}c.d(b,{B:()=>e,F:()=>d})},59545:(a,b,c)=>{c.d(b,{KZ:()=>f});var d=c(16698),e=c(77598);function f(){return(0,e.randomUUID)()}new d.AsyncLocalStorage},65982:(a,b,c)=>{function d({intervalMs:a=2e3,signal:b}={}){let c,e,f=0,g=Date.now(),h=new TextEncoder;return new TransformStream({start(d){e=d,g=Date.now(),c=setInterval(()=>{if(b?.aborted)return void clearInterval(c);let a=`event: progress
20
+ `,c=!0)}catch{}c||(b=a.startsWith("data:")&&!a.startsWith("data: ")?"data: "+a.slice(5)+"\n":a+"\n"),r?.appendConvertedChunk?.(b),f.enqueue(E.encode(b));continue}if(!k)continue;let m=h(k);if(!m)continue;if(m&&m.done){if(!C){C=!0;let a="data: [DONE]\n\n";r?.appendConvertedChunk?.(a),f.enqueue(E.encode(a))}continue}if(m.delta?.text&&(B+=m.delta.text.length),m.delta?.thinking&&(B+=m.delta.thinking.length),m.choices?.[0]?.delta?.content&&(B+=m.choices[0].delta.content.length),m.choices?.[0]?.delta?.reasoning_content&&(B+=m.choices[0].delta.reasoning_content.length),m.candidates?.[0]?.content?.parts)for(let a of m.candidates[0].content.parts)a.text&&"string"==typeof a.text&&(B+=a.text.length);let o=(0,g.f5)(m);o&&(A.usage=o);let q=(0,d.Y8)(c,p,m,A);if(q?._openaiIntermediate)for(let a of q._openaiIntermediate){let b=j(a,e.h.OPENAI);r?.appendOpenAIChunk?.(b)}if(q?.length>0)for(let a of q){if(!i(a,p))continue;let b="message_delta"===a.type||a.choices?.[0]?.finish_reason;if(A.finishReason&&b&&!(0,g.Gh)(a.usage)&&B>0){let b=(0,g.OF)(w,B,p);a.usage=(0,g.WL)(b,p),A.usage=b}else if(A.finishReason&&b&&A.usage){let b=(0,g.O9)(A.usage);a.usage=(0,g.WL)(b,p)}let c=j(a,p);r?.appendConvertedChunk?.(c),f.enqueue(E.encode(c))}}},flush(a){if(G&&(clearInterval(G),G=null),!H){(0,f.uw)(t,q,u,!1);try{let i=D.decode();if(i&&(y+=i),b===n){if(y){let b=y;y.startsWith("data:")&&!y.startsWith("data: ")&&(b="data: "+y.slice(5)),r?.appendConvertedChunk?.(b),a.enqueue(E.encode(b))}if(!(0,g.Gh)(z)&&B>0&&(z=(0,g.OF)(w,B,e.h.OPENAI)),(0,g.Gh)(z)?(0,g.IF)(q,z,t,u,v):(0,f.E5)({model:t,provider:q,connectionId:u,tokens:null,status:"200 OK"}).catch(()=>{}),x)try{x({status:200,usage:z})}catch{}return}if(y.trim()){let b=h(y.trim());if(b&&!b.done){let f=(0,d.Y8)(c,p,b,A);if(f?._openaiIntermediate)for(let a of f._openaiIntermediate){let b=j(a,e.h.OPENAI);r?.appendOpenAIChunk?.(b)}if(f?.length>0)for(let b of f){let c=j(b,p);r?.appendConvertedChunk?.(c),a.enqueue(E.encode(c))}}}let k=(0,d.Y8)(c,p,null,A);if(k?._openaiIntermediate)for(let a of k._openaiIntermediate){let b=j(a,e.h.OPENAI);r?.appendOpenAIChunk?.(b)}if(k?.length>0)for(let b of k){let c=j(b,p);r?.appendConvertedChunk?.(c),a.enqueue(E.encode(c))}if(!C){C=!0;let b="data: [DONE]\n\n";r?.appendConvertedChunk?.(b),a.enqueue(E.encode(b))}if(!(0,g.Gh)(A?.usage)&&B>0&&(A.usage=(0,g.OF)(w,B,p)),(0,g.Gh)(A?.usage)?(0,g.IF)(A.provider||c,A.usage,t,u,v):(0,f.E5)({model:t,provider:q,connectionId:u,tokens:null,status:"200 OK"}).catch(()=>{}),x)try{x({status:200,usage:A?.usage})}catch{}}catch(a){console.log(`[STREAM] Error in flush (${t||"unknown"}):`,a.message||a)}}}},{highWaterMark:16},{highWaterMark:16})}function p(a,b,c=null,d=null,e=null,f=null,g=null,h=null,i=null,j=null){return o({mode:m,targetFormat:a,sourceFormat:b,provider:c,reqLogger:d,toolNameMap:e,model:f,connectionId:g,apiKeyInfo:j,body:h,onComplete:i})}function q(a=null,b=null,c=null,d=null,e=null,f=null,g=null){return o({mode:n,provider:a,reqLogger:b,model:c,connectionId:d,apiKeyInfo:g,body:e,onComplete:f})}},50498:(a,b,c)=>{c.d(b,{l:()=>e});var d=c(55120);function e(a,b,c){if(b===c||b===d.h.OPENAI)return a;if(b===d.h.OPENAI_RESPONSES){let b=a?.object==="response"?a:a?.response||a,c=Array.isArray(b?.output)?b.output:[],d=b?.usage||a?.usage,e="",f="",g=[];for(let a of c)if(a&&"object"==typeof a){if("message"===a.type&&Array.isArray(a.content))for(let b of a.content)b&&"object"==typeof b&&("output_text"===b.type&&"string"==typeof b.text?e+=b.text:"summary_text"===b.type&&"string"==typeof b.text&&(f+=b.text));else if("reasoning"===a.type&&Array.isArray(a.summary))for(let b of a.summary)b?.type==="summary_text"&&"string"==typeof b.text&&(f+=b.text);else if("function_call"===a.type){let b=a.call_id||a.id||`call_${Date.now()}_${g.length}`,c="string"==typeof a.arguments?a.arguments:JSON.stringify(a.arguments||{});g.push({id:b,type:"function",function:{name:a.name||"",arguments:c}})}}let h={role:"assistant"};e&&(h.content=e),f&&(h.reasoning_content=f),g.length>0&&(h.tool_calls=g),h.content||h.tool_calls||(h.content="");let i=Number(b?.created_at)||Math.floor(Date.now()/1e3),j=b?.model||a?.model||"openai-responses",k=g.length>0?"tool_calls":"stop",l={id:`chatcmpl-${b?.id||Date.now()}`,object:"chat.completion",created:i,model:j,choices:[{index:0,message:h,finish_reason:k}]};if(d&&"object"==typeof d){let a=d.input_tokens||0,b=d.output_tokens||0;l.usage={prompt_tokens:a,completion_tokens:b,total_tokens:a+b},d.reasoning_tokens>0&&(l.usage.completion_tokens_details={reasoning_tokens:d.reasoning_tokens}),(d.cache_read_input_tokens>0||d.cache_creation_input_tokens>0)&&(l.usage.prompt_tokens_details={},d.cache_read_input_tokens>0&&(l.usage.prompt_tokens_details.cached_tokens=d.cache_read_input_tokens),d.cache_creation_input_tokens>0&&(l.usage.prompt_tokens_details.cache_creation_tokens=d.cache_creation_input_tokens))}return l}if(b===d.h.GEMINI||b===d.h.ANTIGRAVITY||b===d.h.GEMINI_CLI){let b=a.response||a;if(!b?.candidates?.[0])return a;let c=b.candidates[0],d=c.content,e=b.usageMetadata||a.usageMetadata,f="",g=[],h="";if(d?.parts)for(let a of d.parts)!0===a.thought&&a.text?h+=a.text:void 0!==a.text&&(f+=a.text),a.functionCall&&g.push({id:`call_${a.functionCall.name}_${Date.now()}_${g.length}`,type:"function",function:{name:a.functionCall.name,arguments:JSON.stringify(a.functionCall.args||{})}});let i={role:"assistant"};f&&(i.content=f),h&&(i.reasoning_content=h),g.length>0&&(i.tool_calls=g),i.content||i.tool_calls||(i.content="");let j=(c.finishReason||"stop").toLowerCase();"stop"===j&&g.length>0&&(j="tool_calls");let k={id:`chatcmpl-${b.responseId||Date.now()}`,object:"chat.completion",created:Math.floor(new Date(b.createTime||Date.now()).getTime()/1e3),model:b.modelVersion||"gemini",choices:[{index:0,message:i,finish_reason:j}]};return e&&(k.usage={prompt_tokens:(e.promptTokenCount||0)+(e.thoughtsTokenCount||0),completion_tokens:e.candidatesTokenCount||0,total_tokens:e.totalTokenCount||0},e.thoughtsTokenCount>0&&(k.usage.completion_tokens_details={reasoning_tokens:e.thoughtsTokenCount})),k}if(b===d.h.CLAUDE){if(!a.content)return a;let b="",c="",d=[];for(let e of a.content)"text"===e.type?b+=e.text:"thinking"===e.type?c+=e.thinking||"":"tool_use"===e.type&&d.push({id:e.id,type:"function",function:{name:e.name,arguments:JSON.stringify(e.input||{})}});let e={role:"assistant"};b&&(e.content=b),c&&(e.reasoning_content=c),d.length>0&&(e.tool_calls=d),e.content||e.tool_calls||(e.content="");let f=a.stop_reason||"stop";"end_turn"===f&&(f="stop"),"tool_use"===f&&(f="tool_calls");let g={id:`chatcmpl-${a.id||Date.now()}`,object:"chat.completion",created:Math.floor(Date.now()/1e3),model:a.model||"claude",choices:[{index:0,message:e,finish_reason:f}]};return a.usage&&(g.usage={prompt_tokens:a.usage.input_tokens||0,completion_tokens:a.usage.output_tokens||0,total_tokens:(a.usage.input_tokens||0)+(a.usage.output_tokens||0)}),g}return a}},54745:(a,b,c)=>{function d(a,b){let c=String(a||"").split("\n"),d=[];for(let a of c){let b=a.trim();if(!b.startsWith("data:"))continue;let c=b.slice(5).trim();if(c&&"[DONE]"!==c)try{d.push(JSON.parse(c))}catch{}}if(0===d.length)return null;let e=d[0],f=[],g=[],h="stop",i=null;for(let a of d){let b=a?.choices?.[0],c=b?.delta||{};"string"==typeof c.content&&c.content.length>0&&f.push(c.content),"string"==typeof c.reasoning_content&&c.reasoning_content.length>0&&g.push(c.reasoning_content),b?.finish_reason&&(h=b.finish_reason),a?.usage&&"object"==typeof a.usage&&(i=a.usage)}let j={role:"assistant",content:f.join("")};g.length>0&&(j.reasoning_content=g.join(""));let k={id:e.id||`chatcmpl-${Date.now()}`,object:"chat.completion",created:e.created||Math.floor(Date.now()/1e3),model:e.model||b||"unknown",choices:[{index:0,message:j,finish_reason:h}]};return i&&(k.usage=i),k}function e(a,b){let c=String(a||"").split("\n"),d=[];for(let a of c){let b=a.trim();if(!b.startsWith("data:"))continue;let c=b.slice(5).trim();if(c&&"[DONE]"!==c)try{d.push(JSON.parse(c))}catch{}}if(0===d.length)return null;let e=null,f=null;for(let a of d)a?.type==="response.completed"&&a.response&&(e=a.response),a?.response&&"object"==typeof a.response?f=a.response:a?.object==="response"&&(f=a);let g=e||f;return g&&"object"==typeof g?{id:g.id||`resp_${Date.now()}`,object:"response",model:g.model||b||"unknown",output:Array.isArray(g.output)?g.output:[],usage:g.usage||null,status:g.status||(e?"completed":"in_progress"),created_at:g.created_at||Math.floor(Date.now()/1e3),metadata:g.metadata||{}}:null}c.d(b,{B:()=>e,F:()=>d})},59545:(a,b,c)=>{c.d(b,{KZ:()=>f});var d=c(16698),e=c(77598);function f(){return(0,e.randomUUID)()}new d.AsyncLocalStorage},65982:(a,b,c)=>{function d({intervalMs:a=2e3,signal:b}={}){let c,e,f=0,g=Date.now(),h=new TextEncoder;return new TransformStream({start(d){e=d,g=Date.now(),c=setInterval(()=>{if(b?.aborted)return void clearInterval(c);let a=`event: progress
21
21
  data: ${JSON.stringify({tokens_generated:f,elapsed_ms:Date.now()-g})}
22
22
 
23
23
  `;try{d.enqueue(h.encode(a))}catch{clearInterval(c)}},a),b?.addEventListener("abort",()=>{clearInterval(c)},{once:!0})},transform(a,b){let c=("string"==typeof a?a:new TextDecoder().decode(a)).split("\n").filter(a=>a.startsWith("data: "));f+=c.length,b.enqueue(a)},flush(){if(clearInterval(c),e)try{let a=`event: progress
24
24
  data: ${JSON.stringify({tokens_generated:f,elapsed_ms:Date.now()-g,done:!0})}
25
25
 
26
- `;e.enqueue(h.encode(a))}catch{}}})}function e(a){return!!a&&"true"===("function"==typeof a.get?b=>a.get(b):b=>a[b])("x-omniroute-progress")}c.d(b,{Y:()=>d,Z:()=>e})},69590:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{w:()=>C});var e=c(95982),f=c(32113),g=c(89575),h=c(55120),i=c(26695),j=c(6327),k=c(50101),l=c(87068),m=c(89122),n=c(23969),o=c(71861),p=c(60293),q=c(82795),r=c(27230),s=c(37544),t=c(50498),u=c(8550),v=c(54745),w=c(92937),x=c(1308),y=c(9315),z=c(79335),A=c(65982),B=a([s]);async function C({body:a,modelInfo:b,credentials:c,log:d,onCredentialsRefreshed:B,onRequestSuccess:C,onDisconnect:D,clientRawRequest:E,connectionId:F,apiKeyInfo:G=null,userAgent:H,comboName:I}){let J,K,L,M,N,O,{provider:P,model:Q}=b,R=Date.now(),S=(0,z.xp)(E?.headers),T=(0,z.ic)(S);if(T)return d?.debug?.("IDEMPOTENCY",`Hit for key=${S?.slice(0,12)}...`),{success:!0,response:new Response(JSON.stringify(T.response),{status:T.status,headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)(),"X-OmniRoute-Idempotent":"true"}})};await (0,x.rh)();let U=(0,f.Tz)(a),V=(E?.endpoint||"").toLowerCase().endsWith("/responses"),W=(0,q.c)(a,Q,H);if(W)return W;let X=n.PROVIDER_ID_TO_ALIAS[P]||P,Y=(0,n.ux)(X,Q)||(0,f.jJ)(P),Z=!0===a.stream;if((0,y.TZ)(a,E?.headers)){let b=(0,y.gR)(Q,a.messages,a.temperature,a.top_p),c=(0,y.Cb)(b);if(c)return d?.debug?.("CACHE",`Semantic cache HIT for ${Q}`),{success:!0,response:new Response(JSON.stringify(c),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)(),"X-OmniRoute-Cache":"HIT"}})}}let $=await (0,m.q)(U,Y,Q);E&&$.logClientRawRequest(E.endpoint,E.body,E.headers),$.logRawRequest(a),d?.debug?.("FORMAT",`${U} → ${Y} | stream=${Z}`);let _=a;try{_=(0,g.GH)(U,Y,Q,a,Z,c,P,$)}catch(g){let a=Number(g?.statusCode),b=Number.isInteger(a)&&a>=400&&a<=599?a:p.gx.SERVER_ERROR,c=g?.message||"Invalid request",f="string"==typeof g?.errorType?g.errorType:null;if(d?.warn?.("TRANSLATE",`Request translation failed: ${c}`),f)return{success:!1,status:b,error:c,response:new Response(JSON.stringify({error:{message:c,type:f,code:f}}),{status:b,headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)()}})};return(0,o.A1)(b,c)}let aa=_._toolNameMap;delete _._toolNameMap,_.model=Q;let ab=(0,s.SB)(P);(0,r.uw)(Q,P,F,!0),(0,r.E5)({model:Q,provider:P,connectionId:F,status:"PENDING"}).catch(()=>{});let ac=_.messages?.length||_.contents?.length||_.request?.contents?.length||0;d?.debug?.("REQUEST",`${P.toUpperCase()} | ${Q} | ${ac} msgs`);let ad=(0,j.jd)({onDisconnect:D,log:d,provider:P,model:Q});try{let a=await (0,x.YO)(P,F,Q,()=>ab.execute({model:Q,body:_,stream:Z,credentials:c,signal:ad.signal,log:d}));J=a.response,K=a.url,L=a.headers,M=a.transformedBody,$.logTargetRequest(K,L,M),(0,x.Kr)(P,F,J.headers,J.status,Q)}catch(c){if((0,r.uw)(Q,P,F,!1),(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${"AbortError"===c.name?499:p.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:"AbortError"===c.name?499:p.gx.BAD_GATEWAY,model:Q,provider:P,connectionId:F,duration:Date.now()-R,requestBody:a,error:c.message,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{}),"AbortError"===c.name)return ad.handleError(c),(0,o.A1)(499,"Request aborted");let b=(0,o.lR)(c,P,Q,p.gx.BAD_GATEWAY);return console.log(`${i.lm.red}[ERROR] ${b}${i.lm.reset}`),(0,o.A1)(p.gx.BAD_GATEWAY,b)}if(J.status===p.gx.UNAUTHORIZED||J.status===p.gx.FORBIDDEN){let a=await (0,l.qZ)(()=>ab.refreshCredentials(c,d),3,d);if(a?.accessToken||a?.copilotToken){d?.info?.("TOKEN",`${P.toUpperCase()} | refreshed`),Object.assign(c,a),B&&a&&await B(a);try{let a=await ab.execute({model:Q,body:_,stream:Z,credentials:c,signal:ad.signal,log:d});a.response.ok&&(J=a.response,K=a.url)}catch(a){d?.warn?.("TOKEN",`${P.toUpperCase()} | retry after refresh failed`)}}else d?.warn?.("TOKEN",`${P.toUpperCase()} | refresh failed`)}if(!J.ok){(0,r.uw)(Q,P,F,!1);let{statusCode:b,message:c,retryAfterMs:e}=await (0,o.zL)(J,P);(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${b}`}).catch(()=>{}),(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:b,model:Q,provider:P,connectionId:F,duration:Date.now()-R,requestBody:a,error:c,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{});let f=(0,o.lR)(Error(c),P,Q,b);if(console.log(`${i.lm.red}[ERROR] ${f}${i.lm.reset}`),e&&"antigravity"===P){let a=Math.ceil(e/1e3);d?.debug?.("RETRY",`Antigravity quota reset in ${a}s (${e}ms)`)}return $.logError(Error(c),M||_),(0,x.Kr)(P,F,J.headers,b,Q),(0,o.A1)(b,f,e)}if(!Z){let b;(0,r.uw)(Q,P,F,!1);let c=(J.headers.get("content-type")||"").toLowerCase(),f=await J.text();if(c.includes("text/event-stream")||/(^|\n)\s*(event|data):/m.test(f)){let a=Y===h.h.OPENAI_RESPONSES?(0,v.B)(f,Q):(0,v.F)(f,Q);if(!a)return(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${p.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,o.A1)(p.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");b=a}else try{b=f?JSON.parse(f):{}}catch{return(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${p.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,o.A1)(p.gx.BAD_GATEWAY,"Invalid JSON response from provider")}C&&await C();let j=(0,u.M)(b,P);if((0,r.E5)({model:Q,provider:P,connectionId:F,tokens:j,status:"200 OK"}).catch(()=>{}),(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:200,model:Q,provider:P,connectionId:F,duration:Date.now()-R,tokens:j,requestBody:a,responseBody:b,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{}),j&&"object"==typeof j){let a=`[${new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit"})}] 📊 [USAGE] ${P.toUpperCase()} | in=${j?.prompt_tokens||0} | out=${j?.completion_tokens||0}${F?` | account=${F.slice(0,8)}...`:""}`;console.log(`${i.lm.green}${a}${i.lm.reset}`),(0,r.sZ)({provider:P||"unknown",model:Q||"unknown",tokens:j,timestamp:new Date().toISOString(),connectionId:F||void 0,apiKeyId:G?.id||void 0,apiKeyName:G?.name||void 0}).catch(a=>{console.error("Failed to save usage stats:",a.message)})}let l=(0,g.nZ)(Y,U)?(0,t.l)(b,Y,U):b;if(U===h.h.OPENAI&&(l=(0,w.LG)(l)),l?.usage){let a=(0,k.O9)(l.usage);l.usage=(0,k.WL)(a,U)}else{let b=JSON.stringify(l?.choices?.[0]?.message?.content||"").length;if(b>0){let c=(0,k.OF)(a,b,U);l.usage=(0,k.WL)(c,U)}}if((0,y.TZ)(a,E?.headers)){let b=(0,y.gR)(Q,a.messages,a.temperature,a.top_p),c=j?.prompt_tokens+j?.completion_tokens||0;(0,y.yv)(b,Q,l,c),d?.debug?.("CACHE",`Stored response for ${Q} (${c} tokens)`)}return(0,z.tm)(S,l,200),{success:!0,response:new Response(JSON.stringify(l),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)(),"X-OmniRoute-Cache":"MISS"}})}}C&&await C();let ae={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":(0,e.i)()},af=({status:b,usage:c})=>{(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:b||200,model:Q,provider:P,connectionId:F,duration:Date.now()-R,tokens:c||{},requestBody:a,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{})},ag=H?.toLowerCase().includes("droid")||H?.toLowerCase().includes("codex-cli");if("codex"!==P||Y!==h.h.OPENAI_RESPONSES||U!==h.h.OPENAI||V||ag?(0,g.nZ)(Y,U)?(d?.debug?.("STREAM",`Translation mode: ${Y} → ${U}`),N=(0,i.i5)(Y,U,P,$,aa,Q,F,a,af,G)):(d?.debug?.("STREAM","Standard passthrough mode"),N=(0,i.l2)(P,$,Q,F,a,af,G)):(d?.debug?.("STREAM",`Codex translation mode: openai-responses → openai`),N=(0,i.i5)("openai-responses","openai",P,$,aa,Q,F,a,af,G)),(0,A.Z)(E?.headers)){let a=(0,A.Y)({signal:ad.signal});O=(0,j.Jb)(J,N,ad).pipeThrough(a),ae["X-OmniRoute-Progress"]="enabled"}else O=(0,j.Jb)(J,N,ad);return{success:!0,response:new Response(O,{headers:ae})}}s=(B.then?(await B)():B)[0],d()}catch(a){d(a)}})},76340:(a,b,c)=>{let d;c.d(b,{Wk:()=>s,jf:()=>p,qT:()=>r});var e=c(16698),f=c(79522);try{({createSession:d}=c(22546))}catch{d=null}class g{constructor(){this.session=null,this.available=!!d}async getSession(){if(!this.available)return null;if(this.session)return this.session;let a=process.env.HTTPS_PROXY||process.env.https_proxy||process.env.HTTP_PROXY||process.env.http_proxy||process.env.ALL_PROXY||process.env.all_proxy||void 0,b={browser:"chrome_124",os:"macos"};return a&&(b.proxy=a,console.log(`[TlsClient] Using proxy: ${a}`)),this.session=await d(b),console.log("[TlsClient] Session created (Chrome 124 TLS fingerprint)"),this.session}async fetch(a,b={}){let c=await this.getSession();if(!c)throw Error("wreq-js not available");let d={method:(b.method||"GET").toUpperCase(),headers:b.headers,body:b.body,redirect:"manual"===b.redirect?"manual":"follow"};return b.signal&&(d.signal=b.signal),await c.fetch(a,d)}async exit(){this.session&&(await this.session.close(),this.session=null)}}let h=new g;function i(){return"true"===process.env.ENABLE_TLS_FINGERPRINT}let j=new e.AsyncLocalStorage,k="u">typeof caches&&"object"==typeof caches,l=Symbol.for("omniroute.proxyFetch.state"),m=(globalThis[l]||(globalThis[l]={originalFetch:globalThis.fetch,proxyContext:new e.AsyncLocalStorage,isPatched:!1}),globalThis[l]),n=m.originalFetch,o=m.proxyContext;async function p(a,b){if("function"!=typeof b)throw TypeError("runWithProxyContext requires a callback function");let c=a?(0,f.HN)(a):null;return o.run(a||null,async()=>(c&&console.log(`[ProxyFetch] Applied request proxy context: ${(0,f.OK)(c)}`),b()))}async function q(a,b={}){let c;if(b?.dispatcher)return n(a,b);let d="string"==typeof a?a:a&&"string"==typeof a.url?a.url:String(a);try{c=function(a){let b=o.getStore();if(b)return{source:"context",proxyUrl:(0,f.HN)(b)};let c=function(a){let b;if(function(a){let b,c=process.env.NO_PROXY||process.env.no_proxy;if(!c)return!1;try{b=new URL(a)}catch{return!1}let d=b.hostname.toLowerCase(),e=b.port||("https:"===b.protocol?"443":"80");return c.split(",").map(a=>a.trim().toLowerCase()).filter(Boolean).some(a=>{if("*"===a)return!0;let[b,c]=a.split(":");return(!c||c===e)&&!!b&&(b.startsWith(".")?d.endsWith(b)||d===b.slice(1):d===b||d.endsWith(`.${b}`))})}(a))return null;try{b=new URL(a).protocol}catch{return null}let c="https:"===b?process.env.HTTPS_PROXY||process.env.https_proxy||process.env.ALL_PROXY||process.env.all_proxy:process.env.HTTP_PROXY||process.env.http_proxy||process.env.ALL_PROXY||process.env.all_proxy;return c?(0,f.zP)(c,"environment proxy"):null}(a);return c?{source:"env",proxyUrl:c}:{source:"direct",proxyUrl:null}}(d)}catch(b){let a=b instanceof Error?b.message:String(b);throw console.error(`[ProxyFetch] Proxy configuration error: ${a}`),b}let{source:e,proxyUrl:g}=c;if(!g){if(i()&&h.available)try{let a=j.getStore();return a&&(a.used=!0),await h.fetch(d,b)}catch(c){let a=c instanceof Error?c.message:String(c);console.warn(`[ProxyFetch] TLS fingerprint failed, falling back to native fetch: ${a}`);let b=j.getStore();b&&(b.used=!1)}return n(a,b)}try{let c=(0,f.I_)(g);return await n(a,{...b,dispatcher:c})}catch(b){let a=b instanceof Error?b.message:String(b);throw console.error(`[ProxyFetch] Proxy request failed (${e}, fail-closed): ${a}`),b}}async function r(a){let b={used:!1};return{result:await j.run(b,a),tlsFingerprintUsed:b.used}}function s(){return i()&&h.available}k||m.isPatched||(globalThis.fetch=q,m.isPatched=!0)},77458:(a,b,c)=>{c.d(b,{Jh:()=>g});let d=[{name:"system_override",pattern:/\b(ignore|disregard|forget)\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?|rules?|context)/i,severity:"high"},{name:"role_hijack",pattern:/\b(you\s+are\s+now|act\s+as\s+if|pretend\s+(to\s+be|you\s+are)|from\s+now\s+on\s+you\s+are)\b/i,severity:"medium"},{name:"system_prompt_leak",pattern:/\b(reveal|show|display|print|output|repeat)\s+(your\s+)?(system\s+prompt|instructions?|initial\s+prompt|hidden\s+prompt)/i,severity:"high"},{name:"delimiter_injection",pattern:/(\[SYSTEM\]|\[INST\]|<<SYS>>|<\|im_start\|>|<\|system\|>|<\|user\|>)/i,severity:"high"},{name:"jailbreak_dan",pattern:/\b(DAN|do\s+anything\s+now|jailbreak|developer\s+mode|enable\s+developer)\b/i,severity:"medium"},{name:"encoding_evasion",pattern:/\b(base64\s+decode|rot13|hex\s+decode|unicode\s+escape)\b.*\b(instruction|prompt|command)\b/i,severity:"medium"}],e=[{name:"email",pattern:/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b/g,replacement:"[EMAIL_REDACTED]"},{name:"cpf",pattern:/\b\d{3}\.\d{3}\.\d{3}-\d{2}\b/g,replacement:"[CPF_REDACTED]"},{name:"cnpj",pattern:/\b\d{2}\.\d{3}\.\d{3}\/\d{4}-\d{2}\b/g,replacement:"[CNPJ_REDACTED]"},{name:"credit_card",pattern:/\b(?:\d{4}[-\s]?){3}\d{4}\b/g,replacement:"[CARD_REDACTED]"},{name:"phone_br",pattern:/\b\(?\d{2}\)?\s?\d{4,5}-?\d{4}\b/g,replacement:"[PHONE_REDACTED]"},{name:"ssn_us",pattern:/\b\d{3}-\d{2}-\d{4}\b/g,replacement:"[SSN_REDACTED]"}];function f(a,b=!1){let c=[],d=a;for(let f of e){let e=a.match(f.pattern);e&&e.length>0&&(c.push({type:f.name,count:e.length}),b&&(d=d.replace(f.pattern,f.replacement)))}return{text:d,detections:c}}function g(a,b=console){let c={enabled:"false"!==process.env.INPUT_SANITIZER_ENABLED,mode:process.env.INPUT_SANITIZER_MODE||"warn",piiRedaction:"true"===process.env.PII_REDACTION_ENABLED},e={blocked:!1,modified:!1,detections:[],piiDetections:[],sanitizedBody:null};if(!c.enabled)return e;let h=(function(a){let b=[];for(let c of a.messages||a.input||[])if("string"==typeof c)b.push(c);else if("string"==typeof c.content)b.push(c.content);else if(Array.isArray(c.content))for(let a of c.content)"string"==typeof a?b.push(a):a.text&&b.push(a.text);if("string"==typeof a.system)b.push(a.system);else if(Array.isArray(a.system))for(let c of a.system)"string"==typeof c?b.push(c):c.text&&b.push(c.text);return b})(a).join("\n"),i=function(a){let b=[];for(let c of d){let d=a.match(c.pattern);d&&b.push({pattern:c.name,severity:c.severity,match:d[0].slice(0,50)})}return b}(h);if(i.length>0){e.detections=i;let a=i.filter(a=>"high"===a.severity),d=a.length>0?"warn":"info";if(b[d]&&b[d](`[SANITIZER] Prompt injection detected: ${i.map(a=>a.pattern).join(", ")}`),"block"===c.mode&&a.length>0)return e.blocked=!0,e}if(c.piiRedaction){let d=f(h,"redact"===c.mode);e.piiDetections=d.detections,d.detections.length>0&&(b.warn?.(`[SANITIZER] PII detected: ${d.detections.map(a=>`${a.type}(${a.count})`).join(", ")}`),"redact"===c.mode&&(e.sanitizedBody=function(a){let b=JSON.parse(JSON.stringify(a));for(let a of b.messages||b.input||[])if("string"==typeof a.content)a.content=f(a.content,!0).text;else if(Array.isArray(a.content))for(let b of a.content)if("string"==typeof b){let c=a.content.indexOf(b);a.content[c]=f(b,!0).text}else b.text&&(b.text=f(b.text,!0).text);return"string"==typeof b.system&&(b.system=f(b.system,!0).text),b}(a),e.modified=!0))}return e}},79335:(a,b,c)=>{let d;c.d(b,{ic:()=>g,ne:()=>i,tm:()=>h,xp:()=>f});let e=new Map;function f(a){if(!a)return null;let b="function"==typeof a.get?b=>a.get(b):b=>a[b];return b("idempotency-key")||b("x-request-id")||null}function g(a){if(!a)return null;let b=e.get(a);return b?Date.now()>=b.expiresAt?(e.delete(a),null):{response:b.response,status:b.status}:null}function h(a,b,c,f=5e3){a&&(!d&&(d=setInterval(()=>{let a=Date.now();for(let[b,c]of e)a>=c.expiresAt&&e.delete(b)},3e4)).unref&&d.unref(),e.set(a,{response:b,status:c,expiresAt:Date.now()+f}))}function i(){return{activeKeys:e.size,windowMs:5e3}}},79522:(a,b,c)=>{c.d(b,{HN:()=>m,I_:()=>n,OK:()=>k,QX:()=>j,zP:()=>l});var d=c(47774),e=c(20406);let f=Symbol.for("omniroute.proxyDispatcher.cache"),g=new Set(["http:","https:","socks5:"]);function h(a){return"https:"===a||"wss:"===a?"443":"socks5:"===a?"1080":"8080"}function i(a,b){if(!a)return h(b);let c=Number(a);if(!Number.isInteger(c)||c<1||c>65535)throw Error("[ProxyDispatcher] Invalid proxy port");return String(c)}function j(){return"true"===process.env.ENABLE_SOCKS5_PROXY}function k(a){let b=new URL(a),c=b.port||h(b.protocol);return`${b.protocol}//${b.hostname}:${c}`}function l(a,b="proxy",{allowSocks5:c=j()}={}){let d;try{d=new URL(a)}catch{throw Error(`[ProxyDispatcher] Invalid ${b} URL`)}if(!g.has(d.protocol))throw Error(`[ProxyDispatcher] Unsupported ${b} protocol: ${d.protocol.replace(":","")}`);if("socks5:"===d.protocol&&!c)throw Error("[ProxyDispatcher] SOCKS5 proxy is disabled (set ENABLE_SOCKS5_PROXY=true to enable)");if(!d.hostname)throw Error(`[ProxyDispatcher] Invalid ${b} host`);return d.port=i(d.port,d.protocol),d.toString()}function m(a,{allowSocks5:b=j()}={}){if(!a)return null;if("string"==typeof a)return l(a,"context proxy",{allowSocks5:b});if("object"!=typeof a||Array.isArray(a))throw Error("[ProxyDispatcher] Invalid context proxy config");let c=String(a.type||"http").toLowerCase(),d=`${c}:`;if(!g.has(d))throw Error(`[ProxyDispatcher] Unsupported context proxy protocol: ${c}`);if("socks5:"===d&&!b)throw Error("[ProxyDispatcher] SOCKS5 proxy is disabled (set ENABLE_SOCKS5_PROXY=true to enable)");if(!a.host)throw Error("[ProxyDispatcher] Context proxy host is required");let e=i(a.port,d),f=new URL(`${c}://${a.host}:${e}`);return a.username&&(f.username=a.username,f.password=a.password||""),l(f.toString(),"context proxy",{allowSocks5:b})}function n(a){let b=l(a,"proxy dispatcher"),c=(globalThis[f]||(globalThis[f]=new Map),globalThis[f]),g=c.get(b);if(g)return g;let h=new URL(b);if("socks5:"===h.protocol){let a={type:5,host:h.hostname,port:Number(i(h.port,h.protocol))};h.username&&(a.userId=decodeURIComponent(h.username)),h.password&&(a.password=decodeURIComponent(h.password)),g=(0,e.vI)(a)}else g=new d.ProxyAgent(b);return c.set(b,g),g}},82795:(a,b,c)=>{c.d(b,{c:()=>j});var d=c(95982),e=c(32113),f=c(89575),g=c(55120),h=c(60293),i=c(26695);function j(a,b,c=""){if(!c.includes("claude-cli")||!a.messages?.length)return null;let m=a.messages,n=a=>"string"==typeof a?a:Array.isArray(a)?a.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"",o=!1,p=m[m.length-1];if(p?.role==="assistant"&&p.content?.[0]?.text==="{"&&(o=!0),o||"Warmup"===n(m[0]?.content)&&(o=!0),o||1!==m.length||m[0]?.role!=="user"||"count"===n(m[0]?.content)&&(o=!0),!o&&h.C8?.length){let a=m.filter(a=>"user"===a.role).map(a=>n(a.content)).join(" ");h.C8.some(b=>a.includes(b))&&(o=!0)}if(!o)return null;let q=(0,e.Tz)(a);return!1!==a.stream?function(a,b){let c=k(b),e=(0,f.Ws)(a);e.model=b;let h=l(c),j=[];for(let b of h){let c=(0,f.Y8)(g.h.OPENAI,a,b,e);if(c?.length>0)for(let b of c)j.push((0,i.v8)(b,a))}let m=(0,f.Y8)(g.h.OPENAI,a,null,e);if(m?.length>0)for(let b of m)j.push((0,i.v8)(b,a));return j.push("data: [DONE]\n\n"),{success:!0,response:new Response(j.join(""),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":(0,d.i)()}})}}(q,b):function(a,b){let c=k(b);if(a===g.h.OPENAI)return{success:!0,response:new Response(JSON.stringify(c),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,d.i)()}})};let e=(0,f.Ws)(a);e.model=b;let h=l(c),i=[];for(let b of h){let c=(0,f.Y8)(g.h.OPENAI,a,b,e);c?.length>0&&i.push(...c)}let j=(0,f.Y8)(g.h.OPENAI,a,null,e);return j?.length>0&&i.push(...j),{success:!0,response:new Response(JSON.stringify(function(a,b){if(!a||0===a.length)return k("unknown");let c=a[a.length-1];if(b===g.h.CLAUDE&&a.find(a=>"message_stop"===a.type)){a.find(a=>"content_block_delta"===a.type);let b=a.find(a=>"message_delta"===a.type),d=a.find(a=>"message_start"===a.type);d?.message&&(c=d.message,b?.usage&&(c.usage=b.usage))}return c}(i,a)),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,d.i)()}})}}(q,b)}function k(a){let b=`chatcmpl-${Date.now()}`;return{id:b,object:"chat.completion",created:Math.floor(Date.now()/1e3),model:a,choices:[{index:0,message:{role:"assistant",content:"CLI Command Execution: Clear Terminal"},finish_reason:"stop"}],usage:{prompt_tokens:1,completion_tokens:1,total_tokens:2}}}function l(a){let{id:b,created:c,model:d,choices:e}=a;return[{id:b,object:"chat.completion.chunk",created:c,model:d,choices:[{index:0,delta:{role:"assistant",content:e[0].message.content},finish_reason:null}]},{id:b,object:"chat.completion.chunk",created:c,model:d,choices:[{index:0,delta:{},finish_reason:"stop"}],usage:a.usage}]}},89122:(a,b,c)=>{c.d(b,{q:()=>m});let d="u">typeof process&&process.versions?.node&&!0,e="u">typeof process&&process.env?.ENABLE_REQUEST_LOGS==="true",f=null,g=null,h=null;async function i(){if(d&&e&&!f)try{f=await Promise.resolve().then(c.t.bind(c,29021,23)),h=(g=await Promise.resolve().then(c.t.bind(c,33873,23))).join("u">typeof process&&process.cwd?process.cwd():".","logs")}catch{}}async function j(a,b,c){if(await i(),!f||!h)return null;try{await f.promises.mkdir(h,{recursive:!0});let d=function(a=new Date){let b=a=>String(a).padStart(2,"0"),c=a.getFullYear(),d=b(a.getMonth()+1),e=b(a.getDate()),f=b(a.getHours()),g=b(a.getMinutes()),h=b(a.getSeconds());return`${c}${d}${e}_${f}${g}${h}`}(),e=(c||"unknown").replace(/[/:]/g,"-"),i=`${a}_${b}_${e}_${d}`,j=g.join(h,i);return await f.promises.mkdir(j,{recursive:!0}),j}catch(a){return console.log("[LOG] Failed to create log session:",a.message),null}}function k(a,b,c){if(!f||!a)return;let d=g.join(a,b);f.promises.writeFile(d,JSON.stringify(c,null,2)).catch(a=>console.log(`[LOG] Failed to write ${b}:`,a.message))}function l(a){if(!a)return{};let b={...a},c=["authorization","x-api-key","cookie","token"];for(let a of Object.keys(b)){let d=a.toLowerCase();if(c.some(a=>d.includes(a))){let c=b[a];c&&c.length>20&&(b[a]=c.slice(0,10)+"..."+c.slice(-5))}}return b}async function m(a,b,c){if(!e)return{sessionPath:null,logClientRawRequest(){},logRawRequest(){},logOpenAIRequest(){},logTargetRequest(){},logProviderResponse(){},appendProviderChunk(){},appendOpenAIChunk(){},logConvertedResponse(){},appendConvertedChunk(){},logError(){}};let d=await j(a,b,c);return{get sessionPath(){return d},logClientRawRequest(a,b,c={}){k(d,"1_req_client.json",{timestamp:new Date().toISOString(),endpoint:a,headers:l(c),body:b})},logRawRequest(a,b={}){k(d,"2_req_source.json",{timestamp:new Date().toISOString(),headers:l(b),body:a})},logOpenAIRequest(a){k(d,"3_req_openai.json",{timestamp:new Date().toISOString(),body:a})},logTargetRequest(a,b,c){k(d,"4_req_target.json",{timestamp:new Date().toISOString(),url:a,headers:l(b),body:c})},logProviderResponse(a,b,c,e){k(d,"5_res_provider.json",{timestamp:new Date().toISOString(),status:a,statusText:b,headers:c?"function"==typeof c.entries?Object.fromEntries(c.entries()):c:{},body:e})},appendProviderChunk(a){if(!f||!d)return;let b=g.join(d,"5_res_provider.txt");f.promises.appendFile(b,a).catch(()=>{})},appendOpenAIChunk(a){if(!f||!d)return;let b=g.join(d,"6_res_openai.txt");f.promises.appendFile(b,a).catch(()=>{})},logConvertedResponse(a){k(d,"7_res_client.json",{timestamp:new Date().toISOString(),body:a})},appendConvertedChunk(a){if(!f||!d)return;let b=g.join(d,"7_res_client.txt");f.promises.appendFile(b,a).catch(()=>{})},logError(a,b=null){k(d,"6_error.json",{timestamp:new Date().toISOString(),error:a?.message||String(a),stack:a?.stack,requestBody:b})}}}},92937:(a,b,c)=>{c.d(b,{LG:()=>g,LM:()=>j,Zb:()=>f});let d=new Set(["prompt_tokens","completion_tokens","total_tokens","prompt_tokens_details","completion_tokens_details"]),e=/<think>([\s\S]*?)<\/think>/gi;function f(a){if(!a||"string"!=typeof a)return{content:a||"",thinking:null};let b=[],c=!1,d=a.replace(e,(a,d)=>{c=!0;let e=d.trim();return e&&b.push(e),""});return c?{content:d.trim(),thinking:b.length>0?b.join("\n\n"):null}:{content:a,thinking:null}}function g(a){var b;if(!a||"object"!=typeof a)return a;let c={};return c.id=(b=a.id)&&"string"==typeof b?(b.startsWith("chatcmpl-"),b):`chatcmpl-${crypto.randomUUID().replace(/-/g,"").slice(0,29)}`,c.object=a.object||"chat.completion",c.created=a.created||Math.floor(Date.now()/1e3),c.model=a.model||"unknown",Array.isArray(a.choices)?c.choices=a.choices.map((a,b)=>{var c,d;let e;return c=a,d=b,e={index:c.index??d,finish_reason:c.finish_reason||null},c.message&&(e.message=h(c.message)),c.delta&&(e.delta=h(c.delta)),void 0!==c.logprobs&&(e.logprobs=c.logprobs),e}):c.choices=[],a.usage&&"object"==typeof a.usage&&(c.usage=i(a.usage)),a.system_fingerprint&&(c.system_fingerprint=a.system_fingerprint),c}function h(a){if(!a||"object"!=typeof a)return a;let b={};if(a.role&&(b.role=a.role),void 0!==a.refusal&&(b.refusal=a.refusal),"string"==typeof a.content){let{content:c,thinking:d}=f(a.content);b.content=c,d&&!a.reasoning_content&&(b.reasoning_content=d)}else void 0!==a.content&&(b.content=a.content);return a.reasoning_content&&!b.reasoning_content&&(b.reasoning_content=a.reasoning_content),a.tool_calls&&(b.tool_calls=a.tool_calls),a.function_call&&(b.function_call=a.function_call),b}function i(a){if(!a||"object"!=typeof a)return a;let b={};for(let c of d)void 0!==a[c]&&(b[c]=a[c]);return void 0===b.prompt_tokens&&(b.prompt_tokens=0),void 0===b.completion_tokens&&(b.completion_tokens=0),void 0===b.total_tokens&&(b.total_tokens=b.prompt_tokens+b.completion_tokens),b}function j(a){if(!a||"object"!=typeof a)return a;let b={};return void 0!==a.id&&(b.id=a.id),b.object=a.object||"chat.completion.chunk",void 0!==a.created&&(b.created=a.created),void 0!==a.model&&(b.model=a.model),Array.isArray(a.choices)&&(b.choices=a.choices.map(a=>{let b={index:a.index??0};if(void 0!==a.delta){b.delta={};let c=a.delta;void 0!==c.role&&(b.delta.role=c.role),void 0!==c.content&&(b.delta.content=c.content),void 0!==c.reasoning_content&&(b.delta.reasoning_content=c.reasoning_content),void 0!==c.tool_calls&&(b.delta.tool_calls=c.tool_calls),void 0!==c.function_call&&(b.delta.function_call=c.function_call)}return void 0!==a.finish_reason&&(b.finish_reason=a.finish_reason),void 0!==a.logprobs&&(b.logprobs=a.logprobs),b})),a.usage&&"object"==typeof a.usage&&(b.usage=i(a.usage)),a.system_fingerprint&&(b.system_fingerprint=a.system_fingerprint),b}}};
26
+ `;e.enqueue(h.encode(a))}catch{}}})}function e(a){return!!a&&"true"===("function"==typeof a.get?b=>a.get(b):b=>a[b])("x-omniroute-progress")}c.d(b,{Y:()=>d,Z:()=>e})},69590:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{w:()=>C});var e=c(95982),f=c(32113),g=c(89575),h=c(55120),i=c(49076),j=c(6327),k=c(50101),l=c(87068),m=c(89122),n=c(23969),o=c(71861),p=c(60293),q=c(82795),r=c(27230),s=c(37544),t=c(50498),u=c(8550),v=c(54745),w=c(92937),x=c(1308),y=c(9315),z=c(79335),A=c(65982),B=a([s]);async function C({body:a,modelInfo:b,credentials:c,log:d,onCredentialsRefreshed:B,onRequestSuccess:C,onDisconnect:D,clientRawRequest:E,connectionId:F,apiKeyInfo:G=null,userAgent:H,comboName:I}){let J,K,L,M,N,O,{provider:P,model:Q}=b,R=Date.now(),S=(0,z.xp)(E?.headers),T=(0,z.ic)(S);if(T)return d?.debug?.("IDEMPOTENCY",`Hit for key=${S?.slice(0,12)}...`),{success:!0,response:new Response(JSON.stringify(T.response),{status:T.status,headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)(),"X-OmniRoute-Idempotent":"true"}})};await (0,x.rh)();let U=(0,f.Tz)(a),V=(E?.endpoint||"").toLowerCase().endsWith("/responses"),W=(0,q.c)(a,Q,H);if(W)return W;let X=n.PROVIDER_ID_TO_ALIAS[P]||P,Y=(0,n.ux)(X,Q)||(0,f.jJ)(P),Z=!0===a.stream;if((0,y.TZ)(a,E?.headers)){let b=(0,y.gR)(Q,a.messages,a.temperature,a.top_p),c=(0,y.Cb)(b);if(c)return d?.debug?.("CACHE",`Semantic cache HIT for ${Q}`),{success:!0,response:new Response(JSON.stringify(c),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)(),"X-OmniRoute-Cache":"HIT"}})}}let $=await (0,m.q)(U,Y,Q);E&&$.logClientRawRequest(E.endpoint,E.body,E.headers),$.logRawRequest(a),d?.debug?.("FORMAT",`${U} → ${Y} | stream=${Z}`);let _=a;try{_=(0,g.GH)(U,Y,Q,a,Z,c,P,$)}catch(g){let a=Number(g?.statusCode),b=Number.isInteger(a)&&a>=400&&a<=599?a:p.gx.SERVER_ERROR,c=g?.message||"Invalid request",f="string"==typeof g?.errorType?g.errorType:null;if(d?.warn?.("TRANSLATE",`Request translation failed: ${c}`),f)return{success:!1,status:b,error:c,response:new Response(JSON.stringify({error:{message:c,type:f,code:f}}),{status:b,headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)()}})};return(0,o.A1)(b,c)}let aa=_._toolNameMap;delete _._toolNameMap,_.model=Q;let ab=(0,s.SB)(P);(0,r.uw)(Q,P,F,!0),(0,r.E5)({model:Q,provider:P,connectionId:F,status:"PENDING"}).catch(()=>{});let ac=_.messages?.length||_.contents?.length||_.request?.contents?.length||0;d?.debug?.("REQUEST",`${P.toUpperCase()} | ${Q} | ${ac} msgs`);let ad=(0,j.jd)({onDisconnect:D,log:d,provider:P,model:Q});try{let a=await (0,x.YO)(P,F,Q,()=>ab.execute({model:Q,body:_,stream:Z,credentials:c,signal:ad.signal,log:d}));J=a.response,K=a.url,L=a.headers,M=a.transformedBody,$.logTargetRequest(K,L,M),(0,x.Kr)(P,F,J.headers,J.status,Q)}catch(c){if((0,r.uw)(Q,P,F,!1),(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${"AbortError"===c.name?499:p.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:"AbortError"===c.name?499:p.gx.BAD_GATEWAY,model:Q,provider:P,connectionId:F,duration:Date.now()-R,requestBody:a,error:c.message,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{}),"AbortError"===c.name)return ad.handleError(c),(0,o.A1)(499,"Request aborted");let b=(0,o.lR)(c,P,Q,p.gx.BAD_GATEWAY);return console.log(`${i.lm.red}[ERROR] ${b}${i.lm.reset}`),(0,o.A1)(p.gx.BAD_GATEWAY,b)}if(J.status===p.gx.UNAUTHORIZED||J.status===p.gx.FORBIDDEN){let a=await (0,l.qZ)(()=>ab.refreshCredentials(c,d),3,d);if(a?.accessToken||a?.copilotToken){d?.info?.("TOKEN",`${P.toUpperCase()} | refreshed`),Object.assign(c,a),B&&a&&await B(a);try{let a=await ab.execute({model:Q,body:_,stream:Z,credentials:c,signal:ad.signal,log:d});a.response.ok&&(J=a.response,K=a.url)}catch(a){d?.warn?.("TOKEN",`${P.toUpperCase()} | retry after refresh failed`)}}else d?.warn?.("TOKEN",`${P.toUpperCase()} | refresh failed`)}if(!J.ok){(0,r.uw)(Q,P,F,!1);let{statusCode:b,message:c,retryAfterMs:e}=await (0,o.zL)(J,P);(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${b}`}).catch(()=>{}),(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:b,model:Q,provider:P,connectionId:F,duration:Date.now()-R,requestBody:a,error:c,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{});let f=(0,o.lR)(Error(c),P,Q,b);if(console.log(`${i.lm.red}[ERROR] ${f}${i.lm.reset}`),e&&"antigravity"===P){let a=Math.ceil(e/1e3);d?.debug?.("RETRY",`Antigravity quota reset in ${a}s (${e}ms)`)}return $.logError(Error(c),M||_),(0,x.Kr)(P,F,J.headers,b,Q),(0,o.A1)(b,f,e)}if(!Z){let b;(0,r.uw)(Q,P,F,!1);let c=(J.headers.get("content-type")||"").toLowerCase(),f=await J.text();if(c.includes("text/event-stream")||/(^|\n)\s*(event|data):/m.test(f)){let a=Y===h.h.OPENAI_RESPONSES?(0,v.B)(f,Q):(0,v.F)(f,Q);if(!a)return(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${p.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,o.A1)(p.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");b=a}else try{b=f?JSON.parse(f):{}}catch{return(0,r.E5)({model:Q,provider:P,connectionId:F,status:`FAILED ${p.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,o.A1)(p.gx.BAD_GATEWAY,"Invalid JSON response from provider")}C&&await C();let j=(0,u.M)(b,P);if((0,r.E5)({model:Q,provider:P,connectionId:F,tokens:j,status:"200 OK"}).catch(()=>{}),(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:200,model:Q,provider:P,connectionId:F,duration:Date.now()-R,tokens:j,requestBody:a,responseBody:b,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{}),j&&"object"==typeof j){let a=`[${new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit"})}] 📊 [USAGE] ${P.toUpperCase()} | in=${j?.prompt_tokens||0} | out=${j?.completion_tokens||0}${F?` | account=${F.slice(0,8)}...`:""}`;console.log(`${i.lm.green}${a}${i.lm.reset}`),(0,r.sZ)({provider:P||"unknown",model:Q||"unknown",tokens:j,timestamp:new Date().toISOString(),connectionId:F||void 0,apiKeyId:G?.id||void 0,apiKeyName:G?.name||void 0}).catch(a=>{console.error("Failed to save usage stats:",a.message)})}let l=(0,g.nZ)(Y,U)?(0,t.l)(b,Y,U):b;if(U===h.h.OPENAI&&(l=(0,w.LG)(l)),l?.usage){let a=(0,k.O9)(l.usage);l.usage=(0,k.WL)(a,U)}else{let b=JSON.stringify(l?.choices?.[0]?.message?.content||"").length;if(b>0){let c=(0,k.OF)(a,b,U);l.usage=(0,k.WL)(c,U)}}if((0,y.TZ)(a,E?.headers)){let b=(0,y.gR)(Q,a.messages,a.temperature,a.top_p),c=j?.prompt_tokens+j?.completion_tokens||0;(0,y.yv)(b,Q,l,c),d?.debug?.("CACHE",`Stored response for ${Q} (${c} tokens)`)}return(0,z.tm)(S,l,200),{success:!0,response:new Response(JSON.stringify(l),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,e.i)(),"X-OmniRoute-Cache":"MISS"}})}}C&&await C();let ae={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":(0,e.i)()},af=({status:b,usage:c})=>{(0,r.gK)({method:"POST",path:E?.endpoint||"/v1/chat/completions",status:b||200,model:Q,provider:P,connectionId:F,duration:Date.now()-R,tokens:c||{},requestBody:a,sourceFormat:U,targetFormat:Y,comboName:I,apiKeyId:G?.id||null,apiKeyName:G?.name||null}).catch(()=>{})},ag=H?.toLowerCase().includes("droid")||H?.toLowerCase().includes("codex-cli");if("codex"!==P||Y!==h.h.OPENAI_RESPONSES||U!==h.h.OPENAI||V||ag?(0,g.nZ)(Y,U)?(d?.debug?.("STREAM",`Translation mode: ${Y} → ${U}`),N=(0,i.i5)(Y,U,P,$,aa,Q,F,a,af,G)):(d?.debug?.("STREAM","Standard passthrough mode"),N=(0,i.l2)(P,$,Q,F,a,af,G)):(d?.debug?.("STREAM",`Codex translation mode: openai-responses → openai`),N=(0,i.i5)("openai-responses","openai",P,$,aa,Q,F,a,af,G)),(0,A.Z)(E?.headers)){let a=(0,A.Y)({signal:ad.signal});O=(0,j.Jb)(J,N,ad).pipeThrough(a),ae["X-OmniRoute-Progress"]="enabled"}else O=(0,j.Jb)(J,N,ad);return{success:!0,response:new Response(O,{headers:ae})}}s=(B.then?(await B)():B)[0],d()}catch(a){d(a)}})},76340:(a,b,c)=>{let d;c.d(b,{Wk:()=>s,jf:()=>p,qT:()=>r});var e=c(16698),f=c(79522);try{({createSession:d}=c(22546))}catch{d=null}class g{constructor(){this.session=null,this.available=!!d}async getSession(){if(!this.available)return null;if(this.session)return this.session;let a=process.env.HTTPS_PROXY||process.env.https_proxy||process.env.HTTP_PROXY||process.env.http_proxy||process.env.ALL_PROXY||process.env.all_proxy||void 0,b={browser:"chrome_124",os:"macos"};return a&&(b.proxy=a,console.log(`[TlsClient] Using proxy: ${a}`)),this.session=await d(b),console.log("[TlsClient] Session created (Chrome 124 TLS fingerprint)"),this.session}async fetch(a,b={}){let c=await this.getSession();if(!c)throw Error("wreq-js not available");let d={method:(b.method||"GET").toUpperCase(),headers:b.headers,body:b.body,redirect:"manual"===b.redirect?"manual":"follow"};return b.signal&&(d.signal=b.signal),await c.fetch(a,d)}async exit(){this.session&&(await this.session.close(),this.session=null)}}let h=new g;function i(){return"true"===process.env.ENABLE_TLS_FINGERPRINT}let j=new e.AsyncLocalStorage,k="u">typeof caches&&"object"==typeof caches,l=Symbol.for("omniroute.proxyFetch.state"),m=(globalThis[l]||(globalThis[l]={originalFetch:globalThis.fetch,proxyContext:new e.AsyncLocalStorage,isPatched:!1}),globalThis[l]),n=m.originalFetch,o=m.proxyContext;async function p(a,b){if("function"!=typeof b)throw TypeError("runWithProxyContext requires a callback function");let c=a?(0,f.HN)(a):null;return o.run(a||null,async()=>(c&&console.log(`[ProxyFetch] Applied request proxy context: ${(0,f.OK)(c)}`),b()))}async function q(a,b={}){let c;if(b?.dispatcher)return n(a,b);let d="string"==typeof a?a:a&&"string"==typeof a.url?a.url:String(a);try{c=function(a){let b=o.getStore();if(b)return{source:"context",proxyUrl:(0,f.HN)(b)};let c=function(a){let b;if(function(a){let b,c=process.env.NO_PROXY||process.env.no_proxy;if(!c)return!1;try{b=new URL(a)}catch{return!1}let d=b.hostname.toLowerCase(),e=b.port||("https:"===b.protocol?"443":"80");return c.split(",").map(a=>a.trim().toLowerCase()).filter(Boolean).some(a=>{if("*"===a)return!0;let[b,c]=a.split(":");return(!c||c===e)&&!!b&&(b.startsWith(".")?d.endsWith(b)||d===b.slice(1):d===b||d.endsWith(`.${b}`))})}(a))return null;try{b=new URL(a).protocol}catch{return null}let c="https:"===b?process.env.HTTPS_PROXY||process.env.https_proxy||process.env.ALL_PROXY||process.env.all_proxy:process.env.HTTP_PROXY||process.env.http_proxy||process.env.ALL_PROXY||process.env.all_proxy;return c?(0,f.zP)(c,"environment proxy"):null}(a);return c?{source:"env",proxyUrl:c}:{source:"direct",proxyUrl:null}}(d)}catch(b){let a=b instanceof Error?b.message:String(b);throw console.error(`[ProxyFetch] Proxy configuration error: ${a}`),b}let{source:e,proxyUrl:g}=c;if(!g){if(i()&&h.available)try{let a=j.getStore();return a&&(a.used=!0),await h.fetch(d,b)}catch(c){let a=c instanceof Error?c.message:String(c);console.warn(`[ProxyFetch] TLS fingerprint failed, falling back to native fetch: ${a}`);let b=j.getStore();b&&(b.used=!1)}return n(a,b)}try{let c=(0,f.I_)(g);return await n(a,{...b,dispatcher:c})}catch(b){let a=b instanceof Error?b.message:String(b);throw console.error(`[ProxyFetch] Proxy request failed (${e}, fail-closed): ${a}`),b}}async function r(a){let b={used:!1};return{result:await j.run(b,a),tlsFingerprintUsed:b.used}}function s(){return i()&&h.available}k||m.isPatched||(globalThis.fetch=q,m.isPatched=!0)},77458:(a,b,c)=>{c.d(b,{Jh:()=>g});let d=[{name:"system_override",pattern:/\b(ignore|disregard|forget)\s+(all\s+)?(previous|prior|above|earlier)\s+(instructions?|prompts?|rules?|context)/i,severity:"high"},{name:"role_hijack",pattern:/\b(you\s+are\s+now|act\s+as\s+if|pretend\s+(to\s+be|you\s+are)|from\s+now\s+on\s+you\s+are)\b/i,severity:"medium"},{name:"system_prompt_leak",pattern:/\b(reveal|show|display|print|output|repeat)\s+(your\s+)?(system\s+prompt|instructions?|initial\s+prompt|hidden\s+prompt)/i,severity:"high"},{name:"delimiter_injection",pattern:/(\[SYSTEM\]|\[INST\]|<<SYS>>|<\|im_start\|>|<\|system\|>|<\|user\|>)/i,severity:"high"},{name:"jailbreak_dan",pattern:/\b(DAN|do\s+anything\s+now|jailbreak|developer\s+mode|enable\s+developer)\b/i,severity:"medium"},{name:"encoding_evasion",pattern:/\b(base64\s+decode|rot13|hex\s+decode|unicode\s+escape)\b.*\b(instruction|prompt|command)\b/i,severity:"medium"}],e=[{name:"email",pattern:/\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b/g,replacement:"[EMAIL_REDACTED]"},{name:"cpf",pattern:/\b\d{3}\.\d{3}\.\d{3}-\d{2}\b/g,replacement:"[CPF_REDACTED]"},{name:"cnpj",pattern:/\b\d{2}\.\d{3}\.\d{3}\/\d{4}-\d{2}\b/g,replacement:"[CNPJ_REDACTED]"},{name:"credit_card",pattern:/\b(?:\d{4}[-\s]?){3}\d{4}\b/g,replacement:"[CARD_REDACTED]"},{name:"phone_br",pattern:/\b\(?\d{2}\)?\s?\d{4,5}-?\d{4}\b/g,replacement:"[PHONE_REDACTED]"},{name:"ssn_us",pattern:/\b\d{3}-\d{2}-\d{4}\b/g,replacement:"[SSN_REDACTED]"}];function f(a,b=!1){let c=[],d=a;for(let f of e){let e=a.match(f.pattern);e&&e.length>0&&(c.push({type:f.name,count:e.length}),b&&(d=d.replace(f.pattern,f.replacement)))}return{text:d,detections:c}}function g(a,b=console){let c={enabled:"false"!==process.env.INPUT_SANITIZER_ENABLED,mode:process.env.INPUT_SANITIZER_MODE||"warn",piiRedaction:"true"===process.env.PII_REDACTION_ENABLED},e={blocked:!1,modified:!1,detections:[],piiDetections:[],sanitizedBody:null};if(!c.enabled)return e;let h=(function(a){let b=[];for(let c of a.messages||a.input||[])if("string"==typeof c)b.push(c);else if("string"==typeof c.content)b.push(c.content);else if(Array.isArray(c.content))for(let a of c.content)"string"==typeof a?b.push(a):a.text&&b.push(a.text);if("string"==typeof a.system)b.push(a.system);else if(Array.isArray(a.system))for(let c of a.system)"string"==typeof c?b.push(c):c.text&&b.push(c.text);return b})(a).join("\n"),i=function(a){let b=[];for(let c of d){let d=a.match(c.pattern);d&&b.push({pattern:c.name,severity:c.severity,match:d[0].slice(0,50)})}return b}(h);if(i.length>0){e.detections=i;let a=i.filter(a=>"high"===a.severity),d=a.length>0?"warn":"info";if(b[d]&&b[d](`[SANITIZER] Prompt injection detected: ${i.map(a=>a.pattern).join(", ")}`),"block"===c.mode&&a.length>0)return e.blocked=!0,e}if(c.piiRedaction){let d=f(h,"redact"===c.mode);e.piiDetections=d.detections,d.detections.length>0&&(b.warn?.(`[SANITIZER] PII detected: ${d.detections.map(a=>`${a.type}(${a.count})`).join(", ")}`),"redact"===c.mode&&(e.sanitizedBody=function(a){let b=JSON.parse(JSON.stringify(a));for(let a of b.messages||b.input||[])if("string"==typeof a.content)a.content=f(a.content,!0).text;else if(Array.isArray(a.content))for(let b of a.content)if("string"==typeof b){let c=a.content.indexOf(b);a.content[c]=f(b,!0).text}else b.text&&(b.text=f(b.text,!0).text);return"string"==typeof b.system&&(b.system=f(b.system,!0).text),b}(a),e.modified=!0))}return e}},79335:(a,b,c)=>{let d;c.d(b,{ic:()=>g,ne:()=>i,tm:()=>h,xp:()=>f});let e=new Map;function f(a){if(!a)return null;let b="function"==typeof a.get?b=>a.get(b):b=>a[b];return b("idempotency-key")||b("x-request-id")||null}function g(a){if(!a)return null;let b=e.get(a);return b?Date.now()>=b.expiresAt?(e.delete(a),null):{response:b.response,status:b.status}:null}function h(a,b,c,f=5e3){a&&(!d&&(d=setInterval(()=>{let a=Date.now();for(let[b,c]of e)a>=c.expiresAt&&e.delete(b)},3e4)).unref&&d.unref(),e.set(a,{response:b,status:c,expiresAt:Date.now()+f}))}function i(){return{activeKeys:e.size,windowMs:5e3}}},79522:(a,b,c)=>{c.d(b,{HN:()=>m,I_:()=>n,OK:()=>k,QX:()=>j,zP:()=>l});var d=c(47774),e=c(20406);let f=Symbol.for("omniroute.proxyDispatcher.cache"),g=new Set(["http:","https:","socks5:"]);function h(a){return"https:"===a||"wss:"===a?"443":"socks5:"===a?"1080":"8080"}function i(a,b){if(!a)return h(b);let c=Number(a);if(!Number.isInteger(c)||c<1||c>65535)throw Error("[ProxyDispatcher] Invalid proxy port");return String(c)}function j(){return"true"===process.env.ENABLE_SOCKS5_PROXY}function k(a){let b=new URL(a),c=b.port||h(b.protocol);return`${b.protocol}//${b.hostname}:${c}`}function l(a,b="proxy",{allowSocks5:c=j()}={}){let d;try{d=new URL(a)}catch{throw Error(`[ProxyDispatcher] Invalid ${b} URL`)}if(!g.has(d.protocol))throw Error(`[ProxyDispatcher] Unsupported ${b} protocol: ${d.protocol.replace(":","")}`);if("socks5:"===d.protocol&&!c)throw Error("[ProxyDispatcher] SOCKS5 proxy is disabled (set ENABLE_SOCKS5_PROXY=true to enable)");if(!d.hostname)throw Error(`[ProxyDispatcher] Invalid ${b} host`);return d.port=i(d.port,d.protocol),d.toString()}function m(a,{allowSocks5:b=j()}={}){if(!a)return null;if("string"==typeof a)return l(a,"context proxy",{allowSocks5:b});if("object"!=typeof a||Array.isArray(a))throw Error("[ProxyDispatcher] Invalid context proxy config");let c=String(a.type||"http").toLowerCase(),d=`${c}:`;if(!g.has(d))throw Error(`[ProxyDispatcher] Unsupported context proxy protocol: ${c}`);if("socks5:"===d&&!b)throw Error("[ProxyDispatcher] SOCKS5 proxy is disabled (set ENABLE_SOCKS5_PROXY=true to enable)");if(!a.host)throw Error("[ProxyDispatcher] Context proxy host is required");let e=i(a.port,d),f=new URL(`${c}://${a.host}:${e}`);return a.username&&(f.username=a.username,f.password=a.password||""),l(f.toString(),"context proxy",{allowSocks5:b})}function n(a){let b=l(a,"proxy dispatcher"),c=(globalThis[f]||(globalThis[f]=new Map),globalThis[f]),g=c.get(b);if(g)return g;let h=new URL(b);if("socks5:"===h.protocol){let a={type:5,host:h.hostname,port:Number(i(h.port,h.protocol))};h.username&&(a.userId=decodeURIComponent(h.username)),h.password&&(a.password=decodeURIComponent(h.password)),g=(0,e.vI)(a)}else g=new d.ProxyAgent(b);return c.set(b,g),g}},82795:(a,b,c)=>{c.d(b,{c:()=>j});var d=c(95982),e=c(32113),f=c(89575),g=c(55120),h=c(60293),i=c(49076);function j(a,b,c=""){if(!c.includes("claude-cli")||!a.messages?.length)return null;let m=a.messages,n=a=>"string"==typeof a?a:Array.isArray(a)?a.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"",o=!1,p=m[m.length-1];if(p?.role==="assistant"&&p.content?.[0]?.text==="{"&&(o=!0),o||"Warmup"===n(m[0]?.content)&&(o=!0),o||1!==m.length||m[0]?.role!=="user"||"count"===n(m[0]?.content)&&(o=!0),!o&&h.C8?.length){let a=m.filter(a=>"user"===a.role).map(a=>n(a.content)).join(" ");h.C8.some(b=>a.includes(b))&&(o=!0)}if(!o)return null;let q=(0,e.Tz)(a);return!1!==a.stream?function(a,b){let c=k(b),e=(0,f.Ws)(a);e.model=b;let h=l(c),j=[];for(let b of h){let c=(0,f.Y8)(g.h.OPENAI,a,b,e);if(c?.length>0)for(let b of c)j.push((0,i.v8)(b,a))}let m=(0,f.Y8)(g.h.OPENAI,a,null,e);if(m?.length>0)for(let b of m)j.push((0,i.v8)(b,a));return j.push("data: [DONE]\n\n"),{success:!0,response:new Response(j.join(""),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":(0,d.i)()}})}}(q,b):function(a,b){let c=k(b);if(a===g.h.OPENAI)return{success:!0,response:new Response(JSON.stringify(c),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,d.i)()}})};let e=(0,f.Ws)(a);e.model=b;let h=l(c),i=[];for(let b of h){let c=(0,f.Y8)(g.h.OPENAI,a,b,e);c?.length>0&&i.push(...c)}let j=(0,f.Y8)(g.h.OPENAI,a,null,e);return j?.length>0&&i.push(...j),{success:!0,response:new Response(JSON.stringify(function(a,b){if(!a||0===a.length)return k("unknown");let c=a[a.length-1];if(b===g.h.CLAUDE&&a.find(a=>"message_stop"===a.type)){a.find(a=>"content_block_delta"===a.type);let b=a.find(a=>"message_delta"===a.type),d=a.find(a=>"message_start"===a.type);d?.message&&(c=d.message,b?.usage&&(c.usage=b.usage))}return c}(i,a)),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":(0,d.i)()}})}}(q,b)}function k(a){let b=`chatcmpl-${Date.now()}`;return{id:b,object:"chat.completion",created:Math.floor(Date.now()/1e3),model:a,choices:[{index:0,message:{role:"assistant",content:"CLI Command Execution: Clear Terminal"},finish_reason:"stop"}],usage:{prompt_tokens:1,completion_tokens:1,total_tokens:2}}}function l(a){let{id:b,created:c,model:d,choices:e}=a;return[{id:b,object:"chat.completion.chunk",created:c,model:d,choices:[{index:0,delta:{role:"assistant",content:e[0].message.content},finish_reason:null}]},{id:b,object:"chat.completion.chunk",created:c,model:d,choices:[{index:0,delta:{},finish_reason:"stop"}],usage:a.usage}]}},89122:(a,b,c)=>{c.d(b,{q:()=>m});let d="u">typeof process&&process.versions?.node&&!0,e="u">typeof process&&process.env?.ENABLE_REQUEST_LOGS==="true",f=null,g=null,h=null;async function i(){if(d&&e&&!f)try{f=await Promise.resolve().then(c.t.bind(c,29021,23)),h=(g=await Promise.resolve().then(c.t.bind(c,33873,23))).join("u">typeof process&&process.cwd?process.cwd():".","logs")}catch{}}async function j(a,b,c){if(await i(),!f||!h)return null;try{await f.promises.mkdir(h,{recursive:!0});let d=function(a=new Date){let b=a=>String(a).padStart(2,"0"),c=a.getFullYear(),d=b(a.getMonth()+1),e=b(a.getDate()),f=b(a.getHours()),g=b(a.getMinutes()),h=b(a.getSeconds());return`${c}${d}${e}_${f}${g}${h}`}(),e=(c||"unknown").replace(/[/:]/g,"-"),i=`${a}_${b}_${e}_${d}`,j=g.join(h,i);return await f.promises.mkdir(j,{recursive:!0}),j}catch(a){return console.log("[LOG] Failed to create log session:",a.message),null}}function k(a,b,c){if(!f||!a)return;let d=g.join(a,b);f.promises.writeFile(d,JSON.stringify(c,null,2)).catch(a=>console.log(`[LOG] Failed to write ${b}:`,a.message))}function l(a){if(!a)return{};let b={...a},c=["authorization","x-api-key","cookie","token"];for(let a of Object.keys(b)){let d=a.toLowerCase();if(c.some(a=>d.includes(a))){let c=b[a];c&&c.length>20&&(b[a]=c.slice(0,10)+"..."+c.slice(-5))}}return b}async function m(a,b,c){if(!e)return{sessionPath:null,logClientRawRequest(){},logRawRequest(){},logOpenAIRequest(){},logTargetRequest(){},logProviderResponse(){},appendProviderChunk(){},appendOpenAIChunk(){},logConvertedResponse(){},appendConvertedChunk(){},logError(){}};let d=await j(a,b,c);return{get sessionPath(){return d},logClientRawRequest(a,b,c={}){k(d,"1_req_client.json",{timestamp:new Date().toISOString(),endpoint:a,headers:l(c),body:b})},logRawRequest(a,b={}){k(d,"2_req_source.json",{timestamp:new Date().toISOString(),headers:l(b),body:a})},logOpenAIRequest(a){k(d,"3_req_openai.json",{timestamp:new Date().toISOString(),body:a})},logTargetRequest(a,b,c){k(d,"4_req_target.json",{timestamp:new Date().toISOString(),url:a,headers:l(b),body:c})},logProviderResponse(a,b,c,e){k(d,"5_res_provider.json",{timestamp:new Date().toISOString(),status:a,statusText:b,headers:c?"function"==typeof c.entries?Object.fromEntries(c.entries()):c:{},body:e})},appendProviderChunk(a){if(!f||!d)return;let b=g.join(d,"5_res_provider.txt");f.promises.appendFile(b,a).catch(()=>{})},appendOpenAIChunk(a){if(!f||!d)return;let b=g.join(d,"6_res_openai.txt");f.promises.appendFile(b,a).catch(()=>{})},logConvertedResponse(a){k(d,"7_res_client.json",{timestamp:new Date().toISOString(),body:a})},appendConvertedChunk(a){if(!f||!d)return;let b=g.join(d,"7_res_client.txt");f.promises.appendFile(b,a).catch(()=>{})},logError(a,b=null){k(d,"6_error.json",{timestamp:new Date().toISOString(),error:a?.message||String(a),stack:a?.stack,requestBody:b})}}}},92937:(a,b,c)=>{c.d(b,{LG:()=>g,LM:()=>j,Zb:()=>f});let d=new Set(["prompt_tokens","completion_tokens","total_tokens","prompt_tokens_details","completion_tokens_details"]),e=/<think>([\s\S]*?)<\/think>/gi;function f(a){if(!a||"string"!=typeof a)return{content:a||"",thinking:null};let b=[],c=!1,d=a.replace(e,(a,d)=>{c=!0;let e=d.trim();return e&&b.push(e),""});return c?{content:d.trim(),thinking:b.length>0?b.join("\n\n"):null}:{content:a,thinking:null}}function g(a){var b;if(!a||"object"!=typeof a)return a;let c={};return c.id=(b=a.id)&&"string"==typeof b?(b.startsWith("chatcmpl-"),b):`chatcmpl-${crypto.randomUUID().replace(/-/g,"").slice(0,29)}`,c.object=a.object||"chat.completion",c.created=a.created||Math.floor(Date.now()/1e3),c.model=a.model||"unknown",Array.isArray(a.choices)?c.choices=a.choices.map((a,b)=>{var c,d;let e;return c=a,d=b,e={index:c.index??d,finish_reason:c.finish_reason||null},c.message&&(e.message=h(c.message)),c.delta&&(e.delta=h(c.delta)),void 0!==c.logprobs&&(e.logprobs=c.logprobs),e}):c.choices=[],a.usage&&"object"==typeof a.usage&&(c.usage=i(a.usage)),a.system_fingerprint&&(c.system_fingerprint=a.system_fingerprint),c}function h(a){if(!a||"object"!=typeof a)return a;let b={};if(a.role&&(b.role=a.role),void 0!==a.refusal&&(b.refusal=a.refusal),"string"==typeof a.content){let{content:c,thinking:d}=f(a.content);b.content=c,d&&!a.reasoning_content&&(b.reasoning_content=d)}else void 0!==a.content&&(b.content=a.content);return a.reasoning_content&&!b.reasoning_content&&(b.reasoning_content=a.reasoning_content),a.tool_calls&&(b.tool_calls=a.tool_calls),a.function_call&&(b.function_call=a.function_call),b}function i(a){if(!a||"object"!=typeof a)return a;let b={};for(let c of d)void 0!==a[c]&&(b[c]=a[c]);return void 0===b.prompt_tokens&&(b.prompt_tokens=0),void 0===b.completion_tokens&&(b.completion_tokens=0),void 0===b.total_tokens&&(b.total_tokens=b.prompt_tokens+b.completion_tokens),b}function j(a){if(!a||"object"!=typeof a)return a;let b={};return void 0!==a.id&&(b.id=a.id),b.object=a.object||"chat.completion.chunk",void 0!==a.created&&(b.created=a.created),void 0!==a.model&&(b.model=a.model),Array.isArray(a.choices)&&(b.choices=a.choices.map(a=>{let b={index:a.index??0};if(void 0!==a.delta){b.delta={};let c=a.delta;void 0!==c.role&&(b.delta.role=c.role),void 0!==c.content&&(b.delta.content=c.content),void 0!==c.reasoning_content&&(b.delta.reasoning_content=c.reasoning_content),void 0!==c.tool_calls&&(b.delta.tool_calls=c.tool_calls),void 0!==c.function_call&&(b.delta.function_call=c.function_call)}return void 0!==a.finish_reason&&(b.finish_reason=a.finish_reason),void 0!==a.logprobs&&(b.logprobs=a.logprobs),b})),a.usage&&"object"==typeof a.usage&&(b.usage=i(a.usage)),a.system_fingerprint&&(b.system_fingerprint=a.system_fingerprint),b}}};
@@ -1,4 +1,4 @@
1
- "use strict";exports.id=2910,exports.ids=[2910],exports.modules={42910:(a,b,c)=>{c.d(b,{nJ:()=>o,NJ:()=>r,oh:()=>p,G6:()=>u,sm:()=>w,I8:()=>n,m1:()=>m,jX:()=>x,kB:()=>t});var d=c(87550),e=c.n(d),f=c(76760),g=c.n(f),h=c(73024),i=c.n(h),j=c(88189),k=c(73136);let l=function(){try{let a="file:///home/diegosouzapw/dev/proxys/9router/src/lib/db/migrationRunner.ts";if(a&&a.startsWith("file://")){let b=(0,k.fileURLToPath)(a);return g().join(g().dirname(b),"migrations")}}catch{}return g().join(process.cwd(),"src","lib","db","migrations")}(),m="object"==typeof globalThis.caches&&null!==globalThis.caches,n="phase-production-build"===process.env.NEXT_PHASE,o=(0,j._3)({isCloud:m});m||(0,j.sm)();let p=m?null:g().join(o,"storage.sqlite"),q=m?null:g().join(o,"db.json"),r=m?null:g().join(o,"db_backups");if(!m&&!i().existsSync(o))try{i().mkdirSync(o,{recursive:!0})}catch(b){let a=b instanceof Error?b.message:String(b);console.warn(`[DB] Cannot create data directory '${o}': ${a}
1
+ "use strict";exports.id=2910,exports.ids=[2910],exports.modules={42910:(a,b,c)=>{c.d(b,{nJ:()=>o,NJ:()=>r,oh:()=>p,G6:()=>u,sm:()=>w,I8:()=>n,m1:()=>m,jX:()=>x,kB:()=>t});var d=c(87550),e=c.n(d),f=c(76760),g=c.n(f),h=c(73024),i=c.n(h),j=c(88189),k=c(73136);let l=function(){try{let a="file:///home/runner/work/OmniRoute/OmniRoute/src/lib/db/migrationRunner.ts";if(a&&a.startsWith("file://")){let b=(0,k.fileURLToPath)(a);return g().join(g().dirname(b),"migrations")}}catch{}return g().join(process.cwd(),"src","lib","db","migrations")}(),m="object"==typeof globalThis.caches&&null!==globalThis.caches,n="phase-production-build"===process.env.NEXT_PHASE,o=(0,j._3)({isCloud:m});m||(0,j.sm)();let p=m?null:g().join(o,"storage.sqlite"),q=m?null:g().join(o,"db.json"),r=m?null:g().join(o,"db_backups");if(!m&&!i().existsSync(o))try{i().mkdirSync(o,{recursive:!0})}catch(b){let a=b instanceof Error?b.message:String(b);console.warn(`[DB] Cannot create data directory '${o}': ${a}
2
2
  [DB] Set the DATA_DIR environment variable to a writable path, e.g.:
3
3
  [DB] DATA_DIR=/path/to/writable/dir omniroute`)}let s=`
4
4
  CREATE TABLE IF NOT EXISTS provider_connections (
@@ -199,7 +199,7 @@
199
199
  );
200
200
  CREATE INDEX IF NOT EXISTS idx_sc_sig ON semantic_cache(signature);
201
201
  CREATE INDEX IF NOT EXISTS idx_sc_model ON semantic_cache(model);
202
- `;function t(a){if(!a)return null;let b={};for(let[c,d]of Object.entries(a)){let a=c.replace(/_([a-z])/g,(a,b)=>b.toUpperCase());if("isActive"===a||"rateLimitProtection"===a)b[a]=1===d||!0===d;else if("providerSpecificData"===a&&"string"==typeof d)try{b[a]=JSON.parse(d)}catch{b[a]=d}else b[a]=d}return b}function u(a){let b={};for(let[c,d]of Object.entries(a))null!=d&&(b[c]=d);return b}let v=null;function w(){if(v)return v;if(m||n)return n&&console.log("[DB] Build phase detected — using in-memory SQLite (read-only)"),(v=new(e())(":memory:")).pragma("journal_mode = WAL"),v.exec(s),v;if(i().existsSync(p))try{let a=new(e())(p,{readonly:!0}),b=a.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='schema_migrations'").get();if(a.close(),b){let a=p+".old-schema";for(let b of(console.log(`[DB] Old incompatible schema detected — renaming to ${g().basename(a)}`),i().renameSync(p,a),["-wal","-shm"]))try{i().existsSync(p+b)&&i().unlinkSync(p+b)}catch{}}}catch(a){console.warn("[DB] Could not probe existing DB, will create fresh:",a.message);try{i().unlinkSync(p)}catch{}}(v=new(e())(p)).pragma("journal_mode = WAL"),v.pragma("busy_timeout = 5000"),v.pragma("synchronous = NORMAL"),v.exec(s);var a=v;try{let b=a.prepare("PRAGMA table_info(provider_connections)").all();new Set(b.map(a=>a.name)).has("rate_limit_protection")||(a.exec("ALTER TABLE provider_connections ADD COLUMN rate_limit_protection INTEGER DEFAULT 0"),console.log("[DB] Added provider_connections.rate_limit_protection column"))}catch(a){console.warn("[DB] Failed to verify provider_connections schema:",a.message)}return v.exec(`
202
+ `;function t(a){if(!a)return null;let b={};for(let[c,d]of Object.entries(a)){let a=c.replace(/_([a-z])/g,(a,b)=>b.toUpperCase());if("isActive"===a||"rateLimitProtection"===a)b[a]=1===d||!0===d;else if("providerSpecificData"===a&&"string"==typeof d)try{b[a]=JSON.parse(d)}catch{b[a]=d}else b[a]=d}return b}function u(a){let b={};for(let[c,d]of Object.entries(a))null!=d&&(b[c]=d);return b}let v=null;function w(){if(v)return v;if(m||n)return n&&console.log("[DB] Build phase detected — using in-memory SQLite (read-only)"),(v=new(e())(":memory:")).pragma("journal_mode = WAL"),v.exec(s),v;if(i().existsSync(p))try{let a=new(e())(p,{readonly:!0});if(a.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='schema_migrations'").get()){let b=!1;try{let c=a.prepare("SELECT COUNT(*) as c FROM provider_connections").get();b=c&&c.c>0}catch{}if(a.close(),b){console.log(`[DB] Old schema_migrations table found but data exists — preserving data (#146)`);let a=new(e())(p);try{a.exec("DROP TABLE IF EXISTS schema_migrations"),a.pragma("wal_checkpoint(TRUNCATE)")}catch(a){console.warn("[DB] Could not clean up old schema table:",a.message)}finally{a.close()}}else{let a=p+".old-schema";for(let b of(console.log(`[DB] Old incompatible schema detected (empty) — renaming to ${g().basename(a)}`),i().renameSync(p,a),["-wal","-shm"]))try{i().existsSync(p+b)&&i().unlinkSync(p+b)}catch{}}}else a.close()}catch(a){console.warn("[DB] Could not probe existing DB, will create fresh:",a.message);try{i().unlinkSync(p)}catch{}}(v=new(e())(p)).pragma("journal_mode = WAL"),v.pragma("busy_timeout = 5000"),v.pragma("synchronous = NORMAL"),v.exec(s);var a=v;try{let b=a.prepare("PRAGMA table_info(provider_connections)").all();new Set(b.map(a=>a.name)).has("rate_limit_protection")||(a.exec("ALTER TABLE provider_connections ADD COLUMN rate_limit_protection INTEGER DEFAULT 0"),console.log("[DB] Added provider_connections.rate_limit_protection column"))}catch(a){console.warn("[DB] Failed to verify provider_connections schema:",a.message)}return v.exec(`
203
203
  CREATE TABLE IF NOT EXISTS _omniroute_migrations (
204
204
  version TEXT PRIMARY KEY,
205
205
  name TEXT NOT NULL,