9router 0.3.87 β†’ 0.3.90

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 (572) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +9 -8
  3. package/app/.next/build-manifest.json +2 -2
  4. package/app/.next/routes-manifest.json +6 -0
  5. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page.js +2 -2
  6. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
  7. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js +2 -2
  8. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  9. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js +2 -2
  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 -2
  12. package/app/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -1
  13. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js +2 -2
  14. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  15. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page.js +2 -2
  16. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page_client-reference-manifest.js +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page.js +2 -2
  18. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page_client-reference-manifest.js +1 -1
  19. package/app/.next/server/app/(dashboard)/dashboard/mitm/page.js +2 -2
  20. package/app/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
  21. package/app/.next/server/app/(dashboard)/dashboard/page.js +2 -2
  22. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  23. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js +2 -2
  24. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  25. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +2 -2
  26. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  27. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js +2 -2
  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 +2 -2
  30. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  31. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page.js +3 -3
  32. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
  33. package/app/.next/server/app/(dashboard)/dashboard/quota/page.js +2 -2
  34. package/app/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
  35. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js +2 -2
  36. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  37. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js +2 -2
  38. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  39. package/app/.next/server/app/_global-error/page.js +3 -3
  40. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  41. package/app/.next/server/app/_global-error.html +1 -1
  42. package/app/.next/server/app/_global-error.rsc +1 -1
  43. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  44. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  45. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  46. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  47. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  48. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  49. package/app/.next/server/app/_not-found/page.js +2 -2
  50. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  51. package/app/.next/server/app/_not-found.html +1 -1
  52. package/app/.next/server/app/_not-found.rsc +3 -3
  53. package/app/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  54. package/app/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  55. package/app/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  56. package/app/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  57. package/app/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  58. package/app/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  59. package/app/.next/server/app/api/auth/login/route.js +1 -1
  60. package/app/.next/server/app/api/auth/logout/route.js +1 -1
  61. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
  62. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +1 -2
  63. package/app/.next/server/app/api/cli-tools/claude-settings/route.js +2 -2
  64. package/app/.next/server/app/api/cli-tools/codex-settings/route.js +3 -3
  65. package/app/.next/server/app/api/cli-tools/copilot-settings/route.js +2 -2
  66. package/app/.next/server/app/api/cli-tools/droid-settings/route.js +2 -2
  67. package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js +2 -2
  68. package/app/.next/server/app/api/cli-tools/opencode-settings/route.js +2 -2
  69. package/app/.next/server/app/api/cloud/auth/route.js +1 -1
  70. package/app/.next/server/app/api/cloud/credentials/update/route.js +1 -1
  71. package/app/.next/server/app/api/cloud/model/resolve/route.js +1 -1
  72. package/app/.next/server/app/api/cloud/models/alias/route.js +1 -1
  73. package/app/.next/server/app/api/combos/[id]/route.js +1 -1
  74. package/app/.next/server/app/api/combos/route.js +1 -1
  75. package/app/.next/server/app/api/health/route.js +1 -1
  76. package/app/.next/server/app/api/init/route.js +1 -1
  77. package/app/.next/server/app/api/keys/[id]/route.js +1 -1
  78. package/app/.next/server/app/api/keys/route.js +1 -1
  79. package/app/.next/server/app/api/locale/route.js +1 -1
  80. package/app/.next/server/app/api/media-providers/tts/elevenlabs/voices/route.js +1 -1
  81. package/app/.next/server/app/api/media-providers/tts/voices/route.js +1 -1
  82. package/app/.next/server/app/api/models/alias/route.js +1 -1
  83. package/app/.next/server/app/api/models/availability/route.js +1 -1
  84. package/app/.next/server/app/api/models/route.js +1 -1
  85. package/app/.next/server/app/api/models/test/route.js +1 -1
  86. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js +1 -1
  87. package/app/.next/server/app/api/oauth/cursor/auto-import/route.js +2 -2
  88. package/app/.next/server/app/api/oauth/cursor/import/route.js +1 -1
  89. package/app/.next/server/app/api/oauth/gitlab/pat/route.js +1 -1
  90. package/app/.next/server/app/api/oauth/iflow/cookie/route.js +1 -1
  91. package/app/.next/server/app/api/oauth/kiro/auto-import/route.js +1 -1
  92. package/app/.next/server/app/api/oauth/kiro/import/route.js +1 -1
  93. package/app/.next/server/app/api/oauth/kiro/social-authorize/route.js +1 -1
  94. package/app/.next/server/app/api/oauth/kiro/social-exchange/route.js +1 -1
  95. package/app/.next/server/app/api/pricing/route.js +1 -1
  96. package/app/.next/server/app/api/provider-nodes/[id]/route.js +1 -1
  97. package/app/.next/server/app/api/provider-nodes/route.js +1 -1
  98. package/app/.next/server/app/api/provider-nodes/validate/route.js +1 -1
  99. package/app/.next/server/app/api/providers/[id]/models/route.js +1 -1
  100. package/app/.next/server/app/api/providers/[id]/route.js +1 -1
  101. package/app/.next/server/app/api/providers/[id]/test/route.js +1 -1
  102. package/app/.next/server/app/api/providers/[id]/test-models/route.js +1 -1
  103. package/app/.next/server/app/api/providers/client/route.js +1 -1
  104. package/app/.next/server/app/api/providers/kilo/free-models/route.js +1 -1
  105. package/app/.next/server/app/api/providers/route.js +1 -1
  106. package/app/.next/server/app/api/providers/test-batch/route.js +1 -1
  107. package/app/.next/server/app/api/providers/validate/route.js +1 -1
  108. package/app/.next/server/app/api/proxy-pools/[id]/route.js +1 -1
  109. package/app/.next/server/app/api/proxy-pools/[id]/test/route.js +1 -1
  110. package/app/.next/server/app/api/proxy-pools/route.js +1 -1
  111. package/app/.next/server/app/api/proxy-pools/vercel-deploy/route.js +2 -2
  112. package/app/.next/server/app/api/settings/database/route.js +1 -1
  113. package/app/.next/server/app/api/settings/proxy-test/route.js +1 -1
  114. package/app/.next/server/app/api/settings/require-login/route.js +1 -1
  115. package/app/.next/server/app/api/settings/route.js +1 -1
  116. package/app/.next/server/app/api/shutdown/route.js +1 -1
  117. package/app/.next/server/app/api/tags/route.js +1 -1
  118. package/app/.next/server/app/api/translator/console-logs/route.js +1 -1
  119. package/app/.next/server/app/api/translator/console-logs/stream/route.js +2 -2
  120. package/app/.next/server/app/api/translator/load/route.js +1 -1
  121. package/app/.next/server/app/api/translator/save/route.js +1 -1
  122. package/app/.next/server/app/api/translator/send/route.js +1 -1
  123. package/app/.next/server/app/api/translator/translate/route.js +1 -1
  124. package/app/.next/server/app/api/tunnel/disable/route.js +1 -1
  125. package/app/.next/server/app/api/tunnel/enable/route.js +1 -1
  126. package/app/.next/server/app/api/tunnel/status/route.js +1 -1
  127. package/app/.next/server/app/api/tunnel/tailscale-check/route.js +2 -2
  128. package/app/.next/server/app/api/tunnel/tailscale-disable/route.js +1 -1
  129. package/app/.next/server/app/api/tunnel/tailscale-enable/route.js +1 -1
  130. package/app/.next/server/app/api/tunnel/tailscale-install/route.js +3 -3
  131. package/app/.next/server/app/api/tunnel/tailscale-login/route.js +2 -2
  132. package/app/.next/server/app/api/tunnel/tailscale-start-daemon/route.js +1 -1
  133. package/app/.next/server/app/api/usage/[connectionId]/route.js +1 -1
  134. package/app/.next/server/app/api/usage/chart/route.js +1 -1
  135. package/app/.next/server/app/api/usage/history/route.js +1 -1
  136. package/app/.next/server/app/api/usage/providers/route.js +1 -1
  137. package/app/.next/server/app/api/usage/request-details/route.js +1 -1
  138. package/app/.next/server/app/api/usage/request-logs/route.js +1 -1
  139. package/app/.next/server/app/api/usage/stats/route.js +1 -1
  140. package/app/.next/server/app/api/usage/stream/route.js +2 -2
  141. package/app/.next/server/app/api/v1/api/chat/route.js +1 -1
  142. package/app/.next/server/app/api/v1/audio/speech/route.js +1 -1
  143. package/app/.next/server/app/api/v1/chat/completions/route.js +1 -1
  144. package/app/.next/server/app/api/v1/embeddings/route.js +1 -1
  145. package/app/.next/server/app/api/v1/messages/count_tokens/route.js +1 -1
  146. package/app/.next/server/app/api/v1/messages/route.js +1 -1
  147. package/app/.next/server/app/api/v1/models/route.js +1 -1
  148. package/app/.next/server/app/api/v1/responses/compact/route.js +1 -0
  149. package/app/.next/server/app/api/v1/responses/compact/route.js.nft.json +1 -0
  150. package/app/.next/server/app/api/v1/responses/compact/route_client-reference-manifest.js +1 -0
  151. package/app/.next/server/app/api/v1/responses/route.js +1 -1
  152. package/app/.next/server/app/api/v1/route.js +1 -1
  153. package/app/.next/server/app/api/v1beta/models/[...path]/route.js +1 -1
  154. package/app/.next/server/app/api/v1beta/models/route.js +1 -1
  155. package/app/.next/server/app/api/version/route.js +1 -1
  156. package/app/.next/server/app/callback/page.js +2 -2
  157. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  158. package/app/.next/server/app/callback.html +1 -1
  159. package/app/.next/server/app/callback.rsc +3 -3
  160. package/app/.next/server/app/callback.segments/_full.segment.rsc +3 -3
  161. package/app/.next/server/app/callback.segments/_head.segment.rsc +1 -1
  162. package/app/.next/server/app/callback.segments/_index.segment.rsc +3 -3
  163. package/app/.next/server/app/callback.segments/_tree.segment.rsc +1 -1
  164. package/app/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +1 -1
  165. package/app/.next/server/app/callback.segments/callback.segment.rsc +1 -1
  166. package/app/.next/server/app/dashboard/basic-chat.html +1 -1
  167. package/app/.next/server/app/dashboard/basic-chat.rsc +5 -5
  168. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat/__PAGE__.segment.rsc +2 -2
  169. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat.segment.rsc +1 -1
  170. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  171. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  172. package/app/.next/server/app/dashboard/basic-chat.segments/_full.segment.rsc +5 -5
  173. package/app/.next/server/app/dashboard/basic-chat.segments/_head.segment.rsc +1 -1
  174. package/app/.next/server/app/dashboard/basic-chat.segments/_index.segment.rsc +3 -3
  175. package/app/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +1 -1
  176. package/app/.next/server/app/dashboard/cli-tools.html +1 -1
  177. package/app/.next/server/app/dashboard/cli-tools.rsc +5 -5
  178. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +2 -2
  179. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +1 -1
  180. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  181. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  182. package/app/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +5 -5
  183. package/app/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +1 -1
  184. package/app/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +3 -3
  185. package/app/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +1 -1
  186. package/app/.next/server/app/dashboard/combos.html +1 -1
  187. package/app/.next/server/app/dashboard/combos.rsc +5 -5
  188. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +2 -2
  189. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +1 -1
  190. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  191. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  192. package/app/.next/server/app/dashboard/combos.segments/_full.segment.rsc +5 -5
  193. package/app/.next/server/app/dashboard/combos.segments/_head.segment.rsc +1 -1
  194. package/app/.next/server/app/dashboard/combos.segments/_index.segment.rsc +3 -3
  195. package/app/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +1 -1
  196. package/app/.next/server/app/dashboard/endpoint.html +1 -1
  197. package/app/.next/server/app/dashboard/endpoint.rsc +5 -5
  198. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +2 -2
  199. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +1 -1
  200. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  201. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  202. package/app/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +5 -5
  203. package/app/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +1 -1
  204. package/app/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +3 -3
  205. package/app/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +1 -1
  206. package/app/.next/server/app/dashboard/mitm.html +1 -1
  207. package/app/.next/server/app/dashboard/mitm.rsc +5 -5
  208. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm/__PAGE__.segment.rsc +2 -2
  209. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm.segment.rsc +1 -1
  210. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  211. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  212. package/app/.next/server/app/dashboard/mitm.segments/_full.segment.rsc +5 -5
  213. package/app/.next/server/app/dashboard/mitm.segments/_head.segment.rsc +1 -1
  214. package/app/.next/server/app/dashboard/mitm.segments/_index.segment.rsc +3 -3
  215. package/app/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +1 -1
  216. package/app/.next/server/app/dashboard/profile.html +1 -1
  217. package/app/.next/server/app/dashboard/profile.rsc +5 -5
  218. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +2 -2
  219. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +1 -1
  220. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  221. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  222. package/app/.next/server/app/dashboard/profile.segments/_full.segment.rsc +5 -5
  223. package/app/.next/server/app/dashboard/profile.segments/_head.segment.rsc +1 -1
  224. package/app/.next/server/app/dashboard/profile.segments/_index.segment.rsc +3 -3
  225. package/app/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +1 -1
  226. package/app/.next/server/app/dashboard/providers/new.html +1 -1
  227. package/app/.next/server/app/dashboard/providers/new.rsc +5 -5
  228. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +2 -2
  229. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +1 -1
  230. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  231. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  232. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  233. package/app/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +5 -5
  234. package/app/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +1 -1
  235. package/app/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +3 -3
  236. package/app/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +1 -1
  237. package/app/.next/server/app/dashboard/providers.html +1 -1
  238. package/app/.next/server/app/dashboard/providers.rsc +5 -5
  239. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +2 -2
  240. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  241. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  242. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  243. package/app/.next/server/app/dashboard/providers.segments/_full.segment.rsc +5 -5
  244. package/app/.next/server/app/dashboard/providers.segments/_head.segment.rsc +1 -1
  245. package/app/.next/server/app/dashboard/providers.segments/_index.segment.rsc +3 -3
  246. package/app/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +1 -1
  247. package/app/.next/server/app/dashboard/proxy-pools.html +1 -1
  248. package/app/.next/server/app/dashboard/proxy-pools.rsc +5 -5
  249. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools/__PAGE__.segment.rsc +2 -2
  250. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools.segment.rsc +1 -1
  251. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  252. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  253. package/app/.next/server/app/dashboard/proxy-pools.segments/_full.segment.rsc +5 -5
  254. package/app/.next/server/app/dashboard/proxy-pools.segments/_head.segment.rsc +1 -1
  255. package/app/.next/server/app/dashboard/proxy-pools.segments/_index.segment.rsc +3 -3
  256. package/app/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +1 -1
  257. package/app/.next/server/app/dashboard/quota.html +2 -2
  258. package/app/.next/server/app/dashboard/quota.rsc +6 -6
  259. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota/__PAGE__.segment.rsc +3 -3
  260. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota.segment.rsc +1 -1
  261. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  262. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  263. package/app/.next/server/app/dashboard/quota.segments/_full.segment.rsc +6 -6
  264. package/app/.next/server/app/dashboard/quota.segments/_head.segment.rsc +1 -1
  265. package/app/.next/server/app/dashboard/quota.segments/_index.segment.rsc +3 -3
  266. package/app/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +1 -1
  267. package/app/.next/server/app/dashboard/settings/pricing/page.js +2 -2
  268. package/app/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  269. package/app/.next/server/app/dashboard/settings/pricing.html +1 -1
  270. package/app/.next/server/app/dashboard/settings/pricing.rsc +3 -3
  271. package/app/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +3 -3
  272. package/app/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +1 -1
  273. package/app/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +3 -3
  274. package/app/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +1 -1
  275. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +1 -1
  276. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +1 -1
  277. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +1 -1
  278. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +1 -1
  279. package/app/.next/server/app/dashboard/translator.html +1 -1
  280. package/app/.next/server/app/dashboard/translator.rsc +5 -5
  281. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +2 -2
  282. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +1 -1
  283. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  284. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  285. package/app/.next/server/app/dashboard/translator.segments/_full.segment.rsc +5 -5
  286. package/app/.next/server/app/dashboard/translator.segments/_head.segment.rsc +1 -1
  287. package/app/.next/server/app/dashboard/translator.segments/_index.segment.rsc +3 -3
  288. package/app/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +1 -1
  289. package/app/.next/server/app/dashboard/usage.html +1 -1
  290. package/app/.next/server/app/dashboard/usage.rsc +5 -5
  291. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +2 -2
  292. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +1 -1
  293. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  294. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  295. package/app/.next/server/app/dashboard/usage.segments/_full.segment.rsc +5 -5
  296. package/app/.next/server/app/dashboard/usage.segments/_head.segment.rsc +1 -1
  297. package/app/.next/server/app/dashboard/usage.segments/_index.segment.rsc +3 -3
  298. package/app/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +1 -1
  299. package/app/.next/server/app/dashboard.html +1 -1
  300. package/app/.next/server/app/dashboard.rsc +5 -5
  301. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +2 -2
  302. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  303. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  304. package/app/.next/server/app/dashboard.segments/_full.segment.rsc +5 -5
  305. package/app/.next/server/app/dashboard.segments/_head.segment.rsc +1 -1
  306. package/app/.next/server/app/dashboard.segments/_index.segment.rsc +3 -3
  307. package/app/.next/server/app/dashboard.segments/_tree.segment.rsc +1 -1
  308. package/app/.next/server/app/favicon.ico/route.js +1 -1
  309. package/app/.next/server/app/index.html +1 -1
  310. package/app/.next/server/app/index.rsc +3 -3
  311. package/app/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  312. package/app/.next/server/app/index.segments/_full.segment.rsc +3 -3
  313. package/app/.next/server/app/index.segments/_head.segment.rsc +1 -1
  314. package/app/.next/server/app/index.segments/_index.segment.rsc +3 -3
  315. package/app/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  316. package/app/.next/server/app/landing/page.js +2 -2
  317. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  318. package/app/.next/server/app/landing.html +1 -1
  319. package/app/.next/server/app/landing.rsc +3 -3
  320. package/app/.next/server/app/landing.segments/_full.segment.rsc +3 -3
  321. package/app/.next/server/app/landing.segments/_head.segment.rsc +1 -1
  322. package/app/.next/server/app/landing.segments/_index.segment.rsc +3 -3
  323. package/app/.next/server/app/landing.segments/_tree.segment.rsc +1 -1
  324. package/app/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +1 -1
  325. package/app/.next/server/app/landing.segments/landing.segment.rsc +1 -1
  326. package/app/.next/server/app/login/page.js +2 -2
  327. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  328. package/app/.next/server/app/login.html +1 -1
  329. package/app/.next/server/app/login.rsc +4 -4
  330. package/app/.next/server/app/login.segments/_full.segment.rsc +4 -4
  331. package/app/.next/server/app/login.segments/_head.segment.rsc +1 -1
  332. package/app/.next/server/app/login.segments/_index.segment.rsc +3 -3
  333. package/app/.next/server/app/login.segments/_tree.segment.rsc +1 -1
  334. package/app/.next/server/app/login.segments/login/__PAGE__.segment.rsc +2 -2
  335. package/app/.next/server/app/login.segments/login.segment.rsc +1 -1
  336. package/app/.next/server/app/manifest.webmanifest/route.js +2 -2
  337. package/app/.next/server/app/page.js +2 -2
  338. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  339. package/app/.next/server/app-paths-manifest.json +9 -8
  340. package/app/.next/server/chunks/1574.js +1 -1
  341. package/app/.next/server/chunks/1578.js +1 -1
  342. package/app/.next/server/chunks/2049.js +1 -1
  343. package/app/.next/server/chunks/242.js +1 -1
  344. package/app/.next/server/chunks/3774.js +3 -3
  345. package/app/.next/server/chunks/450.js +1 -1
  346. package/app/.next/server/chunks/514.js +2 -2
  347. package/app/.next/server/chunks/586.js +1 -0
  348. package/app/.next/server/chunks/6379.js +1 -1
  349. package/app/.next/server/chunks/6502.js +1 -1
  350. package/app/.next/server/chunks/6560.js +1 -1
  351. package/app/.next/server/chunks/7243.js +1 -0
  352. package/app/.next/server/chunks/8202.js +3 -3
  353. package/app/.next/server/chunks/8480.js +1 -1
  354. package/app/.next/server/chunks/8838.js +1 -1
  355. package/app/.next/server/chunks/9489.js +1 -1
  356. package/app/.next/server/middleware-build-manifest.js +1 -1
  357. package/app/.next/server/middleware.js +4 -4
  358. package/app/.next/server/pages/404.html +1 -1
  359. package/app/.next/server/pages/500.html +1 -1
  360. package/app/.next/server/server-reference-manifest.js +1 -1
  361. package/app/.next/server/server-reference-manifest.json +1 -1
  362. package/app/.next/static/Seqmp6275x677iq3fTzPt/_buildManifest.js +1 -0
  363. package/app/.next/static/chunks/{1237-ad8b85796830b483.js β†’ 1237-06ab8ceb0847165d.js} +1 -1
  364. package/app/.next/static/chunks/{4156-79259ee78f702b12.js β†’ 4156-d2436f4645532dc5.js} +1 -1
  365. package/app/.next/static/chunks/{505-534835b087aaa3a0.js β†’ 505-e8dec61412d86c58.js} +1 -1
  366. package/app/.next/static/chunks/8035-0bbf141cee7024b0.js +3 -0
  367. package/app/.next/static/chunks/app/_global-error/{page-ceb851f470785140.js β†’ page-4ed867ac6edb2a89.js} +1 -1
  368. package/app/.next/static/chunks/app/api/auth/login/{route-ceb851f470785140.js β†’ route-4ed867ac6edb2a89.js} +1 -1
  369. package/app/.next/static/chunks/app/api/auth/logout/{route-ceb851f470785140.js β†’ route-4ed867ac6edb2a89.js} +1 -1
  370. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/{route-ceb851f470785140.js β†’ route-4ed867ac6edb2a89.js} +1 -1
  371. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-4ed867ac6edb2a89.js +1 -0
  372. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-4ed867ac6edb2a89.js +1 -0
  373. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-4ed867ac6edb2a89.js +1 -0
  374. package/app/.next/static/chunks/app/api/cli-tools/copilot-settings/route-4ed867ac6edb2a89.js +1 -0
  375. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-4ed867ac6edb2a89.js +1 -0
  376. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-4ed867ac6edb2a89.js +1 -0
  377. package/app/.next/static/chunks/app/api/cli-tools/opencode-settings/route-4ed867ac6edb2a89.js +1 -0
  378. package/app/.next/static/chunks/app/api/cloud/auth/route-4ed867ac6edb2a89.js +1 -0
  379. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-4ed867ac6edb2a89.js +1 -0
  380. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-4ed867ac6edb2a89.js +1 -0
  381. package/app/.next/static/chunks/app/api/cloud/models/alias/route-4ed867ac6edb2a89.js +1 -0
  382. package/app/.next/static/chunks/app/api/combos/[id]/route-4ed867ac6edb2a89.js +1 -0
  383. package/app/.next/static/chunks/app/api/combos/route-4ed867ac6edb2a89.js +1 -0
  384. package/app/.next/static/chunks/app/api/health/route-4ed867ac6edb2a89.js +1 -0
  385. package/app/.next/static/chunks/app/api/init/route-4ed867ac6edb2a89.js +1 -0
  386. package/app/.next/static/chunks/app/api/keys/[id]/route-4ed867ac6edb2a89.js +1 -0
  387. package/app/.next/static/chunks/app/api/keys/route-4ed867ac6edb2a89.js +1 -0
  388. package/app/.next/static/chunks/app/api/locale/route-4ed867ac6edb2a89.js +1 -0
  389. package/app/.next/static/chunks/app/api/media-providers/tts/elevenlabs/voices/route-4ed867ac6edb2a89.js +1 -0
  390. package/app/.next/static/chunks/app/api/media-providers/tts/voices/route-4ed867ac6edb2a89.js +1 -0
  391. package/app/.next/static/chunks/app/api/models/alias/route-4ed867ac6edb2a89.js +1 -0
  392. package/app/.next/static/chunks/app/api/models/availability/route-4ed867ac6edb2a89.js +1 -0
  393. package/app/.next/static/chunks/app/api/models/route-4ed867ac6edb2a89.js +1 -0
  394. package/app/.next/static/chunks/app/api/models/test/route-4ed867ac6edb2a89.js +1 -0
  395. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-4ed867ac6edb2a89.js +1 -0
  396. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-4ed867ac6edb2a89.js +1 -0
  397. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-4ed867ac6edb2a89.js +1 -0
  398. package/app/.next/static/chunks/app/api/oauth/gitlab/pat/route-4ed867ac6edb2a89.js +1 -0
  399. package/app/.next/static/chunks/app/api/oauth/iflow/cookie/route-4ed867ac6edb2a89.js +1 -0
  400. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-4ed867ac6edb2a89.js +1 -0
  401. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-4ed867ac6edb2a89.js +1 -0
  402. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-4ed867ac6edb2a89.js +1 -0
  403. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-4ed867ac6edb2a89.js +1 -0
  404. package/app/.next/static/chunks/app/api/pricing/route-4ed867ac6edb2a89.js +1 -0
  405. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-4ed867ac6edb2a89.js +1 -0
  406. package/app/.next/static/chunks/app/api/provider-nodes/route-4ed867ac6edb2a89.js +1 -0
  407. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-4ed867ac6edb2a89.js +1 -0
  408. package/app/.next/static/chunks/app/api/providers/[id]/models/route-4ed867ac6edb2a89.js +1 -0
  409. package/app/.next/static/chunks/app/api/providers/[id]/route-4ed867ac6edb2a89.js +1 -0
  410. package/app/.next/static/chunks/app/api/providers/[id]/test/route-4ed867ac6edb2a89.js +1 -0
  411. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-4ed867ac6edb2a89.js +1 -0
  412. package/app/.next/static/chunks/app/api/providers/client/route-4ed867ac6edb2a89.js +1 -0
  413. package/app/.next/static/chunks/app/api/providers/kilo/free-models/route-4ed867ac6edb2a89.js +1 -0
  414. package/app/.next/static/chunks/app/api/providers/route-4ed867ac6edb2a89.js +1 -0
  415. package/app/.next/static/chunks/app/api/providers/test-batch/route-4ed867ac6edb2a89.js +1 -0
  416. package/app/.next/static/chunks/app/api/providers/validate/route-4ed867ac6edb2a89.js +1 -0
  417. package/app/.next/static/chunks/app/api/proxy-pools/[id]/route-4ed867ac6edb2a89.js +1 -0
  418. package/app/.next/static/chunks/app/api/proxy-pools/[id]/test/route-4ed867ac6edb2a89.js +1 -0
  419. package/app/.next/static/chunks/app/api/proxy-pools/route-4ed867ac6edb2a89.js +1 -0
  420. package/app/.next/static/chunks/app/api/proxy-pools/vercel-deploy/route-4ed867ac6edb2a89.js +1 -0
  421. package/app/.next/static/chunks/app/api/settings/database/route-4ed867ac6edb2a89.js +1 -0
  422. package/app/.next/static/chunks/app/api/settings/proxy-test/route-4ed867ac6edb2a89.js +1 -0
  423. package/app/.next/static/chunks/app/api/settings/require-login/route-4ed867ac6edb2a89.js +1 -0
  424. package/app/.next/static/chunks/app/api/settings/route-4ed867ac6edb2a89.js +1 -0
  425. package/app/.next/static/chunks/app/api/shutdown/route-4ed867ac6edb2a89.js +1 -0
  426. package/app/.next/static/chunks/app/api/tags/route-4ed867ac6edb2a89.js +1 -0
  427. package/app/.next/static/chunks/app/api/translator/console-logs/route-4ed867ac6edb2a89.js +1 -0
  428. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-4ed867ac6edb2a89.js +1 -0
  429. package/app/.next/static/chunks/app/api/translator/load/route-4ed867ac6edb2a89.js +1 -0
  430. package/app/.next/static/chunks/app/api/translator/save/route-4ed867ac6edb2a89.js +1 -0
  431. package/app/.next/static/chunks/app/api/translator/send/route-4ed867ac6edb2a89.js +1 -0
  432. package/app/.next/static/chunks/app/api/translator/translate/route-4ed867ac6edb2a89.js +1 -0
  433. package/app/.next/static/chunks/app/api/tunnel/disable/route-4ed867ac6edb2a89.js +1 -0
  434. package/app/.next/static/chunks/app/api/tunnel/enable/route-4ed867ac6edb2a89.js +1 -0
  435. package/app/.next/static/chunks/app/api/tunnel/status/route-4ed867ac6edb2a89.js +1 -0
  436. package/app/.next/static/chunks/app/api/tunnel/tailscale-check/route-4ed867ac6edb2a89.js +1 -0
  437. package/app/.next/static/chunks/app/api/tunnel/tailscale-disable/route-4ed867ac6edb2a89.js +1 -0
  438. package/app/.next/static/chunks/app/api/tunnel/tailscale-enable/route-4ed867ac6edb2a89.js +1 -0
  439. package/app/.next/static/chunks/app/api/tunnel/tailscale-install/route-4ed867ac6edb2a89.js +1 -0
  440. package/app/.next/static/chunks/app/api/tunnel/tailscale-login/route-4ed867ac6edb2a89.js +1 -0
  441. package/app/.next/static/chunks/app/api/tunnel/tailscale-start-daemon/route-4ed867ac6edb2a89.js +1 -0
  442. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-4ed867ac6edb2a89.js +1 -0
  443. package/app/.next/static/chunks/app/api/usage/chart/route-4ed867ac6edb2a89.js +1 -0
  444. package/app/.next/static/chunks/app/api/usage/history/route-4ed867ac6edb2a89.js +1 -0
  445. package/app/.next/static/chunks/app/api/usage/providers/route-4ed867ac6edb2a89.js +1 -0
  446. package/app/.next/static/chunks/app/api/usage/request-details/route-4ed867ac6edb2a89.js +1 -0
  447. package/app/.next/static/chunks/app/api/usage/request-logs/route-4ed867ac6edb2a89.js +1 -0
  448. package/app/.next/static/chunks/app/api/usage/stats/route-4ed867ac6edb2a89.js +1 -0
  449. package/app/.next/static/chunks/app/api/usage/stream/route-4ed867ac6edb2a89.js +1 -0
  450. package/app/.next/static/chunks/app/api/v1/api/chat/route-4ed867ac6edb2a89.js +1 -0
  451. package/app/.next/static/chunks/app/api/v1/audio/speech/route-4ed867ac6edb2a89.js +1 -0
  452. package/app/.next/static/chunks/app/api/v1/chat/completions/route-4ed867ac6edb2a89.js +1 -0
  453. package/app/.next/static/chunks/app/api/v1/embeddings/route-4ed867ac6edb2a89.js +1 -0
  454. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-4ed867ac6edb2a89.js +1 -0
  455. package/app/.next/static/chunks/app/api/v1/messages/route-4ed867ac6edb2a89.js +1 -0
  456. package/app/.next/static/chunks/app/api/v1/models/route-4ed867ac6edb2a89.js +1 -0
  457. package/app/.next/static/chunks/app/api/v1/responses/compact/route-4ed867ac6edb2a89.js +1 -0
  458. package/app/.next/static/chunks/app/api/v1/responses/route-4ed867ac6edb2a89.js +1 -0
  459. package/app/.next/static/chunks/app/api/v1/route-4ed867ac6edb2a89.js +1 -0
  460. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-4ed867ac6edb2a89.js +1 -0
  461. package/app/.next/static/chunks/app/api/v1beta/models/route-4ed867ac6edb2a89.js +1 -0
  462. package/app/.next/static/chunks/app/api/version/route-4ed867ac6edb2a89.js +1 -0
  463. package/app/.next/static/chunks/app/manifest.webmanifest/route-4ed867ac6edb2a89.js +1 -0
  464. package/app/.next/static/chunks/app/page-4ed867ac6edb2a89.js +1 -0
  465. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-4ed867ac6edb2a89.js +1 -0
  466. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-4ed867ac6edb2a89.js +1 -0
  467. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-4ed867ac6edb2a89.js +1 -0
  468. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-4ed867ac6edb2a89.js +1 -0
  469. package/app/package.json +1 -1
  470. package/app/src/mitm/server.js +6 -1
  471. package/cli.js +62 -36
  472. package/package.json +1 -1
  473. package/app/.next/static/ISW3Q3vhKNz3nIX0Um5qA/_buildManifest.js +0 -1
  474. package/app/.next/static/chunks/8035-f895fe0642100959.js +0 -3
  475. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-ceb851f470785140.js +0 -1
  476. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-ceb851f470785140.js +0 -1
  477. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-ceb851f470785140.js +0 -1
  478. package/app/.next/static/chunks/app/api/cli-tools/copilot-settings/route-ceb851f470785140.js +0 -1
  479. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-ceb851f470785140.js +0 -1
  480. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-ceb851f470785140.js +0 -1
  481. package/app/.next/static/chunks/app/api/cli-tools/opencode-settings/route-ceb851f470785140.js +0 -1
  482. package/app/.next/static/chunks/app/api/cloud/auth/route-ceb851f470785140.js +0 -1
  483. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-ceb851f470785140.js +0 -1
  484. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-ceb851f470785140.js +0 -1
  485. package/app/.next/static/chunks/app/api/cloud/models/alias/route-ceb851f470785140.js +0 -1
  486. package/app/.next/static/chunks/app/api/combos/[id]/route-ceb851f470785140.js +0 -1
  487. package/app/.next/static/chunks/app/api/combos/route-ceb851f470785140.js +0 -1
  488. package/app/.next/static/chunks/app/api/health/route-ceb851f470785140.js +0 -1
  489. package/app/.next/static/chunks/app/api/init/route-ceb851f470785140.js +0 -1
  490. package/app/.next/static/chunks/app/api/keys/[id]/route-ceb851f470785140.js +0 -1
  491. package/app/.next/static/chunks/app/api/keys/route-ceb851f470785140.js +0 -1
  492. package/app/.next/static/chunks/app/api/locale/route-ceb851f470785140.js +0 -1
  493. package/app/.next/static/chunks/app/api/media-providers/tts/elevenlabs/voices/route-ceb851f470785140.js +0 -1
  494. package/app/.next/static/chunks/app/api/media-providers/tts/voices/route-ceb851f470785140.js +0 -1
  495. package/app/.next/static/chunks/app/api/models/alias/route-ceb851f470785140.js +0 -1
  496. package/app/.next/static/chunks/app/api/models/availability/route-ceb851f470785140.js +0 -1
  497. package/app/.next/static/chunks/app/api/models/route-ceb851f470785140.js +0 -1
  498. package/app/.next/static/chunks/app/api/models/test/route-ceb851f470785140.js +0 -1
  499. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-ceb851f470785140.js +0 -1
  500. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-ceb851f470785140.js +0 -1
  501. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-ceb851f470785140.js +0 -1
  502. package/app/.next/static/chunks/app/api/oauth/gitlab/pat/route-ceb851f470785140.js +0 -1
  503. package/app/.next/static/chunks/app/api/oauth/iflow/cookie/route-ceb851f470785140.js +0 -1
  504. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-ceb851f470785140.js +0 -1
  505. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-ceb851f470785140.js +0 -1
  506. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-ceb851f470785140.js +0 -1
  507. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-ceb851f470785140.js +0 -1
  508. package/app/.next/static/chunks/app/api/pricing/route-ceb851f470785140.js +0 -1
  509. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-ceb851f470785140.js +0 -1
  510. package/app/.next/static/chunks/app/api/provider-nodes/route-ceb851f470785140.js +0 -1
  511. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-ceb851f470785140.js +0 -1
  512. package/app/.next/static/chunks/app/api/providers/[id]/models/route-ceb851f470785140.js +0 -1
  513. package/app/.next/static/chunks/app/api/providers/[id]/route-ceb851f470785140.js +0 -1
  514. package/app/.next/static/chunks/app/api/providers/[id]/test/route-ceb851f470785140.js +0 -1
  515. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-ceb851f470785140.js +0 -1
  516. package/app/.next/static/chunks/app/api/providers/client/route-ceb851f470785140.js +0 -1
  517. package/app/.next/static/chunks/app/api/providers/kilo/free-models/route-ceb851f470785140.js +0 -1
  518. package/app/.next/static/chunks/app/api/providers/route-ceb851f470785140.js +0 -1
  519. package/app/.next/static/chunks/app/api/providers/test-batch/route-ceb851f470785140.js +0 -1
  520. package/app/.next/static/chunks/app/api/providers/validate/route-ceb851f470785140.js +0 -1
  521. package/app/.next/static/chunks/app/api/proxy-pools/[id]/route-ceb851f470785140.js +0 -1
  522. package/app/.next/static/chunks/app/api/proxy-pools/[id]/test/route-ceb851f470785140.js +0 -1
  523. package/app/.next/static/chunks/app/api/proxy-pools/route-ceb851f470785140.js +0 -1
  524. package/app/.next/static/chunks/app/api/proxy-pools/vercel-deploy/route-ceb851f470785140.js +0 -1
  525. package/app/.next/static/chunks/app/api/settings/database/route-ceb851f470785140.js +0 -1
  526. package/app/.next/static/chunks/app/api/settings/proxy-test/route-ceb851f470785140.js +0 -1
  527. package/app/.next/static/chunks/app/api/settings/require-login/route-ceb851f470785140.js +0 -1
  528. package/app/.next/static/chunks/app/api/settings/route-ceb851f470785140.js +0 -1
  529. package/app/.next/static/chunks/app/api/shutdown/route-ceb851f470785140.js +0 -1
  530. package/app/.next/static/chunks/app/api/tags/route-ceb851f470785140.js +0 -1
  531. package/app/.next/static/chunks/app/api/translator/console-logs/route-ceb851f470785140.js +0 -1
  532. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-ceb851f470785140.js +0 -1
  533. package/app/.next/static/chunks/app/api/translator/load/route-ceb851f470785140.js +0 -1
  534. package/app/.next/static/chunks/app/api/translator/save/route-ceb851f470785140.js +0 -1
  535. package/app/.next/static/chunks/app/api/translator/send/route-ceb851f470785140.js +0 -1
  536. package/app/.next/static/chunks/app/api/translator/translate/route-ceb851f470785140.js +0 -1
  537. package/app/.next/static/chunks/app/api/tunnel/disable/route-ceb851f470785140.js +0 -1
  538. package/app/.next/static/chunks/app/api/tunnel/enable/route-ceb851f470785140.js +0 -1
  539. package/app/.next/static/chunks/app/api/tunnel/status/route-ceb851f470785140.js +0 -1
  540. package/app/.next/static/chunks/app/api/tunnel/tailscale-check/route-ceb851f470785140.js +0 -1
  541. package/app/.next/static/chunks/app/api/tunnel/tailscale-disable/route-ceb851f470785140.js +0 -1
  542. package/app/.next/static/chunks/app/api/tunnel/tailscale-enable/route-ceb851f470785140.js +0 -1
  543. package/app/.next/static/chunks/app/api/tunnel/tailscale-install/route-ceb851f470785140.js +0 -1
  544. package/app/.next/static/chunks/app/api/tunnel/tailscale-login/route-ceb851f470785140.js +0 -1
  545. package/app/.next/static/chunks/app/api/tunnel/tailscale-start-daemon/route-ceb851f470785140.js +0 -1
  546. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-ceb851f470785140.js +0 -1
  547. package/app/.next/static/chunks/app/api/usage/chart/route-ceb851f470785140.js +0 -1
  548. package/app/.next/static/chunks/app/api/usage/history/route-ceb851f470785140.js +0 -1
  549. package/app/.next/static/chunks/app/api/usage/providers/route-ceb851f470785140.js +0 -1
  550. package/app/.next/static/chunks/app/api/usage/request-details/route-ceb851f470785140.js +0 -1
  551. package/app/.next/static/chunks/app/api/usage/request-logs/route-ceb851f470785140.js +0 -1
  552. package/app/.next/static/chunks/app/api/usage/stats/route-ceb851f470785140.js +0 -1
  553. package/app/.next/static/chunks/app/api/usage/stream/route-ceb851f470785140.js +0 -1
  554. package/app/.next/static/chunks/app/api/v1/api/chat/route-ceb851f470785140.js +0 -1
  555. package/app/.next/static/chunks/app/api/v1/audio/speech/route-ceb851f470785140.js +0 -1
  556. package/app/.next/static/chunks/app/api/v1/chat/completions/route-ceb851f470785140.js +0 -1
  557. package/app/.next/static/chunks/app/api/v1/embeddings/route-ceb851f470785140.js +0 -1
  558. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-ceb851f470785140.js +0 -1
  559. package/app/.next/static/chunks/app/api/v1/messages/route-ceb851f470785140.js +0 -1
  560. package/app/.next/static/chunks/app/api/v1/models/route-ceb851f470785140.js +0 -1
  561. package/app/.next/static/chunks/app/api/v1/responses/route-ceb851f470785140.js +0 -1
  562. package/app/.next/static/chunks/app/api/v1/route-ceb851f470785140.js +0 -1
  563. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-ceb851f470785140.js +0 -1
  564. package/app/.next/static/chunks/app/api/v1beta/models/route-ceb851f470785140.js +0 -1
  565. package/app/.next/static/chunks/app/api/version/route-ceb851f470785140.js +0 -1
  566. package/app/.next/static/chunks/app/manifest.webmanifest/route-ceb851f470785140.js +0 -1
  567. package/app/.next/static/chunks/app/page-ceb851f470785140.js +0 -1
  568. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-ceb851f470785140.js +0 -1
  569. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-ceb851f470785140.js +0 -1
  570. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-ceb851f470785140.js +0 -1
  571. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-ceb851f470785140.js +0 -1
  572. /package/app/.next/static/{ISW3Q3vhKNz3nIX0Um5qA β†’ Seqmp6275x677iq3fTzPt}/_ssgManifest.js +0 -0
