ktrouter 1.1.1 → 1.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (272) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +5 -5
  3. package/app/.next/build-manifest.json +2 -2
  4. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
  5. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/[toolId]/page_client-reference-manifest.js +1 -1
  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/console-log/page_client-reference-manifest.js +1 -1
  9. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  10. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page_client-reference-manifest.js +1 -1
  11. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page_client-reference-manifest.js +1 -1
  12. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page_client-reference-manifest.js +1 -1
  13. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page_client-reference-manifest.js +1 -1
  14. package/app/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
  15. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  16. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +2 -2
  18. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  19. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  20. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  21. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
  22. package/app/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
  23. package/app/.next/server/app/(dashboard)/dashboard/skills/page_client-reference-manifest.js +1 -1
  24. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  25. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  26. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  27. package/app/.next/server/app/_global-error.html +1 -1
  28. package/app/.next/server/app/_global-error.rsc +1 -1
  29. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  30. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  31. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  32. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  33. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  34. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  35. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  36. package/app/.next/server/app/_not-found.html +1 -1
  37. package/app/.next/server/app/_not-found.rsc +3 -3
  38. package/app/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  39. package/app/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  40. package/app/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  41. package/app/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  42. package/app/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  43. package/app/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  44. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  45. package/app/.next/server/app/callback.html +1 -1
  46. package/app/.next/server/app/callback.rsc +3 -3
  47. package/app/.next/server/app/callback.segments/_full.segment.rsc +3 -3
  48. package/app/.next/server/app/callback.segments/_head.segment.rsc +1 -1
  49. package/app/.next/server/app/callback.segments/_index.segment.rsc +3 -3
  50. package/app/.next/server/app/callback.segments/_tree.segment.rsc +1 -1
  51. package/app/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +1 -1
  52. package/app/.next/server/app/callback.segments/callback.segment.rsc +1 -1
  53. package/app/.next/server/app/dashboard/basic-chat.html +1 -1
  54. package/app/.next/server/app/dashboard/basic-chat.rsc +5 -5
  55. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat/__PAGE__.segment.rsc +2 -2
  56. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat.segment.rsc +1 -1
  57. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  58. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  59. package/app/.next/server/app/dashboard/basic-chat.segments/_full.segment.rsc +5 -5
  60. package/app/.next/server/app/dashboard/basic-chat.segments/_head.segment.rsc +1 -1
  61. package/app/.next/server/app/dashboard/basic-chat.segments/_index.segment.rsc +3 -3
  62. package/app/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +1 -1
  63. package/app/.next/server/app/dashboard/cli-tools.html +1 -1
  64. package/app/.next/server/app/dashboard/cli-tools.rsc +5 -5
  65. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +2 -2
  66. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +1 -1
  67. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  68. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  69. package/app/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +5 -5
  70. package/app/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +1 -1
  71. package/app/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +3 -3
  72. package/app/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +1 -1
  73. package/app/.next/server/app/dashboard/combos.html +1 -1
  74. package/app/.next/server/app/dashboard/combos.rsc +5 -5
  75. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +2 -2
  76. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +1 -1
  77. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  78. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  79. package/app/.next/server/app/dashboard/combos.segments/_full.segment.rsc +5 -5
  80. package/app/.next/server/app/dashboard/combos.segments/_head.segment.rsc +1 -1
  81. package/app/.next/server/app/dashboard/combos.segments/_index.segment.rsc +3 -3
  82. package/app/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +1 -1
  83. package/app/.next/server/app/dashboard/endpoint.html +1 -1
  84. package/app/.next/server/app/dashboard/endpoint.rsc +5 -5
  85. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +2 -2
  86. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +1 -1
  87. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  88. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  89. package/app/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +5 -5
  90. package/app/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +1 -1
  91. package/app/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +3 -3
  92. package/app/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +1 -1
  93. package/app/.next/server/app/dashboard/media-providers/web.html +1 -1
  94. package/app/.next/server/app/dashboard/media-providers/web.rsc +5 -5
  95. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard/media-providers/web/__PAGE__.segment.rsc +2 -2
  96. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard/media-providers/web.segment.rsc +1 -1
  97. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard/media-providers.segment.rsc +1 -1
  98. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  99. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  100. package/app/.next/server/app/dashboard/media-providers/web.segments/_full.segment.rsc +5 -5
  101. package/app/.next/server/app/dashboard/media-providers/web.segments/_head.segment.rsc +1 -1
  102. package/app/.next/server/app/dashboard/media-providers/web.segments/_index.segment.rsc +3 -3
  103. package/app/.next/server/app/dashboard/media-providers/web.segments/_tree.segment.rsc +1 -1
  104. package/app/.next/server/app/dashboard/mitm.html +1 -1
  105. package/app/.next/server/app/dashboard/mitm.rsc +5 -5
  106. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm/__PAGE__.segment.rsc +2 -2
  107. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm.segment.rsc +1 -1
  108. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  109. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  110. package/app/.next/server/app/dashboard/mitm.segments/_full.segment.rsc +5 -5
  111. package/app/.next/server/app/dashboard/mitm.segments/_head.segment.rsc +1 -1
  112. package/app/.next/server/app/dashboard/mitm.segments/_index.segment.rsc +3 -3
  113. package/app/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +1 -1
  114. package/app/.next/server/app/dashboard/profile.html +1 -1
  115. package/app/.next/server/app/dashboard/profile.rsc +5 -5
  116. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +2 -2
  117. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +1 -1
  118. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  119. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  120. package/app/.next/server/app/dashboard/profile.segments/_full.segment.rsc +5 -5
  121. package/app/.next/server/app/dashboard/profile.segments/_head.segment.rsc +1 -1
  122. package/app/.next/server/app/dashboard/profile.segments/_index.segment.rsc +3 -3
  123. package/app/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +1 -1
  124. package/app/.next/server/app/dashboard/providers/new.html +1 -1
  125. package/app/.next/server/app/dashboard/providers/new.rsc +5 -5
  126. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +2 -2
  127. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +1 -1
  128. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  129. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  130. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  131. package/app/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +5 -5
  132. package/app/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +1 -1
  133. package/app/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +3 -3
  134. package/app/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +1 -1
  135. package/app/.next/server/app/dashboard/providers.html +1 -1
  136. package/app/.next/server/app/dashboard/providers.rsc +5 -5
  137. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +2 -2
  138. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  139. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  140. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  141. package/app/.next/server/app/dashboard/providers.segments/_full.segment.rsc +5 -5
  142. package/app/.next/server/app/dashboard/providers.segments/_head.segment.rsc +1 -1
  143. package/app/.next/server/app/dashboard/providers.segments/_index.segment.rsc +3 -3
  144. package/app/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +1 -1
  145. package/app/.next/server/app/dashboard/proxy-pools.html +1 -1
  146. package/app/.next/server/app/dashboard/proxy-pools.rsc +5 -5
  147. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools/__PAGE__.segment.rsc +2 -2
  148. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools.segment.rsc +1 -1
  149. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  150. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  151. package/app/.next/server/app/dashboard/proxy-pools.segments/_full.segment.rsc +5 -5
  152. package/app/.next/server/app/dashboard/proxy-pools.segments/_head.segment.rsc +1 -1
  153. package/app/.next/server/app/dashboard/proxy-pools.segments/_index.segment.rsc +3 -3
  154. package/app/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +1 -1
  155. package/app/.next/server/app/dashboard/quota.html +2 -2
  156. package/app/.next/server/app/dashboard/quota.rsc +6 -6
  157. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota/__PAGE__.segment.rsc +3 -3
  158. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota.segment.rsc +1 -1
  159. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  160. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  161. package/app/.next/server/app/dashboard/quota.segments/_full.segment.rsc +6 -6
  162. package/app/.next/server/app/dashboard/quota.segments/_head.segment.rsc +1 -1
  163. package/app/.next/server/app/dashboard/quota.segments/_index.segment.rsc +3 -3
  164. package/app/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +1 -1
  165. package/app/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  166. package/app/.next/server/app/dashboard/settings/pricing.html +1 -1
  167. package/app/.next/server/app/dashboard/settings/pricing.rsc +3 -3
  168. package/app/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +3 -3
  169. package/app/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +1 -1
  170. package/app/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +3 -3
  171. package/app/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +1 -1
  172. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +1 -1
  173. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +1 -1
  174. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +1 -1
  175. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +1 -1
  176. package/app/.next/server/app/dashboard/skills.html +1 -1
  177. package/app/.next/server/app/dashboard/skills.rsc +5 -5
  178. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk/dashboard/skills/__PAGE__.segment.rsc +2 -2
  179. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk/dashboard/skills.segment.rsc +1 -1
  180. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  181. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  182. package/app/.next/server/app/dashboard/skills.segments/_full.segment.rsc +5 -5
  183. package/app/.next/server/app/dashboard/skills.segments/_head.segment.rsc +1 -1
  184. package/app/.next/server/app/dashboard/skills.segments/_index.segment.rsc +3 -3
  185. package/app/.next/server/app/dashboard/skills.segments/_tree.segment.rsc +1 -1
  186. package/app/.next/server/app/dashboard/translator.html +1 -1
  187. package/app/.next/server/app/dashboard/translator.rsc +5 -5
  188. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +2 -2
  189. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +1 -1
  190. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  191. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  192. package/app/.next/server/app/dashboard/translator.segments/_full.segment.rsc +5 -5
  193. package/app/.next/server/app/dashboard/translator.segments/_head.segment.rsc +1 -1
  194. package/app/.next/server/app/dashboard/translator.segments/_index.segment.rsc +3 -3
  195. package/app/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +1 -1
  196. package/app/.next/server/app/dashboard/usage.html +1 -1
  197. package/app/.next/server/app/dashboard/usage.rsc +5 -5
  198. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +2 -2
  199. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +1 -1
  200. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  201. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  202. package/app/.next/server/app/dashboard/usage.segments/_full.segment.rsc +5 -5
  203. package/app/.next/server/app/dashboard/usage.segments/_head.segment.rsc +1 -1
  204. package/app/.next/server/app/dashboard/usage.segments/_index.segment.rsc +3 -3
  205. package/app/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +1 -1
  206. package/app/.next/server/app/dashboard.html +1 -1
  207. package/app/.next/server/app/dashboard.rsc +5 -5
  208. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +2 -2
  209. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  210. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  211. package/app/.next/server/app/dashboard.segments/_full.segment.rsc +5 -5
  212. package/app/.next/server/app/dashboard.segments/_head.segment.rsc +1 -1
  213. package/app/.next/server/app/dashboard.segments/_index.segment.rsc +3 -3
  214. package/app/.next/server/app/dashboard.segments/_tree.segment.rsc +1 -1
  215. package/app/.next/server/app/index.html +1 -1
  216. package/app/.next/server/app/index.rsc +3 -3
  217. package/app/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  218. package/app/.next/server/app/index.segments/_full.segment.rsc +3 -3
  219. package/app/.next/server/app/index.segments/_head.segment.rsc +1 -1
  220. package/app/.next/server/app/index.segments/_index.segment.rsc +3 -3
  221. package/app/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  222. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  223. package/app/.next/server/app/landing.html +1 -1
  224. package/app/.next/server/app/landing.rsc +3 -3
  225. package/app/.next/server/app/landing.segments/_full.segment.rsc +3 -3
  226. package/app/.next/server/app/landing.segments/_head.segment.rsc +1 -1
  227. package/app/.next/server/app/landing.segments/_index.segment.rsc +3 -3
  228. package/app/.next/server/app/landing.segments/_tree.segment.rsc +1 -1
  229. package/app/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +1 -1
  230. package/app/.next/server/app/landing.segments/landing.segment.rsc +1 -1
  231. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  232. package/app/.next/server/app/login.html +1 -1
  233. package/app/.next/server/app/login.rsc +4 -4
  234. package/app/.next/server/app/login.segments/_full.segment.rsc +4 -4
  235. package/app/.next/server/app/login.segments/_head.segment.rsc +1 -1
  236. package/app/.next/server/app/login.segments/_index.segment.rsc +3 -3
  237. package/app/.next/server/app/login.segments/_tree.segment.rsc +1 -1
  238. package/app/.next/server/app/login.segments/login/__PAGE__.segment.rsc +2 -2
  239. package/app/.next/server/app/login.segments/login.segment.rsc +1 -1
  240. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  241. package/app/.next/server/app-paths-manifest.json +5 -5
  242. package/app/.next/server/chunks/2029.js +1 -1
  243. package/app/.next/server/chunks/2722.js +1 -1
  244. package/app/.next/server/chunks/412.js +1 -1
  245. package/app/.next/server/chunks/4404.js +1 -1
  246. package/app/.next/server/chunks/4820.js +1 -1
  247. package/app/.next/server/chunks/4884.js +1 -1
  248. package/app/.next/server/chunks/5718.js +1 -1
  249. package/app/.next/server/chunks/9142.js +1 -1
  250. package/app/.next/server/middleware-build-manifest.js +1 -1
  251. package/app/.next/server/middleware.js +1 -1
  252. package/app/.next/server/pages/404.html +1 -1
  253. package/app/.next/server/pages/500.html +1 -1
  254. package/app/.next/static/chunks/1321-0d17eb2cdb3c271c.js +1 -0
  255. package/app/{.next-cli-build/static/chunks/5497-d6ff7b6a239deb68.js → .next/static/chunks/5497-00a27f5d1a376aed.js} +1 -1
  256. package/app/.next/static/chunks/{6069-0119c69cf786aea4.js → 6069-7212bf60ef116c9d.js} +1 -1
  257. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-820f3344240f98b4.js +3 -0
  258. package/app/.next-cli-build/static/chunks/1321-0d17eb2cdb3c271c.js +1 -0
  259. package/app/{.next/static/chunks/5497-d6ff7b6a239deb68.js → .next-cli-build/static/chunks/5497-00a27f5d1a376aed.js} +1 -1
  260. package/app/.next-cli-build/static/chunks/{6069-0119c69cf786aea4.js → 6069-7212bf60ef116c9d.js} +1 -1
  261. package/app/.next-cli-build/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-820f3344240f98b4.js +3 -0
  262. package/app/package.json +2 -2
  263. package/app/src/mitm/server.js +2 -2
  264. package/package.json +2 -2
  265. package/app/.next/static/chunks/1321-24b400ddf2b790cc.js +0 -1
  266. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-eaf1901db53c3f6b.js +0 -3
  267. package/app/.next-cli-build/static/chunks/1321-24b400ddf2b790cc.js +0 -1
  268. package/app/.next-cli-build/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-eaf1901db53c3f6b.js +0 -3
  269. /package/app/.next/static/{T_8jxnjC9lP9zXO0ueMK0 → jyXpy67B4EkYvokitcrfF}/_buildManifest.js +0 -0
  270. /package/app/.next/static/{T_8jxnjC9lP9zXO0ueMK0 → jyXpy67B4EkYvokitcrfF}/_ssgManifest.js +0 -0
  271. /package/app/.next-cli-build/static/{T_8jxnjC9lP9zXO0ueMK0 → jyXpy67B4EkYvokitcrfF}/_buildManifest.js +0 -0
  272. /package/app/.next-cli-build/static/{T_8jxnjC9lP9zXO0ueMK0 → jyXpy67B4EkYvokitcrfF}/_ssgManifest.js +0 -0
