9router 0.3.23 → 0.3.27

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 (479) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +37 -34
  3. package/app/.next/build-manifest.json +2 -2
  4. package/app/.next/routes-manifest.json +18 -0
  5. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js +1 -1
  6. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js.nft.json +1 -1
  7. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  8. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js +1 -1
  9. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js.nft.json +1 -1
  10. package/app/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  11. package/app/.next/server/app/(dashboard)/dashboard/console-log/page.js +2 -0
  12. package/app/.next/server/app/(dashboard)/dashboard/console-log/page.js.nft.json +1 -0
  13. package/app/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -0
  14. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js +1 -1
  15. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js.nft.json +1 -1
  16. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/page.js +1 -1
  18. package/app/.next/server/app/(dashboard)/dashboard/page.js.nft.json +1 -1
  19. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  20. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js +1 -1
  21. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js.nft.json +1 -1
  22. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  23. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +2 -2
  24. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js.nft.json +1 -1
  25. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  26. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js +1 -1
  27. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js.nft.json +1 -1
  28. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  29. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js +1 -1
  30. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js.nft.json +1 -1
  31. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  32. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js +1 -1
  33. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js.nft.json +1 -1
  34. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  35. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js +1 -1
  36. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js.nft.json +1 -1
  37. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  38. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  39. package/app/.next/server/app/_global-error.html +2 -2
  40. package/app/.next/server/app/_global-error.rsc +1 -1
  41. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  42. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  43. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  44. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  45. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  46. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  47. package/app/.next/server/app/_not-found/page.js +1 -1
  48. package/app/.next/server/app/_not-found/page.js.nft.json +1 -1
  49. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  50. package/app/.next/server/app/_not-found.html +1 -1
  51. package/app/.next/server/app/_not-found.rsc +3 -3
  52. package/app/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  53. package/app/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  54. package/app/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  55. package/app/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  56. package/app/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  57. package/app/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  58. package/app/.next/server/app/api/auth/login/route_client-reference-manifest.js +1 -1
  59. package/app/.next/server/app/api/auth/logout/route_client-reference-manifest.js +1 -1
  60. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route_client-reference-manifest.js +1 -1
  61. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +2 -2
  62. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js.nft.json +1 -1
  63. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route_client-reference-manifest.js +1 -1
  64. package/app/.next/server/app/api/cli-tools/claude-settings/route_client-reference-manifest.js +1 -1
  65. package/app/.next/server/app/api/cli-tools/codex-settings/route_client-reference-manifest.js +1 -1
  66. package/app/.next/server/app/api/cli-tools/droid-settings/route_client-reference-manifest.js +1 -1
  67. package/app/.next/server/app/api/cli-tools/openclaw-settings/route_client-reference-manifest.js +1 -1
  68. package/app/.next/server/app/api/cloud/auth/route_client-reference-manifest.js +1 -1
  69. package/app/.next/server/app/api/cloud/credentials/update/route_client-reference-manifest.js +1 -1
  70. package/app/.next/server/app/api/cloud/model/resolve/route_client-reference-manifest.js +1 -1
  71. package/app/.next/server/app/api/cloud/models/alias/route_client-reference-manifest.js +1 -1
  72. package/app/.next/server/app/api/combos/[id]/route_client-reference-manifest.js +1 -1
  73. package/app/.next/server/app/api/combos/route_client-reference-manifest.js +1 -1
  74. package/app/.next/server/app/api/init/route.js +1 -1
  75. package/app/.next/server/app/api/init/route.js.nft.json +1 -1
  76. package/app/.next/server/app/api/init/route_client-reference-manifest.js +1 -1
  77. package/app/.next/server/app/api/keys/[id]/route_client-reference-manifest.js +1 -1
  78. package/app/.next/server/app/api/keys/route_client-reference-manifest.js +1 -1
  79. package/app/.next/server/app/api/models/alias/route_client-reference-manifest.js +1 -1
  80. package/app/.next/server/app/api/models/route.js +1 -1
  81. package/app/.next/server/app/api/models/route.js.nft.json +1 -1
  82. package/app/.next/server/app/api/models/route_client-reference-manifest.js +1 -1
  83. package/app/.next/server/app/api/models/test/route_client-reference-manifest.js +1 -1
  84. package/app/.next/server/app/api/oauth/[provider]/[action]/route_client-reference-manifest.js +1 -1
  85. package/app/.next/server/app/api/oauth/cursor/auto-import/route_client-reference-manifest.js +1 -1
  86. package/app/.next/server/app/api/oauth/cursor/import/route_client-reference-manifest.js +1 -1
  87. package/app/.next/server/app/api/oauth/kiro/auto-import/route_client-reference-manifest.js +1 -1
  88. package/app/.next/server/app/api/oauth/kiro/import/route_client-reference-manifest.js +1 -1
  89. package/app/.next/server/app/api/oauth/kiro/social-authorize/route_client-reference-manifest.js +1 -1
  90. package/app/.next/server/app/api/oauth/kiro/social-exchange/route_client-reference-manifest.js +1 -1
  91. package/app/.next/server/app/api/pricing/route_client-reference-manifest.js +1 -1
  92. package/app/.next/server/app/api/provider-nodes/[id]/route_client-reference-manifest.js +1 -1
  93. package/app/.next/server/app/api/provider-nodes/route.js +1 -1
  94. package/app/.next/server/app/api/provider-nodes/route_client-reference-manifest.js +1 -1
  95. package/app/.next/server/app/api/provider-nodes/validate/route_client-reference-manifest.js +1 -1
  96. package/app/.next/server/app/api/providers/[id]/models/route_client-reference-manifest.js +1 -1
  97. package/app/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -1
  98. package/app/.next/server/app/api/providers/[id]/test/route_client-reference-manifest.js +1 -1
  99. package/app/.next/server/app/api/providers/[id]/test-models/route.js +1 -1
  100. package/app/.next/server/app/api/providers/[id]/test-models/route_client-reference-manifest.js +1 -1
  101. package/app/.next/server/app/api/providers/client/route_client-reference-manifest.js +1 -1
  102. package/app/.next/server/app/api/providers/route.js +1 -1
  103. package/app/.next/server/app/api/providers/route.js.nft.json +1 -1
  104. package/app/.next/server/app/api/providers/route_client-reference-manifest.js +1 -1
  105. package/app/.next/server/app/api/providers/test-batch/route_client-reference-manifest.js +1 -1
  106. package/app/.next/server/app/api/providers/validate/route.js +1 -1
  107. package/app/.next/server/app/api/providers/validate/route_client-reference-manifest.js +1 -1
  108. package/app/.next/server/app/api/settings/database/route_client-reference-manifest.js +1 -1
  109. package/app/.next/server/app/api/settings/proxy-test/route_client-reference-manifest.js +1 -1
  110. package/app/.next/server/app/api/settings/require-login/route_client-reference-manifest.js +1 -1
  111. package/app/.next/server/app/api/settings/route_client-reference-manifest.js +1 -1
  112. package/app/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  113. package/app/.next/server/app/api/tags/route_client-reference-manifest.js +1 -1
  114. package/app/.next/server/app/api/translator/console-logs/route.js +1 -0
  115. package/app/.next/server/app/api/translator/console-logs/route.js.nft.json +1 -0
  116. package/app/.next/server/app/api/translator/console-logs/route_client-reference-manifest.js +1 -0
  117. package/app/.next/server/app/api/translator/console-logs/stream/route.js +7 -0
  118. package/app/.next/server/app/api/translator/console-logs/stream/route.js.nft.json +1 -0
  119. package/app/.next/server/app/api/translator/console-logs/stream/route_client-reference-manifest.js +1 -0
  120. package/app/.next/server/app/api/translator/load/route_client-reference-manifest.js +1 -1
  121. package/app/.next/server/app/api/translator/save/route_client-reference-manifest.js +1 -1
  122. package/app/.next/server/app/api/translator/send/route_client-reference-manifest.js +1 -1
  123. package/app/.next/server/app/api/translator/translate/route_client-reference-manifest.js +1 -1
  124. package/app/.next/server/app/api/tunnel/disable/route_client-reference-manifest.js +1 -1
  125. package/app/.next/server/app/api/tunnel/enable/route_client-reference-manifest.js +1 -1
  126. package/app/.next/server/app/api/tunnel/status/route_client-reference-manifest.js +1 -1
  127. package/app/.next/server/app/api/usage/[connectionId]/route_client-reference-manifest.js +1 -1
  128. package/app/.next/server/app/api/usage/chart/route_client-reference-manifest.js +1 -1
  129. package/app/.next/server/app/api/usage/history/route_client-reference-manifest.js +1 -1
  130. package/app/.next/server/app/api/usage/providers/route.js +1 -1
  131. package/app/.next/server/app/api/usage/providers/route_client-reference-manifest.js +1 -1
  132. package/app/.next/server/app/api/usage/request-details/route_client-reference-manifest.js +1 -1
  133. package/app/.next/server/app/api/usage/request-logs/route_client-reference-manifest.js +1 -1
  134. package/app/.next/server/app/api/usage/stream/route_client-reference-manifest.js +1 -1
  135. package/app/.next/server/app/api/v1/api/chat/route_client-reference-manifest.js +1 -1
  136. package/app/.next/server/app/api/v1/chat/completions/route_client-reference-manifest.js +1 -1
  137. package/app/.next/server/app/api/v1/embeddings/route_client-reference-manifest.js +1 -1
  138. package/app/.next/server/app/api/v1/messages/count_tokens/route_client-reference-manifest.js +1 -1
  139. package/app/.next/server/app/api/v1/messages/route_client-reference-manifest.js +1 -1
  140. package/app/.next/server/app/api/v1/models/route.js +1 -1
  141. package/app/.next/server/app/api/v1/models/route_client-reference-manifest.js +1 -1
  142. package/app/.next/server/app/api/v1/responses/route_client-reference-manifest.js +1 -1
  143. package/app/.next/server/app/api/v1/route_client-reference-manifest.js +1 -1
  144. package/app/.next/server/app/api/v1beta/models/[...path]/route.js +1 -1
  145. package/app/.next/server/app/api/v1beta/models/[...path]/route_client-reference-manifest.js +1 -1
  146. package/app/.next/server/app/api/v1beta/models/route.js +1 -1
  147. package/app/.next/server/app/api/v1beta/models/route_client-reference-manifest.js +1 -1
  148. package/app/.next/server/app/api/version/route.js +1 -1
  149. package/app/.next/server/app/api/version/route_client-reference-manifest.js +1 -1
  150. package/app/.next/server/app/callback/page.js +1 -1
  151. package/app/.next/server/app/callback/page.js.nft.json +1 -1
  152. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  153. package/app/.next/server/app/callback.html +1 -1
  154. package/app/.next/server/app/callback.rsc +3 -3
  155. package/app/.next/server/app/callback.segments/_full.segment.rsc +3 -3
  156. package/app/.next/server/app/callback.segments/_head.segment.rsc +1 -1
  157. package/app/.next/server/app/callback.segments/_index.segment.rsc +3 -3
  158. package/app/.next/server/app/callback.segments/_tree.segment.rsc +2 -2
  159. package/app/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +1 -1
  160. package/app/.next/server/app/callback.segments/callback.segment.rsc +1 -1
  161. package/app/.next/server/app/dashboard/cli-tools.html +1 -1
  162. package/app/.next/server/app/dashboard/cli-tools.rsc +5 -5
  163. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +2 -2
  164. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +1 -1
  165. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  166. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  167. package/app/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +5 -5
  168. package/app/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +1 -1
  169. package/app/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +3 -3
  170. package/app/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +2 -2
  171. package/app/.next/server/app/dashboard/combos.html +1 -1
  172. package/app/.next/server/app/dashboard/combos.rsc +5 -5
  173. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +2 -2
  174. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +1 -1
  175. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  176. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  177. package/app/.next/server/app/dashboard/combos.segments/_full.segment.rsc +5 -5
  178. package/app/.next/server/app/dashboard/combos.segments/_head.segment.rsc +1 -1
  179. package/app/.next/server/app/dashboard/combos.segments/_index.segment.rsc +3 -3
  180. package/app/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +2 -2
  181. package/app/.next/server/app/dashboard/endpoint.html +1 -1
  182. package/app/.next/server/app/dashboard/endpoint.rsc +5 -5
  183. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +2 -2
  184. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +1 -1
  185. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  186. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  187. package/app/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +5 -5
  188. package/app/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +1 -1
  189. package/app/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +3 -3
  190. package/app/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +2 -2
  191. package/app/.next/server/app/dashboard/profile.html +1 -1
  192. package/app/.next/server/app/dashboard/profile.rsc +5 -5
  193. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +2 -2
  194. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +1 -1
  195. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  196. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  197. package/app/.next/server/app/dashboard/profile.segments/_full.segment.rsc +5 -5
  198. package/app/.next/server/app/dashboard/profile.segments/_head.segment.rsc +1 -1
  199. package/app/.next/server/app/dashboard/profile.segments/_index.segment.rsc +3 -3
  200. package/app/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +2 -2
  201. package/app/.next/server/app/dashboard/providers/new.html +1 -1
  202. package/app/.next/server/app/dashboard/providers/new.rsc +5 -5
  203. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +2 -2
  204. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +1 -1
  205. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  206. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  207. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  208. package/app/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +5 -5
  209. package/app/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +1 -1
  210. package/app/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +3 -3
  211. package/app/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +2 -2
  212. package/app/.next/server/app/dashboard/providers.html +1 -1
  213. package/app/.next/server/app/dashboard/providers.rsc +5 -5
  214. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +2 -2
  215. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  216. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  217. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  218. package/app/.next/server/app/dashboard/providers.segments/_full.segment.rsc +5 -5
  219. package/app/.next/server/app/dashboard/providers.segments/_head.segment.rsc +1 -1
  220. package/app/.next/server/app/dashboard/providers.segments/_index.segment.rsc +3 -3
  221. package/app/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +2 -2
  222. package/app/.next/server/app/dashboard/settings/pricing/page.js +1 -1
  223. package/app/.next/server/app/dashboard/settings/pricing/page.js.nft.json +1 -1
  224. package/app/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  225. package/app/.next/server/app/dashboard/settings/pricing.html +1 -1
  226. package/app/.next/server/app/dashboard/settings/pricing.rsc +3 -3
  227. package/app/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +3 -3
  228. package/app/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +1 -1
  229. package/app/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +3 -3
  230. package/app/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +2 -2
  231. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +1 -1
  232. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +1 -1
  233. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +1 -1
  234. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +1 -1
  235. package/app/.next/server/app/dashboard/translator.html +1 -1
  236. package/app/.next/server/app/dashboard/translator.rsc +5 -5
  237. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +2 -2
  238. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +1 -1
  239. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  240. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  241. package/app/.next/server/app/dashboard/translator.segments/_full.segment.rsc +5 -5
  242. package/app/.next/server/app/dashboard/translator.segments/_head.segment.rsc +1 -1
  243. package/app/.next/server/app/dashboard/translator.segments/_index.segment.rsc +3 -3
  244. package/app/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +2 -2
  245. package/app/.next/server/app/dashboard/usage.html +1 -1
  246. package/app/.next/server/app/dashboard/usage.rsc +5 -5
  247. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +2 -2
  248. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +1 -1
  249. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  250. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  251. package/app/.next/server/app/dashboard/usage.segments/_full.segment.rsc +5 -5
  252. package/app/.next/server/app/dashboard/usage.segments/_head.segment.rsc +1 -1
  253. package/app/.next/server/app/dashboard/usage.segments/_index.segment.rsc +3 -3
  254. package/app/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +2 -2
  255. package/app/.next/server/app/dashboard.html +1 -1
  256. package/app/.next/server/app/dashboard.rsc +5 -5
  257. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +2 -2
  258. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  259. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  260. package/app/.next/server/app/dashboard.segments/_full.segment.rsc +5 -5
  261. package/app/.next/server/app/dashboard.segments/_head.segment.rsc +1 -1
  262. package/app/.next/server/app/dashboard.segments/_index.segment.rsc +3 -3
  263. package/app/.next/server/app/dashboard.segments/_tree.segment.rsc +2 -2
  264. package/app/.next/server/app/index.html +1 -1
  265. package/app/.next/server/app/index.rsc +3 -3
  266. package/app/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  267. package/app/.next/server/app/index.segments/_full.segment.rsc +3 -3
  268. package/app/.next/server/app/index.segments/_head.segment.rsc +1 -1
  269. package/app/.next/server/app/index.segments/_index.segment.rsc +3 -3
  270. package/app/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  271. package/app/.next/server/app/landing/page.js +1 -1
  272. package/app/.next/server/app/landing/page.js.nft.json +1 -1
  273. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  274. package/app/.next/server/app/landing.html +1 -1
  275. package/app/.next/server/app/landing.rsc +3 -3
  276. package/app/.next/server/app/landing.segments/_full.segment.rsc +3 -3
  277. package/app/.next/server/app/landing.segments/_head.segment.rsc +1 -1
  278. package/app/.next/server/app/landing.segments/_index.segment.rsc +3 -3
  279. package/app/.next/server/app/landing.segments/_tree.segment.rsc +2 -2
  280. package/app/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +1 -1
  281. package/app/.next/server/app/landing.segments/landing.segment.rsc +1 -1
  282. package/app/.next/server/app/login/page.js +1 -1
  283. package/app/.next/server/app/login/page.js.nft.json +1 -1
  284. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  285. package/app/.next/server/app/login.html +1 -1
  286. package/app/.next/server/app/login.rsc +4 -4
  287. package/app/.next/server/app/login.segments/_full.segment.rsc +4 -4
  288. package/app/.next/server/app/login.segments/_head.segment.rsc +1 -1
  289. package/app/.next/server/app/login.segments/_index.segment.rsc +3 -3
  290. package/app/.next/server/app/login.segments/_tree.segment.rsc +2 -2
  291. package/app/.next/server/app/login.segments/login/__PAGE__.segment.rsc +2 -2
  292. package/app/.next/server/app/login.segments/login.segment.rsc +1 -1
  293. package/app/.next/server/app/manifest.webmanifest/route_client-reference-manifest.js +1 -1
  294. package/app/.next/server/app/page.js +1 -1
  295. package/app/.next/server/app/page.js.nft.json +1 -1
  296. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  297. package/app/.next/server/app-paths-manifest.json +37 -34
  298. package/app/.next/server/chunks/1238.js +5 -5
  299. package/app/.next/server/chunks/1424.js +1 -1
  300. package/app/.next/server/chunks/2280.js +1 -1
  301. package/app/.next/server/chunks/412.js +2 -2
  302. package/app/.next/server/chunks/4989.js +1 -1
  303. package/app/.next/server/chunks/{6186.js → 6182.js} +3 -3
  304. package/app/.next/server/chunks/8756.js +1 -1
  305. package/app/.next/server/chunks/8895.js +2 -2
  306. package/app/.next/server/functions-config-manifest.json +15 -1
  307. package/app/.next/server/middleware.js +15 -0
  308. package/app/.next/server/pages/404.html +1 -1
  309. package/app/.next/server/pages/500.html +2 -2
  310. package/app/.next/server/server-reference-manifest.js +1 -1
  311. package/app/.next/server/server-reference-manifest.json +1 -1
  312. package/app/.next/static/WVNl0xvRB6AUPlWoux5nO/_buildManifest.js +1 -0
  313. package/app/.next/static/chunks/{5497-73785ad32a2265a2.js → 5497-ddcd9a9fbd35c26e.js} +2 -2
  314. package/app/.next/static/chunks/{8729-6581baa52870d9f9.js → 8729-cbaa00bf4b5e675b.js} +1 -1
  315. package/app/.next/static/chunks/app/(dashboard)/dashboard/console-log/page-f901161d567d6bc7.js +1 -0
  316. package/app/.next/static/chunks/app/_global-error/page-ea22cc6d0e23ff6d.js +1 -0
  317. package/app/.next/static/chunks/app/api/auth/login/route-ea22cc6d0e23ff6d.js +1 -0
  318. package/app/.next/static/chunks/app/api/auth/logout/route-ea22cc6d0e23ff6d.js +1 -0
  319. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-ea22cc6d0e23ff6d.js +1 -0
  320. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-ea22cc6d0e23ff6d.js +1 -0
  321. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-ea22cc6d0e23ff6d.js +1 -0
  322. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-ea22cc6d0e23ff6d.js +1 -0
  323. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-ea22cc6d0e23ff6d.js +1 -0
  324. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-ea22cc6d0e23ff6d.js +1 -0
  325. package/app/.next/static/chunks/app/api/cloud/auth/route-ea22cc6d0e23ff6d.js +1 -0
  326. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-ea22cc6d0e23ff6d.js +1 -0
  327. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-ea22cc6d0e23ff6d.js +1 -0
  328. package/app/.next/static/chunks/app/api/cloud/models/alias/route-ea22cc6d0e23ff6d.js +1 -0
  329. package/app/.next/static/chunks/app/api/combos/[id]/route-ea22cc6d0e23ff6d.js +1 -0
  330. package/app/.next/static/chunks/app/api/combos/route-ea22cc6d0e23ff6d.js +1 -0
  331. package/app/.next/static/chunks/app/api/init/route-ea22cc6d0e23ff6d.js +1 -0
  332. package/app/.next/static/chunks/app/api/keys/[id]/route-ea22cc6d0e23ff6d.js +1 -0
  333. package/app/.next/static/chunks/app/api/keys/route-ea22cc6d0e23ff6d.js +1 -0
  334. package/app/.next/static/chunks/app/api/models/alias/route-ea22cc6d0e23ff6d.js +1 -0
  335. package/app/.next/static/chunks/app/api/models/route-ea22cc6d0e23ff6d.js +1 -0
  336. package/app/.next/static/chunks/app/api/models/test/route-ea22cc6d0e23ff6d.js +1 -0
  337. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-ea22cc6d0e23ff6d.js +1 -0
  338. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-ea22cc6d0e23ff6d.js +1 -0
  339. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-ea22cc6d0e23ff6d.js +1 -0
  340. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-ea22cc6d0e23ff6d.js +1 -0
  341. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-ea22cc6d0e23ff6d.js +1 -0
  342. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-ea22cc6d0e23ff6d.js +1 -0
  343. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-ea22cc6d0e23ff6d.js +1 -0
  344. package/app/.next/static/chunks/app/api/pricing/route-ea22cc6d0e23ff6d.js +1 -0
  345. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-ea22cc6d0e23ff6d.js +1 -0
  346. package/app/.next/static/chunks/app/api/provider-nodes/route-ea22cc6d0e23ff6d.js +1 -0
  347. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-ea22cc6d0e23ff6d.js +1 -0
  348. package/app/.next/static/chunks/app/api/providers/[id]/models/route-ea22cc6d0e23ff6d.js +1 -0
  349. package/app/.next/static/chunks/app/api/providers/[id]/route-ea22cc6d0e23ff6d.js +1 -0
  350. package/app/.next/static/chunks/app/api/providers/[id]/test/route-ea22cc6d0e23ff6d.js +1 -0
  351. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-ea22cc6d0e23ff6d.js +1 -0
  352. package/app/.next/static/chunks/app/api/providers/client/route-ea22cc6d0e23ff6d.js +1 -0
  353. package/app/.next/static/chunks/app/api/providers/route-ea22cc6d0e23ff6d.js +1 -0
  354. package/app/.next/static/chunks/app/api/providers/test-batch/route-ea22cc6d0e23ff6d.js +1 -0
  355. package/app/.next/static/chunks/app/api/providers/validate/route-ea22cc6d0e23ff6d.js +1 -0
  356. package/app/.next/static/chunks/app/api/settings/database/route-ea22cc6d0e23ff6d.js +1 -0
  357. package/app/.next/static/chunks/app/api/settings/proxy-test/route-ea22cc6d0e23ff6d.js +1 -0
  358. package/app/.next/static/chunks/app/api/settings/require-login/route-ea22cc6d0e23ff6d.js +1 -0
  359. package/app/.next/static/chunks/app/api/settings/route-ea22cc6d0e23ff6d.js +1 -0
  360. package/app/.next/static/chunks/app/api/shutdown/route-ea22cc6d0e23ff6d.js +1 -0
  361. package/app/.next/static/chunks/app/api/tags/route-ea22cc6d0e23ff6d.js +1 -0
  362. package/app/.next/static/chunks/app/api/translator/console-logs/route-ea22cc6d0e23ff6d.js +1 -0
  363. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-ea22cc6d0e23ff6d.js +1 -0
  364. package/app/.next/static/chunks/app/api/translator/load/route-ea22cc6d0e23ff6d.js +1 -0
  365. package/app/.next/static/chunks/app/api/translator/save/route-ea22cc6d0e23ff6d.js +1 -0
  366. package/app/.next/static/chunks/app/api/translator/send/route-ea22cc6d0e23ff6d.js +1 -0
  367. package/app/.next/static/chunks/app/api/translator/translate/route-ea22cc6d0e23ff6d.js +1 -0
  368. package/app/.next/static/chunks/app/api/tunnel/disable/route-ea22cc6d0e23ff6d.js +1 -0
  369. package/app/.next/static/chunks/app/api/tunnel/enable/route-ea22cc6d0e23ff6d.js +1 -0
  370. package/app/.next/static/chunks/app/api/tunnel/status/route-ea22cc6d0e23ff6d.js +1 -0
  371. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-ea22cc6d0e23ff6d.js +1 -0
  372. package/app/.next/static/chunks/app/api/usage/chart/route-ea22cc6d0e23ff6d.js +1 -0
  373. package/app/.next/static/chunks/app/api/usage/history/route-ea22cc6d0e23ff6d.js +1 -0
  374. package/app/.next/static/chunks/app/api/usage/providers/route-ea22cc6d0e23ff6d.js +1 -0
  375. package/app/.next/static/chunks/app/api/usage/request-details/route-ea22cc6d0e23ff6d.js +1 -0
  376. package/app/.next/static/chunks/app/api/usage/request-logs/route-ea22cc6d0e23ff6d.js +1 -0
  377. package/app/.next/static/chunks/app/api/usage/stream/route-ea22cc6d0e23ff6d.js +1 -0
  378. package/app/.next/static/chunks/app/api/v1/api/chat/route-ea22cc6d0e23ff6d.js +1 -0
  379. package/app/.next/static/chunks/app/api/v1/chat/completions/route-ea22cc6d0e23ff6d.js +1 -0
  380. package/app/.next/static/chunks/app/api/v1/embeddings/route-ea22cc6d0e23ff6d.js +1 -0
  381. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-ea22cc6d0e23ff6d.js +1 -0
  382. package/app/.next/static/chunks/app/api/v1/messages/route-ea22cc6d0e23ff6d.js +1 -0
  383. package/app/.next/static/chunks/app/api/v1/models/route-ea22cc6d0e23ff6d.js +1 -0
  384. package/app/.next/static/chunks/app/api/v1/responses/route-ea22cc6d0e23ff6d.js +1 -0
  385. package/app/.next/static/chunks/app/api/v1/route-ea22cc6d0e23ff6d.js +1 -0
  386. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-ea22cc6d0e23ff6d.js +1 -0
  387. package/app/.next/static/chunks/app/api/v1beta/models/route-ea22cc6d0e23ff6d.js +1 -0
  388. package/app/.next/static/chunks/app/api/version/route-ea22cc6d0e23ff6d.js +1 -0
  389. package/app/.next/static/chunks/app/manifest.webmanifest/route-ea22cc6d0e23ff6d.js +1 -0
  390. package/app/.next/static/chunks/app/page-ea22cc6d0e23ff6d.js +1 -0
  391. package/app/.next/static/chunks/{main-d7c65caed43cf6c9.js → main-aab9e1b069a77e0f.js} +3 -3
  392. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-ea22cc6d0e23ff6d.js +1 -0
  393. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-ea22cc6d0e23ff6d.js +1 -0
  394. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-ea22cc6d0e23ff6d.js +1 -0
  395. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-ea22cc6d0e23ff6d.js +1 -0
  396. package/app/.next/static/css/3995d76bba6fb14a.css +3 -0
  397. package/app/package.json +1 -1
  398. package/package.json +1 -1
  399. package/app/.next/server/chunks/4801.js +0 -1
  400. package/app/.next/static/U0a4hjt9mumOZwgo88ICN/_buildManifest.js +0 -1
  401. package/app/.next/static/chunks/app/_global-error/page-4ee6f1166dedacaf.js +0 -1
  402. package/app/.next/static/chunks/app/api/auth/login/route-4ee6f1166dedacaf.js +0 -1
  403. package/app/.next/static/chunks/app/api/auth/logout/route-4ee6f1166dedacaf.js +0 -1
  404. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-4ee6f1166dedacaf.js +0 -1
  405. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-4ee6f1166dedacaf.js +0 -1
  406. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-4ee6f1166dedacaf.js +0 -1
  407. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-4ee6f1166dedacaf.js +0 -1
  408. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-4ee6f1166dedacaf.js +0 -1
  409. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-4ee6f1166dedacaf.js +0 -1
  410. package/app/.next/static/chunks/app/api/cloud/auth/route-4ee6f1166dedacaf.js +0 -1
  411. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-4ee6f1166dedacaf.js +0 -1
  412. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-4ee6f1166dedacaf.js +0 -1
  413. package/app/.next/static/chunks/app/api/cloud/models/alias/route-4ee6f1166dedacaf.js +0 -1
  414. package/app/.next/static/chunks/app/api/combos/[id]/route-4ee6f1166dedacaf.js +0 -1
  415. package/app/.next/static/chunks/app/api/combos/route-4ee6f1166dedacaf.js +0 -1
  416. package/app/.next/static/chunks/app/api/init/route-4ee6f1166dedacaf.js +0 -1
  417. package/app/.next/static/chunks/app/api/keys/[id]/route-4ee6f1166dedacaf.js +0 -1
  418. package/app/.next/static/chunks/app/api/keys/route-4ee6f1166dedacaf.js +0 -1
  419. package/app/.next/static/chunks/app/api/models/alias/route-4ee6f1166dedacaf.js +0 -1
  420. package/app/.next/static/chunks/app/api/models/route-4ee6f1166dedacaf.js +0 -1
  421. package/app/.next/static/chunks/app/api/models/test/route-4ee6f1166dedacaf.js +0 -1
  422. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-4ee6f1166dedacaf.js +0 -1
  423. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-4ee6f1166dedacaf.js +0 -1
  424. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-4ee6f1166dedacaf.js +0 -1
  425. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-4ee6f1166dedacaf.js +0 -1
  426. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-4ee6f1166dedacaf.js +0 -1
  427. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-4ee6f1166dedacaf.js +0 -1
  428. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-4ee6f1166dedacaf.js +0 -1
  429. package/app/.next/static/chunks/app/api/pricing/route-4ee6f1166dedacaf.js +0 -1
  430. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-4ee6f1166dedacaf.js +0 -1
  431. package/app/.next/static/chunks/app/api/provider-nodes/route-4ee6f1166dedacaf.js +0 -1
  432. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-4ee6f1166dedacaf.js +0 -1
  433. package/app/.next/static/chunks/app/api/providers/[id]/models/route-4ee6f1166dedacaf.js +0 -1
  434. package/app/.next/static/chunks/app/api/providers/[id]/route-4ee6f1166dedacaf.js +0 -1
  435. package/app/.next/static/chunks/app/api/providers/[id]/test/route-4ee6f1166dedacaf.js +0 -1
  436. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-4ee6f1166dedacaf.js +0 -1
  437. package/app/.next/static/chunks/app/api/providers/client/route-4ee6f1166dedacaf.js +0 -1
  438. package/app/.next/static/chunks/app/api/providers/route-4ee6f1166dedacaf.js +0 -1
  439. package/app/.next/static/chunks/app/api/providers/test-batch/route-4ee6f1166dedacaf.js +0 -1
  440. package/app/.next/static/chunks/app/api/providers/validate/route-4ee6f1166dedacaf.js +0 -1
  441. package/app/.next/static/chunks/app/api/settings/database/route-4ee6f1166dedacaf.js +0 -1
  442. package/app/.next/static/chunks/app/api/settings/proxy-test/route-4ee6f1166dedacaf.js +0 -1
  443. package/app/.next/static/chunks/app/api/settings/require-login/route-4ee6f1166dedacaf.js +0 -1
  444. package/app/.next/static/chunks/app/api/settings/route-4ee6f1166dedacaf.js +0 -1
  445. package/app/.next/static/chunks/app/api/shutdown/route-4ee6f1166dedacaf.js +0 -1
  446. package/app/.next/static/chunks/app/api/tags/route-4ee6f1166dedacaf.js +0 -1
  447. package/app/.next/static/chunks/app/api/translator/load/route-4ee6f1166dedacaf.js +0 -1
  448. package/app/.next/static/chunks/app/api/translator/save/route-4ee6f1166dedacaf.js +0 -1
  449. package/app/.next/static/chunks/app/api/translator/send/route-4ee6f1166dedacaf.js +0 -1
  450. package/app/.next/static/chunks/app/api/translator/translate/route-4ee6f1166dedacaf.js +0 -1
  451. package/app/.next/static/chunks/app/api/tunnel/disable/route-4ee6f1166dedacaf.js +0 -1
  452. package/app/.next/static/chunks/app/api/tunnel/enable/route-4ee6f1166dedacaf.js +0 -1
  453. package/app/.next/static/chunks/app/api/tunnel/status/route-4ee6f1166dedacaf.js +0 -1
  454. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-4ee6f1166dedacaf.js +0 -1
  455. package/app/.next/static/chunks/app/api/usage/chart/route-4ee6f1166dedacaf.js +0 -1
  456. package/app/.next/static/chunks/app/api/usage/history/route-4ee6f1166dedacaf.js +0 -1
  457. package/app/.next/static/chunks/app/api/usage/providers/route-4ee6f1166dedacaf.js +0 -1
  458. package/app/.next/static/chunks/app/api/usage/request-details/route-4ee6f1166dedacaf.js +0 -1
  459. package/app/.next/static/chunks/app/api/usage/request-logs/route-4ee6f1166dedacaf.js +0 -1
  460. package/app/.next/static/chunks/app/api/usage/stream/route-4ee6f1166dedacaf.js +0 -1
  461. package/app/.next/static/chunks/app/api/v1/api/chat/route-4ee6f1166dedacaf.js +0 -1
  462. package/app/.next/static/chunks/app/api/v1/chat/completions/route-4ee6f1166dedacaf.js +0 -1
  463. package/app/.next/static/chunks/app/api/v1/embeddings/route-4ee6f1166dedacaf.js +0 -1
  464. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-4ee6f1166dedacaf.js +0 -1
  465. package/app/.next/static/chunks/app/api/v1/messages/route-4ee6f1166dedacaf.js +0 -1
  466. package/app/.next/static/chunks/app/api/v1/models/route-4ee6f1166dedacaf.js +0 -1
  467. package/app/.next/static/chunks/app/api/v1/responses/route-4ee6f1166dedacaf.js +0 -1
  468. package/app/.next/static/chunks/app/api/v1/route-4ee6f1166dedacaf.js +0 -1
  469. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-4ee6f1166dedacaf.js +0 -1
  470. package/app/.next/static/chunks/app/api/v1beta/models/route-4ee6f1166dedacaf.js +0 -1
  471. package/app/.next/static/chunks/app/api/version/route-4ee6f1166dedacaf.js +0 -1
  472. package/app/.next/static/chunks/app/manifest.webmanifest/route-4ee6f1166dedacaf.js +0 -1
  473. package/app/.next/static/chunks/app/page-4ee6f1166dedacaf.js +0 -1
  474. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-4ee6f1166dedacaf.js +0 -1
  475. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-4ee6f1166dedacaf.js +0 -1
  476. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-4ee6f1166dedacaf.js +0 -1
  477. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-4ee6f1166dedacaf.js +0 -1
  478. package/app/.next/static/css/6f5522f8077f0304.css +0 -3
  479. /package/app/.next/static/{U0a4hjt9mumOZwgo88ICN → WVNl0xvRB6AUPlWoux5nO}/_ssgManifest.js +0 -0