@@ -1,3 +1,3 @@
1
- "use strict";exports.id=3774,exports.ids=[3774],exports.modules={13774:(a,b,c)=>{c.d(b,{A1:()=>y,Kp:()=>w,LC:()=>F,OZ:()=>D,PZ:()=>G,Z2:()=>q,ZI:()=>H,a$:()=>v,c$:()=>E,xh:()=>t});var d=c(29021),e=c.n(d),f=c(33873),g=c.n(f),h=c(21820),i=c.n(h),j=c(79646),k=c(98012);c(19931);let l=g().join(i().homedir(),".9router","bin"),m="darwin"===i().platform();i().platform();let n="win32"===i().platform(),o=g().join(l,n?"tailscale.exe":"tailscale"),p=g().join(i().homedir(),".9router","tailscale"),q=g().join(p,"tailscaled.sock"),r=n?[]:["--socket",q];function s(){try{let a=(0,j.execSync)("which tailscale 2>/dev/null || where tailscale 2>nul",{encoding:"utf8"}).trim();if(a)return a}catch(a){}return e().existsSync(o)?o:null}function t(){return null!==s()}function u(...a){return[...r,...a]}function v(){let a=s();if(!a)return!1;try{let b=(0,j.execSync)(`"${a}" ${r.join(" ")} status --json`,{encoding:"utf8",env:{...process.env,PATH:z},timeout:5e3}),c=JSON.parse(b);return"Running"===c.BackendState}catch(a){return!1}}function w(){let a=s();if(!a)return!1;try{let b=(0,j.execSync)(`"${a}" ${r.join(" ")} funnel status --json 2>/dev/null`,{encoding:"utf8"}),c=JSON.parse(b);return Object.keys(c.AllowFunnel||{}).length>0}catch(a){return!1}}function x(a){let b=s();if(!b)return null;try{let a=(0,j.execSync)(`"${b}" ${r.join(" ")} status --json`,{encoding:"utf8"}),c=JSON.parse(a),d=c.Self?.DNSName?.replace(/\.$/,"");if(d)return`https://${d}`}catch(a){}return null}async function y(a,b,c){let d=c||(()=>{});return n?(await C(d),{success:!0}):(m?await A(a,d):await B(a,d),d("Starting daemon..."),await D(a),d("Logging in..."),E(b))}let z=`/usr/local/bin:/opt/homebrew/bin:/usr/bin:/bin:${process.env.PATH||""}`;async function A(a,b){if(function(){try{return(0,j.execSync)("which brew",{stdio:"ignore",env:{...process.env,PATH:z}}),!0}catch{return!1}}()){b("Installing via Homebrew..."),await new Promise((a,c)=>{let d=(0,j.spawn)("brew",["install","tailscale"],{stdio:["ignore","pipe","pipe"],env:{...process.env,PATH:z}});d.stdout.on("data",a=>{let c=a.toString().trim();c&&b(c)}),d.stderr.on("data",a=>{let c=a.toString().trim();c&&b(c)}),d.on("close",b=>{0===b?a():c(Error(`brew install failed (code ${b})`))}),d.on("error",c)});return}let c=g().join(i().tmpdir(),"tailscale.pkg");b("Downloading Tailscale package..."),await new Promise((a,d)=>{let e=(0,j.spawn)("curl",["-fL","--progress-bar","https://pkgs.tailscale.com/stable/tailscale-latest.pkg","-o",c],{stdio:["ignore","pipe","pipe"]});e.stderr.on("data",a=>{let c=a.toString().trim();c&&b(c)}),e.on("close",b=>{0===b?a():d(Error("Download failed"))}),e.on("error",d)}),b("Installing package..."),await new Promise((d,e)=>{let f=(0,j.spawn)("sudo",["-S","installer","-pkg",c,"-target","/"],{stdio:["pipe","pipe","pipe"]}),g="";f.stderr.on("data",a=>{g+=a.toString()}),f.stdout.on("data",a=>{let c=a.toString().trim();c&&b(c)}),f.on("close",a=>{try{(0,j.execSync)(`rm -f ${c}`,{stdio:"ignore"})}catch{}0===a?d():e(Error(g.includes("incorrect password")||g.includes("Sorry")?"Wrong sudo password":g||`Exit code ${a}`))}),f.on("error",e),f.stdin.write(`${a}
2
- `),f.stdin.end()})}async function B(a,b){return b("Downloading install script..."),new Promise((c,d)=>{let e=(0,j.spawn)("curl",["-fsSL","https://tailscale.com/install.sh"],{stdio:["ignore","pipe","pipe"]}),f="",g="";e.stdout.on("data",a=>{f+=a.toString()}),e.stderr.on("data",a=>{g+=a.toString()}),e.on("exit",e=>{if(0!==e)return d(Error(`Failed to download install script: ${g}`));b("Running install script...");let h=(0,j.spawn)("sudo",["-S","sh"],{stdio:["pipe","pipe","pipe"]}),i="";h.stdout.on("data",a=>{let c=a.toString().trim();c&&b(c)}),h.stderr.on("data",a=>{i+=a.toString()}),h.on("close",a=>{0===a?c():d(Error(i.includes("incorrect password")||i.includes("Sorry")?"Wrong sudo password":i||`Exit code ${a}`))}),h.on("error",d),h.stdin.write(`${a}
3
- `),h.stdin.write(f),h.stdin.end()}),e.on("error",d)})}async function C(a){let b=g().join(i().tmpdir(),"tailscale-setup.msi");a("Downloading Tailscale installer..."),await new Promise((c,d)=>{let e=(0,j.spawn)("powershell",["-NoProfile","-NonInteractive","-Command",`Invoke-WebRequest -Uri 'https://pkgs.tailscale.com/stable/tailscale-setup-latest-amd64.msi' -OutFile '${b}'`],{stdio:["ignore","pipe","pipe"]});e.stdout.on("data",b=>{let c=b.toString().trim();c&&a(c)}),e.stderr.on("data",b=>{let c=b.toString().trim();c&&a(c)}),e.on("close",a=>0===a?c():d(Error("Download failed"))),e.on("error",d)}),a("Installing Tailscale (UAC prompt may appear)..."),await new Promise((c,d)=>{let f=(0,j.spawn)("msiexec",["/i",b,"/quiet","/norestart"],{stdio:["ignore","pipe","pipe"]});f.stdout.on("data",b=>{let c=b.toString().trim();c&&a(c)}),f.stderr.on("data",b=>{let c=b.toString().trim();c&&a(c)}),f.on("close",a=>{try{e().unlinkSync(b)}catch{}0===a?c():d(Error(`msiexec failed (code ${a})`))}),f.on("error",d)}),a("Installation complete.")}async function D(a){if(n)return;try{let a=s()||"tailscale";(0,j.execSync)(`"${a}" ${r.join(" ")} status --json`,{stdio:"ignore",env:{...process.env,PATH:z},timeout:3e3});return}catch{}e().existsSync(p)||e().mkdirSync(p,{recursive:!0});let b=`${m?"/usr/local/bin/tailscaled":"tailscaled"} --socket=${q} --statedir=${p}`;await (0,k.execWithPassword)(`nohup ${b} > /dev/null 2>&1 &`,a||""),await new Promise(a=>setTimeout(a,3e3))}function E(a){let b=s();return b?new Promise((c,d)=>{if(D("").catch(()=>{}),v())return void c({alreadyLoggedIn:!0});let e=u("up","--accept-routes");a&&e.push(`--hostname=${a}`);let f=(0,j.spawn)(b,e,{stdio:["ignore","pipe","pipe"],detached:!0}),g=!1,h="",i=setTimeout(()=>{if(g)return;g=!0,f.unref();let a=k(h);a?c({authUrl:a}):d(Error("tailscale up timed out without auth URL"))},15e3),k=a=>{let b=a.match(/https:\/\/login\.tailscale\.com\/a\/[a-zA-Z0-9]+/);return b?b[0]:null},l=a=>{let b=k(h+=a.toString());b&&!g&&(g=!0,clearTimeout(i),f.unref(),c({authUrl:b}))};f.stdout.on("data",l),f.stderr.on("data",l),f.on("error",a=>{g||(g=!0,clearTimeout(i),d(a))}),f.on("exit",a=>{if(g)return;g=!0,clearTimeout(i);let b=k(h);b?c({authUrl:b}):v()?c({alreadyLoggedIn:!0}):d(Error(`tailscale up exited with code ${a}`))})}):Promise.reject(Error("Tailscale not installed"))}async function F(a){let b=s();if(!b)throw Error("Tailscale not installed");try{(0,j.execSync)(`"${b}" ${r.join(" ")} funnel --bg reset`,{stdio:"ignore"})}catch(a){}return new Promise((c,d)=>{let e=(0,j.spawn)(b,u("funnel","--bg",`${a}`),{stdio:["ignore","pipe","pipe"]}),f=!1,g="",h=setTimeout(()=>{if(f)return;f=!0;let b=x(a);b?c({tunnelUrl:b}):d(Error(`Tailscale funnel timed out: ${g.trim()||"no output"}`))},3e4),i=a=>(a.match(/https:\/\/[a-z0-9-]+\.[a-z0-9.-]+\.ts\.net[^\s]*/i)||[])[0]?.replace(/\/$/,"")||null,k=!1,l=a=>{if((g+=a.toString()).includes("Funnel is not enabled")&&(k=!0),k&&!f){let a=g.match(/https:\/\/login\.tailscale\.com\/[^\s]+/);if(a){f=!0,clearTimeout(h),e.kill(),c({funnelNotEnabled:!0,enableUrl:a[0]});return}}let b=i(g);b&&!f&&(f=!0,clearTimeout(h),c({tunnelUrl:b}))};e.stdout.on("data",l),e.stderr.on("data",l),e.on("exit",b=>{if(f)return;f=!0,clearTimeout(h);let e=i(g)||x(a);e?c({tunnelUrl:e}):d(Error(`tailscale funnel failed (code ${b}): ${g.trim()}`))}),e.on("error",a=>{f||(f=!0,clearTimeout(h),d(a))})})}function G(){let a=s();if(a)try{(0,j.execSync)(`"${a}" ${r.join(" ")} funnel --bg reset`,{stdio:"ignore"})}catch(a){}}async function H(a){try{(0,j.execSync)("pkill -x tailscaled",{stdio:"ignore",timeout:3e3})}catch{}try{(0,j.execSync)("pgrep -x tailscaled",{stdio:"ignore",timeout:2e3})}catch{return}if(!n)try{await (0,k.execWithPassword)("pkill -x tailscaled",a||"")}catch{}try{e().existsSync(q)&&e().unlinkSync(q)}catch{}}},19931:(a,b,c)=>{c.d(b,{C7:()=>n,Cr:()=>q,LZ:()=>o,jd:()=>t,r4:()=>r,xS:()=>p});var d=c(29021),e=c.n(d),f=c(33873),g=c.n(f),h=c(21820),i=c.n(h);let j=g().join(i().homedir(),".9router","tunnel"),k=g().join(j,"state.json"),l=g().join(j,"cloudflared.pid");function m(){e().existsSync(j)||e().mkdirSync(j,{recursive:!0})}function n(){try{if(e().existsSync(k))return JSON.parse(e().readFileSync(k,"utf8"))}catch(a){}return null}function o(a){m(),e().writeFileSync(k,JSON.stringify(a,null,2))}function p(a){m(),e().writeFileSync(l,a.toString())}function q(){try{if(e().existsSync(l))return parseInt(e().readFileSync(l,"utf8"))}catch(a){}return null}function r(){try{e().existsSync(l)&&e().unlinkSync(l)}catch(a){}}g().join(j,"tailscale.pid");let s="abcdefghijklmnpqrstuvwxyz23456789";function t(){let a="";for(let b=0;b<6;b++)a+=s.charAt(Math.floor(Math.random()*s.length));return a}}};
1
+ "use strict";exports.id=3774,exports.ids=[3774],exports.modules={13774:(a,b,c)=>{c.d(b,{A1:()=>z,Kp:()=>x,LC:()=>G,OZ:()=>E,PZ:()=>H,Z2:()=>q,ZI:()=>I,a$:()=>w,c$:()=>F,xh:()=>u});var d=c(29021),e=c.n(d),f=c(33873),g=c.n(f),h=c(21820),i=c.n(h),j=c(79646),k=c(98012);c(19931);let l=g().join(i().homedir(),".9router","bin"),m="darwin"===i().platform();i().platform();let n="win32"===i().platform(),o=g().join(l,n?"tailscale.exe":"tailscale"),p=g().join(i().homedir(),".9router","tailscale"),q=g().join(p,"tailscaled.sock"),r=n?[]:["--socket",q],s="C:\\Program Files\\Tailscale\\tailscale.exe";function t(){try{let a=(0,j.execSync)("which tailscale 2>/dev/null || where tailscale 2>nul",{encoding:"utf8",windowsHide:!0}).trim();if(a)return a}catch(a){}return e().existsSync(o)?o:n&&e().existsSync(s)?s:null}function u(){return null!==t()}function v(...a){return[...r,...a]}function w(){let a=t();if(!a)return!1;try{let b=(0,j.execSync)(`"${a}" ${r.join(" ")} status --json`,{encoding:"utf8",windowsHide:!0,env:{...process.env,PATH:A},timeout:5e3}),c=JSON.parse(b);return"Running"===c.BackendState}catch(a){return!1}}function x(){let a=t();if(!a)return!1;try{let b=(0,j.execSync)(`"${a}" ${r.join(" ")} funnel status --json 2>/dev/null`,{encoding:"utf8",windowsHide:!0}),c=JSON.parse(b);return Object.keys(c.AllowFunnel||{}).length>0}catch(a){return!1}}function y(a){let b=t();if(!b)return null;try{let a=(0,j.execSync)(`"${b}" ${r.join(" ")} status --json`,{encoding:"utf8",windowsHide:!0}),c=JSON.parse(a),d=c.Self?.DNSName?.replace(/\.$/,"");if(d)return`https://${d}`}catch(a){}return null}async function z(a,b,c){let d=c||(()=>{});return n?(await D(d),{success:!0}):(m?await B(a,d):await C(a,d),d("Starting daemon..."),await E(a),d("Logging in..."),F(b))}let A=`/usr/local/bin:/opt/homebrew/bin:/usr/bin:/bin:${process.env.PATH||""}`;async function B(a,b){if(function(){try{return(0,j.execSync)("which brew",{stdio:"ignore",windowsHide:!0,env:{...process.env,PATH:A}}),!0}catch{return!1}}()){b("Installing via Homebrew..."),await new Promise((a,c)=>{let d=(0,j.spawn)("brew",["install","tailscale"],{stdio:["ignore","pipe","pipe"],windowsHide:!0,env:{...process.env,PATH:A}});d.stdout.on("data",a=>{let c=a.toString().trim();c&&b(c)}),d.stderr.on("data",a=>{let c=a.toString().trim();c&&b(c)}),d.on("close",b=>{0===b?a():c(Error(`brew install failed (code ${b})`))}),d.on("error",c)});return}let c=g().join(i().tmpdir(),"tailscale.pkg");b("Downloading Tailscale package..."),await new Promise((a,d)=>{let e=(0,j.spawn)("curl",["-fL","--progress-bar","https://pkgs.tailscale.com/stable/tailscale-latest.pkg","-o",c],{stdio:["ignore","pipe","pipe"],windowsHide:!0});e.stderr.on("data",a=>{let c=a.toString().trim();c&&b(c)}),e.on("close",b=>{0===b?a():d(Error("Download failed"))}),e.on("error",d)}),b("Installing package..."),await new Promise((d,e)=>{let f=(0,j.spawn)("sudo",["-S","installer","-pkg",c,"-target","/"],{stdio:["pipe","pipe","pipe"],windowsHide:!0}),g="";f.stderr.on("data",a=>{g+=a.toString()}),f.stdout.on("data",a=>{let c=a.toString().trim();c&&b(c)}),f.on("close",a=>{try{(0,j.execSync)(`rm -f ${c}`,{stdio:"ignore",windowsHide:!0})}catch{}0===a?d():e(Error(g.includes("incorrect password")||g.includes("Sorry")?"Wrong sudo password":g||`Exit code ${a}`))}),f.on("error",e),f.stdin.write(`${a}
2
+ `),f.stdin.end()})}async function C(a,b){return b("Downloading install script..."),new Promise((c,d)=>{let e=(0,j.spawn)("curl",["-fsSL","https://tailscale.com/install.sh"],{stdio:["ignore","pipe","pipe"],windowsHide:!0}),f="",g="";e.stdout.on("data",a=>{f+=a.toString()}),e.stderr.on("data",a=>{g+=a.toString()}),e.on("exit",e=>{if(0!==e)return d(Error(`Failed to download install script: ${g}`));b("Running install script...");let h=(0,j.spawn)("sudo",["-S","sh"],{stdio:["pipe","pipe","pipe"],windowsHide:!0}),i="";h.stdout.on("data",a=>{let c=a.toString().trim();c&&b(c)}),h.stderr.on("data",a=>{i+=a.toString()}),h.on("close",a=>{0===a?c():d(Error(i.includes("incorrect password")||i.includes("Sorry")?"Wrong sudo password":i||`Exit code ${a}`))}),h.on("error",d),h.stdin.write(`${a}
3
+ `),h.stdin.write(f),h.stdin.end()}),e.on("error",d)})}async function D(a){let b=g().join(i().tmpdir(),"tailscale-setup.msi");a("Downloading Tailscale installer..."),await new Promise((c,d)=>{let e=(0,j.spawn)("curl.exe",["-L","-#","-o",b,"https://pkgs.tailscale.com/stable/tailscale-setup-latest-amd64.msi"],{stdio:["ignore","pipe","pipe"],windowsHide:!0}),f="";e.stderr.on("data",b=>{let c=b.toString().match(/(\d+\.\d)%/);c&&c[1]!==f&&(f=c[1],a(`Downloading... ${f}%`))}),e.on("close",a=>0===a?c():d(Error("Download failed"))),e.on("error",d)}),a("Installing Tailscale (UAC prompt may appear)..."),await new Promise((c,d)=>{let f=`'/i','${b}','TS_NOLAUNCH=true','/quiet','/norestart'`,g=(0,j.spawn)("powershell",["-NoProfile","-NonInteractive","-Command",`Start-Process msiexec -ArgumentList ${f} -Verb RunAs -Wait`],{stdio:["ignore","pipe","pipe"],windowsHide:!0});g.stderr.on("data",b=>{let c=b.toString().trim();c&&a(c)}),g.on("close",a=>{try{e().unlinkSync(b)}catch{}0===a?c():d(Error(`msiexec failed (code ${a})`))}),g.on("error",d)}),a("Verifying installation...");let c=Date.now();for(;Date.now()-c<1e4;){if(e().existsSync(s))return void a("Installation complete.");await new Promise(a=>setTimeout(a,1e3))}throw Error("Installation finished but tailscale.exe not found")}async function E(a){if(n)return;try{let a=t()||"tailscale";(0,j.execSync)(`"${a}" ${r.join(" ")} status --json`,{stdio:"ignore",windowsHide:!0,env:{...process.env,PATH:A},timeout:3e3});return}catch{}e().existsSync(p)||e().mkdirSync(p,{recursive:!0});let b=`${m?"/usr/local/bin/tailscaled":"tailscaled"} --socket=${q} --statedir=${p}`;await (0,k.execWithPassword)(`nohup ${b} > /dev/null 2>&1 &`,a||""),await new Promise(a=>setTimeout(a,3e3))}function F(a){let b=t();return b?new Promise((c,d)=>{if(E("").catch(()=>{}),w())return void c({alreadyLoggedIn:!0});let e=v("up","--accept-routes");a&&e.push(`--hostname=${a}`);let f=(0,j.spawn)(b,e,{stdio:["ignore","pipe","pipe"],detached:!0,windowsHide:!0}),g=!1,h="",i=setTimeout(()=>{if(g)return;g=!0,f.unref();let a=k(h);a?c({authUrl:a}):d(Error("tailscale up timed out without auth URL"))},15e3),k=a=>{let b=a.match(/https:\/\/login\.tailscale\.com\/a\/[a-zA-Z0-9]+/);return b?b[0]:null},l=a=>{let b=k(h+=a.toString());b&&!g&&(g=!0,clearTimeout(i),f.unref(),c({authUrl:b}))};f.stdout.on("data",l),f.stderr.on("data",l),f.on("error",a=>{g||(g=!0,clearTimeout(i),d(a))}),f.on("exit",a=>{if(g)return;g=!0,clearTimeout(i);let b=k(h);b?c({authUrl:b}):w()?c({alreadyLoggedIn:!0}):d(Error(`tailscale up exited with code ${a}`))})}):Promise.reject(Error("Tailscale not installed"))}async function G(a){let b=t();if(!b)throw Error("Tailscale not installed");try{(0,j.execSync)(`"${b}" ${r.join(" ")} funnel --bg reset`,{stdio:"ignore",windowsHide:!0})}catch(a){}return new Promise((c,d)=>{let e=(0,j.spawn)(b,v("funnel","--bg",`${a}`),{stdio:["ignore","pipe","pipe"],windowsHide:!0}),f=!1,g="",h=setTimeout(()=>{if(f)return;f=!0;let b=y(a);b?c({tunnelUrl:b}):d(Error(`Tailscale funnel timed out: ${g.trim()||"no output"}`))},3e4),i=a=>(a.match(/https:\/\/[a-z0-9-]+\.[a-z0-9.-]+\.ts\.net[^\s]*/i)||[])[0]?.replace(/\/$/,"")||null,k=!1,l=a=>{if((g+=a.toString()).includes("Funnel is not enabled")&&(k=!0),k&&!f){let a=g.match(/https:\/\/login\.tailscale\.com\/[^\s]+/);if(a){f=!0,clearTimeout(h),e.kill(),c({funnelNotEnabled:!0,enableUrl:a[0]});return}}let b=i(g);b&&!f&&(f=!0,clearTimeout(h),c({tunnelUrl:b}))};e.stdout.on("data",l),e.stderr.on("data",l),e.on("exit",b=>{if(f)return;f=!0,clearTimeout(h);let e=i(g)||y(a);e?c({tunnelUrl:e}):d(Error(`tailscale funnel failed (code ${b}): ${g.trim()}`))}),e.on("error",a=>{f||(f=!0,clearTimeout(h),d(a))})})}function H(){let a=t();if(a)try{(0,j.execSync)(`"${a}" ${r.join(" ")} funnel --bg reset`,{stdio:"ignore",windowsHide:!0})}catch(a){}}async function I(a){try{(0,j.execSync)("pkill -x tailscaled",{stdio:"ignore",windowsHide:!0,timeout:3e3})}catch{}try{(0,j.execSync)("pgrep -x tailscaled",{stdio:"ignore",windowsHide:!0,timeout:2e3})}catch{return}if(!n)try{await (0,k.execWithPassword)("pkill -x tailscaled",a||"")}catch{}try{e().existsSync(q)&&e().unlinkSync(q)}catch{}}},19931:(a,b,c)=>{c.d(b,{C7:()=>n,Cr:()=>q,LZ:()=>o,jd:()=>t,r4:()=>r,xS:()=>p});var d=c(29021),e=c.n(d),f=c(33873),g=c.n(f),h=c(21820),i=c.n(h);let j=g().join(i().homedir(),".9router","tunnel"),k=g().join(j,"state.json"),l=g().join(j,"cloudflared.pid");function m(){e().existsSync(j)||e().mkdirSync(j,{recursive:!0})}function n(){try{if(e().existsSync(k))return JSON.parse(e().readFileSync(k,"utf8"))}catch(a){}return null}function o(a){m(),e().writeFileSync(k,JSON.stringify(a,null,2))}function p(a){m(),e().writeFileSync(l,a.toString())}function q(){try{if(e().existsSync(l))return parseInt(e().readFileSync(l,"utf8"))}catch(a){}return null}function r(){try{e().existsSync(l)&&e().unlinkSync(l)}catch(a){}}g().join(j,"tailscale.pid");let s="abcdefghijklmnpqrstuvwxyz23456789";function t(){let a="";for(let b=0;b<6;b++)a+=s.charAt(Math.floor(Math.random()*s.length));return a}}};
@@ -1,4 +1,4 @@
1
- "use strict";exports.id=450,exports.ids=[450],exports.modules={4565:(a,b,c)=>{c.d(b,{default:()=>k});var d=c(26835),e=c(30978),f=c.n(e),g=c(10074);let h=[{label:"Features",href:"#features"},{label:"Pricing",href:"#pricing"},{label:"Changelog",href:"#"}],i=[{label:"Documentation",href:"#"},{label:"API Reference",href:"#"},{label:"Help Center",href:"#"}],j=[{label:"About",href:"#"},{label:"Blog",href:"#"},{label:"Contact",href:"#"}];function k(){return(0,d.jsx)("footer",{className:"bg-bg border-t border-border pt-16 pb-12",children:(0,d.jsxs)("div",{className:"container mx-auto px-4 sm:px-6 lg:px-8",children:[(0,d.jsxs)("div",{className:"grid grid-cols-2 md:grid-cols-4 lg:grid-cols-5 gap-10 mb-12",children:[(0,d.jsxs)("div",{className:"col-span-2 lg:col-span-2",children:[(0,d.jsxs)("div",{className:"flex items-center gap-2 mb-6",children:[(0,d.jsx)("div",{className:"size-6 text-primary",children:(0,d.jsx)("svg",{className:"w-full h-full",fill:"currentColor",viewBox:"0 0 48 48",children:(0,d.jsx)("path",{clipRule:"evenodd",d:"M12.0799 24L4 19.2479L9.95537 8.75216L18.04 13.4961L18.0446 4H29.9554L29.96 13.4961L38.0446 8.75216L44 19.2479L35.92 24L44 28.7521L38.0446 39.2479L29.96 34.5039L29.9554 44H18.0446L18.04 34.5039L9.95537 39.2479L4 28.7521L12.0799 24Z",fillRule:"evenodd"})})}),(0,d.jsx)("span",{className:"text-xl font-bold text-text-main",children:g.vQ.name})]}),(0,d.jsx)("p",{className:"text-text-muted mb-6 max-w-sm font-light",children:"The unified interface for modern AI infrastructure. Secure, observable, and scalable."}),(0,d.jsxs)("div",{className:"flex gap-4",children:[(0,d.jsx)("a",{href:"#",className:"text-gray-400 hover:text-primary transition-colors","aria-label":"Twitter",children:(0,d.jsx)("svg",{className:"w-5 h-5",fill:"currentColor",viewBox:"0 0 24 24",children:(0,d.jsx)("path",{d:"M22.46 6c-.77.35-1.6.58-2.46.69.88-.53 1.56-1.37 1.88-2.38-.83.5-1.75.85-2.72 1.05C18.37 4.5 17.26 4 16 4c-2.35 0-4.27 1.92-4.27 4.29 0 .34.04.67.11.98C8.28 9.09 5.11 7.38 3 4.79c-.37.63-.58 1.37-.58 2.15 0 1.49.75 2.81 1.91 3.56-.71 0-1.37-.2-1.95-.5v.03c0 2.08 1.48 3.82 3.44 4.21a4.22 4.22 0 0 1-1.93.07 4.28 4.28 0 0 0 4 2.98 8.521 8.521 0 0 1-5.33 1.84c-.34 0-.68-.02-1.02-.06C3.44 20.29 5.7 21 8.12 21 16 21 20.33 14.46 20.33 8.79c0-.19 0-.37-.01-.56.84-.6 1.56-1.36 2.14-2.23z"})})}),(0,d.jsx)("a",{href:"#",className:"text-gray-400 hover:text-primary transition-colors","aria-label":"GitHub",children:(0,d.jsx)("svg",{className:"w-5 h-5",fill:"currentColor",viewBox:"0 0 24 24",children:(0,d.jsx)("path",{d:"M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0 1 12 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0 0 22 12.017C22 6.484 17.522 2 12 2z"})})})]})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("h4",{className:"font-semibold text-text-main mb-4",children:"Product"}),(0,d.jsx)("ul",{className:"flex flex-col gap-3 text-sm text-text-muted font-light",children:h.map(a=>(0,d.jsx)("li",{children:(0,d.jsx)(f(),{href:a.href,className:"hover:text-primary transition-colors",children:a.label})},a.label))})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("h4",{className:"font-semibold text-text-main mb-4",children:"Resources"}),(0,d.jsx)("ul",{className:"flex flex-col gap-3 text-sm text-text-muted font-light",children:i.map(a=>(0,d.jsx)("li",{children:(0,d.jsx)(f(),{href:a.href,className:"hover:text-primary transition-colors",children:a.label})},a.label))})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("h4",{className:"font-semibold text-text-main mb-4",children:"Company"}),(0,d.jsx)("ul",{className:"flex flex-col gap-3 text-sm text-text-muted font-light",children:j.map(a=>(0,d.jsx)("li",{children:(0,d.jsx)(f(),{href:a.href,className:"hover:text-primary transition-colors",children:a.label})},a.label))})]})]}),(0,d.jsxs)("div",{className:"border-t border-border pt-8 flex flex-col md:flex-row justify-between items-center gap-4",children:[(0,d.jsxs)("p",{className:"text-sm text-text-muted",children:["\xa9 ",new Date().getFullYear()," ",g.vQ.name," Inc. All rights reserved."]}),(0,d.jsxs)("div",{className:"flex gap-6 text-sm text-text-muted",children:[(0,d.jsx)(f(),{href:"#",className:"hover:text-primary transition-colors",children:"Privacy Policy"}),(0,d.jsx)(f(),{href:"#",className:"hover:text-primary transition-colors",children:"Terms of Service"})]})]})]})})}},7274:(a,b,c)=>{c.d(b,{default:()=>j});var d=c(26835),e=c(53830),f=c(41183),g=c.n(f),h=c(50450),i=c(93617);function j({isOpen:a,provider:b,providerInfo:c,onSuccess:f,onClose:g,oauthMeta:k}){let[l,m]=(0,e.useState)("waiting"),[n,o]=(0,e.useState)(null),[p,q]=(0,e.useState)(""),[r,s]=(0,e.useState)(null),[t,u]=(0,e.useState)(!1),[v,w]=(0,e.useState)(null),[x,y]=(0,e.useState)(!1),z=(0,e.useRef)(null),A=(0,e.useRef)(!1),{copied:B,copy:C}=(0,i.C)(),[D,E]=(0,e.useState)(!1),[F,G]=(0,e.useState)("/callback?code=...");(0,e.useRef)(!1);let H=(0,e.useCallback)(async(a,c)=>{if(n)try{let d=await fetch(`/api/oauth/${b}/exchange`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:a,redirectUri:n.redirectUri,codeVerifier:n.codeVerifier,state:c,...k?{meta:k}:{}})}),e=await d.json();if(!d.ok)throw Error(e.error);m("success"),f?.()}catch(a){s(a.message),m("error")}},[n,b,f]),I=(0,e.useCallback)(async(a,c,d,e)=>{A.current=!1,y(!0);for(let g=0;g<60;g++){if(A.current){console.log("[OAuthModal] Polling aborted"),y(!1);return}if(await new Promise(a=>setTimeout(a,1e3*d)),A.current){console.log("[OAuthModal] Polling aborted after sleep"),y(!1);return}try{let g=await fetch(`/api/oauth/${b}/poll`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({deviceCode:a,codeVerifier:c,extraData:e})}),h=await g.json();if(h.success){A.current=!0,m("success"),y(!1),f?.();return}if("expired_token"===h.error||"access_denied"===h.error)throw Error(h.errorDescription||h.error);"slow_down"===h.error&&(d=Math.min(d+5,30))}catch(a){s(a.message),m("error"),y(!1);return}}s("Authorization timeout"),m("error"),y(!1)},[b,f]),J=(0,e.useCallback)(async()=>{if(b)try{let a;if(s(null),["github","qwen","kiro","kimi-coding","kilocode","codebuddy"].includes(b)){u(!0),m("waiting");let a=await fetch(`/api/oauth/${b}/device-code`),c=await a.json();if(!a.ok)throw Error(c.error);w(c);let d=c.verification_uri_complete||c.verification_uri;d&&window.open(d,"_blank");let e="kiro"===b?{_clientId:c._clientId,_clientSecret:c._clientSecret}:null;I(c.device_code,c.codeVerifier,c.interval||5,e);return}if("codex"===b)a="http://localhost:1455/auth/callback";else{let b=window.location.port||("https:"===window.location.protocol?"443":"80");a=`http://localhost:${b}/callback`}let c=new URL(`/api/oauth/${b}/authorize`,window.location.origin);c.searchParams.set("redirect_uri",a),k&&Object.entries(k).forEach(([a,b])=>{b&&c.searchParams.set(a,b)});let d=await fetch(c.toString()),e=await d.json();if(!d.ok)throw Error(e.error);o({...e,redirectUri:a}),"codex"!==b&&D?(m("waiting"),z.current=window.open(e.authUrl,"oauth_popup","width=600,height=700"),z.current||m("input")):(m("input"),window.open(e.authUrl,"_blank"))}catch(a){s(a.message),m("error")}},[b,D,I]),K=async()=>{try{s(null);let a=new URL(p),b=a.searchParams.get("code"),c=a.searchParams.get("state"),d=a.searchParams.get("error");if(d)throw Error(a.searchParams.get("error_description")||d);if(!b)throw Error("No authorization code found in URL");await H(b,c)}catch(a){s(a.message),m("error")}},L=(0,e.useCallback)(()=>{g()},[g]);return b&&c?(0,d.jsx)(h.aF,{isOpen:a,title:`Connect ${c.name}`,onClose:L,size:"lg",children:(0,d.jsxs)("div",{className:"flex flex-col gap-4",children:["waiting"===l&&!t&&(0,d.jsxs)("div",{className:"text-center py-6",children:[(0,d.jsx)("div",{className:"size-16 mx-auto mb-4 rounded-full bg-primary/10 flex items-center justify-center",children:(0,d.jsx)("span",{className:"material-symbols-outlined text-3xl text-primary animate-spin",children:"progress_activity"})}),(0,d.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Waiting for Authorization"}),(0,d.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Complete the authorization in the popup window."}),(0,d.jsx)(h.$n,{variant:"ghost",onClick:()=>m("input"),children:"Popup blocked? Enter URL manually"})]}),"waiting"===l&&t&&v&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsxs)("div",{className:"text-center py-4",children:[(0,d.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Visit the URL below and enter the code:"}),(0,d.jsxs)("div",{className:"bg-sidebar p-4 rounded-lg mb-4",children:[(0,d.jsx)("p",{className:"text-xs text-text-muted mb-1",children:"Verification URL"}),(0,d.jsxs)("div",{className:"flex items-center gap-2",children:[(0,d.jsx)("code",{className:"flex-1 text-sm break-all",children:v.verification_uri}),(0,d.jsx)(h.$n,{size:"sm",variant:"ghost",icon:"verify_url"===B?"check":"content_copy",onClick:()=>C(v.verification_uri,"verify_url")})]})]}),(0,d.jsxs)("div",{className:"bg-primary/10 p-4 rounded-lg",children:[(0,d.jsx)("p",{className:"text-xs text-text-muted mb-1",children:"Your Code"}),(0,d.jsxs)("div",{className:"flex items-center justify-center gap-2",children:[(0,d.jsx)("p",{className:"text-2xl font-mono font-bold text-primary",children:v.user_code}),(0,d.jsx)(h.$n,{size:"sm",variant:"ghost",icon:"user_code"===B?"check":"content_copy",onClick:()=>C(v.user_code,"user_code")})]})]})]}),x&&(0,d.jsxs)("div",{className:"flex items-center justify-center gap-2 text-sm text-text-muted",children:[(0,d.jsx)("span",{className:"material-symbols-outlined animate-spin",children:"progress_activity"}),"Waiting for authorization..."]})]}),"input"===l&&!t&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsxs)("div",{className:"space-y-4",children:[(0,d.jsxs)("div",{children:[(0,d.jsx)("p",{className:"text-sm font-medium mb-2",children:"Step 1: Open this URL in your browser"}),(0,d.jsxs)("div",{className:"flex gap-2",children:[(0,d.jsx)(h.pd,{value:n?.authUrl||"",readOnly:!0,className:"flex-1 font-mono text-xs"}),(0,d.jsx)(h.$n,{variant:"secondary",icon:"auth_url"===B?"check":"content_copy",onClick:()=>C(n?.authUrl,"auth_url"),children:"Copy"})]})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("p",{className:"text-sm font-medium mb-2",children:"Step 2: Paste the callback URL here"}),(0,d.jsx)("p",{className:"text-xs text-text-muted mb-2",children:"After authorization, copy the full URL from your browser."}),(0,d.jsx)(h.pd,{value:p,onChange:a=>q(a.target.value),placeholder:F,className:"font-mono text-xs"})]})]}),(0,d.jsxs)("div",{className:"flex gap-2",children:[(0,d.jsx)(h.$n,{onClick:K,fullWidth:!0,disabled:!p,children:"Connect"}),(0,d.jsx)(h.$n,{onClick:L,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]}),"success"===l&&(0,d.jsxs)("div",{className:"text-center py-6",children:[(0,d.jsx)("div",{className:"size-16 mx-auto mb-4 rounded-full bg-green-100 dark:bg-green-900/30 flex items-center justify-center",children:(0,d.jsx)("span",{className:"material-symbols-outlined text-3xl text-green-600",children:"check_circle"})}),(0,d.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Connected Successfully!"}),(0,d.jsxs)("p",{className:"text-sm text-text-muted mb-4",children:["Your ",c.name," account has been connected."]}),(0,d.jsx)(h.$n,{onClick:L,fullWidth:!0,children:"Done"})]}),"error"===l&&(0,d.jsxs)("div",{className:"text-center py-6",children:[(0,d.jsx)("div",{className:"size-16 mx-auto mb-4 rounded-full bg-red-100 dark:bg-red-900/30 flex items-center justify-center",children:(0,d.jsx)("span",{className:"material-symbols-outlined text-3xl text-red-600",children:"error"})}),(0,d.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Connection Failed"}),(0,d.jsx)("p",{className:"text-sm text-red-600 mb-4",children:r}),(0,d.jsxs)("div",{className:"flex gap-2",children:[(0,d.jsx)(h.$n,{onClick:J,variant:"secondary",fullWidth:!0,children:"Try Again"}),(0,d.jsx)(h.$n,{onClick:L,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})]})}):null}j.propTypes={isOpen:g().bool.isRequired,provider:g().string,providerInfo:g().shape({name:g().string}),onSuccess:g().func,onClose:g().func.isRequired,oauthMeta:g().object}},9904:(a,b,c)=>{c.d(b,{default:()=>m});var d=c(26835),e=c(53830),f=c(41183),g=c.n(f),h=c(33809),i=c(65839),j=c(30207);let k=[...Object.keys(j.zN),...Object.keys(j.IS),...Object.keys(j.nJ),...Object.keys(j.fg)],l=Object.keys(j.IS).filter(a=>j.IS[a].noAuth);function m({isOpen:a,onClose:b,onSelect:c,selectedModel:f,activeProviders:g=[],title:n="Select Model",modelAliases:o={}}){let[p,q]=(0,e.useState)(""),[r,s]=(0,e.useState)([]),[t,u]=(0,e.useState)([]),v=(0,e.useMemo)(()=>({...j.zN,...j.IS,...j.nJ,...j.fg}),[]),w=(0,e.useMemo)(()=>{let a={};return[...new Set([...g.map(a=>a.provider),...l])].sort((a,b)=>{let c=k.indexOf(a),d=k.indexOf(b);return(-1===c?999:c)-(-1===d?999:d)}).forEach(b=>{let c=i.Xg[b]||b,d=v[b]||{name:b,color:"#666"},e=(0,j.mq)(b)||(0,j.gb)(b);if(d.passthroughModels){let e=Object.entries(o).filter(([,a])=>a.startsWith(`${c}/`)).map(([a,b])=>({id:b.replace(`${c}/`,""),name:a,value:b}));if(e.length>0){let f=t.find(a=>a.id===b),g=f?.name||d.name;a[b]={name:g,alias:c,color:d.color,models:e}}}else if(e){let c=g.find(a=>a.provider===b),e=t.find(a=>a.id===b),f=c?.name||e?.name||d.name,h=c?.providerSpecificData?.prefix||e?.prefix||b,i=Object.entries(o).filter(([,a])=>a.startsWith(`${b}/`)).map(([a,c])=>({id:c.replace(`${b}/`,""),name:a,value:`${h}/${c.replace(`${b}/`,"")}`})),j=i.length>0?i:[{id:`__placeholder__${b}`,name:`${h}/model-id`,value:`${h}/model-id`,isPlaceholder:!0}];a[b]={name:f,alias:h,color:d.color,models:j,isCustom:!0,hasModels:i.length>0}}else{let e=(0,i.KC)(b),f=new Set(e.map(a=>a.id)),g=e.length>0,h=Object.entries(o).filter(([a,b])=>b.startsWith(`${c}/`)&&(!g||a===b.replace(`${c}/`,""))&&!f.has(b.replace(`${c}/`,""))).map(([a,b])=>({id:b.replace(`${c}/`,""),name:a,value:b,isCustom:!0})),j=[...e.map(a=>({id:a.id,name:a.name,value:`${c}/${a.id}`})),...h];j.length>0&&(a[b]={name:d.name,alias:c,color:d.color,models:j})}}),a},[g,o,v,t]),x=(0,e.useMemo)(()=>{if(!p.trim())return r;let a=p.toLowerCase();return r.filter(b=>b.name.toLowerCase().includes(a))},[r,p]),y=(0,e.useMemo)(()=>{if(!p.trim())return w;let a=p.toLowerCase(),b={};return Object.entries(w).forEach(([c,d])=>{let e=d.models.filter(b=>b.name.toLowerCase().includes(a)||b.id.toLowerCase().includes(a)),f=d.name.toLowerCase().includes(a);(e.length>0||f)&&(b[c]={...d,models:e})}),b},[w,p]),z=a=>{c(a),b(),q("")};return(0,d.jsxs)(h.default,{isOpen:a,onClose:()=>{b(),q("")},title:n,size:"md",className:"p-4!",children:[(0,d.jsx)("div",{className:"mb-3",children:(0,d.jsxs)("div",{className:"relative",children:[(0,d.jsx)("span",{className:"material-symbols-outlined absolute left-2.5 top-1/2 -translate-y-1/2 text-text-muted text-[16px]",children:"search"}),(0,d.jsx)("input",{type:"text",placeholder:"Search...",value:p,onChange:a=>q(a.target.value),className:"w-full pl-8 pr-3 py-1.5 bg-surface border border-border rounded text-xs focus:outline-none focus:ring-1 focus:ring-primary/50"})]})}),(0,d.jsxs)("div",{className:"max-h-[400px] overflow-y-auto space-y-3",children:[x.length>0&&(0,d.jsxs)("div",{children:[(0,d.jsxs)("div",{className:"flex items-center gap-1.5 mb-1.5 sticky top-0 bg-surface py-0.5",children:[(0,d.jsx)("span",{className:"material-symbols-outlined text-primary text-[14px]",children:"layers"}),(0,d.jsx)("span",{className:"text-xs font-medium text-primary",children:"Combos"}),(0,d.jsxs)("span",{className:"text-[10px] text-text-muted",children:["(",x.length,")"]})]}),(0,d.jsx)("div",{className:"flex flex-wrap gap-1.5",children:x.map(a=>{let b=f===a.name;return(0,d.jsx)("button",{onClick:()=>z({id:a.name,name:a.name,value:a.name}),className:`
1
+ "use strict";exports.id=450,exports.ids=[450],exports.modules={4565:(a,b,c)=>{c.d(b,{default:()=>k});var d=c(26835),e=c(30978),f=c.n(e),g=c(10074);let h=[{label:"Features",href:"#features"},{label:"Pricing",href:"#pricing"},{label:"Changelog",href:"#"}],i=[{label:"Documentation",href:"#"},{label:"API Reference",href:"#"},{label:"Help Center",href:"#"}],j=[{label:"About",href:"#"},{label:"Blog",href:"#"},{label:"Contact",href:"#"}];function k(){return(0,d.jsx)("footer",{className:"bg-bg border-t border-border pt-16 pb-12",children:(0,d.jsxs)("div",{className:"container mx-auto px-4 sm:px-6 lg:px-8",children:[(0,d.jsxs)("div",{className:"grid grid-cols-2 md:grid-cols-4 lg:grid-cols-5 gap-10 mb-12",children:[(0,d.jsxs)("div",{className:"col-span-2 lg:col-span-2",children:[(0,d.jsxs)("div",{className:"flex items-center gap-2 mb-6",children:[(0,d.jsx)("div",{className:"size-6 text-primary",children:(0,d.jsx)("svg",{className:"w-full h-full",fill:"currentColor",viewBox:"0 0 48 48",children:(0,d.jsx)("path",{clipRule:"evenodd",d:"M12.0799 24L4 19.2479L9.95537 8.75216L18.04 13.4961L18.0446 4H29.9554L29.96 13.4961L38.0446 8.75216L44 19.2479L35.92 24L44 28.7521L38.0446 39.2479L29.96 34.5039L29.9554 44H18.0446L18.04 34.5039L9.95537 39.2479L4 28.7521L12.0799 24Z",fillRule:"evenodd"})})}),(0,d.jsx)("span",{className:"text-xl font-bold text-text-main",children:g.vQ.name})]}),(0,d.jsx)("p",{className:"text-text-muted mb-6 max-w-sm font-light",children:"The unified interface for modern AI infrastructure. Secure, observable, and scalable."}),(0,d.jsxs)("div",{className:"flex gap-4",children:[(0,d.jsx)("a",{href:"#",className:"text-gray-400 hover:text-primary transition-colors","aria-label":"Twitter",children:(0,d.jsx)("svg",{className:"w-5 h-5",fill:"currentColor",viewBox:"0 0 24 24",children:(0,d.jsx)("path",{d:"M22.46 6c-.77.35-1.6.58-2.46.69.88-.53 1.56-1.37 1.88-2.38-.83.5-1.75.85-2.72 1.05C18.37 4.5 17.26 4 16 4c-2.35 0-4.27 1.92-4.27 4.29 0 .34.04.67.11.98C8.28 9.09 5.11 7.38 3 4.79c-.37.63-.58 1.37-.58 2.15 0 1.49.75 2.81 1.91 3.56-.71 0-1.37-.2-1.95-.5v.03c0 2.08 1.48 3.82 3.44 4.21a4.22 4.22 0 0 1-1.93.07 4.28 4.28 0 0 0 4 2.98 8.521 8.521 0 0 1-5.33 1.84c-.34 0-.68-.02-1.02-.06C3.44 20.29 5.7 21 8.12 21 16 21 20.33 14.46 20.33 8.79c0-.19 0-.37-.01-.56.84-.6 1.56-1.36 2.14-2.23z"})})}),(0,d.jsx)("a",{href:"#",className:"text-gray-400 hover:text-primary transition-colors","aria-label":"GitHub",children:(0,d.jsx)("svg",{className:"w-5 h-5",fill:"currentColor",viewBox:"0 0 24 24",children:(0,d.jsx)("path",{d:"M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0 1 12 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0 0 22 12.017C22 6.484 17.522 2 12 2z"})})})]})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("h4",{className:"font-semibold text-text-main mb-4",children:"Product"}),(0,d.jsx)("ul",{className:"flex flex-col gap-3 text-sm text-text-muted font-light",children:h.map(a=>(0,d.jsx)("li",{children:(0,d.jsx)(f(),{href:a.href,className:"hover:text-primary transition-colors",children:a.label})},a.label))})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("h4",{className:"font-semibold text-text-main mb-4",children:"Resources"}),(0,d.jsx)("ul",{className:"flex flex-col gap-3 text-sm text-text-muted font-light",children:i.map(a=>(0,d.jsx)("li",{children:(0,d.jsx)(f(),{href:a.href,className:"hover:text-primary transition-colors",children:a.label})},a.label))})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("h4",{className:"font-semibold text-text-main mb-4",children:"Company"}),(0,d.jsx)("ul",{className:"flex flex-col gap-3 text-sm text-text-muted font-light",children:j.map(a=>(0,d.jsx)("li",{children:(0,d.jsx)(f(),{href:a.href,className:"hover:text-primary transition-colors",children:a.label})},a.label))})]})]}),(0,d.jsxs)("div",{className:"border-t border-border pt-8 flex flex-col md:flex-row justify-between items-center gap-4",children:[(0,d.jsxs)("p",{className:"text-sm text-text-muted",children:["\xa9 ",new Date().getFullYear()," ",g.vQ.name," Inc. All rights reserved."]}),(0,d.jsxs)("div",{className:"flex gap-6 text-sm text-text-muted",children:[(0,d.jsx)(f(),{href:"#",className:"hover:text-primary transition-colors",children:"Privacy Policy"}),(0,d.jsx)(f(),{href:"#",className:"hover:text-primary transition-colors",children:"Terms of Service"})]})]})]})})}},7274:(a,b,c)=>{c.d(b,{default:()=>j});var d=c(26835),e=c(53830),f=c(41183),g=c.n(f),h=c(50450),i=c(93617);function j({isOpen:a,provider:b,providerInfo:c,onSuccess:f,onClose:g,oauthMeta:k}){let[l,m]=(0,e.useState)("waiting"),[n,o]=(0,e.useState)(null),[p,q]=(0,e.useState)(""),[r,s]=(0,e.useState)(null),[t,u]=(0,e.useState)(!1),[v,w]=(0,e.useState)(null),[x,y]=(0,e.useState)(!1),z=(0,e.useRef)(null),A=(0,e.useRef)(!1),{copied:B,copy:C}=(0,i.C)(),[D,E]=(0,e.useState)(!1),[F,G]=(0,e.useState)("/callback?code=...");(0,e.useRef)(!1);let H=(0,e.useCallback)(async(a,c)=>{if(n)try{let d=await fetch(`/api/oauth/${b}/exchange`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({code:a,redirectUri:n.redirectUri,codeVerifier:n.codeVerifier,state:c,...k?{meta:k}:{}})}),e=await d.json();if(!d.ok)throw Error(e.error);m("success"),f?.()}catch(a){s(a.message),m("error")}},[n,b,f]),I=(0,e.useCallback)(async(a,c,d,e)=>{A.current=!1,y(!0);for(let g=0;g<60;g++){if(A.current){console.log("[OAuthModal] Polling aborted"),y(!1);return}if(await new Promise(a=>setTimeout(a,1e3*d)),A.current){console.log("[OAuthModal] Polling aborted after sleep"),y(!1);return}try{let g=await fetch(`/api/oauth/${b}/poll`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({deviceCode:a,codeVerifier:c,extraData:e})}),h=await g.json();if(h.success){A.current=!0,m("success"),y(!1),f?.();return}if("expired_token"===h.error||"access_denied"===h.error)throw Error(h.errorDescription||h.error);"slow_down"===h.error&&(d=Math.min(d+5,30))}catch(a){s(a.message),m("error"),y(!1);return}}s("Authorization timeout"),m("error"),y(!1)},[b,f]),J=(0,e.useCallback)(async()=>{if(b)try{let a;if(s(null),["github","qwen","kiro","kimi-coding","kilocode","codebuddy"].includes(b)){u(!0),m("waiting");let a=await fetch(`/api/oauth/${b}/device-code`),c=await a.json();if(!a.ok)throw Error(c.error);w(c);let d=c.verification_uri_complete||c.verification_uri;d&&window.open(d,"_blank");let e="kiro"===b?{_clientId:c._clientId,_clientSecret:c._clientSecret}:null;I(c.device_code,c.codeVerifier,c.interval||5,e);return}let c=window.location.port||("https:"===window.location.protocol?"443":"80"),d=!1;if("codex"===b){try{let a=await fetch(`/api/oauth/codex/start-proxy?app_port=${c}`);d=(await a.json()).success}catch{d=!1}a="http://localhost:1455/auth/callback"}else a=`http://localhost:${c}/callback`;let e=new URL(`/api/oauth/${b}/authorize`,window.location.origin);e.searchParams.set("redirect_uri",a),k&&Object.entries(k).forEach(([a,b])=>{b&&e.searchParams.set(a,b)});let f=await fetch(e.toString()),g=await f.json();if(!f.ok)throw Error(g.error);o({...g,redirectUri:a}),"codex"===b&&d||D&&"codex"!==b?(m("waiting"),z.current=window.open(g.authUrl,"oauth_popup","width=600,height=700"),z.current||m("input")):(m("input"),window.open(g.authUrl,"_blank"))}catch(a){s(a.message),m("error")}},[b,D,I]),K=async()=>{try{s(null);let a=new URL(p),b=a.searchParams.get("code"),c=a.searchParams.get("state"),d=a.searchParams.get("error");if(d)throw Error(a.searchParams.get("error_description")||d);if(!b)throw Error("No authorization code found in URL");await H(b,c)}catch(a){s(a.message),m("error")}},L=(0,e.useCallback)(()=>{"codex"===b&&fetch("/api/oauth/codex/stop-proxy").catch(()=>{}),g()},[g,b]);return b&&c?(0,d.jsx)(h.aF,{isOpen:a,title:`Connect ${c.name}`,onClose:L,size:"lg",children:(0,d.jsxs)("div",{className:"flex flex-col gap-4",children:["waiting"===l&&!t&&(0,d.jsxs)("div",{className:"text-center py-6",children:[(0,d.jsx)("div",{className:"size-16 mx-auto mb-4 rounded-full bg-primary/10 flex items-center justify-center",children:(0,d.jsx)("span",{className:"material-symbols-outlined text-3xl text-primary animate-spin",children:"progress_activity"})}),(0,d.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Waiting for Authorization"}),(0,d.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Complete the authorization in the popup window."}),(0,d.jsx)(h.$n,{variant:"ghost",onClick:()=>m("input"),children:"Popup blocked? Enter URL manually"})]}),"waiting"===l&&t&&v&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsxs)("div",{className:"text-center py-4",children:[(0,d.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Visit the URL below and enter the code:"}),(0,d.jsxs)("div",{className:"bg-sidebar p-4 rounded-lg mb-4",children:[(0,d.jsx)("p",{className:"text-xs text-text-muted mb-1",children:"Verification URL"}),(0,d.jsxs)("div",{className:"flex items-center gap-2",children:[(0,d.jsx)("code",{className:"flex-1 text-sm break-all",children:v.verification_uri}),(0,d.jsx)(h.$n,{size:"sm",variant:"ghost",icon:"verify_url"===B?"check":"content_copy",onClick:()=>C(v.verification_uri,"verify_url")})]})]}),(0,d.jsxs)("div",{className:"bg-primary/10 p-4 rounded-lg",children:[(0,d.jsx)("p",{className:"text-xs text-text-muted mb-1",children:"Your Code"}),(0,d.jsxs)("div",{className:"flex items-center justify-center gap-2",children:[(0,d.jsx)("p",{className:"text-2xl font-mono font-bold text-primary",children:v.user_code}),(0,d.jsx)(h.$n,{size:"sm",variant:"ghost",icon:"user_code"===B?"check":"content_copy",onClick:()=>C(v.user_code,"user_code")})]})]})]}),x&&(0,d.jsxs)("div",{className:"flex items-center justify-center gap-2 text-sm text-text-muted",children:[(0,d.jsx)("span",{className:"material-symbols-outlined animate-spin",children:"progress_activity"}),"Waiting for authorization..."]})]}),"input"===l&&!t&&(0,d.jsxs)(d.Fragment,{children:[(0,d.jsxs)("div",{className:"space-y-4",children:[(0,d.jsxs)("div",{children:[(0,d.jsx)("p",{className:"text-sm font-medium mb-2",children:"Step 1: Open this URL in your browser"}),(0,d.jsxs)("div",{className:"flex gap-2",children:[(0,d.jsx)(h.pd,{value:n?.authUrl||"",readOnly:!0,className:"flex-1 font-mono text-xs"}),(0,d.jsx)(h.$n,{variant:"secondary",icon:"auth_url"===B?"check":"content_copy",onClick:()=>C(n?.authUrl,"auth_url"),children:"Copy"})]})]}),(0,d.jsxs)("div",{children:[(0,d.jsx)("p",{className:"text-sm font-medium mb-2",children:"Step 2: Paste the callback URL here"}),(0,d.jsx)("p",{className:"text-xs text-text-muted mb-2",children:"After authorization, copy the full URL from your browser."}),(0,d.jsx)(h.pd,{value:p,onChange:a=>q(a.target.value),placeholder:F,className:"font-mono text-xs"})]})]}),(0,d.jsxs)("div",{className:"flex gap-2",children:[(0,d.jsx)(h.$n,{onClick:K,fullWidth:!0,disabled:!p,children:"Connect"}),(0,d.jsx)(h.$n,{onClick:L,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]}),"success"===l&&(0,d.jsxs)("div",{className:"text-center py-6",children:[(0,d.jsx)("div",{className:"size-16 mx-auto mb-4 rounded-full bg-green-100 dark:bg-green-900/30 flex items-center justify-center",children:(0,d.jsx)("span",{className:"material-symbols-outlined text-3xl text-green-600",children:"check_circle"})}),(0,d.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Connected Successfully!"}),(0,d.jsxs)("p",{className:"text-sm text-text-muted mb-4",children:["Your ",c.name," account has been connected."]}),(0,d.jsx)(h.$n,{onClick:L,fullWidth:!0,children:"Done"})]}),"error"===l&&(0,d.jsxs)("div",{className:"text-center py-6",children:[(0,d.jsx)("div",{className:"size-16 mx-auto mb-4 rounded-full bg-red-100 dark:bg-red-900/30 flex items-center justify-center",children:(0,d.jsx)("span",{className:"material-symbols-outlined text-3xl text-red-600",children:"error"})}),(0,d.jsx)("h3",{className:"text-lg font-semibold mb-2",children:"Connection Failed"}),(0,d.jsx)("p",{className:"text-sm text-red-600 mb-4",children:r}),(0,d.jsxs)("div",{className:"flex gap-2",children:[(0,d.jsx)(h.$n,{onClick:J,variant:"secondary",fullWidth:!0,children:"Try Again"}),(0,d.jsx)(h.$n,{onClick:L,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})]})}):null}j.propTypes={isOpen:g().bool.isRequired,provider:g().string,providerInfo:g().shape({name:g().string}),onSuccess:g().func,onClose:g().func.isRequired,oauthMeta:g().object}},9904:(a,b,c)=>{c.d(b,{default:()=>m});var d=c(26835),e=c(53830),f=c(41183),g=c.n(f),h=c(33809),i=c(65839),j=c(30207);let k=[...Object.keys(j.zN),...Object.keys(j.IS),...Object.keys(j.nJ),...Object.keys(j.fg)],l=Object.keys(j.IS).filter(a=>j.IS[a].noAuth);function m({isOpen:a,onClose:b,onSelect:c,selectedModel:f,activeProviders:g=[],title:n="Select Model",modelAliases:o={}}){let[p,q]=(0,e.useState)(""),[r,s]=(0,e.useState)([]),[t,u]=(0,e.useState)([]),v=(0,e.useMemo)(()=>({...j.zN,...j.IS,...j.nJ,...j.fg}),[]),w=(0,e.useMemo)(()=>{let a={};return[...new Set([...g.map(a=>a.provider),...l])].sort((a,b)=>{let c=k.indexOf(a),d=k.indexOf(b);return(-1===c?999:c)-(-1===d?999:d)}).forEach(b=>{let c=i.Xg[b]||b,d=v[b]||{name:b,color:"#666"},e=(0,j.mq)(b)||(0,j.gb)(b);if(d.passthroughModels){let e=Object.entries(o).filter(([,a])=>a.startsWith(`${c}/`)).map(([a,b])=>({id:b.replace(`${c}/`,""),name:a,value:b}));if(e.length>0){let f=t.find(a=>a.id===b),g=f?.name||d.name;a[b]={name:g,alias:c,color:d.color,models:e}}}else if(e){let c=g.find(a=>a.provider===b),e=t.find(a=>a.id===b),f=c?.name||e?.name||d.name,h=c?.providerSpecificData?.prefix||e?.prefix||b,i=Object.entries(o).filter(([,a])=>a.startsWith(`${b}/`)).map(([a,c])=>({id:c.replace(`${b}/`,""),name:a,value:`${h}/${c.replace(`${b}/`,"")}`})),j=i.length>0?i:[{id:`__placeholder__${b}`,name:`${h}/model-id`,value:`${h}/model-id`,isPlaceholder:!0}];a[b]={name:f,alias:h,color:d.color,models:j,isCustom:!0,hasModels:i.length>0}}else{let e=(0,i.KC)(b),f=new Set(e.map(a=>a.id)),g=e.length>0,h=Object.entries(o).filter(([a,b])=>b.startsWith(`${c}/`)&&(!g||a===b.replace(`${c}/`,""))&&!f.has(b.replace(`${c}/`,""))).map(([a,b])=>({id:b.replace(`${c}/`,""),name:a,value:b,isCustom:!0})),j=[...e.map(a=>({id:a.id,name:a.name,value:`${c}/${a.id}`})),...h];j.length>0&&(a[b]={name:d.name,alias:c,color:d.color,models:j})}}),a},[g,o,v,t]),x=(0,e.useMemo)(()=>{if(!p.trim())return r;let a=p.toLowerCase();return r.filter(b=>b.name.toLowerCase().includes(a))},[r,p]),y=(0,e.useMemo)(()=>{if(!p.trim())return w;let a=p.toLowerCase(),b={};return Object.entries(w).forEach(([c,d])=>{let e=d.models.filter(b=>b.name.toLowerCase().includes(a)||b.id.toLowerCase().includes(a)),f=d.name.toLowerCase().includes(a);(e.length>0||f)&&(b[c]={...d,models:e})}),b},[w,p]),z=a=>{c(a),b(),q("")};return(0,d.jsxs)(h.default,{isOpen:a,onClose:()=>{b(),q("")},title:n,size:"md",className:"p-4!",children:[(0,d.jsx)("div",{className:"mb-3",children:(0,d.jsxs)("div",{className:"relative",children:[(0,d.jsx)("span",{className:"material-symbols-outlined absolute left-2.5 top-1/2 -translate-y-1/2 text-text-muted text-[16px]",children:"search"}),(0,d.jsx)("input",{type:"text",placeholder:"Search...",value:p,onChange:a=>q(a.target.value),className:"w-full pl-8 pr-3 py-1.5 bg-surface border border-border rounded text-xs focus:outline-none focus:ring-1 focus:ring-primary/50"})]})}),(0,d.jsxs)("div",{className:"max-h-[400px] overflow-y-auto space-y-3",children:[x.length>0&&(0,d.jsxs)("div",{children:[(0,d.jsxs)("div",{className:"flex items-center gap-1.5 mb-1.5 sticky top-0 bg-surface py-0.5",children:[(0,d.jsx)("span",{className:"material-symbols-outlined text-primary text-[14px]",children:"layers"}),(0,d.jsx)("span",{className:"text-xs font-medium text-primary",children:"Combos"}),(0,d.jsxs)("span",{className:"text-[10px] text-text-muted",children:["(",x.length,")"]})]}),(0,d.jsx)("div",{className:"flex flex-wrap gap-1.5",children:x.map(a=>{let b=f===a.name;return(0,d.jsx)("button",{onClick:()=>z({id:a.name,name:a.name,value:a.name}),className:`
2
2
  px-2 py-1 rounded-xl text-xs font-medium transition-all border hover:cursor-pointer
3
3
  ${b?"bg-primary text-white border-primary":"bg-surface border-border text-text-main hover:border-primary/50 hover:bg-primary/5"}
4
4
  `,children:a.name},a.id)})})]}),Object.entries(y).map(([a,b])=>(0,d.jsxs)("div",{children:[(0,d.jsxs)("div",{className:"flex items-center gap-1.5 mb-1.5 sticky top-0 bg-surface py-0.5",children:[(0,d.jsx)("div",{className:"w-2 h-2 rounded-full",style:{backgroundColor:b.color}}),(0,d.jsx)("span",{className:"text-xs font-medium text-primary",children:b.name}),(0,d.jsxs)("span",{className:"text-[10px] text-text-muted",children:["(",b.models.length,")"]})]}),(0,d.jsx)("div",{className:"flex flex-wrap gap-1.5",children:b.models.map(a=>{let b=f===a.value,c=a.isPlaceholder;return(0,d.jsx)("button",{onClick:()=>z(a),title:c?"Select to pre-fill, then edit model ID in the input":void 0,className:`
@@ -1,5 +1,5 @@
1
- "use strict";exports.id=514,exports.ids=[514],exports.modules={6021:(a,b,c)=>{c(33873),c(29021);let{MITM_DIR:d}=c(17893),{generateRootCA:e,loadRootCA:f,generateLeafCert:g}=c(89998);a.exports={generateCert:async function a(){return await e()},getCertForDomain:function(a){try{let b=f(),c=g(a,b);return{key:c.key,cert:c.cert}}catch(b){return console.error(`Failed to generate cert for ${a}:`,b.message),null}}}},17893:(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}},28059:(a,b,c)=>{let d=c(29021),e=c(55511),{exec:f}=c(79646),{execWithPassword:g,isSudoAvailable:h}=c(98012),{log:i,err:j}=c(93741),k="win32"===process.platform,l="darwin"===process.platform,m="/usr/local/share/ca-certificates";function n(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 o(a){var b;let c;return k?new Promise(a=>{f('certutil -store Root "9Router MITM Root CA"',{windowsHide:!0},b=>{a(!b)})}):l?(b=a,new Promise(a=>{try{let c=n(b).replace(/:/g,"");f(`security verify-cert -c "${b}" -p ssl -k /Library/Keychains/System.keychain 2>/dev/null`,b=>{if(!b)return a(!0);f(`security dump-trust-settings -d 2>/dev/null | grep -i "${c}"`,(b,c)=>{a(!b&&!!c?.trim())})})}catch{a(!1)}})):(c=`${m}/9router-root-ca.crt`,Promise.resolve(d.existsSync(c)))}async function p(a,b){let c=`security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain "${b}"`;try{await g(`security delete-certificate -c "9Router MITM Root CA" /Library/Keychains/System.keychain 2>/dev/null || true && ${c}`,a),i("\uD83D\uDD10 Cert: βœ… installed to system keychain")}catch(a){throw Error(a.message?.includes("canceled")?"User canceled authorization":"Certificate install failed")}}async function q(a){return new Promise((b,c)=>{f(`certutil -addstore Root "${a}"`,{windowsHide:!0},a=>{a?c(Error(`Failed to install certificate: ${a.message}`)):(i("\uD83D\uDD10 Cert: βœ… installed to Windows Root store"),b())})})}async function r(a,b){let c=n(b).replace(/:/g,""),d=`security delete-certificate -Z "${c}" /Library/Keychains/System.keychain`;try{await g(d,a),i("\uD83D\uDD10 Cert: βœ… uninstalled from system keychain")}catch(a){throw Error("Failed to uninstall certificate")}}async function s(){return new Promise((a,b)=>{f('certutil -delstore Root "9Router MITM Root CA"',{windowsHide:!0},c=>{c?b(Error(`Failed to uninstall certificate: ${c.message}`)):(i("\uD83D\uDD10 Cert: βœ… uninstalled from Windows Root store"),a())})})}async function t(a,b){if(!h())return void i(`πŸ” Cert: cannot install to system store without sudo β€” trust this file on clients: ${b}`);let c=`${m}/9router-root-ca.crt`,d=`cp "${b}" "${c}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(d,a),i("\uD83D\uDD10 Cert: βœ… installed to Linux trust store")}catch(a){throw Error("Certificate install failed")}}async function u(a){if(!h())return;let b=`${m}/9router-root-ca.crt`,c=`rm -f "${b}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(c,a),i("\uD83D\uDD10 Cert: βœ… uninstalled 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 o(b)?i("\uD83D\uDD10 Cert: already trusted βœ…"):k?await q(b):l?await p(a,b):await t(a,b)},uninstallCert:async function a(a,b){await o(b)?k?await s():l?await r(a,b):await u(a):i("\uD83D\uDD10 Cert: not found in system store")},checkCertInstalled:o}},50514:(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,removeAllDNSEntries:o,checkAllDNSStatus:p,TOOL_HOSTS:q,isSudoAvailable:r}=c(98012),s="win32"===process.platform,t="darwin"===process.platform,{generateCert:u}=c(6021),{installCert:v,uninstallCert:w}=c(28059),{isCertExpired:x}=c(89998),{MITM_DIR:y}=c(17893),{log:z,err:A}=c(93741),B="http://localhost:20128";function C(a){return null==a||""===a?"''":`'${String(a).replace(/'/g,"'\\''")}'`}async function D(){if(!T)return B;try{let a=await T(),b=a&&null!=a.mitmRouterBaseUrl?String(a.mitmRouterBaseUrl).trim():"";if(!b)return B;let c=new URL(b);if("http:"!==c.protocol&&"https:"!==c.protocol)return B;return b.replace(/\/+$/,"")}catch{return B}}let E=g.join(y,".mitm.pid"),F=[5e3,1e4,2e4,3e4,6e4],G=0,H=0,I=!1,J=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}(),K="aes-256-gcm",L="9router-mitm-pwd",M=null,N=null;function O(){return globalThis.__mitmSudoPassword||null}function P(a){globalThis.__mitmSudoPassword=a}function Q(a){try{return process.kill(a,0),!0}catch(a){return"EACCES"===a.code}}function R(a,b=!1,e=null){if(s)d(`taskkill ${b?"/F ":""}/PID ${a}`,{windowsHide:!0},()=>{});else{let f=b?"SIGKILL":"SIGTERM",g=`pkill -${f} -P ${a} 2>/dev/null; kill -${f} ${a} 2>/dev/null`;if(e){let{execWithPassword:a}=c(98012);a(g,e).catch(()=>d(g,()=>{}))}else d(g,()=>{})}}function S(){try{let{machineIdSync:a}=c(20243),b=a();return l.createHash("sha256").update(b+L).digest()}catch{return l.createHash("sha256").update(L).digest()}}let T=null,U=null;async function V(a,b){if(U)try{let c,d,e,f,g,h={mitmEnabled:a};b&&(c=S(),d=l.randomBytes(12),e=l.createCipheriv(K,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 U(h)}catch(a){A(`Failed to save settings: ${a.message}`)}}async function W(){if(U)try{await U({mitmSudoEncrypted:null})}catch(a){A(`Failed to clear encrypted password: ${a.message}`)}}async function X(){if(!T)return null;try{let a=await T();if(!a.mitmSudoEncrypted)return null;return function(a){try{let[b,c,d]=a.split(":");if(!b||!c||!d)return null;let e=S(),f=l.createDecipheriv(K,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}}async function Y(a){if(M&&!M.killed){try{M.kill("SIGKILL")}catch{}M=null,N=null}try{if(h.existsSync(E)){let b=parseInt(h.readFileSync(E,"utf-8").trim(),10);b&&Q(b)&&(R(b,!0,a),await new Promise(a=>setTimeout(a,500))),h.unlinkSync(E)}}catch{}if(!s&&J)try{let b=J.replace(/'/g,"'\\''");if(a){let{execWithPassword:d}=c(98012);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{}}async function Z(){let a=null!==M&&!M.killed,b=N;if(!a)try{if(h.existsSync(E)){let c=parseInt(h.readFileSync(E,"utf-8").trim(),10);c&&Q(c)?(a=!0,b=c):h.unlinkSync(E)}}catch{}let d=p(),e=g.join(y,"rootCA.crt"),f=h.existsSync(e),{checkCertInstalled:i}=c(28059),j=!!f&&await i(e);return{running:a,pid:b,certExists:f,certTrusted:j,dnsStatus:d}}async function $(a){if(I)return;if(Date.now()-H>=6e4&&(G=0),G>=5)return void A("Max restart attempts reached. Giving up.");let b=F[Math.min(G,F.length-1)];G++,I=!0,z(`Restarting in ${b/1e3}s... (${G}/5)`),await new Promise(a=>setTimeout(a,b));try{let b=T?await T():null;if(b&&!b.mitmEnabled){z("MITM disabled, skipping restart"),I=!1;return}let c=O()||await X();if(!c&&!s){A("No cached password, cannot auto-restart"),I=!1;return}await _(a,c),z("\uD83D\uDD04 Restarted successfully"),G=0,I=!1}catch(b){A(`Restart attempt ${G}/5 failed: ${b.message}`),I=!1,$(a)}}async function _(a,b){if(!M||M.killed)try{if(h.existsSync(E)){let a=parseInt(h.readFileSync(E,"utf-8").trim(),10);if(a&&Q(a))return N=a,z(`♻️ Reusing existing process (PID: ${a})`),await V(!0,b),b&&P(b),{running:!0,pid:a};h.unlinkSync(E)}}catch{}if(M&&!M.killed)throw Error("MITM server is already running");if(await Y(b),!s){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=>{s?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){z(`Killing orphan node process on port 443 (PID ${a.pid})...`);try{let{execWithPassword:d}=c(98012);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.`)}}}let l=g.join(y,"rootCA.crt"),m=g.join(y,"rootCA.key"),n=h.existsSync(l)&&h.existsSync(m);if(!n||x(l)){if(n){z("\uD83D\uDD10 Cert expired β€” uninstalling old cert...");let a=b||O()||await X();try{await w(a,l)}catch{}}z("\uD83D\uDD10 Generating Root CA..."),await u()}let{checkCertInstalled:o}=c(28059),q=await o(l),B=!s&&!t&&!r();if(q)z("\uD83D\uDD10 Cert: already trusted βœ…");else{z("\uD83D\uDD10 Cert: not trusted β†’ installing...");let a=b||O()||await X();if(B)z(`πŸ” Cert: skipping system trust (no sudo). Install ${l} as a trusted CA on machines that use this proxy.`);else{if(!a&&!s)throw Error("Sudo password required to install Root CA certificate");try{await v(a,l),z("\uD83D\uDD10 Cert: βœ… trusted")}catch(a){throw Error(`Failed to trust certificate: ${a.message}`)}}}let F=await D();if(z(`πŸš€ Starting server... (router: ${F})`),s){try{f('powershell -NonInteractive -WindowStyle Hidden -Command "$c = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1; if ($c -and $c.OwningProcess -gt 4) { Stop-Process -Id $c.OwningProcess -Force -ErrorAction SilentlyContinue }"',{windowsHide:!0}),await new Promise(a=>setTimeout(a,500))}catch{}M=e(process.execPath,[J],{detached:!1,windowsHide:!0,stdio:["ignore","pipe","pipe"],env:{...process.env,ROUTER_API_KEY:a,NODE_ENV:"production",MITM_ROUTER_BASE:F}}),U&&await U({mitmCertInstalled:!0}).catch(()=>{})}else r()?((M=e("sudo",["-S","-E","sh","-c",[`HOME=${C(i.homedir())}`,`ROUTER_API_KEY=${C(a)}`,`MITM_ROUTER_BASE=${C(F)}`,"NODE_ENV=production",C(process.execPath),C(J)].join(" ")],{detached:!1,stdio:["pipe","pipe","pipe"]})).stdin.write(`${b}
2
- `),M.stdin.end()):M=e(process.execPath,[J],{detached:!1,stdio:["ignore","pipe","pipe"],env:{...process.env,ROUTER_API_KEY:a,NODE_ENV:"production",MITM_ROUTER_BASE:F}});M&&(N=M.pid,h.writeFileSync(E,String(N)),H=Date.now());let G=null;M&&(M.stdout.on("data",a=>{process.stdout.write(a)}),M.stderr.on("data",a=>{let b=a.toString().trim();b&&(s||!b.includes("Password:")&&!b.includes("password for"))&&(A(b),G=b),!s&&(b.includes("incorrect password")||b.includes("no password was provided"))&&(P(null),W(),I=!0)}),M.on("exit",b=>{z(`Server exited (code: ${b})`),M=null,N=null;try{h.unlinkSync(E)}catch{}0===b||I||$(a)}));let K=await function(a=443){return new Promise(b=>{let c=Date.now()+8e3,d=()=>{let e=k.request({hostname:"127.0.0.1",port:a,path:"/_mitm_health",method:"GET",rejectUnauthorized:!1},a=>{let c="";a.on("data",a=>{c+=a}),a.on("end",()=>{try{let a=JSON.parse(c);b(!0===a.ok?{ok:!0,pid:a.pid||null}:null)}catch{b(null)}})});e.on("error",()=>{Date.now()<c?setTimeout(d,500):b(null)}),e.end()};d()})}(443);if(!K){if(M&&!M.killed){try{M.kill()}catch{}M=null}let a=function(){try{if(s){let a=f('powershell -NonInteractive -WindowStyle Hidden -Command "$c = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1; if ($c) { $c.OwningProcess } else { 0 }"',{encoding:"utf8",windowsHide:!0}).trim(),b=parseInt(a,10);if(b&&b>4){let a=f(`tasklist /FI "PID eq ${b}" /FO CSV /NH`,{encoding:"utf8",windowsHide:!0}).match(/"([^"]+)"/);if(a)return a[1].replace(".exe","")}}else{let a=f("lsof -i :443",{encoding:"utf8"}).trim().split("\n");if(a.length>1)return a[1].split(/\s+/)[0]}}catch{}return null}(),b=a?` Port 443 already in use by ${a}.`:"",c=G||`Check sudo password or port 443 access.${b}`;throw Error(`MITM server failed to start. ${c}`)}for(let[a,b]of(U&&await U({mitmCertInstalled:!0}).catch(()=>{}),z(`βœ… Server healthy (PID: ${N||K.pid})`),Object.entries(p())))z(`🌐 DNS ${a}: ${b?"βœ… active":"❌ inactive"}`);return await V(!0,b),b&&P(b),{running:!0,pid:N}}async function aa(a){I=!0,G=0,z("⏹ Stopping server...");let b=M,d=b&&!b.killed?b.pid:(()=>{try{return parseInt(h.readFileSync(E,"utf-8").trim(),10)}catch{return null}})();if(d&&Q(d)&&(z(`Killing server (PID: ${d})...`),R(d,!1,a),await new Promise(a=>setTimeout(a,1e3)),Q(d)&&R(d,!0,a)),M=null,N=null,s){let a=g.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"),b=Object.values(q).flat();try{let d=h.readFileSync(a,"utf8").split(/\r?\n/).filter(a=>!b.some(b=>a.includes(b))).join("\r\n");h.writeFileSync(a,d,"utf8"),c(79646).execSync("ipconfig /flushdns",{windowsHide:!0})}catch(a){A(`Failed to clean hosts: ${a.message}`)}}else await o(a);try{h.unlinkSync(E)}catch{}return await V(!1,null),I=!1,{running:!1,pid:null}}async function ab(a,b){if(!(await Z()).running)throw Error("MITM server is not running. Start the server first.");let c=b||O()||await X();return await m(a,c),{success:!0}}a.exports={getMitmStatus:Z,startServer:_,stopServer:aa,enableToolDNS:ab,disableToolDNS:async function a(a,b){let c=b||O()||await X();return await n(a,c),{success:!0}},trustCert:async function a(a){let b=g.join(y,"rootCA.crt");if(!h.existsSync(b))throw Error("Root CA not found. Start server first to generate it.");let{installCert:d}=c(28059);if(!s&&!t&&!r())return void z(`πŸ” Cert: system trust unavailable (no sudo). Use file: ${b}`);let e=a||O()||await X();if(!e&&!s)throw Error("Sudo password required to trust certificate");await d(e,b),e&&P(e)},startMitm:_,stopMitm:aa,getCachedPassword:O,setCachedPassword:P,loadEncryptedPassword:X,clearEncryptedPassword:W,initDbHooks:function(a,b){T=a,U=b}}},89998:(a,b,c)=>{let d=c(33873),e=c(29021),f=c(65978),{MITM_DIR:g}=c(17893),h=d.join(g,"rootCA.key"),i=d.join(g,"rootCA.crt");function j(a){try{let b=f.pki.certificateFromPem(e.readFileSync(a,"utf8")),c=new Date(Date.now()+2592e6);return b.validity.notAfter<c}catch{return!0}}a.exports={generateRootCA:async function a(){let a=e.existsSync(h)&&e.existsSync(i);if(a&&!j(i))return console.log("βœ… Root CA already exists"),{key:h,cert:i};if(a){console.log("\uD83D\uDD10 Root CA expired or expiring soon β€” regenerating...");try{e.unlinkSync(h)}catch{}try{e.unlinkSync(i)}catch{}}e.existsSync(g)||e.mkdirSync(g,{recursive:!0}),console.log("\uD83D\uDD10 Generating Root CA certificate...");let b=f.pki.rsa.generateKeyPair(2048),c=f.pki.createCertificate();c.publicKey=b.publicKey,c.serialNumber="01",c.validity.notBefore=new Date,c.validity.notAfter=new Date,c.validity.notAfter.setFullYear(c.validity.notBefore.getFullYear()+10);let d=[{name:"commonName",value:"9Router MITM Root CA"},{name:"organizationName",value:"9Router"},{name:"countryName",value:"US"}];c.setSubject(d),c.setIssuer(d),c.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,cRLSign:!0,critical:!0},{name:"subjectKeyIdentifier"}]),c.sign(b.privateKey,f.md.sha256.create());let k=f.pki.privateKeyToPem(b.privateKey),l=f.pki.certificateToPem(c);return e.writeFileSync(h,k),e.writeFileSync(i,l),console.log("βœ… Root CA generated successfully"),{key:h,cert:i}},loadRootCA:function(){if(!e.existsSync(h)||!e.existsSync(i))throw Error("Root CA not found. Generate it first.");let a=e.readFileSync(h,"utf8"),b=e.readFileSync(i,"utf8");return{key:f.pki.privateKeyFromPem(a),cert:f.pki.certificateFromPem(b)}},generateLeafCert:function(a,b){let c=f.pki.rsa.generateKeyPair(2048),d=f.pki.createCertificate();return d.publicKey=c.publicKey,d.serialNumber=Math.floor(1e6*Math.random()).toString(),d.validity.notBefore=new Date,d.validity.notAfter=new Date,d.validity.notAfter.setFullYear(d.validity.notBefore.getFullYear()+1),d.setSubject([{name:"commonName",value:a}]),d.setIssuer(b.cert.subject.attributes),d.setExtensions([{name:"basicConstraints",cA:!1},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"subjectAltName",altNames:[{type:2,value:a},{type:2,value:`*.${a}`}]}]),d.sign(b.key,f.md.sha256.create()),{key:f.pki.privateKeyToPem(c.privateKey),cert:f.pki.certificateToPem(d)}},isCertExpired:j,ROOT_CA_CERT_PATH:i,ROOT_CA_KEY_PATH:h}},93741:a=>{function b(){return new Date().toLocaleTimeString("en-US",{hour12:!1})}a.exports={log:a=>console.log(`[${b()}] [MITM] ${a}`),err:a=>console.error(`[${b()}] ❌ [MITM] ${a}`)}},98012:(a,b,c)=>{let{exec:d,spawn:e,execSync:f}=c(79646),g=c(29021),h=c(33873),i=c(21820),{log:j,err:k}=c(93741),l={antigravity:["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com"],copilot:["api.individual.githubcopilot.com"],kiro:["q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com"],cursor:["api2.cursor.sh"]},m="win32"===process.platform,n="darwin"===process.platform,o=m?h.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"):"/etc/hosts";function p(){if(m)return!1;try{return f("command -v sudo",{stdio:"ignore"}),!0}catch{return!1}}function q(a,b){return new Promise((c,d)=>{let f=p(),g=f?e("sudo",["-S","sh","-c",a],{stdio:["pipe","pipe","pipe"]}):e("sh",["-c",a],{stdio:["ignore","pipe","pipe"]}),h="",i="";g.stdout.on("data",a=>{h+=a}),g.stderr.on("data",a=>{i+=a}),g.on("close",a=>{0===a?c(h):d(Error(i||`Exit code ${a}`))}),f&&(g.stdin.write(`${b}
1
+ "use strict";exports.id=514,exports.ids=[514],exports.modules={6021:(a,b,c)=>{c(33873),c(29021);let{MITM_DIR:d}=c(17893),{generateRootCA:e,loadRootCA:f,generateLeafCert:g}=c(89998);a.exports={generateCert:async function a(){return await e()},getCertForDomain:function(a){try{let b=f(),c=g(a,b);return{key:c.key,cert:c.cert}}catch(b){return console.error(`Failed to generate cert for ${a}:`,b.message),null}}}},17893:(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}},28059:(a,b,c)=>{let d=c(29021),e=c(55511),{exec:f}=c(79646),{execWithPassword:g,isSudoAvailable:h}=c(98012),{log:i,err:j}=c(93741),k="win32"===process.platform,l="darwin"===process.platform,m="/usr/local/share/ca-certificates";function n(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 o(a){var b;let c;return k?new Promise(a=>{f('certutil -store Root "9Router MITM Root CA"',{windowsHide:!0},b=>{a(!b)})}):l?(b=a,new Promise(a=>{try{let c=n(b).replace(/:/g,"");f(`security verify-cert -c "${b}" -p ssl -k /Library/Keychains/System.keychain 2>/dev/null`,{windowsHide:!0},b=>{if(!b)return a(!0);f(`security dump-trust-settings -d 2>/dev/null | grep -i "${c}"`,{windowsHide:!0},(b,c)=>{a(!b&&!!c?.trim())})})}catch{a(!1)}})):(c=`${m}/9router-root-ca.crt`,Promise.resolve(d.existsSync(c)))}async function p(a,b){let c=`security add-trusted-cert -d -r trustRoot -k /Library/Keychains/System.keychain "${b}"`;try{await g(`security delete-certificate -c "9Router MITM Root CA" /Library/Keychains/System.keychain 2>/dev/null || true && ${c}`,a),i("\uD83D\uDD10 Cert: βœ… installed to system keychain")}catch(a){throw Error(a.message?.includes("canceled")?"User canceled authorization":"Certificate install failed")}}async function q(a){return new Promise((b,c)=>{f(`certutil -addstore Root "${a}"`,{windowsHide:!0},a=>{a?c(Error(`Failed to install certificate: ${a.message}`)):(i("\uD83D\uDD10 Cert: βœ… installed to Windows Root store"),b())})})}async function r(a,b){let c=n(b).replace(/:/g,""),d=`security delete-certificate -Z "${c}" /Library/Keychains/System.keychain`;try{await g(d,a),i("\uD83D\uDD10 Cert: βœ… uninstalled from system keychain")}catch(a){throw Error("Failed to uninstall certificate")}}async function s(){return new Promise((a,b)=>{f('certutil -delstore Root "9Router MITM Root CA"',{windowsHide:!0},c=>{c?b(Error(`Failed to uninstall certificate: ${c.message}`)):(i("\uD83D\uDD10 Cert: βœ… uninstalled from Windows Root store"),a())})})}async function t(a,b){if(!h())return void i(`πŸ” Cert: cannot install to system store without sudo β€” trust this file on clients: ${b}`);let c=`${m}/9router-root-ca.crt`,d=`cp "${b}" "${c}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(d,a),i("\uD83D\uDD10 Cert: βœ… installed to Linux trust store")}catch(a){throw Error("Certificate install failed")}}async function u(a){if(!h())return;let b=`${m}/9router-root-ca.crt`,c=`rm -f "${b}" && (update-ca-certificates 2>/dev/null || update-ca-trust 2>/dev/null || true)`;try{await g(c,a),i("\uD83D\uDD10 Cert: βœ… uninstalled 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 o(b)?i("\uD83D\uDD10 Cert: already trusted βœ…"):k?await q(b):l?await p(a,b):await t(a,b)},uninstallCert:async function a(a,b){await o(b)?k?await s():l?await r(a,b):await u(a):i("\uD83D\uDD10 Cert: not found in system store")},checkCertInstalled:o}},50514:(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,removeAllDNSEntries:o,checkAllDNSStatus:p,TOOL_HOSTS:q,isSudoAvailable:r}=c(98012),s="win32"===process.platform,t="darwin"===process.platform,{generateCert:u}=c(6021),{installCert:v,uninstallCert:w}=c(28059),{isCertExpired:x}=c(89998),{MITM_DIR:y}=c(17893),{log:z,err:A}=c(93741),B="http://localhost:20128";function C(a){return null==a||""===a?"''":`'${String(a).replace(/'/g,"'\\''")}'`}async function D(){if(!T)return B;try{let a=await T(),b=a&&null!=a.mitmRouterBaseUrl?String(a.mitmRouterBaseUrl).trim():"";if(!b)return B;let c=new URL(b);if("http:"!==c.protocol&&"https:"!==c.protocol)return B;return b.replace(/\/+$/,"")}catch{return B}}let E=g.join(y,".mitm.pid"),F=[5e3,1e4,2e4,3e4,6e4],G=0,H=0,I=!1,J=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}(),K="aes-256-gcm",L="9router-mitm-pwd",M=null,N=null;function O(){return globalThis.__mitmSudoPassword||null}function P(a){globalThis.__mitmSudoPassword=a}function Q(a){try{return process.kill(a,0),!0}catch(a){return"EACCES"===a.code}}function R(a,b=!1,e=null){if(s)d(`taskkill ${b?"/F ":""}/PID ${a}`,{windowsHide:!0},()=>{});else{let f=b?"SIGKILL":"SIGTERM",g=`pkill -${f} -P ${a} 2>/dev/null; kill -${f} ${a} 2>/dev/null`;if(e){let{execWithPassword:a}=c(98012);a(g,e).catch(()=>d(g,{windowsHide:!0},()=>{}))}else d(g,{windowsHide:!0},()=>{})}}function S(){try{let{machineIdSync:a}=c(20243),b=a();return l.createHash("sha256").update(b+L).digest()}catch{return l.createHash("sha256").update(L).digest()}}let T=null,U=null;async function V(a,b){if(U)try{let c,d,e,f,g,h={mitmEnabled:a};b&&(c=S(),d=l.randomBytes(12),e=l.createCipheriv(K,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 U(h)}catch(a){A(`Failed to save settings: ${a.message}`)}}async function W(){if(U)try{await U({mitmSudoEncrypted:null})}catch(a){A(`Failed to clear encrypted password: ${a.message}`)}}async function X(){if(!T)return null;try{let a=await T();if(!a.mitmSudoEncrypted)return null;return function(a){try{let[b,c,d]=a.split(":");if(!b||!c||!d)return null;let e=S(),f=l.createDecipheriv(K,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}}async function Y(a){if(M&&!M.killed){try{M.kill("SIGKILL")}catch{}M=null,N=null}try{if(h.existsSync(E)){let b=parseInt(h.readFileSync(E,"utf-8").trim(),10);b&&Q(b)&&(R(b,!0,a),await new Promise(a=>setTimeout(a,500))),h.unlinkSync(E)}}catch{}if(!s&&J)try{let b=J.replace(/'/g,"'\\''");if(a){let{execWithPassword:d}=c(98012);await d(`pkill -SIGKILL -f "${b}" 2>/dev/null || true`,a).catch(()=>{})}else d(`pkill -SIGKILL -f "${b}" 2>/dev/null || true`,{windowsHide:!0},()=>{});await new Promise(a=>setTimeout(a,500))}catch{}}async function Z(){let a=null!==M&&!M.killed,b=N;if(!a)try{if(h.existsSync(E)){let c=parseInt(h.readFileSync(E,"utf-8").trim(),10);c&&Q(c)?(a=!0,b=c):h.unlinkSync(E)}}catch{}let d=p(),e=g.join(y,"rootCA.crt"),f=h.existsSync(e),{checkCertInstalled:i}=c(28059),j=!!f&&await i(e);return{running:a,pid:b,certExists:f,certTrusted:j,dnsStatus:d}}async function $(a){if(I)return;if(Date.now()-H>=6e4&&(G=0),G>=5)return void A("Max restart attempts reached. Giving up.");let b=F[Math.min(G,F.length-1)];G++,I=!0,z(`Restarting in ${b/1e3}s... (${G}/5)`),await new Promise(a=>setTimeout(a,b));try{let b=T?await T():null;if(b&&!b.mitmEnabled){z("MITM disabled, skipping restart"),I=!1;return}let c=O()||await X();if(!c&&!s){A("No cached password, cannot auto-restart"),I=!1;return}await _(a,c),z("\uD83D\uDD04 Restarted successfully"),G=0,I=!1}catch(b){A(`Restart attempt ${G}/5 failed: ${b.message}`),I=!1,$(a)}}async function _(a,b){if(!M||M.killed)try{if(h.existsSync(E)){let a=parseInt(h.readFileSync(E,"utf-8").trim(),10);if(a&&Q(a))return N=a,z(`♻️ Reusing existing process (PID: ${a})`),await V(!0,b),b&&P(b),{running:!0,pid:a};h.unlinkSync(E)}}catch{}if(M&&!M.killed)throw Error("MITM server is already running");if(await Y(b),!s){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=>{s?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("lsof -nP -iTCP:443 -sTCP:LISTEN -t",{windowsHide:!0},(b,c)=>{if(b||!c?.trim())return a(null);let e=parseInt(c.trim().split("\n")[0],10);if(!e||isNaN(e))return a(null);d(`ps -p ${e} -o comm=`,{windowsHide:!0},(b,c)=>{a({pid:e,name:c?.trim()||"unknown"})})})});if(a&&("node"===a.name||a.name.includes("node"))){z(`Killing orphan node process on port 443 (PID ${a.pid}, name=${a.name})...`);try{let{execWithPassword:d}=c(98012);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.`)}}}let l=g.join(y,"rootCA.crt"),m=g.join(y,"rootCA.key"),n=h.existsSync(l)&&h.existsSync(m);if(!n||x(l)){if(n){z("\uD83D\uDD10 Cert expired β€” uninstalling old cert...");let a=b||O()||await X();try{await w(a,l)}catch{}}z("\uD83D\uDD10 Generating Root CA..."),await u()}let{checkCertInstalled:o}=c(28059),q=await o(l),B=!s&&!t&&!r();if(q)z("\uD83D\uDD10 Cert: already trusted βœ…");else{z("\uD83D\uDD10 Cert: not trusted β†’ installing...");let a=b||O()||await X();if(B)z(`πŸ” Cert: skipping system trust (no sudo). Install ${l} as a trusted CA on machines that use this proxy.`);else{if(!a&&!s)throw Error("Sudo password required to install Root CA certificate");try{await v(a,l),z("\uD83D\uDD10 Cert: βœ… trusted")}catch(a){throw Error(`Failed to trust certificate: ${a.message}`)}}}let F=await D();if(z(`πŸš€ Starting server... (router: ${F})`),s){try{f('powershell -NonInteractive -WindowStyle Hidden -Command "$c = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1; if ($c -and $c.OwningProcess -gt 4) { Stop-Process -Id $c.OwningProcess -Force -ErrorAction SilentlyContinue }"',{windowsHide:!0}),await new Promise(a=>setTimeout(a,500))}catch{}M=e(process.execPath,[J],{detached:!1,windowsHide:!0,stdio:["ignore","pipe","pipe"],env:{...process.env,ROUTER_API_KEY:a,NODE_ENV:"production",MITM_ROUTER_BASE:F}}),U&&await U({mitmCertInstalled:!0}).catch(()=>{})}else r()?((M=e("sudo",["-S","-E","sh","-c",[`HOME=${C(i.homedir())}`,`ROUTER_API_KEY=${C(a)}`,`MITM_ROUTER_BASE=${C(F)}`,"NODE_ENV=production",C(process.execPath),C(J)].join(" ")],{detached:!1,windowsHide:!0,stdio:["pipe","pipe","pipe"]})).stdin.write(`${b}
2
+ `),M.stdin.end()):M=e(process.execPath,[J],{detached:!1,windowsHide:!0,stdio:["ignore","pipe","pipe"],env:{...process.env,ROUTER_API_KEY:a,NODE_ENV:"production",MITM_ROUTER_BASE:F}});M&&(N=M.pid,h.writeFileSync(E,String(N)),H=Date.now());let G=null;M&&(M.stdout.on("data",a=>{process.stdout.write(a)}),M.stderr.on("data",a=>{let b=a.toString().trim();b&&(s||!b.includes("Password:")&&!b.includes("password for"))&&(A(b),G=b),!s&&(b.includes("incorrect password")||b.includes("no password was provided"))&&(P(null),W(),I=!0)}),M.on("exit",b=>{z(`Server exited (code: ${b})`),M=null,N=null;try{h.unlinkSync(E)}catch{}0===b||I||$(a)}));let K=await function(a=443){return new Promise(b=>{let c=Date.now()+8e3,d=()=>{let e=k.request({hostname:"127.0.0.1",port:a,path:"/_mitm_health",method:"GET",rejectUnauthorized:!1},a=>{let c="";a.on("data",a=>{c+=a}),a.on("end",()=>{try{let a=JSON.parse(c);b(!0===a.ok?{ok:!0,pid:a.pid||null}:null)}catch{b(null)}})});e.on("error",()=>{Date.now()<c?setTimeout(d,500):b(null)}),e.end()};d()})}(443);if(!K){if(M&&!M.killed){try{M.kill()}catch{}M=null}let a=function(){try{if(s){let a=f('powershell -NonInteractive -WindowStyle Hidden -Command "$c = Get-NetTCPConnection -LocalPort 443 -State Listen -ErrorAction SilentlyContinue | Select-Object -First 1; if ($c) { $c.OwningProcess } else { 0 }"',{encoding:"utf8",windowsHide:!0}).trim(),b=parseInt(a,10);if(b&&b>4){let a=f(`tasklist /FI "PID eq ${b}" /FO CSV /NH`,{encoding:"utf8",windowsHide:!0}).match(/"([^"]+)"/);if(a)return a[1].replace(".exe","")}}else{let a=f("lsof -i :443",{encoding:"utf8",windowsHide:!0}).trim().split("\n");if(a.length>1)return a[1].split(/\s+/)[0]}}catch{}return null}(),b=a?` Port 443 already in use by ${a}.`:"",c=G||`Check sudo password or port 443 access.${b}`;throw Error(`MITM server failed to start. ${c}`)}for(let[a,b]of(U&&await U({mitmCertInstalled:!0}).catch(()=>{}),z(`βœ… Server healthy (PID: ${N||K.pid})`),Object.entries(p())))z(`🌐 DNS ${a}: ${b?"βœ… active":"❌ inactive"}`);return await V(!0,b),b&&P(b),{running:!0,pid:N}}async function aa(a){I=!0,G=0,z("⏹ Stopping server...");let b=M,d=b&&!b.killed?b.pid:(()=>{try{return parseInt(h.readFileSync(E,"utf-8").trim(),10)}catch{return null}})();if(d&&Q(d)&&(z(`Killing server (PID: ${d})...`),R(d,!1,a),await new Promise(a=>setTimeout(a,1e3)),Q(d)&&R(d,!0,a)),M=null,N=null,s){let a=g.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"),b=Object.values(q).flat();try{let d=h.readFileSync(a,"utf8").split(/\r?\n/).filter(a=>!b.some(b=>a.includes(b))).join("\r\n");h.writeFileSync(a,d,"utf8"),c(79646).execSync("ipconfig /flushdns",{windowsHide:!0})}catch(a){A(`Failed to clean hosts: ${a.message}`)}}else await o(a);try{h.unlinkSync(E)}catch{}return await V(!1,null),I=!1,{running:!1,pid:null}}async function ab(a,b){if(!(await Z()).running)throw Error("MITM server is not running. Start the server first.");let c=b||O()||await X();return await m(a,c),{success:!0}}a.exports={getMitmStatus:Z,startServer:_,stopServer:aa,enableToolDNS:ab,disableToolDNS:async function a(a,b){let c=b||O()||await X();return await n(a,c),{success:!0}},trustCert:async function a(a){let b=g.join(y,"rootCA.crt");if(!h.existsSync(b))throw Error("Root CA not found. Start server first to generate it.");let{installCert:d}=c(28059);if(!s&&!t&&!r())return void z(`πŸ” Cert: system trust unavailable (no sudo). Use file: ${b}`);let e=a||O()||await X();if(!e&&!s)throw Error("Sudo password required to trust certificate");await d(e,b),e&&P(e)},startMitm:_,stopMitm:aa,getCachedPassword:O,setCachedPassword:P,loadEncryptedPassword:X,clearEncryptedPassword:W,initDbHooks:function(a,b){T=a,U=b}}},89998:(a,b,c)=>{let d=c(33873),e=c(29021),f=c(65978),{MITM_DIR:g}=c(17893),h=d.join(g,"rootCA.key"),i=d.join(g,"rootCA.crt");function j(a){try{let b=f.pki.certificateFromPem(e.readFileSync(a,"utf8")),c=new Date(Date.now()+2592e6);return b.validity.notAfter<c}catch{return!0}}a.exports={generateRootCA:async function a(){let a=e.existsSync(h)&&e.existsSync(i);if(a&&!j(i))return console.log("βœ… Root CA already exists"),{key:h,cert:i};if(a){console.log("\uD83D\uDD10 Root CA expired or expiring soon β€” regenerating...");try{e.unlinkSync(h)}catch{}try{e.unlinkSync(i)}catch{}}e.existsSync(g)||e.mkdirSync(g,{recursive:!0}),console.log("\uD83D\uDD10 Generating Root CA certificate...");let b=f.pki.rsa.generateKeyPair(2048),c=f.pki.createCertificate();c.publicKey=b.publicKey,c.serialNumber="01",c.validity.notBefore=new Date,c.validity.notAfter=new Date,c.validity.notAfter.setFullYear(c.validity.notBefore.getFullYear()+10);let d=[{name:"commonName",value:"9Router MITM Root CA"},{name:"organizationName",value:"9Router"},{name:"countryName",value:"US"}];c.setSubject(d),c.setIssuer(d),c.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,cRLSign:!0,critical:!0},{name:"subjectKeyIdentifier"}]),c.sign(b.privateKey,f.md.sha256.create());let k=f.pki.privateKeyToPem(b.privateKey),l=f.pki.certificateToPem(c);return e.writeFileSync(h,k),e.writeFileSync(i,l),console.log("βœ… Root CA generated successfully"),{key:h,cert:i}},loadRootCA:function(){if(!e.existsSync(h)||!e.existsSync(i))throw Error("Root CA not found. Generate it first.");let a=e.readFileSync(h,"utf8"),b=e.readFileSync(i,"utf8");return{key:f.pki.privateKeyFromPem(a),cert:f.pki.certificateFromPem(b)}},generateLeafCert:function(a,b){let c=f.pki.rsa.generateKeyPair(2048),d=f.pki.createCertificate();return d.publicKey=c.publicKey,d.serialNumber=Math.floor(1e6*Math.random()).toString(),d.validity.notBefore=new Date,d.validity.notAfter=new Date,d.validity.notAfter.setFullYear(d.validity.notBefore.getFullYear()+1),d.setSubject([{name:"commonName",value:a}]),d.setIssuer(b.cert.subject.attributes),d.setExtensions([{name:"basicConstraints",cA:!1},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"subjectAltName",altNames:[{type:2,value:a},{type:2,value:`*.${a}`}]}]),d.sign(b.key,f.md.sha256.create()),{key:f.pki.privateKeyToPem(c.privateKey),cert:f.pki.certificateToPem(d)}},isCertExpired:j,ROOT_CA_CERT_PATH:i,ROOT_CA_KEY_PATH:h}},93741:a=>{function b(){return new Date().toLocaleTimeString("en-US",{hour12:!1})}a.exports={log:a=>console.log(`[${b()}] [MITM] ${a}`),err:a=>console.error(`[${b()}] ❌ [MITM] ${a}`)}},98012:(a,b,c)=>{let{exec:d,spawn:e,execSync:f}=c(79646),g=c(29021),h=c(33873),i=c(21820),{log:j,err:k}=c(93741),l={antigravity:["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com"],copilot:["api.individual.githubcopilot.com"],kiro:["q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com"],cursor:["api2.cursor.sh"]},m="win32"===process.platform,n="darwin"===process.platform,o=m?h.join(process.env.SystemRoot||"C:\\Windows","System32","drivers","etc","hosts"):"/etc/hosts";function p(){if(m)return!1;try{return f("command -v sudo",{stdio:"ignore",windowsHide:!0}),!0}catch{return!1}}function q(a,b){return new Promise((c,d)=>{let f=p(),g=f?e("sudo",["-S","sh","-c",a],{stdio:["pipe","pipe","pipe"],windowsHide:!0}):e("sh",["-c",a],{stdio:["ignore","pipe","pipe"],windowsHide:!0}),h="",i="";g.stdout.on("data",a=>{h+=a}),g.stderr.on("data",a=>{i+=a}),g.on("close",a=>{0===a?c(h):d(Error(i||`Exit code ${a}`))}),f&&(g.stdin.write(`${b}
3
3
  `),g.stdin.end())})}async function r(a){m||(n?await q("dscacheutil -flushcache && killall -HUP mDNSResponder",a):await q("resolvectl flush-caches 2>/dev/null || true",a))}function s(a=null){try{let b=g.readFileSync(o,"utf8");if(a)return b.includes(a);return l.antigravity.every(a=>b.includes(a))}catch{return!1}}async function t(a,b){let d=l[a];if(!d)throw Error(`Unknown tool: ${a}`);let e=d.filter(a=>!s(a));if(0===e.length)return void j(`🌐 DNS ${a}: already active`);let f=e.map(a=>`127.0.0.1 ${a}`).join("\n");try{if(m){let a=e.map(a=>`127.0.0.1 ${a}`).join("\r\n")+"\r\n";g.appendFileSync(o,a,"utf8"),c(79646).execSync("ipconfig /flushdns",{windowsHide:!0})}else await q(`echo "${f}" >> ${o}`,b),await r(b);j(`🌐 DNS ${a}: βœ… added ${e.join(", ")}`)}catch(a){throw Error(a.message?.includes("incorrect password")?"Wrong sudo password":"Failed to add DNS entry")}}async function u(a,b){let d=l[a];if(!d)throw Error(`Unknown tool: ${a}`);let e=d.filter(a=>s(a));if(0===e.length)return void j(`🌐 DNS ${a}: already inactive`);try{if(m){let a=g.readFileSync(o,"utf8").split(/\r?\n/).filter(a=>!e.some(b=>a.includes(b))).join("\r\n");g.writeFileSync(o,a,"utf8"),c(79646).execSync("ipconfig /flushdns",{windowsHide:!0})}else{for(let a of e){let c=n?`sed -i '' '/${a}/d' ${o}`:`sed -i '/${a}/d' ${o}`;await q(c,b)}await r(b)}j(`🌐 DNS ${a}: βœ… removed ${e.join(", ")}`)}catch(a){throw Error(a.message?.includes("incorrect password")?"Wrong sudo password":"Failed to remove DNS entry")}}async function v(a){for(let b of Object.keys(l))try{await u(b,a)}catch(a){k(`DNS ${b}: failed to remove β€” ${a.message}`)}}a.exports={TOOL_HOSTS:l,addDNSEntry:t,removeDNSEntry:u,removeAllDNSEntries:v,execWithPassword:q,isSudoAvailable:p,executeElevatedPowerShell:function(a,b=3e4){let c=h.join(i.tmpdir(),`ps_done_${Date.now()}.flag`),e=g.readFileSync(a,"utf8");e+=`
4
4
  Set-Content -Path '${c.replace(/'/g,"''")}' -Value 'done' -Encoding UTF8
5
5
  `,g.writeFileSync(a,e,"utf8");let f=`Start-Process powershell -ArgumentList '-NoProfile','-ExecutionPolicy','Bypass','-WindowStyle','Hidden','-File','${a.replace(/'/g,"''")}' -Verb RunAs -WindowStyle Hidden`;return new Promise((e,h)=>{let i=!1,j=(a,b)=>{i||(i=!0,a(b))};d(`powershell -NoProfile -NonInteractive -WindowStyle Hidden -Command "${f}"`,{windowsHide:!0},()=>{});let k=Date.now()+b,l=()=>{if(!i){if(g.existsSync(c)){try{g.unlinkSync(c),g.unlinkSync(a)}catch{}return j(e)}if(Date.now()>k){try{g.unlinkSync(a)}catch{}return j(h,Error("Timed out waiting for UAC confirmation"))}setTimeout(l,500)}};setTimeout(l,300)})},checkDNSEntry:s,checkAllDNSStatus:function(){try{let a=g.readFileSync(o,"utf8"),b={};for(let[c,d]of Object.entries(l))b[c]=d.every(b=>a.includes(b));return b}catch{return Object.fromEntries(Object.keys(l).map(a=>[a,!1]))}}}}};
@@ -0,0 +1 @@
1
+ "use strict";exports.id=586,exports.ids=[586],exports.modules={30586:(a,b,c)=>{c.d(b,{PROVIDER_PRICING:()=>e,getPricingForModel:()=>h});let d={"claude-opus-4-6":{input:5,output:25,cached:.5,reasoning:25,cache_creation:6.25},"claude-opus-4-5-20251101":{input:5,output:25,cached:.5,reasoning:25,cache_creation:6.25},"claude-sonnet-4-6":{input:3,output:15,cached:.3,reasoning:15,cache_creation:3.75},"claude-sonnet-4-5-20250929":{input:3,output:15,cached:.3,reasoning:15,cache_creation:3.75},"claude-haiku-4-5-20251001":{input:1,output:5,cached:.1,reasoning:5,cache_creation:1.25},"claude-sonnet-4-20250514":{input:3,output:15,cached:1.5,reasoning:15,cache_creation:3},"claude-opus-4-20250514":{input:15,output:25,cached:7.5,reasoning:112.5,cache_creation:15},"claude-3-5-sonnet-20241022":{input:3,output:15,cached:1.5,reasoning:15,cache_creation:3},"claude-haiku-4.5":{input:.5,output:2.5,cached:.05,reasoning:3.75,cache_creation:.5},"claude-opus-4.1":{input:5,output:25,cached:.5,reasoning:37.5,cache_creation:5},"claude-opus-4.5":{input:5,output:25,cached:.5,reasoning:37.5,cache_creation:5},"claude-opus-4.6":{input:5,output:25,cached:.5,reasoning:37.5,cache_creation:5},"claude-sonnet-4":{input:3,output:15,cached:.3,reasoning:22.5,cache_creation:3},"claude-sonnet-4.5":{input:3,output:15,cached:.3,reasoning:22.5,cache_creation:3},"claude-sonnet-4.6":{input:3,output:15,cached:.3,reasoning:22.5,cache_creation:3},"claude-opus-4-5-thinking":{input:5,output:25,cached:.5,reasoning:37.5,cache_creation:5},"claude-opus-4-6-thinking":{input:5,output:25,cached:.5,reasoning:37.5,cache_creation:5},"gpt-3.5-turbo":{input:.5,output:1.5,cached:.25,reasoning:2.25,cache_creation:.5},"gpt-4":{input:2.5,output:10,cached:1.25,reasoning:15,cache_creation:2.5},"gpt-4-turbo":{input:10,output:30,cached:5,reasoning:45,cache_creation:10},"gpt-4o":{input:2.5,output:10,cached:1.25,reasoning:15,cache_creation:2.5},"gpt-4o-mini":{input:.15,output:.6,cached:.075,reasoning:.9,cache_creation:.15},"gpt-4.1":{input:2.5,output:10,cached:1.25,reasoning:15,cache_creation:2.5},"gpt-5":{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3},"gpt-5-mini":{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75},"gpt-5-codex":{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3},"gpt-5.1":{input:4,output:16,cached:2,reasoning:24,cache_creation:4},"gpt-5.1-codex":{input:4,output:16,cached:2,reasoning:24,cache_creation:4},"gpt-5.1-codex-mini":{input:1.5,output:6,cached:.75,reasoning:9,cache_creation:1.5},"gpt-5.1-codex-mini-high":{input:2,output:8,cached:1,reasoning:12,cache_creation:2},"gpt-5.1-codex-max":{input:8,output:32,cached:4,reasoning:48,cache_creation:8},"gpt-5.2":{input:5,output:20,cached:2.5,reasoning:30,cache_creation:5},"gpt-5.2-codex":{input:5,output:20,cached:2.5,reasoning:30,cache_creation:5},"gpt-5.3-codex":{input:6,output:24,cached:3,reasoning:36,cache_creation:6},"gpt-5.3-codex-xhigh":{input:10,output:40,cached:5,reasoning:60,cache_creation:10},"gpt-5.3-codex-high":{input:8,output:32,cached:4,reasoning:48,cache_creation:8},"gpt-5.3-codex-low":{input:4,output:16,cached:2,reasoning:24,cache_creation:4},"gpt-5.3-codex-none":{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3},"gpt-5.3-codex-spark":{input:3,output:12,cached:.3,reasoning:12,cache_creation:3},o1:{input:15,output:60,cached:7.5,reasoning:90,cache_creation:15},"o1-mini":{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3},"gemini-3-flash-preview":{input:.5,output:3,cached:.03,reasoning:4.5,cache_creation:.5},"gemini-3-pro-preview":{input:2,output:12,cached:.25,reasoning:18,cache_creation:2},"gemini-3.1-pro-low":{input:2,output:12,cached:.25,reasoning:18,cache_creation:2},"gemini-3.1-pro-high":{input:4,output:18,cached:.5,reasoning:27,cache_creation:4},"gemini-3-flash":{input:.5,output:3,cached:.03,reasoning:4.5,cache_creation:.5},"gemini-2.5-pro":{input:2,output:12,cached:.25,reasoning:18,cache_creation:2},"gemini-2.5-flash":{input:.3,output:2.5,cached:.03,reasoning:3.75,cache_creation:.3},"gemini-2.5-flash-lite":{input:.15,output:1.25,cached:.015,reasoning:1.875,cache_creation:.15},"qwen3-coder-plus":{input:1,output:4,cached:.5,reasoning:6,cache_creation:1},"qwen3-coder-flash":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"kimi-k2":{input:1,output:4,cached:.5,reasoning:6,cache_creation:1},"kimi-k2-thinking":{input:1.5,output:6,cached:.75,reasoning:9,cache_creation:1.5},"kimi-k2.5":{input:1.2,output:4.8,cached:.6,reasoning:7.2,cache_creation:1.2},"kimi-k2.5-thinking":{input:1.8,output:7.2,cached:.9,reasoning:10.8,cache_creation:1.8},"kimi-latest":{input:1,output:4,cached:.5,reasoning:6,cache_creation:1},"deepseek-chat":{input:.28,output:.42,cached:.028,reasoning:.42,cache_creation:.28},"deepseek-reasoner":{input:.28,output:.42,cached:.028,reasoning:.42,cache_creation:.28},"deepseek-r1":{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75},"deepseek-v3.2-chat":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"deepseek-v3.2-reasoner":{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75},"glm-4.6":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"glm-4.6v":{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75},"glm-4.7":{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75},"glm-5":{input:1,output:4,cached:.5,reasoning:6,cache_creation:1},"MiniMax-M2.1":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"MiniMax-M2.5":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"MiniMax-M2.7":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"minimax-m2.1":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"minimax-m2.5":{input:.6,output:2.4,cached:.3,reasoning:3.6,cache_creation:.6},"grok-code-fast-1":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},auto:{input:2,output:8,cached:1,reasoning:12,cache_creation:2},"oswe-vscode-prime":{input:1,output:4,cached:.5,reasoning:6,cache_creation:1},"gpt-oss-120b-medium":{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5},"vision-model":{input:1.5,output:6,cached:.75,reasoning:9,cache_creation:1.5},"coder-model":{input:1.5,output:6,cached:.75,reasoning:9,cache_creation:1.5}},e={gh:{"gpt-5.3-codex":{input:1.75,output:14,cached:.175,reasoning:14,cache_creation:1.75}}},f=[{pattern:"*-codex-xhigh",pricing:{input:10,output:40,cached:5,reasoning:60,cache_creation:10}},{pattern:"*-codex-high",pricing:{input:8,output:32,cached:4,reasoning:48,cache_creation:8}},{pattern:"*-codex-max",pricing:{input:8,output:32,cached:4,reasoning:48,cache_creation:8}},{pattern:"*-codex-mini-*",pricing:{input:1.5,output:6,cached:.75,reasoning:9,cache_creation:1.5}},{pattern:"*-codex-mini",pricing:{input:1.5,output:6,cached:.75,reasoning:9,cache_creation:1.5}},{pattern:"*-codex-low",pricing:{input:4,output:16,cached:2,reasoning:24,cache_creation:4}},{pattern:"*-codex-none",pricing:{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3}},{pattern:"*-codex-spark",pricing:{input:3,output:12,cached:.3,reasoning:12,cache_creation:3}},{pattern:"codex-*",pricing:{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3}},{pattern:"*-codex",pricing:{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3}},{pattern:"claude-opus-*",pricing:{input:5,output:25,cached:.5,reasoning:25,cache_creation:6.25}},{pattern:"claude-sonnet-*",pricing:{input:3,output:15,cached:.3,reasoning:15,cache_creation:3.75}},{pattern:"claude-haiku-*",pricing:{input:1,output:5,cached:.1,reasoning:5,cache_creation:1.25}},{pattern:"claude-*",pricing:{input:3,output:15,cached:.3,reasoning:15,cache_creation:3.75}},{pattern:"gemini-*-flash-lite",pricing:{input:.15,output:1.25,cached:.015,reasoning:1.875,cache_creation:.15}},{pattern:"gemini-*-flash",pricing:{input:.3,output:2.5,cached:.03,reasoning:3.75,cache_creation:.3}},{pattern:"gemini-*-pro",pricing:{input:2,output:12,cached:.25,reasoning:18,cache_creation:2}},{pattern:"gemini-3-*",pricing:{input:.5,output:3,cached:.03,reasoning:4.5,cache_creation:.5}},{pattern:"gemini-2.5-*",pricing:{input:.3,output:2.5,cached:.03,reasoning:3.75,cache_creation:.3}},{pattern:"gemini-*",pricing:{input:.5,output:3,cached:.03,reasoning:4.5,cache_creation:.5}},{pattern:"gpt-5.3-*",pricing:{input:6,output:24,cached:3,reasoning:36,cache_creation:6}},{pattern:"gpt-5.2-*",pricing:{input:5,output:20,cached:2.5,reasoning:30,cache_creation:5}},{pattern:"gpt-5.1-*",pricing:{input:4,output:16,cached:2,reasoning:24,cache_creation:4}},{pattern:"gpt-5-*",pricing:{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3}},{pattern:"gpt-5*",pricing:{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3}},{pattern:"gpt-4o-*",pricing:{input:.15,output:.6,cached:.075,reasoning:.9,cache_creation:.15}},{pattern:"gpt-4o",pricing:{input:2.5,output:10,cached:1.25,reasoning:15,cache_creation:2.5}},{pattern:"gpt-4*",pricing:{input:2.5,output:10,cached:1.25,reasoning:15,cache_creation:2.5}},{pattern:"o1-*",pricing:{input:3,output:12,cached:1.5,reasoning:18,cache_creation:3}},{pattern:"o1",pricing:{input:15,output:60,cached:7.5,reasoning:90,cache_creation:15}},{pattern:"o3-*",pricing:{input:10,output:40,cached:5,reasoning:60,cache_creation:10}},{pattern:"o4-*",pricing:{input:2,output:8,cached:1,reasoning:12,cache_creation:2}},{pattern:"qwen3-coder-*",pricing:{input:1,output:4,cached:.5,reasoning:6,cache_creation:1}},{pattern:"qwen*-coder-*",pricing:{input:1,output:4,cached:.5,reasoning:6,cache_creation:1}},{pattern:"qwen*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}},{pattern:"kimi-*-thinking",pricing:{input:1.8,output:7.2,cached:.9,reasoning:10.8,cache_creation:1.8}},{pattern:"kimi-k2*",pricing:{input:1.2,output:4.8,cached:.6,reasoning:7.2,cache_creation:1.2}},{pattern:"kimi-*",pricing:{input:1,output:4,cached:.5,reasoning:6,cache_creation:1}},{pattern:"deepseek-*reasoner*",pricing:{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75}},{pattern:"deepseek-r*",pricing:{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75}},{pattern:"deepseek-v*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}},{pattern:"deepseek-*",pricing:{input:.28,output:.42,cached:.028,reasoning:.42,cache_creation:.28}},{pattern:"glm-5*",pricing:{input:1,output:4,cached:.5,reasoning:6,cache_creation:1}},{pattern:"glm-4*",pricing:{input:.75,output:3,cached:.375,reasoning:4.5,cache_creation:.75}},{pattern:"glm-*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}},{pattern:"MiniMax-*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}},{pattern:"minimax-*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}},{pattern:"grok-code-*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}},{pattern:"grok-*",pricing:{input:.5,output:2,cached:.25,reasoning:3,cache_creation:.5}}];function g(a,b){return RegExp("^"+a.split("*").map(a=>a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")).join(".*")+"$").test(b)}function h(a,b){if(!b)return null;if(a&&e[a]?.[b])return e[a][b];let c=b.includes("/")?b.split("/").pop():b;if(d[c])return d[c];if(d[b])return d[b];for(let{pattern:a,pricing:d}of f)if(g(a,c)||g(a,b))return d;return null}}};
@@ -1,4 +1,4 @@
1
- "use strict";exports.id=6379,exports.ids=[6379],exports.modules={2449:(a,b,c)=>{c.d(b,{Bl:()=>k,Qo:()=>g,S5:()=>m,hk:()=>f,kJ:()=>l});var d=c(23016);function e(a=0){return Math.min(d.EQ.base*Math.pow(2,a),d.EQ.max)}function f(a,b,c=0){if(b){let a=("string"==typeof b?b:JSON.stringify(b)).toLowerCase();if(a.includes("no credentials"))return{shouldFallback:!0,cooldownMs:d.Bm.notFound};if(a.includes("request not allowed"))return{shouldFallback:!0,cooldownMs:d.Bm.requestNotAllowed};if(a.includes("improperly formed request"))return{shouldFallback:!0,cooldownMs:d.Bm.paymentRequired};if(a.includes("rate limit")||a.includes("too many requests")||a.includes("quota exceeded")||a.includes("capacity")||a.includes("overloaded")){let a=Math.min(c+1,d.EQ.maxLevel);return{shouldFallback:!0,cooldownMs:e(c),newBackoffLevel:a}}}if(a===d.gx.UNAUTHORIZED)return{shouldFallback:!0,cooldownMs:d.Bm.unauthorized};if(a===d.gx.PAYMENT_REQUIRED||a===d.gx.FORBIDDEN)return{shouldFallback:!0,cooldownMs:d.Bm.paymentRequired};if(a===d.gx.NOT_FOUND)return{shouldFallback:!0,cooldownMs:d.Bm.notFound};if(a===d.gx.RATE_LIMITED){let a=Math.min(c+1,d.EQ.maxLevel);return{shouldFallback:!0,cooldownMs:e(c),newBackoffLevel:a}}return[d.gx.NOT_ACCEPTABLE,d.gx.REQUEST_TIMEOUT,d.gx.SERVER_ERROR,d.gx.BAD_GATEWAY,d.gx.SERVICE_UNAVAILABLE,d.gx.GATEWAY_TIMEOUT].includes(a),{shouldFallback:!0,cooldownMs:d.Bm.transient}}function g(a){if(!a)return"";let b=new Date(a).getTime()-Date.now();if(b<=0)return"reset after 0s";let c=Math.ceil(b/1e3),d=Math.floor(c/3600),e=Math.floor(c%3600/60),f=c%60,g=[];return d>0&&g.push(`${d}h`),e>0&&g.push(`${e}m`),(f>0||0===g.length)&&g.push(`${f}s`),`reset after ${g.join(" ")}`}let h="modelLock_",i=`${h}__all`;function j(a){return a?`${h}${a}`:i}function k(a,b){let c=a[j(b)]||a[i];return!!c&&new Date(c).getTime()>Date.now()}function l(a){if(!a)return null;let b=null,c=Date.now();for(let[d,e]of Object.entries(a)){if(!d.startsWith(h)||!e)continue;let a=new Date(e).getTime();a<=c||(!b||a<b)&&(b=a)}return b?new Date(b).toISOString():null}function m(a,b){return{[j(a)]:new Date(Date.now()+b).toISOString()}}},10664:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{w:()=>x});var e=c(19171),f=c(86806),g=c(56790),h=c(45877),i=c(75237),j=c(41578),k=c(31028),l=c(93326),m=c(29807),n=c(23016),o=c(42617),p=c(60126),q=c(71246),r=c(94535),s=c(88374),t=c(60676),u=c(84155),v=c(53184),w=a([q]);async function x({body:a,modelInfo:b,credentials:c,log:d,onCredentialsRefreshed:w,onRequestSuccess:y,onDisconnect:z,clientRawRequest:A,connectionId:B,userAgent:C,apiKey:D,ccFilterNaming:E,sourceFormatOverride:F,providerThinking:G}){let H,I,J,K,L,M,{provider:N,model:O}=b,P=Date.now(),Q=F||(0,e.Tz)(a),R=(0,o.c)(a,O,C,E);if(R)return R;let S=l.Xg[N]||N,T=(0,l.ux)(S,O)||(0,e.jJ)(N),U=(0,l.cY)(S,O);if(G?.mode&&"auto"!==G.mode){let b=G.mode;"on"!==b||a.thinking?"off"!==b||a.thinking?a.reasoning_effort||(a={...a,reasoning_effort:b}):a={...a,thinking:{type:"disabled"}}:(console.log("Injecting provider-level thinking config override: on"),a={...a,thinking:{type:"enabled",budget_tokens:1e4}})}let V=!0===a.stream||Q===g.h.ANTIGRAVITY||Q===g.h.GEMINI||Q===g.h.GEMINI_CLI,W="openai"===N||"codex"===N,X=!!W||!1!==a.stream,Y=A?.headers?.accept||"",Z=Y.includes("application/json"),$=Y.includes("text/event-stream");Z&&!$&&!0!==a.stream&&(X=!1);let _=await (0,k.q7)(Q,T,O);A&&_.logClientRawRequest(A.endpoint,A.body,A.headers),_.logRawRequest(a),d?.debug?.("FORMAT",`${Q} β†’ ${T} | stream=${X}`);let aa=(0,v.J)(A?.headers||{},a);if((0,v.Q)(aa,N))d?.debug?.("PASSTHROUGH",`${aa} β†’ ${N} | native lossless`),H={...a,model:O};else{if(!(H=(0,f.GH)(Q,T,O,a,X,c,N,_,U,B)))return(0,p.uw)(O,N,B,!1,!0),(0,m.A1)(n.gx.BAD_REQUEST,`Failed to translate request for ${Q} β†’ ${T}`);I=H._toolNameMap,delete H._toolNameMap,H.model=O}let ab=(0,q.SB)(N);(0,p.uw)(O,N,B,!0),(0,p.E5)({model:O,provider:N,connectionId:B,status:"PENDING"}).catch(()=>{});let ac=H.messages?.length||H.input?.length||H.contents?.length||H.request?.contents?.length||0;d?.debug?.("REQUEST",`${N.toUpperCase()} | ${O} | ${ac} msgs`);let ad=(0,i.jd)({onDisconnect:a=>{(0,p.uw)(O,N,B,!1),z&&z(a)},onError:()=>(0,p.uw)(O,N,B,!1),log:d,provider:N,model:O}),ae={connectionProxyEnabled:c?.providerSpecificData?.connectionProxyEnabled===!0,connectionProxyUrl:c?.providerSpecificData?.connectionProxyUrl||"",connectionNoProxy:c?.providerSpecificData?.connectionNoProxy||"",vercelRelayUrl:c?.providerSpecificData?.vercelRelayUrl||""};if(ae.vercelRelayUrl){let a=c?.connectionName||c?.connectionId||"unknown",b=c?.providerSpecificData?.connectionProxyPoolId||"none";d?.info?.("PROXY",`${N.toUpperCase()} | ${O} | conn=${a} | pool=${b} | vercel-relay=${ae.vercelRelayUrl}`)}else if(ae.connectionProxyEnabled&&ae.connectionProxyUrl){let a=ae.connectionProxyUrl;try{let b=new URL(ae.connectionProxyUrl),c=b.hostname||"",d=b.port?`:${b.port}`:"",e=b.protocol||"http:";a=`${e}//${c}${d}`}catch{}let b=c?.providerSpecificData?.connectionProxyPoolId||"none",e=c?.connectionName||c?.connectionId||"unknown";d?.info?.("PROXY",`${N.toUpperCase()} | ${O} | conn=${e} | pool=${b} | url=${a}`)}if(ae.connectionProxyEnabled&&ae.connectionNoProxy){let a=c?.connectionName||c?.connectionId||"unknown";d?.debug?.("PROXY",`${N.toUpperCase()} | ${O} | conn=${a} | no_proxy=${ae.connectionNoProxy}`)}try{let a=await ab.execute({model:O,body:H,stream:X,credentials:c,signal:ad.signal,log:d,proxyOptions:ae});J=a.response,K=a.url,L=a.headers,M=a.transformedBody,_.logTargetRequest(K,L,M)}catch(c){if((0,p.uw)(O,N,B,!1,!0),(0,p.E5)({model:O,provider:N,connectionId:B,status:`FAILED ${"AbortError"===c.name?499:n.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:N,model:O,connectionId:B,latency:{ttft:0,total:Date.now()-P},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,X),providerRequest:H||null,response:{error:c.message||String(c),status:"AbortError"===c.name?499:502,thinking:null},status:"error"})).catch(()=>{}),"AbortError"===c.name)return ad.handleError(c),(0,m.A1)(499,"Request aborted");let b=(0,m.lR)(c,N,O,n.gx.BAD_GATEWAY);return console.log(`${h.lm.red}[ERROR] ${b}${h.lm.reset}`),(0,m.A1)(n.gx.BAD_GATEWAY,b)}if(J.status===n.gx.UNAUTHORIZED||J.status===n.gx.FORBIDDEN)try{let a=await (0,j.qZ)(()=>ab.refreshCredentials(c,d),3,d);if(a?.accessToken||a?.copilotToken){if(d?.info?.("TOKEN",`${N.toUpperCase()} | refreshed`),Object.assign(c,a),w)try{await w(a)}catch(a){d?.warn?.("TOKEN",`onCredentialsRefreshed failed: ${a.message}`)}try{let a=await ab.execute({model:O,body:H,stream:X,credentials:c,signal:ad.signal,log:d,proxyOptions:ae});a.response.ok&&(J=a.response,K=a.url)}catch{d?.warn?.("TOKEN",`${N.toUpperCase()} | retry after refresh failed`)}}else d?.warn?.("TOKEN",`${N.toUpperCase()} | refresh failed`)}catch(a){d?.warn?.("TOKEN",`${N.toUpperCase()} | refresh threw: ${a.message}`)}if(!J.ok){(0,p.uw)(O,N,B,!1,!0);let{statusCode:b,message:c,retryAfterMs:e}=await (0,m.zL)(J,N);(0,p.E5)({model:O,provider:N,connectionId:B,status:`FAILED ${b}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:N,model:O,connectionId:B,latency:{ttft:0,total:Date.now()-P},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,X),providerRequest:M||H||null,response:{error:c,status:b,thinking:null},status:"error"})).catch(()=>{});let f=(0,m.lR)(Error(c),N,O,b);return console.log(`${h.lm.red}[ERROR] ${f}${h.lm.reset}`),e&&"antigravity"===N&&d?.debug?.("RETRY",`Antigravity quota reset in ${Math.ceil(e/1e3)}s`),_.logError(Error(c),M||H),(0,m.A1)(b,f,e)}let af={provider:N,model:O,body:a,stream:X,translatedBody:H,finalBody:M,requestStartTime:P,connectionId:B,apiKey:D,clientRawRequest:A,onRequestSuccess:y},ag=a=>(0,p.E5)({model:O,provider:N,connectionId:B,...a}).catch(()=>{}),ah=()=>(0,p.uw)(O,N,B,!1);if(!V&&W){let a=await (0,s.I)({...af,providerResponse:J,sourceFormat:Q,trackDone:ah,appendLog:ag});if(a)return ad.handleComplete(),a}if(!X){let a=await (0,t.N)({...af,providerResponse:J,sourceFormat:Q,targetFormat:T,reqLogger:_,trackDone:ah,appendLog:ag});return ad.handleComplete(),a}let{onStreamComplete:ai}=(0,u.$)({...af});return(0,u.M)({...af,providerResponse:J,sourceFormat:Q,targetFormat:T,userAgent:C,reqLogger:_,toolNameMap:I,streamController:ad,onStreamComplete:ai})}q=(w.then?(await w)():w)[0],d()}catch(a){d(a)}})},29807:(a,b,c)=>{c.d(b,{A1:()=>g,lR:()=>i,wO:()=>h,yj:()=>e,zL:()=>f});var d=c(23016);function e(a,b){let c;return new Response(JSON.stringify((c=d.LY[a]||(a>=500?{type:"server_error",code:"internal_server_error"}:{type:"invalid_request_error",code:""}),{error:{message:b||d.O[a]||"An error occurred",type:c.type,code:c.code}})),{status:a,headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}async function f(a,b=null){let c="",e=null;try{let b=await a.text();try{let a=JSON.parse(b);c=a.error?.message||a.message||a.error||b}catch{c=b}}catch{c=`Upstream error: ${a.status}`}let g=("string"==typeof c?c:JSON.stringify(c))||d.O[a.status]||`Upstream error: ${a.status}`;return"antigravity"===b&&429===a.status&&(e=function(a){if("string"!=typeof a)return null;let b=a.match(/reset after (\d+h)?(\d+m)?(\d+s)?/i);if(!b)return null;let c=0;return b[1]&&(c+=60*parseInt(b[1])*6e4),b[2]&&(c+=60*parseInt(b[2])*1e3),b[3]&&(c+=1e3*parseInt(b[3])),c>0?c:null}(g)),{statusCode:a.status,message:g,retryAfterMs:e}}function g(a,b,c=null){let d={success:!1,status:a,error:b,response:e(a,b)};return c&&(d.retryAfterMs=c),d}function h(a,b,c,d){let e=Math.max(Math.ceil((new Date(c).getTime()-Date.now())/1e3),1);return new Response(JSON.stringify({error:{message:`${b} (${d})`}}),{status:a,headers:{"Content-Type":"application/json","Retry-After":String(e)}})}function i(a,b,c,d){let e=d||a.code||"FETCH_FAILED",f=a.message||"Unknown error";return`[${e}]: ${f}`}},31028:(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||"unknown").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})}}}},42617:(a,b,c)=>{c.d(b,{c:()=>i});var d=c(19171),e=c(86806),f=c(56790),g=c(23016),h=c(45877);function i(a,b,c="",e=!1){if(!c.includes("claude-cli")||!a.messages?.length)return null;let f=a.messages,h=a=>"string"==typeof a?a:Array.isArray(a)?a.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"",j=!1,m=!1,n=f[f.length-1];if(n?.role==="assistant"&&n.content?.[0]?.text==="{"&&(j=!0),j||"Warmup"===h(f[0]?.content)&&(j=!0),j||1!==f.length||f[0]?.role!=="user"||"count"===h(f[0]?.content)&&(j=!0),!j&&g.C8?.length){let a=f.filter(a=>"user"===a.role).map(a=>h(a.content)).join(" ");g.C8.some(b=>a.includes(b))&&(j=!0)}if(!j&&e){let b=f.find(a=>"system"===a.role),c=h(b?.content),d=Array.isArray(a.system)?a.system.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"string"==typeof a.system?a.system:"";(c||d).includes("isNewTopic")&&(j=!0,m=!0)}if(!j)return null;let o=(0,d.Tz)(a),p=!1!==a.stream;if(m){let a=f.find(a=>"user"===a.role),c=JSON.stringify({isNewTopic:!0,title:h(a?.content).trim().split(/\s+/).slice(0,3).join(" ")});return p?l(o,b,c):k(o,b,c)}return p?l(o,b):k(o,b)}function j(a,b="CLI Command Execution: Clear Terminal"){return{id:`chatcmpl-${Date.now()}`,object:"chat.completion",created:Math.floor(Date.now()/1e3),model:a,choices:[{index:0,message:{role:"assistant",content:b},finish_reason:"stop"}],usage:{prompt_tokens:1,completion_tokens:1,total_tokens:2}}}function k(a,b,c){let d=j(b,c);if(a===f.h.OPENAI)return{success:!0,response:new Response(JSON.stringify(d),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})};let g=(0,e.Ws)(a);g.model=b;let h=m(d),i=[];for(let b of h){let c=(0,e.Y8)(f.h.OPENAI,a,b,g);c?.length>0&&i.push(...c)}let k=(0,e.Y8)(f.h.OPENAI,a,null,g);return k?.length>0&&i.push(...k),{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}(i,a)),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}function l(a,b,c){let d=j(b,c),g=(0,e.Ws)(a);g.model=b;let i=m(d),k=[];for(let b of i){let c=(0,e.Y8)(f.h.OPENAI,a,b,g);if(c?.length>0)for(let b of c)k.push((0,h.v8)(b,a))}let l=(0,e.Y8)(f.h.OPENAI,a,null,g);if(l?.length>0)for(let b of l)k.push((0,h.v8)(b,a));return k.push("data: [DONE]\n\n"),{success:!0,response:new Response(k.join(""),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*"}})}}function m(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}]}},45877:(a,b,c)=>{c.d(b,{i5:()=>m,l2:()=>n,lm:()=>g.lm,v8:()=>h.v8});var d=c(86806),e=c(56790),f=c(60126),g=c(68735),h=c(11572);let i=new TextEncoder,j="translate",k="passthrough";function l(a={}){let{mode:b=j,targetFormat:c,sourceFormat:m,provider:n=null,reqLogger:o=null,toolNameMap:p=null,model:q=null,connectionId:r=null,body:s=null,onStreamComplete:t=null,apiKey:u=null}=a,v="",w=null,x=new TextDecoder("utf-8",{fatal:!1}),y=b===j?{...(0,d.Ws)(m),provider:n,toolNameMap:p,model:q}:null,z=0,A="",B="",C=null;return new TransformStream({transform(a,f){C||(C=Date.now());let j=x.decode(a,{stream:!0});v+=j,o?.appendProviderChunk?.(j);let l=v.split("\n");for(let a of(v=l.pop()||"",l)){let j=a.trim();if(b===k){let b,c=!1;if(j.startsWith("data:")&&"[DONE]"!==j.slice(5).trim())try{let a=JSON.parse(j.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 i=a.choices?.[0]?.delta,k=i?.content,l=i?.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&&(w=m);let n=a.choices?.[0]?.finish_reason;if(n&&!(0,g.Gh)(a.usage)){let d=(0,g.OF)(s,z,e.h.OPENAI);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
1
+ "use strict";exports.id=6379,exports.ids=[6379],exports.modules={2449:(a,b,c)=>{c.d(b,{Bl:()=>k,Qo:()=>g,S5:()=>m,hk:()=>f,kJ:()=>l});var d=c(23016);function e(a=0){return Math.min(d.EQ.base*Math.pow(2,a),d.EQ.max)}function f(a,b,c=0){if(b){let a=("string"==typeof b?b:JSON.stringify(b)).toLowerCase();if(a.includes("no credentials"))return{shouldFallback:!0,cooldownMs:d.Bm.notFound};if(a.includes("request not allowed"))return{shouldFallback:!0,cooldownMs:d.Bm.requestNotAllowed};if(a.includes("improperly formed request"))return{shouldFallback:!0,cooldownMs:d.Bm.paymentRequired};if(a.includes("rate limit")||a.includes("too many requests")||a.includes("quota exceeded")||a.includes("capacity")||a.includes("overloaded")){let a=Math.min(c+1,d.EQ.maxLevel);return{shouldFallback:!0,cooldownMs:e(c),newBackoffLevel:a}}}if(a===d.gx.UNAUTHORIZED)return{shouldFallback:!0,cooldownMs:d.Bm.unauthorized};if(a===d.gx.PAYMENT_REQUIRED||a===d.gx.FORBIDDEN)return{shouldFallback:!0,cooldownMs:d.Bm.paymentRequired};if(a===d.gx.NOT_FOUND)return{shouldFallback:!0,cooldownMs:d.Bm.notFound};if(a===d.gx.RATE_LIMITED){let a=Math.min(c+1,d.EQ.maxLevel);return{shouldFallback:!0,cooldownMs:e(c),newBackoffLevel:a}}return[d.gx.NOT_ACCEPTABLE,d.gx.REQUEST_TIMEOUT,d.gx.SERVER_ERROR,d.gx.BAD_GATEWAY,d.gx.SERVICE_UNAVAILABLE,d.gx.GATEWAY_TIMEOUT].includes(a),{shouldFallback:!0,cooldownMs:d.Bm.transient}}function g(a){if(!a)return"";let b=new Date(a).getTime()-Date.now();if(b<=0)return"reset after 0s";let c=Math.ceil(b/1e3),d=Math.floor(c/3600),e=Math.floor(c%3600/60),f=c%60,g=[];return d>0&&g.push(`${d}h`),e>0&&g.push(`${e}m`),(f>0||0===g.length)&&g.push(`${f}s`),`reset after ${g.join(" ")}`}let h="modelLock_",i=`${h}__all`;function j(a){return a?`${h}${a}`:i}function k(a,b){let c=a[j(b)]||a[i];return!!c&&new Date(c).getTime()>Date.now()}function l(a){if(!a)return null;let b=null,c=Date.now();for(let[d,e]of Object.entries(a)){if(!d.startsWith(h)||!e)continue;let a=new Date(e).getTime();a<=c||(!b||a<b)&&(b=a)}return b?new Date(b).toISOString():null}function m(a,b){return{[j(a)]:new Date(Date.now()+b).toISOString()}}},10664:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{w:()=>x});var e=c(19171),f=c(86806),g=c(56790),h=c(45877),i=c(75237),j=c(41578),k=c(31028),l=c(93326),m=c(29807),n=c(23016),o=c(42617),p=c(60126),q=c(71246),r=c(94535),s=c(88374),t=c(60676),u=c(84155),v=c(53184),w=a([q]);async function x({body:a,modelInfo:b,credentials:c,log:d,onCredentialsRefreshed:w,onRequestSuccess:y,onDisconnect:z,clientRawRequest:A,connectionId:B,userAgent:C,apiKey:D,ccFilterNaming:E,sourceFormatOverride:F,providerThinking:G}){let H,I,J,K,L,M,{provider:N,model:O}=b,P=Date.now(),Q=F||(0,e.Tz)(a),R=(0,o.c)(a,O,C,E);if(R)return R;let S=l.Xg[N]||N,T=(0,l.ux)(S,O)||(0,e.jJ)(N),U=(0,l.cY)(S,O);if(G?.mode&&"auto"!==G.mode){let b=G.mode;"on"!==b||a.thinking?"off"!==b||a.thinking?a.reasoning_effort||(a={...a,reasoning_effort:b}):a={...a,thinking:{type:"disabled"}}:(console.log("Injecting provider-level thinking config override: on"),a={...a,thinking:{type:"enabled",budget_tokens:1e4}})}let V=!0===a.stream||Q===g.h.ANTIGRAVITY||Q===g.h.GEMINI||Q===g.h.GEMINI_CLI,W="openai"===N||"codex"===N,X=!!W||!1!==a.stream,Y=A?.headers?.accept||"",Z=Y.includes("application/json"),$=Y.includes("text/event-stream");Z&&!$&&!0!==a.stream&&(X=!1);let _=await (0,k.q7)(Q,T,O);A&&_.logClientRawRequest(A.endpoint,A.body,A.headers),_.logRawRequest(a),d?.debug?.("FORMAT",`${Q} β†’ ${T} | stream=${X}`);let aa=(0,v.J)(A?.headers||{},a);if((0,v.Q)(aa,N))d?.debug?.("PASSTHROUGH",`${aa} β†’ ${N} | native lossless`),H={...a,model:O};else{if(!(H=(0,f.GH)(Q,T,O,a,X,c,N,_,U,B)))return(0,p.uw)(O,N,B,!1,!0),(0,m.A1)(n.gx.BAD_REQUEST,`Failed to translate request for ${Q} β†’ ${T}`);I=H._toolNameMap,delete H._toolNameMap,H.model=O}let ab=(0,q.SB)(N);(0,p.uw)(O,N,B,!0),(0,p.E5)({model:O,provider:N,connectionId:B,status:"PENDING"}).catch(()=>{});let ac=H.messages?.length||H.input?.length||H.contents?.length||H.request?.contents?.length||0;d?.debug?.("REQUEST",`${N.toUpperCase()} | ${O} | ${ac} msgs`);let ad=(0,i.jd)({onDisconnect:a=>{(0,p.uw)(O,N,B,!1),z&&z(a)},onError:()=>(0,p.uw)(O,N,B,!1),log:d,provider:N,model:O}),ae={connectionProxyEnabled:c?.providerSpecificData?.connectionProxyEnabled===!0,connectionProxyUrl:c?.providerSpecificData?.connectionProxyUrl||"",connectionNoProxy:c?.providerSpecificData?.connectionNoProxy||"",vercelRelayUrl:c?.providerSpecificData?.vercelRelayUrl||""};if(ae.vercelRelayUrl){let a=c?.connectionName||c?.connectionId||"unknown",b=c?.providerSpecificData?.connectionProxyPoolId||"none";d?.info?.("PROXY",`${N.toUpperCase()} | ${O} | conn=${a} | pool=${b} | vercel-relay=${ae.vercelRelayUrl}`)}else if(ae.connectionProxyEnabled&&ae.connectionProxyUrl){let a=ae.connectionProxyUrl;try{let b=new URL(ae.connectionProxyUrl),c=b.hostname||"",d=b.port?`:${b.port}`:"",e=b.protocol||"http:";a=`${e}//${c}${d}`}catch{}let b=c?.providerSpecificData?.connectionProxyPoolId||"none",e=c?.connectionName||c?.connectionId||"unknown";d?.info?.("PROXY",`${N.toUpperCase()} | ${O} | conn=${e} | pool=${b} | url=${a}`)}if(ae.connectionProxyEnabled&&ae.connectionNoProxy){let a=c?.connectionName||c?.connectionId||"unknown";d?.debug?.("PROXY",`${N.toUpperCase()} | ${O} | conn=${a} | no_proxy=${ae.connectionNoProxy}`)}try{let a=await ab.execute({model:O,body:H,stream:X,credentials:c,signal:ad.signal,log:d,proxyOptions:ae});J=a.response,K=a.url,L=a.headers,M=a.transformedBody,_.logTargetRequest(K,L,M)}catch(c){if((0,p.uw)(O,N,B,!1,!0),(0,p.E5)({model:O,provider:N,connectionId:B,status:`FAILED ${"AbortError"===c.name?499:n.gx.BAD_GATEWAY}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:N,model:O,connectionId:B,latency:{ttft:0,total:Date.now()-P},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,X),providerRequest:H||null,response:{error:c.message||String(c),status:"AbortError"===c.name?499:502,thinking:null},status:"error"})).catch(()=>{}),"AbortError"===c.name)return ad.handleError(c),(0,m.A1)(499,"Request aborted");let b=(0,m.lR)(c,N,O,n.gx.BAD_GATEWAY);return console.log(`${h.lm.red}[ERROR] ${b}${h.lm.reset}`),(0,m.A1)(n.gx.BAD_GATEWAY,b)}if(!ab.noAuth&&(J.status===n.gx.UNAUTHORIZED||J.status===n.gx.FORBIDDEN))try{let a=await (0,j.qZ)(()=>ab.refreshCredentials(c,d),3,d);if(a?.accessToken||a?.copilotToken){if(d?.info?.("TOKEN",`${N.toUpperCase()} | refreshed`),Object.assign(c,a),w)try{await w(a)}catch(a){d?.warn?.("TOKEN",`onCredentialsRefreshed failed: ${a.message}`)}try{let a=await ab.execute({model:O,body:H,stream:X,credentials:c,signal:ad.signal,log:d,proxyOptions:ae});a.response.ok&&(J=a.response,K=a.url)}catch{d?.warn?.("TOKEN",`${N.toUpperCase()} | retry after refresh failed`)}}else d?.warn?.("TOKEN",`${N.toUpperCase()} | refresh failed`)}catch(a){d?.warn?.("TOKEN",`${N.toUpperCase()} | refresh threw: ${a.message}`)}if(!J.ok){(0,p.uw)(O,N,B,!1,!0);let{statusCode:b,message:c,retryAfterMs:e}=await (0,m.zL)(J,N);(0,p.E5)({model:O,provider:N,connectionId:B,status:`FAILED ${b}`}).catch(()=>{}),(0,p.ox)((0,r.$R)({provider:N,model:O,connectionId:B,latency:{ttft:0,total:Date.now()-P},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,r.Fo)(a,X),providerRequest:M||H||null,response:{error:c,status:b,thinking:null},status:"error"})).catch(()=>{});let f=(0,m.lR)(Error(c),N,O,b);return console.log(`${h.lm.red}[ERROR] ${f}${h.lm.reset}`),e&&"antigravity"===N&&d?.debug?.("RETRY",`Antigravity quota reset in ${Math.ceil(e/1e3)}s`),_.logError(Error(c),M||H),(0,m.A1)(b,f,e)}let af={provider:N,model:O,body:a,stream:X,translatedBody:H,finalBody:M,requestStartTime:P,connectionId:B,apiKey:D,clientRawRequest:A,onRequestSuccess:y},ag=a=>(0,p.E5)({model:O,provider:N,connectionId:B,...a}).catch(()=>{}),ah=()=>(0,p.uw)(O,N,B,!1);if(!V&&W){let a=await (0,s.I)({...af,providerResponse:J,sourceFormat:Q,trackDone:ah,appendLog:ag});if(a)return ad.handleComplete(),a}if(!X){let a=await (0,t.N)({...af,providerResponse:J,sourceFormat:Q,targetFormat:T,reqLogger:_,trackDone:ah,appendLog:ag});return ad.handleComplete(),a}let{onStreamComplete:ai}=(0,u.$)({...af});return(0,u.M)({...af,providerResponse:J,sourceFormat:Q,targetFormat:T,userAgent:C,reqLogger:_,toolNameMap:I,streamController:ad,onStreamComplete:ai})}q=(w.then?(await w)():w)[0],d()}catch(a){d(a)}})},29807:(a,b,c)=>{c.d(b,{A1:()=>g,lR:()=>i,wO:()=>h,yj:()=>e,zL:()=>f});var d=c(23016);function e(a,b){let c;return new Response(JSON.stringify((c=d.LY[a]||(a>=500?{type:"server_error",code:"internal_server_error"}:{type:"invalid_request_error",code:""}),{error:{message:b||d.O[a]||"An error occurred",type:c.type,code:c.code}})),{status:a,headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}async function f(a,b=null){let c="",e=null;try{let b=await a.text();try{let a=JSON.parse(b);c=a.error?.message||a.message||a.error||b}catch{c=b}}catch{c=`Upstream error: ${a.status}`}let g=("string"==typeof c?c:JSON.stringify(c))||d.O[a.status]||`Upstream error: ${a.status}`;return"antigravity"===b&&429===a.status&&(e=function(a){if("string"!=typeof a)return null;let b=a.match(/reset after (\d+h)?(\d+m)?(\d+s)?/i);if(!b)return null;let c=0;return b[1]&&(c+=60*parseInt(b[1])*6e4),b[2]&&(c+=60*parseInt(b[2])*1e3),b[3]&&(c+=1e3*parseInt(b[3])),c>0?c:null}(g)),{statusCode:a.status,message:g,retryAfterMs:e}}function g(a,b,c=null){let d={success:!1,status:a,error:b,response:e(a,b)};return c&&(d.retryAfterMs=c),d}function h(a,b,c,d){let e=Math.max(Math.ceil((new Date(c).getTime()-Date.now())/1e3),1);return new Response(JSON.stringify({error:{message:`${b} (${d})`}}),{status:a,headers:{"Content-Type":"application/json","Retry-After":String(e)}})}function i(a,b,c,d){let e=d||a.code||"FETCH_FAILED",f=a.message||"Unknown error";return`[${e}]: ${f}`}},31028:(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||"unknown").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})}}}},42617:(a,b,c)=>{c.d(b,{c:()=>i});var d=c(19171),e=c(86806),f=c(56790),g=c(23016),h=c(45877);function i(a,b,c="",e=!1){if(!c.includes("claude-cli")||!a.messages?.length)return null;let f=a.messages,h=a=>"string"==typeof a?a:Array.isArray(a)?a.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"",j=!1,m=!1,n=f[f.length-1];if(n?.role==="assistant"&&n.content?.[0]?.text==="{"&&(j=!0),j||"Warmup"===h(f[0]?.content)&&(j=!0),j||1!==f.length||f[0]?.role!=="user"||"count"===h(f[0]?.content)&&(j=!0),!j&&g.C8?.length){let a=f.filter(a=>"user"===a.role).map(a=>h(a.content)).join(" ");g.C8.some(b=>a.includes(b))&&(j=!0)}if(!j&&e){let b=f.find(a=>"system"===a.role),c=h(b?.content),d=Array.isArray(a.system)?a.system.filter(a=>"text"===a.type).map(a=>a.text).join(" "):"string"==typeof a.system?a.system:"";(c||d).includes("isNewTopic")&&(j=!0,m=!0)}if(!j)return null;let o=(0,d.Tz)(a),p=!1!==a.stream;if(m){let a=f.find(a=>"user"===a.role),c=JSON.stringify({isNewTopic:!0,title:h(a?.content).trim().split(/\s+/).slice(0,3).join(" ")});return p?l(o,b,c):k(o,b,c)}return p?l(o,b):k(o,b)}function j(a,b="CLI Command Execution: Clear Terminal"){return{id:`chatcmpl-${Date.now()}`,object:"chat.completion",created:Math.floor(Date.now()/1e3),model:a,choices:[{index:0,message:{role:"assistant",content:b},finish_reason:"stop"}],usage:{prompt_tokens:1,completion_tokens:1,total_tokens:2}}}function k(a,b,c){let d=j(b,c);if(a===f.h.OPENAI)return{success:!0,response:new Response(JSON.stringify(d),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})};let g=(0,e.Ws)(a);g.model=b;let h=m(d),i=[];for(let b of h){let c=(0,e.Y8)(f.h.OPENAI,a,b,g);c?.length>0&&i.push(...c)}let k=(0,e.Y8)(f.h.OPENAI,a,null,g);return k?.length>0&&i.push(...k),{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}(i,a)),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}function l(a,b,c){let d=j(b,c),g=(0,e.Ws)(a);g.model=b;let i=m(d),k=[];for(let b of i){let c=(0,e.Y8)(f.h.OPENAI,a,b,g);if(c?.length>0)for(let b of c)k.push((0,h.v8)(b,a))}let l=(0,e.Y8)(f.h.OPENAI,a,null,g);if(l?.length>0)for(let b of l)k.push((0,h.v8)(b,a));return k.push("data: [DONE]\n\n"),{success:!0,response:new Response(k.join(""),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*"}})}}function m(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}]}},45877:(a,b,c)=>{c.d(b,{i5:()=>m,l2:()=>n,lm:()=>g.lm,v8:()=>h.v8});var d=c(86806),e=c(56790),f=c(60126),g=c(68735),h=c(11572);let i=new TextEncoder,j="translate",k="passthrough";function l(a={}){let{mode:b=j,targetFormat:c,sourceFormat:m,provider:n=null,reqLogger:o=null,toolNameMap:p=null,model:q=null,connectionId:r=null,body:s=null,onStreamComplete:t=null,apiKey:u=null}=a,v="",w=null,x=new TextDecoder("utf-8",{fatal:!1}),y=b===j?{...(0,d.Ws)(m),provider:n,toolNameMap:p,model:q}:null,z=0,A="",B="",C=null;return new TransformStream({transform(a,f){C||(C=Date.now());let j=x.decode(a,{stream:!0});v+=j,o?.appendProviderChunk?.(j);let l=v.split("\n");for(let a of(v=l.pop()||"",l)){let j=a.trim();if(b===k){let b,c=!1;if(j.startsWith("data:")&&"[DONE]"!==j.slice(5).trim())try{let a=JSON.parse(j.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 i=a.choices?.[0]?.delta,k=i?.content,l=i?.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&&(w=m);let n=a.choices?.[0]?.finish_reason;if(n&&!(0,g.Gh)(a.usage)){let d=(0,g.OF)(s,z,e.h.OPENAI);a.usage=(0,g.WL)(d,e.h.OPENAI),b=`data: ${JSON.stringify(a)}
2
2
  `,w=d,c=!0}else if(n&&w){let d=(0,g.O9)(w);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
4
  `,c=!0)}catch{}c||(b=a.startsWith("data:")&&!a.startsWith("data: ")?"data: "+a.slice(5)+"\n":a+"\n"),o?.appendConvertedChunk?.(b),f.enqueue(i.encode(b));continue}if(!j)continue;let l=(0,h.tV)(j,c);if(!l)continue;if(l&&l.done&&c!==e.h.OLLAMA){let a="data: [DONE]\n\n";o?.appendConvertedChunk?.(a),f.enqueue(i.encode(a));continue}if(l.delta?.text&&(z+=l.delta.text.length,A+=l.delta.text),l.delta?.thinking&&(z+=l.delta.thinking.length,B+=l.delta.thinking),l.choices?.[0]?.delta?.content&&(z+=l.choices[0].delta.content.length,A+=l.choices[0].delta.content),l.choices?.[0]?.delta?.reasoning_content&&(z+=l.choices[0].delta.reasoning_content.length,B+=l.choices[0].delta.reasoning_content),l.candidates?.[0]?.content?.parts)for(let a of l.candidates[0].content.parts)a.text&&"string"==typeof a.text&&(z+=a.text.length,!0===a.thought?B+=a.text:A+=a.text);let n=(0,g.f5)(l);n&&(y.usage=n);let p=(0,d.Y8)(c,m,l,y);if(p?._openaiIntermediate)for(let a of p._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);o?.appendOpenAIChunk?.(b)}if(p?.length>0)for(let a of p){if(!(0,h.c2)(a,m))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)(s,z,m);a.usage=(0,g.WL)(b,m),y.usage=b}else if(y.finishReason&&b&&y.usage){let b=(0,g.O9)(y.usage);a.usage=(0,g.WL)(b,m)}let c=(0,h.v8)(a,m);o?.appendConvertedChunk?.(c),f.enqueue(i.encode(c))}}},flush(a){(0,f.uw)(q,n,r,!1);try{let j=x.decode();if(j&&(v+=j),b===k){if(v){let b=v;v.startsWith("data:")&&!v.startsWith("data: ")&&(b="data: "+v.slice(5)),o?.appendConvertedChunk?.(b),a.enqueue(i.encode(b))}!(0,g.Gh)(w)&&z>0&&(w=(0,g.OF)(s,z,e.h.OPENAI)),(0,g.Gh)(w)?(0,g.IF)(n,w,q,r,u):(0,f.E5)({model:q,provider:n,connectionId:r,tokens:null,status:"200 OK"}).catch(()=>{});let b="data: [DONE]\n\n";o?.appendConvertedChunk?.(b),a.enqueue(i.encode(b)),t&&t({content:A,thinking:B},w,C);return}if(v.trim()){let b=(0,h.tV)(v.trim());if(b&&!b.done){let f=(0,d.Y8)(c,m,b,y);if(f?._openaiIntermediate)for(let a of f._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);o?.appendOpenAIChunk?.(b)}if(f?.length>0)for(let b of f){let c=(0,h.v8)(b,m);o?.appendConvertedChunk?.(c),a.enqueue(i.encode(c))}}}let l=(0,d.Y8)(c,m,null,y);if(l?._openaiIntermediate)for(let a of l._openaiIntermediate){let b=(0,h.v8)(a,e.h.OPENAI);o?.appendOpenAIChunk?.(b)}if(l?.length>0)for(let b of l){let c=(0,h.v8)(b,m);o?.appendConvertedChunk?.(c),a.enqueue(i.encode(c))}let p="data: [DONE]\n\n";o?.appendConvertedChunk?.(p),a.enqueue(i.encode(p)),!(0,g.Gh)(y?.usage)&&z>0&&(y.usage=(0,g.OF)(s,z,m)),(0,g.Gh)(y?.usage)?(0,g.IF)(y.provider||c,y.usage,q,r,u):(0,f.E5)({model:q,provider:n,connectionId:r,tokens:null,status:"200 OK"}).catch(()=>{}),t&&t({content:A,thinking:B},y?.usage,C)}catch(a){console.log("Error in flush:",a)}}})}function m(a,b,c=null,d=null,e=null,f=null,g=null,h=null,i=null,k=null){return l({mode:j,targetFormat:a,sourceFormat:b,provider:c,reqLogger:d,toolNameMap:e,model:f,connectionId:g,body:h,onStreamComplete:i,apiKey:k})}function n(a=null,b=null,c=null,d=null,e=null,f=null,g=null){return l({mode:k,provider:a,reqLogger:b,model:c,connectionId:d,body:e,onStreamComplete:f,apiKey:g})}},46379:(a,b,c)=>{c.a(a,async(a,d)=>{try{c.d(b,{$B:()=>e.$B,SB:()=>g.SB}),c(37973),c(62276),c(43528),c(23016),c(93326),c(56790),c(86806),c(19171),c(53057),c(2449);var e=c(41578),f=c(10664),g=c(71246);c(29807),c(45877);var h=a([f,g]);[f,g]=h.then?(await h)():h,d()}catch(a){d(a)}})},53184:(a,b,c)=>{c.d(b,{J:()=>e,Q:()=>f});let d={claude:["claude","anthropic"],"gemini-cli":["gemini-cli"],antigravity:["antigravity"],codex:["codex"]};function e(a={},b={}){let c=(a["user-agent"]||"").toLowerCase(),d=(a["x-app"]||"").toLowerCase();return"antigravity"===b.userAgent?"antigravity":c.includes("claude-cli")||c.includes("claude-code")||"cli"===d?"claude":c.includes("gemini-cli")?"gemini-cli":c.includes("codex-cli")?"codex":null}function f(a,b){if(!a)return!1;let c=d[a];if(!c)return!1;let e=b.startsWith("anthropic-compatible")?"anthropic":b;return c.includes(e)}},60676:(a,b,c)=>{c.d(b,{N:()=>m});var d=c(56790),e=c(86806),f=c(17019),g=c(68735),h=c(29807),i=c(23016),j=c(88374),k=c(94535),l=c(60126);async function m({providerResponse:a,provider:b,model:c,sourceFormat:n,targetFormat:o,body:p,stream:q,translatedBody:r,finalBody:s,requestStartTime:t,connectionId:u,apiKey:v,clientRawRequest:w,onRequestSuccess:x,reqLogger:y,trackDone:z,appendLog:A}){let B;if(z(),(a.headers.get("content-type")||"").includes("text/event-stream")){let b=await a.text(),d=(0,j.F)(b,c);if(!d)return A({status:`FAILED ${i.gx.BAD_GATEWAY}`}),(0,h.A1)(i.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");B=d}else try{B=await a.json()}catch(a){return A({status:`FAILED ${i.gx.BAD_GATEWAY}`}),console.error(`[ChatCore] Failed to parse JSON from ${b}:`,a.message),(0,h.A1)(i.gx.BAD_GATEWAY,`Invalid JSON response from ${b}`)}y.logProviderResponse(a.status,a.statusText,a.headers,B),x&&await x();let C=(0,k.MK)(B);A({tokens:C,status:"200 OK"}),(0,k.qr)({provider:b,model:c,tokens:C,connectionId:u,apiKey:v,endpoint:w?.endpoint});let D=(0,e.nZ)(o,n)?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||b===d.h.VERTEX){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??"").replace(/^\s*```\s*json\s*\n?/i,"").replace(/\n?\s*```\s*$/i,""):"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 b===d.h.OLLAMA?(0,f.ollamaBodyToOpenAI)(a):a}(B,o,n):B;if(D?.choices?.[0]){let a=D.choices[0],b=a.message;Array.isArray(b?.tool_calls)&&b.tool_calls.length>0&&"tool_calls"!==a.finish_reason&&(a.finish_reason="tool_calls")}if(D.object||(D.object="chat.completion"),D.created||(D.created=Math.floor(Date.now()/1e3)),delete D.prompt_filter_results,D?.choices)for(let a of D.choices)delete a.content_filter_results;if(D?.usage&&(D.usage=(0,g.WL)((0,g.O9)(D.usage),n)),D?.choices)for(let a of D.choices)a?.message&&delete a.message.reasoning_content;y.logConvertedResponse(D);let E=Date.now()-t;return(0,l.ox)((0,k.$R)({provider:b,model:c,connectionId:u,latency:{ttft:E,total:E},tokens:C||{prompt_tokens:0,completion_tokens:0},request:(0,k.Fo)(p,q),providerRequest:s||r||null,providerResponse:B||null,response:{content:D?.choices?.[0]?.message?.content||D?.content||null,thinking:D?.choices?.[0]?.message?.reasoning_content||D?.reasoning_content||null,finish_reason:D?.choices?.[0]?.finish_reason||"unknown"},status:"success"},{endpoint:w?.endpoint||null})).catch(a=>{console.error("[RequestDetail] Failed to save:",a.message)}),{success:!0,response:new Response(JSON.stringify(D),{headers:{"Content-Type":"application/json","Access-Control-Allow-Origin":"*"}})}}},75237:(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:()=>Promise.resolve()})}},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),e.cancel().catch(()=>{}),f.abort().catch(()=>{}),a.error(b)}},cancel(a){c.handleDisconnect(a||"cancelled"),e.cancel(),f.abort()}})}c.d(b,{Jb:()=>e,jd:()=>d})},84155:(a,b,c)=>{c.d(b,{$:()=>l,M:()=>k});var d=c(56790),e=c(86806),f=c(45877),g=c(75237),h=c(94535),i=c(60126);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:l,targetFormat:m,userAgent:n,body:o,stream:p,translatedBody:q,finalBody:r,requestStartTime:s,connectionId:t,apiKey:u,clientRawRequest:v,onRequestSuccess:w,reqLogger:x,toolNameMap:y,streamController:z,onStreamComplete:A}){w&&w();let B=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:l,targetFormat:m,userAgent:n,reqLogger:x,toolNameMap:y,model:c,connectionId:t,body:o,onStreamComplete:A,apiKey:u}),C=(0,g.Jb)(a,B,z),D=`${Date.now()}-${Math.random().toString(36).slice(2,11)}`;return(0,i.ox)((0,h.$R)({provider:b,model:c,connectionId:t,latency:{ttft:0,total:Date.now()-s},tokens:{prompt_tokens:0,completion_tokens:0},request:(0,h.Fo)(o,p),providerRequest:r||q||null,providerResponse:"[Streaming - raw response not captured]",response:{content:"[Streaming in progress...]",thinking:null,type:"streaming"},status:"success"},{id:D})).catch(a=>{console.error("[RequestDetail] Failed to save streaming request:",a.message)}),{success:!0,response:new Response(C,{headers:j})}}function l({provider:a,model:b,connectionId:c,apiKey:d,requestStartTime:e,body:f,stream:g,finalBody:j,translatedBody:k,clientRawRequest:m}){let n=`${Date.now()}-${Math.random().toString(36).slice(2,11)}`;return{onStreamComplete:(l,o,p)=>{let q={ttft:p?p-e:Date.now()-e,total:Date.now()-e},r=l?.content||"[Empty streaming response]",s=l?.thinking||null;(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:r,response:{content:r,thinking:s,type:"streaming"},status:"success"},{id:n})).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:m?.endpoint,label:"STREAM USAGE"})},streamDetailId:n}}},88374:(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:()=>n,F:()=>m});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(29807),h=c(23016),i=c(56790),j=c(94535),k=c(60126);function l(a){if(!a?.content||!Array.isArray(a.content))return"";let b=a.content.find(a=>"output_text"===a.type);if("string"==typeof b?.text)return b.text;let c=a.content.find(a=>"string"==typeof a.text);return"string"==typeof c?.text?c.text:""}function m(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=new Map,h="stop",i=null;for(let a of c){let b=a?.choices?.[0],c=b?.delta||{};if("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&&(h=b.finish_reason),a?.usage&&"object"==typeof a.usage&&(i=a.usage),Array.isArray(c.tool_calls))for(let a of c.tool_calls){let b=a.index??0;g.has(b)||g.set(b,{id:a.id||"",type:"function",function:{name:"",arguments:""}});let c=g.get(b);a.id&&(c.id=a.id),a.function?.name&&(c.function.name+=a.function.name),a.function?.arguments&&(c.function.arguments+=a.function.arguments)}}let j={role:"assistant",content:e.join("")||(g.size>0?null:"")};f.length>0&&(j.reasoning_content=f.join("")),g.size>0&&(j.tool_calls=[...g.entries()].sort((a,b)=>a[0]-b[0]).map(([,a])=>a));let k={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:j,finish_reason:h}]};return i&&(k.usage=i),k}async function n({providerResponse:a,sourceFormat:b,provider:c,model:d,body:e,stream:o,translatedBody:p,finalBody:q,requestStartTime:r,connectionId:s,apiKey:t,clientRawRequest:u,onRequestSuccess:v,trackDone:w,appendLog:x}){let y=a.headers.get("content-type")||"";if(!(y.includes("text/event-stream")||""===y&&"codex"===c))return null;w();let z={provider:c,model:d,connectionId:s,request:(0,j.Fo)(e,o),providerRequest:q||p||null};if("codex"===c||b===i.h.OPENAI_RESPONSES)try{let e,g=await f(a.body);v&&await v();let h=g.usage||{};x({tokens:h,status:"200 OK"}),(0,j.qr)({provider:c,model:d,tokens:h,connectionId:s,apiKey:t,endpoint:u?.endpoint});let{msgItem:m,textContent:n}=function(a){if(!Array.isArray(a))return{msgItem:null,textContent:null};let b=a.filter(a=>a?.type==="message");if(0===b.length)return{msgItem:null,textContent:null};for(let a=b.length-1;a>=0;a--){let c=l(b[a]);if(c.length>0)return{msgItem:b[a],textContent:c}}let c=b[b.length-1];return{msgItem:c,textContent:l(c)}}(g.output),o=Date.now()-r;if((0,k.ox)((0,j.$R)({...z,latency:{ttft:o,total:o},tokens:{prompt_tokens:h.input_tokens||0,completion_tokens:h.output_tokens||0},response:{content:n,thinking:null,finish_reason:g.status||"unknown"},status:"success"},{endpoint:u?.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 p=h.input_tokens||0,q=h.output_tokens||0,w=(g.output||[]).filter(a=>"function_call"===a.type).map((a,b)=>({id:a.call_id||`call_${a.name}_${Date.now()}_${b}`,type:"function",function:{name:a.name,arguments:"string"==typeof a.arguments?a.arguments:JSON.stringify(a.arguments||{})}})),y=w.length>0;if(b===i.h.ANTIGRAVITY||b===i.h.GEMINI||b===i.h.GEMINI_CLI)e={response:{candidates:[{content:{role:"model",parts:[{text:n||""}]},finishReason:"STOP",index:0}],usageMetadata:{promptTokenCount:p,candidatesTokenCount:q,totalTokenCount:p+q},modelVersion:d,responseId:g.id||`resp_${Date.now()}`}};else{let a={role:"assistant",content:n||(y?null:"")};y&&(a.tool_calls=w);let b=y?"tool_calls":"completed"===g.status?"stop":g.status||"stop";e={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:a,finish_reason:b}],usage:{prompt_tokens:p,completion_tokens:q,total_tokens:p+q}}}return{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=m(b,d);if(!e)return(0,g.A1)(h.gx.BAD_GATEWAY,"Invalid SSE response for non-streaming request");v&&await v();let f=e.usage||{};x({tokens:f,status:"200 OK"}),(0,j.qr)({provider:c,model:d,tokens:f,connectionId:s,apiKey:t,endpoint:u?.endpoint});let i=Date.now()-r;if((0,k.ox)((0,j.$R)({...z,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:u?.endpoint||null})).catch(()=>{}),e?.choices)for(let a of e.choices)a?.message?.reasoning_content&&a.message.content&&delete a.message.reasoning_content;return{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")}}},94535:(a,b,c)=>{c.d(b,{$R:()=>i,Fo:()=>g,MK:()=>h,qr:()=>j});var d=c(60126),e=c(45877);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 k=c.input_tokens??c.prompt_tokens??0,l=c.output_tokens??c.completion_tokens??0;if(0===k&&0===l)return;let m=new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit",second:"2-digit"}),n=f?` | account=${f.slice(0,8)}...`:"";console.log(`${e.lm.green}[${m}] πŸ“Š [${i}] ${a.toUpperCase()} | in=${k} | out=${l}${n}${e.lm.reset}`);let o={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:o,timestamp:new Date().toISOString(),connectionId:f||void 0,apiKey:g||void 0,endpoint:h||null}).catch(()=>{})}}};
@@ -1 +1 @@
1
- "use strict";exports.id=6502,exports.ids=[6502],exports.modules={54495:(a,b,c)=>{c.d(b,{Al:()=>t,es:()=>w,fn:()=>x,nN:()=>z,ss:()=>y});var d=c(29021),e=c.n(d),f=c(33873),g=c.n(f),h=c(55591),i=c.n(h),j=c(21820),k=c.n(j),l=c(79646),m=c(19931);let n=g().join(k().homedir(),".9router","bin"),o="cloudflared",p="win32"===k().platform(),q=p?`${o}.exe`:o,r=g().join(n,q),s={darwin:{x64:"cloudflared-darwin-amd64.tgz",arm64:"cloudflared-darwin-arm64.tgz"},win32:{x64:"cloudflared-windows-amd64.exe",x32:"cloudflared-windows-386.exe"},linux:{x64:"cloudflared-linux-amd64",arm64:"cloudflared-linux-arm64"}};async function t(){if(e().existsSync(n)||e().mkdirSync(n,{recursive:!0}),e().existsSync(r))return p||e().chmodSync(r,"755"),r;let a=function(){let a=k().platform(),b=k().arch(),c=s[a];if(!c)throw Error(`Unsupported platform: ${a}`);let d=c[b];if(!d)throw Error(`Unsupported architecture: ${b} for platform ${a}`);return`https://github.com/cloudflare/cloudflared/releases/download/2026.3.0/${d}`}(),b=a.endsWith(".tgz"),c=b?g().join(n,"cloudflared.tgz"):r;return await function a(b,c){return new Promise((d,f)=>{let g=e().createWriteStream(c);i().get(b,b=>{if([301,302].includes(b.statusCode)){g.close(),e().unlinkSync(c),a(b.headers.location,c).then(d).catch(f);return}if(200!==b.statusCode){g.close(),e().unlinkSync(c),f(Error(`Download failed with status ${b.statusCode}`));return}b.pipe(g),g.on("finish",()=>{g.close(()=>d(c))}),g.on("error",a=>{g.close(),e().unlinkSync(c),f(a)})}).on("error",a=>{g.close(),e().existsSync(c)&&e().unlinkSync(c),f(a)})})}(a,c),b&&((0,l.execSync)(`tar -xzf "${c}" -C "${n}"`,{stdio:"pipe"}),e().unlinkSync(c)),p||e().chmodSync(r,"755"),r}let u=null,v=null;function w(a){v=a}async function x(a,b){let c=await t(),d=e().mkdtempSync(g().join(k().tmpdir(),"cloudflared-quick-")),f=g().join(d,"config.yml");e().writeFileSync(f,"# quick-tunnel config placeholder\n","utf8");let h=!1,i=()=>{if(!h){h=!0;try{e().rmSync(d,{recursive:!0,force:!0})}catch(a){}}},j=(0,l.spawn)(c,["tunnel","--url",`http://localhost:${a}`,"--config",f,"--no-autoupdate"],{detached:!1,windowsHide:!0,stdio:["ignore","pipe","pipe"]});return u=j,(0,m.xS)(j.pid),new Promise((a,c)=>{let d=!1,e=setTimeout(()=>{d||(d=!0,i(),c(Error("Quick tunnel timed out")))},9e4),f=null,g=c=>{let g=function(a){let b=[];for(let c of a.matchAll(/https:\/\/([a-z0-9-]+)\.trycloudflare\.com/gi)){let a=c[1];"api"!==a&&b.push(`https://${a}.trycloudflare.com`)}return b.length?b[b.length-1]:null}(c.toString());if(g){if(!d){d=!0,f=g,clearTimeout(e),i(),a({child:j,tunnelUrl:g});return}g!==f&&(f=g,b&&b(g))}};j.stdout.on("data",g),j.stderr.on("data",g),j.on("error",a=>{d||(d=!0,clearTimeout(e),i(),c(a))}),j.on("exit",a=>{if(u=null,(0,m.r4)(),!d){d=!0,clearTimeout(e),i(),c(Error(`cloudflared exited with code ${a}`));return}v&&v(),i()})})}function y(){if(u){try{u.kill()}catch(a){}u=null}let a=(0,m.Cr)();if(a){try{process.kill(a)}catch(a){}(0,m.r4)()}try{(0,l.execSync)("pkill -f cloudflared 2>/dev/null || true",{stdio:"ignore"})}catch(a){}}function z(){let a=(0,m.Cr)();if(!a)return!1;try{return process.kill(a,0),!0}catch(a){return!1}}},56502:(a,b,c)=>{var d=c(37770),e=c(88035),f=c(54495),g=c(50514),h=c(79551),i=c(33873),j=c(29021),k=c(21820),l=c.n(k);if(!process.env.MITM_SERVER_PATH)try{let a=(0,h.fileURLToPath)("file:///Users/Working/router4/app/src/shared/services/initializeApp.js"),b=(0,i.dirname)((0,i.dirname)(a)),c=(0,i.join)(b,"mitm","server.js");(0,j.existsSync)(c)&&(process.env.MITM_SERVER_PATH=c)}catch{}try{(0,g.initDbHooks)(d.getSettings,d.Xx)}catch{}process.setMaxListeners(20);let m=global.__appSingleton??={signalHandlersRegistered:!1,watchdogInterval:null,networkMonitorInterval:null,lastNetworkFingerprint:null,lastWatchdogTick:Date.now(),lastTunnelRestartAt:0,tunnelRestartInProgress:!1,mitmStartInProgress:!1};async function n(){try{if(await (0,d.bI)(),(await (0,d.getSettings)()).tunnelEnabled&&!(0,f.nN)()){console.log("[InitApp] Tunnel was enabled, auto-reconnecting...");try{await (0,e.cb)(),console.log("[InitApp] Tunnel reconnected")}catch(a){console.log("[InitApp] Tunnel reconnect failed:",a.message)}}if(!m.signalHandlersRegistered){let a=()=>{(0,f.ss)(),process.exit()};process.on("SIGINT",a),process.on("SIGTERM",a),m.signalHandlersRegistered=!0}(0,f.Al)().catch(()=>{}),!m.watchdogInterval&&(m.watchdogInterval=setInterval(async()=>{try{if((0,e.M8)()||(0,e.yQ)()||m.tunnelRestartInProgress||!(await (0,d.getSettings)()).tunnelEnabled||(0,f.nN)())return;console.log("[Watchdog] Tunnel process is down, attempting recovery..."),m.tunnelRestartInProgress=!0;try{await (0,e.cb)(),console.log("[Watchdog] Tunnel recovered")}finally{m.tunnelRestartInProgress=!1}}catch(a){console.log("[Watchdog] Recovery failed:",a.message)}},6e4),m.watchdogInterval.unref&&m.watchdogInterval.unref()),!m.networkMonitorInterval&&(m.lastNetworkFingerprint=p(),m.lastWatchdogTick=Date.now(),m.networkMonitorInterval=setInterval(async()=>{try{if((0,e.M8)()||!(await (0,d.getSettings)()).tunnelEnabled)return;let a=Date.now(),b=a-m.lastWatchdogTick;m.lastWatchdogTick=a;let c=p(),g=c!==m.lastNetworkFingerprint,h=b>15e3;if(g&&(m.lastNetworkFingerprint=c),!g&&!h||m.tunnelRestartInProgress||(0,e.yQ)()||a-m.lastTunnelRestartAt<3e4)return;console.log(`[NetworkMonitor] ${h&&g?"sleep/wake + network change":h?"sleep/wake":"network change"} detected, restarting tunnel...`),m.tunnelRestartInProgress=!0,m.lastTunnelRestartAt=a;try{(0,f.ss)(),await new Promise(a=>setTimeout(a,2e3)),await (0,e.cb)(),console.log("[NetworkMonitor] Tunnel restarted"),m.lastNetworkFingerprint=p()}finally{m.tunnelRestartInProgress=!1}}catch(a){console.log("[NetworkMonitor] Tunnel restart failed:",a.message)}},5e3),m.networkMonitorInterval.unref&&m.networkMonitorInterval.unref()),o()}catch(a){console.error("[InitApp] Error:",a)}}async function o(){if(!m.mitmStartInProgress){m.mitmStartInProgress=!0;try{if(!(await (0,d.getSettings)()).mitmEnabled||(await (0,g.getMitmStatus)()).running)return;let a=await (0,g.loadEncryptedPassword)();if(!a&&"win32"!==process.platform)return void console.log("[InitApp] MITM was enabled but no saved password found, skipping auto-start");let b=(await (0,d.getApiKeys)()).find(a=>!1!==a.isActive);console.log("[InitApp] MITM was enabled, auto-starting..."),await (0,g.startMitm)(b?.key||"sk_9router",a),console.log("[InitApp] MITM auto-started")}catch(a){console.log("[InitApp] MITM auto-start failed:",a.message)}finally{m.mitmStartInProgress=!1}}}function p(){let a=l().networkInterfaces(),b=[];for(let[c,d]of Object.entries(a))if(d)for(let a of d)a.internal||"IPv4"!==a.family||b.push(`${c}:${a.address}`);return b.sort().join("|")}let q=!1;async function r(){if(!q)try{await n(),q=!0}catch(a){console.error("[ServerInit] Error initializing app:",a)}return q}"phase-production-build"!==process.env.NEXT_PHASE&&r().catch(console.log)},88035:(a,b,c)=>{c.d(b,{H4:()=>A,Jv:()=>x,M8:()=>r,Rg:()=>w,cb:()=>u,mh:()=>y,rH:()=>z,yQ:()=>s});var d=c(55511),e=c.n(d),f=c(19931),g=c(54495),h=c(13774),i=c(37770),j=c(50514);(0,j.initDbHooks)(i.getSettings,i.Xx);let k=process.env.TUNNEL_WORKER_URL||"https://9router.com",l=[5e3,1e4,2e4,3e4,6e4],m=l.length,n=!1,o=!1,p=null,q=!1;function r(){return q}function s(){return n}async function t(a,b){await fetch(`${k}/api/tunnel/register`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({shortId:a,tunnelUrl:b})})}async function u(a=20128){if(q=!1,(0,g.nN)()){let a=(0,f.C7)();if(a?.tunnelUrl){let b=`https://r${a.shortId}.9router.com`;return{success:!0,tunnelUrl:a.tunnelUrl,shortId:a.shortId,publicUrl:b,alreadyRunning:!0}}}(0,g.ss)();let b=function(){try{let{machineIdSync:a}=c(20243),b=a();return e().createHash("sha256").update(b+"9router-tunnel-salt").digest("hex").substring(0,16)}catch(a){return e().randomUUID().replace(/-/g,"").substring(0,16)}}(),d=(0,f.C7)(),h=d?.shortId||(0,f.jd)(),j=async a=>{q||(await t(h,a),(0,f.LZ)({shortId:h,machineId:b,tunnelUrl:a}),await (0,i.Xx)({tunnelEnabled:!0,tunnelUrl:a}))},{tunnelUrl:k}=await (0,g.fn)(a,j);await t(h,k),(0,f.LZ)({shortId:h,machineId:b,tunnelUrl:k}),await (0,i.Xx)({tunnelEnabled:!0,tunnelUrl:k}),o||((0,g.es)(()=>{n||v(0)}),o=!0);let l=`https://r${h}.9router.com`;return{success:!0,tunnelUrl:k,shortId:h,publicUrl:l}}async function v(a){if(n||q)return;n=!0;let b=l[Math.min(a,l.length-1)];console.log(`[Tunnel] Reconnecting in ${b/1e3}s (attempt ${a+1})...`),await new Promise(a=>{p=setTimeout(a,b)});try{if(q||!(await (0,i.getSettings)()).tunnelEnabled){n=!1;return}await u(),console.log("[Tunnel] Reconnected successfully"),n=!1}catch(c){console.log(`[Tunnel] Reconnect attempt ${a+1} failed:`,c.message),n=!1;let b=a+1;b<m?v(b):(console.log("[Tunnel] All reconnect attempts exhausted, disabling tunnel"),await (0,i.Xx)({tunnelEnabled:!1}))}}async function w(){q=!0,n=!0,p&&(clearTimeout(p),p=null),(0,g.es)(null),o=!1,(0,g.ss)();let a=(0,f.C7)();return a&&(0,f.LZ)({shortId:a.shortId,machineId:a.machineId,tunnelUrl:null}),await (0,i.Xx)({tunnelEnabled:!1,tunnelUrl:""}),n=!1,{success:!0}}async function x(){let a=(0,f.C7)(),b=(0,g.nN)(),c=await (0,i.getSettings)(),d=a?.shortId||"",e=d?`https://r${d}.9router.com`:"";return{enabled:!0===c.tunnelEnabled&&b,tunnelUrl:a?.tunnelUrl||"",shortId:d,publicUrl:e,running:b}}async function y(a=20128){let b=(0,j.getCachedPassword)()||await (0,j.loadEncryptedPassword)()||"";await (0,h.OZ)(b);let c=(0,f.C7)(),d=c?.shortId||(0,f.jd)();if(!(0,h.a$)()){let a=await (0,h.c$)(d);if(a.authUrl)return{success:!1,needsLogin:!0,authUrl:a.authUrl}}(0,h.PZ)();let e=await (0,h.LC)(a);return e.funnelNotEnabled?{success:!1,funnelNotEnabled:!0,enableUrl:e.enableUrl}:(0,h.a$)()&&(0,h.Kp)()?(await (0,i.Xx)({tailscaleEnabled:!0,tailscaleUrl:e.tunnelUrl}),{success:!0,tunnelUrl:e.tunnelUrl}):((0,h.PZ)(),{success:!1,error:"Tailscale not connected. Device may have been removed. Please re-login."})}async function z(){(0,h.PZ)();let a=(0,j.getCachedPassword)()||await (0,j.loadEncryptedPassword)()||"";return await (0,h.ZI)(a),await (0,i.Xx)({tailscaleEnabled:!1,tailscaleUrl:""}),{success:!0}}async function A(){let a=await (0,i.getSettings)(),b=(0,h.Kp)();return{enabled:!0===a.tailscaleEnabled&&b,tunnelUrl:a.tailscaleUrl||"",running:b}}}};
1
+ "use strict";exports.id=6502,exports.ids=[6502],exports.modules={54495:(a,b,c)=>{c.d(b,{Al:()=>t,es:()=>w,fn:()=>x,nN:()=>z,ss:()=>y});var d=c(29021),e=c.n(d),f=c(33873),g=c.n(f),h=c(55591),i=c.n(h),j=c(21820),k=c.n(j),l=c(79646),m=c(19931);let n=g().join(k().homedir(),".9router","bin"),o="cloudflared",p="win32"===k().platform(),q=p?`${o}.exe`:o,r=g().join(n,q),s={darwin:{x64:"cloudflared-darwin-amd64.tgz",arm64:"cloudflared-darwin-arm64.tgz"},win32:{x64:"cloudflared-windows-amd64.exe",x32:"cloudflared-windows-386.exe"},linux:{x64:"cloudflared-linux-amd64",arm64:"cloudflared-linux-arm64"}};async function t(){if(e().existsSync(n)||e().mkdirSync(n,{recursive:!0}),e().existsSync(r))return p||e().chmodSync(r,"755"),r;let a=function(){let a=k().platform(),b=k().arch(),c=s[a];if(!c)throw Error(`Unsupported platform: ${a}`);let d=c[b];if(!d)throw Error(`Unsupported architecture: ${b} for platform ${a}`);return`https://github.com/cloudflare/cloudflared/releases/download/2026.3.0/${d}`}(),b=a.endsWith(".tgz"),c=b?g().join(n,"cloudflared.tgz"):r;return await function a(b,c){return new Promise((d,f)=>{let g=e().createWriteStream(c);i().get(b,b=>{if([301,302].includes(b.statusCode)){g.close(),e().unlinkSync(c),a(b.headers.location,c).then(d).catch(f);return}if(200!==b.statusCode){g.close(),e().unlinkSync(c),f(Error(`Download failed with status ${b.statusCode}`));return}b.pipe(g),g.on("finish",()=>{g.close(()=>d(c))}),g.on("error",a=>{g.close(),e().unlinkSync(c),f(a)})}).on("error",a=>{g.close(),e().existsSync(c)&&e().unlinkSync(c),f(a)})})}(a,c),b&&((0,l.execSync)(`tar -xzf "${c}" -C "${n}"`,{stdio:"pipe",windowsHide:!0}),e().unlinkSync(c)),p||e().chmodSync(r,"755"),r}let u=null,v=null;function w(a){v=a}async function x(a,b){let c=await t(),d=e().mkdtempSync(g().join(k().tmpdir(),"cloudflared-quick-")),f=g().join(d,"config.yml");e().writeFileSync(f,"# quick-tunnel config placeholder\n","utf8");let h=!1,i=()=>{if(!h){h=!0;try{e().rmSync(d,{recursive:!0,force:!0})}catch(a){}}},j=(0,l.spawn)(c,["tunnel","--url",`http://localhost:${a}`,"--config",f,"--no-autoupdate"],{detached:!1,windowsHide:!0,stdio:["ignore","pipe","pipe"]});return u=j,(0,m.xS)(j.pid),new Promise((a,c)=>{let d=!1,e=setTimeout(()=>{d||(d=!0,i(),c(Error("Quick tunnel timed out")))},9e4),f=null,g=c=>{let g=function(a){let b=[];for(let c of a.matchAll(/https:\/\/([a-z0-9-]+)\.trycloudflare\.com/gi)){let a=c[1];"api"!==a&&b.push(`https://${a}.trycloudflare.com`)}return b.length?b[b.length-1]:null}(c.toString());if(g){if(!d){d=!0,f=g,clearTimeout(e),i(),a({child:j,tunnelUrl:g});return}g!==f&&(f=g,b&&b(g))}};j.stdout.on("data",g),j.stderr.on("data",g),j.on("error",a=>{d||(d=!0,clearTimeout(e),i(),c(a))}),j.on("exit",a=>{if(u=null,(0,m.r4)(),!d){d=!0,clearTimeout(e),i(),c(Error(`cloudflared exited with code ${a}`));return}v&&v(),i()})})}function y(){if(u){try{u.kill()}catch(a){}u=null}let a=(0,m.Cr)();if(a){try{process.kill(a)}catch(a){}(0,m.r4)()}try{(0,l.execSync)("pkill -f cloudflared 2>/dev/null || true",{stdio:"ignore",windowsHide:!0})}catch(a){}}function z(){let a=(0,m.Cr)();if(!a)return!1;try{return process.kill(a,0),!0}catch(a){return!1}}},56502:(a,b,c)=>{var d=c(37770),e=c(88035),f=c(54495),g=c(50514),h=c(79551),i=c(33873),j=c(29021),k=c(21820),l=c.n(k);if(!process.env.MITM_SERVER_PATH)try{let a=(0,h.fileURLToPath)("file:///Users/Working/router4/app/src/shared/services/initializeApp.js"),b=(0,i.dirname)((0,i.dirname)(a)),c=(0,i.join)(b,"mitm","server.js");(0,j.existsSync)(c)&&(process.env.MITM_SERVER_PATH=c)}catch{}try{(0,g.initDbHooks)(d.getSettings,d.Xx)}catch{}process.setMaxListeners(20);let m=global.__appSingleton??={signalHandlersRegistered:!1,watchdogInterval:null,networkMonitorInterval:null,lastNetworkFingerprint:null,lastWatchdogTick:Date.now(),lastTunnelRestartAt:0,tunnelRestartInProgress:!1,mitmStartInProgress:!1};async function n(){try{if(await (0,d.bI)(),(await (0,d.getSettings)()).tunnelEnabled&&!(0,f.nN)()){console.log("[InitApp] Tunnel was enabled, auto-reconnecting...");try{await (0,e.cb)(),console.log("[InitApp] Tunnel reconnected")}catch(a){console.log("[InitApp] Tunnel reconnect failed:",a.message)}}if(!m.signalHandlersRegistered){let a=()=>{(0,f.ss)(),process.exit()};process.on("SIGINT",a),process.on("SIGTERM",a),m.signalHandlersRegistered=!0}(0,f.Al)().catch(()=>{}),!m.watchdogInterval&&(m.watchdogInterval=setInterval(async()=>{try{if((0,e.M8)()||(0,e.yQ)()||m.tunnelRestartInProgress||!(await (0,d.getSettings)()).tunnelEnabled||(0,f.nN)())return;console.log("[Watchdog] Tunnel process is down, attempting recovery..."),m.tunnelRestartInProgress=!0;try{await (0,e.cb)(),console.log("[Watchdog] Tunnel recovered")}finally{m.tunnelRestartInProgress=!1}}catch(a){console.log("[Watchdog] Recovery failed:",a.message)}},6e4),m.watchdogInterval.unref&&m.watchdogInterval.unref()),!m.networkMonitorInterval&&(m.lastNetworkFingerprint=p(),m.lastWatchdogTick=Date.now(),m.networkMonitorInterval=setInterval(async()=>{try{if((0,e.M8)()||!(await (0,d.getSettings)()).tunnelEnabled)return;let a=Date.now(),b=a-m.lastWatchdogTick;m.lastWatchdogTick=a;let c=p(),g=c!==m.lastNetworkFingerprint,h=b>15e3;if(g&&(m.lastNetworkFingerprint=c),!g&&!h||m.tunnelRestartInProgress||(0,e.yQ)()||a-m.lastTunnelRestartAt<3e4)return;console.log(`[NetworkMonitor] ${h&&g?"sleep/wake + network change":h?"sleep/wake":"network change"} detected, restarting tunnel...`),m.tunnelRestartInProgress=!0,m.lastTunnelRestartAt=a;try{(0,f.ss)(),await new Promise(a=>setTimeout(a,2e3)),await (0,e.cb)(),console.log("[NetworkMonitor] Tunnel restarted"),m.lastNetworkFingerprint=p()}finally{m.tunnelRestartInProgress=!1}}catch(a){console.log("[NetworkMonitor] Tunnel restart failed:",a.message)}},5e3),m.networkMonitorInterval.unref&&m.networkMonitorInterval.unref()),o()}catch(a){console.error("[InitApp] Error:",a)}}async function o(){if(!m.mitmStartInProgress){m.mitmStartInProgress=!0;try{if(!(await (0,d.getSettings)()).mitmEnabled||(await (0,g.getMitmStatus)()).running)return;let a=await (0,g.loadEncryptedPassword)();if(!a&&"win32"!==process.platform)return void console.log("[InitApp] MITM was enabled but no saved password found, skipping auto-start");let b=(await (0,d.getApiKeys)()).find(a=>!1!==a.isActive);console.log("[InitApp] MITM was enabled, auto-starting..."),await (0,g.startMitm)(b?.key||"sk_9router",a),console.log("[InitApp] MITM auto-started")}catch(a){console.log("[InitApp] MITM auto-start failed:",a.message)}finally{m.mitmStartInProgress=!1}}}function p(){let a=l().networkInterfaces(),b=[];for(let[c,d]of Object.entries(a))if(d)for(let a of d)a.internal||"IPv4"!==a.family||b.push(`${c}:${a.address}`);return b.sort().join("|")}let q=!1;async function r(){if(!q)try{await n(),q=!0}catch(a){console.error("[ServerInit] Error initializing app:",a)}return q}"phase-production-build"!==process.env.NEXT_PHASE&&r().catch(console.log)},88035:(a,b,c)=>{c.d(b,{H4:()=>A,Jv:()=>x,M8:()=>r,Rg:()=>w,cb:()=>u,mh:()=>y,rH:()=>z,yQ:()=>s});var d=c(55511),e=c.n(d),f=c(19931),g=c(54495),h=c(13774),i=c(37770),j=c(50514);(0,j.initDbHooks)(i.getSettings,i.Xx);let k=process.env.TUNNEL_WORKER_URL||"https://9router.com",l=[5e3,1e4,2e4,3e4,6e4],m=l.length,n=!1,o=!1,p=null,q=!1;function r(){return q}function s(){return n}async function t(a,b){await fetch(`${k}/api/tunnel/register`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({shortId:a,tunnelUrl:b})})}async function u(a=20128){if(q=!1,(0,g.nN)()){let a=(0,f.C7)();if(a?.tunnelUrl){let b=`https://r${a.shortId}.9router.com`;return{success:!0,tunnelUrl:a.tunnelUrl,shortId:a.shortId,publicUrl:b,alreadyRunning:!0}}}(0,g.ss)();let b=function(){try{let{machineIdSync:a}=c(20243),b=a();return e().createHash("sha256").update(b+"9router-tunnel-salt").digest("hex").substring(0,16)}catch(a){return e().randomUUID().replace(/-/g,"").substring(0,16)}}(),d=(0,f.C7)(),h=d?.shortId||(0,f.jd)(),j=async a=>{q||(await t(h,a),(0,f.LZ)({shortId:h,machineId:b,tunnelUrl:a}),await (0,i.Xx)({tunnelEnabled:!0,tunnelUrl:a}))},{tunnelUrl:k}=await (0,g.fn)(a,j);await t(h,k),(0,f.LZ)({shortId:h,machineId:b,tunnelUrl:k}),await (0,i.Xx)({tunnelEnabled:!0,tunnelUrl:k}),o||((0,g.es)(()=>{n||v(0)}),o=!0);let l=`https://r${h}.9router.com`;return{success:!0,tunnelUrl:k,shortId:h,publicUrl:l}}async function v(a){if(n||q)return;n=!0;let b=l[Math.min(a,l.length-1)];console.log(`[Tunnel] Reconnecting in ${b/1e3}s (attempt ${a+1})...`),await new Promise(a=>{p=setTimeout(a,b)});try{if(q||!(await (0,i.getSettings)()).tunnelEnabled){n=!1;return}await u(),console.log("[Tunnel] Reconnected successfully"),n=!1}catch(c){console.log(`[Tunnel] Reconnect attempt ${a+1} failed:`,c.message),n=!1;let b=a+1;b<m?v(b):(console.log("[Tunnel] All reconnect attempts exhausted, disabling tunnel"),await (0,i.Xx)({tunnelEnabled:!1}))}}async function w(){q=!0,n=!0,p&&(clearTimeout(p),p=null),(0,g.es)(null),o=!1,(0,g.ss)();let a=(0,f.C7)();return a&&(0,f.LZ)({shortId:a.shortId,machineId:a.machineId,tunnelUrl:null}),await (0,i.Xx)({tunnelEnabled:!1,tunnelUrl:""}),n=!1,{success:!0}}async function x(){let a=(0,f.C7)(),b=(0,g.nN)(),c=await (0,i.getSettings)(),d=a?.shortId||"",e=d?`https://r${d}.9router.com`:"";return{enabled:!0===c.tunnelEnabled&&b,tunnelUrl:a?.tunnelUrl||"",shortId:d,publicUrl:e,running:b}}async function y(a=20128){let b=(0,j.getCachedPassword)()||await (0,j.loadEncryptedPassword)()||"";await (0,h.OZ)(b);let c=(0,f.C7)(),d=c?.shortId||(0,f.jd)();if(!(0,h.a$)()){let a=await (0,h.c$)(d);if(a.authUrl)return{success:!1,needsLogin:!0,authUrl:a.authUrl}}(0,h.PZ)();let e=await (0,h.LC)(a);return e.funnelNotEnabled?{success:!1,funnelNotEnabled:!0,enableUrl:e.enableUrl}:(0,h.a$)()&&(0,h.Kp)()?(await (0,i.Xx)({tailscaleEnabled:!0,tailscaleUrl:e.tunnelUrl}),{success:!0,tunnelUrl:e.tunnelUrl}):((0,h.PZ)(),{success:!1,error:"Tailscale not connected. Device may have been removed. Please re-login."})}async function z(){(0,h.PZ)();let a=(0,j.getCachedPassword)()||await (0,j.loadEncryptedPassword)()||"";return await (0,h.ZI)(a),await (0,i.Xx)({tailscaleEnabled:!1,tailscaleUrl:""}),{success:!0}}async function A(){let a=await (0,i.getSettings)(),b=(0,h.Kp)();return{enabled:!0===a.tailscaleEnabled&&b,tunnelUrl:a.tailscaleUrl||"",running:b}}}};
@@ -1 +1 @@
1
- "use strict";exports.id=6560,exports.ids=[6560],exports.modules={16560:(a,b,c)=>{c.d(b,{I9:()=>i,Ql:()=>j,eU:()=>m,vN:()=>l});var d=c(44575),e=c(37770),f=c(62684),g=c(41578);let h=g.oD,i=(a,b,c)=>(0,g.I9)(a,b,c,d),j=(a,b)=>(0,g.Ql)(a,b,d);function k(a){return new Date(Date.now()+1e3*a).toISOString()}async function l(a,b){try{let c={};b.accessToken&&(c.accessToken=b.accessToken),b.refreshToken&&(c.refreshToken=b.refreshToken),b.expiresIn&&(c.expiresAt=k(b.expiresIn),c.expiresIn=b.expiresIn),b.providerSpecificData&&(c.providerSpecificData={...b.existingProviderSpecificData||{},...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 m(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));if(h?.accessToken){let b={...h,existingProviderSpecificData:c.providerSpecificData};await l(c.connectionId,b),function(a,b,c){("antigravity"===a||"gemini-cli"===a)&&b&&c&&((0,f.Ou)(b),(0,f.eG)(b,c).then(a=>{a&&l(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,providerSpecificData:h.providerSpecificData?{...c.providerSpecificData,...h.providerSpecificData}:c.providerSpecificData,expiresAt:h.expiresIn?k(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 l(c.connectionId,{providerSpecificData:a}),c.providerSpecificData=a,c.copilotToken=f.token}}}return c}},44575:(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)}`}},62684:(a,b,c)=>{c.d(b,{Ou:()=>i,eG:()=>h});var d=c(43528);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:{...d.Ic,Authorization:`Bearer ${a}`},body:JSON.stringify({metadata:d.zv}),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.zv};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:{...d.Ic,Authorization:`Bearer ${a}`},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;console.warn(`[ProjectId] onboardUser attempt ${b} failed: ${a.message}, retrying...`),await new Promise(a=>setTimeout(a,2e3))}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?.()}};
1
+ "use strict";exports.id=6560,exports.ids=[6560],exports.modules={16560:(a,b,c)=>{c.d(b,{I9:()=>i,Ql:()=>j,eU:()=>m,vN:()=>l});var d=c(44575),e=c(37770),f=c(62684),g=c(41578);let h=g.oD,i=(a,b,c)=>(0,g.I9)(a,b,c,d),j=(a,b)=>(0,g.Ql)(a,b,d);function k(a){return new Date(Date.now()+1e3*a).toISOString()}async function l(a,b){try{let c={};b.accessToken&&(c.accessToken=b.accessToken),b.refreshToken&&(c.refreshToken=b.refreshToken),b.expiresIn&&(c.expiresAt=k(b.expiresIn),c.expiresIn=b.expiresIn),b.providerSpecificData&&(c.providerSpecificData={...b.existingProviderSpecificData||{},...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 m(a,b){let c={...b};if(c.expiresAt){let b=new Date(c.expiresAt).getTime()-Date.now(),e=(0,g.Og)(a);if(b<e){let h;d.info("TOKEN_REFRESH","Token expiring soon, refreshing proactively",{provider:a,expiresIn:Math.round(b/1e3),refreshLeadMs:e});let i=await (h=c,(0,g.iD)(a,h,d));if(i?.accessToken){let b={...i,existingProviderSpecificData:c.providerSpecificData};await l(c.connectionId,b),function(a,b,c){("antigravity"===a||"gemini-cli"===a)&&b&&c&&((0,f.Ou)(b),(0,f.eG)(b,c).then(a=>{a&&l(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:i.accessToken,refreshToken:i.refreshToken??c.refreshToken,providerSpecificData:i.providerSpecificData?{...c.providerSpecificData,...i.providerSpecificData}:c.providerSpecificData,expiresAt:i.expiresIn?k(i.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 l(c.connectionId,{providerSpecificData:a}),c.providerSpecificData=a,c.copilotToken=f.token}}}return c}},44575:(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)}`}},62684:(a,b,c)=>{c.d(b,{Ou:()=>i,eG:()=>h});var d=c(43528);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:{...d.Ic,Authorization:`Bearer ${a}`},body:JSON.stringify({metadata:d.zv}),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.zv};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:{...d.Ic,Authorization:`Bearer ${a}`},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;console.warn(`[ProjectId] onboardUser attempt ${b} failed: ${a.message}, retrying...`),await new Promise(a=>setTimeout(a,2e3))}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?.()}};
@@ -0,0 +1 @@
1
+ "use strict";exports.id=7243,exports.ids=[7243],exports.modules={57243:(a,b,c)=>{c.d(b,{generateApiKeyWithMachine:()=>g});var d=c(55511),e=c.n(d);let f=process.env.API_KEY_SECRET||"endpoint-proxy-api-key-secret";function g(a){let b=function(){let a="abcdefghijklmnopqrstuvwxyz0123456789",b="";for(let c=0;c<6;c++)b+=a.charAt(Math.floor(Math.random()*a.length));return b}(),c=e().createHmac("sha256",f).update(a+b).digest("hex").slice(0,8);return{key:`sk-${a}-${b}-${c}`,keyId:b}}}};