@@ -1,4 +1,4 @@
1
- "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6069],{3534:(e,t,s)=>{s.d(t,{dM:()=>a,wn:()=>l});let l={antigravity:{id:"antigravity",name:"Antigravity",image:"/providers/antigravity.png",color:"#4285F4",description:"Google Antigravity IDE with MITM",configType:"mitm",mitmDomain:"daily-cloudcode-pa.googleapis.com",modelAliases:["gemini-3.5-flash-high","gemini-3.5-flash-medium","gemini-3.1-pro-high","gemini-3.1-pro-low","claude-sonnet-4-6-thinking","claude-opus-4-6-thinking","gpt-oss-120b-medium"],defaultModels:[{id:"gemini-3.5-flash-high",name:"Gemini 3.5 Flash (High)",alias:"gemini-3.5-flash-high"},{id:"gemini-3.5-flash-medium",name:"Gemini 3.5 Flash (Medium)",alias:"gemini-3.5-flash-medium"},{id:"gemini-3.1-pro-high",name:"Gemini 3.1 Pro (High)",alias:"gemini-3.1-pro-high"},{id:"gemini-3.1-pro-low",name:"Gemini 3.1 Pro (Low)",alias:"gemini-3.1-pro-low"},{id:"claude-sonnet-4-6-thinking",name:"Claude Sonnet 4.6 (Thinking)",alias:"claude-sonnet-4-6-thinking"},{id:"claude-opus-4-6-thinking",name:"Claude Opus 4.6 (Thinking)",alias:"claude-opus-4-6-thinking"},{id:"gpt-oss-120b-medium",name:"GPT-OSS 120B (Medium)",alias:"gpt-oss-120b-medium"}]},copilot:{id:"copilot",name:"GitHub Copilot",image:"/providers/copilot.png",color:"#1F6FEB",description:"GitHub Copilot IDE with MITM",configType:"mitm",mitmDomain:"api.individual.githubcopilot.com",modelAliases:["gpt-4o-mini","claude-haiku-4.5","gpt-4o","gpt-5-mini"],defaultModels:[{id:"gpt-4o",name:"GPT-4o",alias:"gpt-4o"},{id:"gpt-4.1",name:"GPT-4.1",alias:"gpt-4.1"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5",alias:"claude-haiku-4.5"}]},kiro:{id:"kiro",name:"Kiro",image:"/providers/kiro.png",color:"#FF6B00",description:"Kiro IDE with MITM",configType:"mitm",mitmDomain:"q.us-east-1.amazonaws.com",modelAliases:["auto","claude-opus-4.7","claude-opus-4.6","claude-sonnet-4.6","claude-sonnet-4.5","claude-sonnet-4","claude-haiku-4.5","deepseek-3.2","minimax-m2.5","minimax-m2.1","glm-5","qwen3-coder-next","simple-task"],defaultModels:[{id:"auto",name:"Auto",alias:"auto"},{id:"claude-opus-4.7",name:"Claude Opus 4.7",alias:"claude-opus-4.7"},{id:"claude-opus-4.6",name:"Claude Opus 4.6",alias:"claude-opus-4.6"},{id:"claude-sonnet-4.6",name:"Claude Sonnet 4.6",alias:"claude-sonnet-4.6"},{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5",alias:"claude-sonnet-4.5"},{id:"claude-sonnet-4",name:"Claude Sonnet 4",alias:"claude-sonnet-4"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5",alias:"claude-haiku-4.5"},{id:"deepseek-3.2",name:"DeepSeek 3.2",alias:"deepseek-3.2"},{id:"minimax-m2.5",name:"MiniMax M2.5",alias:"minimax-m2.5"},{id:"minimax-m2.1",name:"MiniMax M2.1",alias:"minimax-m2.1"},{id:"glm-5",name:"GLM-5",alias:"glm-5"},{id:"qwen3-coder-next",name:"Qwen3 Coder Next",alias:"qwen3-coder-next"},{id:"simple-task",name:"Qwen3 Coder Next",alias:"simple-task"}]}},a={claude:{id:"claude",name:"Claude Code",image:"/providers/claude.png",color:"#D97757",description:"Anthropic Claude Code CLI",configType:"env",envVars:{baseUrl:"ANTHROPIC_BASE_URL",model:"ANTHROPIC_MODEL",opusModel:"ANTHROPIC_DEFAULT_OPUS_MODEL",sonnetModel:"ANTHROPIC_DEFAULT_SONNET_MODEL",haikuModel:"ANTHROPIC_DEFAULT_HAIKU_MODEL"},modelAliases:["default","sonnet","opus","haiku","opusplan"],settingsFile:"~/.claude/settings.json",defaultModels:[{id:"opus",name:"Claude Opus",alias:"opus",envKey:"ANTHROPIC_DEFAULT_OPUS_MODEL",defaultValue:"cc/claude-opus-4-6"},{id:"sonnet",name:"Claude Sonnet",alias:"sonnet",envKey:"ANTHROPIC_DEFAULT_SONNET_MODEL",defaultValue:"cc/claude-sonnet-4-6"},{id:"haiku",name:"Claude Haiku",alias:"haiku",envKey:"ANTHROPIC_DEFAULT_HAIKU_MODEL",defaultValue:"cc/claude-haiku-4-5-20251001"}]},openclaw:{id:"openclaw",name:"Open Claw",image:"/providers/openclaw.png",color:"#FF6B35",description:"Open Claw AI Assistant",configType:"custom"},codex:{id:"codex",name:"OpenAI Codex CLI / App",image:"/providers/codex.png",color:"#10A37F",description:"OpenAI Codex CLI",configType:"custom"},opencode:{id:"opencode",name:"OpenCode",image:"/providers/opencode.png",color:"#E87040",description:"OpenCode AI Terminal Assistant",configType:"custom"},cowork:{id:"cowork",name:"Claude Cowork",image:"/providers/claude.png",color:"#D97757",description:"Claude Desktop Cowork (third-party inference)",configType:"custom",modelAliases:["opus","sonnet","haiku","codex","kiro-sonnet"],defaultModels:[{id:"claude-opus-4-7",name:"Claude Opus 4.7",alias:"opus",defaultValue:"cc/claude-opus-4-7"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6",alias:"sonnet",defaultValue:"cc/claude-sonnet-4-6"},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5",alias:"haiku",defaultValue:"cc/claude-haiku-4-5-20251001"},{id:"gpt-5.5",name:"GPT 5.5",alias:"codex",defaultValue:"cx/gpt-5.5"},{id:"kiro-claude-sonnet-4.6",name:"Kiro Claude Sonnet 4.6",alias:"kiro-sonnet",defaultValue:"kr/claude-sonnet-4.6"}]},hermes:{id:"hermes",name:"Hermes Agent",image:"/providers/hermes.png",color:"#8B5CF6",description:"Nous Research self-improving AI agent",configType:"custom"},droid:{id:"droid",name:"Factory Droid",image:"/providers/droid.png",color:"#00D4FF",description:"Factory Droid AI Assistant",configType:"custom"},cursor:{id:"cursor",name:"Cursor",image:"/providers/cursor.png",color:"#000000",description:"Cursor AI Code Editor",configType:"guide",requiresExternalUrl:!0,notes:[{type:"warning",text:"Requires Cursor Pro account to use this feature."},{type:"cloudCheck",text:"Cursor routes requests through its own server, so local endpoint is not supported. Please enable Tunnel or Cloud Endpoint in Settings."}],guideSteps:[{step:1,title:"Open Settings",desc:"Go to Settings → Models"},{step:2,title:"Enable OpenAI API",desc:'Enable "OpenAI API key" option'},{step:3,title:"Base URL",value:"{{baseUrl}}",copyable:!0},{step:4,title:"API Key",type:"apiKeySelector"},{step:5,title:"Add Custom Model",desc:'Click "View All Model" → "Add Custom Model"'},{step:6,title:"Select Model",type:"modelSelector"}]},cline:{id:"cline",name:"Cline",image:"/providers/cline.png",color:"#00D1B2",description:"Cline AI Coding Assistant",configType:"custom"},kilo:{id:"kilo",name:"Kilo Code",image:"/providers/kilocode.png",color:"#FF6B6B",description:"Kilo Code AI Assistant",configType:"custom"},roo:{id:"roo",name:"Roo",image:"/providers/roo.png",color:"#FF6B6B",description:"Roo AI Assistant",configType:"guide",guideSteps:[{step:1,title:"Open Settings",desc:"Go to Roo Settings panel"},{step:2,title:"Select Provider",desc:"Choose API Provider → Ollama"},{step:3,title:"Base URL",value:"{{baseUrl}}",copyable:!0},{step:4,title:"API Key",type:"apiKeySelector"},{step:5,title:"Select Model",type:"modelSelector"}]},continue:{id:"continue",name:"Continue",image:"/providers/continue.png",color:"#7C3AED",description:"Continue AI Assistant",configType:"guide",guideSteps:[{step:1,title:"Open Config",desc:"Open Continue configuration file"},{step:2,title:"API Key",type:"apiKeySelector"},{step:3,title:"Select Model",type:"modelSelector"},{step:4,title:"Add Model Config",desc:"Add the following configuration to your models array:"}],codeBlock:{language:"json",code:`{
1
+ "use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6069],{3534:(e,t,s)=>{s.d(t,{dM:()=>a,wn:()=>l});let l={antigravity:{id:"antigravity",name:"Antigravity",image:"/providers/antigravity.png",color:"#4285F4",description:"Google Antigravity IDE with MITM",configType:"mitm",mitmDomain:"daily-cloudcode-pa.googleapis.com",modelAliases:["gemini-3.5-flash-high","gemini-3.5-flash-medium","gemini-3.5-flash-low","gemini-3.1-pro-high","gemini-3.1-pro-low","claude-sonnet-4-6-thinking","claude-opus-4-6-thinking","gpt-oss-120b-medium"],defaultModels:[{id:"gemini-3.5-flash-high",name:"Gemini 3.5 Flash (High)",alias:"gemini-3.5-flash-high"},{id:"gemini-3.5-flash-medium",name:"Gemini 3.5 Flash (Medium)",alias:"gemini-3.5-flash-medium"},{id:"gemini-3.5-flash-low",name:"Gemini 3.5 Flash (Low)",alias:"gemini-3.5-flash-low"},{id:"gemini-3.1-pro-high",name:"Gemini 3.1 Pro (High)",alias:"gemini-3.1-pro-high"},{id:"gemini-3.1-pro-low",name:"Gemini 3.1 Pro (Low)",alias:"gemini-3.1-pro-low"},{id:"claude-sonnet-4-6-thinking",name:"Claude Sonnet 4.6 (Thinking)",alias:"claude-sonnet-4-6-thinking"},{id:"claude-opus-4-6-thinking",name:"Claude Opus 4.6 (Thinking)",alias:"claude-opus-4-6-thinking"},{id:"gpt-oss-120b-medium",name:"GPT-OSS 120B (Medium)",alias:"gpt-oss-120b-medium"}]},copilot:{id:"copilot",name:"GitHub Copilot",image:"/providers/copilot.png",color:"#1F6FEB",description:"GitHub Copilot IDE with MITM",configType:"mitm",mitmDomain:"api.individual.githubcopilot.com",modelAliases:["gpt-4o-mini","claude-haiku-4.5","gpt-4o","gpt-5-mini"],defaultModels:[{id:"gpt-4o",name:"GPT-4o",alias:"gpt-4o"},{id:"gpt-4.1",name:"GPT-4.1",alias:"gpt-4.1"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5",alias:"claude-haiku-4.5"}]},kiro:{id:"kiro",name:"Kiro",image:"/providers/kiro.png",color:"#FF6B00",description:"Kiro IDE with MITM",configType:"mitm",mitmDomain:"q.us-east-1.amazonaws.com",modelAliases:["auto","claude-opus-4.7","claude-opus-4.6","claude-sonnet-4.6","claude-sonnet-4.5","claude-sonnet-4","claude-haiku-4.5","deepseek-3.2","minimax-m2.5","minimax-m2.1","glm-5","qwen3-coder-next","simple-task"],defaultModels:[{id:"auto",name:"Auto",alias:"auto"},{id:"claude-opus-4.7",name:"Claude Opus 4.7",alias:"claude-opus-4.7"},{id:"claude-opus-4.6",name:"Claude Opus 4.6",alias:"claude-opus-4.6"},{id:"claude-sonnet-4.6",name:"Claude Sonnet 4.6",alias:"claude-sonnet-4.6"},{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5",alias:"claude-sonnet-4.5"},{id:"claude-sonnet-4",name:"Claude Sonnet 4",alias:"claude-sonnet-4"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5",alias:"claude-haiku-4.5"},{id:"deepseek-3.2",name:"DeepSeek 3.2",alias:"deepseek-3.2"},{id:"minimax-m2.5",name:"MiniMax M2.5",alias:"minimax-m2.5"},{id:"minimax-m2.1",name:"MiniMax M2.1",alias:"minimax-m2.1"},{id:"glm-5",name:"GLM-5",alias:"glm-5"},{id:"qwen3-coder-next",name:"Qwen3 Coder Next",alias:"qwen3-coder-next"},{id:"simple-task",name:"Qwen3 Coder Next",alias:"simple-task"}]}},a={claude:{id:"claude",name:"Claude Code",image:"/providers/claude.png",color:"#D97757",description:"Anthropic Claude Code CLI",configType:"env",envVars:{baseUrl:"ANTHROPIC_BASE_URL",model:"ANTHROPIC_MODEL",opusModel:"ANTHROPIC_DEFAULT_OPUS_MODEL",sonnetModel:"ANTHROPIC_DEFAULT_SONNET_MODEL",haikuModel:"ANTHROPIC_DEFAULT_HAIKU_MODEL"},modelAliases:["default","sonnet","opus","haiku","opusplan"],settingsFile:"~/.claude/settings.json",defaultModels:[{id:"opus",name:"Claude Opus",alias:"opus",envKey:"ANTHROPIC_DEFAULT_OPUS_MODEL",defaultValue:"cc/claude-opus-4-6"},{id:"sonnet",name:"Claude Sonnet",alias:"sonnet",envKey:"ANTHROPIC_DEFAULT_SONNET_MODEL",defaultValue:"cc/claude-sonnet-4-6"},{id:"haiku",name:"Claude Haiku",alias:"haiku",envKey:"ANTHROPIC_DEFAULT_HAIKU_MODEL",defaultValue:"cc/claude-haiku-4-5-20251001"}]},openclaw:{id:"openclaw",name:"Open Claw",image:"/providers/openclaw.png",color:"#FF6B35",description:"Open Claw AI Assistant",configType:"custom"},codex:{id:"codex",name:"OpenAI Codex CLI / App",image:"/providers/codex.png",color:"#10A37F",description:"OpenAI Codex CLI",configType:"custom"},opencode:{id:"opencode",name:"OpenCode",image:"/providers/opencode.png",color:"#E87040",description:"OpenCode AI Terminal Assistant",configType:"custom"},cowork:{id:"cowork",name:"Claude Cowork",image:"/providers/claude.png",color:"#D97757",description:"Claude Desktop Cowork (third-party inference)",configType:"custom",modelAliases:["opus","sonnet","haiku","codex","kiro-sonnet"],defaultModels:[{id:"claude-opus-4-7",name:"Claude Opus 4.7",alias:"opus",defaultValue:"cc/claude-opus-4-7"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6",alias:"sonnet",defaultValue:"cc/claude-sonnet-4-6"},{id:"claude-haiku-4-5",name:"Claude Haiku 4.5",alias:"haiku",defaultValue:"cc/claude-haiku-4-5-20251001"},{id:"gpt-5.5",name:"GPT 5.5",alias:"codex",defaultValue:"cx/gpt-5.5"},{id:"kiro-claude-sonnet-4.6",name:"Kiro Claude Sonnet 4.6",alias:"kiro-sonnet",defaultValue:"kr/claude-sonnet-4.6"}]},hermes:{id:"hermes",name:"Hermes Agent",image:"/providers/hermes.png",color:"#8B5CF6",description:"Nous Research self-improving AI agent",configType:"custom"},droid:{id:"droid",name:"Factory Droid",image:"/providers/droid.png",color:"#00D4FF",description:"Factory Droid AI Assistant",configType:"custom"},cursor:{id:"cursor",name:"Cursor",image:"/providers/cursor.png",color:"#000000",description:"Cursor AI Code Editor",configType:"guide",requiresExternalUrl:!0,notes:[{type:"warning",text:"Requires Cursor Pro account to use this feature."},{type:"cloudCheck",text:"Cursor routes requests through its own server, so local endpoint is not supported. Please enable Tunnel or Cloud Endpoint in Settings."}],guideSteps:[{step:1,title:"Open Settings",desc:"Go to Settings → Models"},{step:2,title:"Enable OpenAI API",desc:'Enable "OpenAI API key" option'},{step:3,title:"Base URL",value:"{{baseUrl}}",copyable:!0},{step:4,title:"API Key",type:"apiKeySelector"},{step:5,title:"Add Custom Model",desc:'Click "View All Model" → "Add Custom Model"'},{step:6,title:"Select Model",type:"modelSelector"}]},cline:{id:"cline",name:"Cline",image:"/providers/cline.png",color:"#00D1B2",description:"Cline AI Coding Assistant",configType:"custom"},kilo:{id:"kilo",name:"Kilo Code",image:"/providers/kilocode.png",color:"#FF6B6B",description:"Kilo Code AI Assistant",configType:"custom"},roo:{id:"roo",name:"Roo",image:"/providers/roo.png",color:"#FF6B6B",description:"Roo AI Assistant",configType:"guide",guideSteps:[{step:1,title:"Open Settings",desc:"Go to Roo Settings panel"},{step:2,title:"Select Provider",desc:"Choose API Provider → Ollama"},{step:3,title:"Base URL",value:"{{baseUrl}}",copyable:!0},{step:4,title:"API Key",type:"apiKeySelector"},{step:5,title:"Select Model",type:"modelSelector"}]},continue:{id:"continue",name:"Continue",image:"/providers/continue.png",color:"#7C3AED",description:"Continue AI Assistant",configType:"guide",guideSteps:[{step:1,title:"Open Config",desc:"Open Continue configuration file"},{step:2,title:"API Key",type:"apiKeySelector"},{step:3,title:"Select Model",type:"modelSelector"},{step:4,title:"Add Model Config",desc:"Add the following configuration to your models array:"}],codeBlock:{language:"json",code:`{
2
2
  "apiBase": "{{baseUrl}}",
