9router 0.2.71 → 0.2.73

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 (455) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +42 -40
  3. package/app/.next/build-manifest.json +2 -2
  4. package/app/.next/prerender-manifest.json +3 -3
  5. package/app/.next/routes-manifest.json +12 -0
  6. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  7. package/app/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  8. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  9. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  10. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js +1 -1
  11. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  12. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +1 -1
  13. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  14. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  15. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  16. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js +2 -2
  18. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  19. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  20. package/app/.next/server/app/_global-error.html +2 -2
  21. package/app/.next/server/app/_global-error.rsc +1 -1
  22. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  23. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  24. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  25. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  26. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  27. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  28. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  29. package/app/.next/server/app/_not-found.html +1 -1
  30. package/app/.next/server/app/_not-found.rsc +3 -3
  31. package/app/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  32. package/app/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  33. package/app/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  34. package/app/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  35. package/app/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  36. package/app/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  37. package/app/.next/server/app/api/auth/login/route.js +1 -1
  38. package/app/.next/server/app/api/auth/login/route_client-reference-manifest.js +1 -1
  39. package/app/.next/server/app/api/auth/logout/route_client-reference-manifest.js +1 -1
  40. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
  41. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route_client-reference-manifest.js +1 -1
  42. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +4 -5
  43. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route_client-reference-manifest.js +1 -1
  44. package/app/.next/server/app/api/cli-tools/claude-settings/route.js +2 -2
  45. package/app/.next/server/app/api/cli-tools/claude-settings/route_client-reference-manifest.js +1 -1
  46. package/app/.next/server/app/api/cli-tools/codex-settings/route.js +1 -1
  47. package/app/.next/server/app/api/cli-tools/codex-settings/route_client-reference-manifest.js +1 -1
  48. package/app/.next/server/app/api/cli-tools/droid-settings/route.js +2 -2
  49. package/app/.next/server/app/api/cli-tools/droid-settings/route_client-reference-manifest.js +1 -1
  50. package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js +2 -2
  51. package/app/.next/server/app/api/cli-tools/openclaw-settings/route_client-reference-manifest.js +1 -1
  52. package/app/.next/server/app/api/cloud/auth/route_client-reference-manifest.js +1 -1
  53. package/app/.next/server/app/api/cloud/credentials/update/route_client-reference-manifest.js +1 -1
  54. package/app/.next/server/app/api/cloud/model/resolve/route_client-reference-manifest.js +1 -1
  55. package/app/.next/server/app/api/cloud/models/alias/route.js +1 -1
  56. package/app/.next/server/app/api/cloud/models/alias/route_client-reference-manifest.js +1 -1
  57. package/app/.next/server/app/api/combos/[id]/route.js +1 -1
  58. package/app/.next/server/app/api/combos/[id]/route_client-reference-manifest.js +1 -1
  59. package/app/.next/server/app/api/combos/route.js +1 -1
  60. package/app/.next/server/app/api/combos/route_client-reference-manifest.js +1 -1
  61. package/app/.next/server/app/api/init/route_client-reference-manifest.js +1 -1
  62. package/app/.next/server/app/api/keys/[id]/route.js +1 -1
  63. package/app/.next/server/app/api/keys/[id]/route_client-reference-manifest.js +1 -1
  64. package/app/.next/server/app/api/keys/route.js +1 -1
  65. package/app/.next/server/app/api/keys/route_client-reference-manifest.js +1 -1
  66. package/app/.next/server/app/api/models/alias/route.js +1 -1
  67. package/app/.next/server/app/api/models/alias/route_client-reference-manifest.js +1 -1
  68. package/app/.next/server/app/api/models/route_client-reference-manifest.js +1 -1
  69. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js +1 -1
  70. package/app/.next/server/app/api/oauth/[provider]/[action]/route_client-reference-manifest.js +1 -1
  71. package/app/.next/server/app/api/oauth/cursor/auto-import/route.js +1 -1
  72. package/app/.next/server/app/api/oauth/cursor/auto-import/route_client-reference-manifest.js +1 -1
  73. package/app/.next/server/app/api/oauth/cursor/import/route.js +1 -1
  74. package/app/.next/server/app/api/oauth/cursor/import/route_client-reference-manifest.js +1 -1
  75. package/app/.next/server/app/api/oauth/kiro/auto-import/route_client-reference-manifest.js +1 -1
  76. package/app/.next/server/app/api/oauth/kiro/import/route.js +1 -1
  77. package/app/.next/server/app/api/oauth/kiro/import/route_client-reference-manifest.js +1 -1
  78. package/app/.next/server/app/api/oauth/kiro/social-authorize/route_client-reference-manifest.js +1 -1
  79. package/app/.next/server/app/api/oauth/kiro/social-exchange/route.js +1 -1
  80. package/app/.next/server/app/api/oauth/kiro/social-exchange/route_client-reference-manifest.js +1 -1
  81. package/app/.next/server/app/api/pricing/route_client-reference-manifest.js +1 -1
  82. package/app/.next/server/app/api/provider-nodes/[id]/route_client-reference-manifest.js +1 -1
  83. package/app/.next/server/app/api/provider-nodes/route.js +1 -1
  84. package/app/.next/server/app/api/provider-nodes/route_client-reference-manifest.js +1 -1
  85. package/app/.next/server/app/api/provider-nodes/validate/route_client-reference-manifest.js +1 -1
  86. package/app/.next/server/app/api/providers/[id]/models/route.js +1 -1
  87. package/app/.next/server/app/api/providers/[id]/models/route_client-reference-manifest.js +1 -1
  88. package/app/.next/server/app/api/providers/[id]/route.js +1 -1
  89. package/app/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -1
  90. package/app/.next/server/app/api/providers/[id]/test/route.js +1 -1
  91. package/app/.next/server/app/api/providers/[id]/test/route_client-reference-manifest.js +1 -1
  92. package/app/.next/server/app/api/providers/client/route_client-reference-manifest.js +1 -1
  93. package/app/.next/server/app/api/providers/route.js +1 -1
  94. package/app/.next/server/app/api/providers/route_client-reference-manifest.js +1 -1
  95. package/app/.next/server/app/api/providers/validate/route.js +1 -1
  96. package/app/.next/server/app/api/providers/validate/route_client-reference-manifest.js +1 -1
  97. package/app/.next/server/app/api/settings/require-login/route.js +1 -1
  98. package/app/.next/server/app/api/settings/require-login/route_client-reference-manifest.js +1 -1
  99. package/app/.next/server/app/api/settings/route.js +1 -1
  100. package/app/.next/server/app/api/settings/route_client-reference-manifest.js +1 -1
  101. package/app/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
  102. package/app/.next/server/app/api/sync/cloud/route.js +1 -1
  103. package/app/.next/server/app/api/sync/cloud/route_client-reference-manifest.js +1 -1
  104. package/app/.next/server/app/api/sync/initialize/route_client-reference-manifest.js +1 -1
  105. package/app/.next/server/app/api/tags/route_client-reference-manifest.js +1 -1
  106. package/app/.next/server/app/api/translator/load/route_client-reference-manifest.js +1 -1
  107. package/app/.next/server/app/api/translator/save/route_client-reference-manifest.js +1 -1
  108. package/app/.next/server/app/api/translator/send/route.js +1 -1
  109. package/app/.next/server/app/api/translator/send/route.js.nft.json +1 -1
  110. package/app/.next/server/app/api/translator/send/route_client-reference-manifest.js +1 -1
  111. package/app/.next/server/app/api/translator/translate/route.js +1 -1
  112. package/app/.next/server/app/api/translator/translate/route.js.nft.json +1 -1
  113. package/app/.next/server/app/api/translator/translate/route_client-reference-manifest.js +1 -1
  114. package/app/.next/server/app/api/usage/[connectionId]/route.js +1 -1
  115. package/app/.next/server/app/api/usage/[connectionId]/route.js.nft.json +1 -1
  116. package/app/.next/server/app/api/usage/[connectionId]/route_client-reference-manifest.js +1 -1
  117. package/app/.next/server/app/api/usage/history/route.js +1 -2
  118. package/app/.next/server/app/api/usage/history/route.js.nft.json +1 -1
  119. package/app/.next/server/app/api/usage/history/route_client-reference-manifest.js +1 -1
  120. package/app/.next/server/app/api/usage/providers/route.js +45 -0
  121. package/app/.next/server/app/api/usage/providers/route.js.nft.json +1 -0
  122. package/app/.next/server/app/api/usage/providers/route_client-reference-manifest.js +1 -0
  123. package/app/.next/server/app/api/usage/request-details/route.js +1 -0
  124. package/app/.next/server/app/api/usage/request-details/route.js.nft.json +1 -0
  125. package/app/.next/server/app/api/usage/request-details/route_client-reference-manifest.js +1 -0
  126. package/app/.next/server/app/api/usage/request-logs/route.js +1 -2
  127. package/app/.next/server/app/api/usage/request-logs/route.js.nft.json +1 -1
  128. package/app/.next/server/app/api/usage/request-logs/route_client-reference-manifest.js +1 -1
  129. package/app/.next/server/app/api/v1/api/chat/route.js +1 -1
  130. package/app/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
  131. package/app/.next/server/app/api/v1/api/chat/route_client-reference-manifest.js +1 -1
  132. package/app/.next/server/app/api/v1/chat/completions/route.js +1 -1
  133. package/app/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
  134. package/app/.next/server/app/api/v1/chat/completions/route_client-reference-manifest.js +1 -1
  135. package/app/.next/server/app/api/v1/messages/count_tokens/route_client-reference-manifest.js +1 -1
  136. package/app/.next/server/app/api/v1/messages/route.js +1 -1
  137. package/app/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
  138. package/app/.next/server/app/api/v1/messages/route_client-reference-manifest.js +1 -1
  139. package/app/.next/server/app/api/v1/models/route.js +1 -1
  140. package/app/.next/server/app/api/v1/models/route_client-reference-manifest.js +1 -1
  141. package/app/.next/server/app/api/v1/responses/route.js +1 -1
  142. package/app/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
  143. package/app/.next/server/app/api/v1/responses/route_client-reference-manifest.js +1 -1
  144. package/app/.next/server/app/api/v1/route_client-reference-manifest.js +1 -1
  145. package/app/.next/server/app/api/v1beta/models/[...path]/route.js +1 -1
  146. package/app/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
  147. package/app/.next/server/app/api/v1beta/models/[...path]/route_client-reference-manifest.js +1 -1
  148. package/app/.next/server/app/api/v1beta/models/route.js +1 -1
  149. package/app/.next/server/app/api/v1beta/models/route_client-reference-manifest.js +1 -1
  150. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  151. package/app/.next/server/app/callback.html +1 -1
  152. package/app/.next/server/app/callback.rsc +3 -3
  153. package/app/.next/server/app/callback.segments/_full.segment.rsc +3 -3
  154. package/app/.next/server/app/callback.segments/_head.segment.rsc +1 -1
  155. package/app/.next/server/app/callback.segments/_index.segment.rsc +3 -3
  156. package/app/.next/server/app/callback.segments/_tree.segment.rsc +2 -2
  157. package/app/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +1 -1
  158. package/app/.next/server/app/callback.segments/callback.segment.rsc +1 -1
  159. package/app/.next/server/app/dashboard/cli-tools.html +1 -1
  160. package/app/.next/server/app/dashboard/cli-tools.rsc +5 -5
  161. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +2 -2
  162. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +1 -1
  163. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  164. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  165. package/app/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +5 -5
  166. package/app/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +1 -1
  167. package/app/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +3 -3
  168. package/app/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +2 -2
  169. package/app/.next/server/app/dashboard/combos.html +1 -1
  170. package/app/.next/server/app/dashboard/combos.rsc +5 -5
  171. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +2 -2
  172. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +1 -1
  173. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  174. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  175. package/app/.next/server/app/dashboard/combos.segments/_full.segment.rsc +5 -5
  176. package/app/.next/server/app/dashboard/combos.segments/_head.segment.rsc +1 -1
  177. package/app/.next/server/app/dashboard/combos.segments/_index.segment.rsc +3 -3
  178. package/app/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +2 -2
  179. package/app/.next/server/app/dashboard/endpoint.html +1 -1
  180. package/app/.next/server/app/dashboard/endpoint.rsc +5 -5
  181. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +2 -2
  182. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +1 -1
  183. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  184. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  185. package/app/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +5 -5
  186. package/app/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +1 -1
  187. package/app/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +3 -3
  188. package/app/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +2 -2
  189. package/app/.next/server/app/dashboard/profile.html +1 -1
  190. package/app/.next/server/app/dashboard/profile.rsc +5 -5
  191. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +2 -2
  192. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +1 -1
  193. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  194. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  195. package/app/.next/server/app/dashboard/profile.segments/_full.segment.rsc +5 -5
  196. package/app/.next/server/app/dashboard/profile.segments/_head.segment.rsc +1 -1
  197. package/app/.next/server/app/dashboard/profile.segments/_index.segment.rsc +3 -3
  198. package/app/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +2 -2
  199. package/app/.next/server/app/dashboard/providers/new.html +1 -1
  200. package/app/.next/server/app/dashboard/providers/new.rsc +5 -5
  201. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +2 -2
  202. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +1 -1
  203. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  204. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  205. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  206. package/app/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +5 -5
  207. package/app/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +1 -1
  208. package/app/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +3 -3
  209. package/app/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +2 -2
  210. package/app/.next/server/app/dashboard/providers.html +1 -1
  211. package/app/.next/server/app/dashboard/providers.rsc +5 -5
  212. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +2 -2
  213. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  214. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  215. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  216. package/app/.next/server/app/dashboard/providers.segments/_full.segment.rsc +5 -5
  217. package/app/.next/server/app/dashboard/providers.segments/_head.segment.rsc +1 -1
  218. package/app/.next/server/app/dashboard/providers.segments/_index.segment.rsc +3 -3
  219. package/app/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +2 -2
  220. package/app/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  221. package/app/.next/server/app/dashboard/settings/pricing.html +1 -1
  222. package/app/.next/server/app/dashboard/settings/pricing.rsc +3 -3
  223. package/app/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +3 -3
  224. package/app/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +1 -1
  225. package/app/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +3 -3
  226. package/app/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +2 -2
  227. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +1 -1
  228. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +1 -1
  229. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +1 -1
  230. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +1 -1
  231. package/app/.next/server/app/dashboard/translator.html +1 -1
  232. package/app/.next/server/app/dashboard/translator.rsc +5 -5
  233. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +2 -2
  234. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +1 -1
  235. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  236. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  237. package/app/.next/server/app/dashboard/translator.segments/_full.segment.rsc +5 -5
  238. package/app/.next/server/app/dashboard/translator.segments/_head.segment.rsc +1 -1
  239. package/app/.next/server/app/dashboard/translator.segments/_index.segment.rsc +3 -3
  240. package/app/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +2 -2
  241. package/app/.next/server/app/dashboard/usage.html +1 -1
  242. package/app/.next/server/app/dashboard/usage.rsc +5 -5
  243. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +2 -2
  244. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +1 -1
  245. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  246. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  247. package/app/.next/server/app/dashboard/usage.segments/_full.segment.rsc +5 -5
  248. package/app/.next/server/app/dashboard/usage.segments/_head.segment.rsc +1 -1
  249. package/app/.next/server/app/dashboard/usage.segments/_index.segment.rsc +3 -3
  250. package/app/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +2 -2
  251. package/app/.next/server/app/dashboard.html +1 -1
  252. package/app/.next/server/app/dashboard.rsc +5 -5
  253. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +2 -2
  254. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  255. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  256. package/app/.next/server/app/dashboard.segments/_full.segment.rsc +5 -5
  257. package/app/.next/server/app/dashboard.segments/_head.segment.rsc +1 -1
  258. package/app/.next/server/app/dashboard.segments/_index.segment.rsc +3 -3
  259. package/app/.next/server/app/dashboard.segments/_tree.segment.rsc +2 -2
  260. package/app/.next/server/app/index.html +1 -1
  261. package/app/.next/server/app/index.rsc +3 -3
  262. package/app/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  263. package/app/.next/server/app/index.segments/_full.segment.rsc +3 -3
  264. package/app/.next/server/app/index.segments/_head.segment.rsc +1 -1
  265. package/app/.next/server/app/index.segments/_index.segment.rsc +3 -3
  266. package/app/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  267. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  268. package/app/.next/server/app/landing.html +1 -1
  269. package/app/.next/server/app/landing.rsc +3 -3
  270. package/app/.next/server/app/landing.segments/_full.segment.rsc +3 -3
  271. package/app/.next/server/app/landing.segments/_head.segment.rsc +1 -1
  272. package/app/.next/server/app/landing.segments/_index.segment.rsc +3 -3
  273. package/app/.next/server/app/landing.segments/_tree.segment.rsc +2 -2
  274. package/app/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +1 -1
  275. package/app/.next/server/app/landing.segments/landing.segment.rsc +1 -1
  276. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  277. package/app/.next/server/app/login.html +1 -1
  278. package/app/.next/server/app/login.rsc +4 -4
  279. package/app/.next/server/app/login.segments/_full.segment.rsc +4 -4
  280. package/app/.next/server/app/login.segments/_head.segment.rsc +1 -1
  281. package/app/.next/server/app/login.segments/_index.segment.rsc +3 -3
  282. package/app/.next/server/app/login.segments/_tree.segment.rsc +2 -2
  283. package/app/.next/server/app/login.segments/login/__PAGE__.segment.rsc +2 -2
  284. package/app/.next/server/app/login.segments/login.segment.rsc +1 -1
  285. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  286. package/app/.next/server/app-paths-manifest.json +42 -40
  287. package/app/.next/server/chunks/3110.js +2 -2
  288. package/app/.next/server/chunks/3990.js +41 -0
  289. package/app/.next/server/chunks/412.js +4 -4
  290. package/app/.next/server/chunks/5330.js +2 -3
  291. package/app/.next/server/chunks/7647.js +1 -0
  292. package/app/.next/server/chunks/8152.js +1 -1
  293. package/app/.next/server/chunks/8954.js +1 -1
  294. package/app/.next/server/chunks/9718.js +1 -1
  295. package/app/.next/server/chunks/9862.js +1 -1
  296. package/app/.next/server/pages/404.html +1 -1
  297. package/app/.next/server/pages/500.html +2 -2
  298. package/app/.next/server/server-reference-manifest.js +1 -1
  299. package/app/.next/server/server-reference-manifest.json +1 -1
  300. package/app/.next/static/chunks/1393-ec22348a03d98802.js +1 -0
  301. package/app/.next/static/chunks/8729-30cb66f318ac2d23.js +1 -0
  302. package/app/.next/static/chunks/app/(dashboard)/dashboard/profile/page-738071ba2546b274.js +1 -0
  303. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-d48c3e28182c53fd.js +1 -0
  304. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/page-874d3494c011eaf2.js +1 -0
  305. package/app/.next/static/chunks/app/_global-error/page-1968aadfb379c0a3.js +1 -0
  306. package/app/.next/static/chunks/app/api/auth/login/route-1968aadfb379c0a3.js +1 -0
  307. package/app/.next/static/chunks/app/api/auth/logout/route-1968aadfb379c0a3.js +1 -0
  308. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-1968aadfb379c0a3.js +1 -0
  309. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-1968aadfb379c0a3.js +1 -0
  310. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-1968aadfb379c0a3.js +1 -0
  311. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-1968aadfb379c0a3.js +1 -0
  312. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-1968aadfb379c0a3.js +1 -0
  313. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-1968aadfb379c0a3.js +1 -0
  314. package/app/.next/static/chunks/app/api/cloud/auth/route-1968aadfb379c0a3.js +1 -0
  315. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-1968aadfb379c0a3.js +1 -0
  316. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-1968aadfb379c0a3.js +1 -0
  317. package/app/.next/static/chunks/app/api/cloud/models/alias/route-1968aadfb379c0a3.js +1 -0
  318. package/app/.next/static/chunks/app/api/combos/[id]/route-1968aadfb379c0a3.js +1 -0
  319. package/app/.next/static/chunks/app/api/combos/route-1968aadfb379c0a3.js +1 -0
  320. package/app/.next/static/chunks/app/api/init/route-1968aadfb379c0a3.js +1 -0
  321. package/app/.next/static/chunks/app/api/keys/[id]/route-1968aadfb379c0a3.js +1 -0
  322. package/app/.next/static/chunks/app/api/keys/route-1968aadfb379c0a3.js +1 -0
  323. package/app/.next/static/chunks/app/api/models/alias/route-1968aadfb379c0a3.js +1 -0
  324. package/app/.next/static/chunks/app/api/models/route-1968aadfb379c0a3.js +1 -0
  325. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-1968aadfb379c0a3.js +1 -0
  326. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-1968aadfb379c0a3.js +1 -0
  327. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-1968aadfb379c0a3.js +1 -0
  328. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-1968aadfb379c0a3.js +1 -0
  329. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-1968aadfb379c0a3.js +1 -0
  330. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-1968aadfb379c0a3.js +1 -0
  331. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-1968aadfb379c0a3.js +1 -0
  332. package/app/.next/static/chunks/app/api/pricing/route-1968aadfb379c0a3.js +1 -0
  333. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-1968aadfb379c0a3.js +1 -0
  334. package/app/.next/static/chunks/app/api/provider-nodes/route-1968aadfb379c0a3.js +1 -0
  335. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-1968aadfb379c0a3.js +1 -0
  336. package/app/.next/static/chunks/app/api/providers/[id]/models/route-1968aadfb379c0a3.js +1 -0
  337. package/app/.next/static/chunks/app/api/providers/[id]/route-1968aadfb379c0a3.js +1 -0
  338. package/app/.next/static/chunks/app/api/providers/[id]/test/route-1968aadfb379c0a3.js +1 -0
  339. package/app/.next/static/chunks/app/api/providers/client/route-1968aadfb379c0a3.js +1 -0
  340. package/app/.next/static/chunks/app/api/providers/route-1968aadfb379c0a3.js +1 -0
  341. package/app/.next/static/chunks/app/api/providers/validate/route-1968aadfb379c0a3.js +1 -0
  342. package/app/.next/static/chunks/app/api/settings/require-login/route-1968aadfb379c0a3.js +1 -0
  343. package/app/.next/static/chunks/app/api/settings/route-1968aadfb379c0a3.js +1 -0
  344. package/app/.next/static/chunks/app/api/shutdown/route-1968aadfb379c0a3.js +1 -0
  345. package/app/.next/static/chunks/app/api/sync/cloud/route-1968aadfb379c0a3.js +1 -0
  346. package/app/.next/static/chunks/app/api/sync/initialize/route-1968aadfb379c0a3.js +1 -0
  347. package/app/.next/static/chunks/app/api/tags/route-1968aadfb379c0a3.js +1 -0
  348. package/app/.next/static/chunks/app/api/translator/load/route-1968aadfb379c0a3.js +1 -0
  349. package/app/.next/static/chunks/app/api/translator/save/route-1968aadfb379c0a3.js +1 -0
  350. package/app/.next/static/chunks/app/api/translator/send/route-1968aadfb379c0a3.js +1 -0
  351. package/app/.next/static/chunks/app/api/translator/translate/route-1968aadfb379c0a3.js +1 -0
  352. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-1968aadfb379c0a3.js +1 -0
  353. package/app/.next/static/chunks/app/api/usage/history/route-1968aadfb379c0a3.js +1 -0
  354. package/app/.next/static/chunks/app/api/usage/providers/route-1968aadfb379c0a3.js +1 -0
  355. package/app/.next/static/chunks/app/api/usage/request-details/route-1968aadfb379c0a3.js +1 -0
  356. package/app/.next/static/chunks/app/api/usage/request-logs/route-1968aadfb379c0a3.js +1 -0
  357. package/app/.next/static/chunks/app/api/v1/api/chat/route-1968aadfb379c0a3.js +1 -0
  358. package/app/.next/static/chunks/app/api/v1/chat/completions/route-1968aadfb379c0a3.js +1 -0
  359. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-1968aadfb379c0a3.js +1 -0
  360. package/app/.next/static/chunks/app/api/v1/messages/route-1968aadfb379c0a3.js +1 -0
  361. package/app/.next/static/chunks/app/api/v1/models/route-1968aadfb379c0a3.js +1 -0
  362. package/app/.next/static/chunks/app/api/v1/responses/route-1968aadfb379c0a3.js +1 -0
  363. package/app/.next/static/chunks/app/api/v1/route-1968aadfb379c0a3.js +1 -0
  364. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-1968aadfb379c0a3.js +1 -0
  365. package/app/.next/static/chunks/app/api/v1beta/models/route-1968aadfb379c0a3.js +1 -0
  366. package/app/.next/static/chunks/app/page-1968aadfb379c0a3.js +1 -0
  367. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-1968aadfb379c0a3.js +1 -0
  368. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-1968aadfb379c0a3.js +1 -0
  369. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-1968aadfb379c0a3.js +1 -0
  370. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-1968aadfb379c0a3.js +1 -0
  371. package/app/.next/static/css/e4a2c774b676c378.css +3 -0
  372. package/app/.next/static/jnuJ7xmQaeiHg9oUUDqGs/_buildManifest.js +1 -0
  373. package/app/package.json +1 -1
  374. package/app/public/providers/glm-cn.png +0 -0
  375. package/app/src/mitm/cert/generate.js +44 -0
  376. package/app/src/mitm/cert/install.js +136 -0
  377. package/app/src/mitm/dns/dnsConfig.js +130 -0
  378. package/app/src/mitm/manager.js +227 -0
  379. package/cli.js +110 -144
  380. package/package.json +1 -1
  381. package/src/cli/utils/input.js +7 -1
  382. package/src/cli/utils/menuHelper.js +2 -1
  383. package/app/.next/server/chunks/9707.js +0 -1
  384. package/app/.next/static/FcGNHUA9390qBi1g02a_v/_buildManifest.js +0 -1
  385. package/app/.next/static/chunks/1393-3fdad0258c0b525c.js +0 -1
  386. package/app/.next/static/chunks/8729-9d273189141eb6fb.js +0 -1
  387. package/app/.next/static/chunks/app/(dashboard)/dashboard/profile/page-b61f704bc7de9783.js +0 -1
  388. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-e8509c35110f8541.js +0 -1
  389. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/page-15eac98ba6db9df4.js +0 -1
  390. package/app/.next/static/chunks/app/_global-error/page-901ec69b71429e39.js +0 -1
  391. package/app/.next/static/chunks/app/api/auth/login/route-901ec69b71429e39.js +0 -1
  392. package/app/.next/static/chunks/app/api/auth/logout/route-901ec69b71429e39.js +0 -1
  393. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-901ec69b71429e39.js +0 -1
  394. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-901ec69b71429e39.js +0 -1
  395. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-901ec69b71429e39.js +0 -1
  396. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-901ec69b71429e39.js +0 -1
  397. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-901ec69b71429e39.js +0 -1
  398. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-901ec69b71429e39.js +0 -1
  399. package/app/.next/static/chunks/app/api/cloud/auth/route-901ec69b71429e39.js +0 -1
  400. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-901ec69b71429e39.js +0 -1
  401. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-901ec69b71429e39.js +0 -1
  402. package/app/.next/static/chunks/app/api/cloud/models/alias/route-901ec69b71429e39.js +0 -1
  403. package/app/.next/static/chunks/app/api/combos/[id]/route-901ec69b71429e39.js +0 -1
  404. package/app/.next/static/chunks/app/api/combos/route-901ec69b71429e39.js +0 -1
  405. package/app/.next/static/chunks/app/api/init/route-901ec69b71429e39.js +0 -1
  406. package/app/.next/static/chunks/app/api/keys/[id]/route-901ec69b71429e39.js +0 -1
  407. package/app/.next/static/chunks/app/api/keys/route-901ec69b71429e39.js +0 -1
  408. package/app/.next/static/chunks/app/api/models/alias/route-901ec69b71429e39.js +0 -1
  409. package/app/.next/static/chunks/app/api/models/route-901ec69b71429e39.js +0 -1
  410. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-901ec69b71429e39.js +0 -1
  411. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-901ec69b71429e39.js +0 -1
  412. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-901ec69b71429e39.js +0 -1
  413. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-901ec69b71429e39.js +0 -1
  414. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-901ec69b71429e39.js +0 -1
  415. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-901ec69b71429e39.js +0 -1
  416. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-901ec69b71429e39.js +0 -1
  417. package/app/.next/static/chunks/app/api/pricing/route-901ec69b71429e39.js +0 -1
  418. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-901ec69b71429e39.js +0 -1
  419. package/app/.next/static/chunks/app/api/provider-nodes/route-901ec69b71429e39.js +0 -1
  420. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-901ec69b71429e39.js +0 -1
  421. package/app/.next/static/chunks/app/api/providers/[id]/models/route-901ec69b71429e39.js +0 -1
  422. package/app/.next/static/chunks/app/api/providers/[id]/route-901ec69b71429e39.js +0 -1
  423. package/app/.next/static/chunks/app/api/providers/[id]/test/route-901ec69b71429e39.js +0 -1
  424. package/app/.next/static/chunks/app/api/providers/client/route-901ec69b71429e39.js +0 -1
  425. package/app/.next/static/chunks/app/api/providers/route-901ec69b71429e39.js +0 -1
  426. package/app/.next/static/chunks/app/api/providers/validate/route-901ec69b71429e39.js +0 -1
  427. package/app/.next/static/chunks/app/api/settings/require-login/route-901ec69b71429e39.js +0 -1
  428. package/app/.next/static/chunks/app/api/settings/route-901ec69b71429e39.js +0 -1
  429. package/app/.next/static/chunks/app/api/shutdown/route-901ec69b71429e39.js +0 -1
  430. package/app/.next/static/chunks/app/api/sync/cloud/route-901ec69b71429e39.js +0 -1
  431. package/app/.next/static/chunks/app/api/sync/initialize/route-901ec69b71429e39.js +0 -1
  432. package/app/.next/static/chunks/app/api/tags/route-901ec69b71429e39.js +0 -1
  433. package/app/.next/static/chunks/app/api/translator/load/route-901ec69b71429e39.js +0 -1
  434. package/app/.next/static/chunks/app/api/translator/save/route-901ec69b71429e39.js +0 -1
  435. package/app/.next/static/chunks/app/api/translator/send/route-901ec69b71429e39.js +0 -1
  436. package/app/.next/static/chunks/app/api/translator/translate/route-901ec69b71429e39.js +0 -1
  437. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-901ec69b71429e39.js +0 -1
  438. package/app/.next/static/chunks/app/api/usage/history/route-901ec69b71429e39.js +0 -1
  439. package/app/.next/static/chunks/app/api/usage/request-logs/route-901ec69b71429e39.js +0 -1
  440. package/app/.next/static/chunks/app/api/v1/api/chat/route-901ec69b71429e39.js +0 -1
  441. package/app/.next/static/chunks/app/api/v1/chat/completions/route-901ec69b71429e39.js +0 -1
  442. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-901ec69b71429e39.js +0 -1
  443. package/app/.next/static/chunks/app/api/v1/messages/route-901ec69b71429e39.js +0 -1
  444. package/app/.next/static/chunks/app/api/v1/models/route-901ec69b71429e39.js +0 -1
  445. package/app/.next/static/chunks/app/api/v1/responses/route-901ec69b71429e39.js +0 -1
  446. package/app/.next/static/chunks/app/api/v1/route-901ec69b71429e39.js +0 -1
  447. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-901ec69b71429e39.js +0 -1
  448. package/app/.next/static/chunks/app/api/v1beta/models/route-901ec69b71429e39.js +0 -1
  449. package/app/.next/static/chunks/app/page-901ec69b71429e39.js +0 -1
  450. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-901ec69b71429e39.js +0 -1
  451. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-901ec69b71429e39.js +0 -1
  452. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-901ec69b71429e39.js +0 -1
  453. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-901ec69b71429e39.js +0 -1
  454. package/app/.next/static/css/69b23ffd995e0cf4.css +0 -3
  455. /package/app/.next/static/{FcGNHUA9390qBi1g02a_v → jnuJ7xmQaeiHg9oUUDqGs}/_ssgManifest.js +0 -0