@@ -1,5 +1,5 @@
1
- exports.id=6186,exports.ids=[6186],exports.modules={9631:(a,b,c)=>{"use strict";let d=c(29021),e=c(55511),{exec:f}=c(79646),{execWithPassword:g}=c(66936),h="win32"===process.platform,i="darwin"===process.platform,j="/usr/local/share/ca-certificates";function k(a){let b=d.readFileSync(a,"utf-8"),c=Buffer.from(b.replace(/-----[^-]+-----/g,"").replace(/\s/g,""),"base64");return e.createHash("sha1").update(c).digest("hex").toUpperCase().match(/.{2}/g).join(":")}async function l(a){var b;let c;return h?new Promise(a=>{f("certutil -store Root daily-cloudcode-pa.googleapis.com",b=>{a(!b)})}):i?(b=a,new Promise(a=>{try{let c=k(b);f(`security find-certificate -a -Z /Library/Keychains/System.keychain | grep -i "${c}"`,b=>{a(!b)})}catch{a(!1)}})):(c=`${j}/9router-mitm.crt`,Promise.resolve(d.existsSync(c)))}async function m(a,b){let c=`security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain "${b}"`;try{await g(c,a),console.log(`✅ Installed certificate to system keychain: ${b}`)}catch(a){throw Error(a.message?.includes("canceled")?"User canceled authorization":"Certificate install failed")}}async function n(a){let b=a.replace(/'/g,"''"),c=`Start-Process certutil -ArgumentList '-addstore','Root','${b}' -Verb RunAs -Wait -WindowStyle Hidden`;return new Promise((a,b)=>{f(`powershell -NonInteractive -WindowStyle Hidden -Command "${c}"`,{windowsHide:!0},c=>{c?b(Error(`Failed to install certificate: ${c.message}`)):(console.log("✅ Installed certificate to Windows Root store"),a())})})}async function o(a,b){let c=k(b).replace(/:/g,""),d=`security delete-certificate -Z "${c}" /Library/Keychains/System.keychain`;try{await g(d,a),console.log("✅ Uninstalled certificate from system keychain")}catch(a){throw Error("Failed to uninstall certificate")}}async function p(){return new Promise((a,b)=>{f("powershell -NonInteractive -WindowStyle Hidden -Command \"Start-Process certutil -ArgumentList '-delstore','Root','daily-cloudcode-pa.googleapis.com' -Verb RunAs -Wait -WindowStyle Hidden\"",{windowsHide:!0},c=>{c?b(Error(`Failed to uninstall certificate: ${c.message}`)):(console.log("✅ Uninstalled certificate from Windows Root store"),a())})})}async function q(a,b){let c=`${j}/9router-mitm.crt`,d=`cp "${b}" "${c}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(d,a),console.log("✅ Installed certificate to Linux trust store")}catch(a){throw Error("Certificate install failed")}}async function r(a){let b=`${j}/9router-mitm.crt`,c=`rm -f "${b}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(c,a),console.log("✅ Uninstalled certificate from Linux trust store")}catch(a){throw Error("Failed to uninstall certificate")}}a.exports={installCert:async function a(a,b){if(!d.existsSync(b))throw Error(`Certificate file not found: ${b}`);await l(b)?console.log("✅ Certificate already installed"):h?await n(b):i?await m(a,b):await q(a,b)},uninstallCert:async function a(a,b){await l(b)?h?await p():i?await o(a,b):await r(a):console.log("Certificate not found in system store")},checkCertInstalled:l}},26033:(a,b,c)=>{"use strict";let d=c(33873),e=c(29021),{MITM_DIR:f}=c(82193),g="daily-cloudcode-pa.googleapis.com";a.exports={generateCert:async function(){let a=d.join(f,"server.key"),b=d.join(f,"server.crt");if(e.existsSync(a)&&e.existsSync(b))return console.log("✅ SSL certificate already exists"),{key:a,cert:b};e.existsSync(f)||e.mkdirSync(f,{recursive:!0});let h=c(12044),i=[{name:"commonName",value:g}],j=new Date;j.setFullYear(j.getFullYear()+1);let k=await h.generate(i,{keySize:2048,algorithm:"sha256",notAfterDate:j,extensions:[{name:"subjectAltName",altNames:[{type:2,value:g}]}]});return e.writeFileSync(a,k.private),e.writeFileSync(b,k.cert),console.log(`✅ Generated SSL certificate for ${g}`),{key:a,cert:b}}}},66936:(a,b,c)=>{"use strict";let{exec:d,spawn:e}=c(79646),f=c(29021),g=c(33873),h=c(21820),i=["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com"],j="win32"===process.platform,k="darwin"===process.platform,l=j?g.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"):"/etc/hosts";function m(a,b){return new Promise((c,d)=>{let f=e("sudo",["-S","sh","-c",a],{stdio:["pipe","pipe","pipe"]}),g="",h="";f.stdout.on("data",a=>{g+=a}),f.stderr.on("data",a=>{h+=a}),f.on("close",a=>{0===a?c(g):d(Error(h||`Exit code ${a}`))}),f.stdin.write(`${b}
2
- `),f.stdin.end()})}function n(a=null){try{let b=f.readFileSync(l,"utf8");if(a)return b.includes(a);return i.every(a=>b.includes(a))}catch{return!1}}a.exports={addDNSEntry:async function(a){let b=i.filter(a=>!n(a));if(0===b.length)return void console.log("DNS entries for all target hosts already exist");let c=b.map(a=>`127.0.0.1 ${a}`).join("\n");try{if(j){let a=l.replace(/'/g,"''"),c=b.map(b=>`$hc = Get-Content -Path '${a}' -Raw -ErrorAction SilentlyContinue; if ($hc -notmatch '${b}') { Add-Content -Path '${a}' -Value '127.0.0.1 ${b}' -Encoding UTF8 }`).join("; "),e=`${c}; ipconfig /flushdns | Out-Null`;await new Promise((a,b)=>{let c=e.replace(/"/g,'\\"');d(`powershell -NonInteractive -WindowStyle Hidden -Command "Start-Process powershell -ArgumentList '-NonInteractive -WindowStyle Hidden -Command \\"${c}\\"' -Verb RunAs -Wait"`,{windowsHide:!0},c=>{c?b(Error(`Failed to add DNS: ${c.message}`)):a()})})}else await m(`echo "${c}" >> ${l}`,a);j||(k?await m("dscacheutil -flushcache && killall -HUP mDNSResponder",a):await m("resolvectl flush-caches 2>/dev/null || true",a)),console.log(`✅ Added DNS entries: ${b.join(", ")}`)}catch(a){throw Error(a.message?.includes("incorrect password")?"Wrong sudo password":"Failed to add DNS entry")}},removeDNSEntry:async function(a){let b=i.filter(a=>n(a));if(0===b.length)return void console.log("DNS entries for target hosts do not exist");try{if(j){let a=f.readFileSync(l,"utf8"),b=a.split(/\r?\n/).filter(a=>!i.some(b=>a.includes(b))).join("\r\n");if(!b.trim()&&a.trim())throw Error("Filtered hosts content is empty, aborting to prevent data loss");let c=g.join(h.tmpdir(),"hosts_filtered.tmp");f.writeFileSync(c,b,"utf8");let e=c.replace(/'/g,"''"),j=l.replace(/'/g,"''"),k=`Copy-Item -Path '${e}' -Destination '${j}' -Force; ipconfig /flushdns | Out-Null; Remove-Item '${e}' -ErrorAction SilentlyContinue`;await new Promise((a,b)=>{let e=k.replace(/"/g,'\\"');d(`powershell -NonInteractive -WindowStyle Hidden -Command "Start-Process powershell -ArgumentList '-NonInteractive -WindowStyle Hidden -Command \\"${e}\\"' -Verb RunAs -Wait"`,{windowsHide:!0},d=>{try{f.unlinkSync(c)}catch{}d?b(Error(`Failed to remove DNS entry: ${d.message}`)):a()})})}else for(let c of b){let b=k?`sed -i '' '/${c}/d' ${l}`:`sed -i '/${c}/d' ${l}`;await m(b,a)}j||(k?await m("dscacheutil -flushcache && killall -HUP mDNSResponder",a):await m("resolvectl flush-caches 2>/dev/null || true",a)),console.log(`✅ Removed DNS entries for ${b.join(", ")}`)}catch(a){throw Error(a.message?.includes("incorrect password")?"Wrong sudo password":"Failed to remove DNS entry")}},execWithPassword:m,checkDNSEntry:n}},78335:()=>{},82193:(a,b,c)=>{"use strict";let d=c(33873),e=c(21820),f=process.env.DATA_DIR?process.env.DATA_DIR:"win32"===process.platform?d.join(process.env.APPDATA||d.join(e.homedir(),"AppData","Roaming"),"9router"):d.join(e.homedir(),".9router"),g=d.join(f,"mitm");a.exports={DATA_DIR:f,MITM_DIR:g}},96182:(a,b,c)=>{"use strict";let{exec:d,spawn:e,execSync:f}=c(79646),g=c(33873),h=c(29021),i=c(21820),j=c(91645),k=c(55591),l=c(55511),{addDNSEntry:m,removeDNSEntry:n,checkDNSEntry:o}=c(66936),p="win32"===process.platform,{generateCert:q}=c(26033),{installCert:r}=c(9631),{MITM_DIR:s}=c(82193),t=g.join(s,".mitm.pid"),u=function(){if(process.env.MITM_SERVER_PATH)return process.env.MITM_SERVER_PATH;let a=g.join(__dirname,"server.js");if(h.existsSync(a))return a;let b=g.join(process.cwd(),"src","mitm","server.js");if(h.existsSync(b))return b;let c=g.join(process.cwd(),"..","src","mitm","server.js");return h.existsSync(c)?c:b}(),v="aes-256-gcm",w="9router-mitm-pwd",x=null,y=null;function z(a){globalThis.__mitmSudoPassword=a}function A(a){try{return process.kill(a,0),!0}catch(a){return"EACCES"===a.code}}function B(a,b=!1){if(p)d(`taskkill ${b?"/F ":""}/PID ${a}`,()=>{});else{let c=b?"SIGKILL":"SIGTERM";d(`pkill -${c} -P ${a} 2>/dev/null; kill -${c} ${a} 2>/dev/null`,()=>{})}}function C(){try{let{machineIdSync:a}=c(19713),b=a();return l.createHash("sha256").update(b+w).digest()}catch{return l.createHash("sha256").update(w).digest()}}let D=null,E=null;async function F(a,b){if(!E)return void console.log("[MITM] DB hooks not initialized, skipping save");try{let c,d,e,f,g,h={mitmEnabled:a};b&&(c=C(),d=l.randomBytes(12),e=l.createCipheriv(v,c,d),f=Buffer.concat([e.update(b,"utf8"),e.final()]),g=e.getAuthTag(),h.mitmSudoEncrypted=`${d.toString("hex")}:${g.toString("hex")}:${f.toString("hex")}`),await E(h)}catch(a){console.log("[MITM] Failed to save settings:",a.message)}}async function G(a){if(x&&!x.killed){try{x.kill("SIGKILL")}catch{}x=null,y=null}try{if(h.existsSync(t)){let a=parseInt(h.readFileSync(t,"utf-8").trim(),10);a&&A(a)&&(B(a,!0),await new Promise(a=>setTimeout(a,500))),h.unlinkSync(t)}}catch{}if(!p&&u)try{let b=u.replace(/'/g,"'\\''");if(a){let{execWithPassword:d}=c(66936);await d(`pkill -SIGKILL -f "${b}" 2>/dev/null || true`,a).catch(()=>{})}else d(`pkill -SIGKILL -f "${b}" 2>/dev/null || true`,()=>{});await new Promise(a=>setTimeout(a,500))}catch{}}a.exports={getMitmStatus:async function(){let a=null!==x&&!x.killed,b=y;if(!a)try{if(h.existsSync(t)){let c=parseInt(h.readFileSync(t,"utf-8").trim(),10);c&&A(c)?(a=!0,b=c):h.unlinkSync(t)}}catch{}return{running:a,pid:b,dnsConfigured:o(),certExists:h.existsSync(g.join(s,"server.crt"))}},startMitm:async function(a,b){if(!x||x.killed)try{if(h.existsSync(t)){let a=parseInt(h.readFileSync(t,"utf-8").trim(),10);if(a&&A(a))return y=a,console.log(`[MITM] Reusing existing process PID ${a}`),await F(!0,b),b&&z(b),{running:!0,pid:a};h.unlinkSync(t)}}catch{}if(x&&!x.killed)throw Error("MITM proxy is already running");if(await G(b),!p){let a=await new Promise(a=>{let b=j.createServer();b.once("error",b=>{"EADDRINUSE"===b.code?a("in-use"):a("no-permission")}),b.once("listening",()=>{b.close(()=>a("free"))}),b.listen(443,"127.0.0.1")});if("in-use"===a||"no-permission"===a){let a=await new Promise(a=>{p?d('powershell -NonInteractive -WindowStyle Hidden -Command "$c = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1; if ($c) { $c.OwningProcess } else { 0 }"',{windowsHide:!0},(b,c)=>{if(b)return a(null);let e=parseInt(c.trim(),10);if(!e||e<=4)return a(null);d(`tasklist /FI "PID eq ${e}" /FO CSV /NH`,{windowsHide:!0},(b,c)=>{let d=c?.match(/"([^"]+)"/);a({pid:e,name:d?d[1]:"unknown"})})}):d('ps aux | grep "[s]erver.js"',(b,c)=>{if(!c?.trim())return a(null);for(let b of c.split("\n")){let c=parseInt(b.trim().split(/\s+/)[1],10);if(!isNaN(c))return a({pid:c,name:"node"})}a(null)})});if(a&&"node"===a.name){console.log(`[MITM] Killing orphan node process on port 443 (PID ${a.pid})...`);try{let{execWithPassword:d}=c(66936);await d(`kill -9 ${a.pid}`,b),await new Promise(a=>setTimeout(a,800))}catch{}}else if(a){let b=a.name.includes("/")?a.name.split("/").filter(Boolean).pop():a.name;throw Error(`Port 443 is already in use by "${b}" (PID ${a.pid}). Stop that process first, then retry.`)}}}let l=g.join(s,"server.crt");if(h.existsSync(l)||(console.log("Generating SSL certificate..."),await q()),console.log("Starting MITM server..."),p){let b=g.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"),c=g.join(i.tmpdir(),`mitm_ready_${Date.now()}.flag`),d=l.replace(/'/g,"''"),f=b.replace(/'/g,"''"),j=process.execPath.replace(/'/g,"''"),k=u.replace(/'/g,"''"),m=c.replace(/'/g,"''"),n=["# 0. Kill any orphan node process on port 443\n$conn = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1\nif ($conn -and $conn.OwningProcess -gt 4) { Stop-Process -Id $conn.OwningProcess -Force -ErrorAction SilentlyContinue }\nStart-Sleep -Milliseconds 500\n\n# 1. Install SSL cert to Windows Root store (always run to ensure trust)",`& certutil -addstore Root '${d}' | Out-Null`,"\n# 2. Add DNS entries to hosts file",["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com"].map(a=>`$hc = Get-Content -Path '${f}' -Raw -ErrorAction SilentlyContinue
1
+ "use strict";exports.id=6182,exports.ids=[6182],exports.modules={9631:(a,b,c)=>{let d=c(29021),e=c(55511),{exec:f}=c(79646),{execWithPassword:g}=c(66936),h="win32"===process.platform,i="darwin"===process.platform,j="/usr/local/share/ca-certificates";function k(a){let b=d.readFileSync(a,"utf-8"),c=Buffer.from(b.replace(/-----[^-]+-----/g,"").replace(/\s/g,""),"base64");return e.createHash("sha1").update(c).digest("hex").toUpperCase().match(/.{2}/g).join(":")}async function l(a){var b;let c;return h?new Promise(a=>{f("certutil -store Root daily-cloudcode-pa.googleapis.com",b=>{a(!b)})}):i?(b=a,new Promise(a=>{try{let c=k(b);f(`security find-certificate -a -Z /Library/Keychains/System.keychain | grep -i "${c}"`,b=>{a(!b)})}catch{a(!1)}})):(c=`${j}/9router-mitm.crt`,Promise.resolve(d.existsSync(c)))}async function m(a,b){let c=`security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain "${b}"`;try{await g(c,a),console.log(`✅ Installed certificate to system keychain: ${b}`)}catch(a){throw Error(a.message?.includes("canceled")?"User canceled authorization":"Certificate install failed")}}async function n(a){let b=a.replace(/'/g,"''"),c=`Start-Process certutil -ArgumentList '-addstore','Root','${b}' -Verb RunAs -Wait -WindowStyle Hidden`;return new Promise((a,b)=>{f(`powershell -NonInteractive -WindowStyle Hidden -Command "${c}"`,{windowsHide:!0},c=>{c?b(Error(`Failed to install certificate: ${c.message}`)):(console.log("✅ Installed certificate to Windows Root store"),a())})})}async function o(a,b){let c=k(b).replace(/:/g,""),d=`security delete-certificate -Z "${c}" /Library/Keychains/System.keychain`;try{await g(d,a),console.log("✅ Uninstalled certificate from system keychain")}catch(a){throw Error("Failed to uninstall certificate")}}async function p(){return new Promise((a,b)=>{f("powershell -NonInteractive -WindowStyle Hidden -Command \"Start-Process certutil -ArgumentList '-delstore','Root','daily-cloudcode-pa.googleapis.com' -Verb RunAs -Wait -WindowStyle Hidden\"",{windowsHide:!0},c=>{c?b(Error(`Failed to uninstall certificate: ${c.message}`)):(console.log("✅ Uninstalled certificate from Windows Root store"),a())})})}async function q(a,b){let c=`${j}/9router-mitm.crt`,d=`cp "${b}" "${c}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(d,a),console.log("✅ Installed certificate to Linux trust store")}catch(a){throw Error("Certificate install failed")}}async function r(a){let b=`${j}/9router-mitm.crt`,c=`rm -f "${b}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(c,a),console.log("✅ Uninstalled certificate from Linux trust store")}catch(a){throw Error("Failed to uninstall certificate")}}a.exports={installCert:async function a(a,b){if(!d.existsSync(b))throw Error(`Certificate file not found: ${b}`);await l(b)?console.log("✅ Certificate already installed"):h?await n(b):i?await m(a,b):await q(a,b)},uninstallCert:async function a(a,b){await l(b)?h?await p():i?await o(a,b):await r(a):console.log("Certificate not found in system store")},checkCertInstalled:l}},26033:(a,b,c)=>{let d=c(33873),e=c(29021),{MITM_DIR:f}=c(82193),g="daily-cloudcode-pa.googleapis.com";a.exports={generateCert:async function(){let a=d.join(f,"server.key"),b=d.join(f,"server.crt");if(e.existsSync(a)&&e.existsSync(b))return console.log("✅ SSL certificate already exists"),{key:a,cert:b};e.existsSync(f)||e.mkdirSync(f,{recursive:!0});let h=c(12044),i=[{name:"commonName",value:g}],j=new Date;j.setFullYear(j.getFullYear()+1);let k=await h.generate(i,{keySize:2048,algorithm:"sha256",notAfterDate:j,extensions:[{name:"subjectAltName",altNames:[{type:2,value:g}]}]});return e.writeFileSync(a,k.private),e.writeFileSync(b,k.cert),console.log(`✅ Generated SSL certificate for ${g}`),{key:a,cert:b}}}},66936:(a,b,c)=>{let{exec:d,spawn:e}=c(79646),f=c(29021),g=c(33873),h=c(21820),i=["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com"],j="win32"===process.platform,k="darwin"===process.platform,l=j?g.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"):"/etc/hosts";function m(a,b){return new Promise((c,d)=>{let f=e("sudo",["-S","sh","-c",a],{stdio:["pipe","pipe","pipe"]}),g="",h="";f.stdout.on("data",a=>{g+=a}),f.stderr.on("data",a=>{h+=a}),f.on("close",a=>{0===a?c(g):d(Error(h||`Exit code ${a}`))}),f.stdin.write(`${b}
2
+ `),f.stdin.end()})}function n(a=null){try{let b=f.readFileSync(l,"utf8");if(a)return b.includes(a);return i.every(a=>b.includes(a))}catch{return!1}}a.exports={addDNSEntry:async function(a){let b=i.filter(a=>!n(a));if(0===b.length)return void console.log("DNS entries for all target hosts already exist");let c=b.map(a=>`127.0.0.1 ${a}`).join("\n");try{if(j){let a=l.replace(/'/g,"''"),c=b.map(b=>`$hc = Get-Content -Path '${a}' -Raw -ErrorAction SilentlyContinue; if ($hc -notmatch '${b}') { Add-Content -Path '${a}' -Value '127.0.0.1 ${b}' -Encoding UTF8 }`).join("; "),e=`${c}; ipconfig /flushdns | Out-Null`;await new Promise((a,b)=>{let c=e.replace(/"/g,'\\"');d(`powershell -NonInteractive -WindowStyle Hidden -Command "Start-Process powershell -ArgumentList '-NonInteractive -WindowStyle Hidden -Command \\"${c}\\"' -Verb RunAs -Wait"`,{windowsHide:!0},c=>{c?b(Error(`Failed to add DNS: ${c.message}`)):a()})})}else await m(`echo "${c}" >> ${l}`,a);j||(k?await m("dscacheutil -flushcache && killall -HUP mDNSResponder",a):await m("resolvectl flush-caches 2>/dev/null || true",a)),console.log(`✅ Added DNS entries: ${b.join(", ")}`)}catch(a){throw Error(a.message?.includes("incorrect password")?"Wrong sudo password":"Failed to add DNS entry")}},removeDNSEntry:async function(a){let b=i.filter(a=>n(a));if(0===b.length)return void console.log("DNS entries for target hosts do not exist");try{if(j){let a=f.readFileSync(l,"utf8"),b=a.split(/\r?\n/).filter(a=>!i.some(b=>a.includes(b))).join("\r\n");if(!b.trim()&&a.trim())throw Error("Filtered hosts content is empty, aborting to prevent data loss");let c=g.join(h.tmpdir(),"hosts_filtered.tmp");f.writeFileSync(c,b,"utf8");let e=c.replace(/'/g,"''"),j=l.replace(/'/g,"''"),k=`Copy-Item -Path '${e}' -Destination '${j}' -Force; ipconfig /flushdns | Out-Null; Remove-Item '${e}' -ErrorAction SilentlyContinue`;await new Promise((a,b)=>{let e=k.replace(/"/g,'\\"');d(`powershell -NonInteractive -WindowStyle Hidden -Command "Start-Process powershell -ArgumentList '-NonInteractive -WindowStyle Hidden -Command \\"${e}\\"' -Verb RunAs -Wait"`,{windowsHide:!0},d=>{try{f.unlinkSync(c)}catch{}d?b(Error(`Failed to remove DNS entry: ${d.message}`)):a()})})}else for(let c of b){let b=k?`sed -i '' '/${c}/d' ${l}`:`sed -i '/${c}/d' ${l}`;await m(b,a)}j||(k?await m("dscacheutil -flushcache && killall -HUP mDNSResponder",a):await m("resolvectl flush-caches 2>/dev/null || true",a)),console.log(`✅ Removed DNS entries for ${b.join(", ")}`)}catch(a){throw Error(a.message?.includes("incorrect password")?"Wrong sudo password":"Failed to remove DNS entry")}},execWithPassword:m,checkDNSEntry:n}},82193:(a,b,c)=>{let d=c(33873),e=c(21820),f=process.env.DATA_DIR?process.env.DATA_DIR:"win32"===process.platform?d.join(process.env.APPDATA||d.join(e.homedir(),"AppData","Roaming"),"9router"):d.join(e.homedir(),".9router"),g=d.join(f,"mitm");a.exports={DATA_DIR:f,MITM_DIR:g}},96182:(a,b,c)=>{let{exec:d,spawn:e,execSync:f}=c(79646),g=c(33873),h=c(29021),i=c(21820),j=c(91645),k=c(55591),l=c(55511),{addDNSEntry:m,removeDNSEntry:n,checkDNSEntry:o}=c(66936),p="win32"===process.platform,{generateCert:q}=c(26033),{installCert:r}=c(9631),{MITM_DIR:s}=c(82193),t=g.join(s,".mitm.pid"),u=function(){if(process.env.MITM_SERVER_PATH)return process.env.MITM_SERVER_PATH;let a=g.join(__dirname,"server.js");if(h.existsSync(a))return a;let b=g.join(process.cwd(),"src","mitm","server.js");if(h.existsSync(b))return b;let c=g.join(process.cwd(),"..","src","mitm","server.js");return h.existsSync(c)?c:b}(),v="aes-256-gcm",w="9router-mitm-pwd",x=null,y=null;function z(a){globalThis.__mitmSudoPassword=a}function A(a){try{return process.kill(a,0),!0}catch(a){return"EACCES"===a.code}}function B(a,b=!1){if(p)d(`taskkill ${b?"/F ":""}/PID ${a}`,()=>{});else{let c=b?"SIGKILL":"SIGTERM";d(`pkill -${c} -P ${a} 2>/dev/null; kill -${c} ${a} 2>/dev/null`,()=>{})}}function C(){try{let{machineIdSync:a}=c(19713),b=a();return l.createHash("sha256").update(b+w).digest()}catch{return l.createHash("sha256").update(w).digest()}}let D=null,E=null;async function F(a,b){if(!E)return void console.log("[MITM] DB hooks not initialized, skipping save");try{let c,d,e,f,g,h={mitmEnabled:a};b&&(c=C(),d=l.randomBytes(12),e=l.createCipheriv(v,c,d),f=Buffer.concat([e.update(b,"utf8"),e.final()]),g=e.getAuthTag(),h.mitmSudoEncrypted=`${d.toString("hex")}:${g.toString("hex")}:${f.toString("hex")}`),await E(h)}catch(a){console.log("[MITM] Failed to save settings:",a.message)}}async function G(a){if(x&&!x.killed){try{x.kill("SIGKILL")}catch{}x=null,y=null}try{if(h.existsSync(t)){let a=parseInt(h.readFileSync(t,"utf-8").trim(),10);a&&A(a)&&(B(a,!0),await new Promise(a=>setTimeout(a,500))),h.unlinkSync(t)}}catch{}if(!p&&u)try{let b=u.replace(/'/g,"'\\''");if(a){let{execWithPassword:d}=c(66936);await d(`pkill -SIGKILL -f "${b}" 2>/dev/null || true`,a).catch(()=>{})}else d(`pkill -SIGKILL -f "${b}" 2>/dev/null || true`,()=>{});await new Promise(a=>setTimeout(a,500))}catch{}}a.exports={getMitmStatus:async function(){let a=null!==x&&!x.killed,b=y;if(!a)try{if(h.existsSync(t)){let c=parseInt(h.readFileSync(t,"utf-8").trim(),10);c&&A(c)?(a=!0,b=c):h.unlinkSync(t)}}catch{}return{running:a,pid:b,dnsConfigured:o(),certExists:h.existsSync(g.join(s,"server.crt"))}},startMitm:async function(a,b){if(!x||x.killed)try{if(h.existsSync(t)){let a=parseInt(h.readFileSync(t,"utf-8").trim(),10);if(a&&A(a))return y=a,console.log(`[MITM] Reusing existing process PID ${a}`),await F(!0,b),b&&z(b),{running:!0,pid:a};h.unlinkSync(t)}}catch{}if(x&&!x.killed)throw Error("MITM proxy is already running");if(await G(b),!p){let a=await new Promise(a=>{let b=j.createServer();b.once("error",b=>{"EADDRINUSE"===b.code?a("in-use"):a("no-permission")}),b.once("listening",()=>{b.close(()=>a("free"))}),b.listen(443,"127.0.0.1")});if("in-use"===a||"no-permission"===a){let a=await new Promise(a=>{p?d('powershell -NonInteractive -WindowStyle Hidden -Command "$c = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1; if ($c) { $c.OwningProcess } else { 0 }"',{windowsHide:!0},(b,c)=>{if(b)return a(null);let e=parseInt(c.trim(),10);if(!e||e<=4)return a(null);d(`tasklist /FI "PID eq ${e}" /FO CSV /NH`,{windowsHide:!0},(b,c)=>{let d=c?.match(/"([^"]+)"/);a({pid:e,name:d?d[1]:"unknown"})})}):d('ps aux | grep "[s]erver.js"',(b,c)=>{if(!c?.trim())return a(null);for(let b of c.split("\n")){let c=parseInt(b.trim().split(/\s+/)[1],10);if(!isNaN(c))return a({pid:c,name:"node"})}a(null)})});if(a&&"node"===a.name){console.log(`[MITM] Killing orphan node process on port 443 (PID ${a.pid})...`);try{let{execWithPassword:d}=c(66936);await d(`kill -9 ${a.pid}`,b),await new Promise(a=>setTimeout(a,800))}catch{}}else if(a){let b=a.name.includes("/")?a.name.split("/").filter(Boolean).pop():a.name;throw Error(`Port 443 is already in use by "${b}" (PID ${a.pid}). Stop that process first, then retry.`)}}}let l=g.join(s,"server.crt");if(h.existsSync(l)||(console.log("Generating SSL certificate..."),await q()),console.log("Starting MITM server..."),p){let b=g.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"),c=g.join(i.tmpdir(),`mitm_ready_${Date.now()}.flag`),d=l.replace(/'/g,"''"),f=b.replace(/'/g,"''"),j=process.execPath.replace(/'/g,"''"),k=u.replace(/'/g,"''"),m=c.replace(/'/g,"''"),n=["# 0. Kill any orphan node process on port 443\n$conn = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1\nif ($conn -and $conn.OwningProcess -gt 4) { Stop-Process -Id $conn.OwningProcess -Force -ErrorAction SilentlyContinue }\nStart-Sleep -Milliseconds 500\n\n# 1. Install SSL cert to Windows Root store (always run to ensure trust)",`& certutil -addstore Root '${d}' | Out-Null`,"\n# 2. Add DNS entries to hosts file",["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com"].map(a=>`$hc = Get-Content -Path '${f}' -Raw -ErrorAction SilentlyContinue
3
3
  if ($hc -notmatch [regex]::Escape('${a}')) { Add-Content -Path '${f}' -Value '127.0.0.1 ${a}' -Encoding UTF8 }`).join("\n"),"& ipconfig /flushdns | Out-Null\n\n# 3. Start node MITM server elevated (required to bind port 443)",`# Use cmd /c to pass env vars inline — Start-Process does not inherit current env`,`$nodeCmd = 'set ROUTER_API_KEY=${a.replace(/'/g,"''")}&& set NODE_ENV=production&& "${j}" "${k}"'`,"Start-Process cmd -ArgumentList '/c',$nodeCmd -WindowStyle Hidden\n\n# 4. Signal ready\nStart-Sleep -Milliseconds 500",`Set-Content -Path '${m}' -Value 'ready' -Encoding UTF8`].join("\n"),o=g.join(i.tmpdir(),`mitm_start_${Date.now()}.ps1`);h.writeFileSync(o,n,"utf8");let p=`Set oShell = CreateObject("Shell.Application")\r
4
4
  Dim ps\r
5
5
  ps = Chr(34) & "powershell.exe" & Chr(34)\r
@@ -12,4 +12,4 @@ Remove-Item '${f.replace(/'/g,"''")}' -ErrorAction SilentlyContinue
12
12
  Set-Content -Path '${j.replace(/'/g,"''")}' -Value 'done' -Encoding UTF8`,l=g.join(i.tmpdir(),"mitm_stop.ps1");h.writeFileSync(l,k,"utf8");let m=`Set oShell = CreateObject("Shell.Application")\r
13
13
  Dim args\r
14
14
  args = "-NoProfile -ExecutionPolicy Bypass -File " & Chr(34) & "${l}" & Chr(34)\r
15
- oShell.ShellExecute "powershell.exe", args, "", "runas", 1`,n=g.join(i.tmpdir(),"mitm_stop_uac.vbs");h.writeFileSync(n,m,"utf8"),e("wscript.exe",[n],{stdio:"ignore",windowsHide:!1,detached:!0}).unref(),await new Promise(a=>{let b=Date.now()+3e4,c=()=>{if(h.existsSync(j)){try{h.unlinkSync(j),h.unlinkSync(l),h.unlinkSync(n)}catch{}return a()}if(Date.now()>b)return a();setTimeout(c,500)};c()})}else console.log("Removing DNS entry..."),await n(a);try{h.unlinkSync(t)}catch{}return await F(!1,null),{running:!1,pid:null}},getCachedPassword:function(){return globalThis.__mitmSudoPassword||null},setCachedPassword:z,loadEncryptedPassword:async function a(){if(!D)return null;try{let a=await D();if(!a.mitmSudoEncrypted)return null;return function(a){try{let[b,c,d]=a.split(":");if(!b||!c||!d)return null;let e=C(),f=l.createDecipheriv(v,e,Buffer.from(b,"hex"));return f.setAuthTag(Buffer.from(c,"hex")),f.update(Buffer.from(d,"hex"))+f.final("utf8")}catch{return null}}(a.mitmSudoEncrypted)}catch{return null}},initDbHooks:function(a,b){D=a,E=b}}},96487:()=>{}};
15
+ oShell.ShellExecute "powershell.exe", args, "", "runas", 1`,n=g.join(i.tmpdir(),"mitm_stop_uac.vbs");h.writeFileSync(n,m,"utf8"),e("wscript.exe",[n],{stdio:"ignore",windowsHide:!1,detached:!0}).unref(),await new Promise(a=>{let b=Date.now()+3e4,c=()=>{if(h.existsSync(j)){try{h.unlinkSync(j),h.unlinkSync(l),h.unlinkSync(n)}catch{}return a()}if(Date.now()>b)return a();setTimeout(c,500)};c()})}else console.log("Removing DNS entry..."),await n(a);try{h.unlinkSync(t)}catch{}return await F(!1,null),{running:!1,pid:null}},getCachedPassword:function(){return globalThis.__mitmSudoPassword||null},setCachedPassword:z,loadEncryptedPassword:async function a(){if(!D)return null;try{let a=await D();if(!a.mitmSudoEncrypted)return null;return function(a){try{let[b,c,d]=a.split(":");if(!b||!c||!d)return null;let e=C(),f=l.createDecipheriv(v,e,Buffer.from(b,"hex"));return f.setAuthTag(Buffer.from(c,"hex")),f.update(Buffer.from(d,"hex"))+f.final("utf8")}catch{return null}}(a.mitmSudoEncrypted)}catch{return null}},initDbHooks:function(a,b){D=a,E=b}}}};
@@ -1 +1 @@
1
- "use strict";exports.id=8756,exports.ids=[8756],exports.modules={7803:(a,b,c)=>{c.r(b),c.d(b,{debug:()=>f,error:()=>i,info:()=>g,maskKey:()=>m,request:()=>j,response:()=>k,stream:()=>l,warn:()=>h});function d(){return new Date().toLocaleTimeString("en-US",{hour12:!1})}function e(a){if(!a)return"";if("string"==typeof a)return a;try{return JSON.stringify(a)}catch{return String(a)}}function f(a,b,c){!0;{let f=c?` ${e(c)}`:"";console.log(`[${d()}] 🔍 [${a}] ${b}${f}`)}}function g(a,b,c){!0;{let f=c?` ${e(c)}`:"";console.log(`[${d()}] ℹ️ [${a}] ${b}${f}`)}}function h(a,b,c){c&&e(c)}function i(a,b,c){!0;{let f=c?` ${e(c)}`:"";console.log(`[${d()}] ❌ [${a}] ${b}${f}`)}}function j(a,b,c){let f=c?` ${e(c)}`:"";console.log(`\x1b[36m[${d()}] 📥 ${a} ${b}${f}\x1b[0m`)}function k(a,b,c){let f=c?` ${e(c)}`:"";console.log(`[${d()}] ${a<400?"\uD83D\uDCE4":"\uD83D\uDCA5"} ${a} (${b}ms)${f}`)}function l(a,b){let c=b?` ${e(b)}`:"";console.log(`[${d()}] 🌊 [STREAM] ${a}${c}`)}function m(a){return!a||a.length<8?"***":`${a.slice(0,4)}...${a.slice(-4)}`}},38160:(a,b,c)=>{c.d(b,{Ou:()=>i,eG:()=>h});var d=c(2255);let e=new Map,f=new Map,g=null;async function h(a,b){if(!a||!b)return null;let c=e.get(a);if(c&&Date.now()-c.fetchedAt<36e5)return c.projectId;if(f.has(a))return f.get(a).promise;let d=new AbortController,g=(async()=>{try{let c=await j(b,d.signal);if(c)return e.set(a,{projectId:c,fetchedAt:Date.now()}),c;return console.warn("[ProjectId] could not fetch projectId for connection",a.slice(0,8)),null}catch(a){return console.warn(`[ProjectId] Error fetching project ID: ${a.message}`),null}finally{f.delete(a)}})();return f.set(a,{promise:g,controller:d,startedAt:Date.now()}),g}function i(a){e.delete(a)}async function j(a,b){let c=await fetch(d.nZ.loadCodeAssist,{method:"POST",headers:{Authorization:`Bearer ${a}`,"Content-Type":"application/json","User-Agent":(0,d.A9)(),...d.K},body:JSON.stringify({metadata:d.Cn,mode:1}),signal:b});if(!c.ok){let a=await c.text().catch(()=>"");throw Error(`loadCodeAssist failed: HTTP ${c.status} ${a.slice(0,200)}`)}let e=await c.json(),f=function(a){if(!a)return null;if("string"==typeof a.cloudaicompanionProject){let b=a.cloudaicompanionProject.trim();if(b)return b}if(a.cloudaicompanionProject&&"object"==typeof a.cloudaicompanionProject){let b=a.cloudaicompanionProject.id;if("string"==typeof b&&b.trim())return b.trim()}return null}(e);if(f)return f;let g="legacy-tier";if(Array.isArray(e.allowedTiers)){for(let a of e.allowedTiers)if(a&&"object"==typeof a&&!0===a.isDefault&&a.id&&"string"==typeof a.id&&a.id.trim()){g=a.id.trim();break}}return k(a,g,b)}async function k(a,b,c){console.log(`[ProjectId] Onboarding user with tier: ${b}`);let e={tierId:b,metadata:d.Cn,mode:1};for(let b=1;b<=5&&!c?.aborted;b++){let f=new AbortController,g=setTimeout(()=>f.abort(),3e4),h=()=>f.abort();c?.addEventListener("abort",h);try{let c=await fetch(d.nZ.onboardUser,{method:"POST",headers:{Authorization:`Bearer ${a}`,"Content-Type":"application/json","User-Agent":(0,d.A9)(),...d.K},body:JSON.stringify(e),signal:f.signal});if(clearTimeout(g),!c.ok){let a=await c.text().catch(()=>"");throw Error(`onboardUser HTTP ${c.status}: ${a.slice(0,200)}`)}let h=await c.json();if(!0===h.done){let a=function(a){if(!a?.response)return null;let b=a.response.cloudaicompanionProject;if("string"==typeof b){let a=b.trim();if(a)return a}if(b&&"object"==typeof b){let a=b.id;if("string"==typeof a&&a.trim())return a.trim()}return null}(h);if(a)return console.log(`[ProjectId] Successfully onboarded, project ID: ${a}`),a;throw Error("onboardUser done but no project_id in response")}console.log(`[ProjectId] Onboard attempt ${b}/5: not done yet, waiting...`),await new Promise(a=>setTimeout(a,2e3))}catch(a){if(clearTimeout(g),"AbortError"===a.name){if(console.warn(`[ProjectId] onboardUser attempt ${b} aborted (timeout or connection removed)`),c?.aborted)return null;continue}if(5===b)return console.warn(`[ProjectId] onboardUser failed after 5 attempts: ${a.message}`),null;throw a}finally{clearTimeout(g),c?.removeEventListener("abort",h)}}return null}g=setInterval(()=>{try{let a=Date.now();for(let[b,c]of e)(!c||a-c.fetchedAt>=36e5)&&e.delete(b);for(let[b,c]of f){if(!c||"number"!=typeof c.startedAt){f.delete(b);continue}if(a-c.startedAt>12e4){try{c.controller.abort()}catch(a){}f.delete(b)}}}catch(a){console.warn("[ProjectId] cleanup sweep error:",a?.message??a)}},6e5),g?.unref?.()},67828:(a,b,c)=>{c.d(b,{I9:()=>i,eU:()=>l,vN:()=>k});var d=c(7803),e=c(89718),f=c(38160),g=c(8590);let h=g.oD,i=(a,b,c)=>(0,g.I9)(a,b,c,d);function j(a){return new Date(Date.now()+1e3*a).toISOString()}async function k(a,b){try{let c={};b.accessToken&&(c.accessToken=b.accessToken),b.refreshToken&&(c.refreshToken=b.refreshToken),b.expiresIn&&(c.expiresAt=j(b.expiresIn),c.expiresIn=b.expiresIn),b.providerSpecificData&&(c.providerSpecificData=b.providerSpecificData),b.projectId&&(c.projectId=b.projectId);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 l(a,b){let c={...b};if(c.expiresAt){let b=new Date(c.expiresAt).getTime()-Date.now();if(b<h){let e;d.info("TOKEN_REFRESH","Token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round(b/1e3)});let h=await (e=c,(0,g.iD)(a,e,d));h?.accessToken&&(await k(c.connectionId,h),function(a,b,c){("antigravity"===a||"gemini-cli"===a)&&b&&c&&((0,f.Ou)(b),(0,f.eG)(b,c).then(a=>{a&&k(b,{projectId:a}).catch(a=>{d.debug("TOKEN_REFRESH","Failed to persist refreshed projectId",{connectionId:b,error:a?.message??a})})}).catch(a=>{d.debug("TOKEN_REFRESH","Failed to fetch projectId after token refresh",{connectionId:b,error:a?.message??a})}))}(a,(c={...c,accessToken:h.accessToken,refreshToken:h.refreshToken??c.refreshToken,expiresAt:h.expiresIn?j(h.expiresIn):c.expiresAt}).connectionId,c.accessToken))}}if("github"===a&&c.providerSpecificData?.copilotTokenExpiresAt){let b=1e3*c.providerSpecificData.copilotTokenExpiresAt-Date.now();if(b<h){let e;d.info("TOKEN_REFRESH","Copilot token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round(b/1e3)});let f=await (e=c.accessToken,(0,g.jR)(e,d));if(f){let a={...c.providerSpecificData,copilotToken:f.token,copilotTokenExpiresAt:f.expiresAt};await k(c.connectionId,{providerSpecificData:a}),c.providerSpecificData=a}}}return c}},75681:(a,b,c)=>{c.d(b,{DI:()=>h,IS:()=>d,JH:()=>g,Q2:()=>k,fg:()=>f,gb:()=>j,mq:()=>i,rs:()=>m,wG:()=>n,zN:()=>e,zt:()=>l});let d={iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4"},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"}},e={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B"},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},f={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai"},glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Aliyun Bailian",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#5B6EF5",textIcon:"CH",website:"https://chutes.ai"}},g="openai-compatible-",h="anthropic-compatible-";function i(a){return"string"==typeof a&&a.startsWith(g)}function j(a){return"string"==typeof a&&a.startsWith(h)}let k={...d,...e,...f};function l(a){for(let b of Object.values(k))if(b.alias===a||b.id===a)return b;return null}function m(a){let b=l(a);return b?.id||a}function n(a){let b=k[a];return b?.alias||a}Object.values(k).reduce((a,b)=>(a[b.alias]=b.id,a),{}),Object.values(k).reduce((a,b)=>(a[b.id]=b.alias,a),{})}};
1
+ "use strict";exports.id=8756,exports.ids=[8756],exports.modules={7803:(a,b,c)=>{c.r(b),c.d(b,{debug:()=>f,error:()=>i,info:()=>g,maskKey:()=>m,request:()=>j,response:()=>k,stream:()=>l,warn:()=>h});function d(){return new Date().toLocaleTimeString("en-US",{hour12:!1})}function e(a){if(!a)return"";if("string"==typeof a)return a;try{return JSON.stringify(a)}catch{return String(a)}}function f(a,b,c){!0;{let f=c?` ${e(c)}`:"";console.log(`[${d()}] 🔍 [${a}] ${b}${f}`)}}function g(a,b,c){!0;{let f=c?` ${e(c)}`:"";console.log(`[${d()}] ℹ️ [${a}] ${b}${f}`)}}function h(a,b,c){c&&e(c)}function i(a,b,c){!0;{let f=c?` ${e(c)}`:"";console.log(`[${d()}] ❌ [${a}] ${b}${f}`)}}function j(a,b,c){let f=c?` ${e(c)}`:"";console.log(`\x1b[36m[${d()}] 📥 ${a} ${b}${f}\x1b[0m`)}function k(a,b,c){let f=c?` ${e(c)}`:"";console.log(`[${d()}] ${a<400?"\uD83D\uDCE4":"\uD83D\uDCA5"} ${a} (${b}ms)${f}`)}function l(a,b){let c=b?` ${e(b)}`:"";console.log(`[${d()}] 🌊 [STREAM] ${a}${c}`)}function m(a){return!a||a.length<8?"***":`${a.slice(0,4)}...${a.slice(-4)}`}},38160:(a,b,c)=>{c.d(b,{Ou:()=>i,eG:()=>h});var d=c(2255);let e=new Map,f=new Map,g=null;async function h(a,b){if(!a||!b)return null;let c=e.get(a);if(c&&Date.now()-c.fetchedAt<36e5)return c.projectId;if(f.has(a))return f.get(a).promise;let d=new AbortController,g=(async()=>{try{let c=await j(b,d.signal);if(c)return e.set(a,{projectId:c,fetchedAt:Date.now()}),c;return console.warn("[ProjectId] could not fetch projectId for connection",a.slice(0,8)),null}catch(a){return console.warn(`[ProjectId] Error fetching project ID: ${a.message}`),null}finally{f.delete(a)}})();return f.set(a,{promise:g,controller:d,startedAt:Date.now()}),g}function i(a){e.delete(a)}async function j(a,b){let c=await fetch(d.nZ.loadCodeAssist,{method:"POST",headers:{Authorization:`Bearer ${a}`,"Content-Type":"application/json","User-Agent":(0,d.A9)(),...d.K},body:JSON.stringify({metadata:d.Cn,mode:1}),signal:b});if(!c.ok){let a=await c.text().catch(()=>"");throw Error(`loadCodeAssist failed: HTTP ${c.status} ${a.slice(0,200)}`)}let e=await c.json(),f=function(a){if(!a)return null;if("string"==typeof a.cloudaicompanionProject){let b=a.cloudaicompanionProject.trim();if(b)return b}if(a.cloudaicompanionProject&&"object"==typeof a.cloudaicompanionProject){let b=a.cloudaicompanionProject.id;if("string"==typeof b&&b.trim())return b.trim()}return null}(e);if(f)return f;let g="legacy-tier";if(Array.isArray(e.allowedTiers)){for(let a of e.allowedTiers)if(a&&"object"==typeof a&&!0===a.isDefault&&a.id&&"string"==typeof a.id&&a.id.trim()){g=a.id.trim();break}}return k(a,g,b)}async function k(a,b,c){console.log(`[ProjectId] Onboarding user with tier: ${b}`);let e={tierId:b,metadata:d.Cn,mode:1};for(let b=1;b<=5&&!c?.aborted;b++){let f=new AbortController,g=setTimeout(()=>f.abort(),3e4),h=()=>f.abort();c?.addEventListener("abort",h);try{let c=await fetch(d.nZ.onboardUser,{method:"POST",headers:{Authorization:`Bearer ${a}`,"Content-Type":"application/json","User-Agent":(0,d.A9)(),...d.K},body:JSON.stringify(e),signal:f.signal});if(clearTimeout(g),!c.ok){let a=await c.text().catch(()=>"");throw Error(`onboardUser HTTP ${c.status}: ${a.slice(0,200)}`)}let h=await c.json();if(!0===h.done){let a=function(a){if(!a?.response)return null;let b=a.response.cloudaicompanionProject;if("string"==typeof b){let a=b.trim();if(a)return a}if(b&&"object"==typeof b){let a=b.id;if("string"==typeof a&&a.trim())return a.trim()}return null}(h);if(a)return console.log(`[ProjectId] Successfully onboarded, project ID: ${a}`),a;throw Error("onboardUser done but no project_id in response")}console.log(`[ProjectId] Onboard attempt ${b}/5: not done yet, waiting...`),await new Promise(a=>setTimeout(a,2e3))}catch(a){if(clearTimeout(g),"AbortError"===a.name){if(console.warn(`[ProjectId] onboardUser attempt ${b} aborted (timeout or connection removed)`),c?.aborted)return null;continue}if(5===b)return console.warn(`[ProjectId] onboardUser failed after 5 attempts: ${a.message}`),null;throw a}finally{clearTimeout(g),c?.removeEventListener("abort",h)}}return null}g=setInterval(()=>{try{let a=Date.now();for(let[b,c]of e)(!c||a-c.fetchedAt>=36e5)&&e.delete(b);for(let[b,c]of f){if(!c||"number"!=typeof c.startedAt){f.delete(b);continue}if(a-c.startedAt>12e4){try{c.controller.abort()}catch(a){}f.delete(b)}}}catch(a){console.warn("[ProjectId] cleanup sweep error:",a?.message??a)}},6e5),g?.unref?.()},67828:(a,b,c)=>{c.d(b,{I9:()=>i,eU:()=>l,vN:()=>k});var d=c(7803),e=c(89718),f=c(38160),g=c(8590);let h=g.oD,i=(a,b,c)=>(0,g.I9)(a,b,c,d);function j(a){return new Date(Date.now()+1e3*a).toISOString()}async function k(a,b){try{let c={};b.accessToken&&(c.accessToken=b.accessToken),b.refreshToken&&(c.refreshToken=b.refreshToken),b.expiresIn&&(c.expiresAt=j(b.expiresIn),c.expiresIn=b.expiresIn),b.providerSpecificData&&(c.providerSpecificData=b.providerSpecificData),b.projectId&&(c.projectId=b.projectId);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 l(a,b){let c={...b};if(c.expiresAt){let b=new Date(c.expiresAt).getTime()-Date.now();if(b<h){let e;d.info("TOKEN_REFRESH","Token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round(b/1e3)});let h=await (e=c,(0,g.iD)(a,e,d));h?.accessToken&&(await k(c.connectionId,h),function(a,b,c){("antigravity"===a||"gemini-cli"===a)&&b&&c&&((0,f.Ou)(b),(0,f.eG)(b,c).then(a=>{a&&k(b,{projectId:a}).catch(a=>{d.debug("TOKEN_REFRESH","Failed to persist refreshed projectId",{connectionId:b,error:a?.message??a})})}).catch(a=>{d.debug("TOKEN_REFRESH","Failed to fetch projectId after token refresh",{connectionId:b,error:a?.message??a})}))}(a,(c={...c,accessToken:h.accessToken,refreshToken:h.refreshToken??c.refreshToken,expiresAt:h.expiresIn?j(h.expiresIn):c.expiresAt}).connectionId,c.accessToken))}}if("github"===a&&c.providerSpecificData?.copilotTokenExpiresAt){let b=1e3*c.providerSpecificData.copilotTokenExpiresAt-Date.now();if(b<h){let e;d.info("TOKEN_REFRESH","Copilot token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round(b/1e3)});let f=await (e=c.accessToken,(0,g.jR)(e,d));if(f){let a={...c.providerSpecificData,copilotToken:f.token,copilotTokenExpiresAt:f.expiresAt};await k(c.connectionId,{providerSpecificData:a}),c.providerSpecificData=a}}}return c}},75681:(a,b,c)=>{c.d(b,{DI:()=>h,IS:()=>d,JH:()=>g,Q2:()=>k,fg:()=>f,gb:()=>j,mq:()=>i,rs:()=>m,wG:()=>n,zN:()=>e,zt:()=>l});let d={iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4"},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"}},e={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B"},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},f={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai"},glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#5B6EF5",textIcon:"CH",website:"https://chutes.ai"}},g="openai-compatible-",h="anthropic-compatible-";function i(a){return"string"==typeof a&&a.startsWith(g)}function j(a){return"string"==typeof a&&a.startsWith(h)}let k={...d,...e,...f};function l(a){for(let b of Object.values(k))if(b.alias===a||b.id===a)return b;return null}function m(a){let b=l(a);return b?.id||a}function n(a){let b=k[a];return b?.alias||a}Object.values(k).reduce((a,b)=>(a[b.alias]=b.id,a),{}),Object.values(k).reduce((a,b)=>(a[b.id]=b.alias,a),{})}};
@@ -1,4 +1,4 @@
1
- "use strict";exports.id=8895,exports.ids=[8895],exports.modules={5016:(a,b,c)=>{c.d(b,{N:()=>l});var d=c(14170),e=c(33110),f=c(73483),g=c(43659),h=c(2255),i=c(81626),j=c(86171),k=c(47370);async function l({providerResponse:a,provider:b,model:c,sourceFormat:l,targetFormat:m,body:n,stream:o,translatedBody:p,finalBody:q,requestStartTime:r,connectionId:s,apiKey:t,clientRawRequest:u,onRequestSuccess:v,reqLogger:w,trackDone:x,appendLog:y}){let z;if(x(),(a.headers.get("content-type")||"").includes("text/event-stream")){let b=await a.text(),d=(0,i.F)(b,c);if(!d)return y({status:`FAILED ${h.gx.BAD_GATEWAY}`}),(0,g.A1)(h.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");z=d}else try{z=await a.json()}catch(a){return y({status:`FAILED ${h.gx.BAD_GATEWAY}`}),console.error(`[ChatCore] Failed to parse JSON from ${b}:`,a.message),(0,g.A1)(h.gx.BAD_GATEWAY,`Invalid JSON response from ${b}`)}w.logProviderResponse(a.status,a.statusText,a.headers,z),v&&await v();let A=(0,j.MK)(z);y({tokens:A,status:"200 OK"}),(0,j.qr)({provider:b,model:c,tokens:A,connectionId:s,apiKey:t,endpoint:u?.endpoint});let B=(0,e.nZ)(m,l)?function(a,b,c){if(b===c||b===d.h.OPENAI)return a;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?g+=a.text:void 0!==a.text&&(f+=a.text),a.functionCall&&h.push({id:`call_${a.functionCall.name}_${Date.now()}_${h.length}`,type:"function",function:{name:a.functionCall.name,arguments:JSON.stringify(a.functionCall.args||{})}});let i={role:"assistant"};f&&(i.content=f),g&&(i.reasoning_content=g),h.length>0&&(i.tool_calls=h),i.content||i.tool_calls||(i.content="");let j=(c.finishReason||"stop").toLowerCase();"stop"===j&&h.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}(z,m,l):z;if(B.object||(B.object="chat.completion"),B.created||(B.created=Math.floor(Date.now()/1e3)),delete B.prompt_filter_results,B?.choices)for(let a of B.choices)delete a.content_filter_results;B?.usage&&(B.usage=(0,f.WL)((0,f.O9)(B.usage),l)),w.logConvertedResponse(B);let C=Date.now()-r;return(0,k.ox)((0,j.$R)({provider:b,model:c,connectionId:s,latency:{ttft:C,total:C},tokens:A||{prompt_tokens:0,completion_tokens:0},request:(0,j.Fo)(n,o),providerRequest:q||p||null,providerResponse:z||null,response:{content:B?.choices?.[0]?.message?.content||B?.content||null,thinking:B?.choices?.[0]?.message?.reasoning_content||B?.reasoning_content||null,finish_reason:B?.choices?.[0]?.finish_reason||"unknown"},status:"success"},{endpoint:u?.endpoint||null})).catch(a=>{console.error("[RequestDetail] Failed to save:",a.message)}),{success:!0,response:new Response(JSON.stringify(B),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}},20623:(a,b,c)=>{c.d(b,{$:()=>l,M:()=>k});var d=c(14170),e=c(33110),f=c(71857),g=c(59657),h=c(86171),i=c(47370);let j={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*"};function k({providerResponse:a,provider:b,model:c,sourceFormat:k,targetFormat:l,userAgent:m,body:n,stream:o,translatedBody:p,finalBody:q,requestStartTime:r,connectionId:s,apiKey:t,clientRawRequest:u,onRequestSuccess:v,reqLogger:w,toolNameMap:x,streamController:y,onStreamComplete:z}){v&&v();let A=function({provider:a,sourceFormat:b,targetFormat:c,userAgent:g,reqLogger:h,toolNameMap:i,model:j,connectionId:k,body:l,onStreamComplete:m,apiKey:n}){let o=g?.toLowerCase().includes("droid")||g?.toLowerCase().includes("codex-cli");if("codex"===a&&c===d.h.OPENAI_RESPONSES&&!o){let c;return c=b===d.h.OPENAI_RESPONSES?d.h.OPENAI_RESPONSES:b===d.h.CLAUDE?d.h.CLAUDE:b===d.h.ANTIGRAVITY||b===d.h.GEMINI||b===d.h.GEMINI_CLI?d.h.ANTIGRAVITY:d.h.OPENAI,(0,f.i5)(d.h.OPENAI_RESPONSES,c,a,h,i,j,k,l,m,n)}return(0,e.nZ)(c,b)?(0,f.i5)(c,b,a,h,i,j,k,l,m,n):(0,f.l2)(a,h,j,k,l,m,n)}({provider:b,sourceFormat:k,targetFormat:l,userAgent:m,reqLogger:w,toolNameMap:x,model:c,connectionId:s,body:n,onStreamComplete:z,apiKey:t}),B=(0,g.Jb)(a,A,y),C=`${Date.now()}-${Math.random().toString(36).slice(2,11)}`;return(0,i.ox)((0,h.$R)({provider:b,model:c,connectionId:s,latency:{ttft:0,total:Date.now()-r},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,h.Fo)(n,o),providerRequest:q||p||null,providerResponse:"[Streaming - raw response not captured]",response:{content:"[Streaming in progress...]",thinking:null,type:"streaming"},status:"success"},{id:C})).catch(a=>{console.error("[RequestDetail] Failed to save streaming request:",a.message)}),{success:!0,response:new Response(B,{headers:j})}}function l({provider:a,model:b,connectionId:c,apiKey:d,requestStartTime:e,body:f,stream:g,finalBody:j,translatedBody:k,clientRawRequest:l}){let m=`${Date.now()}-${Math.random().toString(36).slice(2,11)}`;return{onStreamComplete:(n,o,p)=>{let q={ttft:p?p-e:Date.now()-e,total:Date.now()-e};(0,i.ox)((0,h.$R)({provider:a,model:b,connectionId:c,latency:q,tokens:o||{prompt_tokens:0,completion_tokens:0},request:(0,h.Fo)(f,g),providerRequest:j||k||null,providerResponse:n.content||"[Empty streaming response]",response:{content:n.content||"[Empty streaming response]",thinking:n.thinking||null,type:"streaming"},status:"success"},{id:m})).catch(a=>{console.error("[RequestDetail] Failed to update streaming content:",a.message)}),(0,h.qr)({provider:a,model:b,tokens:o,connectionId:c,apiKey:d,endpoint:l?.endpoint,label:"STREAM USAGE"})},streamDetailId:m}}},27349:(a,b,c)=>{c.d(b,{c:()=>i});var d=c(57647),e=c(33110),f=c(14170),g=c(2255),h=c(71857);function i(a,b,c=""){if(!c.includes("claude-cli")||!a.messages?.length)return null;let l=a.messages,m=a=>"string"==typeof a?a:Array.isArray(a)?a.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"",n=!1,o=l[l.length-1];if(o?.role==="assistant"&&o.content?.[0]?.text==="{"&&(n=!0),n||"Warmup"===m(l[0]?.content)&&(n=!0),n||1!==l.length||l[0]?.role!=="user"||"count"===m(l[0]?.content)&&(n=!0),!n&&g.C8?.length){let a=l.filter(a=>"user"===a.role).map(a=>m(a.content)).join(" ");g.C8.some(b=>a.includes(b))&&(n=!0)}if(!n)return null;let p=(0,d.Tz)(a);return!1!==a.stream?function(a,b){let c=j(b),d=(0,e.Ws)(a);d.model=b;let g=k(c),i=[];for(let b of g){let c=(0,e.Y8)(f.h.OPENAI,a,b,d);if(c?.length>0)for(let b of c)i.push((0,h.v8)(b,a))}let l=(0,e.Y8)(f.h.OPENAI,a,null,d);if(l?.length>0)for(let b of l)i.push((0,h.v8)(b,a));return i.push("data: [DONE]\n\n"),{success:!0,response:new Response(i.join(""),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*"}})}}(p,b):function(a,b){let c=j(b);if(a===f.h.OPENAI)return{success:!0,response:new Response(JSON.stringify(c),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})};let d=(0,e.Ws)(a);d.model=b;let g=k(c),h=[];for(let b of g){let c=(0,e.Y8)(f.h.OPENAI,a,b,d);c?.length>0&&h.push(...c)}let i=(0,e.Y8)(f.h.OPENAI,a,null,d);return i?.length>0&&h.push(...i),{success:!0,response:new Response(JSON.stringify(function(a,b){if(!a||0===a.length)return j("unknown");let c=a[a.length-1];if(b===f.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}(h,a)),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}(p,b)}function j(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 k(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}]}},39609:(a,b,c)=>{let d=globalThis.fetch,e=null,f=null,g={},h=["cloudcode-pa.googleapis.com","daily-cloudcode-pa.googleapis.com","googleapis.com"],i="x-request-source",j="local",k=["8.8.8.8","8.8.4.4"];async function l(a){if(g[a])return g[a];try{let b=await Promise.resolve().then(c.t.bind(c,14985,23)),{promisify:d}=await Promise.resolve().then(c.t.bind(c,28354,23)),e=new b.Resolver;e.setServers(k);let f=d(e.resolve4.bind(e)),h=await f(a);return g[a]=h[0],h[0]}catch(b){return console.warn(`[ProxyFetch] DNS resolve failed for ${a}:`,b.message),null}}function m(a){if(!a)return null;try{return new URL(a),a}catch{return`http://${a}`}}async function n(a){let b=m(a);if(!b)return null;if(!e||f!==b){try{e?.close?.()}catch{}let{ProxyAgent:a}=await c.e(7774).then(c.t.bind(c,47774,19));e=new a({uri:b}),f=b}return e}async function o(a,b,d){let e=await Promise.resolve().then(c.t.bind(c,55591,23)),f=await Promise.resolve().then(c.t.bind(c,91645,23)),{Readable:g}=c(27910);return new Promise((c,h)=>{let i=new f.Socket;i.connect(443,b,()=>{let b={socket:i,servername:a.hostname,rejectUnauthorized:!1,path:a.pathname+a.search,method:d.method||"POST",headers:{...d.headers,Host:a.hostname}},f=e.request(b,a=>{let b={ok:a.statusCode>=200&&a.statusCode<300,status:a.statusCode,statusText:a.statusMessage,headers:new Map(Object.entries(a.headers)),body:g.toWeb(a),text:async()=>{let b=[];for await(let c of a)b.push(c);return Buffer.concat(b).toString()},json:async()=>JSON.parse(await b.text())};c(b)});f.on("error",h),d.body&&f.write("string"==typeof d.body?d.body:JSON.stringify(d.body)),f.end()}),i.on("error",h)})}async function p(a,b={}){let c="string"==typeof a?a:a.toString();if(function(a,b){if(!b?.headers)return!1;let c=b.headers;if(c[i]!==j&&c[i.charAt(0).toUpperCase()+i.slice(1)]!==j){let b=new URL(a).hostname;return h.some(a=>b.includes(a))&&console.warn(`[ProxyFetch] MITM bypass NOT triggered for ${b} - missing header`),!1}let d=new URL(a).hostname;return h.some(a=>d.includes(a))}(c,b))try{let a=new URL(c),d=await l(a.hostname);if(d)return await o(a,d,b)}catch(a){console.warn(`[ProxyFetch] MITM bypass failed: ${a.message}`)}let e=m(function(a){let b=process.env.NO_PROXY||process.env.no_proxy;if(b){let c=new URL(a).hostname.toLowerCase();if(b.split(",").map(a=>a.trim().toLowerCase()).some(a=>"*"===a||(a.startsWith(".")?c.endsWith(a)||c===a.slice(1):c===a||c.endsWith(`.${a}`))))return null}return"https:"===new URL(a).protocol?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}(c));if(e)try{let c=await n(e);return await d(a,{...b,dispatcher:c})}catch(a){console.warn(`[ProxyFetch] Proxy failed, falling back to direct: ${a.message}`)}return d(a,b)}"u">typeof caches&&"object"==typeof caches||globalThis.fetch===p||(globalThis.fetch=p)},48895:(a,b,c)=>{c.a(a,async(a,b)=>{try{c(39609),c(2255),c(57247),c(14170),c(33110),c(57647),c(40669),c(12557),c(8590);var d=c(92500),e=c(55330);c(43659),c(71857);var f=a([d,e]);[d,e]=f.then?(await f)():f,b()}catch(a){b(a)}})},59657:(a,b,c)=>{function d({onDisconnect:a,onError:b,log:c,provider:e,model:f}={}){let g=new AbortController,h=Date.now(),i=!1,j=null,k=a=>{let b=Date.now()-h,c=e?.toUpperCase()||"UNKNOWN";console.log(`[${new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit",second:"2-digit"})}] 🌊 [STREAM] ${c} | ${f||"unknown"} | ${b}ms | ${a}`)};return{signal:g.signal,startTime:h,isConnected:()=>!i,handleDisconnect:(b="client_closed")=>{i||(i=!0,k(`disconnect: ${b}`),j=setTimeout(()=>{g.abort()},500),a?.({reason:b,duration:Date.now()-h}))},handleComplete:()=>{!i&&(i=!0,k("complete"),j&&(clearTimeout(j),j=null))},handleError:a=>{if(!i){if(i=!0,j&&(clearTimeout(j),j=null),"AbortError"===a.name)return void k("aborted");k(`error: ${a.message}`),b?.(a)}},abort:()=>g.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})},71336:(a,b,c)=>{c.d(b,{q7:()=>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{f.existsSync(h)||f.mkdirSync(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()),i=String(a.getMilliseconds()).padStart(3,"0");return`${c}${d}${e}_${f}${g}${h}_${i}`}(),e=c.replace(/[/:]/g,"-"),i=`${a}_${b}_${e}_${d}`,j=g.join(h,i);return f.mkdirSync(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)try{let d=g.join(a,b);f.writeFileSync(d,JSON.stringify(c,null,2))}catch(a){console.log(`[LOG] Failed to write ${b}:`,a.message)}}function l(a){return a?{...a}:{}}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)try{let b=g.join(d,"5_res_provider.txt");f.appendFileSync(b,a)}catch(a){}},appendOpenAIChunk(a){if(f&&d)try{let b=g.join(d,"6_res_openai.txt");f.appendFileSync(b,a)}catch(a){}},logConvertedResponse(a){k(d,"7_res_client.json",{timestamp:new Date().toISOString(),body:a})},appendConvertedChunk(a){if(f&&d)try{let b=g.join(d,"7_res_client.txt");f.appendFileSync(b,a)}catch(a){}},logError(a,b=null){k(d,"6_error.json",{timestamp:new Date().toISOString(),error:a?.message||String(a),stack:a?.stack,requestBody:b})}}}},71857:(a,b,c)=>{c.d(b,{i5:()=>n,l2:()=>o,lm:()=>g.lm,v8:()=>h.v8});var d=c(33110),e=c(14170),f=c(47370),g=c(73483),h=c(9024);let i=new TextDecoder,j=new TextEncoder,k="translate",l="passthrough";function m(a={}){let{mode:b=k,targetFormat:c,sourceFormat:n,provider:o=null,reqLogger:p=null,toolNameMap:q=null,model:r=null,connectionId:s=null,body:t=null,onStreamComplete:u=null,apiKey:v=null}=a,w="",x=null,y=b===k?{...(0,d.Ws)(n),provider:o,toolNameMap:q,model:r}:null,z=0,A="",B="",C=null;return new TransformStream({transform(a,f){C||(C=Date.now());let k=i.decode(a,{stream:!0});w+=k,p?.appendProviderChunk?.(k);let m=w.split("\n");for(let a of(w=m.pop()||"",m)){let i=a.trim();if(b===l){let b,c=!1;if(i.startsWith("data:")&&"[DONE]"!==i.slice(5).trim())try{let a=JSON.parse(i.slice(5).trim()),d=(0,h.A4)(a),f=!1;if(a.object||(a.object="chat.completion.chunk",f=!0),a.created||(a.created=Math.floor(Date.now()/1e3),f=!0),void 0!==a.prompt_filter_results&&(delete a.prompt_filter_results,f=!0),a?.choices)for(let b of a.choices)void 0!==b.content_filter_results&&(delete b.content_filter_results,f=!0);if(!(0,h.c2)(a,e.h.OPENAI))continue;let j=a.choices?.[0]?.delta,k=j?.content,l=j?.reasoning_content;k&&"string"==typeof k&&(z+=k.length,A+=k),l&&"string"==typeof l&&(z+=l.length,B+=l);let m=(0,g.f5)(a);m&&(x=m);let n=a.choices?.[0]?.finish_reason;if(n&&!(0,g.Gh)(a.usage)){let d=(0,g.OF)(t,z,e.h.OPENAI);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
1
+ "use strict";exports.id=8895,exports.ids=[8895],exports.modules={5016:(a,b,c)=>{c.d(b,{N:()=>l});var d=c(14170),e=c(33110),f=c(73483),g=c(43659),h=c(2255),i=c(81626),j=c(86171),k=c(47370);async function l({providerResponse:a,provider:b,model:c,sourceFormat:l,targetFormat:m,body:n,stream:o,translatedBody:p,finalBody:q,requestStartTime:r,connectionId:s,apiKey:t,clientRawRequest:u,onRequestSuccess:v,reqLogger:w,trackDone:x,appendLog:y}){let z;if(x(),(a.headers.get("content-type")||"").includes("text/event-stream")){let b=await a.text(),d=(0,i.F)(b,c);if(!d)return y({status:`FAILED ${h.gx.BAD_GATEWAY}`}),(0,g.A1)(h.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");z=d}else try{z=await a.json()}catch(a){return y({status:`FAILED ${h.gx.BAD_GATEWAY}`}),console.error(`[ChatCore] Failed to parse JSON from ${b}:`,a.message),(0,g.A1)(h.gx.BAD_GATEWAY,`Invalid JSON response from ${b}`)}w.logProviderResponse(a.status,a.statusText,a.headers,z),v&&await v();let A=(0,j.MK)(z);y({tokens:A,status:"200 OK"}),(0,j.qr)({provider:b,model:c,tokens:A,connectionId:s,apiKey:t,endpoint:u?.endpoint});let B=(0,e.nZ)(m,l)?function(a,b,c){if(b===c||b===d.h.OPENAI)return a;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?g+=a.text:void 0!==a.text&&(f+=a.text),a.functionCall&&h.push({id:`call_${a.functionCall.name}_${Date.now()}_${h.length}`,type:"function",function:{name:a.functionCall.name,arguments:JSON.stringify(a.functionCall.args||{})}});let i={role:"assistant"};f&&(i.content=f),g&&(i.reasoning_content=g),h.length>0&&(i.tool_calls=h),i.content||i.tool_calls||(i.content="");let j=(c.finishReason||"stop").toLowerCase();"stop"===j&&h.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}(z,m,l):z;if(B.object||(B.object="chat.completion"),B.created||(B.created=Math.floor(Date.now()/1e3)),delete B.prompt_filter_results,B?.choices)for(let a of B.choices)delete a.content_filter_results;B?.usage&&(B.usage=(0,f.WL)((0,f.O9)(B.usage),l)),w.logConvertedResponse(B);let C=Date.now()-r;return(0,k.ox)((0,j.$R)({provider:b,model:c,connectionId:s,latency:{ttft:C,total:C},tokens:A||{prompt_tokens:0,completion_tokens:0},request:(0,j.Fo)(n,o),providerRequest:q||p||null,providerResponse:z||null,response:{content:B?.choices?.[0]?.message?.content||B?.content||null,thinking:B?.choices?.[0]?.message?.reasoning_content||B?.reasoning_content||null,finish_reason:B?.choices?.[0]?.finish_reason||"unknown"},status:"success"},{endpoint:u?.endpoint||null})).catch(a=>{console.error("[RequestDetail] Failed to save:",a.message)}),{success:!0,response:new Response(JSON.stringify(B),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}},20623:(a,b,c)=>{c.d(b,{$:()=>l,M:()=>k});var d=c(14170),e=c(33110),f=c(71857),g=c(59657),h=c(86171),i=c(47370);let j={"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*"};function k({providerResponse:a,provider:b,model:c,sourceFormat:k,targetFormat:l,userAgent:m,body:n,stream:o,translatedBody:p,finalBody:q,requestStartTime:r,connectionId:s,apiKey:t,clientRawRequest:u,onRequestSuccess:v,reqLogger:w,toolNameMap:x,streamController:y,onStreamComplete:z}){v&&v();let A=function({provider:a,sourceFormat:b,targetFormat:c,userAgent:g,reqLogger:h,toolNameMap:i,model:j,connectionId:k,body:l,onStreamComplete:m,apiKey:n}){let o=g?.toLowerCase().includes("droid")||g?.toLowerCase().includes("codex-cli");if("codex"===a&&c===d.h.OPENAI_RESPONSES&&!o){let c;return c=b===d.h.OPENAI_RESPONSES?d.h.OPENAI_RESPONSES:b===d.h.CLAUDE?d.h.CLAUDE:b===d.h.ANTIGRAVITY||b===d.h.GEMINI||b===d.h.GEMINI_CLI?d.h.ANTIGRAVITY:d.h.OPENAI,(0,f.i5)(d.h.OPENAI_RESPONSES,c,a,h,i,j,k,l,m,n)}return(0,e.nZ)(c,b)?(0,f.i5)(c,b,a,h,i,j,k,l,m,n):(0,f.l2)(a,h,j,k,l,m,n)}({provider:b,sourceFormat:k,targetFormat:l,userAgent:m,reqLogger:w,toolNameMap:x,model:c,connectionId:s,body:n,onStreamComplete:z,apiKey:t}),B=(0,g.Jb)(a,A,y),C=`${Date.now()}-${Math.random().toString(36).slice(2,11)}`;return(0,i.ox)((0,h.$R)({provider:b,model:c,connectionId:s,latency:{ttft:0,total:Date.now()-r},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,h.Fo)(n,o),providerRequest:q||p||null,providerResponse:"[Streaming - raw response not captured]",response:{content:"[Streaming in progress...]",thinking:null,type:"streaming"},status:"success"},{id:C})).catch(a=>{console.error("[RequestDetail] Failed to save streaming request:",a.message)}),{success:!0,response:new Response(B,{headers:j})}}function l({provider:a,model:b,connectionId:c,apiKey:d,requestStartTime:e,body:f,stream:g,finalBody:j,translatedBody:k,clientRawRequest:l}){let m=`${Date.now()}-${Math.random().toString(36).slice(2,11)}`;return{onStreamComplete:(n,o,p)=>{let q={ttft:p?p-e:Date.now()-e,total:Date.now()-e};(0,i.ox)((0,h.$R)({provider:a,model:b,connectionId:c,latency:q,tokens:o||{prompt_tokens:0,completion_tokens:0},request:(0,h.Fo)(f,g),providerRequest:j||k||null,providerResponse:n.content||"[Empty streaming response]",response:{content:n.content||"[Empty streaming response]",thinking:n.thinking||null,type:"streaming"},status:"success"},{id:m})).catch(a=>{console.error("[RequestDetail] Failed to update streaming content:",a.message)}),(0,h.qr)({provider:a,model:b,tokens:o,connectionId:c,apiKey:d,endpoint:l?.endpoint,label:"STREAM USAGE"})},streamDetailId:m}}},27349:(a,b,c)=>{c.d(b,{c:()=>i});var d=c(57647),e=c(33110),f=c(14170),g=c(2255),h=c(71857);function i(a,b,c=""){if(!c.includes("claude-cli")||!a.messages?.length)return null;let l=a.messages,m=a=>"string"==typeof a?a:Array.isArray(a)?a.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"",n=!1,o=l[l.length-1];if(o?.role==="assistant"&&o.content?.[0]?.text==="{"&&(n=!0),n||"Warmup"===m(l[0]?.content)&&(n=!0),n||1!==l.length||l[0]?.role!=="user"||"count"===m(l[0]?.content)&&(n=!0),!n&&g.C8?.length){let a=l.filter(a=>"user"===a.role).map(a=>m(a.content)).join(" ");g.C8.some(b=>a.includes(b))&&(n=!0)}if(!n)return null;let p=(0,d.Tz)(a);return!1!==a.stream?function(a,b){let c=j(b),d=(0,e.Ws)(a);d.model=b;let g=k(c),i=[];for(let b of g){let c=(0,e.Y8)(f.h.OPENAI,a,b,d);if(c?.length>0)for(let b of c)i.push((0,h.v8)(b,a))}let l=(0,e.Y8)(f.h.OPENAI,a,null,d);if(l?.length>0)for(let b of l)i.push((0,h.v8)(b,a));return i.push("data: [DONE]\n\n"),{success:!0,response:new Response(i.join(""),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*"}})}}(p,b):function(a,b){let c=j(b);if(a===f.h.OPENAI)return{success:!0,response:new Response(JSON.stringify(c),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})};let d=(0,e.Ws)(a);d.model=b;let g=k(c),h=[];for(let b of g){let c=(0,e.Y8)(f.h.OPENAI,a,b,d);c?.length>0&&h.push(...c)}let i=(0,e.Y8)(f.h.OPENAI,a,null,d);return i?.length>0&&h.push(...i),{success:!0,response:new Response(JSON.stringify(function(a,b){if(!a||0===a.length)return j("unknown");let c=a[a.length-1];if(b===f.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}(h,a)),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}(p,b)}function j(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 k(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}]}},39609:(a,b,c)=>{let d=globalThis.fetch,e=null,f=null,g={},h=["cloudcode-pa.googleapis.com","daily-cloudcode-pa.googleapis.com","googleapis.com"],i="x-request-source",j="local",k=["8.8.8.8","8.8.4.4"];async function l(a){if(g[a])return g[a];try{let b=await Promise.resolve().then(c.t.bind(c,14985,23)),{promisify:d}=await Promise.resolve().then(c.t.bind(c,28354,23)),e=new b.Resolver;e.setServers(k);let f=d(e.resolve4.bind(e)),h=await f(a);return g[a]=h[0],h[0]}catch(b){return console.warn(`[ProxyFetch] DNS resolve failed for ${a}:`,b.message),null}}function m(a){if(!a)return null;try{return new URL(a),a}catch{return`http://${a}`}}async function n(a){let b=m(a);if(!b)return null;if(!e||f!==b){try{e?.close?.()}catch{}let{ProxyAgent:a}=await c.e(7774).then(c.t.bind(c,47774,19));e=new a({uri:b}),f=b}return e}async function o(a,b,d){let e=await Promise.resolve().then(c.t.bind(c,55591,23)),f=await Promise.resolve().then(c.t.bind(c,91645,23)),{Readable:g}=c(27910);return new Promise((c,h)=>{let i=new f.Socket;i.connect(443,b,()=>{let b={socket:i,servername:a.hostname,rejectUnauthorized:!1,path:a.pathname+a.search,method:d.method||"POST",headers:{...d.headers,Host:a.hostname}},f=e.request(b,a=>{let b={ok:a.statusCode>=200&&a.statusCode<300,status:a.statusCode,statusText:a.statusMessage,headers:new Map(Object.entries(a.headers)),body:g.toWeb(a),text:async()=>{let b=[];for await(let c of a)b.push(c);return Buffer.concat(b).toString()},json:async()=>JSON.parse(await b.text())};c(b)});f.on("error",h),d.body&&f.write("string"==typeof d.body?d.body:JSON.stringify(d.body)),f.end()}),i.on("error",h)})}async function p(a,b={}){let c="string"==typeof a?a:a.toString();if(function(a,b){if(!b?.headers)return!1;let c=b.headers;if(c[i]!==j&&c[i.charAt(0).toUpperCase()+i.slice(1)]!==j){let b=new URL(a).hostname;return h.some(a=>b.includes(a))&&console.warn(`[ProxyFetch] MITM bypass NOT triggered for ${b} - missing header`),!1}let d=new URL(a).hostname;return h.some(a=>d.includes(a))}(c,b))try{let a=new URL(c),d=await l(a.hostname);if(d)return await o(a,d,b)}catch(a){console.warn(`[ProxyFetch] MITM bypass failed: ${a.message}`)}let e=m(function(a){let b=process.env.NO_PROXY||process.env.no_proxy;if(b){let c=new URL(a).hostname.toLowerCase();if(b.split(",").map(a=>a.trim().toLowerCase()).some(a=>"*"===a||(a.startsWith(".")?c.endsWith(a)||c===a.slice(1):c===a||c.endsWith(`.${a}`))))return null}return"https:"===new URL(a).protocol?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}(c));if(e)try{let c=await n(e);return await d(a,{...b,dispatcher:c})}catch(a){console.warn(`[ProxyFetch] Proxy failed, falling back to direct: ${a.message}`)}return d(a,b)}"u">typeof caches&&"object"==typeof caches||globalThis.fetch===p||(globalThis.fetch=p)},48895:(a,b,c)=>{c.a(a,async(a,b)=>{try{c(39609),c(2255),c(57247),c(14170),c(33110),c(57647),c(40669),c(12557),c(8590);var d=c(92500),e=c(55330);c(43659),c(71857);var f=a([d,e]);[d,e]=f.then?(await f)():f,b()}catch(a){b(a)}})},59657:(a,b,c)=>{function d({onDisconnect:a,onError:b,log:c,provider:e,model:f}={}){let g=new AbortController,h=Date.now(),i=!1,j=null,k=a=>{let b=Date.now()-h,c=e?.toUpperCase()||"UNKNOWN";console.log(`[${new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit",second:"2-digit"})}] 🌊 [STREAM] ${c} | ${f||"unknown"} | ${b}ms | ${a}`)};return{signal:g.signal,startTime:h,isConnected:()=>!i,handleDisconnect:(b="client_closed")=>{i||(i=!0,k(`disconnect: ${b}`),j=setTimeout(()=>{g.abort()},500),a?.({reason:b,duration:Date.now()-h}))},handleComplete:()=>{!i&&(i=!0,k("complete"),j&&(clearTimeout(j),j=null))},handleError:a=>{if(!i){if(i=!0,j&&(clearTimeout(j),j=null),"AbortError"===a.name)return void k("aborted");k(`error: ${a.message}`),b?.(a)}},abort:()=>g.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})},71336:(a,b,c)=>{c.d(b,{q7:()=>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{f.existsSync(h)||f.mkdirSync(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()),i=String(a.getMilliseconds()).padStart(3,"0");return`${c}${d}${e}_${f}${g}${h}_${i}`}(),e=c.replace(/[/:]/g,"-"),i=`${a}_${b}_${e}_${d}`,j=g.join(h,i);return f.mkdirSync(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)try{let d=g.join(a,b);f.writeFileSync(d,JSON.stringify(c,null,2))}catch(a){console.log(`[LOG] Failed to write ${b}:`,a.message)}}function l(a){return a?{...a}:{}}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)try{let b=g.join(d,"5_res_provider.txt");f.appendFileSync(b,a)}catch(a){}},appendOpenAIChunk(a){if(f&&d)try{let b=g.join(d,"6_res_openai.txt");f.appendFileSync(b,a)}catch(a){}},logConvertedResponse(a){k(d,"7_res_client.json",{timestamp:new Date().toISOString(),body:a})},appendConvertedChunk(a){if(f&&d)try{let b=g.join(d,"7_res_client.txt");f.appendFileSync(b,a)}catch(a){}},logError(a,b=null){k(d,"6_error.json",{timestamp:new Date().toISOString(),error:a?.message||String(a),stack:a?.stack,requestBody:b})}}}},71857:(a,b,c)=>{c.d(b,{i5:()=>n,l2:()=>o,lm:()=>g.lm,v8:()=>h.v8});var d=c(33110),e=c(14170),f=c(47370),g=c(73483),h=c(9024);let i=new TextDecoder,j=new TextEncoder,k="translate",l="passthrough";function m(a={}){let{mode:b=k,targetFormat:c,sourceFormat:n,provider:o=null,reqLogger:p=null,toolNameMap:q=null,model:r=null,connectionId:s=null,body:t=null,onStreamComplete:u=null,apiKey:v=null}=a,w="",x=null,y=b===k?{...(0,d.Ws)(n),provider:o,toolNameMap:q,model:r}:null,z=0,A="",B="",C=null;return new TransformStream({transform(a,f){C||(C=Date.now());let k=i.decode(a,{stream:!0});w+=k,p?.appendProviderChunk?.(k);let m=w.split("\n");for(let a of(w=m.pop()||"",m)){let i=a.trim();if(b===l){let b,c=!1;if(i.startsWith("data:")&&"[DONE]"!==i.slice(5).trim())try{let a=JSON.parse(i.slice(5).trim()),d=(0,h.A4)(a),f=!1;if(void 0!==a.choices&&(a.object||(a.object="chat.completion.chunk",f=!0),a.created||(a.created=Math.floor(Date.now()/1e3),f=!0)),void 0!==a.prompt_filter_results&&(delete a.prompt_filter_results,f=!0),a?.choices)for(let b of a.choices)void 0!==b.content_filter_results&&(delete b.content_filter_results,f=!0);if(!(0,h.c2)(a,e.h.OPENAI))continue;let j=a.choices?.[0]?.delta,k=j?.content,l=j?.reasoning_content;k&&"string"==typeof k&&(z+=k.length,A+=k),l&&"string"==typeof l&&(z+=l.length,B+=l);let m=(0,g.f5)(a);m&&(x=m);let n=a.choices?.[0]?.finish_reason;if(n&&!(0,g.Gh)(a.usage)){let d=(0,g.OF)(t,z,e.h.OPENAI);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
2
2
  `,x=d,c=!0}else if(n&&x){let d=(0,g.O9)(x);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
3
3
  `,c=!0}else(d||f)&&(b=`data: ${JSON.stringify(a)}
4
- `,c=!0)}catch{}c||(b=a.startsWith("data:")&&!a.startsWith("data: ")?"data: "+a.slice(5)+"\n":a+"\n"),p?.appendConvertedChunk?.(b),f.enqueue(j.encode(b));continue}if(!i)continue;let k=(0,h.tV)(i);if(!k)continue;if(k&&k.done){let a="data: [DONE]\n\n";p?.appendConvertedChunk?.(a),f.enqueue(j.encode(a));continue}if(k.delta?.text&&(z+=k.delta.text.length,A+=k.delta.text),k.delta?.thinking&&(z+=k.delta.thinking.length,B+=k.delta.thinking),k.choices?.[0]?.delta?.content&&(z+=k.choices[0].delta.content.length,A+=k.choices[0].delta.content),k.choices?.[0]?.delta?.reasoning_content&&(z+=k.choices[0].delta.reasoning_content.length,B+=k.choices[0].delta.reasoning_content),k.candidates?.[0]?.content?.parts)for(let a of k.candidates[0].content.parts)a.text&&"string"==typeof a.text&&(z+=a.text.length,!0===a.thought?B+=a.text:A+=a.text);let m=(0,g.f5)(k);m&&(y.usage=m);let o=(0,d.Y8)(c,n,k,y);if(o?._openaiIntermediate)for(let a of o._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);p?.appendOpenAIChunk?.(b)}if(o?.length>0)for(let a of o){if(!(0,h.c2)(a,n))continue;let b="message_delta"===a.type||a.choices?.[0]?.finish_reason;if(y.finishReason&&b&&!(0,g.Gh)(a.usage)&&z>0){let b=(0,g.OF)(t,z,n);a.usage=(0,g.WL)(b,n),y.usage=b}else if(y.finishReason&&b&&y.usage){let b=(0,g.O9)(y.usage);a.usage=(0,g.WL)(b,n)}let c=(0,h.v8)(a,n);p?.appendConvertedChunk?.(c),f.enqueue(j.encode(c))}}},flush(a){(0,f.uw)(r,o,s,!1);try{let k=i.decode();if(k&&(w+=k),b===l){if(w){let b=w;w.startsWith("data:")&&!w.startsWith("data: ")&&(b="data: "+w.slice(5)),p?.appendConvertedChunk?.(b),a.enqueue(j.encode(b))}!(0,g.Gh)(x)&&z>0&&(x=(0,g.OF)(t,z,e.h.OPENAI)),(0,g.Gh)(x)?(0,g.IF)(o,x,r,s,v):(0,f.E5)({model:r,provider:o,connectionId:s,tokens:null,status:"200 OK"}).catch(()=>{});let b="data: [DONE]\n\n";p?.appendConvertedChunk?.(b),a.enqueue(j.encode(b)),u&&u({content:A,thinking:B},x,C);return}if(w.trim()){let b=(0,h.tV)(w.trim());if(b&&!b.done){let f=(0,d.Y8)(c,n,b,y);if(f?._openaiIntermediate)for(let a of f._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);p?.appendOpenAIChunk?.(b)}if(f?.length>0)for(let b of f){let c=(0,h.v8)(b,n);p?.appendConvertedChunk?.(c),a.enqueue(j.encode(c))}}}let m=(0,d.Y8)(c,n,null,y);if(m?._openaiIntermediate)for(let a of m._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);p?.appendOpenAIChunk?.(b)}if(m?.length>0)for(let b of m){let c=(0,h.v8)(b,n);p?.appendConvertedChunk?.(c),a.enqueue(j.encode(c))}let q="data: [DONE]\n\n";p?.appendConvertedChunk?.(q),a.enqueue(j.encode(q)),!(0,g.Gh)(y?.usage)&&z>0&&(y.usage=(0,g.OF)(t,z,n)),(0,g.Gh)(y?.usage)?(0,g.IF)(y.provider||c,y.usage,r,s,v):(0,f.E5)({model:r,provider:o,connectionId:s,tokens:null,status:"200 OK"}).catch(()=>{}),u&&u({content:A,thinking:B},y?.usage,C)}catch(a){console.log("Error in flush:",a)}}})}function n(a,b,c=null,d=null,e=null,f=null,g=null,h=null,i=null,j=null){return m({mode:k,targetFormat:a,sourceFormat:b,provider:c,reqLogger:d,toolNameMap:e,model:f,connectionId:g,body:h,onStreamComplete:i,apiKey:j})}function o(a=null,b=null,c=null,d=null,e=null,f=null,g=null){return m({mode:l,provider:a,reqLogger:b,model:c,connectionId:d,body:e,onStreamComplete:f,apiKey:g})}},81626:(a,b,c)=>{function d(a,b){let c;if(!a.trim())return;let d=a.match(/^event:\s*(.+)$/m),e=a.match(/^data:\s*(.+)$/m);if(!d||!e)return;let f=d[1].trim(),g=e[1].trim();if("[DONE]"!==g){try{c=JSON.parse(g)}catch{return}"response.created"===f?(b.responseId=c.response?.id||b.responseId,b.created=c.response?.created_at||b.created):"response.output_item.done"===f?b.items.set(c.output_index??0,c.item):"response.completed"===f?(b.status="completed",c.response?.usage&&(b.usage.input_tokens=c.response.usage.input_tokens||0,b.usage.output_tokens=c.response.usage.output_tokens||0,b.usage.total_tokens=c.response.usage.total_tokens||0)):"response.failed"===f&&(b.status="failed")}}c.d(b,{I:()=>m,F:()=>l});let e={input_tokens:0,output_tokens:0,total_tokens:0};async function f(a){if(!a||"function"!=typeof a.getReader)return{id:`resp_${Date.now()}`,object:"response",created_at:Math.floor(Date.now()/1e3),status:"failed",output:[],usage:{...e}};let b=a.getReader(),c=new TextDecoder,f="",g={responseId:"",created:Math.floor(Date.now()/1e3),status:"in_progress",usage:{...e},items:new Map};try{for(;;){let{done:a,value:e}=await b.read();if(a)break;let h=(f+=c.decode(e,{stream:!0})).split("\n\n");for(let a of(f=h.pop()||"",h))d(a,g)}f.trim()&&d(f,g)}finally{b.releaseLock()}let h=[],i=g.items.size>0?Math.max(...g.items.keys()):-1;for(let a=0;a<=i;a++)h.push(g.items.get(a)||{type:"message",content:[],role:"assistant"});return{id:g.responseId||`resp_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,object:"response",created_at:g.created,status:g.status||"completed",output:h,usage:g.usage}}var g=c(43659),h=c(2255),i=c(14170),j=c(86171),k=c(47370);function l(a,b){let c=[];for(let b of String(a||"").split("\n")){let a=b.trim();if(!a.startsWith("data:"))continue;let d=a.slice(5).trim();if(d&&"[DONE]"!==d)try{c.push(JSON.parse(d))}catch{}}if(0===c.length)return null;let d=c[0],e=[],f=[],g="stop",h=null;for(let a of c){let b=a?.choices?.[0],c=b?.delta||{};"string"==typeof c.content&&c.content.length>0&&e.push(c.content),"string"==typeof c.reasoning_content&&c.reasoning_content.length>0&&f.push(c.reasoning_content),b?.finish_reason&&(g=b.finish_reason),a?.usage&&"object"==typeof a.usage&&(h=a.usage)}let i={role:"assistant",content:e.join("")};f.length>0&&(i.reasoning_content=f.join(""));let j={id:d.id||`chatcmpl-${Date.now()}`,object:"chat.completion",created:d.created||Math.floor(Date.now()/1e3),model:d.model||b||"unknown",choices:[{index:0,message:i,finish_reason:g}]};return h&&(j.usage=h),j}async function m({providerResponse:a,sourceFormat:b,provider:c,model:d,body:e,stream:m,translatedBody:n,finalBody:o,requestStartTime:p,connectionId:q,apiKey:r,clientRawRequest:s,onRequestSuccess:t,trackDone:u,appendLog:v}){let w=a.headers.get("content-type")||"";if(!(w.includes("text/event-stream")||""===w&&"codex"===c))return null;u();let x={provider:c,model:d,connectionId:q,request:(0,j.Fo)(e,m),providerRequest:o||n||null};if("codex"===c||b===i.h.OPENAI_RESPONSES)try{let e,g=await f(a.body);t&&await t();let h=g.usage||{};v({tokens:h,status:"200 OK"}),(0,j.qr)({provider:c,model:d,tokens:h,connectionId:q,apiKey:r,endpoint:s?.endpoint});let l=g.output?.find(a=>"message"===a.type),m=l?.content?.find(a=>"output_text"===a.type)?.text||l?.content?.[0]?.text||null,n=Date.now()-p;if((0,k.ox)((0,j.$R)({...x,latency:{ttft:n,total:n},tokens:{prompt_tokens:h.input_tokens||0,completion_tokens:h.output_tokens||0},response:{content:m,thinking:null,finish_reason:g.status||"unknown"},status:"success"},{endpoint:s?.endpoint||null})).catch(()=>{}),b===i.h.OPENAI_RESPONSES)return{success:!0,response:new Response(JSON.stringify(g),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})};let o=h.input_tokens||0,u=h.output_tokens||0;return e=b===i.h.ANTIGRAVITY||b===i.h.GEMINI||b===i.h.GEMINI_CLI?{response:{candidates:[{content:{role:"model",parts:[{text:m||""}]},finishReason:"STOP",index:0}],usageMetadata:{promptTokenCount:o,candidatesTokenCount:u,totalTokenCount:o+u},modelVersion:d,responseId:g.id||`resp_${Date.now()}`}}:{id:g.id||`chatcmpl-${Date.now()}`,object:"chat.completion",created:g.created_at||Math.floor(Date.now()/1e3),model:g.model||d,choices:[{index:0,message:{role:"assistant",content:m||""},finish_reason:"completed"===g.status?"stop":g.status||"stop"}],usage:{prompt_tokens:o,completion_tokens:u,total_tokens:o+u}},{success:!0,response:new Response(JSON.stringify(e),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}catch(a){return console.error("[ChatCore] Responses API SSE→JSON failed:",a),(0,g.A1)(h.gx.BAD_GATEWAY,"Failed to convert streaming response to JSON")}try{let b=await a.text(),e=l(b,d);if(!e)return(0,g.A1)(h.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");t&&await t();let f=e.usage||{};v({tokens:f,status:"200 OK"}),(0,j.qr)({provider:c,model:d,tokens:f,connectionId:q,apiKey:r,endpoint:s?.endpoint});let i=Date.now()-p;return(0,k.ox)((0,j.$R)({...x,latency:{ttft:i,total:i},tokens:f,response:{content:e.choices?.[0]?.message?.content||null,thinking:e.choices?.[0]?.message?.reasoning_content||null,finish_reason:e.choices?.[0]?.finish_reason||"unknown"},status:"success"},{endpoint:s?.endpoint||null})).catch(()=>{}),{success:!0,response:new Response(JSON.stringify(e),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}catch(a){return console.error("[ChatCore] Chat Completions SSE→JSON failed:",a),(0,g.A1)(h.gx.BAD_GATEWAY,"Failed to convert streaming response to JSON")}}},86171:(a,b,c)=>{c.d(b,{$R:()=>i,Fo:()=>g,MK:()=>h,qr:()=>j});var d=c(47370),e=c(71857);let f=["temperature","top_p","top_k","max_tokens","max_completion_tokens","thinking","reasoning","enable_thinking","presence_penalty","frequency_penalty","seed","stop","tools","tool_choice","response_format","prediction","store","metadata","n","logprobs","top_logprobs","logit_bias","user","parallel_tool_calls"];function g(a,b){let c={messages:a.messages||[],model:a.model,stream:b};for(let b of f)void 0!==a[b]&&(c[b]=a[b]);return c}function h(a){return a&&"object"==typeof a?a.usage?.input_tokens!==void 0?{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.usage?.prompt_tokens!==void 0?{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}:a.usageMetadata?{prompt_tokens:a.usageMetadata.promptTokenCount||0,completion_tokens:a.usageMetadata.candidatesTokenCount||0,reasoning_tokens:a.usageMetadata.thoughtsTokenCount}:null:null}function i(a,b={}){return{provider:a.provider||"unknown",model:a.model||"unknown",connectionId:a.connectionId||void 0,timestamp:new Date().toISOString(),latency:a.latency||{ttft:0,total:0},tokens:a.tokens||{prompt_tokens:0,completion_tokens:0},request:a.request,providerRequest:a.providerRequest||null,providerResponse:a.providerResponse||null,response:a.response||{},status:a.status||"success",...b}}function j({provider:a,model:b,tokens:c,connectionId:f,apiKey:g,endpoint:h,label:i="USAGE"}){if(!c||"object"!=typeof c)return;let j=c.input_tokens??c.prompt_tokens??0,k=c.output_tokens??c.completion_tokens??0;if(0===j&&0===k)return;let l=new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit"}),m=f?` | account=${f.slice(0,8)}...`:"";console.log(`${e.lm.green}[${l}] 📊 [${i}] ${a.toUpperCase()} | in=${j} | out=${k}${m}${e.lm.reset}`);let n={prompt_tokens:c.prompt_tokens??c.input_tokens??0,completion_tokens:c.completion_tokens??c.output_tokens??0};(0,d.sZ)({provider:a||"unknown",model:b||"unknown",tokens:n,timestamp:new Date().toISOString(),connectionId:f||void 0,apiKey:g||void 0,endpoint:h||null}).catch(()=>{})}},92500:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{w:()=>w});var e=c(57647),f=c(33110),g=c(14170),h=c(71857),i=c(59657),j=c(8590),k=c(71336),l=c(57247),m=c(43659),n=c(2255),o=c(27349),p=c(47370),q=c(55330),r=c(86171),s=c(81626),t=c(5016),u=c(20623),v=a([q]);async function w({body:a,modelInfo:b,credentials:c,log:d,onCredentialsRefreshed:v,onRequestSuccess:w,onDisconnect:x,clientRawRequest:y,connectionId:z,userAgent:A,apiKey:B,sourceFormatOverride:C}){let D,E,F,G,{provider:H,model:I}=b,J=Date.now(),K=C||(0,e.Tz)(a),L=(0,o.c)(a,I,A);if(L)return L;let M=l.Xg[H]||H,N=(0,l.ux)(M,I)||(0,e.jJ)(H),O=!0===a.stream||K===g.h.ANTIGRAVITY||K===g.h.GEMINI||K===g.h.GEMINI_CLI,P="openai"===H||"codex"===H,Q=!!P||!1!==a.stream,R=await (0,k.q7)(K,N,I);y&&R.logClientRawRequest(y.endpoint,y.body,y.headers),R.logRawRequest(a),d?.debug?.("FORMAT",`${K} → ${N} | stream=${Q}`);let S=(0,f.GH)(K,N,I,a,Q,c,H,R),T=S._toolNameMap;delete S._toolNameMap,S.model=I;let U=(0,q.SB)(H);(0,p.uw)(I,H,z,!0),(0,p.E5)({model:I,provider:H,connectionId:z,status:"PENDING"}).catch(()=>{});let V=S.messages?.length||S.input?.length||S.contents?.length||S.request?.contents?.length||0;d?.debug?.("REQUEST",`${H.toUpperCase()} | ${I} | ${V} msgs`);let W=(0,i.jd)({onDisconnect:a=>{(0,p.uw)(I,H,z,!1),x&&x(a)},onError:()=>(0,p.uw)(I,H,z,!1),log:d,provider:H,model:I});try{let a=await U.execute({model:I,body:S,stream:Q,credentials:c,signal:W.signal,log:d});D=a.response,E=a.url,F=a.headers,G=a.transformedBody,R.logTargetRequest(E,F,G)}catch(c){if((0,p.uw)(I,H,z,!1,!0),(0,p.E5)({model:I,provider:H,connectionId:z,status:`FAILED ${"AbortError"===c.name?499:n.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:H,model:I,connectionId:z,latency:{ttft:0,total:Date.now()-J},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,Q),providerRequest:S||null,response:{error:c.message||String(c),status:"AbortError"===c.name?499:502,thinking:null},status:"error"})).catch(()=>{}),"AbortError"===c.name)return W.handleError(c),(0,m.A1)(499,"Request aborted");let b=(0,m.lR)(c,H,I,n.gx.BAD_GATEWAY);return console.log(`${h.lm.red}[ERROR] ${b}${h.lm.reset}`),(0,m.A1)(n.gx.BAD_GATEWAY,b)}if(D.status===n.gx.UNAUTHORIZED||D.status===n.gx.FORBIDDEN){let a=await (0,j.qZ)(()=>U.refreshCredentials(c,d),3,d);if(a?.accessToken||a?.copilotToken){d?.info?.("TOKEN",`${H.toUpperCase()} | refreshed`),Object.assign(c,a),v&&await v(a);try{let a=await U.execute({model:I,body:S,stream:Q,credentials:c,signal:W.signal,log:d});a.response.ok&&(D=a.response,E=a.url)}catch{d?.warn?.("TOKEN",`${H.toUpperCase()} | retry after refresh failed`)}}else d?.warn?.("TOKEN",`${H.toUpperCase()} | refresh failed`)}if(!D.ok){(0,p.uw)(I,H,z,!1,!0);let{statusCode:b,message:c,retryAfterMs:e}=await (0,m.zL)(D,H);(0,p.E5)({model:I,provider:H,connectionId:z,status:`FAILED ${b}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:H,model:I,connectionId:z,latency:{ttft:0,total:Date.now()-J},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,Q),providerRequest:G||S||null,response:{error:c,status:b,thinking:null},status:"error"})).catch(()=>{});let f=(0,m.lR)(Error(c),H,I,b);return console.log(`${h.lm.red}[ERROR] ${f}${h.lm.reset}`),e&&"antigravity"===H&&d?.debug?.("RETRY",`Antigravity quota reset in ${Math.ceil(e/1e3)}s`),R.logError(Error(c),G||S),(0,m.A1)(b,f,e)}let X={provider:H,model:I,body:a,stream:Q,translatedBody:S,finalBody:G,requestStartTime:J,connectionId:z,apiKey:B,clientRawRequest:y,onRequestSuccess:w},Y=a=>(0,p.E5)({model:I,provider:H,connectionId:z,...a}).catch(()=>{}),Z=()=>(0,p.uw)(I,H,z,!1);if(!O&&P){let a=await (0,s.I)({...X,providerResponse:D,sourceFormat:K,trackDone:Z,appendLog:Y});if(a)return a}if(!Q)return(0,t.N)({...X,providerResponse:D,sourceFormat:K,targetFormat:N,reqLogger:R,trackDone:Z,appendLog:Y});let{onStreamComplete:$}=(0,u.$)({...X});return(0,u.M)({...X,providerResponse:D,sourceFormat:K,targetFormat:N,userAgent:A,reqLogger:R,toolNameMap:T,streamController:W,onStreamComplete:$})}q=(v.then?(await v)():v)[0],d()}catch(a){d(a)}})}};
4
+ `,c=!0)}catch{}c||(b=a.startsWith("data:")&&!a.startsWith("data: ")?"data: "+a.slice(5)+"\n":a+"\n"),p?.appendConvertedChunk?.(b),f.enqueue(j.encode(b));continue}if(!i)continue;let k=(0,h.tV)(i);if(!k)continue;if(k&&k.done){let a="data: [DONE]\n\n";p?.appendConvertedChunk?.(a),f.enqueue(j.encode(a));continue}if(k.delta?.text&&(z+=k.delta.text.length,A+=k.delta.text),k.delta?.thinking&&(z+=k.delta.thinking.length,B+=k.delta.thinking),k.choices?.[0]?.delta?.content&&(z+=k.choices[0].delta.content.length,A+=k.choices[0].delta.content),k.choices?.[0]?.delta?.reasoning_content&&(z+=k.choices[0].delta.reasoning_content.length,B+=k.choices[0].delta.reasoning_content),k.candidates?.[0]?.content?.parts)for(let a of k.candidates[0].content.parts)a.text&&"string"==typeof a.text&&(z+=a.text.length,!0===a.thought?B+=a.text:A+=a.text);let m=(0,g.f5)(k);m&&(y.usage=m);let o=(0,d.Y8)(c,n,k,y);if(o?._openaiIntermediate)for(let a of o._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);p?.appendOpenAIChunk?.(b)}if(o?.length>0)for(let a of o){if(!(0,h.c2)(a,n))continue;let b="message_delta"===a.type||a.choices?.[0]?.finish_reason;if(y.finishReason&&b&&!(0,g.Gh)(a.usage)&&z>0){let b=(0,g.OF)(t,z,n);a.usage=(0,g.WL)(b,n),y.usage=b}else if(y.finishReason&&b&&y.usage){let b=(0,g.O9)(y.usage);a.usage=(0,g.WL)(b,n)}let c=(0,h.v8)(a,n);p?.appendConvertedChunk?.(c),f.enqueue(j.encode(c))}}},flush(a){(0,f.uw)(r,o,s,!1);try{let k=i.decode();if(k&&(w+=k),b===l){if(w){let b=w;w.startsWith("data:")&&!w.startsWith("data: ")&&(b="data: "+w.slice(5)),p?.appendConvertedChunk?.(b),a.enqueue(j.encode(b))}!(0,g.Gh)(x)&&z>0&&(x=(0,g.OF)(t,z,e.h.OPENAI)),(0,g.Gh)(x)?(0,g.IF)(o,x,r,s,v):(0,f.E5)({model:r,provider:o,connectionId:s,tokens:null,status:"200 OK"}).catch(()=>{});let b="data: [DONE]\n\n";p?.appendConvertedChunk?.(b),a.enqueue(j.encode(b)),u&&u({content:A,thinking:B},x,C);return}if(w.trim()){let b=(0,h.tV)(w.trim());if(b&&!b.done){let f=(0,d.Y8)(c,n,b,y);if(f?._openaiIntermediate)for(let a of f._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);p?.appendOpenAIChunk?.(b)}if(f?.length>0)for(let b of f){let c=(0,h.v8)(b,n);p?.appendConvertedChunk?.(c),a.enqueue(j.encode(c))}}}let m=(0,d.Y8)(c,n,null,y);if(m?._openaiIntermediate)for(let a of m._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);p?.appendOpenAIChunk?.(b)}if(m?.length>0)for(let b of m){let c=(0,h.v8)(b,n);p?.appendConvertedChunk?.(c),a.enqueue(j.encode(c))}let q="data: [DONE]\n\n";p?.appendConvertedChunk?.(q),a.enqueue(j.encode(q)),!(0,g.Gh)(y?.usage)&&z>0&&(y.usage=(0,g.OF)(t,z,n)),(0,g.Gh)(y?.usage)?(0,g.IF)(y.provider||c,y.usage,r,s,v):(0,f.E5)({model:r,provider:o,connectionId:s,tokens:null,status:"200 OK"}).catch(()=>{}),u&&u({content:A,thinking:B},y?.usage,C)}catch(a){console.log("Error in flush:",a)}}})}function n(a,b,c=null,d=null,e=null,f=null,g=null,h=null,i=null,j=null){return m({mode:k,targetFormat:a,sourceFormat:b,provider:c,reqLogger:d,toolNameMap:e,model:f,connectionId:g,body:h,onStreamComplete:i,apiKey:j})}function o(a=null,b=null,c=null,d=null,e=null,f=null,g=null){return m({mode:l,provider:a,reqLogger:b,model:c,connectionId:d,body:e,onStreamComplete:f,apiKey:g})}},81626:(a,b,c)=>{function d(a,b){let c;if(!a.trim())return;let d=a.match(/^event:\s*(.+)$/m),e=a.match(/^data:\s*(.+)$/m);if(!d||!e)return;let f=d[1].trim(),g=e[1].trim();if("[DONE]"!==g){try{c=JSON.parse(g)}catch{return}"response.created"===f?(b.responseId=c.response?.id||b.responseId,b.created=c.response?.created_at||b.created):"response.output_item.done"===f?b.items.set(c.output_index??0,c.item):"response.completed"===f?(b.status="completed",c.response?.usage&&(b.usage.input_tokens=c.response.usage.input_tokens||0,b.usage.output_tokens=c.response.usage.output_tokens||0,b.usage.total_tokens=c.response.usage.total_tokens||0)):"response.failed"===f&&(b.status="failed")}}c.d(b,{I:()=>m,F:()=>l});let e={input_tokens:0,output_tokens:0,total_tokens:0};async function f(a){if(!a||"function"!=typeof a.getReader)return{id:`resp_${Date.now()}`,object:"response",created_at:Math.floor(Date.now()/1e3),status:"failed",output:[],usage:{...e}};let b=a.getReader(),c=new TextDecoder,f="",g={responseId:"",created:Math.floor(Date.now()/1e3),status:"in_progress",usage:{...e},items:new Map};try{for(;;){let{done:a,value:e}=await b.read();if(a)break;let h=(f+=c.decode(e,{stream:!0})).split("\n\n");for(let a of(f=h.pop()||"",h))d(a,g)}f.trim()&&d(f,g)}finally{b.releaseLock()}let h=[],i=g.items.size>0?Math.max(...g.items.keys()):-1;for(let a=0;a<=i;a++)h.push(g.items.get(a)||{type:"message",content:[],role:"assistant"});return{id:g.responseId||`resp_${Date.now()}_${Math.random().toString(36).slice(2,8)}`,object:"response",created_at:g.created,status:g.status||"completed",output:h,usage:g.usage}}var g=c(43659),h=c(2255),i=c(14170),j=c(86171),k=c(47370);function l(a,b){let c=[];for(let b of String(a||"").split("\n")){let a=b.trim();if(!a.startsWith("data:"))continue;let d=a.slice(5).trim();if(d&&"[DONE]"!==d)try{c.push(JSON.parse(d))}catch{}}if(0===c.length)return null;let d=c[0],e=[],f=[],g="stop",h=null;for(let a of c){let b=a?.choices?.[0],c=b?.delta||{};"string"==typeof c.content&&c.content.length>0&&e.push(c.content),"string"==typeof c.reasoning_content&&c.reasoning_content.length>0&&f.push(c.reasoning_content),b?.finish_reason&&(g=b.finish_reason),a?.usage&&"object"==typeof a.usage&&(h=a.usage)}let i={role:"assistant",content:e.join("")};f.length>0&&(i.reasoning_content=f.join(""));let j={id:d.id||`chatcmpl-${Date.now()}`,object:"chat.completion",created:d.created||Math.floor(Date.now()/1e3),model:d.model||b||"unknown",choices:[{index:0,message:i,finish_reason:g}]};return h&&(j.usage=h),j}async function m({providerResponse:a,sourceFormat:b,provider:c,model:d,body:e,stream:m,translatedBody:n,finalBody:o,requestStartTime:p,connectionId:q,apiKey:r,clientRawRequest:s,onRequestSuccess:t,trackDone:u,appendLog:v}){let w=a.headers.get("content-type")||"";if(!(w.includes("text/event-stream")||""===w&&"codex"===c))return null;u();let x={provider:c,model:d,connectionId:q,request:(0,j.Fo)(e,m),providerRequest:o||n||null};if("codex"===c||b===i.h.OPENAI_RESPONSES)try{let e,g=await f(a.body);t&&await t();let h=g.usage||{};v({tokens:h,status:"200 OK"}),(0,j.qr)({provider:c,model:d,tokens:h,connectionId:q,apiKey:r,endpoint:s?.endpoint});let l=g.output?.find(a=>"message"===a.type),m=l?.content?.find(a=>"output_text"===a.type)?.text||l?.content?.[0]?.text||null,n=Date.now()-p;if((0,k.ox)((0,j.$R)({...x,latency:{ttft:n,total:n},tokens:{prompt_tokens:h.input_tokens||0,completion_tokens:h.output_tokens||0},response:{content:m,thinking:null,finish_reason:g.status||"unknown"},status:"success"},{endpoint:s?.endpoint||null})).catch(()=>{}),b===i.h.OPENAI_RESPONSES)return{success:!0,response:new Response(JSON.stringify(g),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})};let o=h.input_tokens||0,u=h.output_tokens||0;return e=b===i.h.ANTIGRAVITY||b===i.h.GEMINI||b===i.h.GEMINI_CLI?{response:{candidates:[{content:{role:"model",parts:[{text:m||""}]},finishReason:"STOP",index:0}],usageMetadata:{promptTokenCount:o,candidatesTokenCount:u,totalTokenCount:o+u},modelVersion:d,responseId:g.id||`resp_${Date.now()}`}}:{id:g.id||`chatcmpl-${Date.now()}`,object:"chat.completion",created:g.created_at||Math.floor(Date.now()/1e3),model:g.model||d,choices:[{index:0,message:{role:"assistant",content:m||""},finish_reason:"completed"===g.status?"stop":g.status||"stop"}],usage:{prompt_tokens:o,completion_tokens:u,total_tokens:o+u}},{success:!0,response:new Response(JSON.stringify(e),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}catch(a){return console.error("[ChatCore] Responses API SSE→JSON failed:",a),(0,g.A1)(h.gx.BAD_GATEWAY,"Failed to convert streaming response to JSON")}try{let b=await a.text(),e=l(b,d);if(!e)return(0,g.A1)(h.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");t&&await t();let f=e.usage||{};v({tokens:f,status:"200 OK"}),(0,j.qr)({provider:c,model:d,tokens:f,connectionId:q,apiKey:r,endpoint:s?.endpoint});let i=Date.now()-p;return(0,k.ox)((0,j.$R)({...x,latency:{ttft:i,total:i},tokens:f,response:{content:e.choices?.[0]?.message?.content||null,thinking:e.choices?.[0]?.message?.reasoning_content||null,finish_reason:e.choices?.[0]?.finish_reason||"unknown"},status:"success"},{endpoint:s?.endpoint||null})).catch(()=>{}),{success:!0,response:new Response(JSON.stringify(e),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}catch(a){return console.error("[ChatCore] Chat Completions SSE→JSON failed:",a),(0,g.A1)(h.gx.BAD_GATEWAY,"Failed to convert streaming response to JSON")}}},86171:(a,b,c)=>{c.d(b,{$R:()=>i,Fo:()=>g,MK:()=>h,qr:()=>j});var d=c(47370),e=c(71857);let f=["temperature","top_p","top_k","max_tokens","max_completion_tokens","thinking","reasoning","enable_thinking","presence_penalty","frequency_penalty","seed","stop","tools","tool_choice","response_format","prediction","store","metadata","n","logprobs","top_logprobs","logit_bias","user","parallel_tool_calls"];function g(a,b){let c={messages:a.messages||[],model:a.model,stream:b};for(let b of f)void 0!==a[b]&&(c[b]=a[b]);return c}function h(a){return a&&"object"==typeof a?a.usage?.input_tokens!==void 0?{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.usage?.prompt_tokens!==void 0?{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}:a.usageMetadata?{prompt_tokens:a.usageMetadata.promptTokenCount||0,completion_tokens:a.usageMetadata.candidatesTokenCount||0,reasoning_tokens:a.usageMetadata.thoughtsTokenCount}:null:null}function i(a,b={}){return{provider:a.provider||"unknown",model:a.model||"unknown",connectionId:a.connectionId||void 0,timestamp:new Date().toISOString(),latency:a.latency||{ttft:0,total:0},tokens:a.tokens||{prompt_tokens:0,completion_tokens:0},request:a.request,providerRequest:a.providerRequest||null,providerResponse:a.providerResponse||null,response:a.response||{},status:a.status||"success",...b}}function j({provider:a,model:b,tokens:c,connectionId:f,apiKey:g,endpoint:h,label:i="USAGE"}){if(!c||"object"!=typeof c)return;let j=c.input_tokens??c.prompt_tokens??0,k=c.output_tokens??c.completion_tokens??0;if(0===j&&0===k)return;let l=new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit",second:"2-digit"}),m=f?` | account=${f.slice(0,8)}...`:"";console.log(`${e.lm.green}[${l}] 📊 [${i}] ${a.toUpperCase()} | in=${j} | out=${k}${m}${e.lm.reset}`);let n={prompt_tokens:c.prompt_tokens??c.input_tokens??0,completion_tokens:c.completion_tokens??c.output_tokens??0};(0,d.sZ)({provider:a||"unknown",model:b||"unknown",tokens:n,timestamp:new Date().toISOString(),connectionId:f||void 0,apiKey:g||void 0,endpoint:h||null}).catch(()=>{})}},92500:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{w:()=>w});var e=c(57647),f=c(33110),g=c(14170),h=c(71857),i=c(59657),j=c(8590),k=c(71336),l=c(57247),m=c(43659),n=c(2255),o=c(27349),p=c(47370),q=c(55330),r=c(86171),s=c(81626),t=c(5016),u=c(20623),v=a([q]);async function w({body:a,modelInfo:b,credentials:c,log:d,onCredentialsRefreshed:v,onRequestSuccess:w,onDisconnect:x,clientRawRequest:y,connectionId:z,userAgent:A,apiKey:B,sourceFormatOverride:C}){let D,E,F,G,{provider:H,model:I}=b,J=Date.now(),K=C||(0,e.Tz)(a),L=(0,o.c)(a,I,A);if(L)return L;let M=l.Xg[H]||H,N=(0,l.ux)(M,I)||(0,e.jJ)(H),O=!0===a.stream||K===g.h.ANTIGRAVITY||K===g.h.GEMINI||K===g.h.GEMINI_CLI,P="openai"===H||"codex"===H,Q=!!P||!1!==a.stream,R=await (0,k.q7)(K,N,I);y&&R.logClientRawRequest(y.endpoint,y.body,y.headers),R.logRawRequest(a),d?.debug?.("FORMAT",`${K} → ${N} | stream=${Q}`);let S=(0,f.GH)(K,N,I,a,Q,c,H,R),T=S._toolNameMap;delete S._toolNameMap,S.model=I;let U=(0,q.SB)(H);(0,p.uw)(I,H,z,!0),(0,p.E5)({model:I,provider:H,connectionId:z,status:"PENDING"}).catch(()=>{});let V=S.messages?.length||S.input?.length||S.contents?.length||S.request?.contents?.length||0;d?.debug?.("REQUEST",`${H.toUpperCase()} | ${I} | ${V} msgs`);let W=(0,i.jd)({onDisconnect:a=>{(0,p.uw)(I,H,z,!1),x&&x(a)},onError:()=>(0,p.uw)(I,H,z,!1),log:d,provider:H,model:I});try{let a=await U.execute({model:I,body:S,stream:Q,credentials:c,signal:W.signal,log:d});D=a.response,E=a.url,F=a.headers,G=a.transformedBody,R.logTargetRequest(E,F,G)}catch(c){if((0,p.uw)(I,H,z,!1,!0),(0,p.E5)({model:I,provider:H,connectionId:z,status:`FAILED ${"AbortError"===c.name?499:n.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:H,model:I,connectionId:z,latency:{ttft:0,total:Date.now()-J},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,Q),providerRequest:S||null,response:{error:c.message||String(c),status:"AbortError"===c.name?499:502,thinking:null},status:"error"})).catch(()=>{}),"AbortError"===c.name)return W.handleError(c),(0,m.A1)(499,"Request aborted");let b=(0,m.lR)(c,H,I,n.gx.BAD_GATEWAY);return console.log(`${h.lm.red}[ERROR] ${b}${h.lm.reset}`),(0,m.A1)(n.gx.BAD_GATEWAY,b)}if(D.status===n.gx.UNAUTHORIZED||D.status===n.gx.FORBIDDEN){let a=await (0,j.qZ)(()=>U.refreshCredentials(c,d),3,d);if(a?.accessToken||a?.copilotToken){d?.info?.("TOKEN",`${H.toUpperCase()} | refreshed`),Object.assign(c,a),v&&await v(a);try{let a=await U.execute({model:I,body:S,stream:Q,credentials:c,signal:W.signal,log:d});a.response.ok&&(D=a.response,E=a.url)}catch{d?.warn?.("TOKEN",`${H.toUpperCase()} | retry after refresh failed`)}}else d?.warn?.("TOKEN",`${H.toUpperCase()} | refresh failed`)}if(!D.ok){(0,p.uw)(I,H,z,!1,!0);let{statusCode:b,message:c,retryAfterMs:e}=await (0,m.zL)(D,H);(0,p.E5)({model:I,provider:H,connectionId:z,status:`FAILED ${b}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:H,model:I,connectionId:z,latency:{ttft:0,total:Date.now()-J},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,Q),providerRequest:G||S||null,response:{error:c,status:b,thinking:null},status:"error"})).catch(()=>{});let f=(0,m.lR)(Error(c),H,I,b);return console.log(`${h.lm.red}[ERROR] ${f}${h.lm.reset}`),e&&"antigravity"===H&&d?.debug?.("RETRY",`Antigravity quota reset in ${Math.ceil(e/1e3)}s`),R.logError(Error(c),G||S),(0,m.A1)(b,f,e)}let X={provider:H,model:I,body:a,stream:Q,translatedBody:S,finalBody:G,requestStartTime:J,connectionId:z,apiKey:B,clientRawRequest:y,onRequestSuccess:w},Y=a=>(0,p.E5)({model:I,provider:H,connectionId:z,...a}).catch(()=>{}),Z=()=>(0,p.uw)(I,H,z,!1);if(!O&&P){let a=await (0,s.I)({...X,providerResponse:D,sourceFormat:K,trackDone:Z,appendLog:Y});if(a)return a}if(!Q)return(0,t.N)({...X,providerResponse:D,sourceFormat:K,targetFormat:N,reqLogger:R,trackDone:Z,appendLog:Y});let{onStreamComplete:$}=(0,u.$)({...X});return(0,u.M)({...X,providerResponse:D,sourceFormat:K,targetFormat:N,userAgent:A,reqLogger:R,toolNameMap:T,streamController:W,onStreamComplete:$})}q=(v.then?(await v)():v)[0],d()}catch(a){d(a)}})}};
@@ -1,4 +1,18 @@
1
1
  {
2
2
  "version": 1,
3
- "functions": {}
3
+ "functions": {
4
+ "/_middleware": {
5
+ "runtime": "nodejs",
6
+ "matchers": [
7
+ {
8
+ "regexp": "^(?:\\/(_next\\/data\\/[^/]{1,}))?(?:\\/(\\/?index|\\/?index\\.json))?[\\/#\\?]?$",
9
+ "originalSource": "/"
10
+ },
11
+ {
12
+ "regexp": "^(?:\\/(_next\\/data\\/[^/]{1,}))?\\/dashboard(?:\\/((?:[^\\/#\\?]+?)(?:\\/(?:[^\\/#\\?]+?))*))?(\\.json)?[\\/#\\?]?$",
13
+ "originalSource": "/dashboard/:path*"
14
+ }
15
+ ]
16
+ }
17
+ }
4
18
  }