3
3
  "title": "{{model}}",
4
4
  "model": "{{model}}",
@@ -0,0 +1,3 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[2134],{17721:(e,t,s)=>{"use strict";s.r(t),s.d(t,{default:()=>S});var a=s(95155),i=s(12115),l=s(73321),r=s(98500),n=s.n(r),o=s(5772),d=s(35497),c=s(52679),p=s(28777),m=s(11059);let x=new Map;async function u(e){if(!e?.url||!e?.type)return[];let t=x.get(e.url);if(t&&Date.now()<t.expiresAt)return t.data;try{let t=new URLSearchParams({url:e.url,type:e.type}),s=await fetch(`/api/providers/suggested-models?${t}`);if(!s.ok)return[];let a=(await s.json()).data??[];return x.set(e.url,{data:a,expiresAt:Date.now()+6e5}),a}catch{return[]}}var h=s(14051),f=s.n(h);function g({model:e,fullModel:t,alias:s,copied:i,onCopy:l,testStatus:r,isCustom:n,isFree:o,onDeleteAlias:d,onTest:c,isTesting:p,onDisable:m}){let x="ok"===r?"#22c55e":"error"===r?"#ef4444":void 0;return(0,a.jsx)("div",{className:`group min-w-0 max-w-full rounded-lg border px-3 py-2 ${"ok"===r?"border-green-500/40":"error"===r?"border-red-500/40":"border-border"} hover:bg-sidebar/50`,children:(0,a.jsxs)("div",{className:"flex min-w-0 items-start gap-2 sm:items-center",children:[(0,a.jsx)("span",{className:"material-symbols-outlined shrink-0 text-base",style:x?{color:x}:void 0,children:"ok"===r?"check_circle":"error"===r?"cancel":"smart_toy"}),(0,a.jsxs)("div",{className:"flex min-w-0 flex-1 flex-col gap-1",children:[(0,a.jsx)("code",{className:"max-w-[72vw] truncate rounded bg-sidebar px-1.5 py-0.5 font-mono text-xs text-text-muted sm:max-w-[360px]",children:t}),e.name&&(0,a.jsx)("span",{className:"truncate pl-1 text-[9px] italic text-text-muted/70",children:e.name})]}),c&&(0,a.jsxs)("div",{className:"relative shrink-0 group/btn",children:[(0,a.jsx)("button",{onClick:c,disabled:p,className:`rounded p-0.5 text-text-muted transition-opacity hover:bg-sidebar hover:text-primary ${p?"opacity-100":"opacity-100 sm:opacity-0 sm:group-hover:opacity-100"}`,children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",style:p?{animation:"spin 1s linear infinite"}:void 0,children:p?"progress_activity":"science"})}),(0,a.jsx)("span",{className:"pointer-events-none absolute mt-1 top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:p?"Testing...":"Test"})]}),(0,a.jsxs)("div",{className:"relative shrink-0 group/btn",children:[(0,a.jsx)("button",{onClick:()=>l(t,`model-${e.id}`),className:"rounded p-0.5 text-text-muted hover:bg-sidebar hover:text-primary",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:i===`model-${e.id}`?"check":"content_copy"})}),(0,a.jsx)("span",{className:"pointer-events-none absolute mt-1 top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:i===`model-${e.id}`?"Copied!":"Copy"})]}),n?(0,a.jsx)("button",{onClick:d,className:"ml-auto rounded p-0.5 text-text-muted opacity-100 transition-opacity hover:bg-red-500/10 hover:text-red-500 sm:opacity-0 sm:group-hover:opacity-100",title:"Remove custom model",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"close"})}):m?(0,a.jsx)("button",{onClick:m,className:"ml-auto rounded p-0.5 text-text-muted opacity-100 transition-opacity hover:bg-red-500/10 hover:text-red-500 sm:opacity-0 sm:group-hover:opacity-100",title:"Disable this model",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"close"})}):null]})})}function y({modelId:e,fullModel:t,copied:s,onCopy:i,onDeleteAlias:l,onTest:r,testStatus:n,isTesting:o}){let d="ok"===n?"#22c55e":"error"===n?"#ef4444":void 0;return(0,a.jsxs)("div",{className:`flex items-center gap-3 p-3 rounded-lg border ${"ok"===n?"border-green-500/40":"error"===n?"border-red-500/40":"border-border"} hover:bg-sidebar/50`,children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-base text-text-muted",style:d?{color:d}:void 0,children:"ok"===n?"check_circle":"error"===n?"cancel":"smart_toy"}),(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"text-sm font-medium truncate",children:e}),(0,a.jsxs)("div",{className:"flex items-center gap-1 mt-1",children:[(0,a.jsx)("code",{className:"text-xs text-text-muted font-mono bg-sidebar px-1.5 py-0.5 rounded",children:t}),(0,a.jsxs)("div",{className:"relative group/btn",children:[(0,a.jsx)("button",{onClick:()=>i(t,`model-${e}`),className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:s===`model-${e}`?"check":"content_copy"})}),(0,a.jsx)("span",{className:"pointer-events-none absolute top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:s===`model-${e}`?"Copied!":"Copy"})]}),r&&(0,a.jsxs)("div",{className:"relative group/btn",children:[(0,a.jsx)("button",{onClick:r,disabled:o,className:"p-0.5 hover:bg-sidebar rounded text-text-muted hover:text-primary transition-colors",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",style:o?{animation:"spin 1s linear infinite"}:void 0,children:o?"progress_activity":"science"})}),(0,a.jsx)("span",{className:"pointer-events-none absolute top-5 left-1/2 -translate-x-1/2 text-[10px] text-text-muted whitespace-nowrap opacity-0 group-hover/btn:opacity-100 transition-opacity",children:o?"Testing...":"Test"})]})]})]}),(0,a.jsx)("button",{onClick:l,className:"p-1 hover:bg-red-50 rounded text-red-500",title:"Remove model",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"delete"})})]})}function b({providerStorageAlias:e,providerDisplayAlias:t,modelAliases:s,copied:l,onCopy:r,onSetAlias:n,onDeleteAlias:o,connections:c,isAnthropic:p}){let[m,x]=(0,i.useState)(""),[u,h]=(0,i.useState)(!1),[f,g]=(0,i.useState)(!1),[v,j]=(0,i.useState)(null),[N,w]=(0,i.useState)({}),k=async t=>{if(!v){j(t);try{let s=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${e}/${t}`})}),a=await s.json();w(e=>({...e,[t]:a.ok?"ok":"error"}))}catch{w(e=>({...e,[t]:"error"}))}finally{j(null)}}},C=Object.entries(s).filter(([,t])=>t.startsWith(`${e}/`)).map(([t,s])=>({modelId:s.replace(`${e}/`,""),fullModel:s,alias:t})),S=a=>{let i,l=`${e}/${a}`;if(Object.values(s).includes(l))return null;let r=(i=a.split("/"))[i.length-1];if(!s[r])return r;let n=`${t}-${r}`;return s[n]?null:n},A=async()=>{if(!m.trim()||u)return;let t=m.trim(),s=S(t);if(!s)return void alert("All suggested aliases already exist. Please choose a different model or remove conflicting aliases.");h(!0);try{await n(t,s,e),x("")}catch(e){console.log("Error adding model:",e)}finally{h(!1)}},$=async()=>{if(f)return;let t=c.find(e=>!1!==e.isActive);if(t){g(!0);try{let s=await fetch(`/api/providers/${t.id}/models`),a=await s.json();if(!s.ok)return void alert(a.error||"Failed to import models");let i=a.models||[];if(0===i.length)return void alert("No models returned from /models.");let l=0;for(let t of i){let s=t.id||t.name||t.model;if(!s)continue;let a=S(s);a&&(await n(s,a,e),l+=1)}0===l&&alert("No new models were added.")}catch(e){console.log("Error importing models:",e)}finally{g(!1)}}},T=c.some(e=>!1!==e.isActive);return(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("p",{className:"text-sm text-text-muted",children:["Add ",p?"Anthropic":"OpenAI","-compatible models manually or import them from the /models endpoint."]}),(0,a.jsxs)("div",{className:"flex items-end gap-2 flex-wrap",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-[240px]",children:[(0,a.jsx)("label",{htmlFor:"new-compatible-model-input",className:"text-xs text-text-muted mb-1 block",children:"Model ID"}),(0,a.jsx)("input",{id:"new-compatible-model-input",type:"text",value:m,onChange:e=>x(e.target.value),onKeyDown:e=>"Enter"===e.key&&A(),placeholder:p?"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,a.jsx)(d.$n,{size:"sm",icon:"add",onClick:A,disabled:!m.trim()||u,children:u?"Adding...":"Add"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"download",onClick:$,disabled:!T||f,children:f?"Importing...":"Import from /models"})]}),!T&&(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"Add a connection to enable importing models."}),C.length>0&&(0,a.jsx)("div",{className:"flex flex-col gap-3",children:C.map(({modelId:e,fullModel:s,alias:i})=>(0,a.jsx)(y,{modelId:e,fullModel:`${t}/${e}`,copied:l,onCopy:r,onDeleteAlias:()=>o(i),onTest:c.length>0?()=>k(e):void 0,testStatus:N[e],isTesting:v===e},s))})]})}function v({until:e}){let[t,s]=(0,i.useState)("");return((0,i.useEffect)(()=>{let t=()=>{let t=new Date(e).getTime()-Date.now();if(t<=0)return void s("");let a=Math.floor(t/1e3);if(a<60)s(`${a}s`);else if(a<3600)s(`${Math.floor(a/60)}m ${a%60}s`);else{let e=Math.floor(a/3600),t=Math.floor(a%3600/60);s(`${e}h ${t}m`)}};t();let a=setInterval(t,1e3);return()=>clearInterval(a)},[e]),t)?(0,a.jsxs)("span",{className:"text-xs text-orange-500 font-mono",children:["⏱ ",t]}):null}function j({connection:e,proxyPools:t,isOAuth:s,isFirst:l,isLast:r,onMoveUp:n,onMoveDown:o,onToggleActive:c,onUpdateProxy:p,onEdit:m,onDelete:x,oneByOneStatus:u=null}){let[h,f]=(0,i.useState)(!1),[g,y]=(0,i.useState)(!1),b=(0,i.useRef)(null),N=new Map((t||[]).map(e=>[e.id,e])),w=e.providerSpecificData?.proxyPoolId||null,k=w?N.get(w):null,C=e.providerSpecificData?.connectionProxyEnabled===!0&&!!e.providerSpecificData?.connectionProxyUrl,S=!!w||C,A=k?`Pool: ${k.name}`:w?`Pool: ${w} (inactive/missing)`:C?`Legacy: ${e.providerSpecificData?.connectionProxyUrl}`:"",$="";if(k?.proxyUrl||e.providerSpecificData?.connectionProxyUrl){let t=k?.proxyUrl||e.providerSpecificData?.connectionProxyUrl;try{let e=new URL(t);$=`${e.protocol}//${e.hostname}${e.port?`:${e.port}`:""}`}catch{$=t}}let T=k?.noProxy||e.providerSpecificData?.connectionNoProxy||"",O="default";k?.isActive===!0?O="success":(w||C)&&(O="error"),(0,i.useEffect)(()=>{if(!h)return;let e=e=>{b.current&&!b.current.contains(e.target)&&f(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[h]);let P=async e=>{y(!0);try{await p("__none__"===e?null:e)}finally{y(!1),f(!1)}},I=e.authType||(s?"oauth":"apikey"),E="oauth"===I,R="cookie"===I,D=e=>"string"==typeof e&&/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(e),U=E?D(e.email)?e.email:D(e.name)?e.name:e.name||e.email||e.displayName||"OAuth Account":e.name||e.email||e.displayName||"API Key",[_,z]=(0,i.useState)(!1),q=Object.entries(e).filter(([e])=>e.startsWith("modelLock_")).map(([,e])=>e).filter(e=>!!e).sort()[0]||null;(0,i.useEffect)(()=>{let t=()=>{z(!!Object.entries(e).filter(([e])=>e.startsWith("modelLock_")).map(([,e])=>e).filter(e=>e&&new Date(e).getTime()>Date.now()).sort()[0])};t();let s=q?setInterval(t,1e3):null;return()=>{s&&clearInterval(s)}},[q]);let M="unavailable"!==e.testStatus||_?e.testStatus:"active",K=()=>u?"queued"===u.state?"queued":"testing"===u.state?"testing":"success"===u.state?"success":"failed"===u.state?"failed":null:null;return(0,a.jsxs)("div",{className:`group flex min-w-0 flex-col gap-3 rounded-lg p-2 transition-colors hover:bg-black/[0.02] dark:hover:bg-white/[0.02] sm:flex-row sm:items-center sm:justify-between ${!1===e.isActive?"opacity-60":""}`,children:[(0,a.jsxs)("div",{className:"flex min-w-0 flex-1 items-start gap-2 sm:items-center sm:gap-3",children:[(0,a.jsxs)("div",{className:"flex shrink-0 flex-col",children:[(0,a.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,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_up"})}),(0,a.jsx)("button",{onClick:o,disabled:r,className:`p-0.5 rounded ${r?"text-text-muted/30 cursor-not-allowed":"hover:bg-sidebar text-text-muted hover:text-primary"}`,children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"keyboard_arrow_down"})})]}),(0,a.jsx)("span",{className:"material-symbols-outlined shrink-0 text-base text-text-muted",children:R?"cookie":E?"lock":"key"}),(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"text-sm font-medium truncate",children:U}),(0,a.jsxs)("div",{className:"mt-1 flex min-w-0 flex-wrap items-center gap-1.5 sm:gap-2",children:[(0,a.jsx)(d.Ex,{variant:!1===e.isActive?"default":"active"===M||"success"===M?"success":"error"===M||"expired"===M||"unavailable"===M?"error":"default",size:"sm",dot:!0,children:!1===e.isActive?"disabled":M||"Unknown"}),(0,a.jsx)(d.Ex,{variant:"default",size:"sm",children:E?"OAuth":R?"Cookie":"API Key"}),S&&(0,a.jsx)(d.Ex,{variant:O,size:"sm",children:"Proxy"}),_&&!1!==e.isActive&&(0,a.jsx)(v,{until:q}),e.lastError&&!1!==e.isActive&&(0,a.jsx)("span",{className:"max-w-full truncate text-xs text-red-500 sm:max-w-[300px]",title:e.lastError,children:e.lastError}),(0,a.jsxs)("span",{className:"text-xs text-text-muted",children:["#",e.priority]}),e.globalPriority&&(0,a.jsxs)("span",{className:"text-xs text-text-muted",children:["Auto: ",e.globalPriority]}),K()&&(0,a.jsx)(d.Ex,{variant:u?"success"===u.state?"success":"failed"===u.state?"error":"testing"===u.state?"primary":"default":"default",size:"sm",title:u?.error||void 0,children:K()})]}),S&&(0,a.jsxs)("div",{className:"mt-1 flex items-center gap-2 flex-wrap",children:[(0,a.jsx)("span",{className:"max-w-full truncate text-[11px] text-text-muted sm:max-w-[420px]",title:A,children:A}),$&&(0,a.jsx)("code",{className:"max-w-full truncate rounded bg-black/5 px-1 py-0.5 font-mono text-[10px] text-text-muted dark:bg-white/5 sm:max-w-[260px]",children:$}),T&&(0,a.jsxs)("span",{className:"max-w-full truncate text-[11px] text-text-muted sm:max-w-[320px]",title:T,children:["no_proxy: ",T]})]})]})]}),(0,a.jsxs)("div",{className:"flex w-full items-center justify-between gap-2 sm:w-auto sm:justify-end",children:[(0,a.jsxs)("div",{className:"grid flex-1 grid-cols-3 gap-1 sm:flex sm:flex-none",children:[(t||[]).length>0&&(0,a.jsxs)("div",{className:"relative",ref:b,children:[(0,a.jsxs)("button",{onClick:()=>f(e=>!e),className:`flex w-full flex-col items-center rounded px-2 py-1 transition-colors hover:bg-black/5 dark:hover:bg-white/5 ${S?"text-primary":"text-text-muted hover:text-primary"}`,disabled:g,children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:g?"progress_activity":"lan"}),(0,a.jsx)("span",{className:"text-[10px] leading-tight",children:"Proxy"})]}),h&&(0,a.jsxs)("div",{className:"absolute right-0 top-full z-50 mt-1 max-w-[78vw] min-w-[160px] rounded-lg border border-border bg-bg py-1 shadow-lg",children:[(0,a.jsx)("button",{onClick:()=>P("__none__"),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${!w?"text-primary font-medium":"text-text-main"}`,children:"None"}),(t||[]).map(e=>(0,a.jsx)("button",{onClick:()=>P(e.id),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${w===e.id?"text-primary font-medium":"text-text-main"}`,children:e.name},e.id))]})]}),(0,a.jsxs)("button",{onClick:()=>window.open(`/api/providers/export?connectionId=${e.id}`,"_blank"),className:"flex flex-col items-center rounded px-2 py-1 text-text-muted hover:bg-black/5 hover:text-primary dark:hover:bg-white/5",title:"Export this connection as JSON",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"download"}),(0,a.jsx)("span",{className:"text-[10px] leading-tight",children:"Export"})]}),(0,a.jsxs)("button",{onClick:m,className:"flex flex-col items-center rounded px-2 py-1 text-text-muted hover:bg-black/5 hover:text-primary dark:hover:bg-white/5",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"edit"}),(0,a.jsx)("span",{className:"text-[10px] leading-tight",children:"Edit"})]}),(0,a.jsxs)("button",{onClick:x,className:"flex flex-col items-center rounded px-2 py-1 text-red-500 hover:bg-red-500/10",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"delete"}),(0,a.jsx)("span",{className:"text-[10px] leading-tight",children:"Delete"})]})]}),(0,a.jsx)(d.lM,{size:"sm",checked:e.isActive??!0,onChange:c,title:e.isActive??!0?"Disable connection":"Enable connection"})]})]})}g.propTypes={model:f().shape({id:f().string.isRequired}).isRequired,fullModel:f().string.isRequired,alias:f().string,copied:f().string,onCopy:f().func.isRequired,testStatus:f().oneOf(["ok","error"]),isCustom:f().bool,isFree:f().bool,onDeleteAlias:f().func,onTest:f().func,isTesting:f().bool,onDisable:f().func},f().string.isRequired,f().string.isRequired,f().string,f().func.isRequired,f().func.isRequired,f().func,f().oneOf(["ok","error"]),f().bool,f().string.isRequired,f().object.isRequired,f().string,f().func.isRequired,f().func.isRequired,f().func.isRequired,b.propTypes={providerStorageAlias:f().string.isRequired,providerDisplayAlias:f().string.isRequired,modelAliases:f().object.isRequired,copied:f().string,onCopy:f().func.isRequired,onSetAlias:f().func.isRequired,onDeleteAlias:f().func.isRequired,connections:f().arrayOf(f().shape({id:f().string,isActive:f().bool})).isRequired,isAnthropic:f().bool},v.propTypes={until:f().string.isRequired},j.propTypes={connection:f().shape({id:f().string,name:f().string,email:f().string,displayName:f().string,authType:f().string,modelLockUntil:f().string,testStatus:f().string,isActive:f().bool,lastError:f().string,priority:f().number,globalPriority:f().number}).isRequired,proxyPools:f().arrayOf(f().shape({id:f().string,name:f().string,proxyUrl:f().string,noProxy:f().string,isActive:f().bool})),isOAuth:f().bool.isRequired,isFirst:f().bool.isRequired,isLast:f().bool.isRequired,onMoveUp:f().func.isRequired,onMoveDown:f().func.isRequired,onToggleActive:f().func.isRequired,onUpdateProxy:f().func,onEdit:f().func.isRequired,onDelete:f().func.isRequired,oneByOneStatus:f().shape({state:f().string,error:f().string})};let N=`name1|sk-key1
2
+ name2|sk-key2
3
+ sk-key-only-auto-named`;function w({isOpen:e,provider:t,providerName:s,isCompatible:l,isAnthropic:r,authType:n,authHint:o,website:p,proxyPools:m,error:x,onSave:u,onBulkDone:h,onClose:f}){let g="__none__",y="ollama-local"===t,b="cookie"===n,v="xai"===t&&!b,j=b?"Cookie Value":"API Key",k="azure"===t,C="cloudflare-ai"===t,S=c.Q2?.[t]?.regions||null,A=c.Q2?.[t]?.defaultRegion||S?.[0]?.id||"",[$,T]=(0,i.useState)({name:"",apiKey:"",defaultModel:"",priority:1,proxyPoolId:g,ollamaHostUrl:""}),[O,P]=(0,i.useState)({azureEndpoint:"",apiVersion:"2024-10-01-preview",deployment:"",organization:""}),[I,E]=(0,i.useState)({accountId:""}),[R,D]=(0,i.useState)(A),[U,_]=(0,i.useState)(!1),[z,q]=(0,i.useState)(null),[M,K]=(0,i.useState)(!1),[F,L]=(0,i.useState)("single"),[J,W]=(0,i.useState)(""),[B,H]=(0,i.useState)(null),V=()=>y&&$.ollamaHostUrl.trim()?{baseUrl:$.ollamaHostUrl.trim()}:k?{azureEndpoint:O.azureEndpoint,apiVersion:O.apiVersion,deployment:O.deployment,organization:O.organization}:C?{accountId:I.accountId}:S&&R?{region:R}:void 0,G=async()=>{_(!0);try{let e=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:$.apiKey,providerSpecificData:V()})}),s=await e.json();q(s.valid?"success":"failed")}catch{q("failed")}finally{_(!1)}},Q=async()=>{if(t&&(y||$.apiKey)&&(y||$.name)&&(!l||$.defaultModel.trim())){K(!0);try{let e=!1;try{_(!0),q(null);let s=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:$.apiKey,providerSpecificData:V()})});e=!!(await s.json()).valid,q(e?"success":"failed")}catch{q("failed")}finally{_(!1)}await u({name:$.name||(y?"Ollama Local":""),apiKey:$.apiKey,defaultModel:l?$.defaultModel.trim():void 0,priority:$.priority,proxyPoolId:$.proxyPoolId===g?null:$.proxyPoolId,testStatus:e?"active":"unknown",providerSpecificData:V()})}finally{K(!1)}}},Z=async()=>{let e=J.split("\n").map(e=>e.trim()).filter(Boolean);if(!e.length)return;K(!0),H(null);let s=0,a=0;for(let i=0;i<e.length;i++){let l=e[i].split("|"),r=l.length>=2?l.slice(1).join("|").trim():l[0].trim(),n=l.length>=2?l[0].trim():"Key",o=`${n} ${i+1}`;try{(await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:r,name:o,priority:1,testStatus:"unknown"})})).ok?s++:a++}catch{a++}}K(!1),H({success:s,failed:a}),s>0&&h&&h()};return t?(0,a.jsx)(d.aF,{isOpen:e,title:`Add ${s||t} ${j}`,onClose:f,children:(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.$n,{size:"sm",variant:"single"===F?"primary":"ghost",onClick:()=>{L("single"),H(null)},children:"Single"}),(0,a.jsx)(d.$n,{size:"sm",variant:"bulk"===F?"primary":"ghost",onClick:()=>{L("bulk"),H(null)},children:"Bulk Add"})]}),"bulk"===F&&(0,a.jsxs)("div",{className:"flex flex-col gap-3",children:[(0,a.jsxs)("p",{className:"text-xs text-text-muted",children:["One key per line. Format: ",(0,a.jsx)("code",{children:"name|apiKey"})," or just ",(0,a.jsx)("code",{children:"apiKey"})," (auto-named by index)."]}),(0,a.jsx)("textarea",{className:"w-full rounded border border-accent/30 bg-sidebar p-2 text-sm font-mono resize-y min-h-[140px] focus:outline-none focus:ring-1 focus:ring-primary",placeholder:N,value:J,onChange:e=>W(e.target.value)}),B&&(0,a.jsxs)("div",{className:`text-sm font-medium ${B.failed>0?"text-yellow-400":"text-green-400"}`,children:["✓ ",B.success," added",B.failed>0?`, ✗ ${B.failed} failed`:""]}),(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.$n,{onClick:Z,fullWidth:!0,disabled:M||!J.trim(),children:M?"Adding...":"Add All Keys"}),(0,a.jsx)(d.$n,{onClick:f,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]}),"single"===F&&(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(d.pd,{label:"Name",value:$.name,onChange:e=>T({...$,name:e.target.value}),placeholder:y?"Ollama Local":"Production Key"}),y&&(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.pd,{label:"Ollama Host URL",value:$.ollamaHostUrl,onChange:e=>T({...$,ollamaHostUrl:e.target.value}),placeholder:"http://localhost:11434",className:"flex-1"}),(0,a.jsx)("div",{className:"pt-6",children:(0,a.jsx)(d.$n,{onClick:G,disabled:U||M,variant:"secondary",children:U?"Checking...":"Check"})})]}),!y&&(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.pd,{label:j,type:b?"text":"password",value:$.apiKey,onChange:e=>T({...$,apiKey:e.target.value}),placeholder:b?"grok-web"===t?"sso=xxxxx... or just the raw value":"eyJhbGciOi...":v?"xai-...":"",className:"flex-1"}),(0,a.jsx)("div",{className:"pt-6",children:(0,a.jsx)(d.$n,{onClick:G,disabled:!$.apiKey||U||M,variant:"secondary",children:U?"Checking...":"Check"})})]}),v&&(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"Use a direct xAI API key from console.x.ai. This is separate from Grok Build OAuth."}),b&&o&&(0,a.jsxs)("p",{className:"text-xs text-text-muted",children:[o,p&&(0,a.jsxs)(a.Fragment,{children:[" ",(0,a.jsxs)("a",{href:p,target:"_blank",rel:"noopener noreferrer",className:"text-primary underline",children:["Open ",p.replace(/^https?:\/\//,"")]})]})]}),S&&(0,a.jsx)(d.l6,{label:"Region",value:R,onChange:e=>D(e.target.value),options:S.map(e=>({value:e.id,label:e.label}))}),l&&(0,a.jsx)(d.pd,{label:"Default Model",value:$.defaultModel,onChange:e=>T({...$,defaultModel:e.target.value}),placeholder:r?"claude-3-5-sonnet-latest":"gpt-4o-mini"}),y&&(0,a.jsxs)("p",{className:"text-xs text-text-muted",children:["Leave blank to use ",(0,a.jsx)("code",{children:"http://localhost:11434"}),". For remote Ollama, enter the full host URL (e.g. ",(0,a.jsx)("code",{children:"http://192.168.1.10:11434"}),")."]}),z&&(0,a.jsx)(d.Ex,{variant:"success"===z?"success":"error",children:"success"===z?"Valid":"Invalid"}),x&&(0,a.jsx)("p",{className:"text-xs text-red-500 break-words",children:x}),l&&(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"Enter the model ID exactly as your compatible endpoint expects it. This model will be saved as the connection default."}),C&&(0,a.jsxs)("div",{className:"bg-sidebar/50 p-4 rounded-lg border border-accent/20",children:[(0,a.jsx)("h3",{className:"font-semibold mb-3 text-sm",children:"Cloudflare Workers AI"}),(0,a.jsx)(d.pd,{label:"Account ID",value:I.accountId,onChange:e=>E({...I,accountId:e.target.value}),placeholder:"abc123def456..."}),(0,a.jsxs)("p",{className:"text-xs text-text-muted mt-2",children:["Find your Account ID in the right sidebar of ",(0,a.jsx)("a",{href:"https://dash.cloudflare.com",target:"_blank",rel:"noopener noreferrer",className:"text-primary underline",children:"dash.cloudflare.com"})]})]}),k&&(0,a.jsxs)("div",{className:"bg-sidebar/50 p-4 rounded-lg border border-accent/20",children:[(0,a.jsx)("h3",{className:"font-semibold mb-3 text-sm",children:"Azure OpenAI Configuration"}),(0,a.jsxs)("div",{className:"flex flex-col gap-3",children:[(0,a.jsx)(d.pd,{label:"Azure Endpoint",value:O.azureEndpoint,onChange:e=>P({...O,azureEndpoint:e.target.value}),placeholder:"https://your-resource.openai.azure.com"}),(0,a.jsx)(d.pd,{label:"Deployment Name",value:O.deployment,onChange:e=>P({...O,deployment:e.target.value}),placeholder:"gpt-4"}),(0,a.jsx)(d.pd,{label:"API Version",value:O.apiVersion,onChange:e=>P({...O,apiVersion:e.target.value}),placeholder:"2024-10-01-preview"}),(0,a.jsx)(d.pd,{label:"Organization",value:O.organization,onChange:e=>P({...O,organization:e.target.value}),placeholder:"Organization ID"})]})]}),(0,a.jsx)(d.pd,{label:"Priority",type:"number",value:$.priority,onChange:e=>T({...$,priority:Number.parseInt(e.target.value)||1})}),(0,a.jsx)(d.l6,{label:"Proxy Pool",value:$.proxyPoolId,onChange:e=>T({...$,proxyPoolId:e.target.value}),options:[{value:g,label:"None"},...(m||[]).map(e=>({value:e.id,label:e.name}))],placeholder:"None"}),0===(m||[]).length&&(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"No active proxy pools available. Create one in Proxy Pools page first."}),(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"Legacy manual proxy fields are still accepted by API for backward compatibility."}),(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.$n,{onClick:Q,fullWidth:!0,disabled:M||!y&&(!$.name||!$.apiKey)||l&&!$.defaultModel.trim()||k&&(!O.azureEndpoint||!O.deployment||!O.organization)||C&&!I.accountId,children:M?"Saving...":"Save"}),(0,a.jsx)(d.$n,{onClick:f,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})]})}):null}function k({isOpen:e,node:t,onSave:s,onClose:l,isAnthropic:r}){let[n,o]=(0,i.useState)({name:"",prefix:"",apiType:"chat",baseUrl:"https://api.openai.com/v1"}),[c,p]=(0,i.useState)(!1),[m,x]=(0,i.useState)(""),[u,h]=(0,i.useState)(""),[f,g]=(0,i.useState)(!1),[y,b]=(0,i.useState)(null);(0,i.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()){p(!0);try{let e={name:n.name,prefix:n.prefix,baseUrl:n.baseUrl};r||(e.apiType=n.apiType),await s(e)}finally{p(!1)}}},j=async()=>{g(!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",modelId:u.trim()||void 0})}),t=await e.json();b(t.valid?"success":"failed")}catch{b("failed")}finally{g(!1)}};return t?(0,a.jsx)(d.aF,{isOpen:e,title:`Edit ${r?"Anthropic":"OpenAI"} Compatible`,onClose:l,children:(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsx)(d.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,a.jsx)(d.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,a.jsx)(d.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,a.jsx)(d.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,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.pd,{label:"API Key (for Check)",type:"password",value:m,onChange:e=>x(e.target.value),className:"flex-1"}),(0,a.jsx)("div",{className:"pt-6",children:(0,a.jsx)(d.$n,{onClick:j,disabled:!m||f||!n.baseUrl.trim(),variant:"secondary",children:f?"Checking...":"Check"})})]}),(0,a.jsx)(d.pd,{label:"Model ID (optional)",value:u,onChange:e=>h(e.target.value),placeholder:"e.g. my-model-id",hint:"If provider lacks /models endpoint, enter a model ID to validate via chat/completions instead."}),y&&(0,a.jsx)(d.Ex,{variant:"success"===y?"success":"error",children:"success"===y?"Valid":"Invalid"}),(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.$n,{onClick:v,fullWidth:!0,disabled:!n.name.trim()||!n.prefix.trim()||!n.baseUrl.trim()||c,children:c?"Saving...":"Save"}),(0,a.jsx)(d.$n,{onClick:l,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function C({isOpen:e,providerAlias:t,providerDisplayAlias:s,onSave:l,onClose:r}){let[n,o]=(0,i.useState)(""),[c,p]=(0,i.useState)(null),[m,x]=(0,i.useState)(""),[u,h]=(0,i.useState)(!1);(0,i.useEffect)(()=>{e&&(o(""),p(null),x(""))},[e]);let f=e=>{let s=`${t}/`;return e.startsWith(s)?e.slice(s.length):e},g=async()=>{let e=f(n.trim());if(e){p("testing"),x("");try{let s=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${t}/${e}`})}),a=await s.json();p(a.ok?"ok":"error"),x(a.error||"")}catch(e){p("error"),x(e.message)}}},y=async()=>{let e=f(n.trim());if(e&&!u){h(!0);try{await l(e)}finally{h(!1)}}};return(0,a.jsx)(d.aF,{isOpen:e,onClose:r,title:"Add Custom Model",children:(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("label",{className:"text-sm font-medium mb-1.5 block",children:"Model ID"}),(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)("input",{type:"text",value:n,onChange:e=>{o(e.target.value),p(null),x("")},onKeyDown:e=>{"Enter"===e.key&&g()},placeholder:"e.g. claude-opus-4-5",className:"flex-1 px-3 py-2 text-sm border border-border rounded-lg bg-background focus:outline-none focus:border-primary",autoFocus:!0}),(0,a.jsx)(d.$n,{variant:"secondary",icon:"science",loading:"testing"===c,onClick:g,disabled:!n.trim()||"testing"===c,children:"testing"===c?"Testing...":"Test"})]}),(0,a.jsxs)("p",{className:"text-xs text-text-muted mt-1",children:["Sent to provider as: ",(0,a.jsx)("code",{className:"font-mono bg-sidebar px-1 rounded",children:f(n.trim())||"model-id"})]})]}),"ok"===c&&(0,a.jsxs)("div",{className:"flex items-center gap-2 text-sm text-green-600",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-base",children:"check_circle"}),"Model is reachable"]}),"error"===c&&(0,a.jsxs)("div",{className:"flex items-start gap-2 text-sm text-red-500",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-base shrink-0",children:"cancel"}),(0,a.jsx)("span",{children:m||"Model not reachable"})]}),(0,a.jsxs)("div",{className:"flex gap-2 pt-1",children:[(0,a.jsx)(d.$n,{onClick:r,variant:"ghost",fullWidth:!0,size:"sm",children:"Cancel"}),(0,a.jsx)(d.$n,{onClick:y,fullWidth:!0,size:"sm",disabled:!n.trim()||u,children:u?"Adding...":"Add Model"})]})]})})}function S(){let e,t=(0,l.useParams)(),s=(0,l.useRouter)(),r=t.id,[x,h]=(0,i.useState)([]),[f,y]=(0,i.useState)(!0),[v,N]=(0,i.useState)(null),[S,A]=(0,i.useState)([]),[$,T]=(0,i.useState)(!1),[O,P]=(0,i.useState)(!1),[I,E]=(0,i.useState)(!1),[R,D]=(0,i.useState)(""),[U,_]=(0,i.useState)(!1),[z,q]=(0,i.useState)(!1),[M,K]=(0,i.useState)(!1),[F,L]=(0,i.useState)(null),[J,W]=(0,i.useState)({}),[B,H]=(0,i.useState)(!1),[V,G]=(0,i.useState)({}),[Q,Z]=(0,i.useState)(""),[X,Y]=(0,i.useState)(null),[ee,et]=(0,i.useState)(!1),[es,ea]=(0,i.useState)([]),[ei,el]=(0,i.useState)("__none__"),[er,en]=(0,i.useState)(!1),[eo,ed]=(0,i.useState)(null),[ec,ep]=(0,i.useState)(""),[em,ex]=(0,i.useState)("auto"),[eu,eh]=(0,i.useState)([]),[ef,eg]=(0,i.useState)([]),[ey,eb]=(0,i.useState)([]),[ev,ej]=(0,i.useState)(null),[eN,ew]=(0,i.useState)(!1),ek=(0,i.useRef)(null),[eC,eS]=(0,i.useState)(!1),[eA,e$]=(0,i.useState)(!1),[eT,eO]=(0,i.useState)(null),[eP,eI]=(0,i.useState)({}),[eE,eR]=(0,i.useState)(null),eD=(0,i.useRef)(!1),{copied:eU,copy:e_}=(0,m.C)(),ez=async e=>{let t=e.target.files?.[0];if(t){ew(!0);try{let e=await t.text(),s=JSON.parse(e),a=await fetch("/api/providers/import",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(s)}),i=await a.json();if(a.ok){let e=await fetch("/api/providers");if(e.ok){let t=await e.json();h((t.connections||[]).filter(e=>e.provider===r))}D("")}else D(i.error||"Import failed")}catch(e){D(e.message||"Import failed")}finally{ew(!1),ek.current&&(ek.current.value="")}}},eq=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}:c.zN[r]||c.fg[r]||c.IS[r]||c.nJ[r]||c.br[r],eM=eq?.authModes||[],eK=!!c.zN[r]||!!c.IS[r]||eM.includes("oauth"),eF=!!c.fg[r]||eM.includes("apikey"),eL=!!c.IS[r]?.noAuth,eJ=(0,p.KC)(r),eW=(0,c.wG)(r),eB=(0,c.mq)(r),eH=(0,c.gb)(r),eV=eB||eH,eG=!eV&&eK&&eF,eQ="xai"===r?"Grok Build OAuth":"OAuth",eZ="xai"===r?"xAI API Key":"API Key";c.Q2[r]?.thinkingConfig||c.s9.extended;let eX=eV?r:eW,eY=eV?v?.prefix||r:eW,e0=()=>{T(!0)},e1=()=>{D(""),E(!0)},e2=(0,i.useCallback)(async()=>{try{let e=await fetch(`/api/models/disabled?providerAlias=${encodeURIComponent(eX)}`,{cache:"no-store"}),t=await e.json();e.ok&&eb(t.ids||[])}catch(e){console.log("Error fetching disabled models:",e)}},[eX]),e5=async e=>{try{(await fetch("/api/models/disabled",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerAlias:eX,ids:[e]})})).ok&&await e2()}catch(e){console.log("Error disabling model:",e)}},e3=async e=>{try{(await fetch(`/api/models/disabled?providerAlias=${encodeURIComponent(eX)}&id=${encodeURIComponent(e)}`,{method:"DELETE"})).ok&&await e2()}catch(e){console.log("Error enabling model:",e)}},e4=async e=>{e.length&&ej({title:"Disable All Models",message:`Disable all ${e.length} model(s)?`,onConfirm:async()=>{ej(null);try{(await fetch("/api/models/disabled",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerAlias:eX,ids:e})})).ok&&await e2()}catch(e){console.log("Error disabling all models:",e)}}})},e6=async()=>{try{(await fetch(`/api/models/disabled?providerAlias=${encodeURIComponent(eX)}`,{method:"DELETE"})).ok&&await e2()}catch(e){console.log("Error enabling all models:",e)}},e7=(0,i.useCallback)(async()=>{try{let e=await fetch("/api/models/alias"),t=await e.json();e.ok&&W(t.aliases||{})}catch(e){console.log("Error fetching aliases:",e)}},[]);(0,i.useEffect)(()=>{"kilocode"===r&&fetch("/api/providers/kilo/free-models").then(e=>e.json()).then(e=>{e.models?.length&&eg(e.models)}).catch(()=>{})},[r]);let e8=(0,i.useCallback)(async()=>{try{let[e,t,s,a]=await Promise.all([fetch("/api/providers",{cache:"no-store"}),fetch("/api/provider-nodes",{cache:"no-store"}),fetch("/api/proxy-pools?isActive=true",{cache:"no-store"}),fetch("/api/settings",{cache:"no-store"})]),i=await e.json(),l=await t.json(),n=await s.json(),o=a.ok?await a.json():{};if(e.ok){let e=(i.connections||[]).filter(e=>e.provider===r);h(e)}s.ok&&A(n.proxyPools||[]);let d=(o.providerStrategies||{})[r]||{};ed(d.fallbackStrategy||null),ep(null!=d.stickyRoundRobinLimit?String(d.stickyRoundRobinLimit):"1");let c=(o.providerThinking||{})[r]||{};if(ex(c.mode||"auto"),t.ok){let e=(l.nodes||[]).find(e=>e.id===r)||null;if(!e&&eV)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===r)||null))break}N(e)}}catch(e){console.log("Error fetching connections:",e)}finally{y(!1)}},[r,eV]),e9=async e=>{try{let t=await fetch(`/api/provider-nodes/${r}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)}),s=await t.json();t.ok&&(N(s.node),await e8(),q(!1))}catch(e){console.log("Error updating provider node:",e)}},te=async(e,t)=>{try{let s=await fetch("/api/settings",{cache:"no-store"}),a=(s.ok?await s.json():{}).providerStrategies||{},i={};e&&(i.fallbackStrategy=e),"round-robin"===e&&""!==t&&(i.stickyRoundRobinLimit=Number(t)||3);let l={...a};0===Object.keys(i).length?delete l[r]:l[r]=i,await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerStrategies:l})})}catch(e){console.log("Error saving provider strategy:",e)}};(0,i.useEffect)(()=>{e8(),e7(),e2()},[e8,e7,e2]),(0,i.useEffect)(()=>{let e=(c.zN[r]||c.fg[r]||c.IS[r]||c.nJ[r])?.modelsFetcher;e&&u(e).then(eh)},[r]);let tt=async(e,t,s=eW)=>{let a=`${s}/${e}`;try{let e=await fetch("/api/models/alias",{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:a,alias:t})});if(e.ok)await e7();else{let t=await e.json();alert(t.error||"Failed to set alias")}}catch(e){console.log("Error setting alias:",e)}},ts=async e=>{try{(await fetch(`/api/models/alias?alias=${encodeURIComponent(e)}`,{method:"DELETE"})).ok&&await e7()}catch(e){console.log("Error deleting alias:",e)}},ta=async()=>{if(eC||0===x.length)return;let e=Object.fromEntries(x.map(e=>[e.id,{state:"queued",error:null}]));eD.current=!1,eS(!0),e$(!1),eO(null),eI(e),eR({total:x.length,completed:0,passed:0,failed:0,stopped:!1});let t=0,s=0;try{for(let e=0;e<x.length;e+=1){if(eD.current){eR({total:x.length,completed:e,passed:t,failed:s,stopped:!0});break}let a=x[e];eO(a.id),eI(e=>({...e,[a.id]:{state:"testing",error:null}}));try{let e=await fetch(`/api/providers/${a.id}/test`,{method:"POST"}),i=await e.json(),l=e.ok&&!!i.valid,r=l?null:i.error||"Test failed";l?t+=1:s+=1,eI(e=>({...e,[a.id]:{state:l?"success":"failed",error:r}})),h(e=>e.map(e=>e.id===a.id?{...e,testStatus:l?"active":"error",lastError:r,lastErrorAt:l?null:new Date().toISOString()}:e))}catch(e){s+=1,eI(t=>({...t,[a.id]:{state:"failed",error:e.message||"Test failed"}})),h(t=>t.map(t=>t.id===a.id?{...t,testStatus:"error",lastError:e.message||"Test failed",lastErrorAt:new Date().toISOString()}:t))}eR({total:x.length,completed:e+1,passed:t,failed:s,stopped:!1}),e<x.length-1&&await new Promise(e=>setTimeout(e,1e3))}}finally{eO(null),eS(!1),e$(!1),eD.current=!1,await e8()}},ti=async e=>{ej({title:"Delete Connection",message:"Delete this connection?",onConfirm:async()=>{ej(null);try{(await fetch(`/api/providers/${e}`,{method:"DELETE"})).ok&&h(x.filter(t=>t.id!==e))}catch(e){console.log("Error deleting connection:",e)}}})},tl=()=>{e8(),T(!1)},tr=async e=>{D("");try{let t=await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:r,...e})}),s=null;try{s=await t.json()}catch{s=null}if(t.ok){await e8(),E(!1);return}D(s?.error||"Failed to save connection")}catch(e){console.log("Error saving connection:",e),D("Failed to save connection")}},tn=async e=>{try{(await fetch(`/api/providers/${F.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)})).ok&&(await e8(),_(!1))}catch(e){console.log("Error updating connection:",e)}},to=async(e,t)=>{try{(await fetch(`/api/providers/${e}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({isActive:t})})).ok&&h(s=>s.map(s=>s.id===e?{...s,isActive:t}:s))}catch(e){console.log("Error updating connection status:",e)}},td=async(e,t)=>{let s=[...x];[s[e],s[t]]=[s[t],s[e]],h(s);try{await Promise.all([fetch(`/api/providers/${s[e].id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:e})}),fetch(`/api/providers/${s[t].id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({priority:t})})])}catch(e){console.log("Error swapping priority:",e),await e8()}},tc=x.filter(e=>es.includes(e.id));x.length>0&&(es.length,x.length),(0,i.useEffect)(()=>{ea(e=>e.filter(e=>x.some(t=>t.id===e)))},[x]),(()=>{if(0===tc.length)return;let e=new Set(tc.map(e=>e.providerSpecificData?.proxyPoolId||"__none__"));if(1===e.size){let t=[...e][0];if("__none__"===t)return;let s=S.find(e=>e.id===t);return s?.name}})();let tp=()=>{er||K(!1)},tm=async e=>{en(!0);try{let t=0;for(let{connectionId:s,proxyPoolId:a}of e)try{(await fetch(`/api/providers/${s}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:a})})).ok||(t+=1)}catch(e){console.log("Error applying proxy for",s,e),t+=1}t>0&&alert(`Updated with ${t} failed request(s).`),await e8(),K(!1)}finally{en(!1)}},tx=e=>tm(x.map(t=>({connectionId:t.id,proxyPoolId:e}))),tu=(0,a.jsx)("div",{className:"flex min-w-0 flex-col divide-y divide-black/[0.03] dark:divide-white/[0.03]",children:x.map((e,t)=>(0,a.jsx)("div",{className:"flex min-w-0 items-stretch",children:(0,a.jsx)("div",{className:"flex-1 min-w-0",children:(0,a.jsx)(j,{connection:e,proxyPools:S,isOAuth:eK,isFirst:0===t,isLast:t===x.length-1,onMoveUp:()=>td(t,t-1),onMoveDown:()=>td(t,t+1),onToggleActive:t=>to(e.id,t),onUpdateProxy:async t=>{try{(await fetch(`/api/providers/${e.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:t||null})})).ok&&h(s=>s.map(s=>s.id===e.id?{...s,providerSpecificData:{...s.providerSpecificData,proxyPoolId:t||null}}:s))}catch(e){console.log("Error updating proxy:",e)}},onEdit:()=>{L(e),_(!0)},onDelete:()=>ti(e.id),oneByOneStatus:eP[e.id]||null})})},e.id))}),th=S.filter(e=>!0===e.isActive),tf=(0,a.jsx)(d.aF,{isOpen:M,onClose:tp,title:`Apply Proxy (${x.length} connections)`,children:(0,a.jsxs)("div",{className:"flex flex-col gap-3",children:[(0,a.jsxs)("div",{className:"flex flex-col",children:[(0,a.jsxs)("button",{onClick:()=>{let e=S.filter(e=>!0===e.isActive);return 0===e.length?void alert("No active proxy pools available."):tm(x.map((t,s)=>({connectionId:t.id,proxyPoolId:e[s%e.length].id})))},disabled:er||0===th.length,className:"flex items-center gap-2 rounded-lg px-3 py-2 text-left transition-colors hover:bg-black/[0.04] dark:hover:bg-white/[0.04] disabled:cursor-not-allowed disabled:opacity-50",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-text-muted text-[18px]",children:"sync_alt"}),(0,a.jsx)("span",{className:"text-sm text-text-main",children:"One-to-one (rotate)"})]}),(0,a.jsxs)("button",{onClick:()=>tx(null),disabled:er,className:"flex items-center gap-2 rounded-lg px-3 py-2 text-left transition-colors hover:bg-black/[0.04] dark:hover:bg-white/[0.04] disabled:cursor-not-allowed disabled:opacity-50",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-text-muted text-[18px]",children:"link_off"}),(0,a.jsx)("span",{className:"text-sm text-text-main",children:"None (unbind all)"})]}),S.map(e=>(0,a.jsxs)("button",{onClick:()=>tx(e.id),disabled:er||!0!==e.isActive,className:"flex items-center gap-2 rounded-lg px-3 py-2 text-left transition-colors hover:bg-black/[0.04] dark:hover:bg-white/[0.04] disabled:cursor-not-allowed disabled:opacity-50",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-text-muted text-[18px]",children:"lan"}),(0,a.jsx)("span",{className:"truncate text-sm text-text-main",children:e.name}),!0!==e.isActive&&(0,a.jsx)("span",{className:"text-[10px] text-text-muted",children:"(inactive)"})]},e.id))]}),er&&(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"Applying..."}),(0,a.jsx)(d.$n,{onClick:tp,variant:"ghost",fullWidth:!0,disabled:er,children:"Cancel"})]})}),tg=async e=>{if(!X){Y(e);try{let t=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${eX}/${e}`})}),s=await t.json();G(t=>({...t,[e]:s.ok?"ok":"error"})),Z(s.ok?"":s.error||"Model not reachable")}catch{G(t=>({...t,[e]:"error"})),Z("Network error")}finally{Y(null)}}};return f?(0,a.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,a.jsx)(d.Qv,{}),(0,a.jsx)(d.Qv,{})]}):eq?(0,a.jsxs)("div",{className:"flex min-w-0 flex-col gap-6 px-1 sm:gap-8 sm:px-0",children:[(0,a.jsxs)("div",{className:"min-w-0",children:[(0,a.jsxs)(n(),{href:"/dashboard/providers",className:"inline-flex items-center gap-1 text-sm text-text-muted hover:text-primary transition-colors mb-4",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-lg",children:"arrow_back"}),"Back to Providers"]}),(0,a.jsxs)("div",{className:"flex min-w-0 items-center gap-3 sm:gap-4",children:[(0,a.jsx)("div",{className:"flex size-12 shrink-0 items-center justify-center rounded-lg",style:{backgroundColor:`${eq.color}15`},children:B?(0,a.jsx)("span",{className:"text-sm font-bold",style:{color:eq.color},children:eq.textIcon||eq.id.slice(0,2).toUpperCase()}):(0,a.jsx)(o.default,{src:eB&&eq.apiType?"responses"===eq.apiType?"/providers/oai-r.png":"/providers/oai-cc.png":eH?"/providers/anthropic-m.png":`/providers/${eq.id}.png`,alt:eq.name,width:48,height:48,className:"max-h-12 max-w-12 rounded-lg object-contain",sizes:"48px",onError:()=>H(!0)})}),(0,a.jsxs)("div",{className:"min-w-0",children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 flex-wrap",children:[(0,a.jsx)("h1",{className:"truncate text-2xl font-semibold tracking-tight sm:text-3xl",children:eq.name}),(eq.notice?.apiKeyUrl||eq.notice?.signupUrl||eq.website)&&(0,a.jsxs)("a",{href:eq.notice?.apiKeyUrl||eq.notice?.signupUrl||eq.website,target:"_blank",rel:"noopener noreferrer",className:"text-xs text-primary hover:underline inline-flex items-center gap-1",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"open_in_new"}),eq.notice?.apiKeyUrl?"Get API Key":"Sign up / Learn more"]})]}),(0,a.jsxs)("p",{className:"text-text-muted",children:[x.length," connection",1===x.length?"":"s"]})]})]})]}),eq.deprecated&&(0,a.jsxs)("div",{className:"flex items-center gap-2 px-3 py-2 rounded-lg bg-yellow-500/10 border border-yellow-500/30",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[16px] text-yellow-500 mt-0.5 shrink-0",children:"warning"}),(0,a.jsx)("p",{className:"text-xs text-red-600 dark:text-yellow-400 leading-relaxed",children:eq.deprecationNotice})]}),eq.notice?.text&&!eq.deprecated&&(0,a.jsxs)("div",{className:"flex flex-col gap-2 rounded-lg border border-blue-500/30 bg-blue-500/10 px-3 py-2 sm:flex-row sm:items-center",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[16px] text-blue-500 shrink-0",children:"info"}),(0,a.jsx)("p",{className:"min-w-0 flex-1 text-xs leading-relaxed text-blue-600 dark:text-blue-400",children:eq.notice.text}),eq.notice.apiKeyUrl&&(0,a.jsx)("a",{href:eq.notice.apiKeyUrl,target:"_blank",rel:"noopener noreferrer",className:"inline-flex justify-center rounded bg-blue-500 px-2 py-1 text-xs font-medium text-white transition-colors hover:bg-blue-600 sm:py-0.5",children:"Get API Key →"})]}),eV&&v&&(0,a.jsx)(d.Zp,{children:(0,a.jsxs)("div",{className:"mb-4 flex flex-col gap-3 sm:flex-row sm:items-start sm:justify-between",children:[(0,a.jsxs)("div",{className:"min-w-0",children:[(0,a.jsx)("h2",{className:"text-lg font-semibold",children:eH?"Anthropic Compatible Details":"OpenAI Compatible Details"}),(0,a.jsxs)("p",{className:"break-all text-sm text-text-muted",children:[eH?"Messages API":"responses"===v.apiType?"Responses API":"Chat Completions"," \xb7 ",(v.baseUrl||"").replace(/\/$/,""),"/",eH?"messages":"responses"===v.apiType?"responses":"chat/completions"]})]}),(0,a.jsxs)("div",{className:"grid grid-cols-1 gap-2 sm:flex sm:items-center",children:[(0,a.jsx)(d.$n,{size:"sm",icon:"add",onClick:()=>{D(""),E(!0)},className:"w-full sm:w-auto",children:"Add API Key"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"edit",onClick:()=>q(!0),className:"w-full sm:w-auto",children:"Edit"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"delete",onClick:async()=>{ej({title:"Delete Compatible Node",message:`Delete this ${eH?"Anthropic":"OpenAI"} Compatible node?`,onConfirm:async()=>{ej(null);try{(await fetch(`/api/provider-nodes/${r}`,{method:"DELETE"})).ok&&s.push("/dashboard/providers")}catch(e){console.log("Error deleting provider node:",e)}}})},className:"w-full sm:w-auto",children:"Delete"})]})]})}),eL?(0,a.jsx)(d.gw,{providerId:r}):(0,a.jsxs)(d.Zp,{children:[(0,a.jsxs)("div",{className:"mb-4 flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between",children:[(0,a.jsx)("h2",{className:"text-lg font-semibold",children:"Connections"}),(0,a.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center sm:gap-4",children:[x.length>0&&S.length>0&&(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"lan",onClick:()=>K(!0),children:"Apply Proxy"}),x.length>0&&(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"sync",onClick:ta,disabled:eC,children:eC?"Testing...":"Test One-by-One"}),eC&&(0,a.jsx)(d.$n,{size:"sm",variant:"ghost",icon:"stop",onClick:()=>{eC&&(eD.current=!0,e$(!0))},disabled:eA,children:eA?"Stopping...":"Stop"})]}),(0,a.jsxs)("div",{className:"flex flex-wrap items-center gap-2",children:[(0,a.jsx)("span",{className:"text-xs text-text-muted font-medium",children:"Round Robin"}),(0,a.jsx)(d.lM,{checked:"round-robin"===eo,onChange:e=>{let t=e?"round-robin":null,s=e?ec||"1":ec;e&&!ec&&ep("1"),ed(t),te(t,s)}}),"round-robin"===eo&&(0,a.jsxs)("div",{className:"flex items-center gap-1.5",children:[(0,a.jsx)("span",{className:"text-xs text-text-muted",children:"Sticky:"}),(0,a.jsx)("input",{type:"number",min:1,value:ec,onChange:e=>{var t;ep(t=e.target.value),te("round-robin",t)},placeholder:"1",className:"w-14 px-2 py-1 text-xs border border-border rounded-md bg-background focus:outline-none focus:border-primary"})]})]})]})]}),(0,a.jsxs)("div",{className:"flex flex-wrap gap-2 mb-3",children:[eG?(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(d.$n,{size:"sm",icon:"lock",onClick:e0,children:eQ}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"key",onClick:e1,children:eZ})]}):(0,a.jsx)(d.$n,{size:"sm",icon:"add",onClick:()=>{eK?e0():e1()},children:"Add"}),(0,a.jsx)("input",{ref:ek,type:"file",accept:"application/json",className:"hidden",onChange:ez}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"upload",onClick:()=>ek.current?.click(),disabled:eN,children:eN?"Importing...":"Import"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"download",onClick:()=>window.open(`/api/providers/export?provider=${r}`,"_blank"),disabled:0===x.length,children:"Export All"})]}),0===x.length?(0,a.jsx)("div",{className:"flex items-center gap-3",children:(0,a.jsxs)("div",{className:"flex items-center gap-3",children:[(0,a.jsx)("div",{className:"inline-flex items-center justify-center w-9 h-9 rounded-full bg-primary/10 text-primary shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:eK?"lock":"key"})}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"No connections yet"})]})}):(0,a.jsxs)(a.Fragment,{children:[eE&&(0,a.jsx)("div",{className:"mb-4 rounded-lg border border-black/10 bg-black/[0.02] px-3 py-2 text-xs text-text-muted dark:border-white/10 dark:bg-white/[0.03]",children:(0,a.jsxs)("div",{className:"flex flex-wrap items-center gap-3",children:[(0,a.jsxs)("span",{children:["Total: ",eE.total]}),(0,a.jsxs)("span",{children:["Completed: ",eE.completed]}),(0,a.jsxs)("span",{children:["Passed: ",eE.passed]}),(0,a.jsxs)("span",{children:["Failed: ",eE.failed]}),eE.stopped&&(0,a.jsx)("span",{className:"text-amber-600 dark:text-amber-400",children:"Stopped"}),eC&&eT&&(0,a.jsxs)("span",{children:["Running: ",x.find(e=>e.id===eT)?.name||eT]})]})}),tu]})]}),(0,a.jsxs)(d.Zp,{children:[(0,a.jsxs)("div",{className:"mb-4 flex flex-col gap-2 sm:flex-row sm:items-center sm:justify-between",children:[(0,a.jsx)("h2",{className:"text-lg font-semibold",children:"Available Models"}),!eV&&(e=[...eJ,...ef.filter(e=>!eJ.some(t=>t.id===e.id))].filter(e=>!e.type||"llm"===e.type).map(e=>e.id).filter(e=>!ey.includes(e)),(0,a.jsxs)("div",{className:"flex gap-2",children:[ey.length>0&&(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"restart_alt",onClick:e6,children:"Active All"}),e.length>0&&(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"block",onClick:()=>e4(e),children:"Disable All"})]}))]}),!!Q&&(0,a.jsx)("p",{className:"text-xs text-red-500 mb-3 break-words",children:Q}),(()=>{let e,t,s;if(eV)return(0,a.jsx)(b,{providerStorageAlias:eX,providerDisplayAlias:eY,modelAliases:J,copied:eU,onCopy:e_,onSetAlias:tt,onDeleteAlias:ts,connections:x,isAnthropic:eH});let i=[...eJ,...ef.filter(e=>!eJ.some(t=>t.id===e.id))].filter(e=>!e.type||"llm"===e.type),l=new Set(ey),n=i.filter(e=>!l.has(e.id)),o=i.filter(e=>l.has(e.id)),d=Object.entries(J).filter(([e,t])=>{let s=`${eX}/`;if(!t.startsWith(s))return!1;let a=t.slice(s.length);return eq.passthroughModels?!eJ.some(e=>e.id===a):!eJ.some(e=>e.id===a)&&e===a}).map(([e,t])=>({id:t.slice(`${eX}/`.length),alias:e,fullModel:t}));return(0,a.jsxs)("div",{className:"flex flex-wrap gap-3",children:[d.map(e=>(0,a.jsx)(g,{model:{id:e.id},fullModel:`${eY}/${e.id}`,alias:e.alias,copied:eU,onCopy:e_,onSetAlias:()=>{},onDeleteAlias:()=>ts(e.alias),testStatus:V[e.id],onTest:x.length>0||eL?()=>tg(e.id):void 0,isTesting:X===e.id,isCustom:!0,isFree:!1},e.id)),n.map(e=>{let t=`${eX}/${e.id}`,s=`${r}/${e.id}`,i=Object.entries(J).find(([,e])=>e===t||e===s)?.[0];return(0,a.jsx)(g,{model:e,fullModel:`${eY}/${e.id}`,alias:i,copied:eU,onCopy:e_,onSetAlias:t=>tt(e.id,t,eX),onDeleteAlias:()=>ts(i),testStatus:V[e.id],onTest:x.length>0||eL?()=>tg(e.id):void 0,isTesting:X===e.id,isFree:e.isFree,onDisable:()=>e5(e.id)},e.id)}),(0,a.jsxs)("button",{onClick:()=>et(!0),className:"flex w-full items-center justify-center gap-1.5 rounded-lg border border-dashed border-primary/40 px-3 py-2 text-xs text-primary transition-colors hover:border-primary hover:bg-primary/5 sm:w-auto",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",children:"add"}),"Add Model"]}),eu.length>0&&(e=new Set(Object.values(J)),t=new Set(eJ.map(e=>e.id)),0===(s=eu.filter(s=>!e.has(`${eX}/${s.id}`)&&!t.has(s.id))).length?null:(0,a.jsxs)("div",{className:"w-full mt-2",children:[(0,a.jsx)("p",{className:"text-xs text-text-muted mb-2",children:"Suggested free models (≥200k context):"}),(0,a.jsx)("div",{className:"flex flex-wrap gap-2",children:s.map(e=>(0,a.jsxs)("button",{onClick:async()=>{let t=e.id.split("/").pop();await tt(e.id,t,eX)},className:"flex items-center gap-1 px-2.5 py-1.5 rounded-lg border border-black/10 dark:border-white/10 text-xs text-text-muted hover:text-primary hover:border-primary/40 hover:bg-primary/5 transition-colors",title:`${e.name} \xb7 ${(e.contextLength/1e3).toFixed(0)}k ctx`,children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[13px]",children:"add"}),e.id.split("/").pop()]},e.id))})]})),o.length>0&&(0,a.jsxs)("div",{className:"w-full mt-2",children:[(0,a.jsxs)("p",{className:"text-xs text-text-muted mb-2",children:["Disabled models (",o.length,"):"]}),(0,a.jsx)("div",{className:"flex flex-wrap gap-2",children:o.map(e=>(0,a.jsxs)("button",{onClick:()=>e3(e.id),className:"flex items-center gap-1 px-2.5 py-1.5 rounded-lg border border-dashed border-black/10 dark:border-white/10 text-xs text-text-muted hover:text-primary hover:border-primary/40 hover:bg-primary/5 transition-colors",title:"Restore model",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[13px]",children:"add"}),e.id]},e.id))})]})]})})()]}),tf,"kiro"===r?(0,a.jsx)(d.Mh,{isOpen:$,providerInfo:eq,onSuccess:tl,onClose:()=>T(!1)}):"codex"===r?(0,a.jsx)(d.K3,{isOpen:$,providerInfo:eq,onSuccess:tl,onClose:()=>T(!1)}):"cursor"===r?(0,a.jsx)(d.G9,{isOpen:$,onSuccess:tl,onClose:()=>T(!1)}):"gitlab"===r?(0,a.jsx)(d.vj,{isOpen:$,providerInfo:eq,onSuccess:tl,onClose:()=>T(!1)}):(0,a.jsx)(d.LF,{isOpen:$,provider:r,providerInfo:eq,onSuccess:tl,onClose:()=>T(!1)}),"iflow"===r&&(0,a.jsx)(d.vE,{isOpen:O,onSuccess:()=>{e8(),P(!1)},onClose:()=>P(!1)}),(0,a.jsx)(w,{isOpen:I,provider:r,providerName:eq.name,isCompatible:eV,isAnthropic:eH,authType:eq?.authType,authHint:eq?.authHint,website:eq?.website,proxyPools:S,error:R,onSave:tr,onBulkDone:e8,onClose:()=>{D(""),E(!1)}}),(0,a.jsx)(d.wI,{isOpen:U,connection:F,proxyPools:S,onSave:tn,onClose:()=>_(!1)}),eV&&(0,a.jsx)(k,{isOpen:z,node:v,onSave:e9,onClose:()=>q(!1),isAnthropic:eH}),!eV&&(0,a.jsx)(C,{isOpen:ee,providerAlias:eX,providerDisplayAlias:eY,onSave:async e=>{let t=eq?.passthroughModels?e.split("/").pop():e;await tt(e,t,eX),et(!1)},onClose:()=>et(!1)}),(0,a.jsx)(d.uo,{isOpen:!!ev,onClose:()=>ej(null),onConfirm:ev?.onConfirm,title:ev?.title||"Confirm",message:ev?.message,variant:"danger"})]}):(0,a.jsxs)("div",{className:"text-center py-20",children:[(0,a.jsx)("p",{className:"text-text-muted",children:"Provider not found"}),(0,a.jsx)(n(),{href:"/dashboard/providers",className:"text-primary mt-4 inline-block",children:"Back to Providers"})]})}w.propTypes={isOpen:f().bool.isRequired,provider:f().string,providerName:f().string,isCompatible:f().bool,isAnthropic:f().bool,authType:f().string,authHint:f().string,website:f().string,proxyPools:f().arrayOf(f().shape({id:f().string,name:f().string})),error:f().string,onSave:f().func.isRequired,onBulkDone:f().func,onClose:f().func.isRequired},k.propTypes={isOpen:f().bool.isRequired,node:f().shape({id:f().string,name:f().string,prefix:f().string,apiType:f().string,baseUrl:f().string}),onSave:f().func.isRequired,onClose:f().func.isRequired,isAnthropic:f().bool},C.propTypes={isOpen:f().bool.isRequired,providerAlias:f().string.isRequired,providerDisplayAlias:f().string.isRequired,onSave:f().func.isRequired,onClose:f().func.isRequired}},43883:(e,t,s)=>{Promise.resolve().then(s.bind(s,17721))}},e=>{e.O(0,[2574,3862,2194,698,5772,1321,5497,8441,3794,7358],()=>e(e.s=43883)),_N_E=e.O()}]);
package/app/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ktrouter",
3
- "version": "1.1.1",
3
+ "version": "1.1.3",
4
4
  "description": "KTRouter - AI proxy router with web dashboard",
5
5
  "scripts": {
6
6
  "dev": "next dev --webpack --port 3008",
@@ -77,4 +77,4 @@
77
77
  "author": "QuocTai",
78
78
  "license": "MIT",
79
79
  "private": true
80
- }
80
+ }
@@ -1,4 +1,4 @@
1
- var K=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Zt=K((Od,qn)=>{var gu=require("fs"),Dr=require("path"),Fn=require("os"),xa="ktrouter";function Kn(){return process.platform==="win32"?Dr.join(process.env.APPDATA||Dr.join(Fn.homedir(),"AppData","Roaming"),xa):Dr.join(Fn.homedir(),`.${xa}`)}function yu(){let e=process.env.DATA_DIR;if(!e)return Kn();try{return gu.mkdirSync(e,{recursive:!0}),e}catch(t){if(t?.code==="EACCES"||t?.code==="EPERM")return console.warn(`[DATA_DIR] '${e}' not writable \u2192 fallback ~/.${xa}`),Kn();throw t}}var Mn=yu(),vu=Dr.join(Mn,"mitm");qn.exports={DATA_DIR:Mn,MITM_DIR:vu}});var Sa=K((Vd,Hn)=>{var mu=["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com","api.individual.githubcopilot.com","q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com","api2.cursor.sh"],Cu={antigravity:[":generateContent",":streamGenerateContent"],copilot:["/chat/completions","/v1/messages","/responses"],kiro:["/generateAssistantResponse"],cursor:["/BidiAppend","/RunSSE","/RunPoll","/Run"]},Eu={antigravity:{"gemini-default":"gemini-3.5-flash-high","gemini-3-flash-agent":"gemini-3.5-flash-high","gemini-3-flash":"gemini-3.5-flash-medium","gemini-3.0-flash":"gemini-3.5-flash-medium","gemini-3-pro":"gemini-3.1-pro-high","gemini-3.1-pro":"gemini-3.1-pro-high","gemini-3.5-flash":"gemini-3.5-flash-high","gemini-3.5-flash-low":"gemini-3.5-flash-medium","gemini-pro-agent":"gemini-3.1-pro-high","claude-sonnet-4-6":"claude-sonnet-4-6-thinking","claude-opus-4-6":"claude-opus-4-6-thinking","gpt-oss-120b":"gpt-oss-120b-medium"}},xu={antigravity:[{match:/flash.*high|high.*flash/i,alias:"gemini-3.5-flash-high"},{match:/flash.*medium|medium.*flash|flash.*low|low.*flash/i,alias:"gemini-3.5-flash-medium"},{match:/flash/i,alias:"gemini-3.5-flash-medium"},{match:/pro.*low|low.*pro/i,alias:"gemini-3.1-pro-low"},{match:/gemini.*pro|pro.*gemini/i,alias:"gemini-3.1-pro-high"},{match:/opus/i,alias:"claude-opus-4-6-thinking"},{match:/sonnet|claude/i,alias:"claude-sonnet-4-6-thinking"},{match:/gpt.*oss|oss/i,alias:"gpt-oss-120b-medium"}]},Su=["recordCodeAssistMetrics","recordTrajectoryAnalytics","fetchAdminControls","listExperiments"];function Tu(e){let t=(e||"").split(":")[0];return t==="api.individual.githubcopilot.com"?"copilot":t==="daily-cloudcode-pa.googleapis.com"||t==="cloudcode-pa.googleapis.com"?"antigravity":t==="q.us-east-1.amazonaws.com"||t==="codewhisperer.us-east-1.amazonaws.com"?"kiro":t==="api2.cursor.sh"?"cursor":null}Hn.exports={TARGET_HOSTS:mu,URL_PATTERNS:Cu,MODEL_SYNONYMS:Eu,MODEL_PATTERNS:xu,LOG_BLACKLIST_URL_PARTS:Su,getToolForHost:Tu}});var Mt=K((Fd,Xn)=>{var Ur=require("fs"),Ia=require("path"),Ta=require("zlib"),{DATA_DIR:Au}=Zt(),{LOG_BLACKLIST_URL_PARTS:Iu}=Sa();function Gn(){return new Date().toLocaleTimeString("en-US",{hour12:!1})}var Bu=e=>console.log(`[${Gn()}] [MITM] ${e}`),bu=e=>console.error(`[${Gn()}] \u274C [MITM] ${e}`),Pr=Ia.join(Au,"logs","mitm"),Ba=["1","true","yes","on"].includes(String(process.env.MITM_FILE_LOG||"").toLowerCase()),_u=/^\s*(\{\s*\}|\[\s*\]|null)?\s*$/,Nu=new Set(["authorization","proxy-authorization","cookie","set-cookie","x-api-key","api-key","apikey","access-token","refresh-token","access_token","refresh_token","id_token","token"]);function wu(){return Ba}function zn(){Ur.existsSync(Pr)||Ur.mkdirSync(Pr,{recursive:!0})}function Qn(e){let t=String(e||"").toLowerCase();return Nu.has(t)||t.includes("token")}function Yn(e){return Array.isArray(e)?e.map(()=>"[redacted]"):"[redacted]"}function $n(e={}){let t={};for(let[a,r]of Object.entries(e||{}))t[a]=Qn(a)?Yn(r):r;return t}function Aa(e){if(Array.isArray(e))return e.map(Aa);if(!e||typeof e!="object")return e;let t={};for(let[a,r]of Object.entries(e))t[a]=Qn(a)?Yn(r):Aa(r);return t}function jn(e,t=80){return String(e).replace(/[^a-zA-Z0-9]/g,"_").substring(0,t)}function Wn(e){return e?Iu.some(t=>e.includes(t)):!1}function Ru(e,t){if(!e||e.length===0)return e;try{let a=(t||"").toLowerCase();if(a.includes("gzip"))return Ta.gunzipSync(e);if(a.includes("br"))return Ta.brotliDecompressSync(e);if(a.includes("deflate"))return Ta.inflateSync(e)}catch{}return e}function Lu(e,t,a="raw"){if(!Ba||Wn(e.url))return null;try{zn();let r=new Date().toISOString().replace(/[:.]/g,"-"),n=jn((e.headers.host||"")+e.url),s=Ia.join(Pr,`${r}_${a}_${n}.req.json`),i=null;try{i=JSON.parse(t.toString())}catch{}return Ur.writeFileSync(s,JSON.stringify({method:e.method,url:e.url,host:e.headers.host,headers:$n(e.headers),body:i!==null?Aa(i):t.toString("utf8")},null,2)),s}catch{return null}}function ku(e,t="raw"){if(!Ba||Wn(e.url))return null;zn();let a=new Date().toISOString().replace(/[:.]/g,"-"),r=jn((e.headers.host||"")+e.url),n=Ia.join(Pr,`${a}_${t}_${r}.res.txt`),s=0,i={},o=[];return{writeHeader:(u,l)=>{s=u,i=l||{}},writeChunk:u=>{u!=null&&o.push(Buffer.isBuffer(u)?u:Buffer.from(u))},end:()=>{try{let u=Buffer.concat(o),l=i["content-encoding"]||i["Content-Encoding"],c=Ru(u,l).toString("utf8");if(_u.test(c))return;let g={...i};delete g["content-encoding"],delete g["Content-Encoding"];let m=`STATUS: ${s}
1
+ var K=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var Zt=K((Od,qn)=>{var gu=require("fs"),Dr=require("path"),Fn=require("os"),xa="ktrouter";function Kn(){return process.platform==="win32"?Dr.join(process.env.APPDATA||Dr.join(Fn.homedir(),"AppData","Roaming"),xa):Dr.join(Fn.homedir(),`.${xa}`)}function yu(){let e=process.env.DATA_DIR;if(!e)return Kn();try{return gu.mkdirSync(e,{recursive:!0}),e}catch(t){if(t?.code==="EACCES"||t?.code==="EPERM")return console.warn(`[DATA_DIR] '${e}' not writable \u2192 fallback ~/.${xa}`),Kn();throw t}}var Mn=yu(),vu=Dr.join(Mn,"mitm");qn.exports={DATA_DIR:Mn,MITM_DIR:vu}});var Sa=K((Vd,Hn)=>{var mu=["daily-cloudcode-pa.googleapis.com","cloudcode-pa.googleapis.com","api.individual.githubcopilot.com","q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com","api2.cursor.sh"],Cu={antigravity:[":generateContent",":streamGenerateContent"],copilot:["/chat/completions","/v1/messages","/responses"],kiro:["/generateAssistantResponse"],cursor:["/BidiAppend","/RunSSE","/RunPoll","/Run"]},Eu={antigravity:{"gemini-default":"gemini-3.5-flash-high","gemini-3-flash-agent":"gemini-3.5-flash-high","gemini-3-flash":"gemini-3.5-flash-medium","gemini-3.0-flash":"gemini-3.5-flash-medium","gemini-3-pro":"gemini-3.1-pro-high","gemini-3.1-pro":"gemini-3.1-pro-high","gemini-3.5-flash":"gemini-3.5-flash-high","gemini-3.5-flash-low":"gemini-3.5-flash-low","gemini-pro-agent":"gemini-3.1-pro-high","claude-sonnet-4-6":"claude-sonnet-4-6-thinking","claude-opus-4-6":"claude-opus-4-6-thinking","gpt-oss-120b":"gpt-oss-120b-medium"}},xu={antigravity:[{match:/flash.*high|high.*flash/i,alias:"gemini-3.5-flash-high"},{match:/flash.*medium|medium.*flash/i,alias:"gemini-3.5-flash-medium"},{match:/flash.*low|low.*flash/i,alias:"gemini-3.5-flash-low"},{match:/flash/i,alias:"gemini-3.5-flash-medium"},{match:/pro.*low|low.*pro/i,alias:"gemini-3.1-pro-low"},{match:/gemini.*pro|pro.*gemini/i,alias:"gemini-3.1-pro-high"},{match:/opus/i,alias:"claude-opus-4-6-thinking"},{match:/sonnet|claude/i,alias:"claude-sonnet-4-6-thinking"},{match:/gpt.*oss|oss/i,alias:"gpt-oss-120b-medium"}]},Su=["recordCodeAssistMetrics","recordTrajectoryAnalytics","fetchAdminControls","listExperiments"];function Tu(e){let t=(e||"").split(":")[0];return t==="api.individual.githubcopilot.com"?"copilot":t==="daily-cloudcode-pa.googleapis.com"||t==="cloudcode-pa.googleapis.com"?"antigravity":t==="q.us-east-1.amazonaws.com"||t==="codewhisperer.us-east-1.amazonaws.com"?"kiro":t==="api2.cursor.sh"?"cursor":null}Hn.exports={TARGET_HOSTS:mu,URL_PATTERNS:Cu,MODEL_SYNONYMS:Eu,MODEL_PATTERNS:xu,LOG_BLACKLIST_URL_PARTS:Su,getToolForHost:Tu}});var Mt=K((Fd,Xn)=>{var Ur=require("fs"),Ia=require("path"),Ta=require("zlib"),{DATA_DIR:Au}=Zt(),{LOG_BLACKLIST_URL_PARTS:Iu}=Sa();function Gn(){return new Date().toLocaleTimeString("en-US",{hour12:!1})}var Bu=e=>console.log(`[${Gn()}] [MITM] ${e}`),bu=e=>console.error(`[${Gn()}] \u274C [MITM] ${e}`),Pr=Ia.join(Au,"logs","mitm"),Ba=["1","true","yes","on"].includes(String(process.env.MITM_FILE_LOG||"").toLowerCase()),_u=/^\s*(\{\s*\}|\[\s*\]|null)?\s*$/,Nu=new Set(["authorization","proxy-authorization","cookie","set-cookie","x-api-key","api-key","apikey","access-token","refresh-token","access_token","refresh_token","id_token","token"]);function wu(){return Ba}function zn(){Ur.existsSync(Pr)||Ur.mkdirSync(Pr,{recursive:!0})}function Qn(e){let t=String(e||"").toLowerCase();return Nu.has(t)||t.includes("token")}function Yn(e){return Array.isArray(e)?e.map(()=>"[redacted]"):"[redacted]"}function $n(e={}){let t={};for(let[a,r]of Object.entries(e||{}))t[a]=Qn(a)?Yn(r):r;return t}function Aa(e){if(Array.isArray(e))return e.map(Aa);if(!e||typeof e!="object")return e;let t={};for(let[a,r]of Object.entries(e))t[a]=Qn(a)?Yn(r):Aa(r);return t}function jn(e,t=80){return String(e).replace(/[^a-zA-Z0-9]/g,"_").substring(0,t)}function Wn(e){return e?Iu.some(t=>e.includes(t)):!1}function Ru(e,t){if(!e||e.length===0)return e;try{let a=(t||"").toLowerCase();if(a.includes("gzip"))return Ta.gunzipSync(e);if(a.includes("br"))return Ta.brotliDecompressSync(e);if(a.includes("deflate"))return Ta.inflateSync(e)}catch{}return e}function Lu(e,t,a="raw"){if(!Ba||Wn(e.url))return null;try{zn();let r=new Date().toISOString().replace(/[:.]/g,"-"),n=jn((e.headers.host||"")+e.url),s=Ia.join(Pr,`${r}_${a}_${n}.req.json`),i=null;try{i=JSON.parse(t.toString())}catch{}return Ur.writeFileSync(s,JSON.stringify({method:e.method,url:e.url,host:e.headers.host,headers:$n(e.headers),body:i!==null?Aa(i):t.toString("utf8")},null,2)),s}catch{return null}}function ku(e,t="raw"){if(!Ba||Wn(e.url))return null;zn();let a=new Date().toISOString().replace(/[:.]/g,"-"),r=jn((e.headers.host||"")+e.url),n=Ia.join(Pr,`${a}_${t}_${r}.res.txt`),s=0,i={},o=[];return{writeHeader:(u,l)=>{s=u,i=l||{}},writeChunk:u=>{u!=null&&o.push(Buffer.isBuffer(u)?u:Buffer.from(u))},end:()=>{try{let u=Buffer.concat(o),l=i["content-encoding"]||i["Content-Encoding"],c=Ru(u,l).toString("utf8");if(_u.test(c))return;let g={...i};delete g["content-encoding"],delete g["Content-Encoding"];let m=`STATUS: ${s}
2
2
  HEADERS: ${JSON.stringify($n(g),null,2)}
3
3
  ---BODY---
4
4
  ${c}`;Ur.writeFileSync(n,m)}catch{}},file:n}}Xn.exports={log:Bu,err:bu,dumpRequest:Lu,createResponseDumper:ku,isFileLoggingEnabled:wu}});var Y=K((Kd,Jn)=>{Jn.exports={options:{usePureJavaScript:!1}}});var ti=K((Md,ei)=>{var ba={};ei.exports=ba;var Zn={};ba.encode=function(e,t,a){if(typeof t!="string")throw new TypeError('"alphabet" must be a string.');if(a!==void 0&&typeof a!="number")throw new TypeError('"maxline" must be a number.');var r="";if(!(e instanceof Uint8Array))r=Du(e,t);else{var n=0,s=t.length,i=t.charAt(0),o=[0];for(n=0;n<e.length;++n){for(var u=0,l=e[n];u<o.length;++u)l+=o[u]<<8,o[u]=l%s,l=l/s|0;for(;l>0;)o.push(l%s),l=l/s|0}for(n=0;e[n]===0&&n<e.length-1;++n)r+=i;for(n=o.length-1;n>=0;--n)r+=t[o[n]]}if(a){var f=new RegExp(".{1,"+a+"}","g");r=r.match(f).join(`\r
@@ -61,7 +61,7 @@ ${i}
61
61
  `).replace(/'/g,"'\\''");await kr(`printf '%s' '${o}' | tee ${Ze} > /dev/null`,t),await eu(t)}Ca(`\u{1F310} DNS ${e}: \u2705 removed ${r.join(", ")}`)}catch(n){let s=n.message?.includes("incorrect password")?"Wrong sudo password":`Failed to remove DNS entry: ${n.message}`;throw new Error(s)}}async function hd(e){for(let t of Object.keys(Ft))try{await tu(t,e)}catch(a){ud(`DNS ${t}: failed to remove \u2014 ${a.message}`)}}function pd(){try{if(!_e.existsSync(Ze))return;let e=Object.values(Ft).flat(),t=_e.readFileSync(Ze,"utf8"),a=It?`\r
62
62
  `:`
63
63
  `,n=t.split(/\r?\n/).filter(s=>!e.some(i=>s.includes(i))).join(a).replace(/[\r\n\s]+$/g,"")+a;if(n===t)return;if(_e.writeFileSync(Ze,n,"utf8"),It)try{Lr("ipconfig /flushdns",{windowsHide:!0,stdio:"ignore"})}catch{}else if(Xo)try{Lr("dscacheutil -flushcache && killall -HUP mDNSResponder",{stdio:"ignore"})}catch{}else try{Lr("resolvectl flush-caches 2>/dev/null || true",{stdio:"ignore"})}catch{}}catch{}}ru.exports={TOOL_HOSTS:Ft,addDNSEntry:dd,removeDNSEntry:tu,removeAllDNSEntries:hd,removeAllDNSEntriesSync:pd,execWithPassword:kr,isSudoAvailable:Ea,canRunSudoWithoutPassword:Jo,isSudoPasswordRequired:ld,checkDNSEntry:Ln,checkAllDNSStatus:cd}});var fu=require("https"),nu=require("fs"),iu=require("path"),gd=require("dns"),{promisify:yd}=require("util"),{execSync:kn}=require("child_process"),{log:cu,err:Bt,dumpRequest:vd,createResponseDumper:md,isFileLoggingEnabled:Cd}=Mt(),{TARGET_HOSTS:Ed,URL_PATTERNS:xd,MODEL_SYNONYMS:Sd,MODEL_PATTERNS:Td,getToolForHost:Ad}=Sa(),{DATA_DIR:Yh,MITM_DIR:su}=Zt(),{getCertForDomain:Id}=Eo(),{getMitmAlias:Bd}=Ao(),gr=443,ou=process.platform==="win32",du=Cd(),uu={name:"x-request-source",value:"local"},bd=process.env.MITM_REWRITE_ANTIGRAVITY_PASSTHROUGH==="1"?{"cloudcode-pa.googleapis.com":"daily-cloudcode-pa.googleapis.com"}:{},Dn={antigravity:wo(),copilot:Lo(),kiro:Oo(),cursor:Fo()},Un=new Map,hu;function _d(e,t){try{if(Un.has(e))return t(null,Un.get(e));let a=Id(e);if(!a)return t(new Error(`Failed to generate cert for ${e}`));let r=require("tls").createSecureContext({key:a.key,cert:`${a.cert}
64
- ${hu}`});Un.set(e,r),t(null,r)}catch(a){Bt(`SNI error for ${e}: ${a.message}`),t(a)}}var pu;try{let e=nu.readFileSync(iu.join(su,"rootCA.key")),t=nu.readFileSync(iu.join(su,"rootCA.crt"));hu=t.toString("utf8"),pu={key:e,cert:t,SNICallback:_d}}catch(e){Bt(`Root CA not found: ${e.message}`),process.exit(1)}var Pn={},Nd=300*1e3;async function wd(e){let t=Pn[e];if(t&&Date.now()-t.ts<Nd)return t.ip;let a=new gd.Resolver;a.setServers(["8.8.8.8"]);let n=await yd(a.resolve4.bind(a))(e);return Pn[e]={ip:n[0],ts:Date.now()},Pn[e].ip}function Rd(e){return new Promise((t,a)=>{let r=[];e.on("data",n=>r.push(n)),e.on("end",()=>t(Buffer.concat(r))),e.on("error",a)})}function Ld(e,t){let a=e.match(/\/models\/([^/:]+)/);if(a)return a[1];try{let r=JSON.parse(t.toString());return r.conversationState?r.conversationState.currentMessage?.userInputMessage?.modelId||null:r.model||null}catch{return null}}function kd(e,t){if(!t)return null;try{let a=Bd(e);if(!a)return null;let r=Sd?.[e]?.[t]||t;if(a[r])return a[r];if(e==="antigravity"){let i=(...u)=>{let l=u.find(f=>a[f]);return l?a[l]:null},o=null;if(r==="gemini-3.5-flash-high"?o=i("gemini-3.5-flash-high","gemini-3-flash-agent","gemini-3.5-flash","gemini-3-flash"):r==="gemini-3.5-flash-medium"?o=i("gemini-3.5-flash-medium","gemini-3-flash","gemini-3.0-flash","gemini-3.5-flash-low"):r==="gemini-pro-agent"||r==="gemini-3.1-pro-high"?o=i("gemini-3.1-pro-high","gemini-pro-agent","gemini-3.1-pro"):r==="gemini-3-flash-agent"||r==="gemini-3-flash"?o=i("gemini-3-flash","gemini-3-flash-agent","gemini-3.0-flash"):r==="gemini-3.5-flash-low"?o=i("gemini-3.5-flash-low","gemini-3.5-flash","gemini-3-flash"):r==="claude-sonnet-4-6-thinking"?o=i("claude-sonnet-4-6-thinking","claude-sonnet-4-6"):r==="claude-opus-4-6-thinking"?o=i("claude-opus-4-6-thinking","claude-opus-4-6"):r==="gpt-oss-120b-medium"&&(o=i("gpt-oss-120b-medium","gpt-oss-120b")),o)return o}let n=Td?.[e]?.find(({match:i})=>i.test(t)||i.test(r));if(n?.alias){if(a[n.alias])return a[n.alias];if(e==="antigravity"){let i={"gemini-3.5-flash-high":["gemini-3-flash-agent","gemini-3.5-flash","gemini-3-flash"],"gemini-3.5-flash-medium":["gemini-3-flash","gemini-3.0-flash","gemini-3.5-flash-low"],"claude-sonnet-4-6-thinking":["claude-sonnet-4-6"],"claude-opus-4-6-thinking":["claude-opus-4-6"],"gpt-oss-120b-medium":["gpt-oss-120b"]}[n.alias]?.find(o=>a[o]);if(i)return a[i]}}let s=Object.keys(a).find(i=>i&&a[i]&&(r.startsWith(i)||i.startsWith(r)));return s?a[s]:null}catch{return null}}async function Xt(e,t,a,r){let n=(e.headers.host||Ed[0]).split(":")[0],s=bd[n]||n,i=await wd(s),o=du?md(e,"passthrough"):null,u=fu.request({hostname:i,port:443,path:e.url,method:e.method,headers:{...e.headers,host:s},servername:s,rejectUnauthorized:!1},l=>{if(t.writeHead(l.statusCode,l.headers),o&&o.writeHeader(l.statusCode,l.headers),!r&&!o){l.pipe(t);return}let f=[];l.on("data",c=>{o&&o.writeChunk(c),r&&f.push(c),t.write(c)}),l.on("end",()=>{if(o&&o.end(),t.end(),r)try{r(Buffer.concat(f),l.headers)}catch{}})});u.on("error",l=>{Bt(`Passthrough error: ${l.message}`),o&&(o.writeChunk(`
64
+ ${hu}`});Un.set(e,r),t(null,r)}catch(a){Bt(`SNI error for ${e}: ${a.message}`),t(a)}}var pu;try{let e=nu.readFileSync(iu.join(su,"rootCA.key")),t=nu.readFileSync(iu.join(su,"rootCA.crt"));hu=t.toString("utf8"),pu={key:e,cert:t,SNICallback:_d}}catch(e){Bt(`Root CA not found: ${e.message}`),process.exit(1)}var Pn={},Nd=300*1e3;async function wd(e){let t=Pn[e];if(t&&Date.now()-t.ts<Nd)return t.ip;let a=new gd.Resolver;a.setServers(["8.8.8.8"]);let n=await yd(a.resolve4.bind(a))(e);return Pn[e]={ip:n[0],ts:Date.now()},Pn[e].ip}function Rd(e){return new Promise((t,a)=>{let r=[];e.on("data",n=>r.push(n)),e.on("end",()=>t(Buffer.concat(r))),e.on("error",a)})}function Ld(e,t){let a=e.match(/\/models\/([^/:]+)/);if(a)return a[1];try{let r=JSON.parse(t.toString());return r.conversationState?r.conversationState.currentMessage?.userInputMessage?.modelId||null:r.model||null}catch{return null}}function kd(e,t){if(!t)return null;try{let a=Bd(e);if(!a)return null;let r=Sd?.[e]?.[t]||t;if(a[r])return a[r];if(e==="antigravity"){let i=(...u)=>{let l=u.find(f=>a[f]);return l?a[l]:null},o=null;if(r==="gemini-3.5-flash-high"?o=i("gemini-3.5-flash-high","gemini-3-flash-agent","gemini-3.5-flash","gemini-3-flash"):r==="gemini-3.5-flash-medium"?o=i("gemini-3.5-flash-medium","gemini-3-flash","gemini-3.0-flash","gemini-3.5-flash-low"):r==="gemini-pro-agent"||r==="gemini-3.1-pro-high"?o=i("gemini-3.1-pro-high","gemini-pro-agent","gemini-3.1-pro"):r==="gemini-3-flash-agent"||r==="gemini-3-flash"?o=i("gemini-3-flash","gemini-3-flash-agent","gemini-3.0-flash"):r==="gemini-3.5-flash-low"?o=i("gemini-3.5-flash-low","gemini-3.5-flash-medium","gemini-3-flash"):r==="claude-sonnet-4-6-thinking"?o=i("claude-sonnet-4-6-thinking","claude-sonnet-4-6"):r==="claude-opus-4-6-thinking"?o=i("claude-opus-4-6-thinking","claude-opus-4-6"):r==="gpt-oss-120b-medium"&&(o=i("gpt-oss-120b-medium","gpt-oss-120b")),o)return o}let n=Td?.[e]?.find(({match:i})=>i.test(t)||i.test(r));if(n?.alias){if(a[n.alias])return a[n.alias];if(e==="antigravity"){let i={"gemini-3.5-flash-high":["gemini-3-flash-agent","gemini-3.5-flash","gemini-3-flash"],"gemini-3.5-flash-medium":["gemini-3-flash","gemini-3.0-flash","gemini-3.5-flash-low"],"gemini-3.5-flash-low":["gemini-3.5-flash-medium","gemini-3-flash"],"claude-sonnet-4-6-thinking":["claude-sonnet-4-6"],"claude-opus-4-6-thinking":["claude-opus-4-6"],"gpt-oss-120b-medium":["gpt-oss-120b"]}[n.alias]?.find(o=>a[o]);if(i)return a[i]}}let s=Object.keys(a).find(i=>i&&a[i]&&(r.startsWith(i)||i.startsWith(r)));return s?a[s]:null}catch{return null}}async function Xt(e,t,a,r){let n=(e.headers.host||Ed[0]).split(":")[0],s=bd[n]||n,i=await wd(s),o=du?md(e,"passthrough"):null,u=fu.request({hostname:i,port:443,path:e.url,method:e.method,headers:{...e.headers,host:s},servername:s,rejectUnauthorized:!1},l=>{if(t.writeHead(l.statusCode,l.headers),o&&o.writeHeader(l.statusCode,l.headers),!r&&!o){l.pipe(t);return}let f=[];l.on("data",c=>{o&&o.writeChunk(c),r&&f.push(c),t.write(c)}),l.on("end",()=>{if(o&&o.end(),t.end(),r)try{r(Buffer.concat(f),l.headers)}catch{}})});u.on("error",l=>{Bt(`Passthrough error: ${l.message}`),o&&(o.writeChunk(`
65
65
  [ERROR] ${l.message}
66
66
  `),o.end()),t.headersSent||t.writeHead(502),t.end("Bad Gateway")}),a.length>0&&u.write(a),u.end()}var On=fu.createServer(pu,async(e,t)=>{try{if(e.url==="/_mitm_health"){t.writeHead(200,{"Content-Type":"application/json"}),t.end(JSON.stringify({ok:!0,pid:process.pid}));return}let a=await Rd(e);if(du&&vd(e,a,"raw"),e.headers[uu.name]===uu.value)return Xt(e,t,a);let r=Ad(e.headers.host);if(!r||!(xd[r]||[]).some(u=>e.url.includes(u)))return Xt(e,t,a);if(r==="cursor")return Dn[r].intercept(e,t,a,null,Xt);let i=Ld(e.url,a),o=kd(r,i);return r==="antigravity"||o?Dn[r].intercept(e,t,a,o,Xt):Xt(e,t,a)}catch(a){Bt(`Unhandled error: ${a.message}`),t.headersSent||t.writeHead(500,{"Content-Type":"application/json"}),t.end(JSON.stringify({error:{message:a.message,type:"mitm_error"}}))}});function Dd(e){try{let t=[];if(ou){let a=`powershell -NonInteractive -WindowStyle Hidden -Command "Get-NetTCPConnection -LocalPort ${e} -State Listen -ErrorAction SilentlyContinue | Select-Object -ExpandProperty OwningProcess"`,r=kn(a,{encoding:"utf-8",windowsHide:!0}).trim();if(!r)return;t=r.split(/\r?\n/).map(n=>n.trim()).filter(n=>n&&Number(n)!==process.pid&&Number(n)>4)}else{let a=kn(`lsof -nP -iTCP:${e} -sTCP:LISTEN -t`,{encoding:"utf-8",windowsHide:!0}).trim();if(!a)return;t=a.split(`
67
67
  `).filter(r=>r&&Number(r)!==process.pid)}if(t.length===0)return;t.forEach(a=>{try{ou?kn(`taskkill /F /PID ${a}`,{windowsHide:!0}):process.kill(Number(a),"SIGKILL")}catch(r){Bt(`Failed to kill PID ${a}: ${r.message}`)}}),cu(`Killed ${t.length} process(es) on port ${e}`)}catch(t){if(t.status!==1)throw t}}try{Dd(gr)}catch(e){Bt(`Cannot kill process on port ${gr}: ${e.message}`),process.exit(1)}On.listen(gr,()=>cu(`\u{1F680} Server ready on :${gr}`));On.on("error",e=>{e.code==="EADDRINUSE"?Bt(`Port ${gr} already in use`):e.code==="EACCES"?Bt(`Permission denied for port ${gr}`):Bt(e.message),process.exit(1)});var{removeAllDNSEntriesSync:Ud}=au(),lu=!1,Vn=()=>{if(lu)return;lu=!0,Ud();let e=setTimeout(()=>process.exit(0),1500);On.close(()=>{clearTimeout(e),process.exit(0)})};process.on("SIGTERM",Vn);process.on("SIGINT",Vn);process.platform==="win32"&&process.on("SIGBREAK",Vn);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ktrouter",
3
- "version": "1.1.1",
3
+ "version": "1.1.3",
4
4
  "description": "KTRouter CLI - AI proxy router with web dashboard",
5
5
  "bin": {
6
6
  "ktrouter": "./cli.js"
@@ -47,4 +47,4 @@
47
47
  "nodemon": "^3.1.14"
48
48
  },
49
49
  "author": "QuocTai"
50
- }
50
+ }