n9router 0.3.87 → 0.3.89

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 (262) hide show
  1. package/.next/standalone/.next/BUILD_ID +1 -1
  2. package/.next/standalone/.next/build-manifest.json +3 -3
  3. package/.next/standalone/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
  4. package/.next/standalone/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  5. package/.next/standalone/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  6. package/.next/standalone/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -1
  7. package/.next/standalone/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  8. package/.next/standalone/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
  9. package/.next/standalone/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  10. package/.next/standalone/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  11. package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  12. package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  13. package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  14. package/.next/standalone/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
  15. package/.next/standalone/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
  16. package/.next/standalone/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  17. package/.next/standalone/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  18. package/.next/standalone/.next/server/app/_global-error.html +1 -1
  19. package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
  20. package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  21. package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  22. package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  23. package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  24. package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  25. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  26. package/.next/standalone/.next/server/app/_not-found.html +1 -1
  27. package/.next/standalone/.next/server/app/_not-found.rsc +10 -10
  28. package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +10 -10
  29. package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  30. package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +5 -5
  31. package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  32. package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  33. package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  34. package/.next/standalone/.next/server/app/api/oauth/[provider]/[action]/route.js.nft.json +1 -1
  35. package/.next/standalone/.next/server/app/api/translator/send/route.js.nft.json +1 -1
  36. package/.next/standalone/.next/server/app/api/translator/translate/route.js.nft.json +1 -1
  37. package/.next/standalone/.next/server/app/api/usage/[connectionId]/route.js.nft.json +1 -1
  38. package/.next/standalone/.next/server/app/api/usage/chart/route.js.nft.json +1 -1
  39. package/.next/standalone/.next/server/app/api/usage/history/route.js.nft.json +1 -1
  40. package/.next/standalone/.next/server/app/api/usage/logs/route.js.nft.json +1 -1
  41. package/.next/standalone/.next/server/app/api/usage/request-details/route.js.nft.json +1 -1
  42. package/.next/standalone/.next/server/app/api/usage/request-logs/route.js.nft.json +1 -1
  43. package/.next/standalone/.next/server/app/api/usage/stats/route.js.nft.json +1 -1
  44. package/.next/standalone/.next/server/app/api/usage/stream/route.js.nft.json +1 -1
  45. package/.next/standalone/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
  46. package/.next/standalone/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
  47. package/.next/standalone/.next/server/app/api/v1/embeddings/route.js.nft.json +1 -1
  48. package/.next/standalone/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
  49. package/.next/standalone/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
  50. package/.next/standalone/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
  51. package/.next/standalone/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  52. package/.next/standalone/.next/server/app/callback.html +1 -1
  53. package/.next/standalone/.next/server/app/callback.rsc +12 -12
  54. package/.next/standalone/.next/server/app/callback.segments/_full.segment.rsc +12 -12
  55. package/.next/standalone/.next/server/app/callback.segments/_head.segment.rsc +4 -4
  56. package/.next/standalone/.next/server/app/callback.segments/_index.segment.rsc +5 -5
  57. package/.next/standalone/.next/server/app/callback.segments/_tree.segment.rsc +1 -1
  58. package/.next/standalone/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +4 -4
  59. package/.next/standalone/.next/server/app/callback.segments/callback.segment.rsc +3 -3
  60. package/.next/standalone/.next/server/app/dashboard/basic-chat.html +1 -1
  61. package/.next/standalone/.next/server/app/dashboard/basic-chat.rsc +12 -12
  62. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat/__PAGE__.segment.rsc +3 -3
  63. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat.segment.rsc +3 -3
  64. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  65. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  66. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_full.segment.rsc +12 -12
  67. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_head.segment.rsc +4 -4
  68. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_index.segment.rsc +5 -5
  69. package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +1 -1
  70. package/.next/standalone/.next/server/app/dashboard/cli-tools.html +1 -1
  71. package/.next/standalone/.next/server/app/dashboard/cli-tools.rsc +12 -12
  72. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +3 -3
  73. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +3 -3
  74. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  75. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  76. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +12 -12
  77. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +4 -4
  78. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +5 -5
  79. package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +1 -1
  80. package/.next/standalone/.next/server/app/dashboard/combos.html +1 -1
  81. package/.next/standalone/.next/server/app/dashboard/combos.rsc +13 -13
  82. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +4 -4
  83. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +3 -3
  84. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  85. package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  86. package/.next/standalone/.next/server/app/dashboard/combos.segments/_full.segment.rsc +13 -13
  87. package/.next/standalone/.next/server/app/dashboard/combos.segments/_head.segment.rsc +4 -4
  88. package/.next/standalone/.next/server/app/dashboard/combos.segments/_index.segment.rsc +5 -5
  89. package/.next/standalone/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +1 -1
  90. package/.next/standalone/.next/server/app/dashboard/endpoint.html +1 -1
  91. package/.next/standalone/.next/server/app/dashboard/endpoint.rsc +12 -12
  92. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +3 -3
  93. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +3 -3
  94. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  95. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  96. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +12 -12
  97. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +4 -4
  98. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +5 -5
  99. package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +1 -1
  100. package/.next/standalone/.next/server/app/dashboard/mitm.html +1 -1
  101. package/.next/standalone/.next/server/app/dashboard/mitm.rsc +12 -12
  102. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm/__PAGE__.segment.rsc +3 -3
  103. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm.segment.rsc +3 -3
  104. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  105. package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  106. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_full.segment.rsc +12 -12
  107. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_head.segment.rsc +4 -4
  108. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_index.segment.rsc +5 -5
  109. package/.next/standalone/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +1 -1
  110. package/.next/standalone/.next/server/app/dashboard/profile.html +1 -1
  111. package/.next/standalone/.next/server/app/dashboard/profile.rsc +13 -13
  112. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +4 -4
  113. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +3 -3
  114. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  115. package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  116. package/.next/standalone/.next/server/app/dashboard/profile.segments/_full.segment.rsc +13 -13
  117. package/.next/standalone/.next/server/app/dashboard/profile.segments/_head.segment.rsc +4 -4
  118. package/.next/standalone/.next/server/app/dashboard/profile.segments/_index.segment.rsc +5 -5
  119. package/.next/standalone/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +1 -1
  120. package/.next/standalone/.next/server/app/dashboard/providers/new.html +1 -1
  121. package/.next/standalone/.next/server/app/dashboard/providers/new.rsc +13 -13
  122. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +4 -4
  123. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +3 -3
  124. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +3 -3
  125. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  126. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  127. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +13 -13
  128. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +4 -4
  129. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +5 -5
  130. package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +1 -1
  131. package/.next/standalone/.next/server/app/dashboard/providers.html +1 -1
  132. package/.next/standalone/.next/server/app/dashboard/providers.rsc +13 -13
  133. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +4 -4
  134. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +3 -3
  135. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  136. package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  137. package/.next/standalone/.next/server/app/dashboard/providers.segments/_full.segment.rsc +13 -13
  138. package/.next/standalone/.next/server/app/dashboard/providers.segments/_head.segment.rsc +4 -4
  139. package/.next/standalone/.next/server/app/dashboard/providers.segments/_index.segment.rsc +5 -5
  140. package/.next/standalone/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +1 -1
  141. package/.next/standalone/.next/server/app/dashboard/proxy-pools.html +1 -1
  142. package/.next/standalone/.next/server/app/dashboard/proxy-pools.rsc +13 -13
  143. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools/__PAGE__.segment.rsc +4 -4
  144. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools.segment.rsc +3 -3
  145. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  146. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  147. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_full.segment.rsc +13 -13
  148. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_head.segment.rsc +4 -4
  149. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_index.segment.rsc +5 -5
  150. package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +1 -1
  151. package/.next/standalone/.next/server/app/dashboard/quota.html +2 -2
  152. package/.next/standalone/.next/server/app/dashboard/quota.rsc +13 -13
  153. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota/__PAGE__.segment.rsc +4 -4
  154. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota.segment.rsc +3 -3
  155. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  156. package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  157. package/.next/standalone/.next/server/app/dashboard/quota.segments/_full.segment.rsc +13 -13
  158. package/.next/standalone/.next/server/app/dashboard/quota.segments/_head.segment.rsc +4 -4
  159. package/.next/standalone/.next/server/app/dashboard/quota.segments/_index.segment.rsc +5 -5
  160. package/.next/standalone/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +1 -1
  161. package/.next/standalone/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  162. package/.next/standalone/.next/server/app/dashboard/settings/pricing.html +1 -1
  163. package/.next/standalone/.next/server/app/dashboard/settings/pricing.rsc +12 -12
  164. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +12 -12
  165. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +4 -4
  166. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +5 -5
  167. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +1 -1
  168. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +4 -4
  169. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +3 -3
  170. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +3 -3
  171. package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +3 -3
  172. package/.next/standalone/.next/server/app/dashboard/translator.html +1 -1
  173. package/.next/standalone/.next/server/app/dashboard/translator.rsc +13 -13
  174. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +4 -4
  175. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +3 -3
  176. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  177. package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  178. package/.next/standalone/.next/server/app/dashboard/translator.segments/_full.segment.rsc +13 -13
  179. package/.next/standalone/.next/server/app/dashboard/translator.segments/_head.segment.rsc +4 -4
  180. package/.next/standalone/.next/server/app/dashboard/translator.segments/_index.segment.rsc +5 -5
  181. package/.next/standalone/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +1 -1
  182. package/.next/standalone/.next/server/app/dashboard/usage.html +1 -1
  183. package/.next/standalone/.next/server/app/dashboard/usage.rsc +13 -13
  184. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +4 -4
  185. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +3 -3
  186. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  187. package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  188. package/.next/standalone/.next/server/app/dashboard/usage.segments/_full.segment.rsc +13 -13
  189. package/.next/standalone/.next/server/app/dashboard/usage.segments/_head.segment.rsc +4 -4
  190. package/.next/standalone/.next/server/app/dashboard/usage.segments/_index.segment.rsc +5 -5
  191. package/.next/standalone/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +1 -1
  192. package/.next/standalone/.next/server/app/dashboard.html +1 -1
  193. package/.next/standalone/.next/server/app/dashboard.rsc +12 -12
  194. package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +3 -3
  195. package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
  196. package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
  197. package/.next/standalone/.next/server/app/dashboard.segments/_full.segment.rsc +12 -12
  198. package/.next/standalone/.next/server/app/dashboard.segments/_head.segment.rsc +4 -4
  199. package/.next/standalone/.next/server/app/dashboard.segments/_index.segment.rsc +5 -5
  200. package/.next/standalone/.next/server/app/dashboard.segments/_tree.segment.rsc +1 -1
  201. package/.next/standalone/.next/server/app/index.html +1 -1
  202. package/.next/standalone/.next/server/app/index.rsc +10 -10
  203. package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  204. package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +10 -10
  205. package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
  206. package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +5 -5
  207. package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  208. package/.next/standalone/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  209. package/.next/standalone/.next/server/app/landing.html +1 -1
  210. package/.next/standalone/.next/server/app/landing.rsc +12 -12
  211. package/.next/standalone/.next/server/app/landing.segments/_full.segment.rsc +12 -12
  212. package/.next/standalone/.next/server/app/landing.segments/_head.segment.rsc +4 -4
  213. package/.next/standalone/.next/server/app/landing.segments/_index.segment.rsc +5 -5
  214. package/.next/standalone/.next/server/app/landing.segments/_tree.segment.rsc +1 -1
  215. package/.next/standalone/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +4 -4
  216. package/.next/standalone/.next/server/app/landing.segments/landing.segment.rsc +3 -3
  217. package/.next/standalone/.next/server/app/login/page_client-reference-manifest.js +1 -1
  218. package/.next/standalone/.next/server/app/login.html +1 -1
  219. package/.next/standalone/.next/server/app/login.rsc +12 -12
  220. package/.next/standalone/.next/server/app/login.segments/_full.segment.rsc +12 -12
  221. package/.next/standalone/.next/server/app/login.segments/_head.segment.rsc +4 -4
  222. package/.next/standalone/.next/server/app/login.segments/_index.segment.rsc +5 -5
  223. package/.next/standalone/.next/server/app/login.segments/_tree.segment.rsc +1 -1
  224. package/.next/standalone/.next/server/app/login.segments/login/__PAGE__.segment.rsc +4 -4
  225. package/.next/standalone/.next/server/app/login.segments/login.segment.rsc +3 -3
  226. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  227. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0.yvcis._.js +1 -1
  228. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0148t9m._.js +1 -1
  229. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b802lh._.js +1 -1
  230. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0kpc-o6._.js +1 -1
  231. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0lc~.sk._.js +1 -1
  232. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0lp_pm5._.js +1 -1
  233. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0pwrfp1._.js +1 -1
  234. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0uw3x8s._.js +1 -1
  235. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0y.reft._.js +1 -1
  236. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0y5ae.7._.js +1 -1
  237. package/.next/standalone/.next/server/chunks/_0itng60._.js +1 -1
  238. package/.next/standalone/.next/server/chunks/ssr/_00c58qj._.js +1 -1
  239. package/.next/standalone/.next/server/chunks/ssr/src_0_xhepz._.js +1 -1
  240. package/.next/standalone/.next/server/chunks/ssr/src_app_(dashboard)_dashboard_providers_[id]_page_0-3xvzc.js +1 -1
  241. package/.next/standalone/.next/server/middleware-build-manifest.js +3 -3
  242. package/.next/standalone/.next/server/pages/404.html +1 -1
  243. package/.next/standalone/.next/server/pages/500.html +1 -1
  244. package/.next/standalone/.next/static/chunks/0b285gqd-hcvu.js +1 -0
  245. package/.next/standalone/.next/static/chunks/{0fic3ew7j~9an.js → 0hgyabetclndg.js} +1 -1
  246. package/.next/standalone/mitm/paths.js +17 -0
  247. package/.next/standalone/package-lock.json +2 -2
  248. package/.next/standalone/package.json +1 -1
  249. package/.next/standalone/scripts/publish-npm.sh +2 -0
  250. package/.next/standalone/src/app/(dashboard)/dashboard/providers/[id]/page.js +2 -1
  251. package/.next/standalone/src/mitm/paths.js +17 -0
  252. package/.next/static/chunks/0b285gqd-hcvu.js +1 -0
  253. package/.next/static/chunks/{0fic3ew7j~9an.js → 0hgyabetclndg.js} +1 -1
  254. package/package.json +1 -1
  255. package/.next/standalone/.next/static/chunks/09g0cm09ynuao.js +0 -1
  256. package/.next/static/chunks/09g0cm09ynuao.js +0 -1
  257. /package/.next/standalone/.next/static/{p9jVbJQhFsaISYB4CfDfF → XSoZ0BJFg1b0W2IGyybf7}/_buildManifest.js +0 -0
  258. /package/.next/standalone/.next/static/{p9jVbJQhFsaISYB4CfDfF → XSoZ0BJFg1b0W2IGyybf7}/_clientMiddlewareManifest.js +0 -0
  259. /package/.next/standalone/.next/static/{p9jVbJQhFsaISYB4CfDfF → XSoZ0BJFg1b0W2IGyybf7}/_ssgManifest.js +0 -0
  260. /package/.next/static/{p9jVbJQhFsaISYB4CfDfF → XSoZ0BJFg1b0W2IGyybf7}/_buildManifest.js +0 -0
  261. /package/.next/static/{p9jVbJQhFsaISYB4CfDfF → XSoZ0BJFg1b0W2IGyybf7}/_clientMiddlewareManifest.js +0 -0
  262. /package/.next/static/{p9jVbJQhFsaISYB4CfDfF → XSoZ0BJFg1b0W2IGyybf7}/_ssgManifest.js +0 -0