package/cli.js CHANGED
@@ -257,170 +257,117 @@ function isRestrictedEnvironment() {
257
257
  return null;
258
258
  }
259
259
 
260
- // Check and force update if new version available
261
- function checkAndUpdate() {
260
+ // Check if new version available, return latest version or null
261
+ function checkForUpdate() {
262
262
  return new Promise((resolve) => {
263
263
  if (skipUpdate) {
264
- resolve(false);
264
+ resolve(null);
265
265
  return;
266
266
  }
267
267
 
268
268
  const spinner = createSpinner("Checking for updates...").start();
269
269
  let resolved = false;
270
270
 
271
- // Safety timeout: always resolve after 8 seconds to prevent hanging
272
271
  const safetyTimeout = setTimeout(() => {
273
272
  if (!resolved) {
274
273
  resolved = true;
275
274
  spinner.stop();
276
- resolve(false);
275
+ resolve(null);
277
276
  }
278
277
  }, 8000);
279
278
 
279
+ const done = (version) => {
280
+ if (resolved) return;
281
+ resolved = true;
282
+ clearTimeout(safetyTimeout);
283
+ spinner.stop();
284
+ resolve(version);
285
+ };
286
+
280
287
  const req = https.get(`https://registry.npmjs.org/${pkg.name}/latest`, { timeout: 3000 }, (res) => {
281
288
  let data = "";
282
-
283
289
  res.on("data", chunk => data += chunk);
284
-
285
290
  res.on("end", () => {
286
- if (resolved) return;
287
-
288
291
  try {
289
292
  const latest = JSON.parse(data);
290
293
  if (latest.version && compareVersions(latest.version, pkg.version) > 0) {
291
- resolved = true;
292
- clearTimeout(safetyTimeout);
293
- spinner.succeed(`New version available: ${pkg.version} → ${latest.version}`);
294
-
295
- // Check if running in restricted environment
296
- const restrictedEnv = isRestrictedEnvironment();
297
- if (restrictedEnv) {
298
- console.log(` Run: npm install -g ${pkg.name}@latest\n`);
299
- resolve(false);
300
- return;
301
- }
302
-
303
- console.log(`🔄 Auto-updating...\n`);
304
-
305
- try {
306
- const platform = process.platform;
307
- const newArgs = args.filter(a => a !== "--skip-update");
308
- const argsStr = newArgs.join(" ");
309
-
310
- let updateScript, scriptPath, shellCmd;
311
-
312
- if (platform === "win32") {
313
- // Windows: use CMD batch script
314
- updateScript = `@echo off
315
- echo .
316
- echo 📥 Downloading update...
317
- echo ✅ Waiting for process to exit...
318
- timeout /t 2 /nobreak >nul
319
-
320
- echo ✅ Installing new version...
294
+ done(latest.version);
295
+ } else {
296
+ done(null);
297
+ }
298
+ } catch (e) {
299
+ done(null);
300
+ }
301
+ });
302
+ });
303
+
304
+ req.on("error", () => done(null));
305
+ req.on("timeout", () => { req.destroy(); done(null); });
306
+ });
307
+ }
308
+
309
+ // Run update and exit (user must restart manually)
310
+ function performUpdate() {
311
+ console.log(`\n🔄 Updating ${pkg.name}...\n`);
312
+
313
+ try {
314
+ const platform = process.platform;
315
+ let updateScript, scriptPath, shellCmd;
316
+
317
+ if (platform === "win32") {
318
+ updateScript = `@echo off
319
+ echo 📥 Installing new version...
321
320
  call npm cache clean --force >nul 2>&1
322
321
  call npm install -g ${pkg.name}@latest --prefer-online
323
322
 
324
323
  if %ERRORLEVEL% EQU 0 (
325
- echo ✅ Update completed successfully
326
- echo ✅ Restarting with new version...
327
- ${pkg.name} ${argsStr} --skip-update
324
+ echo.
325
+ echo ✅ Update completed. Run "${pkg.name}" to start.
328
326
  ) else (
329
- echo ❌ Update failed
330
- echo 💡 Try manually: npm install -g ${pkg.name}
331
- echo ✅ Starting with current version...
332
- ${pkg.name} ${argsStr} --skip-update
327
+ echo.
328
+ echo Update failed. Try manually: npm install -g ${pkg.name}@latest
333
329
  )
330
+ pause
334
331
  `;
335
- scriptPath = path.join(os.tmpdir(), `${APP_NAME}-update.bat`);
336
- fs.writeFileSync(scriptPath, updateScript);
337
- shellCmd = ["cmd.exe", ["/c", scriptPath]];
338
- } else {
339
- // macOS/Linux: use bash script
340
- updateScript = `#!/bin/bash
341
- echo "✅ Downloading update..."
342
- echo "✅ Waiting for process to exit..."
332
+ scriptPath = path.join(os.tmpdir(), `${APP_NAME}-update.bat`);
333
+ fs.writeFileSync(scriptPath, updateScript);
334
+ shellCmd = ["cmd.exe", ["/c", scriptPath]];
335
+ } else {
336
+ updateScript = `#!/bin/bash
337
+ echo "📥 Installing new version..."
343
338
  sleep 1
344
339
 
345
340
  pkill -f "${pkg.name}" 2>/dev/null || true
346
341
  sleep 1
347
342
 
348
- echo "✅ Installing new version..."
349
343
  npm cache clean --force 2>/dev/null
350
-
351
- # Try to install with full output for debugging
352
344
  npm install -g ${pkg.name}@latest --prefer-online 2>&1
353
345
  EXIT_CODE=$?
354
346
 
355
347
  if [ $EXIT_CODE -eq 0 ]; then
356
- echo "✅ Update completed successfully"
357
- echo "✅ Restarting with new version..."
358
- ${pkg.name} ${argsStr} --skip-update
348
+ echo ""
349
+ echo "✅ Update completed. Run \\"${pkg.name}\\" to start."
359
350
  else
351
+ echo ""
360
352
  echo "❌ Update failed (exit code: $EXIT_CODE)"
361
- echo "💡 Update manually: npm install -g ${pkg.name}@latest"
362
- echo "✅ Starting with current version..."
363
- ${pkg.name} ${argsStr} --skip-update
353
+ echo "💡 Try manually: npm install -g ${pkg.name}@latest"
364
354
  fi
365
355
  `;
366
- scriptPath = path.join(os.tmpdir(), `${APP_NAME}-update.sh`);
367
- fs.writeFileSync(scriptPath, updateScript, { mode: 0o755 });
368
- shellCmd = ["sh", [scriptPath]];
369
- }
370
-
371
- // Execute update script in background and exit immediately
372
- const child = spawn(shellCmd[0], shellCmd[1], {
373
- detached: true,
374
- stdio: "inherit"
375
- });
376
- child.unref();
377
-
378
- process.exit(0);
379
- } catch (updateErr) {
380
- if (!resolved) {
381
- resolved = true;
382
- clearTimeout(safetyTimeout);
383
- console.error(`⚠️ Auto-update failed: ${updateErr.message}`);
384
- console.log(` Run manually: npm install -g ${pkg.name}\n`);
385
- resolve(false);
386
- }
387
- }
388
- } else {
389
- resolved = true;
390
- clearTimeout(safetyTimeout);
391
- spinner.stop();
392
- resolve(false);
393
- }
394
- } catch (e) {
395
- if (!resolved) {
396
- resolved = true;
397
- clearTimeout(safetyTimeout);
398
- spinner.stop();
399
- resolve(false);
400
- }
401
- }
402
- });
403
- });
404
-
405
- req.on("error", () => {
406
- if (!resolved) {
407
- resolved = true;
408
- clearTimeout(safetyTimeout);
409
- spinner.stop();
410
- resolve(false);
411
- }
412
- });
413
-
414
- req.on("timeout", () => {
415
- if (!resolved) {
416
- resolved = true;
417
- clearTimeout(safetyTimeout);
418
- req.destroy();
419
- spinner.stop();
420
- resolve(false);
421
- }
356
+ scriptPath = path.join(os.tmpdir(), `${APP_NAME}-update.sh`);
357
+ fs.writeFileSync(scriptPath, updateScript, { mode: 0o755 });
358
+ shellCmd = ["sh", [scriptPath]];
359
+ }
360
+
361
+ const child = spawn(shellCmd[0], shellCmd[1], {
362
+ detached: true,
363
+ stdio: "inherit"
422
364
  });
423
- });
365
+ child.unref();
366
+ process.exit(0);
367
+ } catch (err) {
368
+ console.error(`⚠️ Update failed: ${err.message}`);
369
+ console.log(` Run manually: npm install -g ${pkg.name}@latest\n`);
370
+ }
424
371
  }
425
372
 
426
373
  // Open browser
@@ -453,46 +400,61 @@ if (!fs.existsSync(serverPath)) {
453
400
  process.exit(1);
454
401
  }
455
402
 
456
- // Check for updates FIRST, then start server if no update needed
457
- checkAndUpdate().then((hasUpdate) => {
458
- if (!hasUpdate) {
459
- // Kill all old app processes first, then kill anything on target port
460
- killAllAppProcesses().then(() => {
461
- return killProcessOnPort(port);
462
- }).then(() => {
463
- startServer();
464
- });
465
- }
466
- // If hasUpdate=true, process already exited in checkAndUpdate()
403
+ // Check for updates FIRST, then start server
404
+ checkForUpdate().then((latestVersion) => {
405
+ killAllAppProcesses().then(() => {
406
+ return killProcessOnPort(port);
407
+ }).then(() => {
408
+ startServer(latestVersion);
409
+ });
467
410
  });
468
411
 
469
412
  // Show interface selection menu
470
- async function showInterfaceMenu() {
413
+ async function showInterfaceMenu(latestVersion) {
471
414
  const { selectMenu } = require("./src/cli/utils/input");
472
415
  const { clearScreen } = require("./src/cli/utils/display");
416
+ const { getEndpoint, CLOUD_URL } = require("./src/cli/utils/endpoint");
473
417
 
474
418
  clearScreen();
475
419
 
476
420
  const displayHost = host === DEFAULT_HOST ? "localhost" : host;
477
- console.log(`\n🚀 ${pkg.name} v${pkg.version}`);
478
- console.log(`Server: http://${displayHost}:${port}\n`);
479
421
 
480
- const menuItems = [
422
+ // Detect cloud mode for server URL display
423
+ let serverUrl;
424
+ try {
425
+ const { cloudEnabled } = await getEndpoint(port);
426
+ serverUrl = cloudEnabled ? CLOUD_URL : `http://${displayHost}:${port}`;
427
+ } catch (e) {
428
+ serverUrl = `http://${displayHost}:${port}`;
429
+ }
430
+
431
+ const subtitle = `🚀 Server: \x1b[32m${serverUrl}\x1b[0m`;
432
+
433
+ const menuItems = [];
434
+
435
+ if (latestVersion) {
436
+ menuItems.push({ label: `Update to v${latestVersion} (current: v${pkg.version})`, icon: "⬆" });
437
+ }
438
+
439
+ menuItems.push(
481
440
  { label: "Web UI (Open in Browser)", icon: "🌐" },
482
441
  { label: "Terminal UI (Interactive CLI)", icon: "💻" },
483
442
  { label: "Hide to Tray (Background)", icon: "🔔" },
484
443
  { label: "Exit", icon: "🚪" }
485
- ];
444
+ );
445
+
446
+ const selected = await selectMenu(`Choose Interface (v${pkg.version})`, menuItems, 0, subtitle);
486
447
 
487
- const selected = await selectMenu(`Choose Interface (v${pkg.version})`, menuItems);
448
+ const offset = latestVersion ? 1 : 0;
488
449
 
489
- if (selected === 0) return "web";
490
- if (selected === 1) return "terminal";
491
- if (selected === 2) return "hide";
492
- return "exit"; // -1 or 3
450
+ if (latestVersion && selected === 0) return "update";
451
+ if (selected === offset) return "web";
452
+ if (selected === offset + 1) return "terminal";
453
+ if (selected === offset + 2) return "hide";
454
+ return "exit";
493
455
  }
494
456
 
495
- function startServer() {
457
+ function startServer(latestVersion) {
496
458
  const displayHost = host === DEFAULT_HOST ? "localhost" : host;
497
459
  const url = `http://${displayHost}:${port}/dashboard`;
498
460
 
@@ -595,9 +557,13 @@ function startServer() {
595
557
 
596
558
  try {
597
559
  while (true) {
598
- const choice = await showInterfaceMenu();
560
+ const choice = await showInterfaceMenu(latestVersion);
599
561
 
600
- if (choice === "web") {
562
+ if (choice === "update") {
563
+ cleanup();
564
+ performUpdate();
565
+ return;
566
+ } else if (choice === "web") {
601
567
  openBrowser(url);
602
568
  // Wait for user to come back
603
569
  const { pause } = require("./src/cli/utils/input");
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "9router",
3
- "version": "0.2.71",
3
+ "version": "0.2.73",
4
4
  "description": "9Router CLI - Start and manage 9Router server",
5
5
  "bin": {
6
6
  "9router": "./cli.js"
@@ -111,7 +111,7 @@ async function pause(message = "Press Enter to continue...") {
111
111
  * @param {Array<string>} breadcrumb - Optional breadcrumb path
112
112
  * @returns {Promise<number>} Selected index, or -1 if ESC pressed
113
113
  */
114
- async function selectMenu(title, items, defaultIndex = 0, headerContent = "", breadcrumb = []) {
114
+ async function selectMenu(title, items, defaultIndex = 0, subtitle = "", headerContent = "", breadcrumb = []) {
115
115
  return new Promise((resolve) => {
116
116
  let selectedIndex = defaultIndex;
117
117
  let isActive = true;
@@ -140,6 +140,12 @@ async function selectMenu(title, items, defaultIndex = 0, headerContent = "", br
140
140
  const width = Math.min(process.stdout.columns || 40, 40);
141
141
  console.log(`\n${COLORS.terracotta}${"=".repeat(width)}${COLORS.reset}`);
142
142
  console.log(` ${COLORS.bright}${COLORS.terracotta}${title}${COLORS.reset}`);
143
+
144
+ // Show subtitle inside the frame
145
+ if (subtitle) {
146
+ console.log(` ${COLORS.dim}${subtitle}${COLORS.reset}`);
147
+ }
148
+
143
149
  console.log(`${COLORS.terracotta}${"=".repeat(width)}${COLORS.reset}`);
144
150
 
145
151
  // Show breadcrumb if provided
@@ -52,6 +52,7 @@ async function showMenuWithBack(config) {
52
52
  title,
53
53
  menuItems,
54
54
  defaultIndex,
55
+ "",
55
56
  resolvedHeader,
56
57
  breadcrumb
57
58
  );
@@ -126,7 +127,7 @@ async function showListMenu(config) {
126
127
  ? await headerContent(metadata)
127
128
  : headerContent;
128
129
 
129
- const selected = await selectMenu(title, menuItems, 0, header, breadcrumb);
130
+ const selected = await selectMenu(title, menuItems, 0, "", header, breadcrumb);
130
131
 
131
132
  // Back or ESC
132
133
  if (selected === -1 || selected === 0) {
@@ -1 +0,0 @@
1
- exports.id=9707,exports.ids=[9707],exports.modules={2255:(a,b,c)=>{"use strict";c.d(b,{$V:()=>f,Bm:()=>n,C8:()=>o,Co:()=>e,EQ:()=>m,LY:()=>k,NA:()=>g,O:()=>l,Uc:()=>h,eo:()=>i,gx:()=>j,xq:()=>d});let d={claude:{baseUrl:"https://api.anthropic.com/v1/messages",format:"claude",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14,fine-grained-tool-streaming-2025-05-14,context-management-2025-06-27","Anthropic-Dangerous-Direct-Browser-Access":"true","User-Agent":"claude-cli/1.0.83 (external, cli)","X-App":"cli","X-Stainless-Helper-Method":"stream","X-Stainless-Retry-Count":"0","X-Stainless-Runtime-Version":"v24.3.0","X-Stainless-Package-Version":"0.55.1","X-Stainless-Runtime":"node","X-Stainless-Lang":"js","X-Stainless-Arch":"arm64","X-Stainless-Os":"MacOS","X-Stainless-Timeout":"60"},clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",tokenUrl:"https://console.anthropic.com/v1/oauth/token"},gemini:{baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",format:"gemini",clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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"},"gemini-cli":{baseUrl:"https://cloudcode-pa.googleapis.com/v1internal",format:"gemini-cli",clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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"},codex:{baseUrl:"https://chatgpt.com/backend-api/codex/responses",format:"openai-responses",headers:{Version:"0.92.0","Openai-Beta":"responses=experimental","User-Agent":"codex-cli/0.92.0 (Windows 10.0.26100; x64)"},clientId:"app_EMoamEEZ73f0CkXaXp7hrann",clientSecret:"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",tokenUrl:"https://auth.openai.com/oauth/token"},qwen:{baseUrl:"https://portal.qwen.ai/v1/chat/completions",format:"openai",headers:{"User-Agent":"google-api-nodejs-client/9.15.1","X-Goog-Api-Client":"gl-node/22.17.0"},clientId:"f0304373b74a44d2b584a3fb70ca9e56",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",authUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code"},iflow:{baseUrl:"https://apis.iflow.cn/v1/chat/completions",format:"openai",headers:{"User-Agent":"iFlow-Cli"},clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://iflow.cn/oauth/token",authUrl:"https://iflow.cn/oauth"},antigravity:{baseUrls:["https://daily-cloudcode-pa.googleapis.com","https://cloudcode-pa.googleapis.com"],format:"antigravity",headers:{"User-Agent":"antigravity/1.104.0 darwin/arm64"},clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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"},openrouter:{baseUrl:"https://openrouter.ai/api/v1/chat/completions",format:"openai",headers:{"HTTP-Referer":"https://endpoint-proxy.local","X-Title":"Endpoint Proxy"}},openai:{baseUrl:"https://api.openai.com/v1/chat/completions",format:"openai"},glm:{baseUrl:"https://api.z.ai/api/anthropic/v1/messages",format:"claude",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"}},kimi:{baseUrl:"https://api.kimi.com/coding/v1/messages",format:"claude",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"}},minimax:{baseUrl:"https://api.minimax.io/anthropic/v1/messages",format:"claude",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"}},"minimax-cn":{baseUrl:"https://api.minimaxi.com/anthropic/v1/messages",format:"claude",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"}},github:{baseUrl:"https://api.githubcopilot.com/chat/completions",format:"openai",headers:{"copilot-integration-id":"vscode-chat","editor-version":"vscode/1.107.1","editor-plugin-version":"copilot-chat/0.26.7","user-agent":"GitHubCopilotChat/0.26.7","openai-intent":"conversation-panel","x-github-api-version":"2025-04-01","x-vscode-user-agent-library-version":"electron-fetch","X-Initiator":"user",Accept:"application/json","Content-Type":"application/json"}},kiro:{baseUrl:"https://codewhisperer.us-east-1.amazonaws.com/generateAssistantResponse",format:"kiro",headers:{"Content-Type":"application/json",Accept:"application/vnd.amazon.eventstream","X-Amz-Target":"AmazonCodeWhispererStreamingService.GenerateAssistantResponse","User-Agent":"AWS-SDK-JS/3.0.0 kiro-ide/1.0.0","X-Amz-User-Agent":"aws-sdk-js/3.0.0 kiro-ide/1.0.0"},tokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authUrl:"https://prod.us-east-1.auth.desktop.kiro.dev"},cursor:{baseUrl:"https://api2.cursor.sh",chatPath:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",format:"cursor",headers:{"connect-accept-encoding":"gzip","connect-protocol-version":"1","Content-Type":"application/connect+proto","User-Agent":"connect-es/1.6.1"},clientVersion:"1.1.3"}},e="You are Claude Code, Anthropic's official CLI for Claude.",f="Please ignore the following [ignore]You are Antigravity, a powerful agentic AI coding assistant designed by the Google Deepmind team working on Advanced Agentic Coding.You are pair programming with a USER to solve their coding task. The task may require creating a new codebase, modifying or debugging an existing codebase, or simply answering a question.**Absolute paths only****Proactiveness**[/ignore]",g={google:{token:"https://oauth2.googleapis.com/token",auth:"https://accounts.google.com/o/oauth2/auth"},openai:{token:"https://auth.openai.com/oauth/token",auth:"https://auth.openai.com/oauth/authorize"},anthropic:{token:"https://console.anthropic.com/v1/oauth/token",auth:"https://console.anthropic.com/v1/oauth/authorize"},qwen:{token:"https://chat.qwen.ai/api/v1/oauth2/token",auth:"https://chat.qwen.ai/api/v1/oauth2/device/code"},iflow:{token:"https://iflow.cn/oauth/token",auth:"https://iflow.cn/oauth"},github:{token:"https://github.com/login/oauth/access_token",auth:"https://github.com/login/oauth/authorize",deviceCode:"https://github.com/login/device/code"}},h=64e3,i=32e3,j={BAD_REQUEST:400,UNAUTHORIZED:401,PAYMENT_REQUIRED:402,FORBIDDEN:403,NOT_FOUND:404,NOT_ACCEPTABLE:406,REQUEST_TIMEOUT:408,RATE_LIMITED:429,SERVER_ERROR:500,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504},k={[j.BAD_REQUEST]:{type:"invalid_request_error",code:"bad_request"},[j.UNAUTHORIZED]:{type:"authentication_error",code:"invalid_api_key"},[j.FORBIDDEN]:{type:"permission_error",code:"insufficient_quota"},[j.NOT_FOUND]:{type:"invalid_request_error",code:"model_not_found"},[j.RATE_LIMITED]:{type:"rate_limit_error",code:"rate_limit_exceeded"},[j.SERVER_ERROR]:{type:"server_error",code:"internal_server_error"},[j.BAD_GATEWAY]:{type:"server_error",code:"bad_gateway"},[j.SERVICE_UNAVAILABLE]:{type:"server_error",code:"service_unavailable"},[j.GATEWAY_TIMEOUT]:{type:"server_error",code:"gateway_timeout"}},l={[j.BAD_REQUEST]:"Bad request",[j.UNAUTHORIZED]:"Invalid API key provided",[j.FORBIDDEN]:"You exceeded your current quota",[j.NOT_FOUND]:"Model not found",[j.RATE_LIMITED]:"Rate limit exceeded",[j.SERVER_ERROR]:"Internal server error",[j.BAD_GATEWAY]:"Bad gateway - upstream provider error",[j.SERVICE_UNAVAILABLE]:"Service temporarily unavailable",[j.GATEWAY_TIMEOUT]:"Gateway timeout"},m={base:1e3,max:12e4,maxLevel:15},n={unauthorized:12e4,paymentRequired:12e4,notFound:12e4,transient:3e4,requestNotAllowed:5e3,rateLimit:12e4,serviceUnavailable:2e3,authExpired:12e4},o=["Please write a 5-10 word title for the following conversation:"]},57647:(a,b,c)=>{"use strict";c.d(b,{SZ:()=>o,Tz:()=>j,e2:()=>m,jJ:()=>n,vA:()=>l});var d=c(2255);let e="https://api.openai.com/v1",f="https://api.anthropic.com/v1";function g(a){return"string"==typeof a&&a.startsWith("openai-compatible-")}function h(a){return"string"==typeof a&&a.startsWith("anthropic-compatible-")}function i(a){return g(a)&&a.includes("responses")?"responses":"chat"}function j(a){if(a.input&&Array.isArray(a.input))return"openai-responses";if(a.request?.contents&&"antigravity"===a.userAgent)return"antigravity";if(a.contents&&Array.isArray(a.contents))return"gemini";if(a.stream_options||a.response_format||void 0!==a.logprobs||void 0!==a.top_logprobs||void 0!==a.n||void 0!==a.presence_penalty||void 0!==a.frequency_penalty||a.logit_bias||a.user)return"openai";if(a.messages&&Array.isArray(a.messages)){let b=a.messages[0];if(b?.content&&Array.isArray(b.content)){let c=b.content[0];if(c?.type==="text"&&!a.model?.includes("/")){if(a.system||a.anthropic_version)return"claude";let c=b.content.some(a=>"image"===a.type&&a.source?.type==="base64"),d=b.content.some(a=>"image_url"===a.type&&a.image_url?.url);if(c)return"claude";if(d)return"openai";if(b.content.some(a=>"tool_use"===a.type||"tool_result"===a.type))return"claude"}}if(void 0!==a.system||a.anthropic_version)return"claude"}return"openai"}function k(a){if(g(a)){let b=i(a);return{...d.xq.openai,format:"responses"===b?"openai-responses":"openai",baseUrl:e}}return h(a)?{...d.xq.anthropic,format:"claude",baseUrl:f}:d.xq[a]||d.xq.openai}function l(a,b,c=!0,d={}){if(g(a)){var j;let b,c=i(a);return j=d?.baseUrl||e,b=j.replace(/\/$/,""),`${b}${"responses"===c?"/responses":"/chat/completions"}`}if(h(a)){let a;return a=(d?.baseUrl||f).replace(/\/$/,""),`${a}/messages`}let m=k(a);switch(a){case"claude":case"glm":case"kimi":case"minimax":return`${m.baseUrl}?beta=true`;case"gemini":return`${m.baseUrl}/${b}:${c?"streamGenerateContent?alt=sse":"generateContent"}`;case"gemini-cli":return`${m.baseUrl}:${c?"streamGenerateContent?alt=sse":"generateContent"}`;case"antigravity":{let a=d?.baseUrlIndex||0,b=m.baseUrls[a]||m.baseUrls[0];return`${b}${c?"/v1internal:streamGenerateContent?alt=sse":"/v1internal:generateContent"}`}default:return m.baseUrl}}function m(a,b,c=!0,d=null){let e={"Content-Type":"application/json",...k(a).headers};if(h(a))b.apiKey?e["x-api-key"]=b.apiKey:b.accessToken&&(e.Authorization=`Bearer ${b.accessToken}`),e["anthropic-version"]||(e["anthropic-version"]="2023-06-01");else switch(a){case"gemini":b.apiKey?e["x-goog-api-key"]=b.apiKey:b.accessToken&&(e.Authorization=`Bearer ${b.accessToken}`);break;case"antigravity":case"gemini-cli":e.Authorization=`Bearer ${b.accessToken}`;break;case"claude":b.apiKey?e["x-api-key"]=b.apiKey:b.accessToken&&(e.Authorization=`Bearer ${b.accessToken}`);break;case"github":let f=b.copilotToken||b.accessToken;e.Authorization=`Bearer ${f}`,e["Content-Type"]="application/json",e["copilot-integration-id"]="vscode-chat",e["editor-version"]="vscode/1.107.1",e["editor-plugin-version"]="copilot-chat/0.26.7",e["user-agent"]="GitHubCopilotChat/0.26.7",e["openai-intent"]="conversation-panel",e["x-github-api-version"]="2025-04-01",e["x-request-id"]=crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(a){let b=16*Math.random()|0;return("x"==a?b:3&b|8).toString(16)}),e["x-vscode-user-agent-library-version"]="electron-fetch",e["X-Initiator"]="user",e.Accept="application/json";break;case"codex":case"qwen":case"openai":case"openrouter":default:e.Authorization=`Bearer ${b.apiKey||b.accessToken}`;break;case"glm":case"kimi":case"minimax":e["x-api-key"]=b.apiKey}return c&&(e.Accept="text/event-stream"),e}function n(a){return g(a)?"responses"===i(a)?"openai-responses":"openai":h(a)?"claude":k(a).format||"openai"}function o(a){return!function(a){let b=a.messages||a.contents;if(!b?.length)return!0;let c=b[b.length-1];return c?.role==="user"}(a)&&(delete a.reasoning_effort,delete a.thinking),a}},78335:()=>{},96487:()=>{}};
@@ -1 +0,0 @@
1
- self.__BUILD_MANIFEST=function(e,s,t,a,r,i,n){return{__rewrites:{afterFiles:[{has:t,source:"/v1/v1/:path*",destination:a},{has:t,source:"/v1/v1",destination:r},{has:t,source:"/codex/:path*",destination:"/api/v1/responses"},{has:t,source:"/v1/:path*",destination:a},{has:t,source:"/v1",destination:r}],beforeFiles:[],fallback:[]},__routerFilterStatic:{numItems:67,errorRate:1e-4,numBits:1285,numHashes:14,bitArray:[0,0,1,1,1,1,0,0,0,1,0,0,0,1,0,0,0,0,0,0,1,0,0,1,0,1,1,0,1,0,1,1,1,1,1,1,1,0,1,1,0,1,0,1,1,1,1,1,1,1,1,1,1,1,0,1,0,0,1,1,0,0,0,0,1,1,1,0,0,0,1,1,0,1,0,0,1,1,0,0,1,1,0,0,0,0,1,0,1,1,0,0,1,1,1,0,1,1,1,0,0,1,1,0,1,0,1,0,0,1,1,1,0,1,0,0,0,0,1,1,0,0,0,0,1,0,0,1,1,0,1,1,0,0,1,0,0,1,0,0,0,0,1,1,1,1,0,0,0,1,1,1,0,1,0,1,0,1,0,0,1,1,0,1,1,1,0,1,0,1,1,1,0,1,1,0,1,1,1,0,1,0,1,0,1,0,0,0,0,0,0,1,1,0,0,0,1,1,0,1,0,1,1,1,0,1,0,1,0,0,1,1,1,1,1,0,0,0,0,0,0,1,1,0,1,1,1,1,0,1,1,0,0,1,0,0,1,1,0,1,0,1,0,1,1,0,1,1,1,1,1,0,1,0,0,0,0,1,0,1,0,1,0,0,1,1,1,1,1,0,1,0,0,0,0,1,0,1,1,1,1,1,1,0,1,1,0,1,1,0,0,1,1,1,1,0,0,0,1,1,1,0,0,0,1,1,0,1,0,1,0,0,0,1,0,1,0,0,1,1,0,1,1,0,0,1,0,1,0,1,1,1,1,0,1,1,1,1,0,0,0,0,0,0,1,0,0,0,0,1,1,0,1,1,0,1,1,1,0,1,0,0,1,1,1,1,1,0,1,1,1,0,0,1,1,1,0,1,0,0,0,1,0,1,1,1,0,1,1,1,0,1,0,0,0,0,0,0,0,1,0,1,0,1,0,1,1,1,1,0,1,1,1,1,0,0,0,1,0,1,0,1,1,1,0,0,1,0,0,1,1,0,0,1,1,0,1,0,0,1,1,1,1,1,1,1,0,1,0,1,0,1,0,1,0,1,0,1,1,1,0,1,0,1,0,0,1,1,1,1,1,1,0,1,0,1,1,0,0,1,1,0,0,0,1,0,0,1,1,1,1,0,0,1,1,0,1,0,0,1,0,0,1,0,1,0,1,1,1,1,1,0,0,0,1,1,1,1,0,0,1,0,1,1,1,0,1,1,0,1,1,0,0,1,0,0,1,0,1,1,0,0,0,1,1,1,0,1,1,0,0,1,1,0,0,0,0,0,0,0,1,0,0,1,0,0,1,1,1,1,0,0,0,1,0,0,0,1,1,0,0,1,1,0,0,1,1,0,1,1,1,0,1,1,0,0,1,1,1,0,1,0,0,0,1,1,0,0,0,0,1,1,1,1,0,1,0,1,1,0,1,1,1,0,1,0,1,1,1,1,0,1,0,1,1,0,0,1,0,0,1,0,1,0,0,1,0,0,0,0,1,0,0,1,0,0,0,1,1,1,0,1,1,1,1,0,1,0,1,1,1,1,0,1,0,1,1,1,0,0,1,1,0,1,1,1,1,1,0,1,1,0,0,1,1,1,1,0,1,0,1,0,0,1,1,1,0,1,1,0,0,1,0,0,0,1,1,1,1,1,0,1,1,0,1,1,1,1,1,0,0,1,1,0,0,1,1,0,1,1,0,0,1,0,0,0,0,1,1,1,0,0,0,1,0,1,1,0,1,1,0,0,1,1,0,0,0,0,0,0,0,1,0,1,1,1,1,0,1,0,0,1,1,1,0,0,0,0,0,0,0,1,1,0,0,1,1,0,0,0,0,1,0,0,1,0,1,1,0,0,1,1,0,1,1,1,1,0,1,1,0,0,0,1,1,1,1,1,1,0,0,1,0,0,1,0,1,0,0,0,0,1,0,1,0,1,1,0,0,0,1,0,1,0,1,0,1,1,0,0,0,1,0,1,0,0,1,0,0,1,0,0,0,1,1,1,1,0,0,1,1,0,1,0,1,1,0,1,0,1,1,1,0,0,0,1,1,0,1,1,1,0,1,1,0,0,0,1,0,1,1,0,0,1,1,1,0,1,1,1,0,0,1,1,0,0,0,1,1,0,1,1,1,1,0,1,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,0,1,0,1,1,0,0,1,0,0,0,1,1,0,1,1,1,0,1,1,1,0,0,1,0,0,1,1,1,1,1,0,0,1,0,0,0,0,1,1,0,1,0,1,0,0,1,0,0,1,1,0,0,0,0,1,0,1,1,1,1,1,0,1,1,0,0,0,0,1,0,0,0,1,0,0,0,0,1,1,1,1,1,0,0,0,0,1,1,1,1,1,1,1,0,1,1,1,1,1,0,0,1,1,1,0,0,0,0,1,0,1,0,0,1,0,1,1,0,0,0,0,0,1,0,1,0,1,1,1,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,1,1,1,1,1,1,1,1,0,1,0,1,0,0,0,0,0,1,0,1,1,0,0,1,1,0,0,0,1,1,0,0,1,1,0,0,1,0,1,0,0,1,1,0,1,0,0,0,0,1,0,0,1,1,1,0,0,0,1,0,1,1,0,1,1,1,0,1,0,0,1,1,0,1,1,1,0,1,0,0,0,0,1,1,1,1,1,0,0,1,0,1,0,1,0,0,1,1,0,1,1,0,1,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,1,1,0,1,1,0,0,1,1,1,1,0,0,1,0,1,1,1,1,0,0,0,0,0,0,1,1,1,1,0,1,0,0,0,1,1,1,1,1,1,1,1,0,1,0,0,1,0,1,1,1,1,1,1,0,1,0,0,1,1,0,0,1,1,0,0]},__routerFilterDynamic:{numItems:8,errorRate:1e-4,numBits:154,numHashes:14,bitArray:[1,1,1,0,1,1,1,0,0,0,0,1,1,1,1,1,1,1,0,1,1,0,0,1,1,0,1,1,0,0,1,0,1,1,0,0,1,0,0,1,0,0,1,1,0,0,0,0,0,1,0,1,0,0,1,1,1,0,1,1,1,0,0,0,1,0,1,1,1,0,1,0,0,0,1,1,1,0,0,1,1,0,1,1,0,1,0,1,0,1,0,0,1,0,1,0,0,0,1,1,1,0,1,1,1,1,1,0,0,1,1,0,0,0,0,1,1,1,1,1,0,0,0,0,0,0,0,1,1,0,0,1,0,0,1,1,0,0,1,1,0,0,0,1,1,0,1,0,0,1,0,1,0,1]},sortedPages:["/_app"]}}(0,0,void 0,"/api/v1/:path*","/api/v1",0,0),self.__BUILD_MANIFEST_CB&&self.__BUILD_MANIFEST_CB();
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[1393],{1393:(e,s,l)=>{Promise.resolve().then(l.bind(l,5907))},5907:(e,s,l)=>{"use strict";l.d(s,{default:()=>c});var t=l(5155),a=l(2115),r=l(4051),i=l.n(r),n=l(5497),d=l(1059);let o=15e3;function c({machineId:e}){let[s,l]=(0,a.useState)([]),[r,i]=(0,a.useState)(!0),[c,m]=(0,a.useState)(!1),[x,y]=(0,a.useState)(""),[h,u]=(0,a.useState)(null),[p,b]=(0,a.useState)(!1),[g,f]=(0,a.useState)(!1),[j,N]=(0,a.useState)(!1),[v,k]=(0,a.useState)(!1),[w,C]=(0,a.useState)(null),[S,_]=(0,a.useState)(""),{copied:E,copy:P}=(0,d.C)();(0,a.useEffect)(()=>{O(),A()},[]);let $=async(e,s=o)=>{let l=new AbortController,t=setTimeout(()=>l.abort(),s);try{let s=await fetch("/api/sync/cloud",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:e}),signal:l.signal}),t=await s.json().catch(()=>({}));return{ok:s.ok,status:s.status,data:t}}catch(e){if(e?.name==="AbortError")return{ok:!1,status:408,data:{error:"Cloud request timeout"}};return{ok:!1,status:500,data:{error:e.message||"Cloud request failed"}}}finally{clearTimeout(t)}},A=async()=>{try{let e=await fetch("/api/settings");if(e.ok){let s=await e.json();b(s.cloudEnabled||!1)}}catch(e){console.log("Error loading cloud settings:",e)}},O=async()=>{try{let e=await fetch("/api/keys"),s=await e.json();e.ok&&l(s.keys||[])}catch(e){console.log("Error fetching data:",e)}finally{i(!1)}},D=e=>{e?f(!0):N(!0)},I=async()=>{k(!0),_("syncing");try{let{ok:e,data:s}=await $("enable");e?(_("verifying"),s.verified?(b(!0),C({type:"success",message:"Cloud Proxy connected and verified!"})):(b(!0),C({type:"warning",message:s.verifyError||"Connected but verification failed"})),f(!1),s.createdKey&&await O()):C({type:"error",message:s.error||"Failed to enable cloud"})}catch(e){C({type:"error",message:e.message})}finally{k(!1),_("")}},T=async()=>{k(!0),_("syncing");try{await $("sync"),_("disabling");let{ok:e,data:s}=await $("disable");e?(b(!1),C({type:"success",message:"Cloud disabled"}),N(!1)):C({type:"error",message:s.error||"Failed to disable cloud"})}catch(e){console.log("Error disabling cloud:",e),C({type:"error",message:"Failed to disable cloud"})}finally{k(!1),_("")}},W=async()=>{if(x.trim())try{let e=await fetch("/api/keys",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:x})}),s=await e.json();e.ok&&(u(s.key),await O(),y(""),m(!1))}catch(e){console.log("Error creating key:",e)}},F=async e=>{if(confirm("Delete this API key?"))try{(await fetch(`/api/keys/${e}`,{method:"DELETE"})).ok&&l(s.filter(s=>s.id!==e))}catch(e){console.log("Error deleting key:",e)}},[K,q]=(0,a.useState)("/v1");if((0,a.useEffect)(()=>{q(`${window.location.origin}/v1`)},[]),r)return(0,t.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,t.jsx)(n.Qv,{}),(0,t.jsx)(n.Qv,{})]});let L=p?"https://9router.com/v1":K;return(0,t.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,t.jsxs)(n.Zp,{className:"",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,t.jsxs)("div",{children:[(0,t.jsx)("h2",{className:"text-lg font-semibold",children:"API Endpoint"}),(0,t.jsx)("p",{className:"text-sm text-text-muted",children:p?"Using Cloud Proxy":"Using Local Server"})]}),(0,t.jsx)("div",{className:"flex items-center gap-2",children:p?(0,t.jsx)(n.$n,{size:"sm",variant:"secondary",icon:"cloud_off",onClick:()=>D(!1),disabled:v,className:"bg-red-500/10! text-red-500! hover:bg-red-500/20! border-red-500/30!",children:"Disable Cloud"}):(0,t.jsx)(n.$n,{variant:"primary",icon:"cloud_upload",onClick:()=>D(!0),disabled:v,className:"bg-linear-to-r from-primary to-blue-500 hover:from-primary-hover hover:to-blue-600",children:"Enable Cloud"})})]}),(0,t.jsxs)("div",{className:"flex gap-2 mb-3",children:[(0,t.jsx)(n.pd,{value:L,readOnly:!0,className:`flex-1 font-mono text-sm ${p?"animate-border-glow":""}`}),(0,t.jsx)(n.$n,{variant:"secondary",icon:"endpoint_url"===E?"check":"content_copy",onClick:()=>P(L,"endpoint_url"),children:"endpoint_url"===E?"Copied!":"Copy"})]})]}),(0,t.jsxs)(n.Zp,{children:[(0,t.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,t.jsx)("h2",{className:"text-lg font-semibold",children:"API Keys"}),(0,t.jsx)(n.$n,{icon:"add",onClick:()=>m(!0),children:"Create Key"})]}),0===s.length?(0,t.jsxs)("div",{className:"text-center py-12",children:[(0,t.jsx)("div",{className:"inline-flex items-center justify-center w-16 h-16 rounded-full bg-primary/10 text-primary mb-4",children:(0,t.jsx)("span",{className:"material-symbols-outlined text-[32px]",children:"vpn_key"})}),(0,t.jsx)("p",{className:"text-text-main font-medium mb-1",children:"No API keys yet"}),(0,t.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Create your first API key to get started"}),(0,t.jsx)(n.$n,{icon:"add",onClick:()=>m(!0),children:"Create Key"})]}):(0,t.jsx)("div",{className:"flex flex-col",children:s.map(e=>(0,t.jsxs)("div",{className:"group flex items-center justify-between py-3 border-b border-black/[0.03] dark:border-white/[0.03] last:border-b-0",children:[(0,t.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,t.jsx)("p",{className:"text-sm font-medium",children:e.name}),(0,t.jsxs)("div",{className:"flex items-center gap-2 mt-1",children:[(0,t.jsx)("code",{className:"text-xs text-text-muted font-mono",children:e.key}),(0,t.jsx)("button",{onClick:()=>P(e.key,e.id),className:"p-1 hover:bg-black/5 dark:hover:bg-white/5 rounded text-text-muted hover:text-primary opacity-0 group-hover:opacity-100 transition-all",children:(0,t.jsx)("span",{className:"material-symbols-outlined text-[14px]",children:E===e.id?"check":"content_copy"})})]}),(0,t.jsxs)("p",{className:"text-xs text-text-muted mt-1",children:["Created ",new Date(e.createdAt).toLocaleDateString()]})]}),(0,t.jsx)("button",{onClick:()=>F(e.id),className:"p-2 hover:bg-red-500/10 rounded text-red-500 opacity-0 group-hover:opacity-100 transition-all",children:(0,t.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"delete"})})]},e.id))})]}),!1,(0,t.jsx)(n.aF,{isOpen:g,title:"Enable Cloud Proxy",onClose:()=>f(!1),children:(0,t.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,t.jsxs)("div",{className:"bg-blue-50 dark:bg-blue-900/20 border border-blue-200 dark:border-blue-800 rounded-lg p-4",children:[(0,t.jsx)("p",{className:"text-sm text-blue-800 dark:text-blue-200 font-medium mb-2",children:"What you will get"}),(0,t.jsxs)("ul",{className:"text-sm text-blue-700 dark:text-blue-300 space-y-1",children:[(0,t.jsx)("li",{children:"• Access your API from anywhere in the world"}),(0,t.jsx)("li",{children:"• Share endpoint with your team easily"}),(0,t.jsx)("li",{children:"• No need to open ports or configure firewall"}),(0,t.jsx)("li",{children:"• Fast global edge network"})]})]}),(0,t.jsxs)("div",{className:"bg-yellow-50 dark:bg-yellow-900/20 border border-yellow-200 dark:border-yellow-800 rounded-lg p-4",children:[(0,t.jsx)("p",{className:"text-sm text-yellow-800 dark:text-yellow-200 font-medium mb-1",children:"Note"}),(0,t.jsxs)("ul",{className:"text-sm text-yellow-700 dark:text-yellow-300 space-y-1",children:[(0,t.jsx)("li",{children:"• Cloud will keep your auth session for 1 day. If not used, it will be automatically deleted."}),(0,t.jsx)("li",{children:"• Cloud is currently unstable with Claude Code OAuth in some cases."})]})]}),v&&(0,t.jsxs)("div",{className:"flex items-center gap-3 p-3 bg-primary/10 border border-primary/30 rounded-lg",children:[(0,t.jsx)("span",{className:"material-symbols-outlined animate-spin text-primary",children:"progress_activity"}),(0,t.jsx)("div",{className:"flex-1",children:(0,t.jsxs)("p",{className:"text-sm font-medium text-primary",children:["syncing"===S&&"Syncing data to cloud...","verifying"===S&&"Verifying connection..."]})})]}),(0,t.jsxs)("div",{className:"flex gap-2",children:[(0,t.jsx)(n.$n,{onClick:I,fullWidth:!0,disabled:v,children:v?(0,t.jsxs)("span",{className:"flex items-center gap-2",children:[(0,t.jsx)("span",{className:"material-symbols-outlined animate-spin text-sm",children:"progress_activity"}),"syncing"===S?"Syncing...":"Verifying..."]}):"Enable Cloud"}),(0,t.jsx)(n.$n,{onClick:()=>f(!1),variant:"ghost",fullWidth:!0,disabled:v,children:"Cancel"})]})]})}),(0,t.jsx)(n.aF,{isOpen:c,title:"Create API Key",onClose:()=>{m(!1),y("")},children:(0,t.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,t.jsx)(n.pd,{label:"Key Name",value:x,onChange:e=>y(e.target.value),placeholder:"Production Key"}),(0,t.jsxs)("div",{className:"flex gap-2",children:[(0,t.jsx)(n.$n,{onClick:W,fullWidth:!0,disabled:!x.trim(),children:"Create"}),(0,t.jsx)(n.$n,{onClick:()=>{m(!1),y("")},variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}),(0,t.jsx)(n.aF,{isOpen:!!h,title:"API Key Created",onClose:()=>u(null),children:(0,t.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,t.jsxs)("div",{className:"bg-yellow-50 dark:bg-yellow-900/20 border border-yellow-200 dark:border-yellow-800 rounded-lg p-4",children:[(0,t.jsx)("p",{className:"text-sm text-yellow-800 dark:text-yellow-200 mb-2 font-medium",children:"Save this key now!"}),(0,t.jsx)("p",{className:"text-sm text-yellow-700 dark:text-yellow-300",children:"This is the only time you will see this key. Store it securely."})]}),(0,t.jsxs)("div",{className:"flex gap-2",children:[(0,t.jsx)(n.pd,{value:h||"",readOnly:!0,className:"flex-1 font-mono text-sm"}),(0,t.jsx)(n.$n,{variant:"secondary",icon:"created_key"===E?"check":"content_copy",onClick:()=>P(h,"created_key"),children:"created_key"===E?"Copied!":"Copy"})]}),(0,t.jsx)(n.$n,{onClick:()=>u(null),fullWidth:!0,children:"Done"})]})}),(0,t.jsx)(n.aF,{isOpen:j,title:"Disable Cloud Proxy",onClose:()=>!v&&N(!1),children:(0,t.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,t.jsx)("div",{className:"bg-red-50 dark:bg-red-900/20 border border-red-200 dark:border-red-800 rounded-lg p-4",children:(0,t.jsxs)("div",{className:"flex items-start gap-3",children:[(0,t.jsx)("span",{className:"material-symbols-outlined text-red-600 dark:text-red-400",children:"warning"}),(0,t.jsxs)("div",{children:[(0,t.jsx)("p",{className:"text-sm text-red-800 dark:text-red-200 font-medium mb-1",children:"Warning"}),(0,t.jsx)("p",{className:"text-sm text-red-700 dark:text-red-300",children:"All auth sessions will be deleted from cloud."})]})]})}),v&&(0,t.jsxs)("div",{className:"flex items-center gap-3 p-3 bg-primary/10 border border-primary/30 rounded-lg",children:[(0,t.jsx)("span",{className:"material-symbols-outlined animate-spin text-primary",children:"progress_activity"}),(0,t.jsx)("div",{className:"flex-1",children:(0,t.jsxs)("p",{className:"text-sm font-medium text-primary",children:["syncing"===S&&"Syncing latest data...","disabling"===S&&"Disabling cloud..."]})})]}),(0,t.jsx)("p",{className:"text-sm text-text-muted",children:"Are you sure you want to disable cloud proxy?"}),(0,t.jsxs)("div",{className:"flex gap-2",children:[(0,t.jsx)(n.$n,{onClick:T,fullWidth:!0,disabled:v,className:"bg-red-500! hover:bg-red-600! text-white!",children:v?(0,t.jsxs)("span",{className:"flex items-center gap-2",children:[(0,t.jsx)("span",{className:"material-symbols-outlined animate-spin text-sm",children:"progress_activity"}),"syncing"===S?"Syncing...":"Disabling..."]}):"Disable Cloud"}),(0,t.jsx)(n.$n,{onClick:()=>N(!1),variant:"ghost",fullWidth:!0,disabled:v,children:"Cancel"})]})]})})]})}c.propTypes={machineId:i().string.isRequired}}}]);
@@ -1 +0,0 @@
1
- "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[8729],{85:(i,e,n)=>{n.d(e,{A:()=>t});var a=n(1934),o=n(9311),d=n(620);function m(i){let e=document.documentElement,n=window.matchMedia("(prefers-color-scheme: dark)").matches?"dark":"light";"dark"===("system"===i?n:i)?e.classList.add("dark"):e.classList.remove("dark")}let t=(0,a.v)((0,o.Zr)((i,e)=>({theme:d.B2.defaultTheme,setTheme:e=>{i({theme:e}),m(e)},toggleTheme:()=>{let n="dark"===e().theme?"light":"dark";i({theme:n}),m(n)},initTheme:()=>{m(e().theme)}}),{name:d.B2.storageKey}))},620:(i,e,n)=>{n.d(e,{Q2:()=>a.Q2,fg:()=>a.fg,vQ:()=>o,MA:()=>a.MA,zN:()=>a.zN,B2:()=>d});var a=n(2679);n(8777);let o={name:"Endpoint Proxy",description:"AI Infrastructure Management",version:"0.2.71"},d={storageKey:"theme",defaultTheme:"system"}},1110:(i,e,n)=>{n.d(e,{ThemeProvider:()=>m});var a=n(5155),o=n(2115),d=n(85);function m({children:i}){let{initTheme:e}=(0,d.A)();return(0,o.useEffect)(()=>{e()},[e]),(0,a.jsx)(a.Fragment,{children:i})}},2679:(i,e,n)=>{n.d(e,{DI:()=>t,IS:()=>a,JH:()=>m,MA:()=>u,Q2:()=>r,fg:()=>d,gb:()=>c,mq:()=>l,wG:()=>s,wb:()=>g,zN:()=>o});let a={iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"}},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"},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"}},d={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#6366F1",textIcon:"OR",passthroughModels:!0},glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL"},kimi:{id:"kimi",alias:"kimi",name:"Kimi Coding",icon:"psychology",color:"#1E3A8A",textIcon:"KM"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE"}},m="openai-compatible-",t="anthropic-compatible-";function l(i){return"string"==typeof i&&i.startsWith(m)}function c(i){return"string"==typeof i&&i.startsWith(t)}let r={...a,...o,...d},u={oauth:{id:"oauth",name:"OAuth",icon:"lock"},apikey:{id:"apikey",name:"API Key",icon:"key"}};function s(i){let e=r[i];return e?.alias||i}Object.values(r).reduce((i,e)=>(i[e.alias]=e.id,i),{}),Object.values(r).reduce((i,e)=>(i[e.id]=e.alias,i),{});let g=["antigravity","kiro","github"]},3097:(i,e,n)=>{n.d(e,{KC:()=>d,Xg:()=>o,vq:()=>a});let a={cc:[{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-opus-4-5-20251101",name:"Claude 4.5 Opus"},{id:"claude-sonnet-4-5-20250929",name:"Claude 4.5 Sonnet"},{id:"claude-haiku-4-5-20251001",name:"Claude 4.5 Haiku"}],cx:[{id:"gpt-5.3-codex",name:"GPT 5.3 Codex"},{id:"gpt-5.3-codex-xhigh",name:"GPT 5.3 Codex (xHigh)"},{id:"gpt-5.3-codex-high",name:"GPT 5.3 Codex (High)"},{id:"gpt-5.3-codex-low",name:"GPT 5.3 Codex (Low)"},{id:"gpt-5.3-codex-none",name:"GPT 5.3 Codex (None)"},{id:"gpt-5.1-codex-mini",name:"GPT 5.1 Codex Mini"},{id:"gpt-5.1-codex-mini-high",name:"GPT 5.1 Codex Mini (High)"},{id:"gpt-5.2-codex",name:"GPT 5.2 Codex"},{id:"gpt-5.2",name:"GPT 5.2"},{id:"gpt-5.1-codex-max",name:"GPT 5.1 Codex Max"},{id:"gpt-5.1-codex",name:"GPT 5.1 Codex"},{id:"gpt-5.1",name:"GPT 5.1"},{id:"gpt-5-codex",name:"GPT 5 Codex"},{id:"gpt-5-codex-mini",name:"GPT 5 Codex Mini"}],gc:[{id:"gemini-3-flash-preview",name:"Gemini 3 Flash Preview"},{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"}],qw:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus"},{id:"qwen3-coder-flash",name:"Qwen3 Coder Flash"},{id:"vision-model",name:"Qwen3 Vision Model"}],if:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus"},{id:"kimi-k2",name:"Kimi K2"},{id:"kimi-k2-thinking",name:"Kimi K2 Thinking"},{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"deepseek-r1",name:"DeepSeek R1"},{id:"deepseek-v3.2-chat",name:"DeepSeek V3.2 Chat"},{id:"deepseek-v3.2-reasoner",name:"DeepSeek V3.2 Reasoner"},{id:"minimax-m2.1",name:"MiniMax M2.1"},{id:"glm-4.7",name:"GLM 4.7"}],ag:[{id:"claude-opus-4-6-thinking",name:"Claude Opus 4.6 Thinking"},{id:"claude-opus-4-5-thinking",name:"Claude Opus 4.5 Thinking"},{id:"claude-sonnet-4-5-thinking",name:"Claude Sonnet 4.5 Thinking"},{id:"claude-sonnet-4-5",name:"Claude Sonnet 4.5"},{id:"gemini-3-pro-high",name:"Gemini 3 Pro High"},{id:"gemini-3-pro-low",name:"Gemini 3 Pro Low"},{id:"gemini-3-flash",name:"Gemini 3 Flash"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"}],gh:[{id:"gpt-4.1",name:"GPT-4.1"},{id:"gpt-5",name:"GPT-5"},{id:"gpt-5-mini",name:"GPT-5 Mini"},{id:"gpt-5-codex",name:"GPT-5 Codex"},{id:"gpt-5.1",name:"GPT-5.1"},{id:"gpt-5.1-codex",name:"GPT-5.1 Codex"},{id:"gpt-5.1-codex-mini",name:"GPT-5.1 Codex Mini"},{id:"gpt-5.1-codex-max",name:"GPT-5.1 Codex Max"},{id:"gpt-5.2",name:"GPT-5.2"},{id:"gpt-5.2-codex",name:"GPT-5.2 Codex"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5"},{id:"claude-opus-4.1",name:"Claude Opus 4.1"},{id:"claude-opus-4-5-20251101",name:"Claude Opus 4.5 (Full ID)"},{id:"claude-sonnet-4",name:"Claude Sonnet 4"},{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-3-flash",name:"Gemini 3 Flash"},{id:"gemini-3-pro",name:"Gemini 3 Pro"},{id:"grok-code-fast-1",name:"Grok Code Fast 1"},{id:"raptor-mini",name:"Raptor Mini"}],kr:[{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5"}],cu:[{id:"default",name:"Auto (Server Picks)"},{id:"claude-4.5-opus-high-thinking",name:"Claude 4.5 Opus High Thinking"},{id:"claude-4.5-opus-high",name:"Claude 4.5 Opus High"},{id:"claude-4.5-sonnet-thinking",name:"Claude 4.5 Sonnet Thinking"},{id:"claude-4.5-sonnet",name:"Claude 4.5 Sonnet"},{id:"claude-4.5-haiku",name:"Claude 4.5 Haiku"},{id:"claude-4.5-opus",name:"Claude 4.5 Opus"},{id:"gpt-5.2-codex",name:"GPT 5.2 Codex"}],openai:[{id:"gpt-4o",name:"GPT-4o"},{id:"gpt-4o-mini",name:"GPT-4o Mini"},{id:"gpt-4-turbo",name:"GPT-4 Turbo"},{id:"o1",name:"O1"},{id:"o1-mini",name:"O1 Mini"}],anthropic:[{id:"claude-sonnet-4-20250514",name:"Claude Sonnet 4"},{id:"claude-opus-4-20250514",name:"Claude Opus 4"},{id:"claude-3-5-sonnet-20241022",name:"Claude 3.5 Sonnet"}],gemini:[{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"}],openrouter:[{id:"auto",name:"Auto (Best Available)"}],glm:[{id:"glm-4.7",name:"GLM 4.7"},{id:"glm-4.6v",name:"GLM 4.6V (Vision)"}],kimi:[{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"kimi-k2.5-thinking",name:"Kimi K2.5 Thinking"},{id:"kimi-latest",name:"Kimi Latest"}],minimax:[{id:"MiniMax-M2.1",name:"MiniMax M2.1"}]},o={claude:"cc",codex:"cx","gemini-cli":"gc",qwen:"qw",iflow:"if",antigravity:"ag",github:"gh",kiro:"kr",cursor:"cu",openai:"openai",anthropic:"anthropic",gemini:"gemini",openrouter:"openrouter",glm:"glm",kimi:"kimi",minimax:"minimax","minimax-cn":"minimax"};function d(i){return a[o[i]||i]||[]}},8777:(i,e,n)=>{n.d(e,{KC:()=>a.KC,Xg:()=>a.Xg});var a=n(3097);Object.entries(n(2679).Q2).filter(([,i])=>i.passthroughModels).map(([i])=>i),Object.entries(a.vq).flatMap(([i,e])=>e.map(e=>({provider:i,model:e.id,name:e.name})))}}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[3471],{4561:(e,s,t)=>{"use strict";t.r(s),t.d(s,{default:()=>c});var a=t(5155),r=t(2115),l=t(5497),i=t(1620),n=t(1474),d=t(620);function c(){let{theme:e,setTheme:s,isDark:t}=(0,i.D)(),[c,o]=(0,r.useState)({fallbackStrategy:"fill-first"}),[m,x]=(0,r.useState)(!0),[h,p]=(0,r.useState)({current:"",new:"",confirm:""}),[u,g]=(0,r.useState)({type:"",message:""}),[b,j]=(0,r.useState)(!1);(0,r.useEffect)(()=>{fetch("/api/settings").then(e=>e.json()).then(e=>{o(e),x(!1)}).catch(e=>{console.error("Failed to fetch settings:",e),x(!1)})},[]);let f=async e=>{if(e.preventDefault(),h.new!==h.confirm)return void g({type:"error",message:"Passwords do not match"});j(!0),g({type:"",message:""});try{let e=await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({currentPassword:h.current,newPassword:h.new})}),s=await e.json();e.ok?(g({type:"success",message:"Password updated successfully"}),p({current:"",new:"",confirm:""})):g({type:"error",message:s.error||"Failed to update password"})}catch(e){g({type:"error",message:"An error occurred"})}finally{j(!1)}},N=async e=>{try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({fallbackStrategy:e})})).ok&&o(s=>({...s,fallbackStrategy:e}))}catch(e){console.error("Failed to update settings:",e)}},y=async e=>{let s=parseInt(e);if(!isNaN(s)&&!(s<1))try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({stickyRoundRobinLimit:s})})).ok&&o(e=>({...e,stickyRoundRobinLimit:s}))}catch(e){console.error("Failed to update sticky limit:",e)}},v=async e=>{try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({requireLogin:e})})).ok&&o(s=>({...s,requireLogin:e}))}catch(e){console.error("Failed to update require login:",e)}};return(0,a.jsx)("div",{className:"max-w-2xl mx-auto",children:(0,a.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,a.jsxs)(l.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-4 mb-4",children:[(0,a.jsx)("div",{className:"size-12 rounded-lg bg-green-500/10 text-green-500 flex items-center justify-center",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-2xl",children:"computer"})}),(0,a.jsxs)("div",{children:[(0,a.jsx)("h2",{className:"text-xl font-semibold",children:"Local Mode"}),(0,a.jsx)("p",{className:"text-text-muted",children:"Running on your machine"})]})]}),(0,a.jsx)("div",{className:"pt-4 border-t border-border",children:(0,a.jsxs)("p",{className:"text-sm text-text-muted",children:["All data is stored locally in the ",(0,a.jsx)("code",{className:"bg-sidebar px-1 rounded",children:"~/.9router/db.json"})," file."]})})]}),(0,a.jsxs)(l.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-primary/10 text-primary",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"shield"})}),(0,a.jsx)("h3",{className:"text-lg font-semibold",children:"Security"})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex items-center justify-between",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium",children:"Require login"}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"When ON, dashboard requires password. When OFF, access without login."})]}),(0,a.jsx)(l.lM,{checked:!0===c.requireLogin,onChange:()=>v(!c.requireLogin),disabled:m})]}),!0===c.requireLogin&&(0,a.jsxs)("form",{onSubmit:f,className:"flex flex-col gap-4 pt-4 border-t border-border/50",children:[c.hasPassword&&(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"text-sm font-medium",children:"Current Password"}),(0,a.jsx)(l.pd,{type:"password",placeholder:"Enter current password",value:h.current,onChange:e=>p({...h,current:e.target.value}),required:!0})]}),(0,a.jsxs)("div",{className:"grid grid-cols-1 md:grid-cols-2 gap-4",children:[(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"text-sm font-medium",children:"New Password"}),(0,a.jsx)(l.pd,{type:"password",placeholder:"Enter new password",value:h.new,onChange:e=>p({...h,new:e.target.value}),required:!0})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"text-sm font-medium",children:"Confirm New Password"}),(0,a.jsx)(l.pd,{type:"password",placeholder:"Confirm new password",value:h.confirm,onChange:e=>p({...h,confirm:e.target.value}),required:!0})]})]}),u.message&&(0,a.jsx)("p",{className:`text-sm ${"error"===u.type?"text-red-500":"text-green-500"}`,children:u.message}),(0,a.jsx)("div",{className:"pt-2",children:(0,a.jsx)(l.$n,{type:"submit",variant:"primary",loading:b,children:c.hasPassword?"Update Password":"Set Password"})})]})]})]}),(0,a.jsxs)(l.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-blue-500/10 text-blue-500",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"route"})}),(0,a.jsx)("h3",{className:"text-lg font-semibold",children:"Routing Strategy"})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex items-center justify-between",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium",children:"Round Robin"}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"Cycle through accounts to distribute load"})]}),(0,a.jsx)(l.lM,{checked:"round-robin"===c.fallbackStrategy,onChange:()=>N("round-robin"===c.fallbackStrategy?"fill-first":"round-robin"),disabled:m})]}),"round-robin"===c.fallbackStrategy&&(0,a.jsxs)("div",{className:"flex items-center justify-between pt-2 border-t border-border/50",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium",children:"Sticky Limit"}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"Calls per account before switching"})]}),(0,a.jsx)(l.pd,{type:"number",min:"1",max:"10",value:c.stickyRoundRobinLimit||3,onChange:e=>y(e.target.value),disabled:m,className:"w-20 text-center"})]}),(0,a.jsx)("p",{className:"text-xs text-text-muted italic pt-2 border-t border-border/50",children:"round-robin"===c.fallbackStrategy?`Currently distributing requests across all available accounts with ${c.stickyRoundRobinLimit||3} calls per account.`:"Currently using accounts in priority order (Fill First)."})]})]}),(0,a.jsxs)(l.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-purple-500/10 text-purple-500",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"palette"})}),(0,a.jsx)("h3",{className:"text-lg font-semibold",children:"Appearance"})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex items-center justify-between",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium",children:"Dark Mode"}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"Switch between light and dark themes"})]}),(0,a.jsx)(l.lM,{checked:t,onChange:()=>s(t?"light":"dark")})]}),(0,a.jsx)("div",{className:"pt-4 border-t border-border",children:(0,a.jsx)("div",{className:"inline-flex p-1 rounded-lg bg-black/5 dark:bg-white/5",children:["light","dark","system"].map(t=>(0,a.jsxs)("button",{onClick:()=>s(t),className:(0,n.cn)("flex items-center gap-2 px-4 py-2 rounded-md font-medium transition-all",e===t?"bg-white dark:bg-white/10 text-text-main shadow-sm":"text-text-muted hover:text-text-main"),children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"light"===t?"light_mode":"dark"===t?"dark_mode":"contrast"}),(0,a.jsx)("span",{className:"capitalize",children:t})]},t))})})]})]}),(0,a.jsxs)(l.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-green-500/10 text-green-500",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"database"})}),(0,a.jsx)("h3",{className:"text-lg font-semibold",children:"Data"})]}),(0,a.jsx)("div",{className:"flex flex-col gap-3",children:(0,a.jsx)("div",{className:"flex items-center justify-between p-4 rounded-lg bg-bg border border-border",children:(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium",children:"Database Location"}),(0,a.jsx)("p",{className:"text-sm text-text-muted font-mono",children:"~/.9router/db.json"})]})})})]}),(0,a.jsxs)("div",{className:"text-center text-sm text-text-muted py-4",children:[(0,a.jsxs)("p",{children:[d.vQ.name," v",d.vQ.version]}),(0,a.jsx)("p",{className:"mt-1",children:"Local Mode - All data stored on your machine"})]})]})})}},6086:(e,s,t)=>{Promise.resolve().then(t.bind(t,4561))}},e=>{e.O(0,[600,3624,8729,5497,8441,3794,7358],()=>e(e.s=6086)),_N_E=e.O()}]);
@@ -1 +0,0 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[2134],{2397:(e,t,i)=>{Promise.resolve().then(i.bind(i,7162))},7162:(e,t,i)=>{"use strict";i.r(t),i.d(t,{default:()=>h});var s=i(5155),a=i(2115),l=i(4051),r=i.n(l),n=i(3321),o=i(8500),d=i.n(o),c=i(5772),p=i(5497),m=i(2679),u=i(8777),x=i(1059);function h(){let e=(0,n.useParams)(),t=(0,n.useRouter)(),i=e.id,[l,r]=(0,a.useState)([]),[o,h]=(0,a.useState)(!0),[v,b]=(0,a.useState)(null),[w,k]=(0,a.useState)(!1),[S,$]=(0,a.useState)(!1),[T,O]=(0,a.useState)(!1),[E,R]=(0,a.useState)(!1),[q,I]=(0,a.useState)(null),[P,U]=(0,a.useState)({}),[K,D]=(0,a.useState)(!1),{copied:M,copy:L}=(0,x.C)(),_=v?{id:v.id,name:v.name||("anthropic-compatible"===v.type?"Anthropic Compatible":"OpenAI Compatible"),color:"anthropic-compatible"===v.type?"#D97757":"#10A37F",textIcon:"anthropic-compatible"===v.type?"AC":"OC",apiType:v.apiType,baseUrl:v.baseUrl,type:v.type}:m.zN[i]||m.fg[i],F=!!m.zN[i],z=(0,u.KC)(i),J=(0,m.wG)(i),W=(0,m.mq)(i),V=(0,m.gb)(i),B=W||V,Z=B?i:J,G=B?v?.prefix||i:J,Q=(0,a.useCallback)(async()=>{try{let e=await fetch("/api/models/alias"),t=await e.json();e.ok&&U(t.aliases||{})}catch(e){console.log("Error fetching aliases:",e)}},[]),H=(0,a.useCallback)(async()=>{try{let[e,t]=await Promise.all([fetch("/api/providers",{cache:"no-store"}),fetch("/api/provider-nodes",{cache:"no-store"})]),s=await e.json(),a=await t.json();if(e.ok){let e=(s.connections||[]).filter(e=>e.provider===i);r(e)}if(t.ok){let e=(a.nodes||[]).find(e=>e.id===i)||null;if(!e&&B)for(let t=0;t<3;t+=1){await new Promise(e=>setTimeout(e,150));let t=await fetch("/api/provider-nodes",{cache:"no-store"});if(t.ok&&(e=((await t.json()).nodes||[]).find(e=>e.id===i)||null))break}b(e)}}catch(e){console.log("Error fetching connections:",e)}finally{h(!1)}},[i]),X=async e=>{try{let t=await fetch(`/api/provider-nodes/${i}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)}),s=await t.json();t.ok&&(b(s.node),await H(),R(!1))}catch(e){console.log("Error updating provider node:",e)}};(0,a.useEffect)(()=>{H(),Q()},[H,Q]);let Y=async(e,t,i=J)=>{let s=`${i}/${e}`;try{let e=await fetch("/api/models/alias",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:s,alias:t})});if(e.ok)await Q();else{let t=await e.json();alert(t.error||"Failed to set alias")}}catch(e){console.log("Error setting alias:",e)}},ee=async e=>{try{(await fetch(`/api/models/alias?alias=${encodeURIComponent(e)}`,{method:"DELETE"})).ok&&await Q()}catch(e){console.log("Error deleting alias:",e)}},et=async e=>{if(confirm("Delete this connection?"))try{(await fetch(`/api/providers/${e}`,{method:"DELETE"})).ok&&r(l.filter(t=>t.id!==e))}catch(e){console.log("Error deleting connection:",e)}},ei=()=>{H(),k(!1)},es=async e=>{try{(await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:i,...e})})).ok&&(await H(),$(!1))}catch(e){console.log("Error saving connection:",e)}},ea=async e=>{try{(await fetch(`/api/providers/${q.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)})).ok&&(await H(),O(!1))}catch(e){console.log("Error updating connection:",e)}},el=async(e,t)=>{try{(await fetch(`/api/providers/${e}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({isActive:t})})).ok&&r(i=>i.map(i=>i.id===e?{...i,isActive:t}:i))}catch(e){console.log("Error updating connection status:",e)}},er=async(e,t)=>{if(e&&t)try{let i=t.priority,s=e.priority;i===s&&(i=l.indexOf(e)>l.indexOf(t)?t.priority-.5:t.priority+.5),await Promise.all([fetch(`/api/providers/${e.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:i})}),fetch(`/api/providers/${t.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:s})})]),await H()}catch(e){console.log("Error swapping priority:",e)}};return o?(0,s.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,s.jsx)(p.Qv,{}),(0,s.jsx)(p.Qv,{})]}):_?(0,s.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,s.jsxs)("div",{children:[(0,s.jsxs)(d(),{href:"/dashboard/providers",className:"inline-flex items-center gap-1 text-sm text-text-muted hover:text-primary transition-colors mb-4",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-lg",children:"arrow_back"}),"Back to Providers"]}),(0,s.jsxs)("div",{className:"flex items-center gap-4",children:[(0,s.jsx)("div",{className:"rounded-lg flex items-center justify-center",style:{backgroundColor:`${_.color}15`},children:K?(0,s.jsx)("span",{className:"text-sm font-bold",style:{color:_.color},children:_.textIcon||_.id.slice(0,2).toUpperCase()}):(0,s.jsx)(c.default,{src:W&&_.apiType?"responses"===_.apiType?"/providers/oai-r.png":"/providers/oai-cc.png":V?"/providers/anthropic-m.png":`/providers/${_.id}.png`,alt:_.name,width:48,height:48,className:"object-contain rounded-lg max-w-[48px] max-h-[48px]",sizes:"48px",onError:()=>D(!0)})}),(0,s.jsxs)("div",{children:[(0,s.jsx)("h1",{className:"text-3xl font-semibold tracking-tight",children:_.name}),(0,s.jsxs)("p",{className:"text-text-muted",children:[l.length," connection",1===l.length?"":"s"]})]})]})]}),B&&v&&(0,s.jsxs)(p.Zp,{children:[(0,s.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,s.jsxs)("div",{children:[(0,s.jsx)("h2",{className:"text-lg font-semibold",children:V?"Anthropic Compatible Details":"OpenAI Compatible Details"}),(0,s.jsxs)("p",{className:"text-sm text-text-muted",children:[V?"Messages API":"responses"===v.apiType?"Responses API":"Chat Completions"," \xb7 ",(v.baseUrl||"").replace(/\/$/,""),"/",V?"messages":"responses"===v.apiType?"responses":"chat/completions"]})]}),(0,s.jsxs)("div",{className:"flex items-center gap-2",children:[(0,s.jsx)(p.$n,{size:"sm",icon:"add",onClick:()=>$(!0),disabled:l.length>0,children:"Add"}),(0,s.jsx)(p.$n,{size:"sm",variant:"secondary",icon:"edit",onClick:()=>R(!0),children:"Edit"}),(0,s.jsx)(p.$n,{size:"sm",variant:"secondary",icon:"delete",onClick:async()=>{if(confirm(`Delete this ${V?"Anthropic":"OpenAI"} Compatible node?`))try{(await fetch(`/api/provider-nodes/${i}`,{method:"DELETE"})).ok&&t.push("/dashboard/providers")}catch(e){console.log("Error deleting provider node:",e)}},children:"Delete"})]})]}),l.length>0&&(0,s.jsx)("p",{className:"text-sm text-text-muted",children:"Only one connection is allowed per compatible node. Add another node if you need more connections."})]}),(0,s.jsxs)(p.Zp,{children:[(0,s.jsxs)("div",{className:"flex items-center justify-between mb-4",children:[(0,s.jsx)("h2",{className:"text-lg font-semibold",children:"Connections"}),!B&&(0,s.jsx)(p.$n,{size:"sm",icon:"add",onClick:()=>F?k(!0):$(!0),children:"Add"})]}),0===l.length?(0,s.jsxs)("div",{className:"text-center py-12",children:[(0,s.jsx)("div",{className:"inline-flex items-center justify-center w-16 h-16 rounded-full bg-primary/10 text-primary mb-4",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-[32px]",children:F?"lock":"key"})}),(0,s.jsx)("p",{className:"text-text-main font-medium mb-1",children:"No connections yet"}),(0,s.jsx)("p",{className:"text-sm text-text-muted mb-4",children:"Add your first connection to get started"}),!B&&(0,s.jsx)(p.$n,{icon:"add",onClick:()=>F?k(!0):$(!0),children:"Add Connection"})]}):(0,s.jsx)("div",{className:"flex flex-col divide-y divide-black/[0.03] dark:divide-white/[0.03]",children:l.sort((e,t)=>(e.priority||0)-(t.priority||0)).map((e,t)=>(0,s.jsx)(j,{connection:e,isOAuth:F,isFirst:0===t,isLast:t===l.length-1,onMoveUp:()=>er(e,l[t-1]),onMoveDown:()=>er(e,l[t+1]),onToggleActive:t=>el(e.id,t),onEdit:()=>{I(e),O(!0)},onDelete:()=>et(e.id)},e.id))})]}),(0,s.jsxs)(p.Zp,{children:[(0,s.jsx)("h2",{className:"text-lg font-semibold mb-4",children:_.passthroughModels?"Model Aliases":"Available Models"}),B?(0,s.jsx)(g,{providerStorageAlias:Z,providerDisplayAlias:G,modelAliases:P,copied:M,onCopy:L,onSetAlias:Y,onDeleteAlias:ee,connections:l,isAnthropic:V}):_.passthroughModels?(0,s.jsx)(f,{providerAlias:J,modelAliases:P,copied:M,onCopy:L,onSetAlias:Y,onDeleteAlias:ee}):0===z.length?(0,s.jsx)("p",{className:"text-sm text-text-muted",children:"No models configured"}):(0,s.jsx)("div",{className:"flex flex-wrap gap-3",children:z.map(e=>{let t=`${Z}/${e.id}`,a=`${i}/${e.id}`,l=Object.entries(P).find(([,e])=>e===t||e===a)?.[0];return(0,s.jsx)(y,{model:e,fullModel:`${G}/${e.id}`,alias:l,copied:M,onCopy:L,onSetAlias:t=>Y(e.id,t,Z),onDeleteAlias:()=>ee(l)},e.id)})})]}),"kiro"===i?(0,s.jsx)(p.Mh,{isOpen:w,providerInfo:_,onSuccess:ei,onClose:()=>k(!1)}):"cursor"===i?(0,s.jsx)(p.G9,{isOpen:w,onSuccess:ei,onClose:()=>k(!1)}):(0,s.jsx)(p.LF,{isOpen:w,provider:i,providerInfo:_,onSuccess:ei,onClose:()=>k(!1)}),(0,s.jsx)(N,{isOpen:S,provider:i,providerName:_.name,isCompatible:B,isAnthropic:V,onSave:es,onClose:()=>$(!1)}),(0,s.jsx)(C,{isOpen:T,connection:q,onSave:ea,onClose:()=>O(!1)}),B&&(0,s.jsx)(A,{isOpen:E,node:v,onSave:X,onClose:()=>R(!1),isAnthropic:V})]}):(0,s.jsxs)("div",{className:"text-center py-20",children:[(0,s.jsx)("p",{className:"text-text-muted",children:"Provider not found"}),(0,s.jsx)(d(),{href:"/dashboard/providers",className:"text-primary mt-4 inline-block",children:"Back to Providers"})]})}function y({model:e,fullModel:t,alias:i,copied:a,onCopy:l}){return(0,s.jsxs)("div",{className:"flex items-center gap-2 px-3 py-2 rounded-lg border border-border hover:bg-sidebar/50",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",children:"smart_toy"}),(0,s.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:t}),(0,s.jsx)("button",{onClick:()=>l(t,`model-${e.id}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",title:"Copy model",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-sm",children:a===`model-${e.id}`?"check":"content_copy"})})]})}function f({providerAlias:e,modelAliases:t,copied:i,onCopy:l,onSetAlias:r,onDeleteAlias:n}){let[o,d]=(0,a.useState)(""),[c,m]=(0,a.useState)(!1),u=Object.entries(t).filter(([,t])=>t.startsWith(`${e}/`)).map(([t,i])=>({modelId:i.replace(`${e}/`,""),fullModel:i,alias:t})),x=async()=>{let e;if(!o.trim()||c)return;let i=o.trim(),s=(e=i.split("/"))[e.length-1];if(t[s])return void alert(`Alias "${s}" already exists. Please use a different model or edit existing alias.`);m(!0);try{await r(i,s),d("")}catch(e){console.log("Error adding model:",e)}finally{m(!1)}};return(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)("p",{className:"text-sm text-text-muted",children:"OpenRouter supports any model. Add models and create aliases for quick access."}),(0,s.jsxs)("div",{className:"flex items-end gap-2",children:[(0,s.jsxs)("div",{className:"flex-1",children:[(0,s.jsx)("label",{htmlFor:"new-model-input",className:"text-xs text-text-muted mb-1 block",children:"Model ID (from OpenRouter)"}),(0,s.jsx)("input",{id:"new-model-input",type:"text",value:o,onChange:e=>d(e.target.value),onKeyDown:e=>"Enter"===e.key&&x(),placeholder:"anthropic/claude-3-opus",className:"w-full px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary"})]}),(0,s.jsx)(p.$n,{size:"sm",icon:"add",onClick:x,disabled:!o.trim()||c,children:c?"Adding...":"Add"})]}),u.length>0&&(0,s.jsx)("div",{className:"flex flex-col gap-3",children:u.map(({modelId:e,fullModel:t,alias:a})=>(0,s.jsx)(v,{modelId:e,fullModel:t,copied:i,onCopy:l,onDeleteAlias:()=>n(a)},t))})]})}function v({modelId:e,fullModel:t,copied:i,onCopy:a,onDeleteAlias:l}){return(0,s.jsxs)("div",{className:"flex items-center gap-3 p-3 rounded-lg border border-border hover:bg-sidebar/50",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",children:"smart_toy"}),(0,s.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,s.jsx)("p",{className:"text-sm font-medium truncate",children:e}),(0,s.jsxs)("div",{className:"flex items-center gap-1 mt-1",children:[(0,s.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:t}),(0,s.jsx)("button",{onClick:()=>a(t,`model-${e}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",title:"Copy model",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-sm",children:i===`model-${e}`?"check":"content_copy"})})]})]}),(0,s.jsx)("button",{onClick:l,className:"p-1 hover:bg-red-50 rounded text-red-500",title:"Remove model",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-sm",children:"delete"})})]})}function g({providerStorageAlias:e,providerDisplayAlias:t,modelAliases:i,copied:l,onCopy:r,onSetAlias:n,onDeleteAlias:o,connections:d,isAnthropic:c}){let[m,u]=(0,a.useState)(""),[x,h]=(0,a.useState)(!1),[y,f]=(0,a.useState)(!1),g=Object.entries(i).filter(([,t])=>t.startsWith(`${e}/`)).map(([t,i])=>({modelId:i.replace(`${e}/`,""),fullModel:i,alias:t})),b=e=>{let s,a=(s=e.split("/"))[s.length-1];if(!i[a])return a;let l=`${t}-${a}`;return i[l]?null:l},j=async()=>{if(!m.trim()||x)return;let t=m.trim(),i=b(t);if(!i)return void alert("All suggested aliases already exist. Please choose a different model or remove conflicting aliases.");h(!0);try{await n(t,i,e),u("")}catch(e){console.log("Error adding model:",e)}finally{h(!1)}},N=async()=>{if(y)return;let t=d.find(e=>!1!==e.isActive);if(t){f(!0);try{let i=await fetch(`/api/providers/${t.id}/models`),s=await i.json();if(!i.ok)return void alert(s.error||"Failed to import models");let a=s.models||[];if(0===a.length)return void alert("No models returned from /models.");let l=0;for(let t of a){let i=t.id||t.name||t.model;if(!i)continue;let s=b(i);s&&(await n(i,s,e),l+=1)}0===l&&alert("No new models were added.")}catch(e){console.log("Error importing models:",e)}finally{f(!1)}}},C=d.some(e=>!1!==e.isActive);return(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsxs)("p",{className:"text-sm text-text-muted",children:["Add ",c?"Anthropic":"OpenAI","-compatible models manually or import them from the /models endpoint."]}),(0,s.jsxs)("div",{className:"flex items-end gap-2 flex-wrap",children:[(0,s.jsxs)("div",{className:"flex-1 min-w-[240px]",children:[(0,s.jsx)("label",{htmlFor:"new-compatible-model-input",className:"text-xs text-text-muted mb-1 block",children:"Model ID"}),(0,s.jsx)("input",{id:"new-compatible-model-input",type:"text",value:m,onChange:e=>u(e.target.value),onKeyDown:e=>"Enter"===e.key&&j(),placeholder:c?"claude-3-opus-20240229":"gpt-4o",className:"w-full px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary"})]}),(0,s.jsx)(p.$n,{size:"sm",icon:"add",onClick:j,disabled:!m.trim()||x,children:x?"Adding...":"Add"}),(0,s.jsx)(p.$n,{size:"sm",variant:"secondary",icon:"download",onClick:N,disabled:!C||y,children:y?"Importing...":"Import from /models"})]}),!C&&(0,s.jsx)("p",{className:"text-xs text-text-muted",children:"Add a connection to enable importing models."}),g.length>0&&(0,s.jsx)("div",{className:"flex flex-col gap-3",children:g.map(({modelId:e,fullModel:i,alias:a})=>(0,s.jsx)(v,{modelId:e,fullModel:`${t}/${e}`,copied:l,onCopy:r,onDeleteAlias:()=>o(a)},i))})]})}function b({until:e}){let[t,i]=(0,a.useState)("");return((0,a.useEffect)(()=>{let t=()=>{let t=new Date(e).getTime()-Date.now();if(t<=0)return void i("");let s=Math.floor(t/1e3);if(s<60)i(`${s}s`);else if(s<3600)i(`${Math.floor(s/60)}m ${s%60}s`);else{let e=Math.floor(s/3600),t=Math.floor(s%3600/60);i(`${e}h ${t}m`)}};t();let s=setInterval(t,1e3);return()=>clearInterval(s)},[e]),t)?(0,s.jsxs)("span",{className:"text-xs text-orange-500 font-mono",children:["⏱ ",t]}):null}function j({connection:e,isOAuth:t,isFirst:i,isLast:l,onMoveUp:r,onMoveDown:n,onToggleActive:o,onEdit:d,onDelete:c}){let m=t?e.name||e.email||e.displayName||"OAuth Account":e.name,[u,x]=(0,a.useState)(!1);(0,a.useEffect)(()=>{let t=()=>{x(e.rateLimitedUntil&&new Date(e.rateLimitedUntil).getTime()>Date.now())};t();let i=e.rateLimitedUntil?setInterval(t,1e3):null;return()=>{i&&clearInterval(i)}},[e.rateLimitedUntil]);let h="unavailable"!==e.testStatus||u?e.testStatus:"active";return(0,s.jsxs)("div",{className:`group flex items-center justify-between p-3 rounded-lg hover:bg-black/[0.02] dark:hover:bg-white/[0.02] transition-colors ${!1===e.isActive?"opacity-60":""}`,children:[(0,s.jsxs)("div",{className:"flex items-center gap-3 flex-1 min-w-0",children:[(0,s.jsxs)("div",{className:"flex flex-col",children:[(0,s.jsx)("button",{onClick:r,disabled:i,className:`p-0.5 rounded ${i?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,s.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_up"})}),(0,s.jsx)("button",{onClick:n,disabled:l,className:`p-0.5 rounded ${l?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,s.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_down"})})]}),(0,s.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",children:t?"lock":"key"}),(0,s.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,s.jsx)("p",{className:"text-sm font-medium truncate",children:m}),(0,s.jsxs)("div",{className:"flex items-center gap-2 mt-1",children:[(0,s.jsx)(p.Ex,{variant:!1===e.isActive?"default":"active"===h||"success"===h?"success":"error"===h||"expired"===h||"unavailable"===h?"error":"default",size:"sm",dot:!0,children:!1===e.isActive?"disabled":h||"Unknown"}),u&&!1!==e.isActive&&(0,s.jsx)(b,{until:e.rateLimitedUntil}),e.lastError&&!1!==e.isActive&&(0,s.jsx)("span",{className:"text-xs text-red-500 truncate max-w-[300px]",title:e.lastError,children:e.lastError}),(0,s.jsxs)("span",{className:"text-xs text-text-muted",children:["#",e.priority]}),e.globalPriority&&(0,s.jsxs)("span",{className:"text-xs text-text-muted",children:["Auto: ",e.globalPriority]})]})]})]}),(0,s.jsxs)("div",{className:"flex items-center gap-2",children:[(0,s.jsx)(p.lM,{size:"sm",checked:e.isActive??!0,onChange:o,title:e.isActive??!0?"Disable connection":"Enable connection"}),(0,s.jsxs)("div",{className:"flex gap-1 ml-1 opacity-0 group-hover:opacity-100 transition-opacity",children:[(0,s.jsx)("button",{onClick:d,className:"p-2 hover:bg-black/5 dark:hover:bg-white/5 rounded text-text-muted hover:text-primary",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"edit"})}),(0,s.jsx)("button",{onClick:c,className:"p-2 hover:bg-red-500/10 rounded text-red-500",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"delete"})})]})]})]})}function N({isOpen:e,provider:t,providerName:i,isCompatible:l,isAnthropic:r,onSave:n,onClose:o}){let[d,c]=(0,a.useState)({name:"",apiKey:"",priority:1}),[m,u]=(0,a.useState)(!1),[x,h]=(0,a.useState)(null),[y,f]=(0,a.useState)(!1),v=async()=>{u(!0);try{let e=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:d.apiKey})}),i=await e.json();h(i.valid?"success":"failed")}catch{h("failed")}finally{u(!1)}},g=async()=>{if(t&&d.apiKey){f(!0);try{let e=!1;try{u(!0),h(null);let i=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:d.apiKey})});e=!!(await i.json()).valid,h(e?"success":"failed")}catch{h("failed")}finally{u(!1)}await n({name:d.name,apiKey:d.apiKey,priority:d.priority,testStatus:e?"active":"unknown"})}finally{f(!1)}}};return t?(0,s.jsx)(p.aF,{isOpen:e,title:`Add ${i||t} API Key`,onClose:o,children:(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)(p.pd,{label:"Name",value:d.name,onChange:e=>c({...d,name:e.target.value}),placeholder:"Production Key"}),(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(p.pd,{label:"API Key",type:"password",value:d.apiKey,onChange:e=>c({...d,apiKey:e.target.value}),className:"flex-1"}),(0,s.jsx)("div",{className:"pt-6",children:(0,s.jsx)(p.$n,{onClick:v,disabled:!d.apiKey||m||y,variant:"secondary",children:m?"Checking...":"Check"})})]}),x&&(0,s.jsx)(p.Ex,{variant:"success"===x?"success":"error",children:"success"===x?"Valid":"Invalid"}),l&&(0,s.jsx)("p",{className:"text-xs text-text-muted",children:r?`Validation checks ${i||"Anthropic Compatible"} by verifying the API key.`:`Validation checks ${i||"OpenAI Compatible"} via /models on your base URL.`}),(0,s.jsx)(p.pd,{label:"Priority",type:"number",value:d.priority,onChange:e=>c({...d,priority:Number.parseInt(e.target.value)||1})}),(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(p.$n,{onClick:g,fullWidth:!0,disabled:!d.name||!d.apiKey||y,children:y?"Saving...":"Save"}),(0,s.jsx)(p.$n,{onClick:o,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function C({isOpen:e,connection:t,onSave:i,onClose:l}){let[r,n]=(0,a.useState)({name:"",priority:1,apiKey:""}),[o,d]=(0,a.useState)(!1),[c,u]=(0,a.useState)(null),[x,h]=(0,a.useState)(!1),[y,f]=(0,a.useState)(null),[v,g]=(0,a.useState)(!1);(0,a.useEffect)(()=>{t&&(n({name:t.name||"",priority:t.priority||1,apiKey:""}),u(null),f(null))},[t]);let b=async()=>{if(t?.provider){d(!0),u(null);try{let e=await fetch(`/api/providers/${t.id}/test`,{method:"POST"}),i=await e.json();u(i.valid?"success":"failed")}catch{u("failed")}finally{d(!1)}}},j=async()=>{if(t?.provider&&r.apiKey){h(!0),f(null);try{let e=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t.provider,apiKey:r.apiKey})}),i=await e.json();f(i.valid?"success":"failed")}catch{f("failed")}finally{h(!1)}}},N=async()=>{g(!0);try{let e={name:r.name,priority:r.priority};if(!C&&r.apiKey){e.apiKey=r.apiKey;let i="success"===y;if(!i)try{h(!0),f(null);let e=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t.provider,apiKey:r.apiKey})});i=!!(await e.json()).valid,f(i?"success":"failed")}catch{f("failed")}finally{h(!1)}i&&(e.testStatus="active",e.lastError=null,e.lastErrorAt=null)}await i(e)}finally{g(!1)}};if(!t)return null;let C="oauth"===t.authType,A=(0,m.mq)(t.provider)||(0,m.gb)(t.provider);return(0,s.jsx)(p.aF,{isOpen:e,title:"Edit Connection",onClose:l,children:(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)(p.pd,{label:"Name",value:r.name,onChange:e=>n({...r,name:e.target.value}),placeholder:C?"Account name":"Production Key"}),C&&t.email&&(0,s.jsxs)("div",{className:"bg-sidebar/50 p-3 rounded-lg",children:[(0,s.jsx)("p",{className:"text-sm text-text-muted mb-1",children:"Email"}),(0,s.jsx)("p",{className:"font-medium",children:t.email})]}),(0,s.jsx)(p.pd,{label:"Priority",type:"number",value:r.priority,onChange:e=>n({...r,priority:Number.parseInt(e.target.value)||1})}),!C&&(0,s.jsxs)(s.Fragment,{children:[(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(p.pd,{label:"API Key",type:"password",value:r.apiKey,onChange:e=>n({...r,apiKey:e.target.value}),placeholder:"Enter new API key",hint:"Leave blank to keep the current API key.",className:"flex-1"}),(0,s.jsx)("div",{className:"pt-6",children:(0,s.jsx)(p.$n,{onClick:j,disabled:!r.apiKey||x||v,variant:"secondary",children:x?"Checking...":"Check"})})]}),y&&(0,s.jsx)(p.Ex,{variant:"success"===y?"success":"error",children:"success"===y?"Valid":"Invalid"})]}),!A&&(0,s.jsxs)("div",{className:"flex items-center gap-3",children:[(0,s.jsx)(p.$n,{onClick:b,variant:"secondary",disabled:o,children:o?"Testing...":"Test Connection"}),c&&(0,s.jsx)(p.Ex,{variant:"success"===c?"success":"error",children:"success"===c?"Valid":"Failed"})]}),(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(p.$n,{onClick:N,fullWidth:!0,disabled:v,children:v?"Saving...":"Save"}),(0,s.jsx)(p.$n,{onClick:l,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})})}function A({isOpen:e,node:t,onSave:i,onClose:l,isAnthropic:r}){let[n,o]=(0,a.useState)({name:"",prefix:"",apiType:"chat",baseUrl:"https://api.openai.com/v1"}),[d,c]=(0,a.useState)(!1),[m,u]=(0,a.useState)(""),[x,h]=(0,a.useState)(!1),[y,f]=(0,a.useState)(null);(0,a.useEffect)(()=>{t&&o({name:t.name||"",prefix:t.prefix||"",apiType:t.apiType||"chat",baseUrl:t.baseUrl||(r?"https://api.anthropic.com/v1":"https://api.openai.com/v1")})},[t,r]);let v=async()=>{if(n.name.trim()&&n.prefix.trim()&&n.baseUrl.trim()){c(!0);try{let e={name:n.name,prefix:n.prefix,baseUrl:n.baseUrl};r||(e.apiType=n.apiType),await i(e)}finally{c(!1)}}},g=async()=>{h(!0);try{let e=await fetch("/api/provider-nodes/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({baseUrl:n.baseUrl,apiKey:m,type:r?"anthropic-compatible":"openai-compatible"})}),t=await e.json();f(t.valid?"success":"failed")}catch{f("failed")}finally{h(!1)}};return t?(0,s.jsx)(p.aF,{isOpen:e,title:`Edit ${r?"Anthropic":"OpenAI"} Compatible`,onClose:l,children:(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)(p.pd,{label:"Name",value:n.name,onChange:e=>o({...n,name:e.target.value}),placeholder:`${r?"Anthropic":"OpenAI"} Compatible (Prod)`,hint:"Required. A friendly label for this node."}),(0,s.jsx)(p.pd,{label:"Prefix",value:n.prefix,onChange:e=>o({...n,prefix:e.target.value}),placeholder:r?"ac-prod":"oc-prod",hint:"Required. Used as the provider prefix for model IDs."}),!r&&(0,s.jsx)(p.l6,{label:"API Type",options:[{value:"chat",label:"Chat Completions"},{value:"responses",label:"Responses API"}],value:n.apiType,onChange:e=>o({...n,apiType:e.target.value})}),(0,s.jsx)(p.pd,{label:"Base URL",value:n.baseUrl,onChange:e=>o({...n,baseUrl:e.target.value}),placeholder:r?"https://api.anthropic.com/v1":"https://api.openai.com/v1",hint:`Use the base URL (ending in /v1) for your ${r?"Anthropic":"OpenAI"}-compatible API.`}),(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(p.pd,{label:"API Key (for Check)",type:"password",value:m,onChange:e=>u(e.target.value),className:"flex-1"}),(0,s.jsx)("div",{className:"pt-6",children:(0,s.jsx)(p.$n,{onClick:g,disabled:!m||x||!n.baseUrl.trim(),variant:"secondary",children:x?"Checking...":"Check"})})]}),y&&(0,s.jsx)(p.Ex,{variant:"success"===y?"success":"error",children:"success"===y?"Valid":"Invalid"}),(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(p.$n,{onClick:v,fullWidth:!0,disabled:!n.name.trim()||!n.prefix.trim()||!n.baseUrl.trim()||d,children:d?"Saving...":"Save"}),(0,s.jsx)(p.$n,{onClick:l,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}y.propTypes={model:r().shape({id:r().string.isRequired}).isRequired,fullModel:r().string.isRequired,alias:r().string,copied:r().string,onCopy:r().func.isRequired},f.propTypes={providerAlias:r().string.isRequired,modelAliases:r().object.isRequired,copied:r().string,onCopy:r().func.isRequired,onSetAlias:r().func.isRequired,onDeleteAlias:r().func.isRequired},v.propTypes={modelId:r().string.isRequired,fullModel:r().string.isRequired,copied:r().string,onCopy:r().func.isRequired,onDeleteAlias:r().func.isRequired},g.propTypes={providerStorageAlias:r().string.isRequired,providerDisplayAlias:r().string.isRequired,modelAliases:r().object.isRequired,copied:r().string,onCopy:r().func.isRequired,onSetAlias:r().func.isRequired,onDeleteAlias:r().func.isRequired,connections:r().arrayOf(r().shape({id:r().string,isActive:r().bool})).isRequired,isAnthropic:r().bool},b.propTypes={until:r().string.isRequired},j.propTypes={connection:r().shape({id:r().string,name:r().string,email:r().string,displayName:r().string,rateLimitedUntil:r().string,testStatus:r().string,isActive:r().bool,lastError:r().string,priority:r().number,globalPriority:r().number}).isRequired,isOAuth:r().bool.isRequired,isFirst:r().bool.isRequired,isLast:r().bool.isRequired,onMoveUp:r().func.isRequired,onMoveDown:r().func.isRequired,onToggleActive:r().func.isRequired,onEdit:r().func.isRequired,onDelete:r().func.isRequired},N.propTypes={isOpen:r().bool.isRequired,provider:r().string,providerName:r().string,isCompatible:r().bool,isAnthropic:r().bool,onSave:r().func.isRequired,onClose:r().func.isRequired},C.propTypes={isOpen:r().bool.isRequired,connection:r().shape({id:r().string,name:r().string,email:r().string,priority:r().number,authType:r().string,provider:r().string}),onSave:r().func.isRequired,onClose:r().func.isRequired},A.propTypes={isOpen:r().bool.isRequired,node:r().shape({id:r().string,name:r().string,prefix:r().string,apiType:r().string,baseUrl:r().string}),onSave:r().func.isRequired,onClose:r().func.isRequired,isAnthropic:r().bool}}},e=>{e.O(0,[600,3624,8729,5497,8441,3794,7358],()=>e(e.s=2397)),_N_E=e.O()}]);