@yina-npm/openrouterx 0.4.27 → 0.4.31

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 (791) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +14 -3
  3. package/app/.next/build-manifest.json +3 -3
  4. package/app/.next/routes-manifest.json +70 -0
  5. package/app/.next/server/app/(dashboard)/dashboard/admin/keys/page.js +2 -2
  6. package/app/.next/server/app/(dashboard)/dashboard/admin/keys/page.js.nft.json +1 -1
  7. package/app/.next/server/app/(dashboard)/dashboard/admin/keys/page_client-reference-manifest.js +1 -1
  8. package/app/.next/server/app/(dashboard)/dashboard/admin/users/page.js +2 -2
  9. package/app/.next/server/app/(dashboard)/dashboard/admin/users/page.js.nft.json +1 -1
  10. package/app/.next/server/app/(dashboard)/dashboard/admin/users/page_client-reference-manifest.js +1 -1
  11. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page.js +2 -2
  12. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page.js.nft.json +1 -1
  13. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
  14. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js +2 -2
  15. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js.nft.json +1 -1
  16. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js +2 -2
  18. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js.nft.json +1 -1
  19. package/app/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  20. package/app/.next/server/app/(dashboard)/dashboard/console-log/page.js +2 -2
  21. package/app/.next/server/app/(dashboard)/dashboard/console-log/page.js.nft.json +1 -1
  22. package/app/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -1
  23. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js +2 -2
  24. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js.nft.json +1 -1
  25. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  26. package/app/.next/server/app/(dashboard)/dashboard/focus-ui/page.js +2 -2
  27. package/app/.next/server/app/(dashboard)/dashboard/focus-ui/page.js.nft.json +1 -1
  28. package/app/.next/server/app/(dashboard)/dashboard/focus-ui/page_client-reference-manifest.js +1 -1
  29. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page.js +2 -2
  30. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page.js.nft.json +1 -1
  31. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page_client-reference-manifest.js +1 -1
  32. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page.js +2 -2
  33. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page.js.nft.json +1 -1
  34. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page_client-reference-manifest.js +1 -1
  35. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page.js +3 -3
  36. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page.js.nft.json +1 -1
  37. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page_client-reference-manifest.js +1 -1
  38. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page.js +2 -2
  39. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page.js.nft.json +1 -1
  40. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page_client-reference-manifest.js +1 -1
  41. package/app/.next/server/app/(dashboard)/dashboard/mitm/page.js +2 -2
  42. package/app/.next/server/app/(dashboard)/dashboard/mitm/page.js.nft.json +1 -1
  43. package/app/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
  44. package/app/.next/server/app/(dashboard)/dashboard/network-analysis/page.js +2 -2
  45. package/app/.next/server/app/(dashboard)/dashboard/network-analysis/page.js.nft.json +1 -1
  46. package/app/.next/server/app/(dashboard)/dashboard/network-analysis/page_client-reference-manifest.js +1 -1
  47. package/app/.next/server/app/(dashboard)/dashboard/page.js +2 -2
  48. package/app/.next/server/app/(dashboard)/dashboard/page.js.nft.json +1 -1
  49. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  50. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js +2 -2
  51. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js.nft.json +1 -1
  52. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  53. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +4 -2
  54. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js.nft.json +1 -1
  55. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  56. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js +2 -2
  57. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js.nft.json +1 -1
  58. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  59. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js +2 -2
  60. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js.nft.json +1 -1
  61. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  62. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page.js +2 -2
  63. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page.js.nft.json +1 -1
  64. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
  65. package/app/.next/server/app/(dashboard)/dashboard/quota/page.js +2 -2
  66. package/app/.next/server/app/(dashboard)/dashboard/quota/page.js.nft.json +1 -1
  67. package/app/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
  68. package/app/.next/server/app/(dashboard)/dashboard/skills/page.js +2 -2
  69. package/app/.next/server/app/(dashboard)/dashboard/skills/page.js.nft.json +1 -1
  70. package/app/.next/server/app/(dashboard)/dashboard/skills/page_client-reference-manifest.js +1 -1
  71. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js +2 -2
  72. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js.nft.json +1 -1
  73. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  74. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js +2 -2
  75. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js.nft.json +1 -1
  76. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  77. package/app/.next/server/app/(dashboard)/dashboard/user/page.js +3 -3
  78. package/app/.next/server/app/(dashboard)/dashboard/user/page.js.nft.json +1 -1
  79. package/app/.next/server/app/(dashboard)/dashboard/user/page_client-reference-manifest.js +1 -1
  80. package/app/.next/server/app/_global-error/page.js +3 -3
  81. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  82. package/app/.next/server/app/_global-error.html +1 -1
  83. package/app/.next/server/app/_global-error.rsc +1 -1
  84. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  85. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  86. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  87. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  88. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  89. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  90. package/app/.next/server/app/_not-found/page.js +2 -2
  91. package/app/.next/server/app/_not-found/page.js.nft.json +1 -1
  92. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  93. package/app/.next/server/app/_not-found.html +1 -1
  94. package/app/.next/server/app/_not-found.rsc +5 -6
  95. package/app/.next/server/app/_not-found.segments/_full.segment.rsc +5 -6
  96. package/app/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  97. package/app/.next/server/app/_not-found.segments/_index.segment.rsc +5 -6
  98. package/app/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  99. package/app/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  100. package/app/.next/server/app/_not-found.segments/_tree.segment.rsc +3 -4
  101. package/app/.next/server/app/api/auth/login/route.js +1 -1
  102. package/app/.next/server/app/api/auth/login/route.js.nft.json +1 -1
  103. package/app/.next/server/app/api/auth/logout/route.js +1 -1
  104. package/app/.next/server/app/api/auth/logout/route.js.nft.json +1 -1
  105. package/app/.next/server/app/api/auth/me/route.js +1 -1
  106. package/app/.next/server/app/api/auth/me/route.js.nft.json +1 -1
  107. package/app/.next/server/app/api/auth/oidc/callback/route.js +1 -0
  108. package/app/.next/server/app/api/auth/oidc/callback/route.js.nft.json +1 -0
  109. package/app/.next/server/app/api/auth/oidc/callback/route_client-reference-manifest.js +1 -0
  110. package/app/.next/server/app/api/auth/oidc/start/route.js +1 -0
  111. package/app/.next/server/app/api/auth/oidc/start/route.js.nft.json +1 -0
  112. package/app/.next/server/app/api/auth/oidc/start/route_client-reference-manifest.js +1 -0
  113. package/app/.next/server/app/api/auth/oidc/test/route.js +1 -0
  114. package/app/.next/server/app/api/auth/oidc/test/route.js.nft.json +1 -0
  115. package/app/.next/server/app/api/auth/oidc/test/route_client-reference-manifest.js +1 -0
  116. package/app/.next/server/app/api/auth/status/route.js +1 -0
  117. package/app/.next/server/app/api/auth/status/route.js.nft.json +1 -0
  118. package/app/.next/server/app/api/auth/status/route_client-reference-manifest.js +1 -0
  119. package/app/.next/server/app/api/cli-tools/all-statuses/route.js +9 -0
  120. package/app/.next/server/app/api/cli-tools/all-statuses/route.js.nft.json +1 -0
  121. package/app/.next/server/app/api/cli-tools/all-statuses/route_client-reference-manifest.js +1 -0
  122. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
  123. package/app/.next/server/app/api/cli-tools/antigravity-mitm/inject-auth/route.js +1 -1
  124. package/app/.next/server/app/api/cli-tools/antigravity-mitm/restart/route.js +1 -1
  125. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +1 -1
  126. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js.nft.json +1 -1
  127. package/app/.next/server/app/api/cli-tools/antigravity-mitm/test/route.js +1 -1
  128. package/app/.next/server/app/api/cli-tools/claude-settings/route.js +2 -2
  129. package/app/.next/server/app/api/cli-tools/claude-settings/route.js.nft.json +1 -1
  130. package/app/.next/server/app/api/cli-tools/cline-settings/route.js +2 -0
  131. package/app/.next/server/app/api/cli-tools/cline-settings/route.js.nft.json +1 -0
  132. package/app/.next/server/app/api/cli-tools/cline-settings/route_client-reference-manifest.js +1 -0
  133. package/app/.next/server/app/api/cli-tools/codex-settings/route.js +1 -32
  134. package/app/.next/server/app/api/cli-tools/codex-settings/route.js.nft.json +1 -1
  135. package/app/.next/server/app/api/cli-tools/copilot-settings/route.js +1 -1
  136. package/app/.next/server/app/api/cli-tools/cowork-mcp-registry/route.js +1 -1
  137. package/app/.next/server/app/api/cli-tools/cowork-mcp-tools/route.js +2 -0
  138. package/app/.next/server/app/api/cli-tools/cowork-mcp-tools/route.js.nft.json +1 -0
  139. package/app/.next/server/app/api/cli-tools/cowork-mcp-tools/route_client-reference-manifest.js +1 -0
  140. package/app/.next/server/app/api/cli-tools/cowork-settings/route.js +2 -2
  141. package/app/.next/server/app/api/cli-tools/cowork-settings/route.js.nft.json +1 -1
  142. package/app/.next/server/app/api/cli-tools/droid-settings/route.js +1 -1
  143. package/app/.next/server/app/api/cli-tools/droid-settings/route.js.nft.json +1 -1
  144. package/app/.next/server/app/api/cli-tools/hermes-settings/route.js +2 -2
  145. package/app/.next/server/app/api/cli-tools/hermes-settings/route.js.nft.json +1 -1
  146. package/app/.next/server/app/api/cli-tools/kilo-settings/route.js +2 -0
  147. package/app/.next/server/app/api/cli-tools/kilo-settings/route.js.nft.json +1 -0
  148. package/app/.next/server/app/api/cli-tools/kilo-settings/route_client-reference-manifest.js +1 -0
  149. package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js +2 -2
  150. package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js.nft.json +1 -1
  151. package/app/.next/server/app/api/cli-tools/opencode-settings/route.js +2 -2
  152. package/app/.next/server/app/api/cli-tools/opencode-settings/route.js.nft.json +1 -1
  153. package/app/.next/server/app/api/cloud/auth/route.js +1 -1
  154. package/app/.next/server/app/api/cloud/credentials/update/route.js +1 -1
  155. package/app/.next/server/app/api/cloud/model/resolve/route.js +1 -1
  156. package/app/.next/server/app/api/cloud/models/alias/route.js +1 -1
  157. package/app/.next/server/app/api/combos/[id]/route.js +1 -1
  158. package/app/.next/server/app/api/combos/route.js +1 -1
  159. package/app/.next/server/app/api/health/route.js +1 -1
  160. package/app/.next/server/app/api/init/route.js +1 -1
  161. package/app/.next/server/app/api/init/route.js.nft.json +1 -1
  162. package/app/.next/server/app/api/keys/[id]/route.js +1 -1
  163. package/app/.next/server/app/api/keys/[id]/route.js.nft.json +1 -1
  164. package/app/.next/server/app/api/keys/route.js +1 -1
  165. package/app/.next/server/app/api/keys/route.js.nft.json +1 -1
  166. package/app/.next/server/app/api/locale/route.js +1 -1
  167. package/app/.next/server/app/api/mcp/[plugin]/message/route.js +7 -0
  168. package/app/.next/server/app/api/mcp/[plugin]/message/route.js.nft.json +1 -0
  169. package/app/.next/server/app/api/mcp/[plugin]/message/route_client-reference-manifest.js +1 -0
  170. package/app/.next/server/app/api/mcp/[plugin]/sse/route.js +10 -0
  171. package/app/.next/server/app/api/mcp/[plugin]/sse/route.js.nft.json +1 -0
  172. package/app/.next/server/app/api/mcp/[plugin]/sse/route_client-reference-manifest.js +1 -0
  173. package/app/.next/server/app/api/media-providers/tts/deepgram/voices/route.js +1 -1
  174. package/app/.next/server/app/api/media-providers/tts/elevenlabs/voices/route.js +1 -1
  175. package/app/.next/server/app/api/media-providers/tts/inworld/voices/route.js +1 -1
  176. package/app/.next/server/app/api/media-providers/tts/voices/route.js +1 -1
  177. package/app/.next/server/app/api/models/alias/route.js +1 -1
  178. package/app/.next/server/app/api/models/availability/route.js +1 -1
  179. package/app/.next/server/app/api/models/custom/route.js +1 -1
  180. package/app/.next/server/app/api/models/disabled/route.js +1 -1
  181. package/app/.next/server/app/api/models/disabled/route.js.nft.json +1 -1
  182. package/app/.next/server/app/api/models/route.js +1 -1
  183. package/app/.next/server/app/api/models/route.js.nft.json +1 -1
  184. package/app/.next/server/app/api/models/test/route.js +1 -1
  185. package/app/.next/server/app/api/models/test/route.js.nft.json +1 -1
  186. package/app/.next/server/app/api/network-analysis/route.js +2 -2
  187. package/app/.next/server/app/api/network-analysis/route.js.nft.json +1 -1
  188. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js +2 -2
  189. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js.nft.json +1 -1
  190. package/app/.next/server/app/api/oauth/cursor/auto-import/route.js +2 -2
  191. package/app/.next/server/app/api/oauth/cursor/import/route.js +1 -1
  192. package/app/.next/server/app/api/oauth/gitlab/pat/route.js +1 -1
  193. package/app/.next/server/app/api/oauth/iflow/cookie/route.js +1 -1
  194. package/app/.next/server/app/api/oauth/kiro/auto-import/route.js +1 -1
  195. package/app/.next/server/app/api/oauth/kiro/import/route.js +1 -1
  196. package/app/.next/server/app/api/oauth/kiro/social-authorize/route.js +1 -1
  197. package/app/.next/server/app/api/oauth/kiro/social-exchange/route.js +1 -1
  198. package/app/.next/server/app/api/pricing/route.js +1 -1
  199. package/app/.next/server/app/api/provider-nodes/[id]/route.js +1 -1
  200. package/app/.next/server/app/api/provider-nodes/route.js +1 -1
  201. package/app/.next/server/app/api/provider-nodes/route.js.nft.json +1 -1
  202. package/app/.next/server/app/api/provider-nodes/validate/route.js +1 -1
  203. package/app/.next/server/app/api/providers/[id]/models/route.js +1 -1
  204. package/app/.next/server/app/api/providers/[id]/models/route.js.nft.json +1 -1
  205. package/app/.next/server/app/api/providers/[id]/route.js +1 -1
  206. package/app/.next/server/app/api/providers/[id]/route.js.nft.json +1 -1
  207. package/app/.next/server/app/api/providers/[id]/test/route.js +1 -1
  208. package/app/.next/server/app/api/providers/[id]/test-models/route.js +1 -1
  209. package/app/.next/server/app/api/providers/client/route.js +1 -1
  210. package/app/.next/server/app/api/providers/client/route.js.nft.json +1 -1
  211. package/app/.next/server/app/api/providers/kilo/free-models/route.js +1 -1
  212. package/app/.next/server/app/api/providers/route.js +1 -1
  213. package/app/.next/server/app/api/providers/route.js.nft.json +1 -1
  214. package/app/.next/server/app/api/providers/suggested-models/route.js +1 -1
  215. package/app/.next/server/app/api/providers/test-batch/route.js +1 -1
  216. package/app/.next/server/app/api/providers/validate/route.js +1 -1
  217. package/app/.next/server/app/api/proxy-pools/[id]/route.js +1 -1
  218. package/app/.next/server/app/api/proxy-pools/[id]/test/route.js +1 -1
  219. package/app/.next/server/app/api/proxy-pools/route.js +1 -1
  220. package/app/.next/server/app/api/proxy-pools/vercel-deploy/route.js +2 -2
  221. package/app/.next/server/app/api/settings/database/route.js +1 -1
  222. package/app/.next/server/app/api/settings/proxy-test/route.js +1 -1
  223. package/app/.next/server/app/api/settings/require-login/route.js +1 -1
  224. package/app/.next/server/app/api/settings/route.js +1 -1
  225. package/app/.next/server/app/api/shutdown/route.js +1 -1
  226. package/app/.next/server/app/api/tags/route.js +1 -1
  227. package/app/.next/server/app/api/translator/console-logs/route.js +1 -1
  228. package/app/.next/server/app/api/translator/console-logs/stream/route.js +2 -2
  229. package/app/.next/server/app/api/translator/load/route.js +1 -1
  230. package/app/.next/server/app/api/translator/save/route.js +1 -1
  231. package/app/.next/server/app/api/translator/send/route.js +1 -1
  232. package/app/.next/server/app/api/translator/send/route.js.nft.json +1 -1
  233. package/app/.next/server/app/api/translator/translate/route.js +1 -1
  234. package/app/.next/server/app/api/translator/translate/route.js.nft.json +1 -1
  235. package/app/.next/server/app/api/tunnel/disable/route.js +1 -1
  236. package/app/.next/server/app/api/tunnel/disable/route.js.nft.json +1 -1
  237. package/app/.next/server/app/api/tunnel/enable/route.js +1 -1
  238. package/app/.next/server/app/api/tunnel/enable/route.js.nft.json +1 -1
  239. package/app/.next/server/app/api/tunnel/status/route.js +1 -1
  240. package/app/.next/server/app/api/tunnel/status/route.js.nft.json +1 -1
  241. package/app/.next/server/app/api/tunnel/tailscale-check/route.js +1 -1
  242. package/app/.next/server/app/api/tunnel/tailscale-check/route.js.nft.json +1 -1
  243. package/app/.next/server/app/api/tunnel/tailscale-disable/route.js +1 -1
  244. package/app/.next/server/app/api/tunnel/tailscale-disable/route.js.nft.json +1 -1
  245. package/app/.next/server/app/api/tunnel/tailscale-enable/route.js +1 -1
  246. package/app/.next/server/app/api/tunnel/tailscale-enable/route.js.nft.json +1 -1
  247. package/app/.next/server/app/api/tunnel/tailscale-install/route.js +2 -2
  248. package/app/.next/server/app/api/tunnel/tailscale-install/route.js.nft.json +1 -1
  249. package/app/.next/server/app/api/tunnel/tailscale-login/route.js +1 -1
  250. package/app/.next/server/app/api/tunnel/tailscale-start-daemon/route.js +2 -2
  251. package/app/.next/server/app/api/tunnel/tailscale-start-daemon/route.js.nft.json +1 -1
  252. package/app/.next/server/app/api/usage/[connectionId]/route.js +1 -1
  253. package/app/.next/server/app/api/usage/[connectionId]/route.js.nft.json +1 -1
  254. package/app/.next/server/app/api/usage/api-keys/route.js +1 -1
  255. package/app/.next/server/app/api/usage/api-keys/route.js.nft.json +1 -1
  256. package/app/.next/server/app/api/usage/chart/route.js +1 -1
  257. package/app/.next/server/app/api/usage/chart/route.js.nft.json +1 -1
  258. package/app/.next/server/app/api/usage/history/route.js +1 -1
  259. package/app/.next/server/app/api/usage/history/route.js.nft.json +1 -1
  260. package/app/.next/server/app/api/usage/logs/route.js +1 -1
  261. package/app/.next/server/app/api/usage/logs/route.js.nft.json +1 -1
  262. package/app/.next/server/app/api/usage/providers/route.js +1 -1
  263. package/app/.next/server/app/api/usage/providers/route.js.nft.json +1 -1
  264. package/app/.next/server/app/api/usage/request-details/route.js +1 -1
  265. package/app/.next/server/app/api/usage/request-details/route.js.nft.json +1 -1
  266. package/app/.next/server/app/api/usage/request-logs/route.js +1 -1
  267. package/app/.next/server/app/api/usage/request-logs/route.js.nft.json +1 -1
  268. package/app/.next/server/app/api/usage/stats/route.js +1 -1
  269. package/app/.next/server/app/api/usage/stats/route.js.nft.json +1 -1
  270. package/app/.next/server/app/api/usage/stream/route.js +2 -2
  271. package/app/.next/server/app/api/usage/stream/route.js.nft.json +1 -1
  272. package/app/.next/server/app/api/users/[id]/route.js +1 -1
  273. package/app/.next/server/app/api/users/[id]/route.js.nft.json +1 -1
  274. package/app/.next/server/app/api/users/route.js +1 -1
  275. package/app/.next/server/app/api/users/route.js.nft.json +1 -1
  276. package/app/.next/server/app/api/v1/api/chat/route.js +1 -1
  277. package/app/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
  278. package/app/.next/server/app/api/v1/audio/speech/route.js +1 -1
  279. package/app/.next/server/app/api/v1/audio/speech/route.js.nft.json +1 -1
  280. package/app/.next/server/app/api/v1/audio/transcriptions/route.js +1 -1
  281. package/app/.next/server/app/api/v1/audio/transcriptions/route.js.nft.json +1 -1
  282. package/app/.next/server/app/api/v1/audio/voices/route.js +1 -1
  283. package/app/.next/server/app/api/v1/chat/completions/route.js +1 -1
  284. package/app/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
  285. package/app/.next/server/app/api/v1/embeddings/route.js +1 -1
  286. package/app/.next/server/app/api/v1/embeddings/route.js.nft.json +1 -1
  287. package/app/.next/server/app/api/v1/images/generations/route.js +2 -2
  288. package/app/.next/server/app/api/v1/images/generations/route.js.nft.json +1 -1
  289. package/app/.next/server/app/api/v1/messages/count_tokens/route.js +1 -1
  290. package/app/.next/server/app/api/v1/messages/route.js +1 -1
  291. package/app/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
  292. package/app/.next/server/app/api/v1/models/[kind]/route.js +1 -1
  293. package/app/.next/server/app/api/v1/models/[kind]/route.js.nft.json +1 -1
  294. package/app/.next/server/app/api/v1/models/info/route.js +1 -1
  295. package/app/.next/server/app/api/v1/models/route.js +1 -1
  296. package/app/.next/server/app/api/v1/models/route.js.nft.json +1 -1
  297. package/app/.next/server/app/api/v1/responses/compact/route.js +1 -1
  298. package/app/.next/server/app/api/v1/responses/compact/route.js.nft.json +1 -1
  299. package/app/.next/server/app/api/v1/responses/route.js +1 -1
  300. package/app/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
  301. package/app/.next/server/app/api/v1/route.js +1 -1
  302. package/app/.next/server/app/api/v1/route.js.nft.json +1 -1
  303. package/app/.next/server/app/api/v1/search/route.js +1 -1
  304. package/app/.next/server/app/api/v1/search/route.js.nft.json +1 -1
  305. package/app/.next/server/app/api/v1/web/fetch/route.js +1 -1
  306. package/app/.next/server/app/api/v1/web/fetch/route.js.nft.json +1 -1
  307. package/app/.next/server/app/api/v1beta/models/[...path]/route.js +1 -1
  308. package/app/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
  309. package/app/.next/server/app/api/v1beta/models/route.js +1 -1
  310. package/app/.next/server/app/api/version/route.js +1 -1
  311. package/app/.next/server/app/api/version/shutdown/route.js +1 -0
  312. package/app/.next/server/app/api/version/shutdown/route.js.nft.json +1 -0
  313. package/app/.next/server/app/api/version/shutdown/route_client-reference-manifest.js +1 -0
  314. package/app/.next/server/app/api/version/update/route.js +1 -1
  315. package/app/.next/server/app/callback/page.js +2 -2
  316. package/app/.next/server/app/callback/page.js.nft.json +1 -1
  317. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  318. package/app/.next/server/app/callback.html +1 -1
  319. package/app/.next/server/app/callback.rsc +6 -7
  320. package/app/.next/server/app/callback.segments/_full.segment.rsc +6 -7
  321. package/app/.next/server/app/callback.segments/_head.segment.rsc +1 -1
  322. package/app/.next/server/app/callback.segments/_index.segment.rsc +5 -6
  323. package/app/.next/server/app/callback.segments/_tree.segment.rsc +3 -4
  324. package/app/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +2 -2
  325. package/app/.next/server/app/callback.segments/callback.segment.rsc +1 -1
  326. package/app/.next/server/app/dashboard/settings/pricing/page.js +2 -2
  327. package/app/.next/server/app/dashboard/settings/pricing/page.js.nft.json +1 -1
  328. package/app/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  329. package/app/.next/server/app/dashboard/settings/pricing.html +1 -1
  330. package/app/.next/server/app/dashboard/settings/pricing.rsc +5 -6
  331. package/app/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +5 -6
  332. package/app/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +1 -1
  333. package/app/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +5 -6
  334. package/app/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +3 -4
  335. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +1 -1
  336. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +1 -1
  337. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +1 -1
  338. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +1 -1
  339. package/app/.next/server/app/favicon.ico/route.js +1 -1
  340. package/app/.next/server/app/index.html +1 -1
  341. package/app/.next/server/app/index.rsc +5 -6
  342. package/app/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  343. package/app/.next/server/app/index.segments/_full.segment.rsc +5 -6
  344. package/app/.next/server/app/index.segments/_head.segment.rsc +1 -1
  345. package/app/.next/server/app/index.segments/_index.segment.rsc +5 -6
  346. package/app/.next/server/app/index.segments/_tree.segment.rsc +3 -4
  347. package/app/.next/server/app/landing/page.js +2 -2
  348. package/app/.next/server/app/landing/page.js.nft.json +1 -1
  349. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  350. package/app/.next/server/app/landing.html +1 -1
  351. package/app/.next/server/app/landing.rsc +5 -6
  352. package/app/.next/server/app/landing.segments/_full.segment.rsc +5 -6
  353. package/app/.next/server/app/landing.segments/_head.segment.rsc +1 -1
  354. package/app/.next/server/app/landing.segments/_index.segment.rsc +5 -6
  355. package/app/.next/server/app/landing.segments/_tree.segment.rsc +3 -4
  356. package/app/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +1 -1
  357. package/app/.next/server/app/landing.segments/landing.segment.rsc +1 -1
  358. package/app/.next/server/app/login/page.js +2 -2
  359. package/app/.next/server/app/login/page.js.nft.json +1 -1
  360. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  361. package/app/.next/server/app/login.html +1 -1
  362. package/app/.next/server/app/login.rsc +6 -7
  363. package/app/.next/server/app/login.segments/_full.segment.rsc +6 -7
  364. package/app/.next/server/app/login.segments/_head.segment.rsc +1 -1
  365. package/app/.next/server/app/login.segments/_index.segment.rsc +5 -6
  366. package/app/.next/server/app/login.segments/_tree.segment.rsc +3 -4
  367. package/app/.next/server/app/login.segments/login/__PAGE__.segment.rsc +2 -2
  368. package/app/.next/server/app/login.segments/login.segment.rsc +1 -1
  369. package/app/.next/server/app/manifest.webmanifest/route.js +2 -2
  370. package/app/.next/server/app/page.js +2 -2
  371. package/app/.next/server/app/page.js.nft.json +1 -1
  372. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  373. package/app/.next/server/app-paths-manifest.json +14 -3
  374. package/app/.next/server/chunks/1263.js +2 -2
  375. package/app/.next/server/chunks/1350.js +7 -0
  376. package/app/.next/server/chunks/{2574.js → 2343.js} +1 -1
  377. package/app/.next/server/chunks/2506.js +4 -3
  378. package/app/.next/server/chunks/2560.js +1 -0
  379. package/app/.next/server/chunks/3110.js +1 -1
  380. package/app/.next/server/chunks/3593.js +9 -0
  381. package/app/.next/server/chunks/3855.js +1 -1
  382. package/app/.next/server/chunks/3913.js +2 -2
  383. package/app/.next/server/chunks/412.js +5 -5
  384. package/app/.next/server/chunks/4126.js +1 -0
  385. package/app/.next/server/chunks/4739.js +9 -0
  386. package/app/.next/server/chunks/4922.js +9 -0
  387. package/app/.next/server/chunks/4989.js +2 -2
  388. package/app/.next/server/chunks/5217.js +9 -0
  389. package/app/.next/server/chunks/5258.js +9 -0
  390. package/app/.next/server/chunks/{7937.js → 5330.js} +4 -4
  391. package/app/.next/server/chunks/5434.js +1 -1
  392. package/app/.next/server/chunks/5573.js +1 -1
  393. package/app/.next/server/chunks/5627.js +7 -7
  394. package/app/.next/server/chunks/5681.js +1 -1
  395. package/app/.next/server/chunks/5789.js +1 -0
  396. package/app/.next/server/chunks/{8838.js → 6001.js} +1 -1
  397. package/app/.next/server/chunks/6182.js +36 -2
  398. package/app/.next/server/chunks/63.js +3 -3
  399. package/app/.next/server/chunks/6393.js +1 -0
  400. package/app/.next/server/chunks/6936.js +1 -0
  401. package/app/.next/server/chunks/723.js +44 -0
  402. package/app/.next/server/chunks/7540.js +1 -0
  403. package/app/.next/server/chunks/7568.js +1 -0
  404. package/app/.next/server/chunks/7595.js +1 -1
  405. package/app/.next/server/chunks/8520.js +9 -0
  406. package/app/.next/server/chunks/8590.js +1 -1
  407. package/app/.next/server/chunks/8760.js +1 -1
  408. package/app/.next/server/chunks/8895.js +4 -4
  409. package/app/.next/server/chunks/8971.js +1 -0
  410. package/app/.next/server/chunks/906.js +1 -0
  411. package/app/.next/server/chunks/9460.js +1 -0
  412. package/app/.next/server/chunks/9489.js +1 -1
  413. package/app/.next/server/chunks/9528.js +32 -0
  414. package/app/.next/server/chunks/9546.js +1 -0
  415. package/app/.next/server/chunks/9609.js +1 -1
  416. package/app/.next/server/chunks/9641.js +1 -1
  417. package/app/.next/server/chunks/9718.js +1 -1
  418. package/app/.next/server/functions-config-manifest.json +2 -0
  419. package/app/.next/server/middleware-build-manifest.js +1 -1
  420. package/app/.next/server/middleware.js +2 -2
  421. package/app/.next/server/pages/404.html +1 -1
  422. package/app/.next/server/pages/500.html +1 -1
  423. package/app/.next/server/server-reference-manifest.js +1 -1
  424. package/app/.next/server/server-reference-manifest.json +1 -1
  425. package/app/.next/static/bKAtYNzF3T9AwhxzQjlwr/_buildManifest.js +1 -0
  426. package/app/.next/static/chunks/1321-222b8cacaa28a34f.js +1 -0
  427. package/app/.next/static/chunks/5497-83030cc3d92a3519.js +7 -0
  428. package/app/.next/static/chunks/5555-fe35208b285372b6.js +3 -0
  429. package/app/.next/static/chunks/5964-87a3fc549eda915f.js +44 -0
  430. package/app/.next/static/chunks/app/(dashboard)/dashboard/admin/keys/{page-e7d9455fb9021069.js → page-0b0deda6732f2c17.js} +1 -1
  431. package/app/.next/static/chunks/app/(dashboard)/dashboard/admin/users/page-78953d3b1df0d645.js +1 -0
  432. package/app/.next/static/chunks/app/(dashboard)/dashboard/basic-chat/page-c86af5c8f255b3b1.js +1 -0
  433. package/app/.next/static/chunks/app/(dashboard)/dashboard/cli-tools/page-e6ab107aa0c88255.js +1 -0
  434. package/app/.next/static/chunks/app/(dashboard)/dashboard/focus-ui/page-0e1c6e92394e082a.js +1 -0
  435. package/app/.next/static/chunks/app/(dashboard)/dashboard/media-providers/[kind]/page-d7972070450d7abc.js +1 -0
  436. package/app/.next/static/chunks/app/(dashboard)/dashboard/mitm/{page-4473f52ad379b661.js → page-320446d3e8bf8cdf.js} +1 -1
  437. package/app/.next/static/chunks/app/(dashboard)/dashboard/profile/page-653d43b972894dc8.js +1 -0
  438. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-bafdc36ddde43d0d.js +3 -0
  439. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/page-d799365a8ef51d37.js +1 -0
  440. package/app/.next/static/chunks/app/(dashboard)/dashboard/translator/page-1172e1764d69e954.js +1 -0
  441. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/page-4319007c3ca0a634.js +1 -0
  442. package/app/.next/static/chunks/app/(dashboard)/{layout-7ea5a7abc543b04d.js → layout-f01d55c89fabcb07.js} +1 -1
  443. package/app/.next/static/chunks/app/_global-error/page-1172e1764d69e954.js +1 -0
  444. package/app/.next/static/chunks/app/api/auth/login/route-1172e1764d69e954.js +1 -0
  445. package/app/.next/static/chunks/app/api/auth/logout/route-1172e1764d69e954.js +1 -0
  446. package/app/.next/static/chunks/app/api/auth/me/route-1172e1764d69e954.js +1 -0
  447. package/app/.next/static/chunks/app/api/auth/oidc/callback/route-1172e1764d69e954.js +1 -0
  448. package/app/.next/static/chunks/app/api/auth/oidc/start/route-1172e1764d69e954.js +1 -0
  449. package/app/.next/static/chunks/app/api/auth/oidc/test/route-1172e1764d69e954.js +1 -0
  450. package/app/.next/static/chunks/app/api/auth/status/route-1172e1764d69e954.js +1 -0
  451. package/app/.next/static/chunks/app/api/cli-tools/all-statuses/route-1172e1764d69e954.js +1 -0
  452. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-1172e1764d69e954.js +1 -0
  453. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/inject-auth/route-1172e1764d69e954.js +1 -0
  454. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/restart/route-1172e1764d69e954.js +1 -0
  455. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-1172e1764d69e954.js +1 -0
  456. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/test/route-1172e1764d69e954.js +1 -0
  457. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-1172e1764d69e954.js +1 -0
  458. package/app/.next/static/chunks/app/api/cli-tools/cline-settings/route-1172e1764d69e954.js +1 -0
  459. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-1172e1764d69e954.js +1 -0
  460. package/app/.next/static/chunks/app/api/cli-tools/copilot-settings/route-1172e1764d69e954.js +1 -0
  461. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-registry/route-1172e1764d69e954.js +1 -0
  462. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-tools/route-1172e1764d69e954.js +1 -0
  463. package/app/.next/static/chunks/app/api/cli-tools/cowork-settings/route-1172e1764d69e954.js +1 -0
  464. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-1172e1764d69e954.js +1 -0
  465. package/app/.next/static/chunks/app/api/cli-tools/hermes-settings/route-1172e1764d69e954.js +1 -0
  466. package/app/.next/static/chunks/app/api/cli-tools/kilo-settings/route-1172e1764d69e954.js +1 -0
  467. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-1172e1764d69e954.js +1 -0
  468. package/app/.next/static/chunks/app/api/cli-tools/opencode-settings/route-1172e1764d69e954.js +1 -0
  469. package/app/.next/static/chunks/app/api/cloud/auth/route-1172e1764d69e954.js +1 -0
  470. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-1172e1764d69e954.js +1 -0
  471. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-1172e1764d69e954.js +1 -0
  472. package/app/.next/static/chunks/app/api/cloud/models/alias/route-1172e1764d69e954.js +1 -0
  473. package/app/.next/static/chunks/app/api/combos/[id]/route-1172e1764d69e954.js +1 -0
  474. package/app/.next/static/chunks/app/api/combos/route-1172e1764d69e954.js +1 -0
  475. package/app/.next/static/chunks/app/api/health/route-1172e1764d69e954.js +1 -0
  476. package/app/.next/static/chunks/app/api/init/route-1172e1764d69e954.js +1 -0
  477. package/app/.next/static/chunks/app/api/keys/[id]/route-1172e1764d69e954.js +1 -0
  478. package/app/.next/static/chunks/app/api/keys/route-1172e1764d69e954.js +1 -0
  479. package/app/.next/static/chunks/app/api/locale/route-1172e1764d69e954.js +1 -0
  480. package/app/.next/static/chunks/app/api/mcp/[plugin]/message/route-1172e1764d69e954.js +1 -0
  481. package/app/.next/static/chunks/app/api/mcp/[plugin]/sse/route-1172e1764d69e954.js +1 -0
  482. package/app/.next/static/chunks/app/api/media-providers/tts/deepgram/voices/route-1172e1764d69e954.js +1 -0
  483. package/app/.next/static/chunks/app/api/media-providers/tts/elevenlabs/voices/route-1172e1764d69e954.js +1 -0
  484. package/app/.next/static/chunks/app/api/media-providers/tts/inworld/voices/route-1172e1764d69e954.js +1 -0
  485. package/app/.next/static/chunks/app/api/media-providers/tts/voices/route-1172e1764d69e954.js +1 -0
  486. package/app/.next/static/chunks/app/api/models/alias/route-1172e1764d69e954.js +1 -0
  487. package/app/.next/static/chunks/app/api/models/availability/route-1172e1764d69e954.js +1 -0
  488. package/app/.next/static/chunks/app/api/models/custom/route-1172e1764d69e954.js +1 -0
  489. package/app/.next/static/chunks/app/api/models/disabled/route-1172e1764d69e954.js +1 -0
  490. package/app/.next/static/chunks/app/api/models/route-1172e1764d69e954.js +1 -0
  491. package/app/.next/static/chunks/app/api/models/test/route-1172e1764d69e954.js +1 -0
  492. package/app/.next/static/chunks/app/api/network-analysis/route-1172e1764d69e954.js +1 -0
  493. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-1172e1764d69e954.js +1 -0
  494. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-1172e1764d69e954.js +1 -0
  495. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-1172e1764d69e954.js +1 -0
  496. package/app/.next/static/chunks/app/api/oauth/gitlab/pat/route-1172e1764d69e954.js +1 -0
  497. package/app/.next/static/chunks/app/api/oauth/iflow/cookie/route-1172e1764d69e954.js +1 -0
  498. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-1172e1764d69e954.js +1 -0
  499. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-1172e1764d69e954.js +1 -0
  500. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-1172e1764d69e954.js +1 -0
  501. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-1172e1764d69e954.js +1 -0
  502. package/app/.next/static/chunks/app/api/pricing/route-1172e1764d69e954.js +1 -0
  503. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-1172e1764d69e954.js +1 -0
  504. package/app/.next/static/chunks/app/api/provider-nodes/route-1172e1764d69e954.js +1 -0
  505. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-1172e1764d69e954.js +1 -0
  506. package/app/.next/static/chunks/app/api/providers/[id]/models/route-1172e1764d69e954.js +1 -0
  507. package/app/.next/static/chunks/app/api/providers/[id]/route-1172e1764d69e954.js +1 -0
  508. package/app/.next/static/chunks/app/api/providers/[id]/test/route-1172e1764d69e954.js +1 -0
  509. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-1172e1764d69e954.js +1 -0
  510. package/app/.next/static/chunks/app/api/providers/client/route-1172e1764d69e954.js +1 -0
  511. package/app/.next/static/chunks/app/api/providers/kilo/free-models/route-1172e1764d69e954.js +1 -0
  512. package/app/.next/static/chunks/app/api/providers/route-1172e1764d69e954.js +1 -0
  513. package/app/.next/static/chunks/app/api/providers/suggested-models/route-1172e1764d69e954.js +1 -0
  514. package/app/.next/static/chunks/app/api/providers/test-batch/route-1172e1764d69e954.js +1 -0
  515. package/app/.next/static/chunks/app/api/providers/validate/route-1172e1764d69e954.js +1 -0
  516. package/app/.next/static/chunks/app/api/proxy-pools/[id]/route-1172e1764d69e954.js +1 -0
  517. package/app/.next/static/chunks/app/api/proxy-pools/[id]/test/route-1172e1764d69e954.js +1 -0
  518. package/app/.next/static/chunks/app/api/proxy-pools/route-1172e1764d69e954.js +1 -0
  519. package/app/.next/static/chunks/app/api/proxy-pools/vercel-deploy/route-1172e1764d69e954.js +1 -0
  520. package/app/.next/static/chunks/app/api/settings/database/route-1172e1764d69e954.js +1 -0
  521. package/app/.next/static/chunks/app/api/settings/proxy-test/route-1172e1764d69e954.js +1 -0
  522. package/app/.next/static/chunks/app/api/settings/require-login/route-1172e1764d69e954.js +1 -0
  523. package/app/.next/static/chunks/app/api/settings/route-1172e1764d69e954.js +1 -0
  524. package/app/.next/static/chunks/app/api/shutdown/route-1172e1764d69e954.js +1 -0
  525. package/app/.next/static/chunks/app/api/tags/route-1172e1764d69e954.js +1 -0
  526. package/app/.next/static/chunks/app/api/translator/console-logs/route-1172e1764d69e954.js +1 -0
  527. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-1172e1764d69e954.js +1 -0
  528. package/app/.next/static/chunks/app/api/translator/load/route-1172e1764d69e954.js +1 -0
  529. package/app/.next/static/chunks/app/api/translator/save/route-1172e1764d69e954.js +1 -0
  530. package/app/.next/static/chunks/app/api/translator/send/route-1172e1764d69e954.js +1 -0
  531. package/app/.next/static/chunks/app/api/translator/translate/route-1172e1764d69e954.js +1 -0
  532. package/app/.next/static/chunks/app/api/tunnel/disable/route-1172e1764d69e954.js +1 -0
  533. package/app/.next/static/chunks/app/api/tunnel/enable/route-1172e1764d69e954.js +1 -0
  534. package/app/.next/static/chunks/app/api/tunnel/status/route-1172e1764d69e954.js +1 -0
  535. package/app/.next/static/chunks/app/api/tunnel/tailscale-check/route-1172e1764d69e954.js +1 -0
  536. package/app/.next/static/chunks/app/api/tunnel/tailscale-disable/route-1172e1764d69e954.js +1 -0
  537. package/app/.next/static/chunks/app/api/tunnel/tailscale-enable/route-1172e1764d69e954.js +1 -0
  538. package/app/.next/static/chunks/app/api/tunnel/tailscale-install/route-1172e1764d69e954.js +1 -0
  539. package/app/.next/static/chunks/app/api/tunnel/tailscale-login/route-1172e1764d69e954.js +1 -0
  540. package/app/.next/static/chunks/app/api/tunnel/tailscale-start-daemon/route-1172e1764d69e954.js +1 -0
  541. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-1172e1764d69e954.js +1 -0
  542. package/app/.next/static/chunks/app/api/usage/api-keys/route-1172e1764d69e954.js +1 -0
  543. package/app/.next/static/chunks/app/api/usage/chart/route-1172e1764d69e954.js +1 -0
  544. package/app/.next/static/chunks/app/api/usage/history/route-1172e1764d69e954.js +1 -0
  545. package/app/.next/static/chunks/app/api/usage/logs/route-1172e1764d69e954.js +1 -0
  546. package/app/.next/static/chunks/app/api/usage/providers/route-1172e1764d69e954.js +1 -0
  547. package/app/.next/static/chunks/app/api/usage/request-details/route-1172e1764d69e954.js +1 -0
  548. package/app/.next/static/chunks/app/api/usage/request-logs/route-1172e1764d69e954.js +1 -0
  549. package/app/.next/static/chunks/app/api/usage/stats/route-1172e1764d69e954.js +1 -0
  550. package/app/.next/static/chunks/app/api/usage/stream/route-1172e1764d69e954.js +1 -0
  551. package/app/.next/static/chunks/app/api/users/[id]/route-1172e1764d69e954.js +1 -0
  552. package/app/.next/static/chunks/app/api/users/route-1172e1764d69e954.js +1 -0
  553. package/app/.next/static/chunks/app/api/v1/api/chat/route-1172e1764d69e954.js +1 -0
  554. package/app/.next/static/chunks/app/api/v1/audio/speech/route-1172e1764d69e954.js +1 -0
  555. package/app/.next/static/chunks/app/api/v1/audio/transcriptions/route-1172e1764d69e954.js +1 -0
  556. package/app/.next/static/chunks/app/api/v1/audio/voices/route-1172e1764d69e954.js +1 -0
  557. package/app/.next/static/chunks/app/api/v1/chat/completions/route-1172e1764d69e954.js +1 -0
  558. package/app/.next/static/chunks/app/api/v1/embeddings/route-1172e1764d69e954.js +1 -0
  559. package/app/.next/static/chunks/app/api/v1/images/generations/route-1172e1764d69e954.js +1 -0
  560. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-1172e1764d69e954.js +1 -0
  561. package/app/.next/static/chunks/app/api/v1/messages/route-1172e1764d69e954.js +1 -0
  562. package/app/.next/static/chunks/app/api/v1/models/[kind]/route-1172e1764d69e954.js +1 -0
  563. package/app/.next/static/chunks/app/api/v1/models/info/route-1172e1764d69e954.js +1 -0
  564. package/app/.next/static/chunks/app/api/v1/models/route-1172e1764d69e954.js +1 -0
  565. package/app/.next/static/chunks/app/api/v1/responses/compact/route-1172e1764d69e954.js +1 -0
  566. package/app/.next/static/chunks/app/api/v1/responses/route-1172e1764d69e954.js +1 -0
  567. package/app/.next/static/chunks/app/api/v1/route-1172e1764d69e954.js +1 -0
  568. package/app/.next/static/chunks/app/api/v1/search/route-1172e1764d69e954.js +1 -0
  569. package/app/.next/static/chunks/app/api/v1/web/fetch/route-1172e1764d69e954.js +1 -0
  570. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-1172e1764d69e954.js +1 -0
  571. package/app/.next/static/chunks/app/api/v1beta/models/route-1172e1764d69e954.js +1 -0
  572. package/app/.next/static/chunks/app/api/version/route-1172e1764d69e954.js +1 -0
  573. package/app/.next/static/chunks/app/api/version/shutdown/route-1172e1764d69e954.js +1 -0
  574. package/app/.next/static/chunks/app/api/version/update/route-1172e1764d69e954.js +1 -0
  575. package/app/.next/static/chunks/app/callback/page-612232d68e5ef104.js +1 -0
  576. package/app/.next/static/chunks/app/layout-e2bc0634eb8e25c2.js +1 -0
  577. package/app/.next/static/chunks/app/login/page-618b0ac3d3cefbb3.js +1 -0
  578. package/app/.next/static/chunks/app/manifest.webmanifest/route-1172e1764d69e954.js +1 -0
  579. package/app/.next/static/chunks/app/page-1172e1764d69e954.js +1 -0
  580. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-1172e1764d69e954.js +1 -0
  581. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-1172e1764d69e954.js +1 -0
  582. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-1172e1764d69e954.js +1 -0
  583. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-1172e1764d69e954.js +1 -0
  584. package/app/.next/static/chunks/{webpack-d1740476c6ab968a.js → webpack-786de0e184ffd859.js} +1 -1
  585. package/app/.next/static/css/{081a0afca5a9bd20.css → 2e1b7d528c228ec3.css} +1 -1
  586. package/app/.next/static/css/d0e6cedf3e986854.css +1 -0
  587. package/app/.next/static/media/material-symbols-outlined.1060ac06.woff2 +0 -0
  588. package/app/package.json +2 -1
  589. package/app/public/i18n/literals/ar.json +6 -1
  590. package/app/public/i18n/literals/bn.json +6 -1
  591. package/app/public/i18n/literals/cs.json +6 -1
  592. package/app/public/i18n/literals/da.json +6 -1
  593. package/app/public/i18n/literals/de.json +6 -1
  594. package/app/public/i18n/literals/el.json +6 -1
  595. package/app/public/i18n/literals/es.json +6 -1
  596. package/app/public/i18n/literals/fi.json +6 -1
  597. package/app/public/i18n/literals/fr.json +6 -1
  598. package/app/public/i18n/literals/he.json +6 -1
  599. package/app/public/i18n/literals/hi.json +6 -1
  600. package/app/public/i18n/literals/hu.json +6 -1
  601. package/app/public/i18n/literals/id.json +6 -1
  602. package/app/public/i18n/literals/it.json +6 -1
  603. package/app/public/i18n/literals/ja.json +6 -1
  604. package/app/public/i18n/literals/ko.json +6 -1
  605. package/app/public/i18n/literals/nl.json +6 -1
  606. package/app/public/i18n/literals/no.json +6 -1
  607. package/app/public/i18n/literals/pl.json +6 -1
  608. package/app/public/i18n/literals/pt-BR.json +6 -1
  609. package/app/public/i18n/literals/pt-PT.json +6 -1
  610. package/app/public/i18n/literals/ro.json +6 -1
  611. package/app/public/i18n/literals/ru.json +6 -1
  612. package/app/public/i18n/literals/sv.json +6 -1
  613. package/app/public/i18n/literals/th.json +6 -1
  614. package/app/public/i18n/literals/tl.json +6 -1
  615. package/app/public/i18n/literals/tr.json +6 -1
  616. package/app/public/i18n/literals/uk.json +6 -1
  617. package/app/public/i18n/literals/ur.json +6 -1
  618. package/app/public/i18n/literals/vi.json +6 -1
  619. package/app/public/i18n/literals/zh-CN.json +128 -2
  620. package/app/public/i18n/literals/zh-TW.json +6 -1
  621. package/app/src/lib/db/adapters/betterSqliteAdapter.js +55 -0
  622. package/app/src/lib/db/adapters/bunSqliteAdapter.js +63 -0
  623. package/app/src/lib/db/adapters/nodeSqliteAdapter.js +84 -0
  624. package/app/src/lib/db/adapters/sqljsAdapter.js +115 -0
  625. package/app/src/lib/db/migrate.js +248 -0
  626. package/app/src/lib/updater/updater.js +25 -0
  627. package/app/src/mitm/antigravityBootstrap.js +53 -0
  628. package/app/src/mitm/cert/install.js +53 -3
  629. package/app/src/mitm/dbReader.js +22 -0
  630. package/app/src/mitm/dns/dnsConfig.js +37 -8
  631. package/app/src/mitm/manager.js +3 -0
  632. package/app/src/mitm/paths.js +1 -0
  633. package/app/src/mitm/server.js +7 -29
  634. package/cli.js +148 -18
  635. package/package.json +1 -1
  636. package/app/.next/server/chunks/2417.js +0 -1
  637. package/app/.next/server/chunks/2549.js +0 -1
  638. package/app/.next/server/chunks/3605.js +0 -1
  639. package/app/.next/server/chunks/4122.js +0 -1
  640. package/app/.next/server/chunks/5296.js +0 -1
  641. package/app/.next/server/chunks/6184.js +0 -1
  642. package/app/.next/server/chunks/6774.js +0 -1
  643. package/app/.next/server/chunks/7861.js +0 -1
  644. package/app/.next/server/chunks/9547.js +0 -28
  645. package/app/.next/static/7afbTcg6GzYLDAMOJ-jxW/_buildManifest.js +0 -1
  646. package/app/.next/static/chunks/1321-240311c91d7531ef.js +0 -1
  647. package/app/.next/static/chunks/2336-291f4397a7464d20.js +0 -28
  648. package/app/.next/static/chunks/5497-2ef9901a04eb9472.js +0 -7
  649. package/app/.next/static/chunks/5555-595382d9c4d118fe.js +0 -3
  650. package/app/.next/static/chunks/app/(dashboard)/dashboard/admin/users/page-adc5d5e8da3a0761.js +0 -1
  651. package/app/.next/static/chunks/app/(dashboard)/dashboard/basic-chat/page-a4b2b832a4892e6d.js +0 -1
  652. package/app/.next/static/chunks/app/(dashboard)/dashboard/cli-tools/page-bd677c182bc2aae9.js +0 -1
  653. package/app/.next/static/chunks/app/(dashboard)/dashboard/focus-ui/page-74a4a20467839a51.js +0 -1
  654. package/app/.next/static/chunks/app/(dashboard)/dashboard/media-providers/[kind]/page-7cf63e1a3a8adecd.js +0 -1
  655. package/app/.next/static/chunks/app/(dashboard)/dashboard/profile/page-ceb9bffbc34711bc.js +0 -1
  656. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/[id]/page-39ab11dad9bb6b89.js +0 -1
  657. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/page-a0419a964a084f76.js +0 -1
  658. package/app/.next/static/chunks/app/(dashboard)/dashboard/translator/page-e967880631a99483.js +0 -1
  659. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/page-c41fbdb17b88c549.js +0 -1
  660. package/app/.next/static/chunks/app/_global-error/page-e967880631a99483.js +0 -1
  661. package/app/.next/static/chunks/app/api/auth/login/route-e967880631a99483.js +0 -1
  662. package/app/.next/static/chunks/app/api/auth/logout/route-e967880631a99483.js +0 -1
  663. package/app/.next/static/chunks/app/api/auth/me/route-e967880631a99483.js +0 -1
  664. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-e967880631a99483.js +0 -1
  665. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/inject-auth/route-e967880631a99483.js +0 -1
  666. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/restart/route-e967880631a99483.js +0 -1
  667. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-e967880631a99483.js +0 -1
  668. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/test/route-e967880631a99483.js +0 -1
  669. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-e967880631a99483.js +0 -1
  670. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-e967880631a99483.js +0 -1
  671. package/app/.next/static/chunks/app/api/cli-tools/copilot-settings/route-e967880631a99483.js +0 -1
  672. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-registry/route-e967880631a99483.js +0 -1
  673. package/app/.next/static/chunks/app/api/cli-tools/cowork-settings/route-e967880631a99483.js +0 -1
  674. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-e967880631a99483.js +0 -1
  675. package/app/.next/static/chunks/app/api/cli-tools/hermes-settings/route-e967880631a99483.js +0 -1
  676. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-e967880631a99483.js +0 -1
  677. package/app/.next/static/chunks/app/api/cli-tools/opencode-settings/route-e967880631a99483.js +0 -1
  678. package/app/.next/static/chunks/app/api/cloud/auth/route-e967880631a99483.js +0 -1
  679. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-e967880631a99483.js +0 -1
  680. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-e967880631a99483.js +0 -1
  681. package/app/.next/static/chunks/app/api/cloud/models/alias/route-e967880631a99483.js +0 -1
  682. package/app/.next/static/chunks/app/api/combos/[id]/route-e967880631a99483.js +0 -1
  683. package/app/.next/static/chunks/app/api/combos/route-e967880631a99483.js +0 -1
  684. package/app/.next/static/chunks/app/api/health/route-e967880631a99483.js +0 -1
  685. package/app/.next/static/chunks/app/api/init/route-e967880631a99483.js +0 -1
  686. package/app/.next/static/chunks/app/api/keys/[id]/route-e967880631a99483.js +0 -1
  687. package/app/.next/static/chunks/app/api/keys/route-e967880631a99483.js +0 -1
  688. package/app/.next/static/chunks/app/api/locale/route-e967880631a99483.js +0 -1
  689. package/app/.next/static/chunks/app/api/media-providers/tts/deepgram/voices/route-e967880631a99483.js +0 -1
  690. package/app/.next/static/chunks/app/api/media-providers/tts/elevenlabs/voices/route-e967880631a99483.js +0 -1
  691. package/app/.next/static/chunks/app/api/media-providers/tts/inworld/voices/route-e967880631a99483.js +0 -1
  692. package/app/.next/static/chunks/app/api/media-providers/tts/voices/route-e967880631a99483.js +0 -1
  693. package/app/.next/static/chunks/app/api/models/alias/route-e967880631a99483.js +0 -1
  694. package/app/.next/static/chunks/app/api/models/availability/route-e967880631a99483.js +0 -1
  695. package/app/.next/static/chunks/app/api/models/custom/route-e967880631a99483.js +0 -1
  696. package/app/.next/static/chunks/app/api/models/disabled/route-e967880631a99483.js +0 -1
  697. package/app/.next/static/chunks/app/api/models/route-e967880631a99483.js +0 -1
  698. package/app/.next/static/chunks/app/api/models/test/route-e967880631a99483.js +0 -1
  699. package/app/.next/static/chunks/app/api/network-analysis/route-e967880631a99483.js +0 -1
  700. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-e967880631a99483.js +0 -1
  701. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-e967880631a99483.js +0 -1
  702. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-e967880631a99483.js +0 -1
  703. package/app/.next/static/chunks/app/api/oauth/gitlab/pat/route-e967880631a99483.js +0 -1
  704. package/app/.next/static/chunks/app/api/oauth/iflow/cookie/route-e967880631a99483.js +0 -1
  705. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-e967880631a99483.js +0 -1
  706. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-e967880631a99483.js +0 -1
  707. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-e967880631a99483.js +0 -1
  708. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-e967880631a99483.js +0 -1
  709. package/app/.next/static/chunks/app/api/pricing/route-e967880631a99483.js +0 -1
  710. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-e967880631a99483.js +0 -1
  711. package/app/.next/static/chunks/app/api/provider-nodes/route-e967880631a99483.js +0 -1
  712. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-e967880631a99483.js +0 -1
  713. package/app/.next/static/chunks/app/api/providers/[id]/models/route-e967880631a99483.js +0 -1
  714. package/app/.next/static/chunks/app/api/providers/[id]/route-e967880631a99483.js +0 -1
  715. package/app/.next/static/chunks/app/api/providers/[id]/test/route-e967880631a99483.js +0 -1
  716. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-e967880631a99483.js +0 -1
  717. package/app/.next/static/chunks/app/api/providers/client/route-e967880631a99483.js +0 -1
  718. package/app/.next/static/chunks/app/api/providers/kilo/free-models/route-e967880631a99483.js +0 -1
  719. package/app/.next/static/chunks/app/api/providers/route-e967880631a99483.js +0 -1
  720. package/app/.next/static/chunks/app/api/providers/suggested-models/route-e967880631a99483.js +0 -1
  721. package/app/.next/static/chunks/app/api/providers/test-batch/route-e967880631a99483.js +0 -1
  722. package/app/.next/static/chunks/app/api/providers/validate/route-e967880631a99483.js +0 -1
  723. package/app/.next/static/chunks/app/api/proxy-pools/[id]/route-e967880631a99483.js +0 -1
  724. package/app/.next/static/chunks/app/api/proxy-pools/[id]/test/route-e967880631a99483.js +0 -1
  725. package/app/.next/static/chunks/app/api/proxy-pools/route-e967880631a99483.js +0 -1
  726. package/app/.next/static/chunks/app/api/proxy-pools/vercel-deploy/route-e967880631a99483.js +0 -1
  727. package/app/.next/static/chunks/app/api/settings/database/route-e967880631a99483.js +0 -1
  728. package/app/.next/static/chunks/app/api/settings/proxy-test/route-e967880631a99483.js +0 -1
  729. package/app/.next/static/chunks/app/api/settings/require-login/route-e967880631a99483.js +0 -1
  730. package/app/.next/static/chunks/app/api/settings/route-e967880631a99483.js +0 -1
  731. package/app/.next/static/chunks/app/api/shutdown/route-e967880631a99483.js +0 -1
  732. package/app/.next/static/chunks/app/api/tags/route-e967880631a99483.js +0 -1
  733. package/app/.next/static/chunks/app/api/translator/console-logs/route-e967880631a99483.js +0 -1
  734. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-e967880631a99483.js +0 -1
  735. package/app/.next/static/chunks/app/api/translator/load/route-e967880631a99483.js +0 -1
  736. package/app/.next/static/chunks/app/api/translator/save/route-e967880631a99483.js +0 -1
  737. package/app/.next/static/chunks/app/api/translator/send/route-e967880631a99483.js +0 -1
  738. package/app/.next/static/chunks/app/api/translator/translate/route-e967880631a99483.js +0 -1
  739. package/app/.next/static/chunks/app/api/tunnel/disable/route-e967880631a99483.js +0 -1
  740. package/app/.next/static/chunks/app/api/tunnel/enable/route-e967880631a99483.js +0 -1
  741. package/app/.next/static/chunks/app/api/tunnel/status/route-e967880631a99483.js +0 -1
  742. package/app/.next/static/chunks/app/api/tunnel/tailscale-check/route-e967880631a99483.js +0 -1
  743. package/app/.next/static/chunks/app/api/tunnel/tailscale-disable/route-e967880631a99483.js +0 -1
  744. package/app/.next/static/chunks/app/api/tunnel/tailscale-enable/route-e967880631a99483.js +0 -1
  745. package/app/.next/static/chunks/app/api/tunnel/tailscale-install/route-e967880631a99483.js +0 -1
  746. package/app/.next/static/chunks/app/api/tunnel/tailscale-login/route-e967880631a99483.js +0 -1
  747. package/app/.next/static/chunks/app/api/tunnel/tailscale-start-daemon/route-e967880631a99483.js +0 -1
  748. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-e967880631a99483.js +0 -1
  749. package/app/.next/static/chunks/app/api/usage/api-keys/route-e967880631a99483.js +0 -1
  750. package/app/.next/static/chunks/app/api/usage/chart/route-e967880631a99483.js +0 -1
  751. package/app/.next/static/chunks/app/api/usage/history/route-e967880631a99483.js +0 -1
  752. package/app/.next/static/chunks/app/api/usage/logs/route-e967880631a99483.js +0 -1
  753. package/app/.next/static/chunks/app/api/usage/providers/route-e967880631a99483.js +0 -1
  754. package/app/.next/static/chunks/app/api/usage/request-details/route-e967880631a99483.js +0 -1
  755. package/app/.next/static/chunks/app/api/usage/request-logs/route-e967880631a99483.js +0 -1
  756. package/app/.next/static/chunks/app/api/usage/stats/route-e967880631a99483.js +0 -1
  757. package/app/.next/static/chunks/app/api/usage/stream/route-e967880631a99483.js +0 -1
  758. package/app/.next/static/chunks/app/api/users/[id]/route-e967880631a99483.js +0 -1
  759. package/app/.next/static/chunks/app/api/users/route-e967880631a99483.js +0 -1
  760. package/app/.next/static/chunks/app/api/v1/api/chat/route-e967880631a99483.js +0 -1
  761. package/app/.next/static/chunks/app/api/v1/audio/speech/route-e967880631a99483.js +0 -1
  762. package/app/.next/static/chunks/app/api/v1/audio/transcriptions/route-e967880631a99483.js +0 -1
  763. package/app/.next/static/chunks/app/api/v1/audio/voices/route-e967880631a99483.js +0 -1
  764. package/app/.next/static/chunks/app/api/v1/chat/completions/route-e967880631a99483.js +0 -1
  765. package/app/.next/static/chunks/app/api/v1/embeddings/route-e967880631a99483.js +0 -1
  766. package/app/.next/static/chunks/app/api/v1/images/generations/route-e967880631a99483.js +0 -1
  767. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-e967880631a99483.js +0 -1
  768. package/app/.next/static/chunks/app/api/v1/messages/route-e967880631a99483.js +0 -1
  769. package/app/.next/static/chunks/app/api/v1/models/[kind]/route-e967880631a99483.js +0 -1
  770. package/app/.next/static/chunks/app/api/v1/models/info/route-e967880631a99483.js +0 -1
  771. package/app/.next/static/chunks/app/api/v1/models/route-e967880631a99483.js +0 -1
  772. package/app/.next/static/chunks/app/api/v1/responses/compact/route-e967880631a99483.js +0 -1
  773. package/app/.next/static/chunks/app/api/v1/responses/route-e967880631a99483.js +0 -1
  774. package/app/.next/static/chunks/app/api/v1/route-e967880631a99483.js +0 -1
  775. package/app/.next/static/chunks/app/api/v1/search/route-e967880631a99483.js +0 -1
  776. package/app/.next/static/chunks/app/api/v1/web/fetch/route-e967880631a99483.js +0 -1
  777. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-e967880631a99483.js +0 -1
  778. package/app/.next/static/chunks/app/api/v1beta/models/route-e967880631a99483.js +0 -1
  779. package/app/.next/static/chunks/app/api/version/route-e967880631a99483.js +0 -1
  780. package/app/.next/static/chunks/app/api/version/update/route-e967880631a99483.js +0 -1
  781. package/app/.next/static/chunks/app/callback/page-ca2aafefd1c72edc.js +0 -1
  782. package/app/.next/static/chunks/app/layout-88b42fda4d7c38d2.js +0 -1
  783. package/app/.next/static/chunks/app/login/page-cfe122b0047956eb.js +0 -1
  784. package/app/.next/static/chunks/app/manifest.webmanifest/route-e967880631a99483.js +0 -1
  785. package/app/.next/static/chunks/app/page-e967880631a99483.js +0 -1
  786. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-e967880631a99483.js +0 -1
  787. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-e967880631a99483.js +0 -1
  788. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-e967880631a99483.js +0 -1
  789. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-e967880631a99483.js +0 -1
  790. package/app/.next/static/css/b4a6aa6c83661162.css +0 -1
  791. /package/app/.next/static/{7afbTcg6GzYLDAMOJ-jxW → bKAtYNzF3T9AwhxzQjlwr}/_ssgManifest.js +0 -0
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6434],{17169:(e,s,a)=>{"use strict";a.r(s),a.d(s,{default:()=>u});var t=a(95155),r=a(12115),n=a(35497),l=a(52679);let o=["codex","alicode"];function i(e){return Array.isArray(e)?Array.from(new Set(e.map(e=>"string"==typeof e?e.trim():"").filter(Boolean))):[]}function d(e,s=o){return e&&"object"==typeof e&&Object.prototype.hasOwnProperty.call(e,"allowedProviders")?i(e.allowedProviders):i(s)}function c(e){var s;return e&&"object"==typeof e&&Array.isArray(e.allowedProviderConnectionIds)?Array.isArray(s=e.allowedProviderConnectionIds)?Array.from(new Set(s.map(e=>"string"==typeof e?e.trim():"").filter(Boolean))):[]:null}function u(){let[e,s]=(0,r.useState)([]),[a,o]=(0,r.useState)([]),[i,u]=(0,r.useState)(!0),[v,w]=(0,r.useState)(!1),[g,b]=(0,r.useState)({username:"",password:"",displayName:"",role:"sub_user",permissions:[],allowedProviders:[],allowedProviderConnectionIds:[],showQuotaTracker:!0,codexFastMode:!1}),[j,y]=(0,r.useState)(!1),[N,C]=(0,r.useState)(""),[k,P]=(0,r.useState)(null),[T,S]=(0,r.useState)({displayName:"",role:"",permissions:[],allowedProviders:[],allowedProviderConnectionIds:[],showQuotaTracker:!0,codexFastMode:!1,password:""}),[M,A]=(0,r.useState)(null);async function I(){u(!0);try{let[e,a,t]=await Promise.all([fetch("/api/users"),fetch("/api/providers"),fetch("/api/provider-nodes")]),r=await e.json(),n=await a.json(),i=await t.json();s(r.users||[]),o(function(e,s){let a=new Map((s||[]).map(e=>[e.id,e])),t=new Map;for(let s of e||[]){let e=s?.provider;if(!e)continue;let r=l.Q2[e],n=a.get(e),o=n?({"openai-compatible":"OpenAI Compatible","anthropic-compatible":"Anthropic Compatible","custom-embedding":"Custom Embedding","custom-image":"Custom Image"})[n.type]||"Custom Provider":null;t.has(e)||t.set(e,{id:e,label:n?`${n.name||n.prefix||e} (${o})`:r?.name||s.name||e,defaultEnabled:!0,accounts:[]}),t.get(e).accounts.push({id:s.id,label:s.displayName||s.name||s.email||s.id,isActive:!1!==s.isActive})}return Array.from(t.values()).map(e=>({...e,accounts:e.accounts.sort((e,s)=>e.label.localeCompare(s.label,"en"))})).sort((e,s)=>e.label.localeCompare(s.label,"en"))}(n.connections||[],i.nodes||[]))}finally{u(!1)}}async function $(e){e.preventDefault(),C(""),y(!0);try{let e=await fetch("/api/users",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({...g,providerThinking:h(g.codexFastMode)})}),s=await e.json();if(!e.ok)return void C(s.error||"Failed");w(!1),b({username:"",password:"",displayName:"",role:"sub_user",permissions:[],allowedProviders:p(a),allowedProviderConnectionIds:m(a),showQuotaTracker:!0,codexFastMode:!1}),I()}catch{C("Network error")}finally{y(!1)}}async function F(e){e.preventDefault(),y(!0);try{let e={displayName:T.displayName,role:T.role,permissions:T.permissions,allowedProviders:T.allowedProviders,allowedProviderConnectionIds:T.allowedProviderConnectionIds,showQuotaTracker:T.showQuotaTracker,providerThinking:h(T.codexFastMode)};if(T.password&&(e.password=T.password),!(await fetch(`/api/users/${k.id}`,{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)})).ok)return;P(null),I()}finally{y(!1)}}async function Q(e){await fetch(`/api/users/${e}`,{method:"DELETE"}),A(null),I()}(0,r.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{"super_admin"!==e.role?window.location.href="/dashboard/usage":I()}).catch(()=>{window.location.href="/dashboard/usage"})},[]);let O=["view_usage","view_logs","view_keys","manage_own_keys"],_=(e,s)=>{s(s=>{var t,r;let n=s.allowedProviders.includes(e),l=(t=a,r=e,t.find(e=>e.id===r)?.accounts?.map(e=>e.id)||[]);return{...s,allowedProviders:n?s.allowedProviders.filter(s=>s!==e):[...s.allowedProviders,e],allowedProviderConnectionIds:n?s.allowedProviderConnectionIds.filter(e=>!l.includes(e)):Array.from(new Set([...s.allowedProviderConnectionIds,...l]))}})},E=(e,s,a)=>{a(a=>{let t=a.allowedProviderConnectionIds.includes(s)?a.allowedProviderConnectionIds.filter(e=>e!==s):[...a.allowedProviderConnectionIds,s],r=a.allowedProviders.includes(e)?a.allowedProviders:[...a.allowedProviders,e];return{...a,allowedProviders:r,allowedProviderConnectionIds:t}})};return(0,t.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,t.jsxs)("div",{className:"flex items-center justify-between",children:[(0,t.jsxs)("div",{children:[(0,t.jsx)("h1",{className:"text-2xl font-bold",children:"User Management"}),(0,t.jsx)("p",{className:"text-sm text-text-muted mt-1",children:"Manage sub-users and their permissions"})]}),(0,t.jsx)(n.$n,{onClick:()=>{b({username:"",password:"",displayName:"",role:"sub_user",permissions:[],allowedProviders:p(a),allowedProviderConnectionIds:m(a),showQuotaTracker:!0,codexFastMode:!1}),C(""),w(!0)},children:"+ Add Sub-user"})]}),i?(0,t.jsx)("p",{className:"text-text-muted",children:"Loading..."}):0===e.length?(0,t.jsx)(n.Zp,{children:(0,t.jsx)("p",{className:"text-text-muted text-center py-8",children:"No sub-users yet. Create one to get started."})}):(0,t.jsx)("div",{className:"space-y-3",children:e.map(e=>{var s,r;let l,o,i;return(0,t.jsxs)(n.Zp,{className:"flex items-center justify-between",children:[(0,t.jsxs)("div",{className:"flex items-center gap-4",children:[(0,t.jsx)("div",{className:"w-10 h-10 rounded-full bg-primary/10 flex items-center justify-center text-primary font-semibold text-lg",children:e.displayName?.charAt(0)?.toUpperCase()||e.username?.charAt(0)?.toUpperCase()}),(0,t.jsxs)("div",{children:[(0,t.jsx)("p",{className:"font-semibold",children:e.displayName}),(0,t.jsxs)("p",{className:"text-sm text-text-muted",children:["@",e.username," \xb7 ",e.role]})]})]}),(0,t.jsxs)("div",{className:"flex items-center gap-2",children:[(0,t.jsx)("span",{className:"text-xs px-2 py-1 rounded-full bg-surface-alt text-text-muted",children:e.permissions?.join(", ")||"no perms"}),(0,t.jsx)("span",{className:"text-xs px-2 py-1 rounded-full bg-primary/10 text-primary",children:function(e,s){let a=new Map(s.map(e=>[e.id,e.label])),t=d(e,p(s));if(0===t.length)return"No providers enabled";let r=t.map(e=>a.get(e)||e);return r.length<=2?r.join(", "):`${r.slice(0,2).join(", ")} +${r.length-2}`}(e,a)}),(0,t.jsx)("span",{className:"text-xs px-2 py-1 rounded-full bg-surface-alt text-text-muted",children:(l=new Set(d(s=e,p(r=a))),o=new Set(c(s)??x(s,r)),0===(i=r.filter(e=>l.has(e.id)).reduce((e,s)=>e+s.accounts.length,0))?"No accounts":`${o.size}/${i} accounts`)}),(0,t.jsx)("span",{className:`text-xs px-2 py-1 rounded-full ${!1!==e.showQuotaTracker?"bg-emerald-500/10 text-emerald-600":"bg-surface-alt text-text-muted"}`,children:!1!==e.showQuotaTracker?"Quota On":"Quota Off"}),(0,t.jsx)("span",{className:`text-xs px-2 py-1 rounded-full ${e.providerThinking?.codex?.fastMode===!0?"bg-orange-500/10 text-orange-600":"bg-surface-alt text-text-muted"}`,children:e.providerThinking?.codex?.fastMode===!0?"Fast On":"Fast Off"}),(0,t.jsx)(n.$n,{variant:"secondary",size:"sm",onClick:()=>{P(e),S({displayName:e.displayName,role:e.role,permissions:e.permissions||[],allowedProviders:d(e,p(a)),allowedProviderConnectionIds:c(e)??x(e,a),showQuotaTracker:!1!==e.showQuotaTracker,codexFastMode:e.providerThinking?.codex?.fastMode===!0,password:""})},children:"Edit"}),(0,t.jsx)(n.$n,{variant:"danger",size:"sm",onClick:()=>A(e),children:"Delete"})]})]},e.id)})}),v&&(0,t.jsx)(n.aF,{isOpen:v,title:"Create Sub-user",onClose:()=>w(!1),size:"full",children:(0,t.jsxs)("form",{onSubmit:$,className:"flex flex-col gap-4",children:[(0,t.jsx)(n.pd,{label:"Username",value:g.username,onChange:e=>b(s=>({...s,username:e.target.value})),required:!0}),(0,t.jsx)(n.pd,{label:"Display Name",value:g.displayName,onChange:e=>b(s=>({...s,displayName:e.target.value}))}),(0,t.jsx)(n.pd,{label:"Password",type:"password",value:g.password,onChange:e=>b(s=>({...s,password:e.target.value})),required:!0}),(0,t.jsxs)("div",{children:[(0,t.jsx)("p",{className:"text-sm font-medium mb-2",children:"Permissions"}),(0,t.jsx)("div",{className:"flex flex-wrap gap-2",children:O.map(e=>(0,t.jsxs)("label",{className:"flex items-center gap-1.5 text-sm cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:g.permissions.includes(e),onChange:s=>b(a=>({...a,permissions:s.target.checked?[...a.permissions,e]:a.permissions.filter(s=>s!==e)}))}),e]},e))})]}),(0,t.jsx)(f,{providerOptions:a,selectedProviders:g.allowedProviders,selectedConnectionIds:g.allowedProviderConnectionIds,onToggle:e=>_(e,b),onToggleConnection:(e,s)=>E(e,s,b)}),(0,t.jsxs)("label",{className:"flex items-center gap-2 text-sm cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:g.showQuotaTracker,onChange:e=>b(s=>({...s,showQuotaTracker:e.target.checked}))}),"Allow Quota Tracker for this sub-user"]}),(0,t.jsxs)("label",{className:"flex items-center gap-2 text-sm cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:g.codexFastMode,onChange:e=>b(s=>({...s,codexFastMode:e.target.checked}))}),"Enable Codex Fast Mode for this sub-user"]}),N&&(0,t.jsx)("p",{className:"text-red-500 text-sm",children:N}),(0,t.jsxs)("div",{className:"flex justify-end gap-2 mt-2",children:[(0,t.jsx)(n.$n,{variant:"secondary",type:"button",onClick:()=>w(!1),children:"Cancel"}),(0,t.jsx)(n.$n,{type:"submit",loading:j,children:"Create"})]})]})}),k&&(0,t.jsx)(n.aF,{isOpen:!!k,title:`Edit ${k.username}`,onClose:()=>P(null),size:"full",children:(0,t.jsxs)("form",{onSubmit:F,className:"flex flex-col gap-4",children:[(0,t.jsx)(n.pd,{label:"Display Name",value:T.displayName,onChange:e=>S(s=>({...s,displayName:e.target.value}))}),(0,t.jsxs)("div",{children:[(0,t.jsx)("p",{className:"text-sm font-medium mb-2",children:"Permissions"}),(0,t.jsx)("div",{className:"flex flex-wrap gap-2",children:O.map(e=>(0,t.jsxs)("label",{className:"flex items-center gap-1.5 text-sm cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:T.permissions.includes(e),onChange:s=>S(a=>({...a,permissions:s.target.checked?[...a.permissions,e]:a.permissions.filter(s=>s!==e)}))}),e]},e))})]}),(0,t.jsx)(f,{providerOptions:a,selectedProviders:T.allowedProviders,selectedConnectionIds:T.allowedProviderConnectionIds,onToggle:e=>_(e,S),onToggleConnection:(e,s)=>E(e,s,S)}),(0,t.jsxs)("label",{className:"flex items-center gap-2 text-sm cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:T.showQuotaTracker,onChange:e=>S(s=>({...s,showQuotaTracker:e.target.checked}))}),"Allow Quota Tracker for this sub-user"]}),(0,t.jsxs)("label",{className:"flex items-center gap-2 text-sm cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:T.codexFastMode,onChange:e=>S(s=>({...s,codexFastMode:e.target.checked}))}),"Enable Codex Fast Mode for this sub-user"]}),(0,t.jsx)(n.pd,{label:"New Password (leave blank to keep)",type:"password",value:T.password,onChange:e=>S(s=>({...s,password:e.target.value}))}),(0,t.jsxs)("div",{className:"flex justify-end gap-2 mt-2",children:[(0,t.jsx)(n.$n,{variant:"secondary",type:"button",onClick:()=>P(null),children:"Cancel"}),(0,t.jsx)(n.$n,{type:"submit",loading:j,children:"Save"})]})]})}),M&&(0,t.jsxs)(n.aF,{isOpen:!!M,title:"Delete User",onClose:()=>A(null),children:[(0,t.jsxs)("p",{className:"mb-4",children:["Delete user ",(0,t.jsx)("strong",{children:M.username}),"? This cannot be undone."]}),(0,t.jsxs)("div",{className:"flex justify-end gap-2",children:[(0,t.jsx)(n.$n,{variant:"secondary",onClick:()=>A(null),children:"Cancel"}),(0,t.jsx)(n.$n,{variant:"danger",onClick:()=>Q(M.id),children:"Delete"})]})]})]})}function p(e){let s=e.filter(e=>e.defaultEnabled).map(e=>e.id),a=e.map(e=>e.id),t=o.filter(e=>a.includes(e));return s.length>0?s:t.length>0?t:a}function m(e){return e.flatMap(e=>e.accounts.map(e=>e.id))}function x(e,s){let a=new Set(d(e,p(s)));return s.filter(e=>a.has(e.id)).flatMap(e=>e.accounts.map(e=>e.id))}function h(e){return{codex:{fastMode:!0===e}}}function f({providerOptions:e,selectedProviders:s,selectedConnectionIds:a,onToggle:r,onToggleConnection:n}){let l=new Set(s),o=new Set(a);return(0,t.jsxs)("div",{children:[(0,t.jsx)("p",{className:"text-sm font-medium mb-2",children:"Allowed Providers & Accounts"}),0===e.length?(0,t.jsx)("p",{className:"text-xs text-text-muted",children:"Connect providers first, then assign them to this sub-user."}):(0,t.jsx)("div",{className:"flex flex-col gap-3",children:e.map(e=>(0,t.jsxs)("div",{className:"rounded-lg border border-border bg-background p-3",children:[(0,t.jsxs)("label",{className:"flex items-center gap-2 text-sm font-medium cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",checked:l.has(e.id),onChange:()=>r(e.id)}),e.label]}),e.accounts.length>0&&(0,t.jsx)("div",{className:"mt-2 grid gap-1.5 pl-6 sm:grid-cols-2",children:e.accounts.map(s=>(0,t.jsxs)("label",{className:"flex min-w-0 items-center gap-1.5 text-xs text-text-muted cursor-pointer",children:[(0,t.jsx)("input",{type:"checkbox",disabled:!l.has(e.id),checked:l.has(e.id)&&o.has(s.id),onChange:()=>n(e.id,s.id)}),(0,t.jsx)("span",{className:"truncate",children:s.label}),!s.isActive&&(0,t.jsx)("span",{className:"shrink-0 text-[10px] text-amber-600",children:"inactive"})]},s.id))})]},e.id))}),(0,t.jsx)("p",{className:"text-xs text-text-muted mt-2",children:"Only selected providers and selected provider accounts will be visible and usable for this sub-user."})]})}},99139:(e,s,a)=>{Promise.resolve().then(a.bind(a,17169))}},e=>{e.O(0,[2574,3862,1051,1321,5497,8441,3794,7358],()=>e(e.s=99139)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[4465],{58158:(e,t,r)=>{Promise.resolve().then(r.bind(r,88512))},88512:(e,t,r)=>{"use strict";r.d(t,{default:()=>w});var a=r(95155),s=r(12115),i=r(35497),l=r(28777),n=r(52679);let o="basic-chat.sessions",d="basic-chat.activeSessionId",c="basic-chat.activeProviderId",m="basic-chat.draft";function u(){return globalThis.crypto?.randomUUID?globalThis.crypto.randomUUID():`chat_${Date.now()}_${Math.random().toString(16).slice(2)}`}function h(e,t){try{return JSON.parse(e)}catch{return t}}function p(e){if("string"==typeof e)return e;if(null==e)return"";if(Array.isArray(e))return e.map(p).filter(Boolean).join(" ");if("object"==typeof e){if("string"==typeof e.message)return e.message;if("string"==typeof e.error)return e.error;try{return JSON.stringify(e)}catch{}}return String(e)}function x(e=""){let t=p(e).replace(/\s+/g," ").trim();return t?t.length>52?`${t.slice(0,52).trimEnd()}…`:t:"New chat"}async function f(e){return await new Promise((t,r)=>{let a=new FileReader;a.onload=()=>t(String(a.result||"")),a.onerror=()=>r(a.error||Error("Failed to read file")),a.readAsDataURL(e)})}function g(e){return e?.name||function(e=""){return String(e).replace(/[-_]/g," ").replace(/\b\w/g,e=>e.toUpperCase()).trim()||"Unknown"}(e?.provider||e?.id||"provider")}function w(){let[e,t]=(0,s.useState)([]),[r,w]=(0,s.useState)(!0),[b,v]=(0,s.useState)(""),[y,N]=(0,s.useState)(()=>{try{let e=h(globalThis.localStorage.getItem(o),[]);return Array.isArray(e)?e.map(e=>({...e,messages:Array.isArray(e.messages)?e.messages:[]})):[]}catch{return[]}}),[j,S]=(0,s.useState)(()=>globalThis.localStorage.getItem(d)||""),[I,A]=(0,s.useState)(()=>globalThis.localStorage.getItem(c)||""),[k,D]=(0,s.useState)(""),[O,T]=(0,s.useState)(()=>globalThis.localStorage.getItem(m)||""),[$,_]=(0,s.useState)([]),[C,M]=(0,s.useState)(!1),[E,U]=(0,s.useState)(""),[R,z]=(0,s.useState)(""),[q,P]=(0,s.useState)(!1),[J,B]=(0,s.useState)(!1),[F,K]=(0,s.useState)(!1),L=(0,s.useRef)(null),W=(0,s.useRef)(null),H=(0,s.useRef)(!1),Y=(0,s.useRef)(null),G=(0,s.useRef)(null);(0,s.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{"sub_user"===e.role&&(window.location.href="/dashboard/usage")}).catch(()=>{});try{let e=h(globalThis.localStorage.getItem(o),[]);N(Array.isArray(e)?e.map(e=>({...e,messages:Array.isArray(e.messages)?e.messages:[]})):[]),S(globalThis.localStorage.getItem(d)||""),A(globalThis.localStorage.getItem(c)||""),T(globalThis.localStorage.getItem(m)||"")}catch{}finally{P(!0)}},[]),(0,s.useEffect)(()=>{let e=!1;return async function(){w(!0),v("");try{let r=await fetch("/api/providers",{cache:"no-store"}),a=await r.json().catch(()=>({})),s=Array.isArray(a.connections)?a.connections.filter(e=>e?.isActive!==!1):[];if(0===s.length){e||(t([]),v("No providers connected yet."));return}let i=new Map;for(let e of s){let t=e.provider||e.id,r=g(e),a=(0,n.mq)(t)?"openai-compatible":(0,n.gb)(t)?"anthropic-compatible":t;i.has(t)||i.set(t,{providerId:t,providerName:r,providerType:a,connections:[],models:[]});let s=i.get(t);s.providerName=s.providerName||r,s.providerType=s.providerType||a,s.connections.push(e);let o=(0,l.KC)(t).map(t=>t?.id?{id:`${e.provider}/${t.id}`,requestModel:`${e.provider}/${t.id}`,name:t.name||t.id,providerId:e.provider,providerName:g(e),source:"static"}:null).filter(Boolean);s.models.push(...o)}for(let e of(await Promise.all(s.map(async e=>{try{let t=await fetch(`/api/providers/${e.id}/models`,{cache:"no-store"}),r=await t.json().catch(()=>({}));if(!t.ok)return{connection:e,models:[]};let a=(Array.isArray(r?.models)?r.models:Array.isArray(r?.data)?r.data:Array.isArray(r?.results)?r.results:Array.isArray(r)?r:[]).map(t=>(function(e,t){let r="string"==typeof e?e:e?.id||e?.name||e?.model||"";if(!r)return null;let a="string"==typeof e?e:e?.name||e?.displayName||r,s=r;return((0,n.mq)(t.provider)||(0,n.gb)(t.provider))&&!r.includes("/")&&(s=`${t.provider}/${r}`),{id:s,requestModel:s,name:a,providerId:t.provider,providerName:g(t),source:"live"}})(t,e)).filter(Boolean);return{connection:e,models:a}}catch{return{connection:e,models:[]}}})))){let t=e.connection.provider||e.connection.id,r=i.get(t);r&&r.models.push(...e.models)}let o=Array.from(i.values()).map(e=>({...e,models:(function(e){let t=new Map;for(let r of e)r?.id&&(t.has(r.id)||t.set(r.id,r));return Array.from(t.values())})(e.models).sort((e,t)=>e.name.localeCompare(t.name))})).filter(e=>e.models.length>0).sort((e,t)=>e.providerName.localeCompare(t.providerName));e||(t(o),0===o.length&&v("Providers connected but no models available."))}catch(r){e||(v(p(r?.message)||"Failed to load providers/models."),t([]))}finally{e||w(!1)}}(),()=>{e=!0}},[]),(0,s.useEffect)(()=>{let e=e=>{Y.current&&!Y.current.contains(e.target)&&B(!1),G.current&&!G.current.contains(e.target)&&K(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[]);let Q=(0,s.useMemo)(()=>{let t=new Map;for(let r of e)for(let e of r.models)t.set(e.id,{...e,providerId:r.providerId,providerName:r.providerName});return t},[e]),V=(0,s.useMemo)(()=>e.find(e=>e.providerId===I)||e[0]||null,[e,I]),X=(0,s.useMemo)(()=>{if(k&&Q.has(k))return Q.get(k);if(j){let e=y.find(e=>e.id===j);if(e?.modelId&&Q.has(e.modelId))return Q.get(e.modelId)}return V?.models?.[0]||null},[k,Q,V,y,j]),Z=(0,s.useMemo)(()=>y.find(e=>e.id===j)||null,[y,j]),ee=Z?.messages||[],et=(0,s.useMemo)(()=>[...y].sort((e,t)=>new Date(t.updatedAt).getTime()-new Date(e.updatedAt).getTime()),[y]),er=!C&&!!X&&(O.trim().length>0||$.length>0);(0,s.useEffect)(()=>{if(q)try{globalThis.localStorage.setItem(o,JSON.stringify(y)),globalThis.localStorage.setItem(d,j),globalThis.localStorage.setItem(c,I),globalThis.localStorage.setItem(m,O)}catch{}},[q,y,j,I,O]),(0,s.useEffect)(()=>{if(!q||r||H.current||0===e.length)return;let t=e.find(e=>e.providerId===I)||e[0],a=k&&Q.has(k)?Q.get(k):t.models[0];if(y.length>0){let e=y.find(e=>e.id===j)||y[0],r=e?.modelId&&Q.has(e.modelId)?Q.get(e.modelId):a;H.current=!0,S(e.id),A(r?.providerId||t.providerId),D(r?.id||a.id);return}let s={id:u(),title:"New chat",providerId:t.providerId,providerName:t.providerName,modelId:a.id,modelName:a.name,createdAt:new Date().toISOString(),updatedAt:new Date().toISOString(),messages:[]};H.current=!0,N([s]),S(s.id),A(t.providerId),D(a.id)},[q,r,e,Q,y,j,I,k]);let ea=(e,t)=>{N(r=>r.map(r=>r.id===e?t({...r,messages:Array.isArray(r.messages)?r.messages.map(e=>({...e})):[]}):r))},es=e=>e?{id:u(),title:"New chat",providerId:e.providerId,providerName:e.providerName,modelId:e.id,modelName:e.name,createdAt:new Date().toISOString(),updatedAt:new Date().toISOString(),messages:[]}:null,ei=async e=>{let t=Array.from(e.target.files||[]);if(0===t.length)return;let r=t.filter(e=>e.type.startsWith("image/"));if(0===r.length){e.target.value="";return}let a=await Promise.all(r.map(async e=>({id:u(),name:e.name,type:e.type,size:e.size,dataUrl:await f(e)})));_(e=>[...e,...a]),e.target.value=""},el=async()=>{let e=X||V?.models?.[0]||null;if(!e)return;let t=O.trim();if(!t&&0===$.length)return;let r=j,a=y.find(e=>e.id===r);if(!a){if(!(a=es(e)))return;r=a.id,N(e=>[a,...e]),S(r)}let s={id:u(),role:"user",content:t,attachments:$.map(e=>({id:e.id,name:e.name,type:e.type,dataUrl:e.dataUrl})),createdAt:new Date().toISOString()},i=u(),l={id:i,role:"assistant",content:"",createdAt:new Date().toISOString(),status:"streaming"},n=[...a.messages||[],s,l];N(a=>a.map(a=>a.id===r?{...a,providerId:e.providerId,providerName:e.providerName,modelId:e.id,modelName:e.name,messages:n,updatedAt:new Date().toISOString(),title:"New chat"===a.title?x(t):a.title}:a)),T(""),_([]),M(!0),U(i),z(""),W.current?.abort(),W.current=new AbortController;let o=n.filter(e=>"assistant"!==e.role||e.id!==i).map(e=>({role:e.role,content:"user"===e.role?function(e){let t=p(e.content).trim(),r=Array.isArray(e.attachments)?e.attachments:[];if(0===r.length)return t;let a=[];for(let e of(t&&a.push({type:"text",text:t}),r))e?.dataUrl&&a.push({type:"image_url",image_url:{url:e.dataUrl}});return a.length>0?a:t}(e):e.content}));try{var d;let a,s=await fetch("/api/dashboard/chat/completions",{method:"POST",headers:{"Content-Type":"application/json",Accept:"text/event-stream"},body:JSON.stringify({model:e.requestModel||e.id,messages:o,stream:!0}),signal:W.current.signal});if(!s.ok){let e=await s.json().catch(()=>({}));throw Error(p(e.error||e.message||`Request failed (${s.status})`))}let l=s.body?.getReader();if(!l){let e=await s.json().catch(()=>({})),t=p(e?.choices?.[0]?.message?.content||e?.output_text||e?.error||e?.message||"");ea(r,e=>({...e,messages:e.messages.map(e=>e.id===i?{...e,content:t,status:"done"}:e),updatedAt:new Date().toISOString()}));return}let n=new TextDecoder,c="",m="";for(;;){let{value:e,done:t}=await l.read();if(t)break;let a=(c+=n.decode(e,{stream:!0})).split(/\r?\n/);for(let e of(c=a.pop()||"",a)){let t=e.trim();if(!t.startsWith("data:"))continue;let a=t.slice(5).trim();if(a&&"[DONE]"!==a)try{let e=JSON.parse(a),t=function(e){if(!e||"object"!=typeof e)return"";let t=e.choices?.[0];return[(t?.delta||{}).content,t?.message?.content,e.output_text,e.text].map(p).filter(Boolean)[0]||""}(e);if(!t)continue;m+=t,z(m),ea(r,e=>({...e,messages:e.messages.map(e=>e.id===i?{...e,content:m,status:"streaming"}:e),updatedAt:new Date().toISOString()}))}catch{}}}ea(r,e=>({...e,messages:e.messages.map(e=>e.id===i?{...e,content:m||e.content,status:"done"}:e),updatedAt:new Date().toISOString()})),d=r,a=x(t),ea(d,e=>({...e,title:"New chat"===e.title?a:e.title,updatedAt:new Date().toISOString()}))}catch(e){if("AbortError"!==e.name){let t=p(e?.message||e);ea(r,e=>({...e,messages:e.messages.map(e=>e.id===i?{...e,content:e.content||`Error: ${t}`,status:"error"}:e),updatedAt:new Date().toISOString()})),v(t||"Failed to send message.")}}finally{M(!1),U(""),z(""),W.current=null}},en=X?`${X.name}`:"Select model",eo=X?X.requestModel:"Choose from connected providers";return(0,a.jsx)("div",{className:"relative flex-1 flex flex-col h-full min-h-0 min-w-0 bg-[#212121] text-white overflow-hidden",children:(0,a.jsxs)("div",{className:"relative mx-auto flex flex-1 h-full min-h-0 w-full max-w-4xl flex-col",children:[(0,a.jsxs)("div",{className:"flex shrink-0 items-center justify-between gap-3 px-4 py-3 lg:px-6",children:[(0,a.jsxs)("div",{ref:Y,className:"relative",children:[(0,a.jsx)("button",{type:"button",onClick:()=>B(e=>!e),className:"flex items-center gap-3 rounded-2xl border border-white/10 bg-white/5 px-4 py-3 text-left transition hover:bg-white/8",children:(0,a.jsxs)("div",{className:"min-w-0",children:[(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[(0,a.jsx)("span",{className:"text-sm font-semibold text-white",children:en}),(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px] text-white/70",children:"expand_more"})]}),(0,a.jsx)("p",{className:"truncate text-xs text-white/55",children:eo})]})}),J?(0,a.jsxs)("div",{className:"absolute left-0 top-[calc(100%+10px)] z-30 w-[min(520px,calc(100vw-2rem))] overflow-hidden rounded-[20px] border border-white/10 bg-[#262626] shadow-2xl shadow-black/50",children:[(0,a.jsxs)("div",{className:"border-b border-white/10 px-4 py-3",children:[(0,a.jsx)("p",{className:"text-xs uppercase tracking-[0.22em] text-white/45",children:"Models"}),(0,a.jsx)("p",{className:"text-sm text-white/75",children:"Only from connected providers"})]}),(0,a.jsx)("div",{className:"max-h-[60vh] overflow-y-auto p-2 custom-scrollbar",children:e.map(e=>(0,a.jsxs)("div",{className:"mb-2 rounded-[16px] border border-white/10 bg-black/20 p-2",children:[(0,a.jsxs)("div",{className:"flex items-center justify-between px-2 py-2",children:[(0,a.jsx)("p",{className:"text-sm font-semibold text-white",children:e.providerName}),(0,a.jsx)(i.Ex,{size:"sm",variant:"default",children:e.models.length})]}),(0,a.jsx)("div",{className:"grid gap-2 sm:grid-cols-2",children:e.models.map(e=>{let t=e.id===k;return(0,a.jsx)("button",{type:"button",onClick:()=>(e=>{let t=Q.get(e);if(!t)return;let r=y.find(e=>e.id===j);if(r&&r.messages.length>0){let e=es(t);if(!e)return;N(t=>[e,...t]),S(e.id)}else if(r)N(e=>e.map(e=>e.id===r.id?{...e,providerId:t.providerId,providerName:t.providerName,modelId:t.id,modelName:t.name}:e)),S(r.id);else{let e=es(t);if(!e)return;N(t=>[e,...t]),S(e.id)}A(t.providerId),D(t.id),B(!1)})(e.id),className:`rounded-[14px] border px-3 py-3 text-left transition ${t?"border-blue-400/40 bg-blue-500/15":"border-white/10 bg-white/5 hover:bg-white/8"}`,children:(0,a.jsxs)("div",{className:"flex items-start justify-between gap-3",children:[(0,a.jsxs)("div",{className:"min-w-0",children:[(0,a.jsx)("p",{className:"truncate text-sm font-medium text-white",children:e.name}),(0,a.jsx)("p",{className:"truncate text-[11px] text-white/45",children:e.requestModel})]}),t?(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px] text-blue-300",children:"check_circle"}):null]})},e.id)})})]},e.providerId))})]}):null]}),(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[(0,a.jsx)("button",{type:"button",onClick:()=>K(e=>!e),className:"rounded-2xl border border-white/10 bg-white/5 px-4 py-3 text-sm text-white/80 transition hover:bg-white/8",children:"History"}),(0,a.jsx)(i.$n,{variant:"ghost",size:"sm",icon:"delete",onClick:()=>{if(!j)return;let e=y.filter(e=>e.id!==j),t=e[0]||null;N(e),t?(S(t.id),A(t.providerId),D(t.modelId)):(S(""),A(""),D(""))},disabled:!j||0===y.length,children:"Clear"})]})]}),F?(0,a.jsxs)("div",{ref:G,className:"absolute right-4 top-[72px] z-20 w-[min(360px,calc(100vw-2rem))] rounded-[20px] border border-white/10 bg-[#262626] p-2 shadow-2xl shadow-black/50 lg:right-6",children:[(0,a.jsx)("div",{className:"px-3 py-2",children:(0,a.jsx)("p",{className:"text-xs uppercase tracking-[0.22em] text-white/45",children:"Recent chats"})}),(0,a.jsx)("div",{className:"max-h-[48vh] space-y-2 overflow-y-auto p-1 custom-scrollbar",children:0===et.length?(0,a.jsx)("div",{className:"rounded-[16px] border border-dashed border-white/10 bg-white/5 p-4 text-sm text-white/55",children:"No conversations yet."}):et.map(e=>{let t=e.id===j,r=[...e.messages||[]].reverse().find(e=>"user"===e.role)||e.messages?.[0];return(0,a.jsx)("button",{type:"button",onClick:()=>{var t;let r;return t=e.id,void((r=y.find(e=>e.id===t))&&(S(t),A(r.providerId||I),D(r.modelId||k),K(!1)))},className:`w-full rounded-[16px] border px-3 py-3 text-left transition ${t?"border-blue-400/40 bg-blue-500/15":"border-white/10 bg-white/5 hover:bg-white/8"}`,children:(0,a.jsxs)("div",{className:"flex items-start justify-between gap-3",children:[(0,a.jsxs)("div",{className:"min-w-0 flex-1",children:[(0,a.jsx)("p",{className:"truncate text-sm font-medium text-white",children:e.title}),(0,a.jsx)("p",{className:"mt-1 truncate text-xs text-white/50",children:p(r?.content)||"Empty chat"})]}),(0,a.jsx)("span",{className:"text-[10px] text-white/40 shrink-0",children:function(e){if(!e)return"Now";let t=new Date(e).getTime();if(Number.isNaN(t))return"Now";let r=Math.max(1,Math.round((Date.now()-t)/6e4));if(r<60)return`${r}m`;let a=Math.round(r/60);return a<24?`${a}h`:`${Math.round(a/24)}d`}(e.updatedAt)})]})},e.id)})})]}):null,b?(0,a.jsx)("div",{className:"mt-4 rounded-[18px] border border-rose-500/20 bg-rose-500/10 px-4 py-3 text-rose-100",children:(0,a.jsxs)("div",{className:"flex items-start gap-3",children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"error"}),(0,a.jsx)("p",{className:"text-sm leading-6",children:b})]})}):null,(0,a.jsxs)("div",{className:"flex flex-1 flex-col min-h-0",children:[(0,a.jsxs)("div",{className:"flex-1 overflow-y-auto py-4 custom-scrollbar",children:[0===ee.length?(0,a.jsx)("div",{className:"flex min-h-[50vh] items-center justify-center px-4 text-center",children:(0,a.jsxs)("div",{className:"max-w-xl space-y-4",children:[(0,a.jsx)("div",{className:"mx-auto flex size-16 items-center justify-center rounded-[20px] border border-white/10 bg-white/5 text-white/80",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[30px]",children:"chat"})}),(0,a.jsxs)("div",{className:"space-y-2",children:[(0,a.jsx)("h2",{className:"text-2xl font-semibold text-white",children:"Start a conversation"}),(0,a.jsx)("p",{className:"text-sm leading-6 text-white/60",children:"Simple chat interface to interact with any AI model from connected providers. Select a model and start chatting!"})]})]})}):null,(0,a.jsx)("div",{className:"mx-auto flex w-full max-w-3xl flex-col gap-4 px-4",children:ee.map(e=>{let t="user"===e.role,r="assistant"===e.role,s=r&&e.id===E&&"streaming"===e.status,i=p(e.content)||(r?R:"");return(0,a.jsx)("div",{className:`flex w-full ${t?"justify-end":"justify-start"} mb-6`,children:(0,a.jsxs)("div",{className:`max-w-[min(88%,42rem)] ${t?"rounded-3xl bg-[#2f2f2f] px-5 py-3.5 text-white":"text-white/90"}`,children:[(0,a.jsx)("div",{className:"mb-1 flex items-center justify-between gap-3",children:(0,a.jsx)("span",{className:"text-xs font-semibold",children:t?"You":X?.name||"Assistant"})}),e.attachments?.length?(0,a.jsx)("div",{className:"mb-3 grid grid-cols-2 gap-2 sm:grid-cols-3 mt-2",children:e.attachments.map(e=>(0,a.jsx)("a",{href:e.dataUrl,target:"_blank",rel:"noreferrer",className:"overflow-hidden rounded-[18px] border border-white/10 bg-black/20",children:(0,a.jsx)("img",{src:e.dataUrl,alt:e.name,className:"h-28 w-full object-cover"})},e.id))}):null,(0,a.jsxs)("div",{className:"whitespace-pre-wrap break-words text-[15px] leading-7",children:[i,r&&s&&!R?(0,a.jsx)("span",{className:"inline-block animate-pulse",children:"▋"}):null]})]})},e.id)})})]}),(0,a.jsxs)("div",{className:"shrink-0 pt-2",children:[$.length>0?(0,a.jsx)("div",{className:"mx-auto mb-3 flex w-full max-w-3xl flex-wrap gap-2 px-4",children:$.map(e=>(0,a.jsxs)("div",{className:"flex items-center gap-2 rounded-full border border-white/10 bg-white/5 px-3 py-2",children:[(0,a.jsx)("span",{className:"text-xs text-white/80 max-w-[12rem] truncate",children:e.name}),(0,a.jsx)("button",{type:"button",onClick:()=>{var t;return t=e.id,void _(e=>e.filter(e=>e.id!==t))},className:"text-white/55 hover:text-white","aria-label":"Remove attachment",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"close"})})]},e.id))}):null,(0,a.jsx)("div",{className:"mx-auto w-full max-w-3xl px-4 pb-2",children:(0,a.jsxs)("div",{className:"rounded-[26px] bg-[#2f2f2f] px-3 pt-3 pb-2 shadow-[0_0_15px_rgba(0,0,0,0.10)] ring-1 ring-white/5",children:[(0,a.jsx)("textarea",{value:O,onChange:e=>T(e.target.value),onKeyDown:e=>{"Enter"===e.key&&!e.shiftKey&&(e.preventDefault(),er&&el())},placeholder:"Message AI",rows:1,className:"w-full resize-none bg-transparent px-2 text-[15px] leading-6 text-white outline-none placeholder:text-white/40 custom-scrollbar max-h-[25vh] overflow-y-auto"}),(0,a.jsxs)("div",{className:"mt-2 flex items-center justify-between gap-3",children:[(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[(0,a.jsx)("button",{type:"button",onClick:()=>L.current?.click(),disabled:!X||r,className:"p-2 text-white/50 hover:text-white transition rounded-full hover:bg-white/5",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"attach_file"})}),(0,a.jsx)("input",{ref:L,type:"file",accept:"image/*",multiple:!0,className:"hidden",onChange:ei}),(0,a.jsx)("span",{className:"text-xs font-medium text-white/30 truncate max-w-[120px]",children:X?X.name:"No model"})]}),(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[C?(0,a.jsx)("button",{type:"button",onClick:()=>{W.current?.abort()},className:"p-2 text-white bg-white/10 hover:bg-white/20 transition rounded-full h-8 w-8 flex items-center justify-center",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[16px]",children:"stop"})}):null,(0,a.jsx)("button",{onClick:el,disabled:!er,className:`h-8 w-8 rounded-full flex items-center justify-center transition ${er?"bg-white text-black hover:opacity-90":"bg-white/10 text-white/30 cursor-not-allowed"}`,children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[16px]",children:"arrow_upward"})})]})]})]})})]}),(0,a.jsx)("p",{className:"mx-auto mt-2 max-w-3xl px-4 pb-4 text-center text-[11px] text-white/30",children:"Model list is filtered from connected providers."})]})]})})}}},e=>{e.O(0,[2574,3862,1051,1321,5497,8441,3794,7358],()=>e(e.s=58158)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[2326],{25374:(e,t,a)=>{Promise.resolve().then(a.bind(a,75228))},75228:(e,t,a)=>{"use strict";a.d(t,{default:()=>x});var s=a(95155),l=a(12115),i=a(98500),r=a.n(i),n=a(35497),o=a(3534),c=a(28777),d=a(70151);let u="https://9router.com";function x({machineId:e}){let t,a,i,[h,p]=(0,l.useState)([]),[v,m]=(0,l.useState)(!0),[f,b]=(0,l.useState)(null),[g,j]=(0,l.useState)({}),[E,S]=(0,l.useState)(!1),[y,w]=(0,l.useState)(!1),[P,k]=(0,l.useState)(""),[N,A]=(0,l.useState)(!1),[C,M]=(0,l.useState)(""),[_,O]=(0,l.useState)([]),[U,I]=(0,l.useState)({}),[T,Q]=(0,l.useState)(null),[$,X]=(0,l.useState)(!1);(0,l.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{Q(e.role||null)}).catch(()=>{}).finally(()=>X(!0)),F(),q(),D(),Z()},[]);let Z=async()=>{try{let e=await fetch("/api/cli-tools/all-statuses");e.ok&&I(await e.json())}catch(e){console.log("Error fetching tool statuses:",e)}},q=async()=>{try{let[e,t]=await Promise.all([fetch("/api/settings"),fetch("/api/tunnel/status")]);if(e.ok){let t=await e.json();S(t.cloudEnabled||!1)}if(t.ok){let e=await t.json();w(!!(e.tunnel?.enabled||e.tunnel?.settingsEnabled)),k(e.tunnel?.publicUrl||""),A(!!(e.tailscale?.enabled||e.tailscale?.settingsEnabled)),M(e.tailscale?.tunnelUrl||"")}}catch(e){console.log("Error loading settings:",e)}},D=async()=>{try{let e=await fetch("/api/keys");if(e.ok){let t=await e.json();O(t.keys||[])}}catch(e){console.log("Error fetching API keys:",e)}},F=async()=>{try{let e=await fetch("/api/providers"),t=await e.json();e.ok&&p(t.connections||[])}catch(e){console.log("Error fetching connections:",e)}finally{m(!1)}};(0,l.useEffect)(()=>{F(),q(),D(),Z()},[]);let G=()=>h.filter(e=>!1!==e.isActive),K=(0,l.useCallback)((e,t,a)=>{j(s=>s[e]?.[t]===a?s:{...s,[e]:{...s[e],[t]:a}})},[]);if(v)return(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)(n.Qv,{}),(0,s.jsx)(n.Qv,{}),(0,s.jsx)(n.Qv,{})]});let L=(t=G(),a=[],i=new Set,t.forEach(e=>{let t=c.Xg[e.provider]||e.provider;(0,c.KC)(e.provider).forEach(s=>{let l=`${t}/${s.id}`;i.has(l)||(i.add(l),a.push({value:l,label:`${t}/${s.id}`,provider:e.provider,alias:t,connectionName:e.name,modelId:s.id}))})}),a).length>0,R=$&&"sub_user"===T,Y=Object.entries(o.dM),z=R?[]:Object.entries(o.wn);return(0,s.jsxs)("div",{className:"mx-auto flex w-full max-w-5xl flex-col gap-6 px-1 sm:px-0",children:[(0,s.jsxs)("div",{className:"flex flex-col gap-3",children:[R&&(0,s.jsx)("div",{className:"flex items-center",children:(0,s.jsxs)(r(),{href:"/dashboard",className:"inline-flex items-center gap-2 rounded-lg border border-border bg-surface px-3 py-2 text-sm text-text-main transition-colors hover:border-primary hover:text-primary",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"dashboard"}),(0,s.jsx)("span",{children:"Dashboard"})]})}),(0,s.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,s.jsx)("h1",{className:"text-xl font-semibold text-text-main sm:text-2xl",children:"CLI Tools"}),(0,s.jsx)("p",{className:"text-sm text-text-muted",children:"Configure local coding tools to use your openrouterX providers."})]})]}),(0,s.jsx)("div",{className:"grid gap-3 sm:gap-4",children:Y.map(([e,t])=>((e,t)=>{let a={tool:t,isExpanded:f===e,onToggle:()=>b(f===e?null:e),baseUrl:y&&P?P:E&&u?u:window.location.origin,apiKeys:_,manualOnly:R};switch(e){case"claude":return(0,s.jsx)(d.Tk,{...a,activeProviders:G(),modelMappings:g[e]||{},onModelMappingChange:(t,a)=>K(e,t,a),hasActiveProviders:L,cloudEnabled:E,initialStatus:U.claude},e);case"codex":return(0,s.jsx)(d.Ah,{...a,activeProviders:G(),cloudEnabled:E,initialStatus:U.codex},e);case"opencode":return(0,s.jsx)(d.qO,{...a,activeProviders:G(),cloudEnabled:E,initialStatus:U.opencode},e);case"cowork":return(0,s.jsx)(d.Q6,{...a,activeProviders:G(),hasActiveProviders:L,cloudEnabled:E,cloudUrl:u,tunnelEnabled:y,tunnelPublicUrl:P,tailscaleEnabled:N,tailscaleUrl:C,initialStatus:U.cowork},e);case"droid":return(0,s.jsx)(d.ZM,{...a,activeProviders:G(),hasActiveProviders:L,cloudEnabled:E,initialStatus:U.droid},e);case"openclaw":return(0,s.jsx)(d.yZ,{...a,activeProviders:G(),hasActiveProviders:L,cloudEnabled:E,initialStatus:U.openclaw},e);case"hermes":return(0,s.jsx)(d.RF,{...a,activeProviders:G(),hasActiveProviders:L,cloudEnabled:E,initialStatus:U.hermes},e);case"copilot":return(0,s.jsx)(d.h1,{...a,activeProviders:G(),cloudEnabled:E,initialStatus:U.copilot},e);case"cline":return(0,s.jsx)(d.aG,{...a,activeProviders:G(),cloudEnabled:E,initialStatus:U.cline},e);case"kilo":return(0,s.jsx)(d.c9,{...a,activeProviders:G(),cloudEnabled:E,initialStatus:U.kilo},e);default:return(0,s.jsx)(d.a7,{toolId:e,...a,activeProviders:G(),cloudEnabled:E,tunnelEnabled:y},e)}})(e,t))}),z.length>0&&(0,s.jsxs)("div",{className:"grid gap-3 sm:gap-4",children:[(0,s.jsxs)("div",{className:"flex items-center gap-2 px-1",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[18px] text-primary",children:"security"}),(0,s.jsx)("h2",{className:"text-sm font-semibold text-text-main",children:"MITM Tools"})]}),z.map(([e,t])=>(0,s.jsx)(d.gY,{tool:t},e))]})]})}}},e=>{e.O(0,[2574,3862,1051,5772,1321,5497,5964,8441,3794,7358],()=>e(e.s=25374)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[1119],{8642:(e,t,s)=>{Promise.resolve().then(s.bind(s,89455))},14712:(e,t,s)=>{"use strict";s.d(t,{A:()=>o});var a=s(95155),l=s(12115),n=s(35497),r=s(90620);let i={LOG:"text-green-400",INFO:"text-blue-400",WARN:"text-yellow-400",ERROR:"text-red-400",DEBUG:"text-purple-400"};function o({active:e=!0,heightClassName:t="h-[calc(100vh-220px)]",compact:s=!1,showToolbar:c=!0}){let[d,u]=(0,l.useState)([]),[x,m]=(0,l.useState)(!1),p=(0,l.useRef)(null),h=async()=>{try{await fetch("/api/translator/console-logs",{method:"DELETE"})}catch(e){console.error("Failed to clear console logs:",e)}};(0,l.useEffect)(()=>{if(!e)return void m(!1);let t=new EventSource("/api/translator/console-logs/stream");return t.onopen=()=>m(!0),t.onmessage=e=>{let t=JSON.parse(e.data);"init"===t.type?u(t.logs.slice(-r.UY.maxLines)):"line"===t.type?u(e=>{let s=[...e,t.line];return s.length>r.UY.maxLines?s.slice(-r.UY.maxLines):s}):"clear"===t.type&&u([])},t.onerror=()=>m(!1),()=>t.close()},[e]),(0,l.useEffect)(()=>{p.current&&(p.current.scrollTop=p.current.scrollHeight)},[d]);let f=(0,a.jsxs)(a.Fragment,{children:[c&&(0,a.jsxs)("div",{className:"flex items-center justify-between gap-3 px-4 pt-3 pb-2",children:[(0,a.jsxs)("div",{className:"flex items-center gap-2 text-[11px] text-text-muted",children:[(0,a.jsx)("span",{className:`size-2 rounded-full ${x?"bg-green-500":"bg-text-muted/40"}`}),(0,a.jsx)("span",{children:x?"Live":"Disconnected"})]}),(0,a.jsx)(n.$n,{size:"sm",variant:"outline",icon:"delete",onClick:h,children:"Clear"})]}),(0,a.jsx)("div",{ref:p,className:`overflow-y-auto bg-black p-4 font-mono text-xs ${t} ${s?"rounded-lg":"rounded-b-lg"}`,children:0===d.length?(0,a.jsx)("span",{className:"text-text-muted",children:"No console logs yet."}):(0,a.jsx)("div",{className:"space-y-0.5","data-i18n-skip":"true",children:d.map((e,t)=>{let s,l;return(0,a.jsx)("div",{children:(l=i[(s=e.match(/\[(\w+)\]/g))?s[1]?.replace(/\[|\]/g,""):null]||"text-green-400",(0,a.jsx)("span",{className:l,children:e}))},`${t}-${e.slice(0,32)}`)})})})]});return s?f:(0,a.jsx)(n.Zp,{children:f})}},89455:(e,t,s)=>{"use strict";s.d(t,{default:()=>f});var a=s(95155),l=s(12115),n=s(3534),r=s(28777),i=s(52679),o=s(70151),c=s(14712),d=s(75095);let u=["antigravity"],x=Object.entries(n.wn),m=x.map(([e])=>e),p="focus-ui-mitm-tool-visibility",h=Object.fromEntries(m.map(e=>[e,u.includes(e)]));function f(){let[e,t]=(0,l.useState)([]),[s,n]=(0,l.useState)([]),[u,f]=(0,l.useState)({}),[v,j]=(0,l.useState)(!1),[y,N]=(0,l.useState)(null),[w,S]=(0,l.useState)(!0),[k,C]=(0,l.useState)(!0),[E,T]=(0,l.useState)(!0),[O,P]=(0,l.useState)(!0),[M,$]=(0,l.useState)(h),[A,_]=(0,l.useState)(!1),[I,L]=(0,l.useState)({running:!1,certExists:!1,dnsStatus:{},hasCachedPassword:!1});(0,l.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{"sub_user"===e.role&&(window.location.href="/dashboard/usage")}).catch(()=>{}),R(),D(),F(),U()},[]),(0,l.useEffect)(()=>{try{let e=JSON.parse(localStorage.getItem(p)||"null");e&&$(Object.fromEntries(m.map(t=>[t,e?.[t]===!0])))}catch{}_(!0)},[]),(0,l.useEffect)(()=>{if(A)try{localStorage.setItem(p,JSON.stringify(M))}catch{}},[A,M]);let R=async()=>{try{let e=await fetch("/api/providers");if(e.ok){let s=await e.json();t(s.connections||[])}}catch{}},D=async()=>{try{let e=await fetch("/api/keys");if(e.ok){let t=await e.json();n(t.keys||[])}}catch{}},F=async()=>{try{let e=await fetch("/api/models/alias");if(e.ok){let t=await e.json();f(t.aliases||{})}}catch{}},U=async()=>{try{let e=await fetch("/api/settings");if(e.ok){let t=await e.json();j(t.cloudEnabled||!1)}}catch{}},J=()=>e.filter(e=>!1!==e.isActive),K=x.filter(([e])=>M[e]);return(0,a.jsxs)("div",{className:"flex h-full min-h-0 w-full flex-col gap-6 overflow-hidden",children:[(0,a.jsx)(b,{title:"MITM Server",subtitle:"MITM server status and controls",expanded:w,onToggle:()=>S(e=>!e),bodyClassName:"p-0",className:"shrink-0",children:(0,a.jsx)(o.tA,{apiKeys:s,cloudEnabled:v,onStatusChange:L})}),(0,a.jsx)(b,{title:"Providers",subtitle:"MITM tool interception status",expanded:k,onToggle:()=>C(e=>!e),className:"shrink-0",headerControls:(0,a.jsx)(g,{tools:x,visibleTools:M,onToggleTool:e=>$(t=>({...t,[e]:!t[e]}))}),children:(0,a.jsx)("div",{className:"grid gap-3 sm:gap-4",children:K.map(([e,t])=>(0,a.jsx)(o.kn,{tool:t,isExpanded:y===e,onToggle:()=>N(y===e?null:e),serverRunning:I.running,dnsActive:I.dnsStatus?.[e]||!1,hasCachedPassword:I.hasCachedPassword||!1,needsSudoPassword:!1!==I.needsSudoPassword,isWin:!0===I.isWin,apiKeys:s,activeProviders:J(),hasActiveProviders:J().some(e=>(0,r.KC)(e.provider).length>0||(0,i.mq)(e.provider)||(0,i.gb)(e.provider)),modelAliases:u,cloudEnabled:v,onDnsChange:e=>L(t=>({...t,dnsStatus:e.dnsStatus??t.dnsStatus}))},e))})}),(0,a.jsx)(b,{title:"Quota Management",subtitle:"Provider account quota overview",expanded:E,onToggle:()=>T(e=>!e),bodyClassName:"p-4",className:"shrink-0",children:(0,a.jsx)(d.A,{embedded:!0,title:"Quota Management",gridClassName:"grid grid-cols-1 gap-3 sm:grid-cols-2 xl:grid-cols-4",activeFirst:!0,maxRows:1,maxColumns:4})}),(0,a.jsx)(b,{title:"Console Logs",subtitle:"MITM / OpenrouterX realtime output",expanded:O,onToggle:()=>P(e=>!e),bodyClassName:"flex min-h-0 flex-1 flex-col p-3",className:O?"flex min-h-0 flex-1 flex-col":"shrink-0",children:(0,a.jsx)(c.A,{active:O,compact:!0,showToolbar:!0,heightClassName:"min-h-0 flex-1"})})]})}function g({tools:e,visibleTools:t,onToggleTool:s}){return(0,a.jsx)("div",{className:"flex flex-wrap items-center justify-end gap-2",onClick:e=>e.stopPropagation(),children:e.map(([e,l])=>(0,a.jsxs)("label",{className:`inline-flex min-h-8 cursor-pointer select-none items-center gap-2 rounded-lg border px-2.5 py-1 text-xs font-medium transition-colors ${t[e]?"border-primary/40 bg-primary/10 text-primary":"border-border bg-surface text-text-muted hover:border-primary/30 hover:text-text-main"}`,children:[(0,a.jsx)("input",{type:"checkbox",checked:!0===t[e],onChange:()=>s(e),className:"h-3.5 w-3.5 accent-primary"}),(0,a.jsx)("span",{children:l.name})]},e))})}function b({title:e,subtitle:t,expanded:s,onToggle:l,children:n,className:r="",bodyClassName:i="p-0",headerControls:o=null}){return(0,a.jsxs)("div",{className:`overflow-hidden rounded-xl border border-border bg-surface shadow-sm ${r}`,children:[(0,a.jsxs)("div",{className:"flex w-full flex-col gap-3 px-4 py-3 transition-colors hover:bg-surface-2/60 lg:flex-row lg:items-center",children:[(0,a.jsxs)("button",{type:"button",onClick:l,className:"flex min-w-0 flex-1 items-center gap-3 text-left","aria-expanded":s,children:[(0,a.jsx)("span",{className:`material-symbols-outlined text-[18px] text-text-muted transition-transform ${s?"rotate-90":""}`,children:"chevron_right"}),(0,a.jsxs)("span",{className:"flex min-w-0 flex-col",children:[(0,a.jsx)("span",{className:"truncate text-sm font-semibold text-text-main",children:e}),t&&(0,a.jsx)("span",{className:"truncate text-xs text-text-muted",children:t})]})]}),o&&(0,a.jsx)("div",{className:"min-w-0 flex-1 lg:px-3",children:o}),(0,a.jsx)("button",{type:"button",onClick:l,className:"self-start text-[10px] font-medium uppercase tracking-wide text-text-muted transition-colors hover:text-text-main lg:self-center","aria-expanded":s,children:s?"Collapse":"Expand"})]}),s&&(0,a.jsx)("div",{className:`border-t border-border ${i}`,children:n})]})}}},e=>{e.O(0,[2574,3862,1051,5772,1321,5497,5964,5095,8441,3794,7358],()=>e(e.s=8642)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6620],{16144:(e,s,t)=>{"use strict";t.r(s),t.d(s,{default:()=>g});var i=t(95155),a=t(73321),r=t(98500),n=t.n(r),o=t(12115),l=t(35497),c=t(57250),d=t(52679);let m=new Set([]),h={image:"image-combo",tts:"tts-combo"};function x(e){let s=Object.entries(e).some(([e,s])=>e.startsWith("modelLock_")&&s&&new Date(s).getTime()>Date.now());return"unavailable"!==e.testStatus||s?e.testStatus:"active"}function p({provider:e,kind:s,connections:t,isCustom:a,onToggle:r}){let o=d.Q2[e.id],m=!!o?.noAuth,h=t.filter(s=>s.provider===e.id),u=h.filter(e=>{let s=x(e);return"active"===s||"success"===s}).length,g=h.filter(e=>{let s=x(e);return"error"===s||"expired"===s||"unavailable"===s}).length,f=h.length,j=f>0&&h.every(e=>!1===e.isActive);return(0,i.jsx)(n(),{href:`/dashboard/media-providers/${s}/${e.id}`,className:"group",children:(0,i.jsx)(l.Zp,{padding:"xs",className:`h-full hover:bg-black/[0.01] dark:hover:bg-white/[0.01] transition-colors cursor-pointer ${j?"opacity-50":""}`,children:(0,i.jsxs)("div",{className:"flex min-w-0 items-center justify-between gap-3",children:[(0,i.jsxs)("div",{className:"flex min-w-0 items-center gap-3",children:[(0,i.jsx)("div",{className:"size-8 rounded-lg flex items-center justify-center shrink-0",style:{backgroundColor:`${e.color?.length>7?e.color:(e.color??"#888")+"15"}`},children:(0,i.jsx)(c.A,{src:`/providers/${e.id}.png`,alt:e.name,size:30,className:"object-contain rounded-lg max-w-[30px] max-h-[30px]",fallbackText:e.textIcon||e.id.slice(0,2).toUpperCase(),fallbackColor:e.color})}),(0,i.jsxs)("div",{className:"min-w-0",children:[(0,i.jsx)("h3",{className:"font-semibold text-sm",children:e.name}),(0,i.jsxs)("div",{className:"flex items-center gap-2 mt-0.5 flex-wrap",children:[a&&(0,i.jsx)(l.Ex,{variant:"default",size:"sm",children:"Custom"}),m?(0,i.jsx)(l.Ex,{variant:"success",size:"sm",children:"Ready"}):j?(0,i.jsx)(l.Ex,{variant:"default",size:"sm",children:"Disabled"}):0===f?(0,i.jsx)("span",{className:"text-xs text-text-muted",children:"No connections"}):(0,i.jsxs)(i.Fragment,{children:[u>0&&(0,i.jsxs)(l.Ex,{variant:"success",size:"sm",dot:!0,children:[u," Connected"]}),g>0&&(0,i.jsxs)(l.Ex,{variant:"error",size:"sm",dot:!0,children:[g," Error"]}),0===u&&0===g&&(0,i.jsxs)(l.Ex,{variant:"default",size:"sm",children:[f," Added"]})]})]})]})]}),f>0&&(0,i.jsx)("div",{className:"shrink-0 opacity-100 transition-opacity sm:opacity-0 sm:group-hover:opacity-100",onClick:s=>{s.preventDefault(),s.stopPropagation(),r&&r(e.id,j)},children:(0,i.jsx)(l.lM,{size:"sm",checked:!j,onChange:()=>{},title:j?"Enable provider":"Disable provider"})})]})})})}function u({combos:e}){return 0===e.length?null:(0,i.jsx)("div",{className:"flex flex-col gap-2",children:e.map(e=>(0,i.jsx)(n(),{href:`/dashboard/media-providers/combo/${e.id}`,children:(0,i.jsx)(l.Zp,{padding:"xs",className:"hover:bg-black/[0.02] dark:hover:bg-white/[0.02] transition-colors cursor-pointer",children:(0,i.jsxs)("div",{className:"flex min-w-0 items-center gap-3",children:[(0,i.jsx)("span",{className:"material-symbols-outlined text-primary text-[18px]",children:"layers"}),(0,i.jsx)("code",{className:"text-sm font-mono font-medium flex-1 truncate",children:e.name}),(0,i.jsxs)("div",{className:"flex flex-wrap items-center gap-1 sm:shrink-0",children:[e.models.slice(0,6).map((e,s)=>{let t="string"==typeof e?e.split("/")[0]:"",a=d.Q2[t];return(0,i.jsx)("div",{title:a?.name||e,className:"size-5 rounded flex items-center justify-center",style:{backgroundColor:`${a?.color??"#888"}15`},children:(0,i.jsx)(c.A,{src:`/providers/${t}.png`,alt:a?.name||t,size:18,className:"object-contain rounded max-w-[18px] max-h-[18px]",fallbackText:a?.textIcon||t.slice(0,2).toUpperCase(),fallbackColor:a?.color})},`${e}-${s}`)}),e.models.length>6&&(0,i.jsxs)("span",{className:"text-[10px] text-text-muted ml-1",children:["+",e.models.length-6]})]}),(0,i.jsx)("span",{className:"text-[11px] text-text-muted shrink-0",children:e.models.length}),(0,i.jsx)("span",{className:"material-symbols-outlined text-text-muted text-[16px]",children:"chevron_right"})]})})},e.id))})}function g(){let{kind:e}=(0,a.useParams)(),s=(0,a.useRouter)(),[t,r]=(0,o.useState)([]),[n,c]=(0,o.useState)([]),[x,g]=(0,o.useState)([]),[f,j]=(0,o.useState)(!1),[b,v]=(0,o.useState)(!1),[N,C]=(0,o.useState)([]),[y,k]=(0,o.useState)(!1);(0,o.useEffect)(()=>{("webSearch"===e||"webFetch"===e)&&s.replace("/dashboard/media-providers/web")},[e,s]);let w=d.rj.find(s=>s.id===e),$="embedding"===e,E=m.has(e);if((0,o.useEffect)(()=>{w&&(fetch("/api/auth/me",{cache:"no-store"}).then(e=>e.json()).then(e=>{k("sub_user"===e.role),C("sub_user"===e.role&&e.allowedProviders||[])}).catch(()=>{}),fetch("/api/providers",{cache:"no-store"}).then(e=>e.json()).then(e=>r(e.connections||[])).catch(()=>{}),($||"image"===e)&&fetch("/api/provider-nodes",{cache:"no-store"}).then(e=>e.json()).then(e=>c((e.nodes||[]).filter(e=>e.type===($?"custom-embedding":"custom-image")))).catch(()=>{}),E&&fetch("/api/combos",{cache:"no-store"}).then(e=>e.json()).then(e=>g(e.combos||[])).catch(()=>{}))},[$,E,w]),!w)return(0,a.notFound)();let S=(0,d.o5)(e).filter(e=>!y||N.includes(e.id)),z=x.filter(s=>s.kind===e),_=n.filter(e=>!y||N.includes(e.id)).map(s=>({id:s.id,name:s.name||("image"===e?"Custom Image":"Custom Embedding"),color:"image"===e?"#EC4899":"#6366F1",textIcon:"image"===e?"CI":"CE"})),A=[...S,..._],T=async(e,s)=>{let i=t.filter(s=>s.provider===e);r(t=>t.map(t=>t.provider===e?{...t,isActive:s}:t)),await Promise.allSettled(i.map(e=>fetch(`/api/providers/${e.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({isActive:s})})))},O=async()=>{let t=h[e]||`${e}-combo`,i=t,a=1,r=new Set(x.map(e=>e.name));for(;r.has(i);)i=`${t}-${a++}`;let n=await fetch("/api/combos",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:i,models:[],kind:e})});if(n.ok){let e=await n.json();s.push(`/dashboard/media-providers/combo/${e.id}`)}else alert((await n.json()).error||"Failed to create combo")};return(0,i.jsxs)("div",{className:"flex flex-col gap-6",children:[!y&&($||"image"===e||E)&&(0,i.jsxs)("div",{className:"flex items-center justify-end gap-2",children:[E&&(0,i.jsx)(l.$n,{size:"sm",icon:"add",onClick:O,children:"Create Combo"}),$&&(0,i.jsx)(l.$n,{size:"sm",icon:"add",onClick:()=>j(!0),children:"Add Custom Embedding"}),"image"===e&&(0,i.jsx)(l.$n,{size:"sm",icon:"add",onClick:()=>v(!0),children:"Add Custom Image"})]}),E&&z.length>0&&(0,i.jsx)(u,{combos:z}),0===A.length?(0,i.jsxs)("div",{className:"text-center py-12 border border-dashed border-border rounded-xl text-text-muted text-sm",children:["No providers support ",(0,i.jsx)("strong",{children:w.label})," yet."]}):(0,i.jsxs)("div",{className:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 xl:grid-cols-4 gap-4",children:[S.map(s=>(0,i.jsx)(p,{provider:s,kind:e,connections:t,onToggle:T},s.id)),_.map(s=>(0,i.jsx)(p,{provider:s,kind:e,connections:t,isCustom:!0,onToggle:T},s.id))]}),$&&(0,i.jsx)(l.x0,{isOpen:f,onClose:()=>j(!1),onCreated:e=>{c(s=>[...s,e]),j(!1)}}),"image"===e&&(0,i.jsx)(l.VW,{isOpen:b,onClose:()=>v(!1),onCreated:e=>{c(s=>[...s,e]),v(!1)}})]})}},55973:(e,s,t)=>{Promise.resolve().then(t.bind(t,16144))}},e=>{e.O(0,[2574,3862,1051,1321,5497,8441,3794,7358],()=>e(e.s=55973)),_N_E=e.O()}]);
@@ -1 +1 @@
1
- (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6607],{23879:(e,s,a)=>{"use strict";a.d(s,{default:()=>l});var t=a(95155),n=a(12115),i=a(3534),d=a(28777),o=a(52679),c=a(14259);function l(){let[e,s]=(0,n.useState)([]),[a,l]=(0,n.useState)([]),[r,u]=(0,n.useState)({}),[h,f]=(0,n.useState)(!1),[p,w]=(0,n.useState)(null),[g,v]=(0,n.useState)({running:!1,certExists:!1,dnsStatus:{},hasCachedPassword:!1});(0,n.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{"sub_user"===e.role&&(window.location.href="/dashboard/usage")}).catch(()=>{}),S(),y(),k(),b()},[]);let S=async()=>{try{let e=await fetch("/api/providers");if(e.ok){let a=await e.json();s(a.connections||[])}}catch{}},y=async()=>{try{let e=await fetch("/api/keys");if(e.ok){let s=await e.json();l(s.keys||[])}}catch{}},k=async()=>{try{let e=await fetch("/api/models/alias");if(e.ok){let s=await e.json();u(s.aliases||{})}}catch{}},b=async()=>{try{let e=await fetch("/api/settings");if(e.ok){let s=await e.json();f(s.cloudEnabled||!1)}}catch{}},j=()=>e.filter(e=>!1!==e.isActive),m=Object.entries(i.wn);return(0,t.jsxs)("div",{className:"flex w-full flex-col gap-6",children:[(0,t.jsx)(c.tA,{apiKeys:a,cloudEnabled:h,onStatusChange:v}),(0,t.jsx)("div",{className:"grid gap-3 sm:gap-4",children:m.map(([e,s])=>(0,t.jsx)(c.kn,{tool:s,isExpanded:p===e,onToggle:()=>w(p===e?null:e),serverRunning:g.running,dnsActive:g.dnsStatus?.[e]||!1,hasCachedPassword:g.hasCachedPassword||!1,needsSudoPassword:!1!==g.needsSudoPassword,isWin:!0===g.isWin,apiKeys:a,activeProviders:j(),hasActiveProviders:j().some(e=>(0,d.KC)(e.provider).length>0||(0,o.mq)(e.provider)||(0,o.gb)(e.provider)),modelAliases:r,cloudEnabled:h,onDnsChange:e=>v(s=>({...s,dnsStatus:e.dnsStatus??s.dnsStatus}))},e))})]})}},51167:(e,s,a)=>{Promise.resolve().then(a.bind(a,23879))}},e=>{e.O(0,[2574,3862,1051,5772,1321,5497,2336,8441,3794,7358],()=>e(e.s=51167)),_N_E=e.O()}]);
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[6607],{23879:(e,s,a)=>{"use strict";a.d(s,{default:()=>l});var t=a(95155),n=a(12115),i=a(3534),d=a(28777),o=a(52679),c=a(70151);function l(){let[e,s]=(0,n.useState)([]),[a,l]=(0,n.useState)([]),[r,u]=(0,n.useState)({}),[h,f]=(0,n.useState)(!1),[p,w]=(0,n.useState)(null),[g,v]=(0,n.useState)({running:!1,certExists:!1,dnsStatus:{},hasCachedPassword:!1});(0,n.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{"sub_user"===e.role&&(window.location.href="/dashboard/usage")}).catch(()=>{}),S(),y(),k(),b()},[]);let S=async()=>{try{let e=await fetch("/api/providers");if(e.ok){let a=await e.json();s(a.connections||[])}}catch{}},y=async()=>{try{let e=await fetch("/api/keys");if(e.ok){let s=await e.json();l(s.keys||[])}}catch{}},k=async()=>{try{let e=await fetch("/api/models/alias");if(e.ok){let s=await e.json();u(s.aliases||{})}}catch{}},b=async()=>{try{let e=await fetch("/api/settings");if(e.ok){let s=await e.json();f(s.cloudEnabled||!1)}}catch{}},j=()=>e.filter(e=>!1!==e.isActive),m=Object.entries(i.wn);return(0,t.jsxs)("div",{className:"flex w-full flex-col gap-6",children:[(0,t.jsx)(c.tA,{apiKeys:a,cloudEnabled:h,onStatusChange:v}),(0,t.jsx)("div",{className:"grid gap-3 sm:gap-4",children:m.map(([e,s])=>(0,t.jsx)(c.kn,{tool:s,isExpanded:p===e,onToggle:()=>w(p===e?null:e),serverRunning:g.running,dnsActive:g.dnsStatus?.[e]||!1,hasCachedPassword:g.hasCachedPassword||!1,needsSudoPassword:!1!==g.needsSudoPassword,isWin:!0===g.isWin,apiKeys:a,activeProviders:j(),hasActiveProviders:j().some(e=>(0,d.KC)(e.provider).length>0||(0,o.mq)(e.provider)||(0,o.gb)(e.provider)),modelAliases:r,cloudEnabled:h,onDnsChange:e=>v(s=>({...s,dnsStatus:e.dnsStatus??s.dnsStatus}))},e))})]})}},51167:(e,s,a)=>{Promise.resolve().then(a.bind(a,23879))}},e=>{e.O(0,[2574,3862,1051,5772,1321,5497,5964,8441,3794,7358],()=>e(e.s=51167)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[3471],{39600:(e,t,s)=>{Promise.resolve().then(s.bind(s,64561))},64561:(e,t,s)=>{"use strict";s.r(t),s.d(t,{default:()=>b});var a=s(95155),r=s(12115),o=s(35497),i=s(1620),l=s(31474),n=s(90620);let d=[{id:"openai",label:"OpenAI / Codex",targets:["api.openai.com","chatgpt.com"]},{id:"anthropic",label:"Anthropic",targets:["api.anthropic.com"]},{id:"google",label:"Google / Gemini",targets:["generativelanguage.googleapis.com","aiplatform.googleapis.com"]},{id:"antigravity",label:"Antigravity",targets:["cloudcode-pa.googleapis.com","daily-cloudcode-pa.googleapis.com","daily-cloudcode-pa.sandbox.googleapis.com"]},{id:"copilot",label:"GitHub Copilot",targets:["api.individual.githubcopilot.com"]},{id:"openrouter",label:"OpenRouter",targets:["openrouter.ai","api.openrouter.ai"]},{id:"cursor",label:"Cursor",targets:["api2.cursor.sh"]},{id:"kiro",label:"Kiro / AWS",targets:["q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com"]}],c=new Set(d.flatMap(e=>e.targets));function m(e){return Array.from(new Set(e.map(e=>String(e||"").trim()).filter(Boolean)))}function x(e,t,s){let a=String(e||"").trim();if(!a||!t&&!s)return a;try{let e=/^[a-z][a-z0-9+.-]*:\/\//i.test(a),r=new URL(e?a:`http://${a}`);return r.username=t||"",r.password=s||"",r.toString()}catch{return a}}function u(e){try{return decodeURIComponent(e||"")}catch{return e||""}}function p(e){let t=String(e||"").trim();if(!t)return{proxyUrl:"",username:"",password:""};try{let e=/^[a-z][a-z0-9+.-]*:\/\//i.test(t),s=new URL(e?t:`http://${t}`),a=u(s.username),r=u(s.password);s.username="",s.password="";let o=e?s.toString():s.toString().replace(/^http:\/\//i,"");return"/"!==s.pathname||s.search||s.hash||(o=o.replace(/\/$/,"")),{proxyUrl:o,username:a,password:r}}catch{return{proxyUrl:t,username:"",password:""}}}function b(){let{theme:e,setTheme:t,isDark:s}=(0,i.D)(),[u,b]=(0,r.useState)({fallbackStrategy:"fill-first"}),[h,g]=(0,r.useState)(!0),[y,f]=(0,r.useState)({current:"",new:"",confirm:""}),[j,w]=(0,r.useState)({type:"",message:""}),[N,v]=(0,r.useState)(!1),[P,C]=(0,r.useState)(!1),[S,k]=(0,r.useState)({type:"",message:""}),[O,I]=(0,r.useState)({authMode:"password",oidcIssuerUrl:"",oidcClientId:"",oidcScopes:"openid profile email",oidcLoginLabel:"Sign in with OIDC"}),[U,L]=(0,r.useState)(""),[T,R]=(0,r.useState)({type:"",message:""}),[A,D]=(0,r.useState)(!1),[M,$]=(0,r.useState)(!1),[E,F]=(0,r.useState)({type:"",message:""}),[q,J]=(0,r.useState)("/api/auth/oidc/callback"),[H,_]=(0,r.useState)(!1),z=(0,r.useRef)(null),[K,B]=(0,r.useState)({outboundProxyEnabled:!1,outboundProxyUrl:"",outboundNoProxy:"",outboundProxyTargets:[],outboundProxyCustomTargets:"",outboundProxyUsername:"",outboundProxyPassword:"",outboundProxySavedUsername:"",outboundProxySavedPassword:""}),[Z,G]=(0,r.useState)({type:"",message:""}),[W,Q]=(0,r.useState)(!1),[V,Y]=(0,r.useState)(!1);(0,r.useEffect)(()=>{fetch("/api/auth/me").then(e=>e.json()).then(e=>{"sub_user"===e.role&&(window.location.href="/dashboard/usage")}).catch(()=>{})},[]),(0,r.useEffect)(()=>{fetch("/api/settings").then(e=>e.json()).then(e=>{let t=p(e?.outboundProxyUrl);b(e),I({authMode:e?.authMode||"password",oidcIssuerUrl:e?.oidcIssuerUrl||"",oidcClientId:e?.oidcClientId||"",oidcScopes:e?.oidcScopes||"openid profile email",oidcLoginLabel:e?.oidcLoginLabel||"Sign in with OIDC"}),L(""),(e?.authMode==="oidc"||e?.authMode==="both")&&_(!0),B({outboundProxyEnabled:e?.outboundProxyEnabled===!0,outboundProxyUrl:t.proxyUrl,outboundNoProxy:e?.outboundNoProxy||"",outboundProxyTargets:Array.isArray(e?.outboundProxyTargets)?e.outboundProxyTargets:[],outboundProxyCustomTargets:Array.isArray(e?.outboundProxyTargets)?e.outboundProxyTargets.filter(e=>!c.has(e)).join(","):"",outboundProxyUsername:t.username,outboundProxyPassword:"",outboundProxySavedUsername:t.username,outboundProxySavedPassword:t.password}),g(!1)}).catch(e=>{console.error("Failed to fetch settings:",e),g(!1)})},[]),(0,r.useEffect)(()=>{J(`${window.location.origin}/api/auth/oidc/callback`)},[]);let X=async e=>{if(e.preventDefault(),!0!==u.outboundProxyEnabled)return;Q(!0),G({type:"",message:""});let t=es(),s=K.outboundProxyPassword||(K.outboundProxyUsername===K.outboundProxySavedUsername?K.outboundProxySavedPassword:""),a=x(K.outboundProxyUrl,K.outboundProxyUsername,s);try{let e=await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({outboundProxyUrl:a,outboundProxyTargets:t})}),s=await e.json();if(e.ok){let e=p(s?.outboundProxyUrl||a);b(e=>({...e,...s})),B(a=>({...a,outboundProxyUrl:e.proxyUrl,outboundProxyTargets:Array.isArray(s?.outboundProxyTargets)?s.outboundProxyTargets:t,outboundProxyUsername:e.username,outboundProxyPassword:"",outboundProxySavedUsername:e.username,outboundProxySavedPassword:e.password})),G({type:"success",message:"Proxy settings applied"})}else G({type:"error",message:s.error||"Failed to update proxy settings"})}catch(e){G({type:"error",message:"An error occurred"})}finally{Q(!1)}},ee=async()=>{if(!0!==u.outboundProxyEnabled)return;let e=K.outboundProxyPassword||(K.outboundProxyUsername===K.outboundProxySavedUsername?K.outboundProxySavedPassword:""),t=x(K.outboundProxyUrl,K.outboundProxyUsername,e);if(!t)return void G({type:"error",message:"Please enter a Proxy URL to test"});Y(!0),G({type:"",message:""});try{let e=await fetch("/api/settings/proxy-test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyUrl:t})}),s=await e.json();e.ok&&s?.ok?G({type:"success",message:`Proxy test OK (${s.status}) in ${s.elapsedMs}ms`}):G({type:"error",message:s?.error||"Proxy test failed"})}catch(e){G({type:"error",message:"An error occurred"})}finally{Y(!1)}},et=async e=>{Q(!0),G({type:"",message:""});try{let t=await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({outboundProxyEnabled:e})}),s=await t.json();t.ok?(b(e=>({...e,...s})),B(e=>({...e,outboundProxyEnabled:s?.outboundProxyEnabled===!0})),G({type:"success",message:e?"Proxy enabled":"Proxy disabled"})):G({type:"error",message:s.error||"Failed to update proxy settings"})}catch(e){G({type:"error",message:"An error occurred"})}finally{Q(!1)}},es=()=>m([...Array.isArray(K.outboundProxyTargets)?K.outboundProxyTargets:[],...m(String(K.outboundProxyCustomTargets||"").split(","))]),ea=async e=>{if(e.preventDefault(),y.new!==y.confirm)return void w({type:"error",message:"Passwords do not match"});v(!0),w({type:"",message:""});try{let e=await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({currentPassword:y.current,newPassword:y.new})}),t=await e.json();e.ok?(w({type:"success",message:"Password updated successfully"}),f({current:"",new:"",confirm:""})):w({type:"error",message:t.error||"Failed to update password"})}catch(e){w({type:"error",message:"An error occurred"})}finally{v(!1)}},er=async e=>{try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({fallbackStrategy:e})})).ok&&b(t=>({...t,fallbackStrategy:e}))}catch(e){console.error("Failed to update settings:",e)}},eo=async e=>{try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({comboStrategy:e})})).ok&&b(t=>({...t,comboStrategy:e}))}catch(e){console.error("Failed to update combo strategy:",e)}},ei=async e=>{let t=parseInt(e);if(!isNaN(t)&&!(t<1))try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({stickyRoundRobinLimit:t})})).ok&&b(e=>({...e,stickyRoundRobinLimit:t}))}catch(e){console.error("Failed to update sticky limit:",e)}},el=async e=>{let t=parseInt(e);if(!isNaN(t)&&!(t<1))try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({comboStickyRoundRobinLimit:t})})).ok&&b(e=>({...e,comboStickyRoundRobinLimit:t}))}catch(e){console.error("Failed to update combo sticky limit:",e)}},en=async e=>{try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({requireLogin:e})})).ok&&b(t=>({...t,requireLogin:e}))}catch(e){console.error("Failed to update require login:",e)}},ed=(e,t)=>{I(s=>({...s,[e]:t}))},ec=async(e=O.authMode||"password")=>{let t=O.oidcIssuerUrl.trim(),s=O.oidcClientId.trim(),a=O.oidcScopes.trim(),r=O.oidcLoginLabel.trim(),o=U.trim();if("password"!==e&&(!t||!s||!o)&&!u.oidcConfigured)return void R({type:"error",message:"Issuer URL, client ID, and client secret are required to enable OIDC."});D(!0),R({type:"",message:""}),F({type:"",message:""});try{let i={authMode:e,oidcIssuerUrl:t,oidcClientId:s,oidcScopes:a||"openid profile email",oidcLoginLabel:r||"Sign in with OIDC"};o&&(i.oidcClientSecret=o);let l=await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify(i)}),n=await l.json();l.ok?(b(e=>({...e,...n})),I({authMode:n?.authMode||e,oidcIssuerUrl:n?.oidcIssuerUrl||t,oidcClientId:n?.oidcClientId||s,oidcScopes:n?.oidcScopes||a||"openid profile email",oidcLoginLabel:n?.oidcLoginLabel||r||"Sign in with OIDC"}),L(""),R({type:"success",message:"oidc"===e?"OIDC login enabled":"both"===e?"Password and OIDC login enabled":"OIDC settings saved"})):R({type:"error",message:n.error||"Failed to save OIDC settings"})}catch(e){R({type:"error",message:"An error occurred"})}finally{D(!1)}},em=async()=>{let e=O.oidcIssuerUrl.trim(),t=O.oidcClientId.trim(),s=O.oidcScopes.trim(),a=U.trim();if(!e||!t)return void F({type:"error",message:"Issuer URL and client ID are required to test the connection."});$(!0),R({type:"",message:""}),F({type:"",message:""});try{let r=await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({authMode:O.authMode||u.authMode||"password",oidcIssuerUrl:e,oidcClientId:t,oidcScopes:s||"openid profile email",oidcLoginLabel:O.oidcLoginLabel.trim()||"Sign in with OIDC",...a?{oidcClientSecret:a}:{}})}),o=await r.json().catch(()=>({}));if(!r.ok)return void F({type:"error",message:o.error||"Failed to save OIDC settings before testing"});let i=await fetch("/api/auth/oidc/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({issuerUrl:o.oidcIssuerUrl||e,clientId:o.oidcClientId||t,scopes:o.oidcScopes||s||"openid profile email"})}),l=await i.json().catch(()=>({}));if(i.ok&&l?.ok){let e=l.clientSecretTested?!0===l.clientSecretValid?`Connection OK. Discovery loaded from ${l.issuerUrl}. Client secret validated too.`:`Connection OK. Discovery loaded from ${l.issuerUrl}. Client secret was not checked.`:`Connection OK. Discovery loaded from ${l.issuerUrl}.`;F({type:"success",message:e})}else F({type:"error",message:l.error||"OIDC connection test failed"})}catch(e){F({type:"error",message:"An error occurred"})}finally{$(!1)}},ex=async e=>{try{(await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({enableObservability:e})})).ok&&b(t=>({...t,enableObservability:e}))}catch(e){console.error("Failed to update enableObservability:",e)}},eu=async()=>{try{let e=await fetch("/api/settings");if(!e.ok)return;let t=await e.json();b(t)}catch(e){console.error("Failed to reload settings:",e)}},ep=async()=>{C(!0),k({type:"",message:""});try{let e=await fetch("/api/settings/database");if(!e.ok){let t=await e.json().catch(()=>({}));throw Error(t.error||"Failed to export database")}let t=await e.json(),s=JSON.stringify(t,null,2),a=new Blob([s],{type:"application/json"}),r=URL.createObjectURL(a),o=document.createElement("a"),i=new Date().toISOString().replace(/[.:]/g,"-");o.href=r,o.download=`openrouterx-backup-${i}.json`,document.body.appendChild(o),o.click(),document.body.removeChild(o),URL.revokeObjectURL(r),k({type:"success",message:"Database backup downloaded"})}catch(e){k({type:"error",message:e.message||"Failed to export database"})}finally{C(!1)}},eb=async e=>{let t=e.target.files?.[0];if(t){C(!0),k({type:"",message:""});try{let e=await t.text(),s=JSON.parse(e),a=await fetch("/api/settings/database",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(s)}),r=await a.json().catch(()=>({}));if(!a.ok)throw Error(r.error||"Failed to import database");await eu(),k({type:"success",message:"Database imported successfully"})}catch(e){k({type:"error",message:e.message||"Invalid backup file"})}finally{z.current&&(z.current.value=""),C(!1)}}},eh=!0===u.enableObservability;return(0,a.jsx)("div",{className:"max-w-2xl mx-auto px-4 sm:px-0",children:(0,a.jsxs)("div",{className:"flex flex-col gap-6",children:[(0,a.jsxs)(o.Zp,{children:[(0,a.jsxs)("div",{className:"flex flex-col sm:flex-row sm:items-center sm:justify-between gap-4 mb-4",children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 sm:gap-4",children:[(0,a.jsx)("div",{className:"size-10 sm:size-12 rounded-lg bg-green-500/10 text-green-500 flex items-center justify-center shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-xl sm:text-2xl",children:"computer"})}),(0,a.jsxs)("div",{children:[(0,a.jsx)("h2",{className:"text-lg sm:text-xl font-semibold",children:"Local Mode"}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"Running on your machine"})]})]}),(0,a.jsx)("div",{className:"inline-flex p-1 rounded-lg bg-black/5 dark:bg-white/5 w-full sm:w-auto",children:["light","dark","system"].map(s=>(0,a.jsxs)("button",{type:"button",onClick:()=>t(s),className:(0,l.cn)("flex items-center justify-center gap-1 sm:gap-1.5 px-2 sm:px-3 py-1.5 rounded-md font-medium transition-all flex-1 sm:flex-initial",e===s?"bg-white dark:bg-white/10 text-text-main shadow-sm":"text-text-muted hover:text-text-main"),children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:"light"===s?"light_mode":"dark"===s?"dark_mode":"contrast"}),(0,a.jsx)("span",{className:"capitalize text-xs sm:text-sm",children:s})]},s))})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-3 pt-4 border-t border-border",children:[(0,a.jsx)("div",{className:"flex flex-col sm:flex-row sm:items-center sm:justify-between p-3 rounded-lg bg-bg border border-border gap-2",children:(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Database Location"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted font-mono break-all",children:u.databasePath||"~/.openrouterx/db.json"})]})}),(0,a.jsxs)("div",{className:"flex flex-col sm:flex-row gap-2",children:[(0,a.jsx)(o.$n,{variant:"secondary",icon:"download",onClick:ep,loading:P,className:"w-full sm:w-auto",children:"Download Backup"}),(0,a.jsx)(o.$n,{variant:"outline",icon:"upload",onClick:()=>z.current?.click(),disabled:P,className:"w-full sm:w-auto",children:"Import Backup"}),(0,a.jsx)("input",{ref:z,type:"file",accept:"application/json,.json",className:"hidden",onChange:eb})]}),S.message&&(0,a.jsx)("p",{className:`text-sm ${"error"===S.type?"text-red-500":"text-green-600 dark:text-green-400"}`,children:S.message})]})]}),(0,a.jsxs)(o.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-primary/10 text-primary shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"shield"})}),(0,a.jsx)("h3",{className:"text-base sm:text-lg font-semibold",children:"Security"})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex items-start sm:items-center justify-between gap-4",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Require login"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"When ON, dashboard requires password. When OFF, access without login."})]}),(0,a.jsx)(o.lM,{checked:!0===u.requireLogin,onChange:()=>en(!u.requireLogin),disabled:h})]}),!0===u.requireLogin&&(0,a.jsxs)("form",{onSubmit:ea,className:"flex flex-col gap-4 pt-4 border-t border-border/50",children:[u.hasPassword&&(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"text-xs sm:text-sm font-medium",children:"Current Password"}),(0,a.jsx)(o.pd,{type:"password",placeholder:"Enter current password",value:y.current,onChange:e=>f({...y,current:e.target.value}),required:!0})]}),(0,a.jsxs)("div",{className:"grid grid-cols-1 sm:grid-cols-2 gap-4",children:[(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"text-xs sm:text-sm font-medium",children:"New Password"}),(0,a.jsx)(o.pd,{type:"password",placeholder:"Enter new password",value:y.new,onChange:e=>f({...y,new:e.target.value}),required:!0})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"text-xs sm:text-sm font-medium",children:"Confirm New Password"}),(0,a.jsx)(o.pd,{type:"password",placeholder:"Confirm new password",value:y.confirm,onChange:e=>f({...y,confirm:e.target.value}),required:!0})]})]}),j.message&&(0,a.jsx)("p",{className:`text-xs sm:text-sm ${"error"===j.type?"text-red-500":"text-green-500"}`,children:j.message}),(0,a.jsx)("div",{className:"pt-2",children:(0,a.jsx)(o.$n,{type:"submit",variant:"primary",loading:N,className:"w-full sm:w-auto",children:u.hasPassword?"Update Password":"Set Password"})})]})]})]}),(0,a.jsxs)(o.Zp,{children:[(0,a.jsxs)("button",{type:"button",onClick:()=>_(e=>!e),className:"w-full flex items-center gap-3 text-left",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-indigo-500/10 text-indigo-500 shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"lock_open"})}),(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("h3",{className:"text-base sm:text-lg font-semibold",children:"OIDC Dashboard Login"}),(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"oidc"===u.authMode?"OIDC active":"both"===u.authMode?"Password + OIDC active":"Optional SSO via Authentik/Keycloak/Google"})]}),(0,a.jsx)("span",{className:"material-symbols-outlined text-text-muted shrink-0",children:H?"expand_less":"expand_more"})]}),H&&(0,a.jsxs)("div",{className:"flex flex-col gap-4 mt-4",children:[(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Use Authentik or any OIDC provider to sign in to the dashboard. You can enable password-only, OIDC-only, or both for the dashboard; model API access still uses API keys."}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Auth Mode"}),(0,a.jsx)("div",{className:"grid grid-cols-1 sm:grid-cols-3 gap-2",children:[{value:"password",title:"Password only",desc:"Keep the legacy password login."},{value:"oidc",title:"OIDC only",desc:"Require OIDC for dashboard access."},{value:"both",title:"Both",desc:"Allow either password or OIDC."}].map(e=>{let t=O.authMode===e.value;return(0,a.jsxs)("button",{type:"button",onClick:()=>ed("authMode",e.value),className:(0,l.cn)("text-left rounded-lg border p-3 transition-colors",t?"border-primary bg-primary/5":"border-border bg-bg hover:bg-black/5 dark:hover:bg-white/5"),disabled:h||A,children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:e.title}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted mt-1",children:e.desc})]},e.value)})})]}),(0,a.jsxs)("div",{className:"grid grid-cols-1 gap-4",children:[(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Issuer URL"}),(0,a.jsx)(o.pd,{placeholder:"https://auth.example.com/application/o/9router/",value:O.oidcIssuerUrl,onChange:e=>ed("oidcIssuerUrl",e.target.value),disabled:h||A})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Client ID"}),(0,a.jsx)(o.pd,{placeholder:"9router-dashboard",value:O.oidcClientId,onChange:e=>ed("oidcClientId",e.target.value),disabled:h||A})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Client Secret"}),(0,a.jsx)(o.pd,{type:"password",placeholder:"Leave blank to keep existing secret",value:U,onChange:e=>L(e.target.value),disabled:h||A}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"This value is write-only after saving."})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Scopes"}),(0,a.jsx)(o.pd,{placeholder:"openid profile email",value:O.oidcScopes,onChange:e=>ed("oidcScopes",e.target.value),disabled:h||A})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Login Button Label"}),(0,a.jsx)(o.pd,{placeholder:"Sign in with OIDC",value:O.oidcLoginLabel,onChange:e=>ed("oidcLoginLabel",e.target.value),disabled:h||A})]})]}),(0,a.jsxs)("div",{className:"rounded-lg border border-border bg-bg p-3 text-xs sm:text-sm text-text-muted",children:[(0,a.jsx)("p",{className:"font-medium text-text-main mb-1",children:"Redirect URI"}),(0,a.jsx)("code",{className:"block break-all font-mono",children:q})]}),(0,a.jsxs)("div",{className:"flex flex-col sm:flex-row gap-2 pt-2 border-t border-border/50",children:[(0,a.jsx)(o.$n,{type:"button",variant:"primary",loading:A,onClick:()=>ec(),className:"w-full sm:w-auto",children:"Save auth mode"}),(0,a.jsx)(o.$n,{type:"button",variant:"outline",loading:M,onClick:em,className:"w-full sm:w-auto",children:"Test connection"})]}),E.message&&(0,a.jsx)("p",{className:`text-xs sm:text-sm ${"error"===E.type?"text-red-500":"text-green-500"}`,children:E.message}),T.message&&(0,a.jsx)("p",{className:`text-xs sm:text-sm ${"error"===T.type?"text-red-500":"text-green-500"}`,children:T.message}),"oidc"===u.authMode&&(0,a.jsx)("p",{className:"text-xs sm:text-sm text-amber-600 dark:text-amber-400",children:"OIDC login is currently active. Password login is disabled until you switch back."}),"both"===u.authMode&&(0,a.jsx)("p",{className:"text-xs sm:text-sm text-amber-600 dark:text-amber-400",children:"Password and OIDC login are both active."})]})]}),(0,a.jsxs)(o.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-blue-500/10 text-blue-500 shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"route"})}),(0,a.jsx)("h3",{className:"text-base sm:text-lg font-semibold",children:"Routing Strategy"})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex items-start sm:items-center justify-between gap-4",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Round Robin"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Cycle through accounts to distribute load"})]}),(0,a.jsx)(o.lM,{checked:"round-robin"===u.fallbackStrategy,onChange:()=>er("round-robin"===u.fallbackStrategy?"fill-first":"round-robin"),disabled:h})]}),"round-robin"===u.fallbackStrategy&&(0,a.jsxs)("div",{className:"flex items-start sm:items-center justify-between gap-4 pt-2 border-t border-border/50",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Sticky Limit"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Calls per account before switching"})]}),(0,a.jsx)(o.pd,{type:"number",min:"1",max:"10",value:u.stickyRoundRobinLimit||3,onChange:e=>ei(e.target.value),disabled:h,className:"w-16 sm:w-20 text-center shrink-0"})]}),(0,a.jsxs)("div",{className:"flex items-start sm:items-center justify-between gap-4 pt-4 border-t border-border/50",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Combo Round Robin"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Cycle through providers in combos instead of always starting with first"})]}),(0,a.jsx)(o.lM,{checked:"round-robin"===u.comboStrategy,onChange:()=>eo("round-robin"===u.comboStrategy?"fallback":"round-robin"),disabled:h})]}),"round-robin"===u.comboStrategy&&(0,a.jsxs)("div",{className:"flex items-center justify-between pt-2 border-t border-border/50",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("p",{className:"font-medium",children:"Combo Sticky Limit"}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"Calls per combo model before switching"})]}),(0,a.jsx)(o.pd,{type:"number",min:"1",max:"100",value:u.comboStickyRoundRobinLimit||1,onChange:e=>el(e.target.value),disabled:h,className:"w-20 text-center"})]}),(0,a.jsxs)("p",{className:"text-xs text-text-muted italic pt-2 border-t border-border/50",children:["round-robin"===u.fallbackStrategy?`Currently distributing requests across all available accounts with ${u.stickyRoundRobinLimit||3} calls per account.`:"Currently using accounts in priority order (Fill First).","round-robin"===u.comboStrategy?` Combos rotate after ${u.comboStickyRoundRobinLimit||1} call${1===(u.comboStickyRoundRobinLimit||1)?"":"s"} per model.`:" Combos always start with their first model."]})]})]}),(0,a.jsxs)(o.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-purple-500/10 text-purple-500 shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"wifi"})}),(0,a.jsx)("h3",{className:"text-base sm:text-lg font-semibold",children:"Network"})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"flex items-start sm:items-center justify-between gap-4",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Outbound Proxy"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Enable proxy for OAuth + provider outbound requests."})]}),(0,a.jsx)(o.lM,{checked:!0===u.outboundProxyEnabled,onChange:()=>et(!0!==u.outboundProxyEnabled),disabled:h||W})]}),!0===u.outboundProxyEnabled&&(0,a.jsxs)("form",{onSubmit:X,className:"flex flex-col gap-4 pt-2 border-t border-border/50",children:[(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Proxy URL"}),(0,a.jsx)(o.pd,{placeholder:"socks5://127.0.0.1:1080",value:K.outboundProxyUrl,onChange:e=>B(t=>({...t,outboundProxyUrl:e.target.value})),disabled:h||W}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Supports http, https, socks4, socks4a, socks5, and socks5h."})]}),(0,a.jsxs)("div",{className:"grid grid-cols-1 sm:grid-cols-2 gap-3",children:[(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Proxy Username"}),(0,a.jsx)(o.pd,{placeholder:"optional",value:K.outboundProxyUsername,onChange:e=>B(t=>({...t,outboundProxyUsername:e.target.value})),disabled:h||W})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Proxy Password"}),(0,a.jsx)(o.pd,{type:"password",placeholder:K.outboundProxySavedPassword?"saved (hidden)":"optional",value:K.outboundProxyPassword,onChange:e=>B(t=>({...t,outboundProxyPassword:e.target.value})),disabled:h||W})]})]}),(0,a.jsxs)("div",{className:"flex flex-col gap-3 pt-2 border-t border-border/50",children:[(0,a.jsxs)("div",{children:[(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Use Proxy For"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Default is direct. Checked targets use the proxy."})]}),(0,a.jsx)("div",{className:"grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 gap-2",children:d.map(e=>{let t=new Set(K.outboundProxyTargets||[]),s=e.targets.every(e=>t.has(e));return(0,a.jsxs)("label",{className:(0,l.cn)("flex items-center gap-2 rounded-lg border px-3 py-2 text-sm cursor-pointer transition-colors",s?"border-primary bg-primary/5 text-text-main":"border-border bg-surface text-text-muted hover:border-primary/50"),children:[(0,a.jsx)("input",{type:"checkbox",checked:s,onChange:()=>{B(t=>{let s=new Set(t.outboundProxyTargets||[]),a=e.targets.every(e=>s.has(e));for(let t of e.targets)a?s.delete(t):s.add(t);return{...t,outboundProxyTargets:Array.from(s)}})},disabled:h||W,className:"h-4 w-4 accent-primary"}),(0,a.jsx)("span",{className:"truncate",children:e.label})]},e.id)})}),(0,a.jsx)("label",{className:"font-medium text-sm sm:text-base",children:"Custom Proxy Hosts"}),(0,a.jsx)(o.pd,{placeholder:"api.example.com,.example.org",value:K.outboundProxyCustomTargets,onChange:e=>B(t=>({...t,outboundProxyCustomTargets:e.target.value})),disabled:h||W})]}),(0,a.jsxs)("div",{className:"pt-2 border-t border-border/50 flex flex-col sm:flex-row items-stretch sm:items-center gap-2",children:[(0,a.jsx)(o.$n,{type:"button",variant:"secondary",loading:V,disabled:h||W,onClick:ee,className:"w-full sm:w-auto",children:"Test proxy URL"}),(0,a.jsx)(o.$n,{type:"submit",variant:"primary",loading:W,className:"w-full sm:w-auto",children:"Apply"})]})]}),Z.message&&(0,a.jsx)("p",{className:`text-xs sm:text-sm ${"error"===Z.type?"text-red-500":"text-green-500"} pt-2 border-t border-border/50`,children:Z.message})]})]}),(0,a.jsxs)(o.Zp,{children:[(0,a.jsxs)("div",{className:"flex items-center gap-3 mb-4",children:[(0,a.jsx)("div",{className:"p-2 rounded-lg bg-orange-500/10 text-orange-500 shrink-0",children:(0,a.jsx)("span",{className:"material-symbols-outlined text-[20px]",children:"monitoring"})}),(0,a.jsx)("h3",{className:"text-base sm:text-lg font-semibold",children:"Observability"})]}),(0,a.jsxs)("div",{className:"flex items-start sm:items-center justify-between gap-4",children:[(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"font-medium text-sm sm:text-base",children:"Enable Observability"}),(0,a.jsx)("p",{className:"text-xs sm:text-sm text-text-muted",children:"Record request details for inspection in the logs view"})]}),(0,a.jsx)(o.lM,{checked:eh,onChange:ex,disabled:h})]})]}),(0,a.jsxs)("div",{className:"text-center text-xs sm:text-sm text-text-muted py-4",children:[(0,a.jsxs)("p",{children:[n.vQ.name," v",n.vQ.version]}),(0,a.jsx)("p",{className:"mt-1",children:"Local Mode - All data stored on your machine"})]})]})})}}},e=>{e.O(0,[2574,3862,1051,1321,5497,8441,3794,7358],()=>e(e.s=39600)),_N_E=e.O()}]);
@@ -0,0 +1,3 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[2134],{7570:(e,t,s)=>{"use strict";s.r(t),s.d(t,{default:()=>$});var a=s(95155),i=s(12115),r=s(73321),l=s(98500),o=s.n(l),n=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,displayModel:s,alias:i,copied:r,onCopy:l,testStatus:o,isCustom:n,isFree:d,onDeleteAlias:c,onTest:p,isTesting:m,onDisable:x}){let u="ok"===o?"#22c55e":"error"===o?"#ef4444":void 0;return(0,a.jsx)("div",{className:`group min-w-0 max-w-full rounded-lg border px-3 py-2 ${"ok"===o?"border-green-500/40":"error"===o?"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:u?{color:u}:void 0,children:"ok"===o?"check_circle":"error"===o?"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:s||t}),e.name&&(0,a.jsx)("span",{className:"truncate pl-1 text-[9px] italic text-text-muted/70",children:e.name})]}),p&&(0,a.jsxs)("div",{className:"relative shrink-0 group/btn",children:[(0,a.jsx)("button",{onClick:p,disabled:m,className:`rounded p-0.5 text-text-muted transition-opacity hover:bg-sidebar hover:text-primary ${m?"opacity-100":"opacity-100 sm:opacity-0 sm:group-hover:opacity-100"}`,children:(0,a.jsx)("span",{className:"material-symbols-outlined text-sm",style:m?{animation:"spin 1s linear infinite"}:void 0,children:m?"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:m?"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:r===`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:r===`model-${e.id}`?"Copied!":"Copy"})]}),n?(0,a.jsx)("button",{onClick:c,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"})}):x?(0,a.jsx)("button",{onClick:x,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:r,onTest:l,testStatus:o,isTesting:n}){let d="ok"===o?"#22c55e":"error"===o?"#ef4444":void 0;return(0,a.jsxs)("div",{className:`flex items-center gap-3 p-3 rounded-lg border ${"ok"===o?"border-green-500/40":"error"===o?"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"===o?"check_circle":"error"===o?"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"})]}),l&&(0,a.jsxs)("div",{className:"relative group/btn",children:[(0,a.jsx)("button",{onClick:l,disabled:n,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:n?{animation:"spin 1s linear infinite"}:void 0,children:n?"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:n?"Testing...":"Test"})]})]})]}),(0,a.jsx)("button",{onClick:r,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:r,onCopy:l,onSetAlias:o,onDeleteAlias:n,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,r=`${e}/${a}`;if(Object.values(s).includes(r))return null;let l=(i=a.split("/"))[i.length-1];if(!s[l])return l;let o=`${t}-${l}`;return s[o]?null:o},$=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 o(t,s,e),x("")}catch(e){console.log("Error adding model:",e)}finally{h(!1)}},A=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 r=0;for(let t of i){let s=t.id||t.name||t.model;if(!s)continue;let a=S(s);a&&(await o(s,a,e),r+=1)}0===r&&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&&$(),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:$,disabled:!m.trim()||u,children:u?"Adding...":"Add"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"download",onClick:A,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:r,onCopy:l,onDeleteAlias:()=>n(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:r,isLast:l,onMoveUp:o,onMoveDown:n,onToggleActive:c,onUpdateProxy:p,onEdit:m,onDelete:x}){let[u,h]=(0,i.useState)(!1),[f,g]=(0,i.useState)(!1),y=(0,i.useRef)(null),b=new Map((t||[]).map(e=>[e.id,e])),N=e.providerSpecificData?.proxyPoolId||null,w=N?b.get(N):null,k=e.providerSpecificData?.connectionProxyEnabled===!0&&!!e.providerSpecificData?.connectionProxyUrl,C=!!N||k,S=w?`Pool: ${w.name}`:N?`Pool: ${N} (inactive/missing)`:k?`Legacy: ${e.providerSpecificData?.connectionProxyUrl}`:"",$="";if(w?.proxyUrl||e.providerSpecificData?.connectionProxyUrl){let t=w?.proxyUrl||e.providerSpecificData?.connectionProxyUrl;try{let e=new URL(t);$=`${e.protocol}//${e.hostname}${e.port?`:${e.port}`:""}`}catch{$=t}}let A=w?.noProxy||e.providerSpecificData?.connectionNoProxy||"",T="default";w?.isActive===!0?T="success":(N||k)&&(T="error"),(0,i.useEffect)(()=>{if(!u)return;let e=e=>{y.current&&!y.current.contains(e.target)&&h(!1)};return document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[u]);let O=async e=>{g(!0);try{await p("__none__"===e?null:e)}finally{g(!1),h(!1)}},P=e=>"string"==typeof e&&/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(e),I=s?P(e.email)?e.email:P(e.name)?e.name:e.name||e.email||e.displayName||"OAuth Account":e.name,[E,_]=(0,i.useState)(!1),R=Object.entries(e).filter(([e])=>e.startsWith("modelLock_")).map(([,e])=>e).filter(e=>!!e).sort()[0]||null;(0,i.useEffect)(()=>{let t=()=>{_(!!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=R?setInterval(t,1e3):null;return()=>{s&&clearInterval(s)}},[R]);let U="unavailable"!==e.testStatus||E?e.testStatus:"active";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: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_up"})}),(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_down"})})]}),(0,a.jsx)("span",{className:"material-symbols-outlined shrink-0 text-base text-text-muted",children:s?"lock":"key"}),(0,a.jsxs)("div",{className:"flex-1 min-w-0",children:[(0,a.jsx)("p",{className:"text-sm font-medium truncate",children:I}),(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"===U||"success"===U?"success":"error"===U||"expired"===U||"unavailable"===U?"error":"default",size:"sm",dot:!0,children:!1===e.isActive?"disabled":U||"Unknown"}),C&&(0,a.jsx)(d.Ex,{variant:T,size:"sm",children:"Proxy"}),E&&!1!==e.isActive&&(0,a.jsx)(v,{until:R}),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]})]}),C&&(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:S,children:S}),$&&(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:$}),A&&(0,a.jsxs)("span",{className:"max-w-full truncate text-[11px] text-text-muted sm:max-w-[320px]",title:A,children:["no_proxy: ",A]})]})]})]}),(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:y,children:[(0,a.jsxs)("button",{onClick:()=>h(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 ${C?"text-primary":"text-text-muted hover:text-primary"}`,disabled:f,children:[(0,a.jsx)("span",{className:"material-symbols-outlined text-[18px]",children:f?"progress_activity":"lan"}),(0,a.jsx)("span",{className:"text-[10px] leading-tight",children:"Proxy"})]}),u&&(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:()=>O("__none__"),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${!N?"text-primary font-medium":"text-text-main"}`,children:"None"}),(t||[]).map(e=>(0,a.jsx)("button",{onClick:()=>O(e.id),className:`w-full text-left px-3 py-1.5 text-sm hover:bg-black/5 dark:hover:bg-white/5 ${N===e.id?"text-primary font-medium":"text-text-main"}`,children:e.name},e.id))]})]}),(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,displayModel:f().string,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,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};let N=`Production|sk-...
2
+ Backup|sk-...
3
+ sk-...`;function w({isOpen:e,provider:t,providerName:s,isCompatible:r,isAnthropic:l,authType:o,authHint:n,website:c,proxyPools:p,onSave:m,onBulkDone:x,onClose:u}){let h="__none__",f="ollama-local"===t,g="cookie"===o,y=g?"Cookie Value":"API Key",b=g?"grok-web"===t?"sso=xxxxx... or just the raw value":"eyJhbGciOi...":"",v="azure"===t,j="cloudflare-ai"===t,[k,C]=(0,i.useState)({name:"",apiKey:"",priority:1,proxyPoolId:h,ollamaHostUrl:""}),[S,$]=(0,i.useState)({azureEndpoint:"",apiVersion:"2024-10-01-preview",deployment:"",organization:""}),[A,T]=(0,i.useState)({accountId:""}),[O,P]=(0,i.useState)(!1),[I,E]=(0,i.useState)(null),[_,R]=(0,i.useState)(!1),[U,D]=(0,i.useState)("single"),[z,q]=(0,i.useState)(""),[M,J]=(0,i.useState)(null),F=f?"Ollama Local":g?`${s||t} Cookie`:"Production Key";(0,i.useEffect)(()=>{e&&(C({name:r?F:"",apiKey:"",priority:1,proxyPoolId:h,ollamaHostUrl:""}),$({azureEndpoint:"",apiVersion:"2024-10-01-preview",deployment:"",organization:""}),T({accountId:""}),P(!1),E(null),R(!1),D("single"),q(""),J(null))},[F,r,e]);let K=()=>f&&k.ollamaHostUrl.trim()?{baseUrl:k.ollamaHostUrl.trim()}:v?{azureEndpoint:S.azureEndpoint,apiVersion:S.apiVersion,deployment:S.deployment,organization:S.organization}:j?{accountId:A.accountId}:void 0,L=async()=>{P(!0);try{let e=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:k.apiKey,providerSpecificData:K()})}),s=await e.json();E(s.valid?"success":"failed")}catch{E("failed")}finally{P(!1)}},W=async()=>{if(!t||!f&&!k.apiKey)return;let e=k.name.trim()||F;R(!0);try{let s=!1;try{P(!0),E(null);let e=await fetch("/api/providers/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:k.apiKey,providerSpecificData:K()})});s=!!(await e.json()).valid,E(s?"success":"failed")}catch{E("failed")}finally{P(!1)}await m({name:e,apiKey:k.apiKey,priority:k.priority,proxyPoolId:k.proxyPoolId===h?null:k.proxyPoolId,testStatus:s?"active":"unknown",providerSpecificData:K()})}finally{R(!1)}},H=async()=>{let e=z.split("\n").map(e=>e.trim()).filter(Boolean);if(!e.length)return;R(!0),J(null);let s=0,a=0;for(let i=0;i<e.length;i++){let r=e[i].split("|"),l=r.length>=2?r.slice(1).join("|").trim():r[0].trim(),o=r.length>=2?r[0].trim():"Key",n=`${o} ${i+1}`;try{(await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:t,apiKey:l,name:n,priority:1,testStatus:"unknown"})})).ok?s++:a++}catch{a++}}R(!1),J({success:s,failed:a}),s>0&&x&&x()};return t?(0,a.jsx)(d.aF,{isOpen:e,title:`Add ${s||t} ${y}`,onClose:u,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"===U?"primary":"ghost",onClick:()=>{D("single"),J(null)},children:"Single"}),(0,a.jsx)(d.$n,{size:"sm",variant:"bulk"===U?"primary":"ghost",onClick:()=>{D("bulk"),J(null)},children:"Bulk Add"})]}),"bulk"===U&&(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:z,onChange:e=>q(e.target.value)}),M&&(0,a.jsxs)("div",{className:`text-sm font-medium ${M.failed>0?"text-yellow-400":"text-green-400"}`,children:["✓ ",M.success," added",M.failed>0?`, ✗ ${M.failed} failed`:""]}),(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.$n,{onClick:H,fullWidth:!0,disabled:_||!z.trim(),children:_?"Adding...":"Add All Keys"}),(0,a.jsx)(d.$n,{onClick:u,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]}),"single"===U&&(0,a.jsxs)(a.Fragment,{children:[(0,a.jsx)(d.pd,{label:"Name",value:k.name,onChange:e=>C({...k,name:e.target.value}),placeholder:F}),f&&(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.pd,{label:"Ollama Host URL",value:k.ollamaHostUrl,onChange:e=>C({...k,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:L,disabled:O||_,variant:"secondary",children:O?"Checking...":"Check"})})]}),!f&&(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.pd,{label:y,type:g?"text":"password",value:k.apiKey,onChange:e=>C({...k,apiKey:e.target.value}),placeholder:b,className:"flex-1"}),(0,a.jsx)("div",{className:"pt-6",children:(0,a.jsx)(d.$n,{onClick:L,disabled:!k.apiKey||O||_,variant:"secondary",children:O?"Checking...":"Check"})})]}),g&&n&&(0,a.jsxs)("p",{className:"text-xs text-text-muted",children:[n,c&&(0,a.jsxs)(a.Fragment,{children:[" ",(0,a.jsxs)("a",{href:c,target:"_blank",rel:"noopener noreferrer",className:"text-primary underline",children:["Open ",c.replace(/^https?:\/\//,"")]})]})]}),f&&(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"}),")."]}),I&&(0,a.jsx)(d.Ex,{variant:"success"===I?"success":"error",children:"success"===I?"Valid":"Invalid"}),r&&(0,a.jsx)("p",{className:"text-xs text-text-muted",children:l?`Validation checks ${s||"Anthropic Compatible"} by verifying the API key.`:`Validation checks ${s||"OpenAI Compatible"} via /models on your base URL.`}),j&&(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:A.accountId,onChange:e=>T({...A,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"})]})]}),v&&(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:S.azureEndpoint,onChange:e=>$({...S,azureEndpoint:e.target.value}),placeholder:"https://your-resource.openai.azure.com"}),(0,a.jsx)(d.pd,{label:"Deployment Name",value:S.deployment,onChange:e=>$({...S,deployment:e.target.value}),placeholder:"gpt-4"}),(0,a.jsx)(d.pd,{label:"API Version",value:S.apiVersion,onChange:e=>$({...S,apiVersion:e.target.value}),placeholder:"2024-10-01-preview"}),(0,a.jsx)(d.pd,{label:"Organization",value:S.organization,onChange:e=>$({...S,organization:e.target.value}),placeholder:"Organization ID"})]})]}),(0,a.jsx)(d.pd,{label:"Priority",type:"number",value:k.priority,onChange:e=>C({...k,priority:Number.parseInt(e.target.value)||1})}),(0,a.jsx)(d.l6,{label:"Proxy Pool",value:k.proxyPoolId,onChange:e=>C({...k,proxyPoolId:e.target.value}),options:[{value:h,label:"None"},...(p||[]).map(e=>({value:e.id,label:e.name}))],placeholder:"None"}),0===(p||[]).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:W,fullWidth:!0,disabled:_||!f&&!k.apiKey||v&&(!S.azureEndpoint||!S.deployment||!S.organization)||j&&!A.accountId,children:_?"Saving...":"Save"}),(0,a.jsx)(d.$n,{onClick:u,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})]})}):null}function k({isOpen:e,node:t,onSave:s,onClose:r,isAnthropic:l}){let[o,n]=(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&&n({name:t.name||"",prefix:t.prefix||"",apiType:t.apiType||"chat",baseUrl:t.baseUrl||(l?"https://api.anthropic.com/v1":"https://api.openai.com/v1")})},[t,l]);let v=async()=>{if(o.name.trim()&&o.prefix.trim()&&o.baseUrl.trim()){p(!0);try{let e={name:o.name,prefix:o.prefix,baseUrl:o.baseUrl};l||(e.apiType=o.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:o.baseUrl,apiKey:m,type:l?"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 ${l?"Anthropic":"OpenAI"} Compatible`,onClose:r,children:(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsx)(d.pd,{label:"Name",value:o.name,onChange:e=>n({...o,name:e.target.value}),placeholder:`${l?"Anthropic":"OpenAI"} Compatible (Prod)`,hint:"Required. A friendly label for this node."}),(0,a.jsx)(d.pd,{label:"Prefix",value:o.prefix,onChange:e=>n({...o,prefix:e.target.value}),placeholder:l?"ac-prod":"oc-prod",hint:"Required. Used as the provider prefix for model IDs."}),!l&&(0,a.jsx)(d.l6,{label:"API Type",options:[{value:"chat",label:"Chat Completions"},{value:"responses",label:"Responses API"}],value:o.apiType,onChange:e=>n({...o,apiType:e.target.value})}),(0,a.jsx)(d.pd,{label:"Base URL",value:o.baseUrl,onChange:e=>n({...o,baseUrl:e.target.value}),placeholder:l?"https://api.anthropic.com/v1":"https://api.openai.com/v1",hint:`Use the base URL (ending in /v1) for your ${l?"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||!o.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:!o.name.trim()||!o.prefix.trim()||!o.baseUrl.trim()||c,children:c?"Saving...":"Save"}),(0,a.jsx)(d.$n,{onClick:r,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})}):null}function C({isOpen:e,providerAlias:t,providerDisplayAlias:s,onSave:r,onClose:l}){var o;let n,[c,p]=(0,i.useState)(""),[m,x]=(0,i.useState)(null),[u,h]=(0,i.useState)(""),[f,g]=(0,i.useState)(!1);(0,i.useEffect)(()=>{e&&(p(""),x(null),h(""),g(!1))},[e]);let y=(o=c.trim(),n=`${t}/`,o.startsWith(n)?o.slice(n.length):o),b=async()=>{if(y){x("testing"),h("");try{let e=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${t}/${y}`})}),s=await e.json();x(s.ok?"ok":"error"),h(s.error||"")}catch(e){x("error"),h(e.message)}}},v=async()=>{if(y&&!f){g(!0);try{await r(y)}finally{g(!1)}}};return(0,a.jsx)(d.aF,{isOpen:e,onClose:l,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:c,onChange:e=>{p(e.target.value),x(null),h("")},onKeyDown:e=>{"Enter"===e.key&&b()},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,{type:"button",variant:"secondary",icon:"science",loading:"testing"===m,onClick:b,disabled:!y||"testing"===m,children:"testing"===m?"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:y||"model-id"})]})]}),"ok"===m&&(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"===m&&(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:u||"Model not reachable"})]}),(0,a.jsxs)("div",{className:"flex gap-2 pt-1",children:[(0,a.jsx)(d.$n,{type:"button",onClick:l,variant:"ghost",fullWidth:!0,size:"sm",children:"Cancel"}),(0,a.jsx)(d.$n,{type:"button",onClick:v,fullWidth:!0,size:"sm",disabled:!y||f,children:f?"Adding...":"Add Model"})]})]})})}function S({isOpen:e,onClose:t,onSuccess:s}){let[r,l]=(0,i.useState)([]),[o,n]=(0,i.useState)(""),[c,p]=(0,i.useState)(!1),[m,x]=(0,i.useState)(null),[u,h]=(0,i.useState)(null),f=()=>{l([]),n(""),x(null),h(null),t()},g=async()=>{p(!0),x(null),h(null);try{let e=await Promise.all(r.map(async e=>({filename:e.name,jsonText:await e.text()}))),t=o.trim()?[{filename:"pasted JSON",jsonText:o.trim()}]:[],a=[...e,...t];if(0===a.length)throw Error("Select JSON files or paste JSON first");let i=await fetch("/api/oauth/codex/import-batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({items:a})}),l=await i.json();if(!i.ok)throw Error(l.error||"Failed to import accounts");x(l),l.imported?.length>0&&s?.()}catch(e){h(e.message||"Failed to import accounts")}finally{p(!1)}},y=m?.imported?.length||0,b=m?.skipped?.length||0;return(0,a.jsx)(d.aF,{isOpen:e,title:"Import Codex Accounts",onClose:f,size:"lg",children:(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsxs)("div",{className:"rounded-lg border border-border bg-surface/50 p-3",children:[(0,a.jsx)("label",{className:"mb-2 block text-sm font-medium",children:"JSON files"}),(0,a.jsx)("input",{type:"file",accept:".json,application/json",multiple:!0,onChange:e=>l(Array.from(e.target.files||[])),className:"block w-full text-sm text-text-muted file:mr-3 file:rounded-md file:border-0 file:bg-primary file:px-3 file:py-1.5 file:text-sm file:font-medium file:text-white hover:file:bg-primary/90"}),r.length>0&&(0,a.jsx)("div",{className:"mt-2 flex flex-wrap gap-1.5",children:r.map(e=>(0,a.jsx)("span",{className:"rounded bg-primary/10 px-2 py-0.5 text-xs text-primary",children:e.name},`${e.name}-${e.size}`))})]}),(0,a.jsxs)("div",{children:[(0,a.jsx)("label",{className:"mb-2 block text-sm font-medium",children:"Paste JSON"}),(0,a.jsx)("textarea",{value:o,onChange:e=>n(e.target.value),placeholder:'[{ "type": "codex", "access_token": "...", "refresh_token": "..." }]',className:"h-36 w-full resize-none rounded-md border border-black/10 bg-white px-3 py-2 font-mono text-xs text-text-main shadow-inner transition-all placeholder-text-muted/60 focus:border-primary/50 focus:outline-none focus:ring-1 focus:ring-primary/30 dark:border-white/10 dark:bg-white/5"})]}),(0,a.jsx)("div",{className:"rounded-lg border border-border bg-background/60 px-3 py-2 text-xs text-text-muted",children:"Auto-detects Codex Session JSON, CLI Proxy API Auth JSON, and Sub2API JSON."}),u&&(0,a.jsx)("div",{className:"rounded-lg border border-red-500/30 bg-red-500/10 px-3 py-2 text-sm text-red-600",children:u}),m&&(0,a.jsxs)("div",{className:"rounded-lg border border-border bg-surface/40 p-3",children:[(0,a.jsxs)("div",{className:"mb-2 flex flex-wrap items-center gap-2 text-sm",children:[(0,a.jsxs)("span",{className:"font-medium text-green-600",children:[y," imported"]}),b>0&&(0,a.jsxs)("span",{className:"text-text-muted",children:[b," skipped"]})]}),m.imported?.length>0&&(0,a.jsx)("div",{className:"max-h-32 overflow-auto rounded border border-border/70",children:m.imported.map(e=>(0,a.jsxs)("div",{className:"flex items-center justify-between gap-2 border-b border-border/70 px-2 py-1.5 last:border-b-0",children:[(0,a.jsx)("span",{className:"min-w-0 truncate text-xs",children:e.email||e.displayName||e.name||e.id}),(0,a.jsx)("span",{className:"shrink-0 text-xs text-text-muted",children:e.sourceFormat})]},e.id))}),m.skipped?.length>0&&(0,a.jsx)("div",{className:"mt-2 max-h-28 overflow-auto rounded border border-border/70",children:m.skipped.map((e,t)=>(0,a.jsxs)("div",{className:"border-b border-border/70 px-2 py-1.5 text-xs last:border-b-0",children:[(0,a.jsx)("span",{className:"font-medium",children:e.filename}),(0,a.jsxs)("span",{className:"text-text-muted",children:[" \xb7 ",e.reason]})]},`${e.filename}-${t}`))})]}),(0,a.jsxs)("div",{className:"flex gap-2",children:[(0,a.jsx)(d.$n,{onClick:g,loading:c,disabled:c||!r.length&&!o.trim(),fullWidth:!0,children:"Import"}),(0,a.jsx)(d.$n,{onClick:f,variant:"ghost",fullWidth:!0,children:"Close"})]})]})})}function $(){let e,t=(0,r.useParams)(),s=(0,r.useRouter)(),l=t.id,[x,h]=(0,i.useState)([]),[f,y]=(0,i.useState)(!0),[v,N]=(0,i.useState)(null),[$,A]=(0,i.useState)([]),[T,O]=(0,i.useState)(!1),[P,I]=(0,i.useState)(!1),[E,_]=(0,i.useState)(!1),[R,U]=(0,i.useState)(!1),[D,z]=(0,i.useState)(null),[q,M]=(0,i.useState)(!1),[J,F]=(0,i.useState)(!1),[K,L]=(0,i.useState)(!1),[W,H]=(0,i.useState)(!1),[V,B]=(0,i.useState)(null),[G,Q]=(0,i.useState)({}),[Z,X]=(0,i.useState)(!1),[Y,ee]=(0,i.useState)({}),[et,es]=(0,i.useState)(""),[ea,ei]=(0,i.useState)(null),[er,el]=(0,i.useState)(!1),[eo,en]=(0,i.useState)([]),[ed,ec]=(0,i.useState)("__none__"),[ep,em]=(0,i.useState)(!1),[ex,eu]=(0,i.useState)(null),[eh,ef]=(0,i.useState)(""),[eg,ey]=(0,i.useState)("auto"),[eb,ev]=(0,i.useState)(!1),[ej,eN]=(0,i.useState)(!1),[ew,ek]=(0,i.useState)("super_admin"),[eC,eS]=(0,i.useState)([]),[e$,eA]=(0,i.useState)([]),[eT,eO]=(0,i.useState)([]),{copied:eP,copy:eI}=(0,m.C)(),eE=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[l]||c.fg[l]||c.IS[l]||c.nJ[l]||c.br[l],e_=!!c.zN[l]||!!c.IS[l],eR=!!c.IS[l]?.noAuth,eU=(0,p.KC)(l),eD=(0,c.wG)(l),ez=(0,c.mq)(l),eq=(0,c.gb)(l),eM=ez||eq,eJ=c.Q2[l]?.thinkingConfig||null,eF=eM?l:eD,eK=eM?v?.prefix||l:eD,eL="codex"===l,eW=(eJ?.options||[]).map(e=>({value:e,label:"auto"===e?"codex"===l?"Auto (Medium)":"Auto":"xhigh"===e?"XHigh":e.charAt(0).toUpperCase()+e.slice(1)})),eH=(0,i.useCallback)(async()=>{try{let e=await fetch(`/api/models/disabled?providerAlias=${encodeURIComponent(eF)}`,{cache:"no-store"}),t=await e.json();e.ok&&eO(t.ids||[])}catch(e){console.log("Error fetching disabled models:",e)}},[eF]),eV=async e=>{try{(await fetch("/api/models/disabled",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerAlias:eF,ids:[e]})})).ok&&await eH()}catch(e){console.log("Error disabling model:",e)}},eB=async e=>{try{(await fetch(`/api/models/disabled?providerAlias=${encodeURIComponent(eF)}&id=${encodeURIComponent(e)}`,{method:"DELETE"})).ok&&await eH()}catch(e){console.log("Error enabling model:",e)}},eG=async e=>{if(e.length&&confirm(`Disable all ${e.length} model(s)?`))try{(await fetch("/api/models/disabled",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerAlias:eF,ids:e})})).ok&&await eH()}catch(e){console.log("Error disabling all models:",e)}},eQ=async()=>{try{(await fetch(`/api/models/disabled?providerAlias=${encodeURIComponent(eF)}`,{method:"DELETE"})).ok&&await eH()}catch(e){console.log("Error enabling all models:",e)}},eZ=(0,i.useCallback)(async()=>{try{let e=await fetch("/api/models/alias"),t=await e.json();e.ok&&Q(t.aliases||{})}catch(e){console.log("Error fetching aliases:",e)}},[]);(0,i.useEffect)(()=>{"kilocode"===l&&fetch("/api/providers/kilo/free-models").then(e=>e.json()).then(e=>{e.models?.length&&eA(e.models)}).catch(()=>{})},[l]);let eX=(0,i.useCallback)(async()=>{try{let[e,t,s,a,i]=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"}),fetch("/api/auth/me",{cache:"no-store"})]),r=await e.json(),o=await t.json(),n=await s.json(),d=a.ok?await a.json():{},c=i.ok?await i.json():{};if(e.ok){let e=(r.connections||[]).filter(e=>e.provider===l);h(e)}s.ok&&A(n.proxyPools||[]);let p=(d.providerStrategies||{})[l]||{};eu(p.fallbackStrategy||null),ef(null!=p.stickyRoundRobinLimit?String(p.stickyRoundRobinLimit):"1");let m=(d.providerThinking||{})[l]||{},x=c.providerThinkingScopeKey||c.userId||"super_admin",u="sub_user"===c.role?(c.providerThinking||{})[l]||{}:(d.userProviderThinking||{})[x]?.[l]||{};if(ey(m.mode||"auto"),ev(!0===m.fastMode),ek(x),eN(Object.prototype.hasOwnProperty.call(u,"fastMode")?!0===u.fastMode:!0===m.fastMode),t.ok){let e=(o.nodes||[]).find(e=>e.id===l)||null;if(!e&&eM)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===l)||null))break}N(e)}}catch(e){console.log("Error fetching connections:",e)}finally{y(!1)}},[l,eM]),eY=async e=>{try{let t=await fetch(`/api/provider-nodes/${l}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)}),s=await t.json();t.ok&&(N(s.node),await eX(),L(!1))}catch(e){console.log("Error updating provider node:",e)}},e0=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 r={...a};0===Object.keys(i).length?delete r[l]:r[l]=i,await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerStrategies:r})})}catch(e){console.log("Error saving provider strategy:",e)}},e1=async(e,t=eb)=>{try{let s=await fetch("/api/settings",{cache:"no-store"}),a={...(s.ok?await s.json():{}).providerThinking||{}},i={};e&&"auto"!==e&&(i.mode=e),"codex"===l&&!0===t&&(i.fastMode=!0),0===Object.keys(i).length?delete a[l]:a[l]=i,await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({providerThinking:a})})}catch(e){console.log("Error saving thinking config:",e)}},e2=async e=>{try{let t=await fetch("/api/settings",{cache:"no-store"}),s=(t.ok?await t.json():{}).userProviderThinking||{},a=ew||"super_admin",i=s[a]||{},r=i[l]||{},o={...s,[a]:{...i,[l]:{...r,fastMode:e}}};await fetch("/api/settings",{method:"PATCH",headers:{"Content-Type":"application/json"},body:JSON.stringify({userProviderThinking:o})})}catch(e){console.log("Error saving account fast mode:",e)}};(0,i.useEffect)(()=>{(async()=>{await Promise.all([eX(),eZ(),eH()])})()},[eX,eZ,eH]),(0,i.useEffect)(()=>{let e=(c.zN[l]||c.fg[l]||c.IS[l]||c.nJ[l])?.modelsFetcher;e&&u(e).then(eS)},[l]);let e5=async(e,t,s=eD)=>{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 eZ();else{let t=await e.json();alert(t.error||"Failed to set alias")}}catch(e){console.log("Error setting alias:",e)}},e3=async e=>{try{(await fetch(`/api/models/alias?alias=${encodeURIComponent(e)}`,{method:"DELETE"})).ok&&await eZ()}catch(e){console.log("Error deleting alias:",e)}},e4=async e=>{if(confirm("Delete this connection?"))try{(await fetch(`/api/providers/${e}`,{method:"DELETE"})).ok&&h(x.filter(t=>t.id!==e))}catch(e){console.log("Error deleting connection:",e)}},e6=()=>{eX(),O(!1)},e7=async()=>{if(!R){U(!0),z(null);try{let e=await fetch("/api/oauth/codex/refresh-all",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({})}),t=await e.json();if(!e.ok&&!t?.refreshed?.length)throw Error(t.error||"Failed to refresh Codex tokens");z(t),await eX()}catch(e){z({error:e.message,refreshed:[],failed:[],skipped:[]})}finally{U(!1)}}},e8=async e=>{try{(await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:l,...e})})).ok&&(await eX(),M(!1))}catch(e){console.log("Error saving connection:",e)}},e9=async e=>{try{(await fetch(`/api/providers/${V.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)})).ok&&(await eX(),F(!1))}catch(e){console.log("Error updating connection:",e)}},te=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)}},tt=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 eX()}},ts=(0,i.useMemo)(()=>new Set(x.map(e=>e.id)),[x]),ta=(0,i.useMemo)(()=>eo.filter(e=>ts.has(e)),[eo,ts]),ti=x.filter(e=>ta.includes(e.id));x.length>0&&(ta.length,x.length);let tr=(()=>{if(0===ti.length)return"";let e=new Set(ti.map(e=>e.providerSpecificData?.proxyPoolId||"__none__"));if(1===e.size){let t=[...e][0];if("__none__"===t)return"All selected currently unbound";let s=$.find(e=>e.id===t);return`All selected currently bound to ${s?.name||t}`}return"Selected connections have mixed proxy bindings"})(),tl=()=>{ep||H(!1)},to=async()=>{if(0===ta.length)return;let e="__none__"===ed?null:ed;em(!0);try{let t=[];for(let s of ta)try{let a=await fetch(`/api/providers/${s}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({proxyPoolId:e})});t.push(a.ok)}catch(e){console.log("Error applying bulk proxy pool for",s,e),t.push(!1)}let s=t.filter(e=>!e).length;s>0&&alert(`Updated with ${s} failed request(s).`),await eX(),en([]),ec("__none__"),H(!1)}catch(e){console.log("Error applying bulk proxy pool:",e)}finally{em(!1)}},tn=(0,a.jsx)("div",{className:"flex min-w-0 flex-col divide-y divide-black/3 dark:divide-white/3",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:$,isOAuth:e_,isFirst:0===t,isLast:t===x.length-1,onMoveUp:()=>tt(t,t-1),onMoveDown:()=>tt(t,t+1),onToggleActive:t=>te(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:()=>{B(e),F(!0)},onDelete:()=>e4(e.id)})})},e.id))}),td=[{value:"__none__",label:"None"},...$.map(e=>({value:e.id,label:e.name}))],tc=0===ta.length?"Select one or more connections, then click Proxy Action.":tr,tp=ta.length>0&&!ep,tm=(0,a.jsx)(d.aF,{isOpen:W,onClose:tl,title:`Proxy Action (${ta.length} selected)`,children:(0,a.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,a.jsx)(d.l6,{label:"Proxy Pool",value:ed,onChange:e=>ec(e.target.value),options:td,placeholder:"None"}),(0,a.jsx)("p",{className:"text-xs text-text-muted",children:tc}),(0,a.jsx)("p",{className:"text-xs text-text-muted",children:"Selecting None will unbind selected connections from proxy pool."}),(0,a.jsxs)("div",{className:"flex flex-col gap-2 sm:flex-row",children:[(0,a.jsx)(d.$n,{onClick:to,fullWidth:!0,disabled:!tp,children:ep?"Applying...":"Apply"}),(0,a.jsx)(d.$n,{onClick:tl,variant:"ghost",fullWidth:!0,disabled:ep,children:"Cancel"})]})]})}),tx=async e=>{if(!ea){ei(e);try{let t=await fetch("/api/models/test",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({model:`${eF}/${e}`})}),s=await t.json();ee(t=>({...t,[e]:s.ok?"ok":"error"})),es(s.ok?"":s.error||"Model not reachable")}catch{ee(t=>({...t,[e]:"error"})),es("Network error")}finally{ei(null)}}};return f?(0,a.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,a.jsx)(d.Qv,{}),(0,a.jsx)(d.Qv,{})]}):eE?(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)(o(),{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:`${eE.color}15`},children:Z?(0,a.jsx)("span",{className:"text-sm font-bold",style:{color:eE.color},children:eE.textIcon||eE.id.slice(0,2).toUpperCase()}):(0,a.jsx)(n.default,{src:ez&&eE.apiType?"responses"===eE.apiType?"/providers/oai-r.png":"/providers/oai-cc.png":eq?"/providers/anthropic-m.png":`/providers/${eE.id}.png`,alt:eE.name,width:48,height:48,className:"max-h-12 max-w-12 rounded-lg object-contain",sizes:"48px",onError:()=>X(!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:eE.name}),(eE.notice?.apiKeyUrl||eE.notice?.signupUrl||eE.website)&&(0,a.jsxs)("a",{href:eE.notice?.apiKeyUrl||eE.notice?.signupUrl||eE.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"}),eE.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"]})]})]})]}),eE.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:eE.deprecationNotice})]}),eE.notice?.text&&!eE.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:eE.notice.text}),eE.notice.apiKeyUrl&&(0,a.jsx)("a",{href:eE.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 →"})]}),eM&&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:eq?"Anthropic Compatible Details":"OpenAI Compatible Details"}),(0,a.jsxs)("p",{className:"break-all text-sm text-text-muted",children:[eq?"Messages API":"responses"===v.apiType?"Responses API":"Chat Completions"," \xb7 ",(v.baseUrl||"").replace(/\/$/,""),"/",eq?"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:()=>M(!0),disabled:x.length>0,className:"w-full sm:w-auto",children:"Add"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"edit",onClick:()=>L(!0),className:"w-full sm:w-auto",children:"Edit"}),(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"delete",onClick:async()=>{if(confirm(`Delete this ${eq?"Anthropic":"OpenAI"} Compatible node?`))try{(await fetch(`/api/provider-nodes/${l}`,{method:"DELETE"})).ok&&s.push("/dashboard/providers")}catch(e){console.log("Error deleting provider node:",e)}},className:"w-full sm:w-auto",children:"Delete"})]})]})}),eR?(0,a.jsx)(d.gw,{providerId:l}):(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:["codex"===l&&(0,a.jsxs)("div",{className:"flex flex-wrap items-center gap-3",children:[(0,a.jsxs)("label",{className:"flex items-center gap-2",children:[(0,a.jsx)("span",{className:"text-xs font-medium text-text-muted whitespace-nowrap",children:"Global Fast"}),(0,a.jsx)(d.lM,{checked:eb,onChange:e=>{ev(e),e1(eg,e)}})]}),(0,a.jsxs)("label",{className:"flex items-center gap-2",children:[(0,a.jsx)("span",{className:"text-xs font-medium text-text-muted whitespace-nowrap",children:"My Fast"}),(0,a.jsx)(d.lM,{checked:ej,onChange:e=>{eN(e),e2(e)}})]})]}),eJ&&(0,a.jsxs)("div",{className:"flex items-center gap-2",children:[(0,a.jsx)("label",{htmlFor:"provider-default-reasoning",className:"text-xs font-medium text-text-muted whitespace-nowrap",children:"Default Reasoning"}),(0,a.jsxs)("div",{className:"relative",children:[(0,a.jsx)("select",{id:"provider-default-reasoning",value:eg,onChange:e=>{var t;ey(t=e.target.value),e1(t)},disabled:f,className:"h-6 w-28 appearance-none rounded-full border border-border/60 bg-surface-2 pl-3 pr-7 text-xs font-medium text-text-main transition-colors focus:border-primary/50 focus:outline-none focus:ring-2 focus:ring-primary/20 disabled:cursor-not-allowed disabled:opacity-50",children:eW.map(e=>(0,a.jsx)("option",{value:e.value,children:e.label},e.value))}),(0,a.jsx)("span",{className:"material-symbols-outlined pointer-events-none absolute right-2 top-1/2 -translate-y-1/2 text-[16px] text-text-muted",children:"expand_more"})]})]}),(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"===ex,onChange:e=>{let t=e?"round-robin":null,s=e?eh||"1":eh;e&&!eh&&ef("1"),eu(t),e0(t,s)}}),"round-robin"===ex&&(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:eh,onChange:e=>{var t;ef(t=e.target.value),e0("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===x.length?(0,a.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between",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:e_?"lock":"key"})}),(0,a.jsx)("p",{className:"text-sm text-text-muted",children:"No connections yet"})]}),!eM&&(0,a.jsxs)("div",{className:"flex gap-2",children:["iflow"===l&&(0,a.jsx)(d.$n,{size:"sm",icon:"cookie",variant:"secondary",onClick:()=>I(!0),children:"Cookie"}),(0,a.jsx)(d.$n,{size:"sm",icon:"add",onClick:()=>e_?O(!0):M(!0),children:"iflow"===l?"OAuth":"Add Connection"}),"codex"===l&&(0,a.jsx)(d.$n,{size:"sm",icon:"upload_file",variant:"secondary",onClick:()=>_(!0),children:"Batch Import"}),"codex"===l&&(0,a.jsx)(d.$n,{size:"sm",icon:"sync",variant:"secondary",onClick:e7,loading:R,children:"Refresh Tokens"})]})]}):(0,a.jsxs)(a.Fragment,{children:[tn,!eM&&(0,a.jsxs)("div",{className:"mt-4 grid grid-cols-1 gap-2 sm:flex",children:["iflow"===l&&(0,a.jsx)(d.$n,{size:"sm",icon:"cookie",variant:"secondary",onClick:()=>I(!0),title:"Add connection using browser cookie",className:"w-full sm:w-auto",children:"Cookie"}),(0,a.jsx)(d.$n,{size:"sm",icon:"add",onClick:()=>e_?O(!0):M(!0),className:"w-full sm:w-auto",children:"Add"}),"codex"===l&&(0,a.jsx)(d.$n,{size:"sm",icon:"upload_file",variant:"secondary",onClick:()=>_(!0),className:"w-full sm:w-auto",children:"Batch Import"}),"codex"===l&&(0,a.jsx)(d.$n,{size:"sm",icon:"sync",variant:"secondary",onClick:e7,loading:R,className:"w-full sm:w-auto",children:"Refresh Tokens"})]})]}),"codex"===l&&D&&(0,a.jsx)("div",{className:`mt-4 rounded-lg border px-3 py-2 text-sm ${D.error?"border-red-500/30 bg-red-500/10 text-red-600":"border-green-500/30 bg-green-500/10 text-green-700 dark:text-green-300"}`,children:D.error?D.error:`Token refresh complete: ${D.refreshed?.length||0} refreshed, ${D.failed?.length||0} failed, ${D.skipped?.length||0} skipped.`})]}),(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"}),!eM&&(e=[...eU,...e$.filter(e=>!eU.some(t=>t.id===e.id))].filter(e=>!e.type||"llm"===e.type).map(e=>e.id).filter(e=>!eT.includes(e)),(0,a.jsxs)("div",{className:"flex gap-2",children:[eT.length>0&&(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"restart_alt",onClick:eQ,children:"Active All"}),e.length>0&&(0,a.jsx)(d.$n,{size:"sm",variant:"secondary",icon:"block",onClick:()=>eG(e),children:"Disable All"})]}))]}),!!et&&(0,a.jsx)("p",{className:"text-xs text-red-500 mb-3 wrap-break-word",children:et}),(()=>{let e,t,s;if(eM)return(0,a.jsx)(b,{providerStorageAlias:eF,providerDisplayAlias:eK,modelAliases:G,copied:eP,onCopy:eI,onSetAlias:e5,onDeleteAlias:e3,connections:x,isAnthropic:eq});let i=[...eU,...e$.filter(e=>!eU.some(t=>t.id===e.id))].filter(e=>!e.type||"llm"===e.type),r=new Set(eT),o=i.filter(e=>!r.has(e.id)),n=i.filter(e=>r.has(e.id)),d=Object.entries(G).filter(([e,t])=>{let s=`${eF}/`;if(!t.startsWith(s))return!1;let a=t.slice(s.length);return eE.passthroughModels?!eU.some(e=>e.id===a):!eU.some(e=>e.id===a)&&e===a}).map(([e,t])=>({id:t.slice(`${eF}/`.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:`${eK}/${e.id}`,displayModel:eL?e.id:`${eK}/${e.id}`,alias:e.alias,copied:eP,onCopy:eI,onSetAlias:()=>{},onDeleteAlias:()=>e3(e.alias),testStatus:Y[e.id],onTest:x.length>0||eR?()=>tx(e.id):void 0,isTesting:ea===e.id,isCustom:!0,isFree:!1},e.id)),o.map(e=>{let t=`${eF}/${e.id}`,s=`${l}/${e.id}`,i=Object.entries(G).find(([,e])=>e===t||e===s)?.[0];return(0,a.jsx)(g,{model:e,fullModel:`${eK}/${e.id}`,displayModel:eL?e.id:`${eK}/${e.id}`,alias:i,copied:eP,onCopy:eI,onSetAlias:t=>e5(e.id,t,eF),onDeleteAlias:()=>e3(i),testStatus:Y[e.id],onTest:x.length>0||eR?()=>tx(e.id):void 0,isTesting:ea===e.id,isFree:e.isFree,onDisable:()=>eV(e.id)},e.id)}),(0,a.jsxs)("button",{onClick:()=>el(!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"]}),eC.length>0&&(e=new Set(Object.values(G)),t=new Set(eU.map(e=>e.id)),0===(s=eC.filter(s=>!e.has(`${eF}/${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 e5(e.id,t,eF)},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))})]})),n.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 (",n.length,"):"]}),(0,a.jsx)("div",{className:"flex flex-wrap gap-2",children:n.map(e=>(0,a.jsxs)("button",{onClick:()=>eB(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))})]})]})})()]}),tm,"kiro"===l?(0,a.jsx)(d.Mh,{isOpen:T,providerInfo:eE,onSuccess:e6,onClose:()=>O(!1)}):"cursor"===l?(0,a.jsx)(d.G9,{isOpen:T,onSuccess:e6,onClose:()=>O(!1)}):"gitlab"===l?(0,a.jsx)(d.vj,{isOpen:T,providerInfo:eE,onSuccess:e6,onClose:()=>O(!1)}):(0,a.jsx)(d.LF,{isOpen:T,provider:l,providerInfo:eE,onSuccess:e6,onClose:()=>O(!1)}),"iflow"===l&&(0,a.jsx)(d.vE,{isOpen:P,onSuccess:()=>{eX(),I(!1)},onClose:()=>I(!1)}),"codex"===l&&(0,a.jsx)(S,{isOpen:E,onSuccess:eX,onClose:()=>_(!1)}),(0,a.jsx)(w,{isOpen:q,provider:l,providerName:eE.name,isCompatible:eM,isAnthropic:eq,authType:eE?.authType,authHint:eE?.authHint,website:eE?.website,proxyPools:$,onSave:e8,onClose:()=>M(!1)}),(0,a.jsx)(d.wI,{isOpen:J,connection:V,proxyPools:$,onSave:e9,onClose:()=>F(!1)}),eM&&(0,a.jsx)(k,{isOpen:K,node:v,onSave:eY,onClose:()=>L(!1),isAnthropic:eq}),!eM&&(0,a.jsx)(C,{isOpen:er,providerAlias:eF,providerDisplayAlias:eK,onSave:async e=>{let t=eE?.passthroughModels?e.split("/").pop():e;await e5(e,t,eF),el(!1)},onClose:()=>el(!1)})]}):(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)(o(),{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})),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},S.propTypes={isOpen:f().bool.isRequired,onClose:f().func.isRequired,onSuccess:f().func}},53655:(e,t,s)=>{Promise.resolve().then(s.bind(s,7570))}},e=>{e.O(0,[2574,3862,1051,5772,1321,5497,8441,3794,7358],()=>e(e.s=53655)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[8460],{12572:(e,t,a)=>{"use strict";a.r(t),a.d(t,{default:()=>N});var s=a(95155),r=a(12115),l=a(14051),i=a.n(l),n=a(35497),o=a(57250),d=a(90620),c=a(52679),p=a(98500),m=a.n(p),x=a(65921),u=a(38003);let h={available:{icon:"check_circle",color:"#22c55e",label:"Available"},cooldown:{icon:"schedule",color:"#f59e0b",label:"Cooldown"},unavailable:{icon:"error",color:"#ef4444",label:"Unavailable"},unknown:{icon:"help",color:"#6b7280",label:"Unknown"}};function f(){let[e,t]=(0,r.useState)(null),[a,l]=(0,r.useState)(!0),[i,o]=(0,r.useState)(!1),[d,c]=(0,r.useState)(null),p=(0,r.useRef)(null),m=(0,x.i)(),u=(0,r.useCallback)(async()=>{try{let e=await fetch("/api/models/availability");if(e.ok){let a=await e.json();t(a)}}catch{}finally{l(!1)}},[]);(0,r.useEffect)(()=>{u();let e=setInterval(u,3e4);return()=>clearInterval(e)},[u]),(0,r.useEffect)(()=>{let e=e=>{p.current&&!p.current.contains(e.target)&&o(!1)};return i&&document.addEventListener("mousedown",e),()=>document.removeEventListener("mousedown",e)},[i]);let f=async(e,t)=>{c(`${e}:${t}`);try{(await fetch("/api/models/availability",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({action:"clearCooldown",provider:e,model:t})})).ok?(m.success(`Cooldown cleared for ${t}`),await u()):m.error("Failed to clear cooldown")}catch{m.error("Failed to clear cooldown")}finally{c(null)}};if(a)return null;let b=e?.models||[],g=0===(e?.unavailableCount||b.filter(e=>"available"!==e.status).length),v={};return b.forEach(e=>{if("available"===e.status)return;let t=e.provider||"unknown";v[t]||(v[t]=[]),v[t].push(e)}),(0,s.jsx)("div",{className:"relative",ref:p,children:i&&(0,s.jsxs)("div",{className:"absolute top-full right-0 mt-2 w-80 bg-surface border border-border rounded-xl shadow-2xl z-50 overflow-hidden",children:[(0,s.jsxs)("div",{className:"flex items-center justify-between px-4 py-3 border-b border-border bg-bg",children:[(0,s.jsxs)("div",{className:"flex items-center gap-2",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[16px]",style:{color:g?"#22c55e":"#f59e0b"},children:g?"verified":"warning"}),(0,s.jsx)("span",{className:"text-sm font-semibold text-text-main",children:"Model Status"})]}),(0,s.jsx)("button",{onClick:u,className:"p-1 rounded-lg hover:bg-surface text-text-muted hover:text-text-main transition-colors",title:"Refresh",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-[14px]",children:"refresh"})})]}),(0,s.jsx)("div",{className:"px-4 py-3 max-h-60 overflow-y-auto",children:g?(0,s.jsx)("p",{className:"text-sm text-text-muted text-center py-2",children:"All models are responding normally."}):(0,s.jsx)("div",{className:"flex flex-col gap-2.5",children:Object.entries(v).map(([e,t])=>(0,s.jsxs)("div",{children:[(0,s.jsx)("p",{className:"text-xs font-semibold text-text-main mb-1.5 capitalize",children:e}),(0,s.jsx)("div",{className:"flex flex-col gap-1",children:t.map(e=>{let t=h[e.status]||h.unknown,a=d===`${e.provider}:${e.model}`;return(0,s.jsxs)("div",{className:"flex items-center justify-between px-2.5 py-1.5 rounded-lg bg-surface/30",children:[(0,s.jsxs)("div",{className:"flex items-center gap-1.5 min-w-0",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[14px] shrink-0",style:{color:t.color},children:t.icon}),(0,s.jsx)("span",{className:"font-mono text-xs text-text-main truncate",children:e.model})]}),"cooldown"===e.status&&(0,s.jsx)(n.$n,{size:"sm",variant:"ghost",onClick:()=>f(e.provider,e.model),disabled:a,className:"text-[10px] px-1.5! py-0.5! ml-2",children:a?"...":"Clear"})]},`${e.provider}-${e.model}`)})})]},e))})})]})})}var b=a(68828);let g=[{value:"openai-compatible",label:"OpenAI Compatible"},{value:"anthropic-compatible",label:"Anthropic Compatible"}],v=[{value:"chat",label:"Chat Completions"},{value:"responses",label:"Responses API"}];function y({isOpen:e,onClose:t,onImported:a,notify:l}){let[i,o]=(0,r.useState)(""),[d,c]=(0,r.useState)(null),[p,m]=(0,r.useState)(!1),[x,u]=(0,r.useState)(""),[h,f]=(0,r.useState)({type:"openai-compatible",apiType:"chat",name:"",prefix:"",baseUrl:"",connectionName:"Imported Key",apiKey:"",modelId:""}),j=()=>{o(""),c(null),m(!1),u(""),f({type:"openai-compatible",apiType:"chat",name:"",prefix:"",baseUrl:"",connectionName:"Imported Key",apiKey:"",modelId:""}),t()},N=async()=>{if(h.name.trim()&&h.prefix.trim()&&h.baseUrl.trim()){m(!0);try{let e={name:h.name.trim(),prefix:h.prefix.trim(),baseUrl:h.baseUrl.trim(),type:h.type};"openai-compatible"===h.type&&(e.apiType=h.apiType);let t=await fetch("/api/provider-nodes",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e)}),s=await t.json();if(!t.ok)throw Error(s.error||"Failed to create compatible provider");let r=null;if(h.apiKey.trim()){let e=await fetch("/api/providers",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({provider:s.node.id,apiKey:h.apiKey.trim(),name:h.connectionName.trim()||"Imported Key",testStatus:"unknown"})}),t=await e.json();if(!e.ok)throw Error(t.error||"Compatible provider created, but API key import failed");r=t.connection}l.success("Compatible provider imported from cURL"),a?.({node:s.node,connection:r}),j()}catch(e){l.error(e.message||"Failed to import curl")}finally{m(!1)}}};return(0,s.jsx)(n.aF,{isOpen:e,title:"Import Compatible Provider From cURL",onClose:j,children:(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsxs)("div",{className:"flex flex-col gap-2",children:[(0,s.jsx)("label",{className:"text-sm font-medium text-text-main",children:"Paste cURL"}),(0,s.jsx)("textarea",{value:i,onChange:e=>o(e.target.value),placeholder:'curl --request POST --url https://api.example.com/v1/chat/completions --header \'Authorization: Bearer sk-xxx\' --header \'Content-Type: application/json\' --data \'{"model":"gpt-4o-mini","messages":[{"role":"user","content":"Hello"}]}\'',className:"min-h-40 w-full rounded-lg border border-border bg-surface px-3 py-2 text-sm focus:outline-none focus:ring-1 focus:ring-primary/50"}),(0,s.jsxs)("div",{className:"flex flex-col gap-2 sm:flex-row sm:items-center sm:justify-between",children:[(0,s.jsx)("p",{className:"text-xs text-text-muted",children:"Supports full endpoint URLs like `/v1/chat/completions`, `/responses`, or `/v1/messages`."}),(0,s.jsx)(n.$n,{onClick:()=>{try{let e=(0,b.Sq)(i);c(e),u(""),f({type:e.type,apiType:e.apiType||"chat",name:e.defaultName,prefix:e.defaultPrefix,baseUrl:e.baseUrl,connectionName:e.defaultConnectionName,apiKey:e.apiKey,modelId:e.modelId})}catch(e){c(null),u(e.message||"Failed to parse curl")}},variant:"secondary",className:"w-full sm:w-auto",children:"Parse cURL"})]}),x&&(0,s.jsx)("p",{className:"text-sm text-red-500",children:x})]}),d&&(0,s.jsxs)(s.Fragment,{children:[(0,s.jsxs)("div",{className:"flex flex-wrap gap-2",children:[(0,s.jsx)(n.Ex,{variant:"success",children:"Detected"}),(0,s.jsx)(n.Ex,{variant:"default",children:"anthropic-compatible"===h.type?"Anthropic Compatible":"OpenAI Compatible"}),"openai-compatible"===h.type&&(0,s.jsx)(n.Ex,{variant:"default",children:"responses"===h.apiType?"Responses API":"Chat Completions"})]}),(0,s.jsx)(n.l6,{label:"Provider Type",value:h.type,options:g,onChange:e=>f(t=>({...t,type:e.target.value,apiType:"anthropic-compatible"===e.target.value?"chat":t.apiType}))}),"openai-compatible"===h.type&&(0,s.jsx)(n.l6,{label:"API Type",value:h.apiType,options:v,onChange:e=>f(t=>({...t,apiType:e.target.value}))}),(0,s.jsx)(n.pd,{label:"Provider Name",value:h.name,onChange:e=>f(t=>({...t,name:e.target.value})),placeholder:"Compatible Provider"}),(0,s.jsx)(n.pd,{label:"Prefix",value:h.prefix,onChange:e=>f(t=>({...t,prefix:e.target.value})),placeholder:"oc-example"}),(0,s.jsx)(n.pd,{label:"Base URL",value:h.baseUrl,onChange:e=>f(t=>({...t,baseUrl:e.target.value})),placeholder:"https://api.example.com/v1"}),(0,s.jsx)(n.pd,{label:"Connection Name",value:h.connectionName,onChange:e=>f(t=>({...t,connectionName:e.target.value})),placeholder:"Imported Key"}),(0,s.jsx)(n.pd,{label:"API Key",type:"password",value:h.apiKey,onChange:e=>f(t=>({...t,apiKey:e.target.value})),placeholder:"Bearer token from curl"}),(0,s.jsx)(n.pd,{label:"Detected Model",value:h.modelId,onChange:e=>f(t=>({...t,modelId:e.target.value})),placeholder:"Optional"})]}),(0,s.jsxs)("div",{className:"flex gap-2",children:[(0,s.jsx)(n.$n,{onClick:N,fullWidth:!0,disabled:!d||!h.name.trim()||!h.prefix.trim()||!h.baseUrl.trim()||p,children:p?"Importing...":"Create Provider"}),(0,s.jsx)(n.$n,{onClick:j,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})})}function j(e,t,a){let r=[];if(e>0&&r.push((0,s.jsxs)(n.Ex,{variant:"success",size:"sm",dot:!0,children:[e," Connected"]},"connected")),t>0){let e=a?`${t} Error (${a})`:`${t} Error`;r.push((0,s.jsx)(n.Ex,{variant:"error",size:"sm",dot:!0,children:e},"error"))}return 0===r.length?(0,s.jsx)("span",{className:"text-text-muted",children:"No connections"}):r}function N(){let e,t,[a,l]=(0,r.useState)([]),[i,o]=(0,r.useState)([]),[p,m]=(0,r.useState)(!0),[h,b]=(0,r.useState)(!1),[g,v]=(0,r.useState)(!1),[j,N]=(0,r.useState)(!1),[A,U]=(0,r.useState)(!1),[S,R]=(0,r.useState)(null),[O,P]=(0,r.useState)(null),E=(0,x.i)(),$=(0,u.C)(e=>e.query),q=(0,u.C)(e=>e.register),_=(0,u.C)(e=>e.unregister);(0,r.useEffect)(()=>(q("Search providers..."),()=>_()),[q,_]);let z=e=>!$.trim()||e.toLowerCase().includes($.trim().toLowerCase());(0,r.useEffect)(()=>{let e=async()=>{try{let[e,t]=await Promise.all([fetch("/api/providers"),fetch("/api/provider-nodes")]),a=await e.json(),s=await t.json();e.ok&&l(a.connections||[]),t.ok&&o(s.nodes||[])}catch(e){console.log("Error fetching data:",e)}finally{m(!1)}};fetch("/api/auth/me").then(e=>e.json()).then(e=>{"sub_user"===e.role&&(window.location.href="/dashboard/usage")}).catch(()=>{}),e()},[]);let K=(e,t)=>{let s=a.filter(a=>a.provider===e&&a.authType===t),r=e=>{let t=Object.entries(e).some(([e,t])=>e.startsWith("modelLock_")&&t&&new Date(t).getTime()>Date.now());return"unavailable"!==e.testStatus||t?e.testStatus:"active"},l=s.filter(e=>{let t=r(e);return"active"===t||"success"===t}).length,i=s.filter(e=>{let t=r(e);return"error"===t||"expired"===t||"unavailable"===t}),n=i.length,o=s.length,d=o>0&&s.every(e=>!1===e.isActive),c=i.sort((e,t)=>new Date(t.lastErrorAt||0)-new Date(e.lastErrorAt||0))[0];return{connected:l,error:n,total:o,errorCode:c?function(e){if(!e)return null;let t=e.lastErrorType;if("runtime_error"===t)return"RUNTIME";if("upstream_auth_error"===t||"auth_missing"===t||"token_refresh_failed"===t||"token_expired"===t)return"AUTH";if("upstream_rate_limited"===t)return"429";if("upstream_unavailable"===t)return"5XX";if("network_error"===t)return"NET";let a=Number(e.errorCode);if(Number.isFinite(a)&&a>=400)return String(a);let s=function(e){if(!e)return null;let t=e.match(/\b([45]\d{2})\b/);return t?t[1]:"ERR"}(e.lastError);if("401"===s||"403"===s)return"AUTH";if(s&&"ERR"!==s)return s;let r=(e.lastError||"").toLowerCase();return r.includes("runtime")||r.includes("not runnable")||r.includes("not installed")?"RUNTIME":r.includes("invalid api key")||r.includes("token invalid")||r.includes("revoked")||r.includes("unauthorized")?"AUTH":"ERR"}(c):null,errorTime:c?.lastErrorAt?function(e){if(!e)return"";let t=Math.floor((Date.now()-new Date(e).getTime())/6e4);if(t<1)return"just now";if(t<60)return`${t}m ago`;let a=Math.floor(t/60);if(a<24)return`${a}h ago`;let s=Math.floor(a/24);return`${s}d ago`}(c.lastErrorAt):null,allDisabled:d}},D=async(e,t,s)=>{let r=a.filter(a=>a.provider===e&&a.authType===t);l(a=>a.map(a=>a.provider===e&&a.authType===t?{...a,isActive:s}:a)),await Promise.allSettled(r.map(e=>fetch(`/api/providers/${e.id}`,{method:"PUT",headers:{"Content-Type":"application/json"},body:JSON.stringify({isActive:s})})))},F=async(e,t=null)=>{if(!S){R("provider"===e?t:e),P(null);try{let a=await fetch("/api/providers/test-batch",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({mode:e,providerId:t})}),s=await a.json();if(P(s),s.summary){let{passed:e,failed:t,total:a}=s.summary;0===t?E.success(`All ${a} tests passed`):E.warning(`${e}/${a} passed, ${t} failed`)}}catch(e){P({error:"Test request failed"}),E.error("Provider test failed")}finally{R(null)}}},L=i.filter(e=>"openai-compatible"===e.type).map(e=>({id:e.id,name:e.name||"OpenAI Compatible",color:"#10A37F",textIcon:"OC",apiType:e.apiType})).filter(e=>z(e.name)),M=i.filter(e=>"anthropic-compatible"===e.type).map(e=>({id:e.id,name:e.name||"Anthropic Compatible",color:"#D97757",textIcon:"AC"})).filter(e=>z(e.name)),J=Object.entries(d.zN).filter(([,e])=>z(e.name)),B=Object.entries(c.IS).filter(([,e])=>z(e.name)),W=Object.entries(c.nJ).filter(([,e])=>z(e.name)),H=(e=Object.entries(d.fg).filter(([,e])=>(e.serviceKinds??["llm"]).includes("llm")&&z(e.name)),t="apikey",[...e].sort(([e,a],[s,r])=>{let l=K(e,t),i=K(s,t),n=+(l.connected>0),o=+(i.connected>0);return n!==o?o-n:(a.name||"").localeCompare(r.name||"")})),Q=!!$.trim(),V=Q||h?H:H.slice(0,20),X=H.length-20;if(p)return(0,s.jsxs)("div",{className:"flex flex-col gap-8",children:[(0,s.jsx)(n.Qv,{}),(0,s.jsx)(n.Qv,{})]});let Z=J.length>0||B.length>0||W.length>0||H.length>0||L.length>0||M.length>0;return(0,s.jsxs)("div",{className:"flex min-w-0 flex-col gap-6 px-1 sm:px-0",children:[!Z&&(0,s.jsxs)("div",{className:"text-center py-8 border border-dashed border-border rounded-xl",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[32px] text-text-muted mb-2",children:"search_off"}),(0,s.jsx)("p",{className:"text-text-muted text-sm",children:"No providers match your search"})]}),J.length>0&&(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between",children:[(0,s.jsx)("h2",{className:"text-lg sm:text-xl font-semibold flex items-center gap-2 leading-tight",children:"OAuth Providers"}),(0,s.jsxs)("div",{className:"flex w-full flex-col gap-2 sm:w-auto sm:flex-row sm:items-center",children:[(0,s.jsx)(f,{}),(0,s.jsxs)("button",{onClick:()=>F("oauth"),disabled:!!S,className:`flex w-full items-center justify-center gap-1.5 rounded-lg border px-3 py-2 text-xs font-medium transition-colors sm:w-auto sm:py-1.5 ${"oauth"===S?"bg-primary/20 border-primary/40 text-primary animate-pulse":"bg-bg border-border text-text-muted hover:text-text-main hover:border-primary/40"}`,title:"Test all OAuth connections","aria-label":"Test all OAuth connections",children:[(0,s.jsx)("span",{className:`material-symbols-outlined text-[14px]${"oauth"===S?" animate-spin":""}`,children:"play_arrow"}),"oauth"===S?"Testing...":"Test All"]})]})]}),(0,s.jsx)("div",{className:"grid grid-cols-1 gap-3 sm:grid-cols-2 sm:gap-4 lg:grid-cols-3 xl:grid-cols-4",children:J.map(([e,t])=>(0,s.jsx)(w,{providerId:e,provider:t,stats:K(e,"oauth"),authType:"oauth",onToggle:t=>D(e,"oauth",t)},e))})]}),(B.length>0||W.length>0)&&(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between",children:[(0,s.jsx)("h2",{className:"text-lg sm:text-xl font-semibold flex items-center gap-2 leading-tight",children:"Free Tier Providers"}),(0,s.jsxs)("button",{onClick:()=>F("free"),disabled:!!S,className:`flex w-full items-center justify-center gap-1.5 rounded-lg border px-3 py-2 text-xs font-medium transition-colors sm:w-auto sm:py-1.5 ${"free"===S?"bg-primary/20 border-primary/40 text-primary animate-pulse":"bg-bg border-border text-text-muted hover:text-text-main hover:border-primary/40"}`,title:"Test all Free connections","aria-label":"Test all Free provider connections",children:[(0,s.jsx)("span",{className:`material-symbols-outlined text-[14px]${"free"===S?" animate-spin":""}`,children:"play_arrow"}),"free"===S?"Testing...":"Test All"]})]}),(0,s.jsxs)("div",{className:"grid grid-cols-1 gap-3 sm:grid-cols-2 sm:gap-4 lg:grid-cols-3 xl:grid-cols-4",children:[B.map(([e,t])=>(0,s.jsx)(w,{providerId:e,provider:t,stats:K(e,"oauth"),authType:"free",onToggle:t=>D(e,"oauth",t)},e)),W.map(([e,t])=>(0,s.jsx)(C,{providerId:e,provider:t,stats:K(e,"apikey"),authType:"apikey",onToggle:t=>D(e,"apikey",t)},e))]})]}),H.length>0&&(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between",children:[(0,s.jsxs)("h2",{className:"text-lg sm:text-xl font-semibold flex items-center gap-2 leading-tight",children:["API Key Providers"," "]}),(0,s.jsxs)("button",{onClick:()=>F("apikey"),disabled:!!S,className:`flex w-full items-center justify-center gap-1.5 rounded-lg border px-3 py-2 text-xs font-medium transition-colors sm:w-auto sm:py-1.5 ${"apikey"===S?"bg-primary/20 border-primary/40 text-primary animate-pulse":"bg-bg border-border text-text-muted hover:text-text-main hover:border-primary/40"}`,title:"Test all API Key connections","aria-label":"Test all API Key connections",children:[(0,s.jsx)("span",{className:`material-symbols-outlined text-[14px]${"apikey"===S?" animate-spin":""}`,children:"play_arrow"}),"apikey"===S?"Testing...":"Test All"]})]}),(0,s.jsx)("div",{className:"grid grid-cols-1 gap-3 sm:grid-cols-2 sm:gap-4 lg:grid-cols-3 xl:grid-cols-4",children:V.map(([e,t])=>(0,s.jsx)(C,{providerId:e,provider:t,stats:K(e,"apikey"),authType:"apikey",onToggle:t=>D(e,"apikey",t)},e))}),!Q&&!h&&X>0&&(0,s.jsxs)("button",{onClick:()=>b(!0),className:"flex w-full items-center justify-center gap-1.5 rounded-lg border border-dashed border-primary/40 px-3 py-2.5 text-sm font-medium text-primary transition-colors hover:border-primary hover:bg-primary/5",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[16px]",children:"expand_more"}),"Show all ",H.length," providers"]})]}),(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center sm:justify-between",children:[(0,s.jsxs)("h2",{className:"text-lg sm:text-xl font-semibold flex items-center gap-2 leading-tight",children:["API Key Compatible Providers"," "]}),(0,s.jsxs)("div",{className:"grid grid-cols-1 gap-2 sm:flex sm:w-auto",children:[(0,s.jsx)(n.$n,{size:"sm",variant:"secondary",icon:"upload",onClick:()=>U(!0),className:"w-full sm:w-auto",children:"Import cURL"}),(0,s.jsx)(n.$n,{size:"sm",icon:"add",onClick:()=>N(!0),className:"w-full sm:w-auto",children:"Add Anthropic Compatible"}),(0,s.jsx)(n.$n,{size:"sm",variant:"secondary",icon:"add",onClick:()=>v(!0),className:"w-full !bg-white !text-black hover:!bg-gray-100 sm:w-auto",children:"Add OpenAI Compatible"})]})]}),0===L.length&&0===M.length?(0,s.jsxs)("div",{className:"text-center py-8 border border-dashed border-border rounded-xl",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[32px] text-text-muted mb-2",children:"extension"}),(0,s.jsx)("p",{className:"text-text-muted text-sm",children:"No compatible providers added yet"}),(0,s.jsx)("p",{className:"text-text-muted text-xs mt-1",children:"Use the buttons above to add OpenAI or Anthropic compatible endpoints"})]}):(0,s.jsx)("div",{className:"grid grid-cols-1 gap-3 sm:grid-cols-2 sm:gap-4 lg:grid-cols-3 xl:grid-cols-4",children:[...L,...M].map(e=>(0,s.jsx)(C,{providerId:e.id,provider:e,stats:K(e.id,"apikey"),authType:"compatible",onToggle:t=>D(e.id,"apikey",t)},e.id))})]}),(0,s.jsx)(k,{isOpen:g,onClose:()=>v(!1),onCreated:e=>{o(t=>[...t,e]),v(!1)}}),(0,s.jsx)(T,{isOpen:j,onClose:()=>N(!1),onCreated:e=>{o(t=>[...t,e]),N(!1)}}),(0,s.jsx)(y,{isOpen:A,onClose:()=>U(!1),notify:E,onImported:({node:e,connection:t})=>{o(t=>[...t,e]),t&&l(e=>[...e,t]),U(!1)}}),O&&(0,s.jsxs)("div",{className:"fixed inset-0 z-50 flex items-start justify-center px-3 pt-[6vh] sm:pt-[10vh]",onClick:()=>P(null),children:[(0,s.jsx)("div",{className:"absolute inset-0 bg-black/60 backdrop-blur-sm"}),(0,s.jsxs)("div",{className:"relative bg-surface border border-border rounded-xl w-full max-w-[600px] max-h-[86vh] sm:max-h-[80vh] overflow-y-auto shadow-2xl",onClick:e=>e.stopPropagation(),children:[(0,s.jsxs)("div",{className:"sticky top-0 z-10 flex items-center justify-between px-5 py-3 border-b border-border bg-surface/95 backdrop-blur-sm rounded-t-xl",children:[(0,s.jsx)("h3",{className:"font-semibold",children:"Test Results"}),(0,s.jsx)("button",{onClick:()=>P(null),className:"p-1 rounded-lg hover:bg-bg text-text-muted hover:text-text-main transition-colors","aria-label":"Close test results",children:(0,s.jsx)("span",{className:"material-symbols-outlined text-lg",children:"close"})})]}),(0,s.jsx)("div",{className:"p-5",children:(0,s.jsx)(I,{results:O})})]})]})]})}function w({providerId:e,provider:t,stats:a,authType:r,onToggle:l}){let{connected:i,error:d,errorCode:c,errorTime:p,allDisabled:x}=a,u=!!t.noAuth;return(0,s.jsx)(m(),{href:`/dashboard/providers/${e}`,className:"group min-w-0",children:(0,s.jsx)(n.Zp,{padding:"xs",className:`h-full hover:bg-black/[0.01] dark:hover:bg-white/[0.01] transition-colors cursor-pointer ${x?"opacity-50":""}`,children:(0,s.jsxs)("div",{className:"flex min-w-0 items-center justify-between gap-3",children:[(0,s.jsxs)("div",{className:"flex min-w-0 items-center gap-3",children:[(0,s.jsx)("div",{className:"size-8 shrink-0 rounded-lg flex items-center justify-center",style:{backgroundColor:`${t.color?.length>7?t.color:t.color+"15"}`},children:(0,s.jsx)(o.A,{src:`/providers/${t.id}.png`,alt:t.name,size:30,className:"object-contain rounded-lg max-w-[32px] max-h-[32px]",fallbackText:t.textIcon||t.id.slice(0,2).toUpperCase(),fallbackColor:t.color})}),(0,s.jsxs)("div",{className:"min-w-0",children:[(0,s.jsx)("h3",{className:"truncate font-semibold",children:t.name}),(0,s.jsx)("div",{className:"flex min-w-0 items-center gap-1.5 text-xs flex-wrap",children:x?(0,s.jsx)(n.Ex,{variant:"default",size:"sm",children:(0,s.jsxs)("span",{className:"flex items-center gap-1",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[12px]",children:"pause_circle"}),"Disabled"]})}):u?(0,s.jsx)(n.Ex,{variant:"success",size:"sm",dot:!0,children:"Ready"}):(0,s.jsxs)(s.Fragment,{children:[j(i,d,c),p&&(0,s.jsx)("span",{className:"text-text-muted",children:p})]})})]})]}),(0,s.jsx)("div",{className:"flex shrink-0 items-center gap-2",children:a.total>0&&(0,s.jsx)("div",{className:"opacity-100 transition-opacity sm:opacity-0 sm:group-hover:opacity-100",onClick:e=>{e.preventDefault(),e.stopPropagation(),l(!!x)},children:(0,s.jsx)(n.lM,{size:"sm",checked:!x,onChange:()=>{},title:x?"Enable provider":"Disable provider"})})})]})})})}function C({providerId:e,provider:t,stats:a,authType:r,onToggle:l}){let{connected:i,error:d,errorCode:p,errorTime:x,allDisabled:u}=a,h=e.startsWith(c.JH),f=e.startsWith(c.DI);return(0,s.jsx)(m(),{href:`/dashboard/providers/${e}`,className:"group min-w-0",children:(0,s.jsx)(n.Zp,{padding:"xs",className:`h-full hover:bg-black/[0.01] dark:hover:bg-white/[0.01] transition-colors cursor-pointer ${u?"opacity-50":""}`,children:(0,s.jsxs)("div",{className:"flex min-w-0 items-center justify-between gap-3",children:[(0,s.jsxs)("div",{className:"flex min-w-0 items-center gap-3",children:[(0,s.jsx)("div",{className:"size-8 shrink-0 rounded-lg flex items-center justify-center",style:{backgroundColor:`${t.color?.length>7?t.color:t.color+"15"}`},children:(0,s.jsx)(o.A,{src:h?"responses"===t.apiType?"/providers/oai-r.png":"/providers/oai-cc.png":f?"/providers/anthropic-m.png":`/providers/${t.id}.png`,alt:t.name,size:30,className:"object-contain rounded-lg max-w-[30px] max-h-[30px]",fallbackText:t.textIcon||t.id.slice(0,2).toUpperCase(),fallbackColor:t.color})}),(0,s.jsxs)("div",{className:"min-w-0",children:[(0,s.jsx)("h3",{className:"truncate font-semibold",children:t.name}),(0,s.jsx)("div",{className:"flex min-w-0 items-center gap-1.5 text-xs flex-wrap",children:u?(0,s.jsx)(n.Ex,{variant:"default",size:"sm",children:(0,s.jsxs)("span",{className:"flex items-center gap-1",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-[12px]",children:"pause_circle"}),"Disabled"]})}):(0,s.jsxs)(s.Fragment,{children:[j(i,d,p),h&&(0,s.jsx)(n.Ex,{variant:"default",size:"sm",children:"responses"===t.apiType?"Responses":"Chat"}),f&&(0,s.jsx)(n.Ex,{variant:"default",size:"sm",children:"Messages"}),x&&(0,s.jsx)("span",{className:"text-text-muted",children:x})]})})]})]}),(0,s.jsx)("div",{className:"flex shrink-0 items-center gap-2",children:a.total>0&&(0,s.jsx)("div",{className:"opacity-100 transition-opacity sm:opacity-0 sm:group-hover:opacity-100",onClick:e=>{e.preventDefault(),e.stopPropagation(),l(!!u)},children:(0,s.jsx)(n.lM,{size:"sm",checked:!u,onChange:()=>{},title:u?"Enable provider":"Disable provider"})})})]})})})}function k({isOpen:e,onClose:t,onCreated:a}){let[l,i]=(0,r.useState)({name:"",prefix:"",apiType:"chat",baseUrl:"https://api.openai.com/v1"}),[o,d]=(0,r.useState)(!1),[c,p]=(0,r.useState)(""),[m,x]=(0,r.useState)(""),[u,h]=(0,r.useState)(!1),[f,b]=(0,r.useState)(null);(0,r.useEffect)(()=>{i(e=>({...e,baseUrl:"https://api.openai.com/v1"}))},[l.apiType]);let g=async()=>{if(l.name.trim()&&l.prefix.trim()&&l.baseUrl.trim()){d(!0);try{let e=await fetch("/api/provider-nodes",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:l.name,prefix:l.prefix,apiType:l.apiType,baseUrl:l.baseUrl,type:"openai-compatible"})}),t=await e.json();e.ok&&(a(t.node),i({name:"",prefix:"",apiType:"chat",baseUrl:"https://api.openai.com/v1"}),p(""),b(null))}catch(e){console.log("Error creating OpenAI Compatible node:",e)}finally{d(!1)}}},v=async()=>{h(!0);try{let e=await fetch("/api/provider-nodes/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({baseUrl:l.baseUrl,apiKey:c,type:"openai-compatible",modelId:m.trim()||void 0})}),t=await e.json();t.normalizedBaseUrl&&i(e=>({...e,baseUrl:t.normalizedBaseUrl,apiType:t.inferredApiType||e.apiType})),b(t)}catch{b({valid:!1,error:"Network error"})}finally{h(!1)}};return(0,s.jsx)(n.aF,{isOpen:e,title:"Add OpenAI Compatible",onClose:t,children:(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)(n.pd,{label:"Name",value:l.name,onChange:e=>i({...l,name:e.target.value}),placeholder:"OpenAI Compatible (Prod)",hint:"Required. A friendly label for this node."}),(0,s.jsx)(n.pd,{label:"Prefix",value:l.prefix,onChange:e=>i({...l,prefix:e.target.value}),placeholder:"oc-prod",hint:"Required. Used as the provider prefix for model IDs."}),(0,s.jsx)(n.l6,{label:"API Type",options:[{value:"chat",label:"Chat Completions"},{value:"responses",label:"Responses API"}],value:l.apiType,onChange:e=>i({...l,apiType:e.target.value})}),(0,s.jsx)(n.pd,{label:"Base URL",value:l.baseUrl,onChange:e=>i({...l,baseUrl:e.target.value}),placeholder:"https://api.openai.com/v1",hint:"Use the base URL (ending in /v1) for your OpenAI-compatible API."}),(0,s.jsx)(n.pd,{label:"API Key (for Check)",type:"password",value:c,onChange:e=>p(e.target.value)}),(0,s.jsx)(n.pd,{label:"Model ID (optional)",value:m,onChange:e=>x(e.target.value),placeholder:"e.g. gpt-4, claude-3-opus",hint:"If provider lacks /models endpoint, enter a model ID to validate via chat/completions instead."}),(0,s.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center",children:[(0,s.jsx)(n.$n,{onClick:v,disabled:!c||u||!l.baseUrl.trim(),variant:"secondary",className:"w-full sm:w-auto",children:u?"Checking...":"Check"}),(()=>{if(!f)return null;let{valid:e,error:t,method:a}=f;return e?(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.Ex,{variant:"success",children:"Valid"}),"chat"===a&&(0,s.jsx)("span",{className:"text-sm text-text-muted",children:"(via inference test)"})]}):(0,s.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,s.jsx)(n.Ex,{variant:"error",children:"Invalid"}),t&&(0,s.jsx)("span",{className:"text-sm text-red-500",children:t})]})})()]}),(0,s.jsxs)("div",{className:"flex flex-col gap-2 sm:flex-row",children:[(0,s.jsx)(n.$n,{onClick:g,fullWidth:!0,disabled:!l.name.trim()||!l.prefix.trim()||!l.baseUrl.trim()||o,children:o?"Creating...":"Create"}),(0,s.jsx)(n.$n,{onClick:t,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})})}function T({isOpen:e,onClose:t,onCreated:a}){let[l,i]=(0,r.useState)({name:"",prefix:"",baseUrl:"https://api.anthropic.com/v1"}),[o,d]=(0,r.useState)(!1),[c,p]=(0,r.useState)(""),[m,x]=(0,r.useState)(""),[u,h]=(0,r.useState)(!1),[f,b]=(0,r.useState)(null);(0,r.useEffect)(()=>{e&&(b(null),p(""),x(""))},[e]);let g=async()=>{if(l.name.trim()&&l.prefix.trim()&&l.baseUrl.trim()){d(!0);try{let e=await fetch("/api/provider-nodes",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({name:l.name,prefix:l.prefix,baseUrl:l.baseUrl,type:"anthropic-compatible"})}),t=await e.json();e.ok&&(a(t.node),i({name:"",prefix:"",baseUrl:"https://api.anthropic.com/v1"}),p(""),b(null))}catch(e){console.log("Error creating Anthropic Compatible node:",e)}finally{d(!1)}}},v=async()=>{h(!0);try{let e=await fetch("/api/provider-nodes/validate",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({baseUrl:l.baseUrl,apiKey:c,type:"anthropic-compatible",modelId:m.trim()||void 0})}),t=await e.json();t.normalizedBaseUrl&&i(e=>({...e,baseUrl:t.normalizedBaseUrl})),b(t)}catch{b({valid:!1,error:"Network error"})}finally{h(!1)}};return(0,s.jsx)(n.aF,{isOpen:e,title:"Add Anthropic Compatible",onClose:t,children:(0,s.jsxs)("div",{className:"flex flex-col gap-4",children:[(0,s.jsx)(n.pd,{label:"Name",value:l.name,onChange:e=>i({...l,name:e.target.value}),placeholder:"Anthropic Compatible (Prod)",hint:"Required. A friendly label for this node."}),(0,s.jsx)(n.pd,{label:"Prefix",value:l.prefix,onChange:e=>i({...l,prefix:e.target.value}),placeholder:"ac-prod",hint:"Required. Used as the provider prefix for model IDs."}),(0,s.jsx)(n.pd,{label:"Base URL",value:l.baseUrl,onChange:e=>i({...l,baseUrl:e.target.value}),placeholder:"https://api.anthropic.com/v1",hint:"Use the base URL (ending in /v1) for your Anthropic-compatible API. The system will append /messages."}),(0,s.jsx)(n.pd,{label:"API Key (for Check)",type:"password",value:c,onChange:e=>p(e.target.value)}),(0,s.jsx)(n.pd,{label:"Model ID (optional)",value:m,onChange:e=>x(e.target.value),placeholder:"e.g. claude-3-opus",hint:"If provider lacks /models endpoint, enter a model ID to validate via chat/completions instead."}),(0,s.jsxs)("div",{className:"flex flex-col gap-3 sm:flex-row sm:items-center",children:[(0,s.jsx)(n.$n,{onClick:v,disabled:!c||u||!l.baseUrl.trim(),variant:"secondary",className:"w-full sm:w-auto",children:u?"Checking...":"Check"}),(()=>{if(!f)return null;let{valid:e,error:t,method:a}=f;return e?(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(n.Ex,{variant:"success",children:"Valid"}),"chat"===a&&(0,s.jsx)("span",{className:"text-sm text-text-muted",children:"(via inference test)"})]}):(0,s.jsxs)("div",{className:"flex flex-col gap-1",children:[(0,s.jsx)(n.Ex,{variant:"error",children:"Invalid"}),t&&(0,s.jsx)("span",{className:"text-sm text-red-500",children:t})]})})()]}),(0,s.jsxs)("div",{className:"flex flex-col gap-2 sm:flex-row",children:[(0,s.jsx)(n.$n,{onClick:g,fullWidth:!0,disabled:!l.name.trim()||!l.prefix.trim()||!l.baseUrl.trim()||o,children:o?"Creating...":"Create"}),(0,s.jsx)(n.$n,{onClick:t,variant:"ghost",fullWidth:!0,children:"Cancel"})]})]})})}function I({results:e}){if(e.error&&!e.results)return(0,s.jsxs)("div",{className:"text-center py-6",children:[(0,s.jsx)("span",{className:"material-symbols-outlined text-red-500 text-[32px] mb-2 block",children:"error"}),(0,s.jsx)("p",{className:"text-sm text-red-400",children:e.error})]});let{summary:t,mode:a}=e,r=e.results||[];return(0,s.jsxs)("div",{className:"flex min-w-0 flex-col gap-3",children:[t&&(0,s.jsxs)("div",{className:"flex flex-wrap items-center gap-2 text-xs mb-1 sm:gap-3",children:[(0,s.jsxs)("span",{className:"text-text-muted",children:[{oauth:"OAuth",free:"Free",apikey:"API Key",provider:"Provider",all:"All"}[a]||a," Test"]}),(0,s.jsxs)("span",{className:"px-2 py-0.5 rounded bg-emerald-500/15 text-emerald-400 font-medium",children:[t.passed," passed"]}),t.failed>0&&(0,s.jsxs)("span",{className:"px-2 py-0.5 rounded bg-red-500/15 text-red-400 font-medium",children:[t.failed," failed"]}),(0,s.jsxs)("span",{className:"text-text-muted sm:ml-auto",children:[t.total," tested"]})]}),r.map((e,t)=>(0,s.jsxs)("div",{className:"flex min-w-0 flex-wrap items-center gap-2 rounded-lg bg-black/[0.03] px-3 py-2 text-xs dark:bg-white/[0.03] sm:flex-nowrap",children:[(0,s.jsx)("span",{className:`material-symbols-outlined text-[16px] ${e.valid?"text-emerald-500":"text-red-500"}`,children:e.valid?"check_circle":"error"}),(0,s.jsxs)("div",{className:"min-w-0 flex-[1_1_160px]",children:[(0,s.jsx)("span",{className:"block truncate font-medium sm:inline",children:e.connectionName}),(0,s.jsxs)("span",{className:"block truncate text-text-muted sm:ml-1.5 sm:inline",children:["(",e.provider,")"]})]}),void 0!==e.latencyMs&&(0,s.jsxs)("span",{className:"shrink-0 text-text-muted font-mono tabular-nums",children:[e.latencyMs,"ms"]}),(0,s.jsx)("span",{className:`shrink-0 text-[10px] uppercase font-bold px-1.5 py-0.5 rounded ${e.valid?"bg-emerald-500/15 text-emerald-400":"bg-red-500/15 text-red-400"}`,children:e.valid?"OK":e.diagnosis?.type||"ERROR"})]},e.connectionId||t)),0===r.length&&(0,s.jsx)("div",{className:"text-center py-4 text-text-muted text-sm",children:"No active connections found for this group."})]})}y.propTypes={isOpen:i().bool.isRequired,onClose:i().func.isRequired,onImported:i().func,notify:i().shape({success:i().func.isRequired,error:i().func.isRequired}).isRequired},w.propTypes={providerId:i().string.isRequired,provider:i().shape({id:i().string.isRequired,name:i().string.isRequired,color:i().string,textIcon:i().string}).isRequired,stats:i().shape({connected:i().number,error:i().number,errorCode:i().string,errorTime:i().string}).isRequired,authType:i().string,onToggle:i().func},C.propTypes={providerId:i().string.isRequired,provider:i().shape({id:i().string.isRequired,name:i().string.isRequired,color:i().string,textIcon:i().string,apiType:i().string}).isRequired,stats:i().shape({connected:i().number,error:i().number,errorCode:i().string,errorTime:i().string}).isRequired,authType:i().string,onToggle:i().func},k.propTypes={isOpen:i().bool.isRequired,onClose:i().func.isRequired,onCreated:i().func.isRequired},T.propTypes={isOpen:i().bool.isRequired,onClose:i().func.isRequired,onCreated:i().func.isRequired},I.propTypes={results:i().shape({mode:i().string,results:i().array,summary:i().shape({total:i().number,passed:i().number,failed:i().number}),error:i().string}).isRequired}},18255:(e,t,a)=>{Promise.resolve().then(a.bind(a,12572))}},e=>{e.O(0,[2574,3862,1051,1321,5497,8441,3794,7358],()=>e(e.s=18255)),_N_E=e.O()}]);
@@ -0,0 +1 @@
1
+ (self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[39,174,204,318,335,342,387,501,516,543,552,675,747,748,907,931,948,992,997,1070,1088,1110,1118,1200,1288,1337,1382,1451,1512,1566,1666,1686,1697,1860,1907,1910,1946,1949,2121,2198,2284,2296,2525,2772,2785,2797,2919,2922,3025,3038,3079,3102,3397,3472,3507,3528,3549,3562,3568,3579,3883,3888,4010,4245,4286,4422,4444,4612,4656,4674,4761,4896,4993,5018,5079,5107,5177,5211,5226,5377,5466,5637,5685,5745,5922,6091,6100,6107,6268,6319,6432,6479,6529,6580,6594,6619,6740,6743,6819,6919,6988,7131,7158,7218,7241,7311,7429,7442,7445,7473,7508,7520,7824,7851,8026,8167,8207,8246,8453,8489,8573,8648,8673,8736,8791,8814,8870,8948,8974,8975,9027,9069,9088,9141,9199,9321,9461,9678,9709],{84441:()=>{}},_=>{_.O(0,[8441,3794,7358],()=>_(_.s=84441)),_N_E=_.O()}]);