@@ -1,3 +1,3 @@
1
- module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function a(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class i{#e;#t;#r=!1;#o=null;#a=null;#i=null;#n=null;#s(e){return this.#n=e,this.#i||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#i?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#a,this.#a=this.#i=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new i(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new n(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},85063,e=>{"use strict";e.i(46786);let t={clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile","https://www.googleapis.com/auth/cclog","https://www.googleapis.com/auth/experimentsandconfigs"],apiEndpoint:"https://cloudcode-pa.googleapis.com",apiVersion:"v1internal",loadCodeAssistEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:loadCodeAssist",onboardUserEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:onboardUser",loadCodeAssistUserAgent:"google-api-nodejs-client/9.15.1",loadCodeAssistApiClient:"google-cloud-sdk vscode_cloudshelleditor/0.1",loadCodeAssistClientMetadata:JSON.stringify({ideType:"IDE_UNSPECIFIED",platform:"PLATFORM_UNSPECIFIED",pluginType:"GEMINI"})},r={clientId:process.env.KIMI_CODING_OAUTH_CLIENT_ID||"17e5f671-d194-4dfb-9706-5516cb48c098",deviceCodeUrl:"https://auth.kimi.com/api/oauth/device_authorization",tokenUrl:"https://auth.kimi.com/api/oauth/token"};e.s(["ANTIGRAVITY_CONFIG",0,t,"CLAUDE_CONFIG",0,{clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",authorizeUrl:"https://claude.ai/oauth/authorize",tokenUrl:"https://api.anthropic.com/v1/oauth/token",scopes:["org:create_api_key","user:profile","user:inference"],codeChallengeMethod:"S256"},"CLINE_CONFIG",0,{appBaseUrl:"https://app.cline.bot",apiBaseUrl:"https://api.cline.bot",authorizeUrl:"https://api.cline.bot/api/v1/auth/authorize",tokenExchangeUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},"CODEBUDDY_CONFIG",0,{baseUrl:"https://copilot.tencent.com",stateUrl:"https://copilot.tencent.com/v2/plugin/auth/state",tokenUrl:"https://copilot.tencent.com/v2/plugin/auth/token",refreshUrl:"https://copilot.tencent.com/v2/plugin/auth/token/refresh",userAgent:"CLI/2.63.2 CodeBuddy/2.63.2",platform:"CLI",pollInterval:5e3},"CODEX_CONFIG",0,{clientId:"app_EMoamEEZ73f0CkXaXp7hrann",authorizeUrl:"https://auth.openai.com/oauth/authorize",tokenUrl:"https://auth.openai.com/oauth/token",scope:"openid profile email offline_access",codeChallengeMethod:"S256",extraParams:{id_token_add_organizations:"true",codex_cli_simplified_flow:"true",originator:"codex_cli_rs"}},"CURSOR_CONFIG",0,{apiEndpoint:"https://api2.cursor.sh",chatEndpoint:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",modelsEndpoint:"/aiserver.v1.AiService/GetDefaultModelNudgeData",api3Endpoint:"https://api3.cursor.sh",agentEndpoint:"https://agent.api5.cursor.sh",agentNonPrivacyEndpoint:"https://agentn.api5.cursor.sh",clientVersion:"0.48.6",clientType:"ide",tokenStoragePaths:{linux:"~/.config/Cursor/User/globalStorage/state.vscdb",macos:"/Users/<user>/Library/Application Support/Cursor/User/globalStorage/state.vscdb",windows:"%APPDATA%\\Cursor\\User\\globalStorage\\state.vscdb"},dbKeys:{accessToken:"cursorAuth/accessToken",machineId:"storage.serviceMachineId"}},"GEMINI_CONFIG",0,{clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile"]},"GITHUB_CONFIG",0,{clientId:"Iv1.b507a08c87ecfe98",deviceCodeUrl:"https://github.com/login/device/code",tokenUrl:"https://github.com/login/oauth/access_token",userInfoUrl:"https://api.github.com/user",scopes:"read:user",apiVersion:"2022-11-28",copilotTokenUrl:"https://api.github.com/copilot_internal/v2/token",userAgent:"GitHubCopilotChat/0.26.7",editorVersion:"vscode/1.85.0",editorPluginVersion:"copilot-chat/0.26.7"},"GITLAB_CONFIG",0,{defaultBaseUrl:"https://gitlab.com",authorizeUrlPath:"/oauth/authorize",tokenUrlPath:"/oauth/token",userInfoUrlPath:"/api/v4/user",scope:"api read_user",codeChallengeMethod:"S256"},"IFLOW_CONFIG",0,{clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",authorizeUrl:"https://iflow.cn/oauth",tokenUrl:"https://iflow.cn/oauth/token",userInfoUrl:"https://iflow.cn/api/oauth/getUserInfo",extraParams:{loginMethod:"phone",type:"phone"}},"KILOCODE_CONFIG",0,{apiBaseUrl:"https://api.kilo.ai",initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},"KIMI_CODING_CONFIG",0,r,"KIRO_CONFIG",0,{ssoOidcEndpoint:"https://oidc.us-east-1.amazonaws.com",registerClientUrl:"https://oidc.us-east-1.amazonaws.com/client/register",deviceAuthUrl:"https://oidc.us-east-1.amazonaws.com/device_authorization",tokenUrl:"https://oidc.us-east-1.amazonaws.com/token",startUrl:"https://view.awsapps.com/start",clientName:"kiro-oauth-client",clientType:"public",scopes:["codewhisperer:completions","codewhisperer:analysis","codewhisperer:conversations"],grantTypes:["urn:ietf:params:oauth:grant-type:device_code","refresh_token"],issuerUrl:"https://identitycenter.amazonaws.com/ssoins-722374e8c3c8e6c6",socialAuthEndpoint:"https://prod.us-east-1.auth.desktop.kiro.dev",socialLoginUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/login",socialTokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/oauth/token",socialRefreshUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authMethods:["builder-id","idc","google","github","import"]},"QODER_CONFIG",0,{apiBaseUrl:"https://api2.qoder.sh",deviceTokenUrl:"https://api2.qoder.sh/api/v1/deviceToken/poll",deviceRefreshUrl:"https://api2.qoder.sh/api/v1/deviceToken/refresh",refreshUrl:"https://api2.qoder.sh/api/v3/user/refresh_token",userInfoUrl:"https://api2.qoder.sh/api/v1/userinfo",statusUrl:"https://api2.qoder.sh/api/v3/user/status",loginUrl:"https://qoder.com/login"},"QWEN_CONFIG",0,{clientId:"f0304373b74a44d2b584a3fb70ca9e56",deviceCodeUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",scope:"openid profile email model.completion",codeChallengeMethod:"S256"}])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},i="openai-compatible-",n="anthropic-compatible-",s={...t,...r,...o,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,i,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(i)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.87",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,r={}){let o,a=(o=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${o}`:"",i={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...r};return a&&(i.Authorization=a),i}])},1102,e=>{"use strict";e.i(69789);var t=e.i(26753);function r(e){return null==e?"":String(e).trim()}async function o(e={}){let a=r(e?.proxyPoolId),i="__none__"===a?"":a,n=function(e={}){let t=e?.connectionProxyEnabled===!0;return{connectionProxyEnabled:t,connectionProxyUrl:r(e?.connectionProxyUrl),connectionNoProxy:r(e?.connectionNoProxy)}}(e);if(i){let e=await (0,t.getProxyPoolById)(i),o=r(e?.proxyUrl),a=r(e?.noProxy);if(e&&!0===e.isActive&&o)return{source:"pool",proxyPoolId:i,proxyPool:e,connectionProxyEnabled:!0,connectionProxyUrl:o,connectionNoProxy:a,strictProxy:!0===e.strictProxy}}return n.connectionProxyEnabled&&n.connectionProxyUrl?{source:"legacy",proxyPoolId:i||null,proxyPool:null,...n}:{source:"none",proxyPoolId:i||null,proxyPool:null,...n}}e.s(["resolveConnectionProxyConfig",0,o])},78500,(e,t,r)=>{t.exports=e.x("node:async_hooks",()=>require("node:async_hooks"))},60709,e=>{"use strict";var t=e.i(36689);function r(e){return null==e?"":String(e).trim()}async function o({proxyUrl:e,testUrl:a,timeoutMs:i}={}){let n,s=r(e);if(!s)return{ok:!1,status:400,error:"proxyUrl is required"};let l=r(a)||"https://google.com/",c=Number(i),d=Number.isFinite(c)&&c>0?Math.min(c,3e4):8e3;try{try{n=new t.ProxyAgent({uri:s})}catch(e){return{ok:!1,status:400,error:`Invalid proxy URL: ${e?.message||String(e)}`}}let e=new AbortController,r=Date.now(),o=setTimeout(()=>e.abort(),d);try{let o=await (0,t.fetch)(l,{method:"HEAD",dispatcher:n,signal:e.signal,headers:{"User-Agent":"9Router"}});return{ok:o.ok,status:o.status,statusText:o.statusText,url:l,elapsedMs:Date.now()-r}}catch(t){let e=t?.name==="AbortError"?"Proxy test timed out":function(e){if(!e)return"Unknown error";let t=e?.message||String(e),r=e?.cause?.code||e?.code,o=e?.cause?.message;return o&&o!==t?r?`${t}: ${o} (${r})`:`${t}: ${o}`:r&&!t.includes(r)?`${t} (${r})`:t}(t);return{ok:!1,status:500,error:e}}finally{clearTimeout(o)}}finally{try{await n?.close?.()}catch{}}}e.s(["testProxyUrl",0,o])},21122,e=>{"use strict";var t=e.i(26753),r=e.i(1102),o=e.i(60709),a=e.i(88077),i=e.i(20491),n=e.i(85063),s=e.i(26406);let l={claude:{checkExpiry:!0,refreshable:!0},codex:{url:"https://chatgpt.com/backend-api/codex/responses",method:"POST",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"Content-Type":"application/json",originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},body:JSON.stringify({model:"gpt-5.3-codex",input:[],stream:!1,store:!1}),acceptStatuses:[400],refreshable:!0},"gemini-cli":{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},antigravity:{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},github:{url:"https://api.github.com/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"User-Agent":"9Router",Accept:"application/vnd.github+json"}},iflow:{buildUrl:e=>`https://iflow.cn/api/oauth/getUserInfo?accessToken=${encodeURIComponent(e)}`,method:"GET",noAuth:!0},qwen:{checkExpiry:!0,refreshable:!0},kiro:{checkExpiry:!0,refreshable:!0},"kimi-coding":{checkExpiry:!0,refreshable:!1},cursor:{tokenExists:!0},kilocode:{url:`${n.KILOCODE_CONFIG.apiBaseUrl}/api/profile`,method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},cline:{refreshable:!0},gitlab:{url:"https://gitlab.com/api/v4/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},codebuddy:{tokenExists:!0}};async function c(e){return await fetch("https://api.cline.bot/api/v1/users/me",{method:"GET",headers:(0,s.buildClineHeaders)(e,{Accept:"application/json"})})}async function d(e){let t=e.provider,r=e.refreshToken;if(!r)return null;try{if("gemini-cli"===t||"antigravity"===t){let e="gemini-cli"===t?n.GEMINI_CONFIG:n.ANTIGRAVITY_CONFIG,o=await fetch("https://oauth2.googleapis.com/token",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e.clientId,client_secret:e.clientSecret,grant_type:"refresh_token",refresh_token:r})});if(!o.ok)return null;let a=await o.json();return{accessToken:a.access_token,expiresIn:a.expires_in,refreshToken:a.refresh_token||r}}if("codex"===t){let e=await fetch(n.CODEX_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",client_id:n.CODEX_CONFIG.clientId,refresh_token:r})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("claude"===t){let e=await fetch(n.CLAUDE_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:r,client_id:n.CLAUDE_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("kiro"===t){let t=e.providerSpecificData||{},o=t.clientId||e.clientId,a=t.clientSecret||e.clientSecret,i=t.region||e.region;if(o&&a){let e=`https://oidc.${i||"us-east-1"}.amazonaws.com/token`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientId:o,clientSecret:a,refreshToken:r,grantType:"refresh_token"})});if(!t.ok)return null;let n=await t.json();return{accessToken:n.accessToken,expiresIn:n.expiresIn||3600,refreshToken:n.refreshToken||r}}let s=await fetch(n.KIRO_CONFIG.socialRefreshUrl,{method:"POST",headers:{"Content-Type":"application/json","User-Agent":"kiro-cli/1.0.0"},body:JSON.stringify({refreshToken:r})});if(!s.ok)return null;let l=await s.json();return{accessToken:l.accessToken,expiresIn:l.expiresIn||3600,refreshToken:l.refreshToken||r}}if("qwen"===t){let e=await fetch(n.QWEN_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:r,client_id:n.QWEN_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("cline"===t){let e=await fetch(n.CLINE_CONFIG.refreshUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({refreshToken:r,grantType:"refresh_token",clientType:"extension"})});if(!e.ok)return null;let t=await e.json(),o=t?.data||t,a=o?.expiresAt?Math.max(1,Math.floor((new Date(o.expiresAt).getTime()-Date.now())/1e3)):3600;return{accessToken:o?.accessToken,expiresIn:a,refreshToken:o?.refreshToken||r}}return null}catch(e){return console.log(`Error refreshing ${t} token:`,e.message),null}}async function p(e,t=null){var r;let o=l[e.provider];if(!o)return{valid:!1,error:"Provider test not supported",refreshed:!1};if(!e.accessToken)return{valid:!1,error:"No access token",refreshed:!1};if(o.tokenExists)return{valid:!0,error:null,refreshed:!1,newTokens:null};let a=e.accessToken,i=!1,n=null,s=!!(r=e).expiresAt&&new Date(r.expiresAt).getTime()<=Date.now()+3e5;if(o.refreshable&&s&&e.refreshToken){let t=await d(e);if(!t)return{valid:!1,error:"Token expired and refresh failed",refreshed:!1};a=t.accessToken,i=!0,n=t}if(o.checkExpiry)return i?{valid:!0,error:null,refreshed:i,newTokens:n}:s?{valid:!1,error:"Token expired",refreshed:!1}:{valid:!0,error:null,refreshed:!1,newTokens:null};if("cline"===e.provider){let t=async e=>{let t=await c(e);return t.ok?{valid:!0,error:null,refreshed:i,newTokens:n}:401===t.status?{valid:!1,error:"Token invalid or revoked",refreshed:i}:403===t.status?{valid:!1,error:"Access denied",refreshed:i}:{valid:!1,error:`API returned ${t.status}`,refreshed:i}},r=await t(a);if(r.valid||"Token invalid or revoked"!==r.error||!e.refreshToken)return r;let o=await d(e);return o?.accessToken?(i=!0,n=o,a=o.accessToken,await t(a)):{valid:!1,error:"Token invalid or revoked",refreshed:!1}}try{let r=o.buildUrl?o.buildUrl(a):o.url,s=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a}`,...o.extraHeaders},l={method:o.method,headers:s};o.body&&(l.body=o.body);let c=await u(r,l,t);if(c.ok||o.acceptStatuses&&o.acceptStatuses.includes(c.status))return{valid:!0,error:null,refreshed:i,newTokens:n};if(401===c.status&&o.refreshable&&!i&&e.refreshToken){let a=await d(e);if(a){let e=o.buildUrl?o.buildUrl(a.accessToken):r,i=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a.accessToken}`,...o.extraHeaders},n={method:o.method,headers:i};o.body&&(n.body=o.body);let s=await u(e,n,t);if(s.ok||o.acceptStatuses&&o.acceptStatuses.includes(s.status))return{valid:!0,error:null,refreshed:!0,newTokens:a}}return{valid:!1,error:"Token invalid or revoked",refreshed:!1}}if(401===c.status)return{valid:!1,error:"Token invalid or revoked",refreshed:i};if(403===c.status)return{valid:!1,error:"Access denied",refreshed:i};return{valid:!1,error:`API returned ${c.status}`,refreshed:i}}catch(e){return{valid:!1,error:e.message,refreshed:i}}}async function u(t,r={},o=null){if(!o?.connectionProxyEnabled||!o?.connectionProxyUrl)return fetch(t,r);let{proxyAwareFetch:a}=await e.A(27349);return a(t,r,{connectionProxyEnabled:!0,connectionProxyUrl:o.connectionProxyUrl,connectionNoProxy:o.connectionNoProxy||""})}async function h(e,t=null){if((0,a.isOpenAICompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{let o=await u(`${r.replace(/\/$/,"")}/models`,{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}if((0,a.isAnthropicCompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{(r=r.replace(/\/$/,"")).endsWith("/messages")&&(r=r.slice(0,-9));let o=await u(`${r}/models`,{headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}try{switch(e.provider){case"openai":{let r=await u("https://api.openai.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"anthropic":{let r=await u("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"claude-3-haiku-20240307",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"gemini":{let r=await u(`https://generativelanguage.googleapis.com/v1/models?key=${e.apiKey}`,{},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"openrouter":{let r=await u("https://openrouter.ai/api/v1/auth/key",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"glm":{let r=await u("https://api.z.ai/api/anthropic/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"glm-cn":{let r=await u("https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"minimax":case"minimax-cn":{let r=await u({minimax:"https://api.minimax.io/anthropic/v1/messages","minimax-cn":"https://api.minimaxi.com/anthropic/v1/messages"}[e.provider],{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"minimax-m2",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"kimi":{let r=await u("https://api.kimi.com/coding/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"kimi-latest",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"alicode":case"alicode-intl":{let r="alicode-intl"===e.provider?"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions":"https://coding.dashscope.aliyuncs.com/v1/chat/completions",o=await u(r,{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:(0,i.getDefaultModel)(e.provider),max_tokens:1,messages:[{role:"user",content:"test"}]})},t),a=401!==o.status&&403!==o.status;return{valid:a,error:a?null:"Invalid API key"}}case"deepseek":{let r=await u("https://api.deepseek.com/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"groq":{let r=await u("https://api.groq.com/openai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"mistral":{let r=await u("https://api.mistral.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"xai":{let r=await u("https://api.x.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nvidia":{let r=await u("https://integrate.api.nvidia.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"perplexity":{let r=await u("https://api.perplexity.ai/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"together":{let r=await u("https://api.together.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"fireworks":{let r=await u("https://api.fireworks.ai/inference/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cerebras":{let r=await u("https://api.cerebras.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cohere":{let r=await u("https://api.cohere.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nebius":{let r=await u("https://api.studio.nebius.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"siliconflow":{let r=await u("https://api.siliconflow.cn/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"hyperbolic":{let r=await u("https://api.hyperbolic.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"ollama":{let t=await fetch("https://ollama.com/api/tags",{headers:{Authorization:`Bearer ${e.apiKey}`}});return{valid:t.ok,error:t.ok?null:"Invalid API key"}}case"ollama-local":{let e=await fetch("http://localhost:11434/api/tags");return{valid:e.ok,error:e.ok?null:"Ollama not running on localhost:11434"}}case"deepgram":{let r=await u("https://api.deepgram.com/v1/projects",{headers:{Authorization:`Token ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"assemblyai":{let r=await u("https://api.assemblyai.com/v1/account",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nanobanana":{let r=await u("https://api.nanobananaapi.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"chutes":{let r=await u("https://llm.chutes.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}default:return{valid:!1,error:"Provider test not supported"}}}catch(e){return{valid:!1,error:e.message}}}async function m(e){let a,i=await (0,t.getProviderConnectionById)(e);if(!i)return{valid:!1,error:"Connection not found",latencyMs:0,testedAt:new Date().toISOString()};let n=await (0,r.resolveConnectionProxyConfig)(i.providerSpecificData||{});if(n.connectionProxyEnabled&&n.connectionProxyUrl){let r=await (0,o.testProxyUrl)({proxyUrl:n.connectionProxyUrl});if(!r.ok){let o=r.error||`Proxy test failed with status ${r.status}`;return await (0,t.updateProviderConnection)(e,{testStatus:"error",lastError:o,lastErrorAt:new Date().toISOString()}),{valid:!1,error:o,latencyMs:0,testedAt:new Date().toISOString()}}}let s=Date.now();a="apikey"===i.authType?await h(i,n):await p(i,n);let l=Date.now()-s,c={testStatus:a.valid?"active":"error",lastError:a.valid?null:a.error,lastErrorAt:a.valid?null:new Date().toISOString()};return a.refreshed&&a.newTokens&&(c.accessToken=a.newTokens.accessToken,a.newTokens.refreshToken&&(c.refreshToken=a.newTokens.refreshToken),a.newTokens.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*a.newTokens.expiresIn).toISOString())),await (0,t.updateProviderConnection)(e,c),{valid:a.valid,error:a.error,latencyMs:l,testedAt:new Date().toISOString()}}e.s(["testSingleConnection",0,m])},75526,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),i=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),h=e.i(70101),m=e.i(26937),f=e.i(10372),v=e.i(93695);e.i(20232);var g=e.i(220),k=e.i(89171),y=e.i(21122);async function w(e,{params:t}){try{let{id:e}=await t,r=await (0,y.testSingleConnection)(e);if("Connection not found"===r.error)return k.NextResponse.json({error:"Connection not found"},{status:404});return k.NextResponse.json({valid:r.valid,error:r.error,refreshed:r.refreshed||!1})}catch(e){return console.log("Error testing connection:",e),k.NextResponse.json({error:"Test failed"},{status:500})}}e.s(["POST",0,w],4814);var x=e.i(4814);let I=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/providers/[id]/test/route",pathname:"/api/providers/[id]/test",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/[id]/test/route.js",nextConfigOutput:"standalone",userland:x,...{}}),{workAsyncStorage:b,workUnitAsyncStorage:A,serverHooks:P}=I;async function C(e,t,o){o.requestMeta&&(0,a.setRequestMeta)(e,o.requestMeta),I.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let k="/api/providers/[id]/test/route";k=k.replace(/\/index$/,"")||"/";let y=await I.prepare(e,t,{srcPage:k,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:b,parsedUrl:A,isDraftMode:P,prerenderManifest:C,routerServerContext:T,isOnDemandRevalidate:_,revalidateOnlyGenerated:E,resolvedPathname:O,clientReferenceManifest:U,serverActionsManifest:S}=y,N=(0,s.normalizeAppPath)(k),R=!!(C.dynamicRoutes[N]||C.routes[O]),F=async()=>((null==T?void 0:T.render404)?await T.render404(e,t,A,!1):t.end("This page could not be found"),null);if(R&&!P){let e=!!C.routes[O],t=C.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(b.adapterPath)return await F();throw new v.NoFallbackError}}let D=null;!R||I.isDev||P||(D="/index"===(D=O)?"/":D);let B=!0===I.isDev||!R,q=R&&!B;S&&U&&(0,n.setManifestsSingleton)({page:k,clientReferenceManifest:U,serverActionsManifest:S});let G=e.method||"GET",j=(0,i.getTracer)(),$=j.getActiveScopeSpan(),M=!!(null==T?void 0:T.isWrappedByNextServer),z=!!(0,a.getRequestMeta)(e,"minimalMode"),K=(0,a.getRequestMeta)(e,"incrementalCache")||await I.getIncrementalCache(e,b,C,z);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let L={params:x,previewProps:C.preview,renderOpts:{experimental:{authInterrupts:!!b.experimental.authInterrupts},cacheComponents:!!b.cacheComponents,supportsDynamicResponse:B,incrementalCache:K,cacheLifeProfiles:b.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>I.onRequestError(e,t,o,a,T)},sharedContext:{buildId:w}},H=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=c.NextRequestAdapter.fromNodeNextRequest(H,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>I.handle(X,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=j.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${G} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",o),a.updateName(t))}else e.updateName(`${G} ${k}`)}),s=async a=>{var i,s;let l=async({previousCacheEntry:r})=>{try{if(!z&&_&&E&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await n(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let s=L.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=L.renderOpts.collectedTags;if(!R)return await (0,u.sendResponse)(H,V,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,o=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await I.onRequestError(e,t,{routerKind:"App Router",routePath:k,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:_})},!1,T),t}},c=await I.handleResponse({req:e,nextConfig:b,cacheKey:D,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:_,revalidateOnlyGenerated:E,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:z});if(!R)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",_?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),P&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return z&&R||d.delete(f.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)(H,V,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};M&&$?await s($):(a=j.getActiveScopeSpan(),await j.withPropagatedContext(e.headers,()=>j.trace(d.BaseServerSpan.handleRequest,{spanName:`${G} ${k}`,kind:i.SpanKind.SERVER,attributes:{"http.method":G,"http.target":e.url}},s),void 0,!M))}catch(t){if(t instanceof v.NoFallbackError||await I.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:_})},!1,T),R)throw t;return await (0,u.sendResponse)(H,V,new Response(null,{status:500})),null}}e.s(["handler",0,C,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:b,workUnitAsyncStorage:A})},"routeModule",0,I,"serverHooks",0,P,"workAsyncStorage",0,b,"workUnitAsyncStorage",0,A],75526)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))},27349,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0jbhiai._.js"].map(t=>e.l(t))).then(()=>t(13061)))}];
1
+ module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function a(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class i{#e;#t;#r=!1;#o=null;#a=null;#i=null;#n=null;#s(e){return this.#n=e,this.#i||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#i?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#a,this.#a=this.#i=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new i(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new n(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},85063,e=>{"use strict";e.i(46786);let t={clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile","https://www.googleapis.com/auth/cclog","https://www.googleapis.com/auth/experimentsandconfigs"],apiEndpoint:"https://cloudcode-pa.googleapis.com",apiVersion:"v1internal",loadCodeAssistEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:loadCodeAssist",onboardUserEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:onboardUser",loadCodeAssistUserAgent:"google-api-nodejs-client/9.15.1",loadCodeAssistApiClient:"google-cloud-sdk vscode_cloudshelleditor/0.1",loadCodeAssistClientMetadata:JSON.stringify({ideType:"IDE_UNSPECIFIED",platform:"PLATFORM_UNSPECIFIED",pluginType:"GEMINI"})},r={clientId:process.env.KIMI_CODING_OAUTH_CLIENT_ID||"17e5f671-d194-4dfb-9706-5516cb48c098",deviceCodeUrl:"https://auth.kimi.com/api/oauth/device_authorization",tokenUrl:"https://auth.kimi.com/api/oauth/token"};e.s(["ANTIGRAVITY_CONFIG",0,t,"CLAUDE_CONFIG",0,{clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",authorizeUrl:"https://claude.ai/oauth/authorize",tokenUrl:"https://api.anthropic.com/v1/oauth/token",scopes:["org:create_api_key","user:profile","user:inference"],codeChallengeMethod:"S256"},"CLINE_CONFIG",0,{appBaseUrl:"https://app.cline.bot",apiBaseUrl:"https://api.cline.bot",authorizeUrl:"https://api.cline.bot/api/v1/auth/authorize",tokenExchangeUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},"CODEBUDDY_CONFIG",0,{baseUrl:"https://copilot.tencent.com",stateUrl:"https://copilot.tencent.com/v2/plugin/auth/state",tokenUrl:"https://copilot.tencent.com/v2/plugin/auth/token",refreshUrl:"https://copilot.tencent.com/v2/plugin/auth/token/refresh",userAgent:"CLI/2.63.2 CodeBuddy/2.63.2",platform:"CLI",pollInterval:5e3},"CODEX_CONFIG",0,{clientId:"app_EMoamEEZ73f0CkXaXp7hrann",authorizeUrl:"https://auth.openai.com/oauth/authorize",tokenUrl:"https://auth.openai.com/oauth/token",scope:"openid profile email offline_access",codeChallengeMethod:"S256",extraParams:{id_token_add_organizations:"true",codex_cli_simplified_flow:"true",originator:"codex_cli_rs"}},"CURSOR_CONFIG",0,{apiEndpoint:"https://api2.cursor.sh",chatEndpoint:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",modelsEndpoint:"/aiserver.v1.AiService/GetDefaultModelNudgeData",api3Endpoint:"https://api3.cursor.sh",agentEndpoint:"https://agent.api5.cursor.sh",agentNonPrivacyEndpoint:"https://agentn.api5.cursor.sh",clientVersion:"0.48.6",clientType:"ide",tokenStoragePaths:{linux:"~/.config/Cursor/User/globalStorage/state.vscdb",macos:"/Users/<user>/Library/Application Support/Cursor/User/globalStorage/state.vscdb",windows:"%APPDATA%\\Cursor\\User\\globalStorage\\state.vscdb"},dbKeys:{accessToken:"cursorAuth/accessToken",machineId:"storage.serviceMachineId"}},"GEMINI_CONFIG",0,{clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile"]},"GITHUB_CONFIG",0,{clientId:"Iv1.b507a08c87ecfe98",deviceCodeUrl:"https://github.com/login/device/code",tokenUrl:"https://github.com/login/oauth/access_token",userInfoUrl:"https://api.github.com/user",scopes:"read:user",apiVersion:"2022-11-28",copilotTokenUrl:"https://api.github.com/copilot_internal/v2/token",userAgent:"GitHubCopilotChat/0.26.7",editorVersion:"vscode/1.85.0",editorPluginVersion:"copilot-chat/0.26.7"},"GITLAB_CONFIG",0,{defaultBaseUrl:"https://gitlab.com",authorizeUrlPath:"/oauth/authorize",tokenUrlPath:"/oauth/token",userInfoUrlPath:"/api/v4/user",scope:"api read_user",codeChallengeMethod:"S256"},"IFLOW_CONFIG",0,{clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",authorizeUrl:"https://iflow.cn/oauth",tokenUrl:"https://iflow.cn/oauth/token",userInfoUrl:"https://iflow.cn/api/oauth/getUserInfo",extraParams:{loginMethod:"phone",type:"phone"}},"KILOCODE_CONFIG",0,{apiBaseUrl:"https://api.kilo.ai",initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},"KIMI_CODING_CONFIG",0,r,"KIRO_CONFIG",0,{ssoOidcEndpoint:"https://oidc.us-east-1.amazonaws.com",registerClientUrl:"https://oidc.us-east-1.amazonaws.com/client/register",deviceAuthUrl:"https://oidc.us-east-1.amazonaws.com/device_authorization",tokenUrl:"https://oidc.us-east-1.amazonaws.com/token",startUrl:"https://view.awsapps.com/start",clientName:"kiro-oauth-client",clientType:"public",scopes:["codewhisperer:completions","codewhisperer:analysis","codewhisperer:conversations"],grantTypes:["urn:ietf:params:oauth:grant-type:device_code","refresh_token"],issuerUrl:"https://identitycenter.amazonaws.com/ssoins-722374e8c3c8e6c6",socialAuthEndpoint:"https://prod.us-east-1.auth.desktop.kiro.dev",socialLoginUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/login",socialTokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/oauth/token",socialRefreshUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authMethods:["builder-id","idc","google","github","import"]},"QODER_CONFIG",0,{apiBaseUrl:"https://api2.qoder.sh",deviceTokenUrl:"https://api2.qoder.sh/api/v1/deviceToken/poll",deviceRefreshUrl:"https://api2.qoder.sh/api/v1/deviceToken/refresh",refreshUrl:"https://api2.qoder.sh/api/v3/user/refresh_token",userInfoUrl:"https://api2.qoder.sh/api/v1/userinfo",statusUrl:"https://api2.qoder.sh/api/v3/user/status",loginUrl:"https://qoder.com/login"},"QWEN_CONFIG",0,{clientId:"f0304373b74a44d2b584a3fb70ca9e56",deviceCodeUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",scope:"openid profile email model.completion",codeChallengeMethod:"S256"}])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},i="openai-compatible-",n="anthropic-compatible-",s={...t,...r,...o,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,i,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(i)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.89",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,r={}){let o,a=(o=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${o}`:"",i={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...r};return a&&(i.Authorization=a),i}])},1102,e=>{"use strict";e.i(69789);var t=e.i(26753);function r(e){return null==e?"":String(e).trim()}async function o(e={}){let a=r(e?.proxyPoolId),i="__none__"===a?"":a,n=function(e={}){let t=e?.connectionProxyEnabled===!0;return{connectionProxyEnabled:t,connectionProxyUrl:r(e?.connectionProxyUrl),connectionNoProxy:r(e?.connectionNoProxy)}}(e);if(i){let e=await (0,t.getProxyPoolById)(i),o=r(e?.proxyUrl),a=r(e?.noProxy);if(e&&!0===e.isActive&&o)return{source:"pool",proxyPoolId:i,proxyPool:e,connectionProxyEnabled:!0,connectionProxyUrl:o,connectionNoProxy:a,strictProxy:!0===e.strictProxy}}return n.connectionProxyEnabled&&n.connectionProxyUrl?{source:"legacy",proxyPoolId:i||null,proxyPool:null,...n}:{source:"none",proxyPoolId:i||null,proxyPool:null,...n}}e.s(["resolveConnectionProxyConfig",0,o])},78500,(e,t,r)=>{t.exports=e.x("node:async_hooks",()=>require("node:async_hooks"))},60709,e=>{"use strict";var t=e.i(36689);function r(e){return null==e?"":String(e).trim()}async function o({proxyUrl:e,testUrl:a,timeoutMs:i}={}){let n,s=r(e);if(!s)return{ok:!1,status:400,error:"proxyUrl is required"};let l=r(a)||"https://google.com/",c=Number(i),d=Number.isFinite(c)&&c>0?Math.min(c,3e4):8e3;try{try{n=new t.ProxyAgent({uri:s})}catch(e){return{ok:!1,status:400,error:`Invalid proxy URL: ${e?.message||String(e)}`}}let e=new AbortController,r=Date.now(),o=setTimeout(()=>e.abort(),d);try{let o=await (0,t.fetch)(l,{method:"HEAD",dispatcher:n,signal:e.signal,headers:{"User-Agent":"9Router"}});return{ok:o.ok,status:o.status,statusText:o.statusText,url:l,elapsedMs:Date.now()-r}}catch(t){let e=t?.name==="AbortError"?"Proxy test timed out":function(e){if(!e)return"Unknown error";let t=e?.message||String(e),r=e?.cause?.code||e?.code,o=e?.cause?.message;return o&&o!==t?r?`${t}: ${o} (${r})`:`${t}: ${o}`:r&&!t.includes(r)?`${t} (${r})`:t}(t);return{ok:!1,status:500,error:e}}finally{clearTimeout(o)}}finally{try{await n?.close?.()}catch{}}}e.s(["testProxyUrl",0,o])},21122,e=>{"use strict";var t=e.i(26753),r=e.i(1102),o=e.i(60709),a=e.i(88077),i=e.i(20491),n=e.i(85063),s=e.i(26406);let l={claude:{checkExpiry:!0,refreshable:!0},codex:{url:"https://chatgpt.com/backend-api/codex/responses",method:"POST",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"Content-Type":"application/json",originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},body:JSON.stringify({model:"gpt-5.3-codex",input:[],stream:!1,store:!1}),acceptStatuses:[400],refreshable:!0},"gemini-cli":{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},antigravity:{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},github:{url:"https://api.github.com/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"User-Agent":"9Router",Accept:"application/vnd.github+json"}},iflow:{buildUrl:e=>`https://iflow.cn/api/oauth/getUserInfo?accessToken=${encodeURIComponent(e)}`,method:"GET",noAuth:!0},qwen:{checkExpiry:!0,refreshable:!0},kiro:{checkExpiry:!0,refreshable:!0},"kimi-coding":{checkExpiry:!0,refreshable:!1},cursor:{tokenExists:!0},kilocode:{url:`${n.KILOCODE_CONFIG.apiBaseUrl}/api/profile`,method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},cline:{refreshable:!0},gitlab:{url:"https://gitlab.com/api/v4/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},codebuddy:{tokenExists:!0}};async function c(e){return await fetch("https://api.cline.bot/api/v1/users/me",{method:"GET",headers:(0,s.buildClineHeaders)(e,{Accept:"application/json"})})}async function d(e){let t=e.provider,r=e.refreshToken;if(!r)return null;try{if("gemini-cli"===t||"antigravity"===t){let e="gemini-cli"===t?n.GEMINI_CONFIG:n.ANTIGRAVITY_CONFIG,o=await fetch("https://oauth2.googleapis.com/token",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e.clientId,client_secret:e.clientSecret,grant_type:"refresh_token",refresh_token:r})});if(!o.ok)return null;let a=await o.json();return{accessToken:a.access_token,expiresIn:a.expires_in,refreshToken:a.refresh_token||r}}if("codex"===t){let e=await fetch(n.CODEX_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",client_id:n.CODEX_CONFIG.clientId,refresh_token:r})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("claude"===t){let e=await fetch(n.CLAUDE_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:r,client_id:n.CLAUDE_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("kiro"===t){let t=e.providerSpecificData||{},o=t.clientId||e.clientId,a=t.clientSecret||e.clientSecret,i=t.region||e.region;if(o&&a){let e=`https://oidc.${i||"us-east-1"}.amazonaws.com/token`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientId:o,clientSecret:a,refreshToken:r,grantType:"refresh_token"})});if(!t.ok)return null;let n=await t.json();return{accessToken:n.accessToken,expiresIn:n.expiresIn||3600,refreshToken:n.refreshToken||r}}let s=await fetch(n.KIRO_CONFIG.socialRefreshUrl,{method:"POST",headers:{"Content-Type":"application/json","User-Agent":"kiro-cli/1.0.0"},body:JSON.stringify({refreshToken:r})});if(!s.ok)return null;let l=await s.json();return{accessToken:l.accessToken,expiresIn:l.expiresIn||3600,refreshToken:l.refreshToken||r}}if("qwen"===t){let e=await fetch(n.QWEN_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:r,client_id:n.QWEN_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("cline"===t){let e=await fetch(n.CLINE_CONFIG.refreshUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({refreshToken:r,grantType:"refresh_token",clientType:"extension"})});if(!e.ok)return null;let t=await e.json(),o=t?.data||t,a=o?.expiresAt?Math.max(1,Math.floor((new Date(o.expiresAt).getTime()-Date.now())/1e3)):3600;return{accessToken:o?.accessToken,expiresIn:a,refreshToken:o?.refreshToken||r}}return null}catch(e){return console.log(`Error refreshing ${t} token:`,e.message),null}}async function p(e,t=null){var r;let o=l[e.provider];if(!o)return{valid:!1,error:"Provider test not supported",refreshed:!1};if(!e.accessToken)return{valid:!1,error:"No access token",refreshed:!1};if(o.tokenExists)return{valid:!0,error:null,refreshed:!1,newTokens:null};let a=e.accessToken,i=!1,n=null,s=!!(r=e).expiresAt&&new Date(r.expiresAt).getTime()<=Date.now()+3e5;if(o.refreshable&&s&&e.refreshToken){let t=await d(e);if(!t)return{valid:!1,error:"Token expired and refresh failed",refreshed:!1};a=t.accessToken,i=!0,n=t}if(o.checkExpiry)return i?{valid:!0,error:null,refreshed:i,newTokens:n}:s?{valid:!1,error:"Token expired",refreshed:!1}:{valid:!0,error:null,refreshed:!1,newTokens:null};if("cline"===e.provider){let t=async e=>{let t=await c(e);return t.ok?{valid:!0,error:null,refreshed:i,newTokens:n}:401===t.status?{valid:!1,error:"Token invalid or revoked",refreshed:i}:403===t.status?{valid:!1,error:"Access denied",refreshed:i}:{valid:!1,error:`API returned ${t.status}`,refreshed:i}},r=await t(a);if(r.valid||"Token invalid or revoked"!==r.error||!e.refreshToken)return r;let o=await d(e);return o?.accessToken?(i=!0,n=o,a=o.accessToken,await t(a)):{valid:!1,error:"Token invalid or revoked",refreshed:!1}}try{let r=o.buildUrl?o.buildUrl(a):o.url,s=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a}`,...o.extraHeaders},l={method:o.method,headers:s};o.body&&(l.body=o.body);let c=await u(r,l,t);if(c.ok||o.acceptStatuses&&o.acceptStatuses.includes(c.status))return{valid:!0,error:null,refreshed:i,newTokens:n};if(401===c.status&&o.refreshable&&!i&&e.refreshToken){let a=await d(e);if(a){let e=o.buildUrl?o.buildUrl(a.accessToken):r,i=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a.accessToken}`,...o.extraHeaders},n={method:o.method,headers:i};o.body&&(n.body=o.body);let s=await u(e,n,t);if(s.ok||o.acceptStatuses&&o.acceptStatuses.includes(s.status))return{valid:!0,error:null,refreshed:!0,newTokens:a}}return{valid:!1,error:"Token invalid or revoked",refreshed:!1}}if(401===c.status)return{valid:!1,error:"Token invalid or revoked",refreshed:i};if(403===c.status)return{valid:!1,error:"Access denied",refreshed:i};return{valid:!1,error:`API returned ${c.status}`,refreshed:i}}catch(e){return{valid:!1,error:e.message,refreshed:i}}}async function u(t,r={},o=null){if(!o?.connectionProxyEnabled||!o?.connectionProxyUrl)return fetch(t,r);let{proxyAwareFetch:a}=await e.A(27349);return a(t,r,{connectionProxyEnabled:!0,connectionProxyUrl:o.connectionProxyUrl,connectionNoProxy:o.connectionNoProxy||""})}async function h(e,t=null){if((0,a.isOpenAICompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{let o=await u(`${r.replace(/\/$/,"")}/models`,{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}if((0,a.isAnthropicCompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{(r=r.replace(/\/$/,"")).endsWith("/messages")&&(r=r.slice(0,-9));let o=await u(`${r}/models`,{headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}try{switch(e.provider){case"openai":{let r=await u("https://api.openai.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"anthropic":{let r=await u("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"claude-3-haiku-20240307",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"gemini":{let r=await u(`https://generativelanguage.googleapis.com/v1/models?key=${e.apiKey}`,{},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"openrouter":{let r=await u("https://openrouter.ai/api/v1/auth/key",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"glm":{let r=await u("https://api.z.ai/api/anthropic/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"glm-cn":{let r=await u("https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"minimax":case"minimax-cn":{let r=await u({minimax:"https://api.minimax.io/anthropic/v1/messages","minimax-cn":"https://api.minimaxi.com/anthropic/v1/messages"}[e.provider],{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"minimax-m2",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"kimi":{let r=await u("https://api.kimi.com/coding/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"kimi-latest",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"alicode":case"alicode-intl":{let r="alicode-intl"===e.provider?"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions":"https://coding.dashscope.aliyuncs.com/v1/chat/completions",o=await u(r,{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:(0,i.getDefaultModel)(e.provider),max_tokens:1,messages:[{role:"user",content:"test"}]})},t),a=401!==o.status&&403!==o.status;return{valid:a,error:a?null:"Invalid API key"}}case"deepseek":{let r=await u("https://api.deepseek.com/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"groq":{let r=await u("https://api.groq.com/openai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"mistral":{let r=await u("https://api.mistral.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"xai":{let r=await u("https://api.x.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nvidia":{let r=await u("https://integrate.api.nvidia.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"perplexity":{let r=await u("https://api.perplexity.ai/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"together":{let r=await u("https://api.together.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"fireworks":{let r=await u("https://api.fireworks.ai/inference/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cerebras":{let r=await u("https://api.cerebras.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cohere":{let r=await u("https://api.cohere.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nebius":{let r=await u("https://api.studio.nebius.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"siliconflow":{let r=await u("https://api.siliconflow.cn/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"hyperbolic":{let r=await u("https://api.hyperbolic.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"ollama":{let t=await fetch("https://ollama.com/api/tags",{headers:{Authorization:`Bearer ${e.apiKey}`}});return{valid:t.ok,error:t.ok?null:"Invalid API key"}}case"ollama-local":{let e=await fetch("http://localhost:11434/api/tags");return{valid:e.ok,error:e.ok?null:"Ollama not running on localhost:11434"}}case"deepgram":{let r=await u("https://api.deepgram.com/v1/projects",{headers:{Authorization:`Token ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"assemblyai":{let r=await u("https://api.assemblyai.com/v1/account",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nanobanana":{let r=await u("https://api.nanobananaapi.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"chutes":{let r=await u("https://llm.chutes.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}default:return{valid:!1,error:"Provider test not supported"}}}catch(e){return{valid:!1,error:e.message}}}async function m(e){let a,i=await (0,t.getProviderConnectionById)(e);if(!i)return{valid:!1,error:"Connection not found",latencyMs:0,testedAt:new Date().toISOString()};let n=await (0,r.resolveConnectionProxyConfig)(i.providerSpecificData||{});if(n.connectionProxyEnabled&&n.connectionProxyUrl){let r=await (0,o.testProxyUrl)({proxyUrl:n.connectionProxyUrl});if(!r.ok){let o=r.error||`Proxy test failed with status ${r.status}`;return await (0,t.updateProviderConnection)(e,{testStatus:"error",lastError:o,lastErrorAt:new Date().toISOString()}),{valid:!1,error:o,latencyMs:0,testedAt:new Date().toISOString()}}}let s=Date.now();a="apikey"===i.authType?await h(i,n):await p(i,n);let l=Date.now()-s,c={testStatus:a.valid?"active":"error",lastError:a.valid?null:a.error,lastErrorAt:a.valid?null:new Date().toISOString()};return a.refreshed&&a.newTokens&&(c.accessToken=a.newTokens.accessToken,a.newTokens.refreshToken&&(c.refreshToken=a.newTokens.refreshToken),a.newTokens.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*a.newTokens.expiresIn).toISOString())),await (0,t.updateProviderConnection)(e,c),{valid:a.valid,error:a.error,latencyMs:l,testedAt:new Date().toISOString()}}e.s(["testSingleConnection",0,m])},75526,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),i=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),h=e.i(70101),m=e.i(26937),f=e.i(10372),v=e.i(93695);e.i(20232);var g=e.i(220),k=e.i(89171),y=e.i(21122);async function w(e,{params:t}){try{let{id:e}=await t,r=await (0,y.testSingleConnection)(e);if("Connection not found"===r.error)return k.NextResponse.json({error:"Connection not found"},{status:404});return k.NextResponse.json({valid:r.valid,error:r.error,refreshed:r.refreshed||!1})}catch(e){return console.log("Error testing connection:",e),k.NextResponse.json({error:"Test failed"},{status:500})}}e.s(["POST",0,w],4814);var x=e.i(4814);let I=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/providers/[id]/test/route",pathname:"/api/providers/[id]/test",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/[id]/test/route.js",nextConfigOutput:"standalone",userland:x,...{}}),{workAsyncStorage:b,workUnitAsyncStorage:A,serverHooks:P}=I;async function C(e,t,o){o.requestMeta&&(0,a.setRequestMeta)(e,o.requestMeta),I.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let k="/api/providers/[id]/test/route";k=k.replace(/\/index$/,"")||"/";let y=await I.prepare(e,t,{srcPage:k,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:b,parsedUrl:A,isDraftMode:P,prerenderManifest:C,routerServerContext:T,isOnDemandRevalidate:_,revalidateOnlyGenerated:E,resolvedPathname:O,clientReferenceManifest:U,serverActionsManifest:S}=y,N=(0,s.normalizeAppPath)(k),R=!!(C.dynamicRoutes[N]||C.routes[O]),F=async()=>((null==T?void 0:T.render404)?await T.render404(e,t,A,!1):t.end("This page could not be found"),null);if(R&&!P){let e=!!C.routes[O],t=C.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(b.adapterPath)return await F();throw new v.NoFallbackError}}let D=null;!R||I.isDev||P||(D="/index"===(D=O)?"/":D);let B=!0===I.isDev||!R,q=R&&!B;S&&U&&(0,n.setManifestsSingleton)({page:k,clientReferenceManifest:U,serverActionsManifest:S});let G=e.method||"GET",j=(0,i.getTracer)(),$=j.getActiveScopeSpan(),M=!!(null==T?void 0:T.isWrappedByNextServer),z=!!(0,a.getRequestMeta)(e,"minimalMode"),K=(0,a.getRequestMeta)(e,"incrementalCache")||await I.getIncrementalCache(e,b,C,z);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let L={params:x,previewProps:C.preview,renderOpts:{experimental:{authInterrupts:!!b.experimental.authInterrupts},cacheComponents:!!b.cacheComponents,supportsDynamicResponse:B,incrementalCache:K,cacheLifeProfiles:b.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>I.onRequestError(e,t,o,a,T)},sharedContext:{buildId:w}},H=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=c.NextRequestAdapter.fromNodeNextRequest(H,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>I.handle(X,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=j.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${G} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",o),a.updateName(t))}else e.updateName(`${G} ${k}`)}),s=async a=>{var i,s;let l=async({previousCacheEntry:r})=>{try{if(!z&&_&&E&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await n(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let s=L.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=L.renderOpts.collectedTags;if(!R)return await (0,u.sendResponse)(H,V,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,o=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await I.onRequestError(e,t,{routerKind:"App Router",routePath:k,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:_})},!1,T),t}},c=await I.handleResponse({req:e,nextConfig:b,cacheKey:D,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:_,revalidateOnlyGenerated:E,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:z});if(!R)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",_?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),P&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return z&&R||d.delete(f.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)(H,V,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};M&&$?await s($):(a=j.getActiveScopeSpan(),await j.withPropagatedContext(e.headers,()=>j.trace(d.BaseServerSpan.handleRequest,{spanName:`${G} ${k}`,kind:i.SpanKind.SERVER,attributes:{"http.method":G,"http.target":e.url}},s),void 0,!M))}catch(t){if(t instanceof v.NoFallbackError||await I.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:_})},!1,T),R)throw t;return await (0,u.sendResponse)(H,V,new Response(null,{status:500})),null}}e.s(["handler",0,C,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:b,workUnitAsyncStorage:A})},"routeModule",0,I,"serverHooks",0,P,"workAsyncStorage",0,b,"workUnitAsyncStorage",0,A],75526)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))},27349,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0jbhiai._.js"].map(t=>e.l(t))).then(()=>t(13061)))}];
2
2
 
3
3
  //# sourceMappingURL=%5Broot-of-the-server%5D__0pwrfp1._.js.map
@@ -1,3 +1,3 @@
1
- module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function a(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class i{#e;#t;#r=!1;#o=null;#a=null;#i=null;#n=null;#s(e){return this.#n=e,this.#i||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#i?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#a,this.#a=this.#i=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new i(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new n(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},85063,e=>{"use strict";e.i(46786);let t={clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile","https://www.googleapis.com/auth/cclog","https://www.googleapis.com/auth/experimentsandconfigs"],apiEndpoint:"https://cloudcode-pa.googleapis.com",apiVersion:"v1internal",loadCodeAssistEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:loadCodeAssist",onboardUserEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:onboardUser",loadCodeAssistUserAgent:"google-api-nodejs-client/9.15.1",loadCodeAssistApiClient:"google-cloud-sdk vscode_cloudshelleditor/0.1",loadCodeAssistClientMetadata:JSON.stringify({ideType:"IDE_UNSPECIFIED",platform:"PLATFORM_UNSPECIFIED",pluginType:"GEMINI"})},r={clientId:process.env.KIMI_CODING_OAUTH_CLIENT_ID||"17e5f671-d194-4dfb-9706-5516cb48c098",deviceCodeUrl:"https://auth.kimi.com/api/oauth/device_authorization",tokenUrl:"https://auth.kimi.com/api/oauth/token"};e.s(["ANTIGRAVITY_CONFIG",0,t,"CLAUDE_CONFIG",0,{clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",authorizeUrl:"https://claude.ai/oauth/authorize",tokenUrl:"https://api.anthropic.com/v1/oauth/token",scopes:["org:create_api_key","user:profile","user:inference"],codeChallengeMethod:"S256"},"CLINE_CONFIG",0,{appBaseUrl:"https://app.cline.bot",apiBaseUrl:"https://api.cline.bot",authorizeUrl:"https://api.cline.bot/api/v1/auth/authorize",tokenExchangeUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},"CODEBUDDY_CONFIG",0,{baseUrl:"https://copilot.tencent.com",stateUrl:"https://copilot.tencent.com/v2/plugin/auth/state",tokenUrl:"https://copilot.tencent.com/v2/plugin/auth/token",refreshUrl:"https://copilot.tencent.com/v2/plugin/auth/token/refresh",userAgent:"CLI/2.63.2 CodeBuddy/2.63.2",platform:"CLI",pollInterval:5e3},"CODEX_CONFIG",0,{clientId:"app_EMoamEEZ73f0CkXaXp7hrann",authorizeUrl:"https://auth.openai.com/oauth/authorize",tokenUrl:"https://auth.openai.com/oauth/token",scope:"openid profile email offline_access",codeChallengeMethod:"S256",extraParams:{id_token_add_organizations:"true",codex_cli_simplified_flow:"true",originator:"codex_cli_rs"}},"CURSOR_CONFIG",0,{apiEndpoint:"https://api2.cursor.sh",chatEndpoint:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",modelsEndpoint:"/aiserver.v1.AiService/GetDefaultModelNudgeData",api3Endpoint:"https://api3.cursor.sh",agentEndpoint:"https://agent.api5.cursor.sh",agentNonPrivacyEndpoint:"https://agentn.api5.cursor.sh",clientVersion:"0.48.6",clientType:"ide",tokenStoragePaths:{linux:"~/.config/Cursor/User/globalStorage/state.vscdb",macos:"/Users/<user>/Library/Application Support/Cursor/User/globalStorage/state.vscdb",windows:"%APPDATA%\\Cursor\\User\\globalStorage\\state.vscdb"},dbKeys:{accessToken:"cursorAuth/accessToken",machineId:"storage.serviceMachineId"}},"GEMINI_CONFIG",0,{clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile"]},"GITHUB_CONFIG",0,{clientId:"Iv1.b507a08c87ecfe98",deviceCodeUrl:"https://github.com/login/device/code",tokenUrl:"https://github.com/login/oauth/access_token",userInfoUrl:"https://api.github.com/user",scopes:"read:user",apiVersion:"2022-11-28",copilotTokenUrl:"https://api.github.com/copilot_internal/v2/token",userAgent:"GitHubCopilotChat/0.26.7",editorVersion:"vscode/1.85.0",editorPluginVersion:"copilot-chat/0.26.7"},"GITLAB_CONFIG",0,{defaultBaseUrl:"https://gitlab.com",authorizeUrlPath:"/oauth/authorize",tokenUrlPath:"/oauth/token",userInfoUrlPath:"/api/v4/user",scope:"api read_user",codeChallengeMethod:"S256"},"IFLOW_CONFIG",0,{clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",authorizeUrl:"https://iflow.cn/oauth",tokenUrl:"https://iflow.cn/oauth/token",userInfoUrl:"https://iflow.cn/api/oauth/getUserInfo",extraParams:{loginMethod:"phone",type:"phone"}},"KILOCODE_CONFIG",0,{apiBaseUrl:"https://api.kilo.ai",initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},"KIMI_CODING_CONFIG",0,r,"KIRO_CONFIG",0,{ssoOidcEndpoint:"https://oidc.us-east-1.amazonaws.com",registerClientUrl:"https://oidc.us-east-1.amazonaws.com/client/register",deviceAuthUrl:"https://oidc.us-east-1.amazonaws.com/device_authorization",tokenUrl:"https://oidc.us-east-1.amazonaws.com/token",startUrl:"https://view.awsapps.com/start",clientName:"kiro-oauth-client",clientType:"public",scopes:["codewhisperer:completions","codewhisperer:analysis","codewhisperer:conversations"],grantTypes:["urn:ietf:params:oauth:grant-type:device_code","refresh_token"],issuerUrl:"https://identitycenter.amazonaws.com/ssoins-722374e8c3c8e6c6",socialAuthEndpoint:"https://prod.us-east-1.auth.desktop.kiro.dev",socialLoginUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/login",socialTokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/oauth/token",socialRefreshUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authMethods:["builder-id","idc","google","github","import"]},"QODER_CONFIG",0,{apiBaseUrl:"https://api2.qoder.sh",deviceTokenUrl:"https://api2.qoder.sh/api/v1/deviceToken/poll",deviceRefreshUrl:"https://api2.qoder.sh/api/v1/deviceToken/refresh",refreshUrl:"https://api2.qoder.sh/api/v3/user/refresh_token",userInfoUrl:"https://api2.qoder.sh/api/v1/userinfo",statusUrl:"https://api2.qoder.sh/api/v3/user/status",loginUrl:"https://qoder.com/login"},"QWEN_CONFIG",0,{clientId:"f0304373b74a44d2b584a3fb70ca9e56",deviceCodeUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",scope:"openid profile email model.completion",codeChallengeMethod:"S256"}])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},i="openai-compatible-",n="anthropic-compatible-",s={...t,...r,...o,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,i,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(i)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.87",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,r={}){let o,a=(o=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${o}`:"",i={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...r};return a&&(i.Authorization=a),i}])},1102,e=>{"use strict";e.i(69789);var t=e.i(26753);function r(e){return null==e?"":String(e).trim()}async function o(e={}){let a=r(e?.proxyPoolId),i="__none__"===a?"":a,n=function(e={}){let t=e?.connectionProxyEnabled===!0;return{connectionProxyEnabled:t,connectionProxyUrl:r(e?.connectionProxyUrl),connectionNoProxy:r(e?.connectionNoProxy)}}(e);if(i){let e=await (0,t.getProxyPoolById)(i),o=r(e?.proxyUrl),a=r(e?.noProxy);if(e&&!0===e.isActive&&o)return{source:"pool",proxyPoolId:i,proxyPool:e,connectionProxyEnabled:!0,connectionProxyUrl:o,connectionNoProxy:a,strictProxy:!0===e.strictProxy}}return n.connectionProxyEnabled&&n.connectionProxyUrl?{source:"legacy",proxyPoolId:i||null,proxyPool:null,...n}:{source:"none",proxyPoolId:i||null,proxyPool:null,...n}}e.s(["resolveConnectionProxyConfig",0,o])},78500,(e,t,r)=>{t.exports=e.x("node:async_hooks",()=>require("node:async_hooks"))},60709,e=>{"use strict";var t=e.i(36689);function r(e){return null==e?"":String(e).trim()}async function o({proxyUrl:e,testUrl:a,timeoutMs:i}={}){let n,s=r(e);if(!s)return{ok:!1,status:400,error:"proxyUrl is required"};let l=r(a)||"https://google.com/",c=Number(i),d=Number.isFinite(c)&&c>0?Math.min(c,3e4):8e3;try{try{n=new t.ProxyAgent({uri:s})}catch(e){return{ok:!1,status:400,error:`Invalid proxy URL: ${e?.message||String(e)}`}}let e=new AbortController,r=Date.now(),o=setTimeout(()=>e.abort(),d);try{let o=await (0,t.fetch)(l,{method:"HEAD",dispatcher:n,signal:e.signal,headers:{"User-Agent":"9Router"}});return{ok:o.ok,status:o.status,statusText:o.statusText,url:l,elapsedMs:Date.now()-r}}catch(t){let e=t?.name==="AbortError"?"Proxy test timed out":function(e){if(!e)return"Unknown error";let t=e?.message||String(e),r=e?.cause?.code||e?.code,o=e?.cause?.message;return o&&o!==t?r?`${t}: ${o} (${r})`:`${t}: ${o}`:r&&!t.includes(r)?`${t} (${r})`:t}(t);return{ok:!1,status:500,error:e}}finally{clearTimeout(o)}}finally{try{await n?.close?.()}catch{}}}e.s(["testProxyUrl",0,o])},21122,e=>{"use strict";var t=e.i(26753),r=e.i(1102),o=e.i(60709),a=e.i(88077),i=e.i(20491),n=e.i(85063),s=e.i(26406);let l={claude:{checkExpiry:!0,refreshable:!0},codex:{url:"https://chatgpt.com/backend-api/codex/responses",method:"POST",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"Content-Type":"application/json",originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},body:JSON.stringify({model:"gpt-5.3-codex",input:[],stream:!1,store:!1}),acceptStatuses:[400],refreshable:!0},"gemini-cli":{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},antigravity:{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},github:{url:"https://api.github.com/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"User-Agent":"9Router",Accept:"application/vnd.github+json"}},iflow:{buildUrl:e=>`https://iflow.cn/api/oauth/getUserInfo?accessToken=${encodeURIComponent(e)}`,method:"GET",noAuth:!0},qwen:{checkExpiry:!0,refreshable:!0},kiro:{checkExpiry:!0,refreshable:!0},"kimi-coding":{checkExpiry:!0,refreshable:!1},cursor:{tokenExists:!0},kilocode:{url:`${n.KILOCODE_CONFIG.apiBaseUrl}/api/profile`,method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},cline:{refreshable:!0},gitlab:{url:"https://gitlab.com/api/v4/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},codebuddy:{tokenExists:!0}};async function c(e){return await fetch("https://api.cline.bot/api/v1/users/me",{method:"GET",headers:(0,s.buildClineHeaders)(e,{Accept:"application/json"})})}async function d(e){let t=e.provider,r=e.refreshToken;if(!r)return null;try{if("gemini-cli"===t||"antigravity"===t){let e="gemini-cli"===t?n.GEMINI_CONFIG:n.ANTIGRAVITY_CONFIG,o=await fetch("https://oauth2.googleapis.com/token",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e.clientId,client_secret:e.clientSecret,grant_type:"refresh_token",refresh_token:r})});if(!o.ok)return null;let a=await o.json();return{accessToken:a.access_token,expiresIn:a.expires_in,refreshToken:a.refresh_token||r}}if("codex"===t){let e=await fetch(n.CODEX_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",client_id:n.CODEX_CONFIG.clientId,refresh_token:r})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("claude"===t){let e=await fetch(n.CLAUDE_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:r,client_id:n.CLAUDE_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("kiro"===t){let t=e.providerSpecificData||{},o=t.clientId||e.clientId,a=t.clientSecret||e.clientSecret,i=t.region||e.region;if(o&&a){let e=`https://oidc.${i||"us-east-1"}.amazonaws.com/token`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientId:o,clientSecret:a,refreshToken:r,grantType:"refresh_token"})});if(!t.ok)return null;let n=await t.json();return{accessToken:n.accessToken,expiresIn:n.expiresIn||3600,refreshToken:n.refreshToken||r}}let s=await fetch(n.KIRO_CONFIG.socialRefreshUrl,{method:"POST",headers:{"Content-Type":"application/json","User-Agent":"kiro-cli/1.0.0"},body:JSON.stringify({refreshToken:r})});if(!s.ok)return null;let l=await s.json();return{accessToken:l.accessToken,expiresIn:l.expiresIn||3600,refreshToken:l.refreshToken||r}}if("qwen"===t){let e=await fetch(n.QWEN_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:r,client_id:n.QWEN_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("cline"===t){let e=await fetch(n.CLINE_CONFIG.refreshUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({refreshToken:r,grantType:"refresh_token",clientType:"extension"})});if(!e.ok)return null;let t=await e.json(),o=t?.data||t,a=o?.expiresAt?Math.max(1,Math.floor((new Date(o.expiresAt).getTime()-Date.now())/1e3)):3600;return{accessToken:o?.accessToken,expiresIn:a,refreshToken:o?.refreshToken||r}}return null}catch(e){return console.log(`Error refreshing ${t} token:`,e.message),null}}async function p(e,t=null){var r;let o=l[e.provider];if(!o)return{valid:!1,error:"Provider test not supported",refreshed:!1};if(!e.accessToken)return{valid:!1,error:"No access token",refreshed:!1};if(o.tokenExists)return{valid:!0,error:null,refreshed:!1,newTokens:null};let a=e.accessToken,i=!1,n=null,s=!!(r=e).expiresAt&&new Date(r.expiresAt).getTime()<=Date.now()+3e5;if(o.refreshable&&s&&e.refreshToken){let t=await d(e);if(!t)return{valid:!1,error:"Token expired and refresh failed",refreshed:!1};a=t.accessToken,i=!0,n=t}if(o.checkExpiry)return i?{valid:!0,error:null,refreshed:i,newTokens:n}:s?{valid:!1,error:"Token expired",refreshed:!1}:{valid:!0,error:null,refreshed:!1,newTokens:null};if("cline"===e.provider){let t=async e=>{let t=await c(e);return t.ok?{valid:!0,error:null,refreshed:i,newTokens:n}:401===t.status?{valid:!1,error:"Token invalid or revoked",refreshed:i}:403===t.status?{valid:!1,error:"Access denied",refreshed:i}:{valid:!1,error:`API returned ${t.status}`,refreshed:i}},r=await t(a);if(r.valid||"Token invalid or revoked"!==r.error||!e.refreshToken)return r;let o=await d(e);return o?.accessToken?(i=!0,n=o,a=o.accessToken,await t(a)):{valid:!1,error:"Token invalid or revoked",refreshed:!1}}try{let r=o.buildUrl?o.buildUrl(a):o.url,s=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a}`,...o.extraHeaders},l={method:o.method,headers:s};o.body&&(l.body=o.body);let c=await u(r,l,t);if(c.ok||o.acceptStatuses&&o.acceptStatuses.includes(c.status))return{valid:!0,error:null,refreshed:i,newTokens:n};if(401===c.status&&o.refreshable&&!i&&e.refreshToken){let a=await d(e);if(a){let e=o.buildUrl?o.buildUrl(a.accessToken):r,i=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a.accessToken}`,...o.extraHeaders},n={method:o.method,headers:i};o.body&&(n.body=o.body);let s=await u(e,n,t);if(s.ok||o.acceptStatuses&&o.acceptStatuses.includes(s.status))return{valid:!0,error:null,refreshed:!0,newTokens:a}}return{valid:!1,error:"Token invalid or revoked",refreshed:!1}}if(401===c.status)return{valid:!1,error:"Token invalid or revoked",refreshed:i};if(403===c.status)return{valid:!1,error:"Access denied",refreshed:i};return{valid:!1,error:`API returned ${c.status}`,refreshed:i}}catch(e){return{valid:!1,error:e.message,refreshed:i}}}async function u(t,r={},o=null){if(!o?.connectionProxyEnabled||!o?.connectionProxyUrl)return fetch(t,r);let{proxyAwareFetch:a}=await e.A(27349);return a(t,r,{connectionProxyEnabled:!0,connectionProxyUrl:o.connectionProxyUrl,connectionNoProxy:o.connectionNoProxy||""})}async function h(e,t=null){if((0,a.isOpenAICompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{let o=await u(`${r.replace(/\/$/,"")}/models`,{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}if((0,a.isAnthropicCompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{(r=r.replace(/\/$/,"")).endsWith("/messages")&&(r=r.slice(0,-9));let o=await u(`${r}/models`,{headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}try{switch(e.provider){case"openai":{let r=await u("https://api.openai.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"anthropic":{let r=await u("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"claude-3-haiku-20240307",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"gemini":{let r=await u(`https://generativelanguage.googleapis.com/v1/models?key=${e.apiKey}`,{},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"openrouter":{let r=await u("https://openrouter.ai/api/v1/auth/key",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"glm":{let r=await u("https://api.z.ai/api/anthropic/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"glm-cn":{let r=await u("https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"minimax":case"minimax-cn":{let r=await u({minimax:"https://api.minimax.io/anthropic/v1/messages","minimax-cn":"https://api.minimaxi.com/anthropic/v1/messages"}[e.provider],{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"minimax-m2",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"kimi":{let r=await u("https://api.kimi.com/coding/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"kimi-latest",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"alicode":case"alicode-intl":{let r="alicode-intl"===e.provider?"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions":"https://coding.dashscope.aliyuncs.com/v1/chat/completions",o=await u(r,{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:(0,i.getDefaultModel)(e.provider),max_tokens:1,messages:[{role:"user",content:"test"}]})},t),a=401!==o.status&&403!==o.status;return{valid:a,error:a?null:"Invalid API key"}}case"deepseek":{let r=await u("https://api.deepseek.com/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"groq":{let r=await u("https://api.groq.com/openai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"mistral":{let r=await u("https://api.mistral.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"xai":{let r=await u("https://api.x.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nvidia":{let r=await u("https://integrate.api.nvidia.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"perplexity":{let r=await u("https://api.perplexity.ai/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"together":{let r=await u("https://api.together.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"fireworks":{let r=await u("https://api.fireworks.ai/inference/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cerebras":{let r=await u("https://api.cerebras.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cohere":{let r=await u("https://api.cohere.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nebius":{let r=await u("https://api.studio.nebius.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"siliconflow":{let r=await u("https://api.siliconflow.cn/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"hyperbolic":{let r=await u("https://api.hyperbolic.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"ollama":{let t=await fetch("https://ollama.com/api/tags",{headers:{Authorization:`Bearer ${e.apiKey}`}});return{valid:t.ok,error:t.ok?null:"Invalid API key"}}case"ollama-local":{let e=await fetch("http://localhost:11434/api/tags");return{valid:e.ok,error:e.ok?null:"Ollama not running on localhost:11434"}}case"deepgram":{let r=await u("https://api.deepgram.com/v1/projects",{headers:{Authorization:`Token ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"assemblyai":{let r=await u("https://api.assemblyai.com/v1/account",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nanobanana":{let r=await u("https://api.nanobananaapi.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"chutes":{let r=await u("https://llm.chutes.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}default:return{valid:!1,error:"Provider test not supported"}}}catch(e){return{valid:!1,error:e.message}}}async function m(e){let a,i=await (0,t.getProviderConnectionById)(e);if(!i)return{valid:!1,error:"Connection not found",latencyMs:0,testedAt:new Date().toISOString()};let n=await (0,r.resolveConnectionProxyConfig)(i.providerSpecificData||{});if(n.connectionProxyEnabled&&n.connectionProxyUrl){let r=await (0,o.testProxyUrl)({proxyUrl:n.connectionProxyUrl});if(!r.ok){let o=r.error||`Proxy test failed with status ${r.status}`;return await (0,t.updateProviderConnection)(e,{testStatus:"error",lastError:o,lastErrorAt:new Date().toISOString()}),{valid:!1,error:o,latencyMs:0,testedAt:new Date().toISOString()}}}let s=Date.now();a="apikey"===i.authType?await h(i,n):await p(i,n);let l=Date.now()-s,c={testStatus:a.valid?"active":"error",lastError:a.valid?null:a.error,lastErrorAt:a.valid?null:new Date().toISOString()};return a.refreshed&&a.newTokens&&(c.accessToken=a.newTokens.accessToken,a.newTokens.refreshToken&&(c.refreshToken=a.newTokens.refreshToken),a.newTokens.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*a.newTokens.expiresIn).toISOString())),await (0,t.updateProviderConnection)(e,c),{valid:a.valid,error:a.error,latencyMs:l,testedAt:new Date().toISOString()}}e.s(["testSingleConnection",0,m])},19208,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),i=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),h=e.i(70101),m=e.i(26937),f=e.i(10372),g=e.i(93695);e.i(20232);var v=e.i(220),y=e.i(22734),k=e.i(14747),w=e.i(46786),x=e.i(26753),I=e.i(21122);let b=k.default.join(w.default.homedir(),".antigravity_tools"),A=k.default.join(b,"accounts.json"),P=k.default.join(b,"accounts");function C(){return y.default.existsSync(A)&&JSON.parse(y.default.readFileSync(A,"utf-8")).accounts||[]}function T(e){let t=k.default.join(P,`${e}.json`);return y.default.existsSync(t)?JSON.parse(y.default.readFileSync(t,"utf-8")):null}async function _(){try{if(!y.default.existsSync(b))return Response.json({error:"~/.antigravity_tools not found",accounts:[]},{status:404});let e=C(),t=await (0,x.getProviderConnections)({provider:"antigravity"}),r=new Set(t.map(e=>e.email)),o=e.map(e=>{let t=T(e.id);return{id:e.id,email:e.email,name:e.name,disabled:e.disabled,hasToken:!!t?.token?.access_token,hasRefreshToken:!!t?.token?.refresh_token,isNew:!r.has(e.email)}});return Response.json({accounts:o,total:o.length})}catch(e){return console.error("[antigravity-tools/import] Preview error:",e),Response.json({error:e.message},{status:500})}}async function E(){try{if(!y.default.existsSync(b))return Response.json({error:"~/.antigravity_tools not found"},{status:404});let e=C(),t=await (0,x.getProviderConnections)({provider:"antigravity"}),r=new Set(t.map(e=>e.email)),o=0,a=0,i=0,n=[];for(let t of e)try{if(t.disabled){i++;continue}let e=T(t.id);if(!e?.token?.access_token){i++;continue}let n=e.token,s=null;n.expiry_timestamp?s=new Date(1e3*n.expiry_timestamp).toISOString():n.expires_in&&(s=new Date(Date.now()+1e3*n.expires_in).toISOString());let l={provider:"antigravity",authType:"oauth",email:t.email||n.email,name:t.name||t.email,accessToken:n.access_token,refreshToken:n.refresh_token||null,expiresAt:s,projectId:n.project_id||null,isActive:!0},c=r.has(l.email),d=await (0,x.createProviderConnection)(l);try{let e=await (0,I.testSingleConnection)(d.id);console.log(`[antigravity-tools/import] Tested ${l.email}: ${e.valid?"active":"error"} (${e.latencyMs}ms)`)}catch(e){console.log(`[antigravity-tools/import] Test failed for ${l.email}: ${e.message}`)}c?a++:(o++,r.add(l.email))}catch(e){n.push({email:t.email,error:e.message})}return console.log(`[antigravity-tools/import] Done: imported=${o}, updated=${a}, skipped=${i}, errors=${n.length}`),Response.json({imported:o,updated:a,skipped:i,errors:n,total:e.length})}catch(e){return console.error("[antigravity-tools/import] Import error:",e),Response.json({error:e.message},{status:500})}}e.s(["GET",0,_,"POST",0,E],74714);var O=e.i(74714);let S=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/antigravity-tools/import/route",pathname:"/api/antigravity-tools/import",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/antigravity-tools/import/route.js",nextConfigOutput:"standalone",userland:O,...{}}),{workAsyncStorage:U,workUnitAsyncStorage:N,serverHooks:R}=S;async function F(e,t,o){o.requestMeta&&(0,a.setRequestMeta)(e,o.requestMeta),S.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/antigravity-tools/import/route";y=y.replace(/\/index$/,"")||"/";let k=await S.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!k)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:I,parsedUrl:b,isDraftMode:A,prerenderManifest:P,routerServerContext:C,isOnDemandRevalidate:T,revalidateOnlyGenerated:_,resolvedPathname:E,clientReferenceManifest:O,serverActionsManifest:U}=k,N=(0,s.normalizeAppPath)(y),R=!!(P.dynamicRoutes[N]||P.routes[E]),F=async()=>((null==C?void 0:C.render404)?await C.render404(e,t,b,!1):t.end("This page could not be found"),null);if(R&&!A){let e=!!P.routes[E],t=P.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await F();throw new g.NoFallbackError}}let D=null;!R||S.isDev||A||(D="/index"===(D=E)?"/":D);let $=!0===S.isDev||!R,j=R&&!$;U&&O&&(0,n.setManifestsSingleton)({page:y,clientReferenceManifest:O,serverActionsManifest:U});let B=e.method||"GET",q=(0,i.getTracer)(),G=q.getActiveScopeSpan(),M=!!(null==C?void 0:C.isWrappedByNextServer),z=!!(0,a.getRequestMeta)(e,"minimalMode"),K=(0,a.getRequestMeta)(e,"incrementalCache")||await S.getIncrementalCache(e,I,P,z);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let L={params:x,previewProps:P.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:$,incrementalCache:K,cacheLifeProfiles:I.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>S.onRequestError(e,t,o,a,C)},sharedContext:{buildId:w}},H=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=c.NextRequestAdapter.fromNodeNextRequest(H,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>S.handle(X,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=q.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${B} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",o),a.updateName(t))}else e.updateName(`${B} ${y}`)}),s=async a=>{var i,s;let l=async({previousCacheEntry:r})=>{try{if(!z&&T&&_&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await n(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let s=L.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=L.renderOpts.collectedTags;if(!R)return await (0,u.sendResponse)(H,V,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,o=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:v.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await S.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:T})},!1,C),t}},c=await S.handleResponse({req:e,nextConfig:I,cacheKey:D,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:P,isRoutePPREnabled:!1,isOnDemandRevalidate:T,revalidateOnlyGenerated:_,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:z});if(!R)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==v.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",T?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return z&&R||d.delete(f.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)(H,V,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};M&&G?await s(G):(a=q.getActiveScopeSpan(),await q.withPropagatedContext(e.headers,()=>q.trace(d.BaseServerSpan.handleRequest,{spanName:`${B} ${y}`,kind:i.SpanKind.SERVER,attributes:{"http.method":B,"http.target":e.url}},s),void 0,!M))}catch(t){if(t instanceof g.NoFallbackError||await S.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:T})},!1,C),R)throw t;return await (0,u.sendResponse)(H,V,new Response(null,{status:500})),null}}e.s(["handler",0,F,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:U,workUnitAsyncStorage:N})},"routeModule",0,S,"serverHooks",0,R,"workAsyncStorage",0,U,"workUnitAsyncStorage",0,N],19208)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))},27349,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__10y-ljc._.js"].map(t=>e.l(t))).then(()=>t(13061)))}];
1
+ module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function a(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class i{#e;#t;#r=!1;#o=null;#a=null;#i=null;#n=null;#s(e){return this.#n=e,this.#i||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#i?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#a,this.#a=this.#i=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new i(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new n(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},85063,e=>{"use strict";e.i(46786);let t={clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile","https://www.googleapis.com/auth/cclog","https://www.googleapis.com/auth/experimentsandconfigs"],apiEndpoint:"https://cloudcode-pa.googleapis.com",apiVersion:"v1internal",loadCodeAssistEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:loadCodeAssist",onboardUserEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:onboardUser",loadCodeAssistUserAgent:"google-api-nodejs-client/9.15.1",loadCodeAssistApiClient:"google-cloud-sdk vscode_cloudshelleditor/0.1",loadCodeAssistClientMetadata:JSON.stringify({ideType:"IDE_UNSPECIFIED",platform:"PLATFORM_UNSPECIFIED",pluginType:"GEMINI"})},r={clientId:process.env.KIMI_CODING_OAUTH_CLIENT_ID||"17e5f671-d194-4dfb-9706-5516cb48c098",deviceCodeUrl:"https://auth.kimi.com/api/oauth/device_authorization",tokenUrl:"https://auth.kimi.com/api/oauth/token"};e.s(["ANTIGRAVITY_CONFIG",0,t,"CLAUDE_CONFIG",0,{clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",authorizeUrl:"https://claude.ai/oauth/authorize",tokenUrl:"https://api.anthropic.com/v1/oauth/token",scopes:["org:create_api_key","user:profile","user:inference"],codeChallengeMethod:"S256"},"CLINE_CONFIG",0,{appBaseUrl:"https://app.cline.bot",apiBaseUrl:"https://api.cline.bot",authorizeUrl:"https://api.cline.bot/api/v1/auth/authorize",tokenExchangeUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},"CODEBUDDY_CONFIG",0,{baseUrl:"https://copilot.tencent.com",stateUrl:"https://copilot.tencent.com/v2/plugin/auth/state",tokenUrl:"https://copilot.tencent.com/v2/plugin/auth/token",refreshUrl:"https://copilot.tencent.com/v2/plugin/auth/token/refresh",userAgent:"CLI/2.63.2 CodeBuddy/2.63.2",platform:"CLI",pollInterval:5e3},"CODEX_CONFIG",0,{clientId:"app_EMoamEEZ73f0CkXaXp7hrann",authorizeUrl:"https://auth.openai.com/oauth/authorize",tokenUrl:"https://auth.openai.com/oauth/token",scope:"openid profile email offline_access",codeChallengeMethod:"S256",extraParams:{id_token_add_organizations:"true",codex_cli_simplified_flow:"true",originator:"codex_cli_rs"}},"CURSOR_CONFIG",0,{apiEndpoint:"https://api2.cursor.sh",chatEndpoint:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",modelsEndpoint:"/aiserver.v1.AiService/GetDefaultModelNudgeData",api3Endpoint:"https://api3.cursor.sh",agentEndpoint:"https://agent.api5.cursor.sh",agentNonPrivacyEndpoint:"https://agentn.api5.cursor.sh",clientVersion:"0.48.6",clientType:"ide",tokenStoragePaths:{linux:"~/.config/Cursor/User/globalStorage/state.vscdb",macos:"/Users/<user>/Library/Application Support/Cursor/User/globalStorage/state.vscdb",windows:"%APPDATA%\\Cursor\\User\\globalStorage\\state.vscdb"},dbKeys:{accessToken:"cursorAuth/accessToken",machineId:"storage.serviceMachineId"}},"GEMINI_CONFIG",0,{clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile"]},"GITHUB_CONFIG",0,{clientId:"Iv1.b507a08c87ecfe98",deviceCodeUrl:"https://github.com/login/device/code",tokenUrl:"https://github.com/login/oauth/access_token",userInfoUrl:"https://api.github.com/user",scopes:"read:user",apiVersion:"2022-11-28",copilotTokenUrl:"https://api.github.com/copilot_internal/v2/token",userAgent:"GitHubCopilotChat/0.26.7",editorVersion:"vscode/1.85.0",editorPluginVersion:"copilot-chat/0.26.7"},"GITLAB_CONFIG",0,{defaultBaseUrl:"https://gitlab.com",authorizeUrlPath:"/oauth/authorize",tokenUrlPath:"/oauth/token",userInfoUrlPath:"/api/v4/user",scope:"api read_user",codeChallengeMethod:"S256"},"IFLOW_CONFIG",0,{clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",authorizeUrl:"https://iflow.cn/oauth",tokenUrl:"https://iflow.cn/oauth/token",userInfoUrl:"https://iflow.cn/api/oauth/getUserInfo",extraParams:{loginMethod:"phone",type:"phone"}},"KILOCODE_CONFIG",0,{apiBaseUrl:"https://api.kilo.ai",initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},"KIMI_CODING_CONFIG",0,r,"KIRO_CONFIG",0,{ssoOidcEndpoint:"https://oidc.us-east-1.amazonaws.com",registerClientUrl:"https://oidc.us-east-1.amazonaws.com/client/register",deviceAuthUrl:"https://oidc.us-east-1.amazonaws.com/device_authorization",tokenUrl:"https://oidc.us-east-1.amazonaws.com/token",startUrl:"https://view.awsapps.com/start",clientName:"kiro-oauth-client",clientType:"public",scopes:["codewhisperer:completions","codewhisperer:analysis","codewhisperer:conversations"],grantTypes:["urn:ietf:params:oauth:grant-type:device_code","refresh_token"],issuerUrl:"https://identitycenter.amazonaws.com/ssoins-722374e8c3c8e6c6",socialAuthEndpoint:"https://prod.us-east-1.auth.desktop.kiro.dev",socialLoginUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/login",socialTokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/oauth/token",socialRefreshUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authMethods:["builder-id","idc","google","github","import"]},"QODER_CONFIG",0,{apiBaseUrl:"https://api2.qoder.sh",deviceTokenUrl:"https://api2.qoder.sh/api/v1/deviceToken/poll",deviceRefreshUrl:"https://api2.qoder.sh/api/v1/deviceToken/refresh",refreshUrl:"https://api2.qoder.sh/api/v3/user/refresh_token",userInfoUrl:"https://api2.qoder.sh/api/v1/userinfo",statusUrl:"https://api2.qoder.sh/api/v3/user/status",loginUrl:"https://qoder.com/login"},"QWEN_CONFIG",0,{clientId:"f0304373b74a44d2b584a3fb70ca9e56",deviceCodeUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",scope:"openid profile email model.completion",codeChallengeMethod:"S256"}])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},i="openai-compatible-",n="anthropic-compatible-",s={...t,...r,...o,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,i,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(i)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.89",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,r={}){let o,a=(o=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${o}`:"",i={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...r};return a&&(i.Authorization=a),i}])},1102,e=>{"use strict";e.i(69789);var t=e.i(26753);function r(e){return null==e?"":String(e).trim()}async function o(e={}){let a=r(e?.proxyPoolId),i="__none__"===a?"":a,n=function(e={}){let t=e?.connectionProxyEnabled===!0;return{connectionProxyEnabled:t,connectionProxyUrl:r(e?.connectionProxyUrl),connectionNoProxy:r(e?.connectionNoProxy)}}(e);if(i){let e=await (0,t.getProxyPoolById)(i),o=r(e?.proxyUrl),a=r(e?.noProxy);if(e&&!0===e.isActive&&o)return{source:"pool",proxyPoolId:i,proxyPool:e,connectionProxyEnabled:!0,connectionProxyUrl:o,connectionNoProxy:a,strictProxy:!0===e.strictProxy}}return n.connectionProxyEnabled&&n.connectionProxyUrl?{source:"legacy",proxyPoolId:i||null,proxyPool:null,...n}:{source:"none",proxyPoolId:i||null,proxyPool:null,...n}}e.s(["resolveConnectionProxyConfig",0,o])},78500,(e,t,r)=>{t.exports=e.x("node:async_hooks",()=>require("node:async_hooks"))},60709,e=>{"use strict";var t=e.i(36689);function r(e){return null==e?"":String(e).trim()}async function o({proxyUrl:e,testUrl:a,timeoutMs:i}={}){let n,s=r(e);if(!s)return{ok:!1,status:400,error:"proxyUrl is required"};let l=r(a)||"https://google.com/",c=Number(i),d=Number.isFinite(c)&&c>0?Math.min(c,3e4):8e3;try{try{n=new t.ProxyAgent({uri:s})}catch(e){return{ok:!1,status:400,error:`Invalid proxy URL: ${e?.message||String(e)}`}}let e=new AbortController,r=Date.now(),o=setTimeout(()=>e.abort(),d);try{let o=await (0,t.fetch)(l,{method:"HEAD",dispatcher:n,signal:e.signal,headers:{"User-Agent":"9Router"}});return{ok:o.ok,status:o.status,statusText:o.statusText,url:l,elapsedMs:Date.now()-r}}catch(t){let e=t?.name==="AbortError"?"Proxy test timed out":function(e){if(!e)return"Unknown error";let t=e?.message||String(e),r=e?.cause?.code||e?.code,o=e?.cause?.message;return o&&o!==t?r?`${t}: ${o} (${r})`:`${t}: ${o}`:r&&!t.includes(r)?`${t} (${r})`:t}(t);return{ok:!1,status:500,error:e}}finally{clearTimeout(o)}}finally{try{await n?.close?.()}catch{}}}e.s(["testProxyUrl",0,o])},21122,e=>{"use strict";var t=e.i(26753),r=e.i(1102),o=e.i(60709),a=e.i(88077),i=e.i(20491),n=e.i(85063),s=e.i(26406);let l={claude:{checkExpiry:!0,refreshable:!0},codex:{url:"https://chatgpt.com/backend-api/codex/responses",method:"POST",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"Content-Type":"application/json",originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},body:JSON.stringify({model:"gpt-5.3-codex",input:[],stream:!1,store:!1}),acceptStatuses:[400],refreshable:!0},"gemini-cli":{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},antigravity:{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},github:{url:"https://api.github.com/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"User-Agent":"9Router",Accept:"application/vnd.github+json"}},iflow:{buildUrl:e=>`https://iflow.cn/api/oauth/getUserInfo?accessToken=${encodeURIComponent(e)}`,method:"GET",noAuth:!0},qwen:{checkExpiry:!0,refreshable:!0},kiro:{checkExpiry:!0,refreshable:!0},"kimi-coding":{checkExpiry:!0,refreshable:!1},cursor:{tokenExists:!0},kilocode:{url:`${n.KILOCODE_CONFIG.apiBaseUrl}/api/profile`,method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},cline:{refreshable:!0},gitlab:{url:"https://gitlab.com/api/v4/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},codebuddy:{tokenExists:!0}};async function c(e){return await fetch("https://api.cline.bot/api/v1/users/me",{method:"GET",headers:(0,s.buildClineHeaders)(e,{Accept:"application/json"})})}async function d(e){let t=e.provider,r=e.refreshToken;if(!r)return null;try{if("gemini-cli"===t||"antigravity"===t){let e="gemini-cli"===t?n.GEMINI_CONFIG:n.ANTIGRAVITY_CONFIG,o=await fetch("https://oauth2.googleapis.com/token",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e.clientId,client_secret:e.clientSecret,grant_type:"refresh_token",refresh_token:r})});if(!o.ok)return null;let a=await o.json();return{accessToken:a.access_token,expiresIn:a.expires_in,refreshToken:a.refresh_token||r}}if("codex"===t){let e=await fetch(n.CODEX_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",client_id:n.CODEX_CONFIG.clientId,refresh_token:r})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("claude"===t){let e=await fetch(n.CLAUDE_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:r,client_id:n.CLAUDE_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("kiro"===t){let t=e.providerSpecificData||{},o=t.clientId||e.clientId,a=t.clientSecret||e.clientSecret,i=t.region||e.region;if(o&&a){let e=`https://oidc.${i||"us-east-1"}.amazonaws.com/token`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientId:o,clientSecret:a,refreshToken:r,grantType:"refresh_token"})});if(!t.ok)return null;let n=await t.json();return{accessToken:n.accessToken,expiresIn:n.expiresIn||3600,refreshToken:n.refreshToken||r}}let s=await fetch(n.KIRO_CONFIG.socialRefreshUrl,{method:"POST",headers:{"Content-Type":"application/json","User-Agent":"kiro-cli/1.0.0"},body:JSON.stringify({refreshToken:r})});if(!s.ok)return null;let l=await s.json();return{accessToken:l.accessToken,expiresIn:l.expiresIn||3600,refreshToken:l.refreshToken||r}}if("qwen"===t){let e=await fetch(n.QWEN_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:r,client_id:n.QWEN_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("cline"===t){let e=await fetch(n.CLINE_CONFIG.refreshUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({refreshToken:r,grantType:"refresh_token",clientType:"extension"})});if(!e.ok)return null;let t=await e.json(),o=t?.data||t,a=o?.expiresAt?Math.max(1,Math.floor((new Date(o.expiresAt).getTime()-Date.now())/1e3)):3600;return{accessToken:o?.accessToken,expiresIn:a,refreshToken:o?.refreshToken||r}}return null}catch(e){return console.log(`Error refreshing ${t} token:`,e.message),null}}async function p(e,t=null){var r;let o=l[e.provider];if(!o)return{valid:!1,error:"Provider test not supported",refreshed:!1};if(!e.accessToken)return{valid:!1,error:"No access token",refreshed:!1};if(o.tokenExists)return{valid:!0,error:null,refreshed:!1,newTokens:null};let a=e.accessToken,i=!1,n=null,s=!!(r=e).expiresAt&&new Date(r.expiresAt).getTime()<=Date.now()+3e5;if(o.refreshable&&s&&e.refreshToken){let t=await d(e);if(!t)return{valid:!1,error:"Token expired and refresh failed",refreshed:!1};a=t.accessToken,i=!0,n=t}if(o.checkExpiry)return i?{valid:!0,error:null,refreshed:i,newTokens:n}:s?{valid:!1,error:"Token expired",refreshed:!1}:{valid:!0,error:null,refreshed:!1,newTokens:null};if("cline"===e.provider){let t=async e=>{let t=await c(e);return t.ok?{valid:!0,error:null,refreshed:i,newTokens:n}:401===t.status?{valid:!1,error:"Token invalid or revoked",refreshed:i}:403===t.status?{valid:!1,error:"Access denied",refreshed:i}:{valid:!1,error:`API returned ${t.status}`,refreshed:i}},r=await t(a);if(r.valid||"Token invalid or revoked"!==r.error||!e.refreshToken)return r;let o=await d(e);return o?.accessToken?(i=!0,n=o,a=o.accessToken,await t(a)):{valid:!1,error:"Token invalid or revoked",refreshed:!1}}try{let r=o.buildUrl?o.buildUrl(a):o.url,s=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a}`,...o.extraHeaders},l={method:o.method,headers:s};o.body&&(l.body=o.body);let c=await u(r,l,t);if(c.ok||o.acceptStatuses&&o.acceptStatuses.includes(c.status))return{valid:!0,error:null,refreshed:i,newTokens:n};if(401===c.status&&o.refreshable&&!i&&e.refreshToken){let a=await d(e);if(a){let e=o.buildUrl?o.buildUrl(a.accessToken):r,i=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a.accessToken}`,...o.extraHeaders},n={method:o.method,headers:i};o.body&&(n.body=o.body);let s=await u(e,n,t);if(s.ok||o.acceptStatuses&&o.acceptStatuses.includes(s.status))return{valid:!0,error:null,refreshed:!0,newTokens:a}}return{valid:!1,error:"Token invalid or revoked",refreshed:!1}}if(401===c.status)return{valid:!1,error:"Token invalid or revoked",refreshed:i};if(403===c.status)return{valid:!1,error:"Access denied",refreshed:i};return{valid:!1,error:`API returned ${c.status}`,refreshed:i}}catch(e){return{valid:!1,error:e.message,refreshed:i}}}async function u(t,r={},o=null){if(!o?.connectionProxyEnabled||!o?.connectionProxyUrl)return fetch(t,r);let{proxyAwareFetch:a}=await e.A(27349);return a(t,r,{connectionProxyEnabled:!0,connectionProxyUrl:o.connectionProxyUrl,connectionNoProxy:o.connectionNoProxy||""})}async function h(e,t=null){if((0,a.isOpenAICompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{let o=await u(`${r.replace(/\/$/,"")}/models`,{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}if((0,a.isAnthropicCompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{(r=r.replace(/\/$/,"")).endsWith("/messages")&&(r=r.slice(0,-9));let o=await u(`${r}/models`,{headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}try{switch(e.provider){case"openai":{let r=await u("https://api.openai.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"anthropic":{let r=await u("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"claude-3-haiku-20240307",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"gemini":{let r=await u(`https://generativelanguage.googleapis.com/v1/models?key=${e.apiKey}`,{},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"openrouter":{let r=await u("https://openrouter.ai/api/v1/auth/key",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"glm":{let r=await u("https://api.z.ai/api/anthropic/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"glm-cn":{let r=await u("https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"minimax":case"minimax-cn":{let r=await u({minimax:"https://api.minimax.io/anthropic/v1/messages","minimax-cn":"https://api.minimaxi.com/anthropic/v1/messages"}[e.provider],{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"minimax-m2",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"kimi":{let r=await u("https://api.kimi.com/coding/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"kimi-latest",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"alicode":case"alicode-intl":{let r="alicode-intl"===e.provider?"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions":"https://coding.dashscope.aliyuncs.com/v1/chat/completions",o=await u(r,{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:(0,i.getDefaultModel)(e.provider),max_tokens:1,messages:[{role:"user",content:"test"}]})},t),a=401!==o.status&&403!==o.status;return{valid:a,error:a?null:"Invalid API key"}}case"deepseek":{let r=await u("https://api.deepseek.com/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"groq":{let r=await u("https://api.groq.com/openai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"mistral":{let r=await u("https://api.mistral.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"xai":{let r=await u("https://api.x.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nvidia":{let r=await u("https://integrate.api.nvidia.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"perplexity":{let r=await u("https://api.perplexity.ai/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"together":{let r=await u("https://api.together.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"fireworks":{let r=await u("https://api.fireworks.ai/inference/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cerebras":{let r=await u("https://api.cerebras.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cohere":{let r=await u("https://api.cohere.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nebius":{let r=await u("https://api.studio.nebius.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"siliconflow":{let r=await u("https://api.siliconflow.cn/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"hyperbolic":{let r=await u("https://api.hyperbolic.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"ollama":{let t=await fetch("https://ollama.com/api/tags",{headers:{Authorization:`Bearer ${e.apiKey}`}});return{valid:t.ok,error:t.ok?null:"Invalid API key"}}case"ollama-local":{let e=await fetch("http://localhost:11434/api/tags");return{valid:e.ok,error:e.ok?null:"Ollama not running on localhost:11434"}}case"deepgram":{let r=await u("https://api.deepgram.com/v1/projects",{headers:{Authorization:`Token ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"assemblyai":{let r=await u("https://api.assemblyai.com/v1/account",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nanobanana":{let r=await u("https://api.nanobananaapi.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"chutes":{let r=await u("https://llm.chutes.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}default:return{valid:!1,error:"Provider test not supported"}}}catch(e){return{valid:!1,error:e.message}}}async function m(e){let a,i=await (0,t.getProviderConnectionById)(e);if(!i)return{valid:!1,error:"Connection not found",latencyMs:0,testedAt:new Date().toISOString()};let n=await (0,r.resolveConnectionProxyConfig)(i.providerSpecificData||{});if(n.connectionProxyEnabled&&n.connectionProxyUrl){let r=await (0,o.testProxyUrl)({proxyUrl:n.connectionProxyUrl});if(!r.ok){let o=r.error||`Proxy test failed with status ${r.status}`;return await (0,t.updateProviderConnection)(e,{testStatus:"error",lastError:o,lastErrorAt:new Date().toISOString()}),{valid:!1,error:o,latencyMs:0,testedAt:new Date().toISOString()}}}let s=Date.now();a="apikey"===i.authType?await h(i,n):await p(i,n);let l=Date.now()-s,c={testStatus:a.valid?"active":"error",lastError:a.valid?null:a.error,lastErrorAt:a.valid?null:new Date().toISOString()};return a.refreshed&&a.newTokens&&(c.accessToken=a.newTokens.accessToken,a.newTokens.refreshToken&&(c.refreshToken=a.newTokens.refreshToken),a.newTokens.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*a.newTokens.expiresIn).toISOString())),await (0,t.updateProviderConnection)(e,c),{valid:a.valid,error:a.error,latencyMs:l,testedAt:new Date().toISOString()}}e.s(["testSingleConnection",0,m])},19208,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),i=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),h=e.i(70101),m=e.i(26937),f=e.i(10372),g=e.i(93695);e.i(20232);var v=e.i(220),y=e.i(22734),k=e.i(14747),w=e.i(46786),x=e.i(26753),I=e.i(21122);let b=k.default.join(w.default.homedir(),".antigravity_tools"),A=k.default.join(b,"accounts.json"),P=k.default.join(b,"accounts");function C(){return y.default.existsSync(A)&&JSON.parse(y.default.readFileSync(A,"utf-8")).accounts||[]}function T(e){let t=k.default.join(P,`${e}.json`);return y.default.existsSync(t)?JSON.parse(y.default.readFileSync(t,"utf-8")):null}async function _(){try{if(!y.default.existsSync(b))return Response.json({error:"~/.antigravity_tools not found",accounts:[]},{status:404});let e=C(),t=await (0,x.getProviderConnections)({provider:"antigravity"}),r=new Set(t.map(e=>e.email)),o=e.map(e=>{let t=T(e.id);return{id:e.id,email:e.email,name:e.name,disabled:e.disabled,hasToken:!!t?.token?.access_token,hasRefreshToken:!!t?.token?.refresh_token,isNew:!r.has(e.email)}});return Response.json({accounts:o,total:o.length})}catch(e){return console.error("[antigravity-tools/import] Preview error:",e),Response.json({error:e.message},{status:500})}}async function E(){try{if(!y.default.existsSync(b))return Response.json({error:"~/.antigravity_tools not found"},{status:404});let e=C(),t=await (0,x.getProviderConnections)({provider:"antigravity"}),r=new Set(t.map(e=>e.email)),o=0,a=0,i=0,n=[];for(let t of e)try{if(t.disabled){i++;continue}let e=T(t.id);if(!e?.token?.access_token){i++;continue}let n=e.token,s=null;n.expiry_timestamp?s=new Date(1e3*n.expiry_timestamp).toISOString():n.expires_in&&(s=new Date(Date.now()+1e3*n.expires_in).toISOString());let l={provider:"antigravity",authType:"oauth",email:t.email||n.email,name:t.name||t.email,accessToken:n.access_token,refreshToken:n.refresh_token||null,expiresAt:s,projectId:n.project_id||null,isActive:!0},c=r.has(l.email),d=await (0,x.createProviderConnection)(l);try{let e=await (0,I.testSingleConnection)(d.id);console.log(`[antigravity-tools/import] Tested ${l.email}: ${e.valid?"active":"error"} (${e.latencyMs}ms)`)}catch(e){console.log(`[antigravity-tools/import] Test failed for ${l.email}: ${e.message}`)}c?a++:(o++,r.add(l.email))}catch(e){n.push({email:t.email,error:e.message})}return console.log(`[antigravity-tools/import] Done: imported=${o}, updated=${a}, skipped=${i}, errors=${n.length}`),Response.json({imported:o,updated:a,skipped:i,errors:n,total:e.length})}catch(e){return console.error("[antigravity-tools/import] Import error:",e),Response.json({error:e.message},{status:500})}}e.s(["GET",0,_,"POST",0,E],74714);var O=e.i(74714);let S=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/antigravity-tools/import/route",pathname:"/api/antigravity-tools/import",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/antigravity-tools/import/route.js",nextConfigOutput:"standalone",userland:O,...{}}),{workAsyncStorage:U,workUnitAsyncStorage:N,serverHooks:R}=S;async function F(e,t,o){o.requestMeta&&(0,a.setRequestMeta)(e,o.requestMeta),S.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/antigravity-tools/import/route";y=y.replace(/\/index$/,"")||"/";let k=await S.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!k)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:I,parsedUrl:b,isDraftMode:A,prerenderManifest:P,routerServerContext:C,isOnDemandRevalidate:T,revalidateOnlyGenerated:_,resolvedPathname:E,clientReferenceManifest:O,serverActionsManifest:U}=k,N=(0,s.normalizeAppPath)(y),R=!!(P.dynamicRoutes[N]||P.routes[E]),F=async()=>((null==C?void 0:C.render404)?await C.render404(e,t,b,!1):t.end("This page could not be found"),null);if(R&&!A){let e=!!P.routes[E],t=P.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await F();throw new g.NoFallbackError}}let D=null;!R||S.isDev||A||(D="/index"===(D=E)?"/":D);let $=!0===S.isDev||!R,j=R&&!$;U&&O&&(0,n.setManifestsSingleton)({page:y,clientReferenceManifest:O,serverActionsManifest:U});let B=e.method||"GET",q=(0,i.getTracer)(),G=q.getActiveScopeSpan(),M=!!(null==C?void 0:C.isWrappedByNextServer),z=!!(0,a.getRequestMeta)(e,"minimalMode"),K=(0,a.getRequestMeta)(e,"incrementalCache")||await S.getIncrementalCache(e,I,P,z);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let L={params:x,previewProps:P.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:$,incrementalCache:K,cacheLifeProfiles:I.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>S.onRequestError(e,t,o,a,C)},sharedContext:{buildId:w}},H=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=c.NextRequestAdapter.fromNodeNextRequest(H,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>S.handle(X,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=q.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${B} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",o),a.updateName(t))}else e.updateName(`${B} ${y}`)}),s=async a=>{var i,s;let l=async({previousCacheEntry:r})=>{try{if(!z&&T&&_&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await n(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let s=L.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=L.renderOpts.collectedTags;if(!R)return await (0,u.sendResponse)(H,V,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,o=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:v.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await S.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:T})},!1,C),t}},c=await S.handleResponse({req:e,nextConfig:I,cacheKey:D,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:P,isRoutePPREnabled:!1,isOnDemandRevalidate:T,revalidateOnlyGenerated:_,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:z});if(!R)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==v.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",T?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return z&&R||d.delete(f.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)(H,V,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};M&&G?await s(G):(a=q.getActiveScopeSpan(),await q.withPropagatedContext(e.headers,()=>q.trace(d.BaseServerSpan.handleRequest,{spanName:`${B} ${y}`,kind:i.SpanKind.SERVER,attributes:{"http.method":B,"http.target":e.url}},s),void 0,!M))}catch(t){if(t instanceof g.NoFallbackError||await S.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:T})},!1,C),R)throw t;return await (0,u.sendResponse)(H,V,new Response(null,{status:500})),null}}e.s(["handler",0,F,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:U,workUnitAsyncStorage:N})},"routeModule",0,S,"serverHooks",0,R,"workAsyncStorage",0,U,"workUnitAsyncStorage",0,N],19208)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))},27349,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__10y-ljc._.js"].map(t=>e.l(t))).then(()=>t(13061)))}];
2
2
 
3
3
  //# sourceMappingURL=%5Broot-of-the-server%5D__0uw3x8s._.js.map