9router 0.4.28 → 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 (853) hide show
  1. package/app/.next/BUILD_ID +1 -1
  2. package/app/.next/app-path-routes-manifest.json +14 -6
  3. package/app/.next/build-manifest.json +3 -3
  4. package/app/.next/required-server-files.json +6 -0
  5. package/app/.next/routes-manifest.json +52 -0
  6. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page.js +2 -2
  7. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page.js.nft.json +1 -1
  8. package/app/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
  9. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js +2 -2
  10. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page.js.nft.json +1 -1
  11. package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
  12. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js +2 -2
  13. package/app/.next/server/app/(dashboard)/dashboard/combos/page.js.nft.json +1 -1
  14. package/app/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
  15. package/app/.next/server/app/(dashboard)/dashboard/console-log/page.js +2 -2
  16. package/app/.next/server/app/(dashboard)/dashboard/console-log/page.js.nft.json +1 -1
  17. package/app/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -1
  18. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js +2 -2
  19. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page.js.nft.json +1 -1
  20. package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
  21. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page.js +2 -2
  22. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page.js.nft.json +1 -1
  23. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/[id]/page_client-reference-manifest.js +1 -1
  24. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page.js +2 -2
  25. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page.js.nft.json +1 -1
  26. package/app/.next/server/app/(dashboard)/dashboard/media-providers/[kind]/page_client-reference-manifest.js +1 -1
  27. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page.js +2 -2
  28. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page.js.nft.json +1 -1
  29. package/app/.next/server/app/(dashboard)/dashboard/media-providers/combo/[id]/page_client-reference-manifest.js +1 -1
  30. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page.js +2 -2
  31. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page.js.nft.json +1 -1
  32. package/app/.next/server/app/(dashboard)/dashboard/media-providers/web/page_client-reference-manifest.js +1 -1
  33. package/app/.next/server/app/(dashboard)/dashboard/mitm/page.js +2 -2
  34. package/app/.next/server/app/(dashboard)/dashboard/mitm/page.js.nft.json +1 -1
  35. package/app/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
  36. package/app/.next/server/app/(dashboard)/dashboard/page.js +2 -2
  37. package/app/.next/server/app/(dashboard)/dashboard/page.js.nft.json +1 -1
  38. package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
  39. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js +2 -2
  40. package/app/.next/server/app/(dashboard)/dashboard/profile/page.js.nft.json +1 -1
  41. package/app/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
  42. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js +3 -3
  43. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js.nft.json +1 -1
  44. package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
  45. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js +2 -2
  46. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page.js.nft.json +1 -1
  47. package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
  48. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js +2 -2
  49. package/app/.next/server/app/(dashboard)/dashboard/providers/page.js.nft.json +1 -1
  50. package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
  51. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page.js +3 -3
  52. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page.js.nft.json +1 -1
  53. package/app/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
  54. package/app/.next/server/app/(dashboard)/dashboard/quota/page.js +2 -2
  55. package/app/.next/server/app/(dashboard)/dashboard/quota/page.js.nft.json +1 -1
  56. package/app/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
  57. package/app/.next/server/app/(dashboard)/dashboard/skills/page.js +2 -2
  58. package/app/.next/server/app/(dashboard)/dashboard/skills/page.js.nft.json +1 -1
  59. package/app/.next/server/app/(dashboard)/dashboard/skills/page_client-reference-manifest.js +1 -1
  60. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js +2 -2
  61. package/app/.next/server/app/(dashboard)/dashboard/translator/page.js.nft.json +1 -1
  62. package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
  63. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js +2 -2
  64. package/app/.next/server/app/(dashboard)/dashboard/usage/page.js.nft.json +1 -1
  65. package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
  66. package/app/.next/server/app/_global-error/page.js +2 -2
  67. package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  68. package/app/.next/server/app/_global-error.html +1 -1
  69. package/app/.next/server/app/_global-error.rsc +1 -1
  70. package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  71. package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  72. package/app/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  73. package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  74. package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  75. package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  76. package/app/.next/server/app/_not-found/page.js +2 -2
  77. package/app/.next/server/app/_not-found/page.js.nft.json +1 -1
  78. package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  79. package/app/.next/server/app/_not-found.html +1 -1
  80. package/app/.next/server/app/_not-found.rsc +18 -20
  81. package/app/.next/server/app/_not-found.segments/_full.segment.rsc +18 -20
  82. package/app/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  83. package/app/.next/server/app/_not-found.segments/_index.segment.rsc +7 -9
  84. package/app/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  85. package/app/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  86. package/app/.next/server/app/_not-found.segments/_tree.segment.rsc +3 -4
  87. package/app/.next/server/app/api/auth/login/route.js +1 -1
  88. package/app/.next/server/app/api/auth/login/route.js.nft.json +1 -1
  89. package/app/.next/server/app/api/auth/logout/route.js +1 -1
  90. package/app/.next/server/app/api/auth/logout/route.js.nft.json +1 -1
  91. package/app/.next/server/app/api/auth/oidc/callback/route.js +1 -0
  92. package/app/.next/server/app/api/auth/oidc/callback/route.js.nft.json +1 -0
  93. package/app/.next/server/app/api/auth/oidc/callback/route_client-reference-manifest.js +1 -0
  94. package/app/.next/server/app/api/auth/oidc/start/route.js +1 -0
  95. package/app/.next/server/app/api/auth/oidc/start/route.js.nft.json +1 -0
  96. package/app/.next/server/app/api/auth/oidc/start/route_client-reference-manifest.js +1 -0
  97. package/app/.next/server/app/api/auth/oidc/test/route.js +1 -0
  98. package/app/.next/server/app/api/auth/oidc/test/route.js.nft.json +1 -0
  99. package/app/.next/server/app/api/auth/oidc/test/route_client-reference-manifest.js +1 -0
  100. package/app/.next/server/app/api/auth/status/route.js +1 -0
  101. package/app/.next/server/app/api/auth/status/route.js.nft.json +1 -0
  102. package/app/.next/server/app/api/auth/status/route_client-reference-manifest.js +1 -0
  103. package/app/.next/server/app/api/cli-tools/all-statuses/route.js +2 -2
  104. package/app/.next/server/app/api/cli-tools/all-statuses/route.js.nft.json +1 -1
  105. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
  106. package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js.nft.json +1 -1
  107. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +1 -1
  108. package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js.nft.json +1 -1
  109. package/app/.next/server/app/api/cli-tools/claude-settings/route.js +1 -1
  110. package/app/.next/server/app/api/cli-tools/cline-settings/route.js +2 -0
  111. package/app/.next/server/app/api/cli-tools/cline-settings/route.js.nft.json +1 -0
  112. package/app/.next/server/app/api/cli-tools/cline-settings/route_client-reference-manifest.js +1 -0
  113. package/app/.next/server/app/api/cli-tools/codex-settings/route.js +1 -1
  114. package/app/.next/server/app/api/cli-tools/copilot-settings/route.js +1 -1
  115. package/app/.next/server/app/api/cli-tools/cowork-mcp-registry/route.js +1 -1
  116. package/app/.next/server/app/api/cli-tools/cowork-mcp-tools/route.js +1 -1
  117. package/app/.next/server/app/api/cli-tools/cowork-settings/route.js +2 -2
  118. package/app/.next/server/app/api/cli-tools/cowork-settings/route.js.nft.json +1 -1
  119. package/app/.next/server/app/api/cli-tools/droid-settings/route.js +2 -2
  120. package/app/.next/server/app/api/cli-tools/hermes-settings/route.js +2 -2
  121. package/app/.next/server/app/api/cli-tools/kilo-settings/route.js +2 -0
  122. package/app/.next/server/app/api/cli-tools/kilo-settings/route.js.nft.json +1 -0
  123. package/app/.next/server/app/api/cli-tools/kilo-settings/route_client-reference-manifest.js +1 -0
  124. package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js +2 -2
  125. package/app/.next/server/app/api/cli-tools/opencode-settings/route.js +1 -1
  126. package/app/.next/server/app/api/cloud/auth/route.js +1 -1
  127. package/app/.next/server/app/api/cloud/auth/route.js.nft.json +1 -1
  128. package/app/.next/server/app/api/cloud/credentials/update/route.js +1 -1
  129. package/app/.next/server/app/api/cloud/credentials/update/route.js.nft.json +1 -1
  130. package/app/.next/server/app/api/cloud/model/resolve/route.js +1 -1
  131. package/app/.next/server/app/api/cloud/model/resolve/route.js.nft.json +1 -1
  132. package/app/.next/server/app/api/cloud/models/alias/route.js +1 -1
  133. package/app/.next/server/app/api/cloud/models/alias/route.js.nft.json +1 -1
  134. package/app/.next/server/app/api/combos/[id]/route.js +1 -1
  135. package/app/.next/server/app/api/combos/[id]/route.js.nft.json +1 -1
  136. package/app/.next/server/app/api/combos/route.js +1 -1
  137. package/app/.next/server/app/api/combos/route.js.nft.json +1 -1
  138. package/app/.next/server/app/api/health/route.js +1 -1
  139. package/app/.next/server/app/api/init/route.js +1 -1
  140. package/app/.next/server/app/api/init/route.js.nft.json +1 -1
  141. package/app/.next/server/app/api/keys/[id]/route.js +1 -1
  142. package/app/.next/server/app/api/keys/[id]/route.js.nft.json +1 -1
  143. package/app/.next/server/app/api/keys/route.js +1 -1
  144. package/app/.next/server/app/api/keys/route.js.nft.json +1 -1
  145. package/app/.next/server/app/api/locale/route.js +1 -1
  146. package/app/.next/server/app/api/mcp/[plugin]/message/route.js +7 -0
  147. package/app/.next/server/app/api/mcp/[plugin]/message/route.js.nft.json +1 -0
  148. package/app/.next/server/app/api/mcp/[plugin]/message/route_client-reference-manifest.js +1 -0
  149. package/app/.next/server/app/api/mcp/[plugin]/sse/route.js +10 -0
  150. package/app/.next/server/app/api/mcp/[plugin]/sse/route.js.nft.json +1 -0
  151. package/app/.next/server/app/api/mcp/[plugin]/sse/route_client-reference-manifest.js +1 -0
  152. package/app/.next/server/app/api/media-providers/tts/deepgram/voices/route.js +1 -1
  153. package/app/.next/server/app/api/media-providers/tts/deepgram/voices/route.js.nft.json +1 -1
  154. package/app/.next/server/app/api/media-providers/tts/elevenlabs/voices/route.js +1 -1
  155. package/app/.next/server/app/api/media-providers/tts/elevenlabs/voices/route.js.nft.json +1 -1
  156. package/app/.next/server/app/api/media-providers/tts/inworld/voices/route.js +1 -1
  157. package/app/.next/server/app/api/media-providers/tts/inworld/voices/route.js.nft.json +1 -1
  158. package/app/.next/server/app/api/media-providers/tts/voices/route.js +1 -1
  159. package/app/.next/server/app/api/models/alias/route.js +1 -1
  160. package/app/.next/server/app/api/models/alias/route.js.nft.json +1 -1
  161. package/app/.next/server/app/api/models/availability/route.js +1 -1
  162. package/app/.next/server/app/api/models/availability/route.js.nft.json +1 -1
  163. package/app/.next/server/app/api/models/custom/route.js +1 -1
  164. package/app/.next/server/app/api/models/custom/route.js.nft.json +1 -1
  165. package/app/.next/server/app/api/models/disabled/route.js +1 -1
  166. package/app/.next/server/app/api/models/disabled/route.js.nft.json +1 -1
  167. package/app/.next/server/app/api/models/route.js +1 -1
  168. package/app/.next/server/app/api/models/route.js.nft.json +1 -1
  169. package/app/.next/server/app/api/models/test/route.js +1 -1
  170. package/app/.next/server/app/api/models/test/route.js.nft.json +1 -1
  171. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js +2 -2
  172. package/app/.next/server/app/api/oauth/[provider]/[action]/route.js.nft.json +1 -1
  173. package/app/.next/server/app/api/oauth/cursor/auto-import/route.js +2 -2
  174. package/app/.next/server/app/api/oauth/cursor/import/route.js +1 -1
  175. package/app/.next/server/app/api/oauth/cursor/import/route.js.nft.json +1 -1
  176. package/app/.next/server/app/api/oauth/gitlab/pat/route.js +1 -1
  177. package/app/.next/server/app/api/oauth/gitlab/pat/route.js.nft.json +1 -1
  178. package/app/.next/server/app/api/oauth/iflow/cookie/route.js +1 -1
  179. package/app/.next/server/app/api/oauth/iflow/cookie/route.js.nft.json +1 -1
  180. package/app/.next/server/app/api/oauth/kiro/auto-import/route.js +1 -1
  181. package/app/.next/server/app/api/oauth/kiro/import/route.js +1 -1
  182. package/app/.next/server/app/api/oauth/kiro/import/route.js.nft.json +1 -1
  183. package/app/.next/server/app/api/oauth/kiro/social-authorize/route.js +1 -1
  184. package/app/.next/server/app/api/oauth/kiro/social-exchange/route.js +1 -1
  185. package/app/.next/server/app/api/oauth/kiro/social-exchange/route.js.nft.json +1 -1
  186. package/app/.next/server/app/api/pricing/route.js +1 -1
  187. package/app/.next/server/app/api/pricing/route.js.nft.json +1 -1
  188. package/app/.next/server/app/api/provider-nodes/[id]/route.js +1 -1
  189. package/app/.next/server/app/api/provider-nodes/[id]/route.js.nft.json +1 -1
  190. package/app/.next/server/app/api/provider-nodes/route.js +1 -1
  191. package/app/.next/server/app/api/provider-nodes/route.js.nft.json +1 -1
  192. package/app/.next/server/app/api/provider-nodes/validate/route.js +1 -1
  193. package/app/.next/server/app/api/providers/[id]/models/route.js +1 -1
  194. package/app/.next/server/app/api/providers/[id]/models/route.js.nft.json +1 -1
  195. package/app/.next/server/app/api/providers/[id]/route.js +1 -1
  196. package/app/.next/server/app/api/providers/[id]/route.js.nft.json +1 -1
  197. package/app/.next/server/app/api/providers/[id]/test/route.js +1 -1
  198. package/app/.next/server/app/api/providers/[id]/test/route.js.nft.json +1 -1
  199. package/app/.next/server/app/api/providers/[id]/test-models/route.js +1 -1
  200. package/app/.next/server/app/api/providers/[id]/test-models/route.js.nft.json +1 -1
  201. package/app/.next/server/app/api/providers/client/route.js +1 -1
  202. package/app/.next/server/app/api/providers/client/route.js.nft.json +1 -1
  203. package/app/.next/server/app/api/providers/kilo/free-models/route.js +1 -1
  204. package/app/.next/server/app/api/providers/route.js +1 -1
  205. package/app/.next/server/app/api/providers/route.js.nft.json +1 -1
  206. package/app/.next/server/app/api/providers/suggested-models/route.js +1 -1
  207. package/app/.next/server/app/api/providers/test-batch/route.js +1 -1
  208. package/app/.next/server/app/api/providers/test-batch/route.js.nft.json +1 -1
  209. package/app/.next/server/app/api/providers/validate/route.js +1 -1
  210. package/app/.next/server/app/api/providers/validate/route.js.nft.json +1 -1
  211. package/app/.next/server/app/api/proxy-pools/[id]/route.js +1 -1
  212. package/app/.next/server/app/api/proxy-pools/[id]/route.js.nft.json +1 -1
  213. package/app/.next/server/app/api/proxy-pools/[id]/test/route.js +1 -1
  214. package/app/.next/server/app/api/proxy-pools/[id]/test/route.js.nft.json +1 -1
  215. package/app/.next/server/app/api/proxy-pools/route.js +1 -1
  216. package/app/.next/server/app/api/proxy-pools/route.js.nft.json +1 -1
  217. package/app/.next/server/app/api/proxy-pools/vercel-deploy/route.js +2 -2
  218. package/app/.next/server/app/api/proxy-pools/vercel-deploy/route.js.nft.json +1 -1
  219. package/app/.next/server/app/api/settings/database/route.js +1 -1
  220. package/app/.next/server/app/api/settings/database/route.js.nft.json +1 -1
  221. package/app/.next/server/app/api/settings/proxy-test/route.js +1 -1
  222. package/app/.next/server/app/api/settings/require-login/route.js +1 -1
  223. package/app/.next/server/app/api/settings/require-login/route.js.nft.json +1 -1
  224. package/app/.next/server/app/api/settings/route.js +1 -1
  225. package/app/.next/server/app/api/settings/route.js.nft.json +1 -1
  226. package/app/.next/server/app/api/shutdown/route.js +1 -1
  227. package/app/.next/server/app/api/tags/route.js +1 -1
  228. package/app/.next/server/app/api/translator/console-logs/route.js +1 -1
  229. package/app/.next/server/app/api/translator/console-logs/stream/route.js +2 -2
  230. package/app/.next/server/app/api/translator/load/route.js +1 -1
  231. package/app/.next/server/app/api/translator/save/route.js +1 -1
  232. package/app/.next/server/app/api/translator/send/route.js +1 -1
  233. package/app/.next/server/app/api/translator/send/route.js.nft.json +1 -1
  234. package/app/.next/server/app/api/translator/translate/route.js +1 -1
  235. package/app/.next/server/app/api/translator/translate/route.js.nft.json +1 -1
  236. package/app/.next/server/app/api/tunnel/disable/route.js +1 -1
  237. package/app/.next/server/app/api/tunnel/disable/route.js.nft.json +1 -1
  238. package/app/.next/server/app/api/tunnel/enable/route.js +1 -1
  239. package/app/.next/server/app/api/tunnel/enable/route.js.nft.json +1 -1
  240. package/app/.next/server/app/api/tunnel/status/route.js +1 -1
  241. package/app/.next/server/app/api/tunnel/status/route.js.nft.json +1 -1
  242. package/app/.next/server/app/api/tunnel/tailscale-check/route.js +1 -15
  243. package/app/.next/server/app/api/tunnel/tailscale-check/route.js.nft.json +1 -1
  244. package/app/.next/server/app/api/tunnel/tailscale-disable/route.js +1 -1
  245. package/app/.next/server/app/api/tunnel/tailscale-disable/route.js.nft.json +1 -1
  246. package/app/.next/server/app/api/tunnel/tailscale-enable/route.js +1 -1
  247. package/app/.next/server/app/api/tunnel/tailscale-enable/route.js.nft.json +1 -1
  248. package/app/.next/server/app/api/tunnel/tailscale-install/route.js +3 -3
  249. package/app/.next/server/app/api/tunnel/tailscale-install/route.js.nft.json +1 -1
  250. package/app/.next/server/app/api/tunnel/tailscale-login/route.js +1 -15
  251. package/app/.next/server/app/api/tunnel/tailscale-login/route.js.nft.json +1 -1
  252. package/app/.next/server/app/api/tunnel/tailscale-start-daemon/route.js +2 -2
  253. package/app/.next/server/app/api/tunnel/tailscale-start-daemon/route.js.nft.json +1 -1
  254. package/app/.next/server/app/api/usage/[connectionId]/route.js +1 -1
  255. package/app/.next/server/app/api/usage/[connectionId]/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/providers/route.js +1 -1
  261. package/app/.next/server/app/api/usage/providers/route.js.nft.json +1 -1
  262. package/app/.next/server/app/api/usage/request-details/route.js +1 -1
  263. package/app/.next/server/app/api/usage/request-details/route.js.nft.json +1 -1
  264. package/app/.next/server/app/api/usage/request-logs/route.js +1 -1
  265. package/app/.next/server/app/api/usage/request-logs/route.js.nft.json +1 -1
  266. package/app/.next/server/app/api/usage/stats/route.js +1 -1
  267. package/app/.next/server/app/api/usage/stats/route.js.nft.json +1 -1
  268. package/app/.next/server/app/api/usage/stream/route.js +2 -2
  269. package/app/.next/server/app/api/usage/stream/route.js.nft.json +1 -1
  270. package/app/.next/server/app/api/v1/api/chat/route.js +1 -1
  271. package/app/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
  272. package/app/.next/server/app/api/v1/audio/speech/route.js +1 -1
  273. package/app/.next/server/app/api/v1/audio/speech/route.js.nft.json +1 -1
  274. package/app/.next/server/app/api/v1/audio/transcriptions/route.js +1 -1
  275. package/app/.next/server/app/api/v1/audio/transcriptions/route.js.nft.json +1 -1
  276. package/app/.next/server/app/api/v1/audio/voices/route.js +1 -1
  277. package/app/.next/server/app/api/v1/chat/completions/route.js +1 -1
  278. package/app/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
  279. package/app/.next/server/app/api/v1/embeddings/route.js +1 -1
  280. package/app/.next/server/app/api/v1/embeddings/route.js.nft.json +1 -1
  281. package/app/.next/server/app/api/v1/images/generations/route.js +2 -2
  282. package/app/.next/server/app/api/v1/images/generations/route.js.nft.json +1 -1
  283. package/app/.next/server/app/api/v1/messages/count_tokens/route.js +1 -1
  284. package/app/.next/server/app/api/v1/messages/route.js +1 -1
  285. package/app/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
  286. package/app/.next/server/app/api/v1/models/[kind]/route.js +1 -1
  287. package/app/.next/server/app/api/v1/models/[kind]/route.js.nft.json +1 -1
  288. package/app/.next/server/app/api/v1/models/info/route.js +1 -1
  289. package/app/.next/server/app/api/v1/models/route.js +1 -1
  290. package/app/.next/server/app/api/v1/models/route.js.nft.json +1 -1
  291. package/app/.next/server/app/api/v1/responses/compact/route.js +1 -1
  292. package/app/.next/server/app/api/v1/responses/compact/route.js.nft.json +1 -1
  293. package/app/.next/server/app/api/v1/responses/route.js +1 -1
  294. package/app/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
  295. package/app/.next/server/app/api/v1/route.js +1 -1
  296. package/app/.next/server/app/api/v1/route.js.nft.json +1 -1
  297. package/app/.next/server/app/api/v1/search/route.js +1 -1
  298. package/app/.next/server/app/api/v1/search/route.js.nft.json +1 -1
  299. package/app/.next/server/app/api/v1/web/fetch/route.js +1 -1
  300. package/app/.next/server/app/api/v1/web/fetch/route.js.nft.json +1 -1
  301. package/app/.next/server/app/api/v1beta/models/[...path]/route.js +1 -1
  302. package/app/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
  303. package/app/.next/server/app/api/v1beta/models/route.js +1 -1
  304. package/app/.next/server/app/api/version/route.js +1 -1
  305. package/app/.next/server/app/api/version/shutdown/route.js +1 -1
  306. package/app/.next/server/app/api/version/update/route.js +1 -1
  307. package/app/.next/server/app/callback/page.js +2 -2
  308. package/app/.next/server/app/callback/page.js.nft.json +1 -1
  309. package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
  310. package/app/.next/server/app/callback.html +1 -1
  311. package/app/.next/server/app/callback.rsc +22 -24
  312. package/app/.next/server/app/callback.segments/_full.segment.rsc +22 -24
  313. package/app/.next/server/app/callback.segments/_head.segment.rsc +1 -1
  314. package/app/.next/server/app/callback.segments/_index.segment.rsc +7 -9
  315. package/app/.next/server/app/callback.segments/_tree.segment.rsc +3 -4
  316. package/app/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +2 -2
  317. package/app/.next/server/app/callback.segments/callback.segment.rsc +1 -1
  318. package/app/.next/server/app/dashboard/basic-chat.html +1 -1
  319. package/app/.next/server/app/dashboard/basic-chat.rsc +20 -22
  320. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat/__PAGE__.segment.rsc +2 -2
  321. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat.segment.rsc +1 -1
  322. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  323. package/app/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  324. package/app/.next/server/app/dashboard/basic-chat.segments/_full.segment.rsc +20 -22
  325. package/app/.next/server/app/dashboard/basic-chat.segments/_head.segment.rsc +1 -1
  326. package/app/.next/server/app/dashboard/basic-chat.segments/_index.segment.rsc +7 -9
  327. package/app/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +3 -4
  328. package/app/.next/server/app/dashboard/cli-tools.html +1 -1
  329. package/app/.next/server/app/dashboard/cli-tools.rsc +21 -23
  330. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +2 -2
  331. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +1 -1
  332. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  333. package/app/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  334. package/app/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +21 -23
  335. package/app/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +1 -1
  336. package/app/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +7 -9
  337. package/app/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +3 -4
  338. package/app/.next/server/app/dashboard/combos.html +1 -1
  339. package/app/.next/server/app/dashboard/combos.rsc +23 -25
  340. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +2 -2
  341. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +1 -1
  342. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  343. package/app/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  344. package/app/.next/server/app/dashboard/combos.segments/_full.segment.rsc +23 -25
  345. package/app/.next/server/app/dashboard/combos.segments/_head.segment.rsc +1 -1
  346. package/app/.next/server/app/dashboard/combos.segments/_index.segment.rsc +7 -9
  347. package/app/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +3 -4
  348. package/app/.next/server/app/dashboard/endpoint.html +1 -1
  349. package/app/.next/server/app/dashboard/endpoint.rsc +21 -23
  350. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +2 -2
  351. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +1 -1
  352. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  353. package/app/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  354. package/app/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +21 -23
  355. package/app/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +1 -1
  356. package/app/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +7 -9
  357. package/app/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +3 -4
  358. package/app/.next/server/app/dashboard/media-providers/web.html +1 -1
  359. package/app/.next/server/app/dashboard/media-providers/web.rsc +23 -27
  360. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard/media-providers/web/__PAGE__.segment.rsc +2 -2
  361. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard/media-providers/web.segment.rsc +1 -1
  362. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard/media-providers.segment.rsc +1 -1
  363. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  364. package/app/.next/server/app/dashboard/media-providers/web.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  365. package/app/.next/server/app/dashboard/media-providers/web.segments/_full.segment.rsc +23 -27
  366. package/app/.next/server/app/dashboard/media-providers/web.segments/_head.segment.rsc +1 -1
  367. package/app/.next/server/app/dashboard/media-providers/web.segments/_index.segment.rsc +7 -9
  368. package/app/.next/server/app/dashboard/media-providers/web.segments/_tree.segment.rsc +3 -4
  369. package/app/.next/server/app/dashboard/mitm.html +1 -1
  370. package/app/.next/server/app/dashboard/mitm.rsc +20 -22
  371. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm/__PAGE__.segment.rsc +2 -2
  372. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm.segment.rsc +1 -1
  373. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  374. package/app/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  375. package/app/.next/server/app/dashboard/mitm.segments/_full.segment.rsc +20 -22
  376. package/app/.next/server/app/dashboard/mitm.segments/_head.segment.rsc +1 -1
  377. package/app/.next/server/app/dashboard/mitm.segments/_index.segment.rsc +7 -9
  378. package/app/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +3 -4
  379. package/app/.next/server/app/dashboard/profile.html +1 -1
  380. package/app/.next/server/app/dashboard/profile.rsc +23 -26
  381. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +2 -2
  382. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +1 -1
  383. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  384. package/app/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  385. package/app/.next/server/app/dashboard/profile.segments/_full.segment.rsc +23 -26
  386. package/app/.next/server/app/dashboard/profile.segments/_head.segment.rsc +1 -1
  387. package/app/.next/server/app/dashboard/profile.segments/_index.segment.rsc +7 -9
  388. package/app/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +3 -4
  389. package/app/.next/server/app/dashboard/providers/new.html +1 -1
  390. package/app/.next/server/app/dashboard/providers/new.rsc +23 -27
  391. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +2 -2
  392. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +1 -1
  393. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  394. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  395. package/app/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  396. package/app/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +23 -27
  397. package/app/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +1 -1
  398. package/app/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +7 -9
  399. package/app/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +3 -4
  400. package/app/.next/server/app/dashboard/providers.html +1 -1
  401. package/app/.next/server/app/dashboard/providers.rsc +23 -26
  402. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +2 -2
  403. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +1 -1
  404. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  405. package/app/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  406. package/app/.next/server/app/dashboard/providers.segments/_full.segment.rsc +23 -26
  407. package/app/.next/server/app/dashboard/providers.segments/_head.segment.rsc +1 -1
  408. package/app/.next/server/app/dashboard/providers.segments/_index.segment.rsc +7 -9
  409. package/app/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +3 -4
  410. package/app/.next/server/app/dashboard/proxy-pools.html +1 -1
  411. package/app/.next/server/app/dashboard/proxy-pools.rsc +23 -26
  412. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools/__PAGE__.segment.rsc +2 -2
  413. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools.segment.rsc +1 -1
  414. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  415. package/app/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  416. package/app/.next/server/app/dashboard/proxy-pools.segments/_full.segment.rsc +23 -26
  417. package/app/.next/server/app/dashboard/proxy-pools.segments/_head.segment.rsc +1 -1
  418. package/app/.next/server/app/dashboard/proxy-pools.segments/_index.segment.rsc +7 -9
  419. package/app/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +3 -4
  420. package/app/.next/server/app/dashboard/quota.html +2 -2
  421. package/app/.next/server/app/dashboard/quota.rsc +21 -23
  422. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota/__PAGE__.segment.rsc +3 -3
  423. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota.segment.rsc +1 -1
  424. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  425. package/app/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  426. package/app/.next/server/app/dashboard/quota.segments/_full.segment.rsc +21 -23
  427. package/app/.next/server/app/dashboard/quota.segments/_head.segment.rsc +1 -1
  428. package/app/.next/server/app/dashboard/quota.segments/_index.segment.rsc +7 -9
  429. package/app/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +3 -4
  430. package/app/.next/server/app/dashboard/settings/pricing/page.js +2 -2
  431. package/app/.next/server/app/dashboard/settings/pricing/page.js.nft.json +1 -1
  432. package/app/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
  433. package/app/.next/server/app/dashboard/settings/pricing.html +1 -1
  434. package/app/.next/server/app/dashboard/settings/pricing.rsc +22 -24
  435. package/app/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +22 -24
  436. package/app/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +1 -1
  437. package/app/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +7 -9
  438. package/app/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +3 -4
  439. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +1 -1
  440. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +1 -1
  441. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +1 -1
  442. package/app/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +1 -1
  443. package/app/.next/server/app/dashboard/skills.html +1 -1
  444. package/app/.next/server/app/dashboard/skills.rsc +23 -25
  445. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk/dashboard/skills/__PAGE__.segment.rsc +2 -2
  446. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk/dashboard/skills.segment.rsc +1 -1
  447. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  448. package/app/.next/server/app/dashboard/skills.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  449. package/app/.next/server/app/dashboard/skills.segments/_full.segment.rsc +23 -25
  450. package/app/.next/server/app/dashboard/skills.segments/_head.segment.rsc +1 -1
  451. package/app/.next/server/app/dashboard/skills.segments/_index.segment.rsc +7 -9
  452. package/app/.next/server/app/dashboard/skills.segments/_tree.segment.rsc +3 -4
  453. package/app/.next/server/app/dashboard/translator.html +1 -1
  454. package/app/.next/server/app/dashboard/translator.rsc +23 -26
  455. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +2 -2
  456. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +1 -1
  457. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  458. package/app/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  459. package/app/.next/server/app/dashboard/translator.segments/_full.segment.rsc +23 -26
  460. package/app/.next/server/app/dashboard/translator.segments/_head.segment.rsc +1 -1
  461. package/app/.next/server/app/dashboard/translator.segments/_index.segment.rsc +7 -9
  462. package/app/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +3 -4
  463. package/app/.next/server/app/dashboard/usage.html +1 -1
  464. package/app/.next/server/app/dashboard/usage.rsc +23 -25
  465. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +2 -2
  466. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +1 -1
  467. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  468. package/app/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  469. package/app/.next/server/app/dashboard/usage.segments/_full.segment.rsc +23 -25
  470. package/app/.next/server/app/dashboard/usage.segments/_head.segment.rsc +1 -1
  471. package/app/.next/server/app/dashboard/usage.segments/_index.segment.rsc +7 -9
  472. package/app/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +3 -4
  473. package/app/.next/server/app/dashboard.html +1 -1
  474. package/app/.next/server/app/dashboard.rsc +21 -23
  475. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +2 -2
  476. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +1 -1
  477. package/app/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +2 -2
  478. package/app/.next/server/app/dashboard.segments/_full.segment.rsc +21 -23
  479. package/app/.next/server/app/dashboard.segments/_head.segment.rsc +1 -1
  480. package/app/.next/server/app/dashboard.segments/_index.segment.rsc +7 -9
  481. package/app/.next/server/app/dashboard.segments/_tree.segment.rsc +3 -4
  482. package/app/.next/server/app/favicon.ico/route.js +1 -1
  483. package/app/.next/server/app/index.html +1 -1
  484. package/app/.next/server/app/index.rsc +17 -19
  485. package/app/.next/server/app/index.segments/__PAGE__.segment.rsc +1 -1
  486. package/app/.next/server/app/index.segments/_full.segment.rsc +17 -19
  487. package/app/.next/server/app/index.segments/_head.segment.rsc +1 -1
  488. package/app/.next/server/app/index.segments/_index.segment.rsc +7 -9
  489. package/app/.next/server/app/index.segments/_tree.segment.rsc +3 -4
  490. package/app/.next/server/app/landing/page.js +2 -2
  491. package/app/.next/server/app/landing/page.js.nft.json +1 -1
  492. package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
  493. package/app/.next/server/app/landing.html +1 -1
  494. package/app/.next/server/app/landing.rsc +22 -24
  495. package/app/.next/server/app/landing.segments/_full.segment.rsc +22 -24
  496. package/app/.next/server/app/landing.segments/_head.segment.rsc +1 -1
  497. package/app/.next/server/app/landing.segments/_index.segment.rsc +7 -9
  498. package/app/.next/server/app/landing.segments/_tree.segment.rsc +3 -4
  499. package/app/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +1 -1
  500. package/app/.next/server/app/landing.segments/landing.segment.rsc +1 -1
  501. package/app/.next/server/app/login/page.js +2 -2
  502. package/app/.next/server/app/login/page.js.nft.json +1 -1
  503. package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
  504. package/app/.next/server/app/login.html +1 -1
  505. package/app/.next/server/app/login.rsc +22 -24
  506. package/app/.next/server/app/login.segments/_full.segment.rsc +22 -24
  507. package/app/.next/server/app/login.segments/_head.segment.rsc +1 -1
  508. package/app/.next/server/app/login.segments/_index.segment.rsc +7 -9
  509. package/app/.next/server/app/login.segments/_tree.segment.rsc +3 -4
  510. package/app/.next/server/app/login.segments/login/__PAGE__.segment.rsc +2 -2
  511. package/app/.next/server/app/login.segments/login.segment.rsc +1 -1
  512. package/app/.next/server/app/manifest.webmanifest/route.js +2 -2
  513. package/app/.next/server/app/page.js +2 -2
  514. package/app/.next/server/app/page.js.nft.json +1 -1
  515. package/app/.next/server/app/page_client-reference-manifest.js +1 -1
  516. package/app/.next/server/app-paths-manifest.json +14 -6
  517. package/app/.next/server/chunks/1071.js +1 -0
  518. package/app/.next/server/chunks/1574.js +1 -1
  519. package/app/.next/server/chunks/1578.js +1 -1
  520. package/app/.next/server/chunks/1795.js +1 -0
  521. package/app/.next/server/chunks/2009.js +1 -0
  522. package/app/.next/server/chunks/2035.js +39 -0
  523. package/app/.next/server/chunks/21.js +1 -1
  524. package/app/.next/server/chunks/2701.js +1 -0
  525. package/app/.next/server/chunks/3666.js +1 -0
  526. package/app/.next/server/chunks/3774.js +4 -3
  527. package/app/.next/server/chunks/450.js +5 -5
  528. package/app/.next/server/chunks/4723.js +1 -0
  529. package/app/.next/server/chunks/514.js +49 -0
  530. package/app/.next/server/chunks/5159.js +1 -1
  531. package/app/.next/server/chunks/5882.js +1 -0
  532. package/app/.next/server/chunks/6263.js +2 -2
  533. package/app/.next/server/chunks/6283.js +1 -1
  534. package/app/.next/server/chunks/6379.js +3 -3
  535. package/app/.next/server/chunks/6634.js +7 -0
  536. package/app/.next/server/chunks/6799.js +1 -1
  537. package/app/.next/server/chunks/7301.js +1 -1
  538. package/app/.next/server/chunks/7417.js +1 -0
  539. package/app/.next/server/chunks/7686.js +13 -0
  540. package/app/.next/server/chunks/7810.js +1 -1
  541. package/app/.next/server/chunks/7973.js +1 -1
  542. package/app/.next/server/chunks/8012.js +15 -0
  543. package/app/.next/server/chunks/8035.js +1 -1
  544. package/app/.next/server/chunks/8202.js +4 -4
  545. package/app/.next/server/chunks/8647.js +1 -1
  546. package/app/.next/server/chunks/9737.js +1 -1
  547. package/app/.next/server/functions-config-manifest.json +2 -0
  548. package/app/.next/server/middleware-build-manifest.js +1 -1
  549. package/app/.next/server/middleware.js +4 -4
  550. package/app/.next/server/pages/404.html +1 -1
  551. package/app/.next/server/pages/500.html +1 -1
  552. package/app/.next/server/server-reference-manifest.js +1 -1
  553. package/app/.next/server/server-reference-manifest.json +1 -1
  554. package/app/.next/static/chunks/4156-c8bd7124d8219ccc.js +7 -0
  555. package/app/.next/static/chunks/505-39ae32473371c4a3.js +1 -0
  556. package/app/.next/static/chunks/5810-9924ce14d1c08095.js +39 -0
  557. package/app/.next/static/chunks/8035-49b6b5ee48c18a8f.js +3 -0
  558. package/app/.next/static/chunks/app/(dashboard)/dashboard/basic-chat/page-03929d42abde11dc.js +1 -0
  559. package/app/.next/static/chunks/app/(dashboard)/dashboard/cli-tools/{page-8ff504b85ad321a1.js → page-c59d764c4311535a.js} +1 -1
  560. package/app/.next/static/chunks/app/(dashboard)/dashboard/mitm/{page-bad9a5af75575018.js → page-e9d61c090a6ab757.js} +1 -1
  561. package/app/.next/static/chunks/app/(dashboard)/dashboard/profile/page-3582cb03c9ef5dd8.js +1 -0
  562. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/page-4cb14309c0658008.js +1 -0
  563. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/page-5c83526aa571f533.js +1 -0
  564. package/app/.next/static/chunks/app/_global-error/page-42ea861e9cbd3f66.js +1 -0
  565. package/app/.next/static/chunks/app/api/auth/login/route-42ea861e9cbd3f66.js +1 -0
  566. package/app/.next/static/chunks/app/api/auth/logout/route-42ea861e9cbd3f66.js +1 -0
  567. package/app/.next/static/chunks/app/api/auth/oidc/callback/route-42ea861e9cbd3f66.js +1 -0
  568. package/app/.next/static/chunks/app/api/auth/oidc/start/route-42ea861e9cbd3f66.js +1 -0
  569. package/app/.next/static/chunks/app/api/auth/oidc/test/route-42ea861e9cbd3f66.js +1 -0
  570. package/app/.next/static/chunks/app/api/auth/status/route-42ea861e9cbd3f66.js +1 -0
  571. package/app/.next/static/chunks/app/api/cli-tools/all-statuses/route-42ea861e9cbd3f66.js +1 -0
  572. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-42ea861e9cbd3f66.js +1 -0
  573. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-42ea861e9cbd3f66.js +1 -0
  574. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-42ea861e9cbd3f66.js +1 -0
  575. package/app/.next/static/chunks/app/api/cli-tools/cline-settings/route-42ea861e9cbd3f66.js +1 -0
  576. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-42ea861e9cbd3f66.js +1 -0
  577. package/app/.next/static/chunks/app/api/cli-tools/copilot-settings/route-42ea861e9cbd3f66.js +1 -0
  578. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-registry/route-42ea861e9cbd3f66.js +1 -0
  579. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-tools/route-42ea861e9cbd3f66.js +1 -0
  580. package/app/.next/static/chunks/app/api/cli-tools/cowork-settings/route-42ea861e9cbd3f66.js +1 -0
  581. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-42ea861e9cbd3f66.js +1 -0
  582. package/app/.next/static/chunks/app/api/cli-tools/hermes-settings/route-42ea861e9cbd3f66.js +1 -0
  583. package/app/.next/static/chunks/app/api/cli-tools/kilo-settings/route-42ea861e9cbd3f66.js +1 -0
  584. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-42ea861e9cbd3f66.js +1 -0
  585. package/app/.next/static/chunks/app/api/cli-tools/opencode-settings/route-42ea861e9cbd3f66.js +1 -0
  586. package/app/.next/static/chunks/app/api/cloud/auth/route-42ea861e9cbd3f66.js +1 -0
  587. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-42ea861e9cbd3f66.js +1 -0
  588. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-42ea861e9cbd3f66.js +1 -0
  589. package/app/.next/static/chunks/app/api/cloud/models/alias/route-42ea861e9cbd3f66.js +1 -0
  590. package/app/.next/static/chunks/app/api/combos/[id]/route-42ea861e9cbd3f66.js +1 -0
  591. package/app/.next/static/chunks/app/api/combos/route-42ea861e9cbd3f66.js +1 -0
  592. package/app/.next/static/chunks/app/api/health/route-42ea861e9cbd3f66.js +1 -0
  593. package/app/.next/static/chunks/app/api/init/route-42ea861e9cbd3f66.js +1 -0
  594. package/app/.next/static/chunks/app/api/keys/[id]/route-42ea861e9cbd3f66.js +1 -0
  595. package/app/.next/static/chunks/app/api/keys/route-42ea861e9cbd3f66.js +1 -0
  596. package/app/.next/static/chunks/app/api/locale/route-42ea861e9cbd3f66.js +1 -0
  597. package/app/.next/static/chunks/app/api/mcp/[plugin]/message/route-42ea861e9cbd3f66.js +1 -0
  598. package/app/.next/static/chunks/app/api/mcp/[plugin]/sse/route-42ea861e9cbd3f66.js +1 -0
  599. package/app/.next/static/chunks/app/api/media-providers/tts/deepgram/voices/route-42ea861e9cbd3f66.js +1 -0
  600. package/app/.next/static/chunks/app/api/media-providers/tts/elevenlabs/voices/route-42ea861e9cbd3f66.js +1 -0
  601. package/app/.next/static/chunks/app/api/media-providers/tts/inworld/voices/route-42ea861e9cbd3f66.js +1 -0
  602. package/app/.next/static/chunks/app/api/media-providers/tts/voices/route-42ea861e9cbd3f66.js +1 -0
  603. package/app/.next/static/chunks/app/api/models/alias/route-42ea861e9cbd3f66.js +1 -0
  604. package/app/.next/static/chunks/app/api/models/availability/route-42ea861e9cbd3f66.js +1 -0
  605. package/app/.next/static/chunks/app/api/models/custom/route-42ea861e9cbd3f66.js +1 -0
  606. package/app/.next/static/chunks/app/api/models/disabled/route-42ea861e9cbd3f66.js +1 -0
  607. package/app/.next/static/chunks/app/api/models/route-42ea861e9cbd3f66.js +1 -0
  608. package/app/.next/static/chunks/app/api/models/test/route-42ea861e9cbd3f66.js +1 -0
  609. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-42ea861e9cbd3f66.js +1 -0
  610. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-42ea861e9cbd3f66.js +1 -0
  611. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-42ea861e9cbd3f66.js +1 -0
  612. package/app/.next/static/chunks/app/api/oauth/gitlab/pat/route-42ea861e9cbd3f66.js +1 -0
  613. package/app/.next/static/chunks/app/api/oauth/iflow/cookie/route-42ea861e9cbd3f66.js +1 -0
  614. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-42ea861e9cbd3f66.js +1 -0
  615. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-42ea861e9cbd3f66.js +1 -0
  616. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-42ea861e9cbd3f66.js +1 -0
  617. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-42ea861e9cbd3f66.js +1 -0
  618. package/app/.next/static/chunks/app/api/pricing/route-42ea861e9cbd3f66.js +1 -0
  619. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-42ea861e9cbd3f66.js +1 -0
  620. package/app/.next/static/chunks/app/api/provider-nodes/route-42ea861e9cbd3f66.js +1 -0
  621. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-42ea861e9cbd3f66.js +1 -0
  622. package/app/.next/static/chunks/app/api/providers/[id]/models/route-42ea861e9cbd3f66.js +1 -0
  623. package/app/.next/static/chunks/app/api/providers/[id]/route-42ea861e9cbd3f66.js +1 -0
  624. package/app/.next/static/chunks/app/api/providers/[id]/test/route-42ea861e9cbd3f66.js +1 -0
  625. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-42ea861e9cbd3f66.js +1 -0
  626. package/app/.next/static/chunks/app/api/providers/client/route-42ea861e9cbd3f66.js +1 -0
  627. package/app/.next/static/chunks/app/api/providers/kilo/free-models/route-42ea861e9cbd3f66.js +1 -0
  628. package/app/.next/static/chunks/app/api/providers/route-42ea861e9cbd3f66.js +1 -0
  629. package/app/.next/static/chunks/app/api/providers/suggested-models/route-42ea861e9cbd3f66.js +1 -0
  630. package/app/.next/static/chunks/app/api/providers/test-batch/route-42ea861e9cbd3f66.js +1 -0
  631. package/app/.next/static/chunks/app/api/providers/validate/route-42ea861e9cbd3f66.js +1 -0
  632. package/app/.next/static/chunks/app/api/proxy-pools/[id]/route-42ea861e9cbd3f66.js +1 -0
  633. package/app/.next/static/chunks/app/api/proxy-pools/[id]/test/route-42ea861e9cbd3f66.js +1 -0
  634. package/app/.next/static/chunks/app/api/proxy-pools/route-42ea861e9cbd3f66.js +1 -0
  635. package/app/.next/static/chunks/app/api/proxy-pools/vercel-deploy/route-42ea861e9cbd3f66.js +1 -0
  636. package/app/.next/static/chunks/app/api/settings/database/route-42ea861e9cbd3f66.js +1 -0
  637. package/app/.next/static/chunks/app/api/settings/proxy-test/route-42ea861e9cbd3f66.js +1 -0
  638. package/app/.next/static/chunks/app/api/settings/require-login/route-42ea861e9cbd3f66.js +1 -0
  639. package/app/.next/static/chunks/app/api/settings/route-42ea861e9cbd3f66.js +1 -0
  640. package/app/.next/static/chunks/app/api/shutdown/route-42ea861e9cbd3f66.js +1 -0
  641. package/app/.next/static/chunks/app/api/tags/route-42ea861e9cbd3f66.js +1 -0
  642. package/app/.next/static/chunks/app/api/translator/console-logs/route-42ea861e9cbd3f66.js +1 -0
  643. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-42ea861e9cbd3f66.js +1 -0
  644. package/app/.next/static/chunks/app/api/translator/load/route-42ea861e9cbd3f66.js +1 -0
  645. package/app/.next/static/chunks/app/api/translator/save/route-42ea861e9cbd3f66.js +1 -0
  646. package/app/.next/static/chunks/app/api/translator/send/route-42ea861e9cbd3f66.js +1 -0
  647. package/app/.next/static/chunks/app/api/translator/translate/route-42ea861e9cbd3f66.js +1 -0
  648. package/app/.next/static/chunks/app/api/tunnel/disable/route-42ea861e9cbd3f66.js +1 -0
  649. package/app/.next/static/chunks/app/api/tunnel/enable/route-42ea861e9cbd3f66.js +1 -0
  650. package/app/.next/static/chunks/app/api/tunnel/status/route-42ea861e9cbd3f66.js +1 -0
  651. package/app/.next/static/chunks/app/api/tunnel/tailscale-check/route-42ea861e9cbd3f66.js +1 -0
  652. package/app/.next/static/chunks/app/api/tunnel/tailscale-disable/route-42ea861e9cbd3f66.js +1 -0
  653. package/app/.next/static/chunks/app/api/tunnel/tailscale-enable/route-42ea861e9cbd3f66.js +1 -0
  654. package/app/.next/static/chunks/app/api/tunnel/tailscale-install/route-42ea861e9cbd3f66.js +1 -0
  655. package/app/.next/static/chunks/app/api/tunnel/tailscale-login/route-42ea861e9cbd3f66.js +1 -0
  656. package/app/.next/static/chunks/app/api/tunnel/tailscale-start-daemon/route-42ea861e9cbd3f66.js +1 -0
  657. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-42ea861e9cbd3f66.js +1 -0
  658. package/app/.next/static/chunks/app/api/usage/chart/route-42ea861e9cbd3f66.js +1 -0
  659. package/app/.next/static/chunks/app/api/usage/history/route-42ea861e9cbd3f66.js +1 -0
  660. package/app/.next/static/chunks/app/api/usage/providers/route-42ea861e9cbd3f66.js +1 -0
  661. package/app/.next/static/chunks/app/api/usage/request-details/route-42ea861e9cbd3f66.js +1 -0
  662. package/app/.next/static/chunks/app/api/usage/request-logs/route-42ea861e9cbd3f66.js +1 -0
  663. package/app/.next/static/chunks/app/api/usage/stats/route-42ea861e9cbd3f66.js +1 -0
  664. package/app/.next/static/chunks/app/api/usage/stream/route-42ea861e9cbd3f66.js +1 -0
  665. package/app/.next/static/chunks/app/api/v1/api/chat/route-42ea861e9cbd3f66.js +1 -0
  666. package/app/.next/static/chunks/app/api/v1/audio/speech/route-42ea861e9cbd3f66.js +1 -0
  667. package/app/.next/static/chunks/app/api/v1/audio/transcriptions/route-42ea861e9cbd3f66.js +1 -0
  668. package/app/.next/static/chunks/app/api/v1/audio/voices/route-42ea861e9cbd3f66.js +1 -0
  669. package/app/.next/static/chunks/app/api/v1/chat/completions/route-42ea861e9cbd3f66.js +1 -0
  670. package/app/.next/static/chunks/app/api/v1/embeddings/route-42ea861e9cbd3f66.js +1 -0
  671. package/app/.next/static/chunks/app/api/v1/images/generations/route-42ea861e9cbd3f66.js +1 -0
  672. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-42ea861e9cbd3f66.js +1 -0
  673. package/app/.next/static/chunks/app/api/v1/messages/route-42ea861e9cbd3f66.js +1 -0
  674. package/app/.next/static/chunks/app/api/v1/models/[kind]/route-42ea861e9cbd3f66.js +1 -0
  675. package/app/.next/static/chunks/app/api/v1/models/info/route-42ea861e9cbd3f66.js +1 -0
  676. package/app/.next/static/chunks/app/api/v1/models/route-42ea861e9cbd3f66.js +1 -0
  677. package/app/.next/static/chunks/app/api/v1/responses/compact/route-42ea861e9cbd3f66.js +1 -0
  678. package/app/.next/static/chunks/app/api/v1/responses/route-42ea861e9cbd3f66.js +1 -0
  679. package/app/.next/static/chunks/app/api/v1/route-42ea861e9cbd3f66.js +1 -0
  680. package/app/.next/static/chunks/app/api/v1/search/route-42ea861e9cbd3f66.js +1 -0
  681. package/app/.next/static/chunks/app/api/v1/web/fetch/route-42ea861e9cbd3f66.js +1 -0
  682. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-42ea861e9cbd3f66.js +1 -0
  683. package/app/.next/static/chunks/app/api/v1beta/models/route-42ea861e9cbd3f66.js +1 -0
  684. package/app/.next/static/chunks/app/api/version/route-42ea861e9cbd3f66.js +1 -0
  685. package/app/.next/static/chunks/app/api/version/shutdown/route-42ea861e9cbd3f66.js +1 -0
  686. package/app/.next/static/chunks/app/api/version/update/route-42ea861e9cbd3f66.js +1 -0
  687. package/app/.next/static/chunks/app/callback/page-6ea4675be396cdb5.js +1 -0
  688. package/app/.next/static/chunks/app/layout-fcda570933db809f.js +1 -0
  689. package/app/.next/static/chunks/app/login/page-dc885cca61893e2a.js +1 -0
  690. package/app/.next/static/chunks/app/manifest.webmanifest/route-42ea861e9cbd3f66.js +1 -0
  691. package/app/.next/static/chunks/app/page-42ea861e9cbd3f66.js +1 -0
  692. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-42ea861e9cbd3f66.js +1 -0
  693. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-42ea861e9cbd3f66.js +1 -0
  694. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-42ea861e9cbd3f66.js +1 -0
  695. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-42ea861e9cbd3f66.js +1 -0
  696. package/app/.next/static/chunks/{webpack-86e40ea2022f394c.js → webpack-ab7d9d893d55abd4.js} +1 -1
  697. package/app/.next/static/css/{081a0afca5a9bd20.css → 2e1b7d528c228ec3.css} +1 -1
  698. package/app/.next/static/css/a6ccc343d8389dcd.css +1 -0
  699. package/app/.next/static/media/material-symbols-outlined.1060ac06.woff2 +0 -0
  700. package/app/.next/static/xjtYx1FfVtGAPQbE4LiMu/_buildManifest.js +1 -0
  701. package/app/package.json +2 -1
  702. package/app/server.js +1 -1
  703. package/app/src/mitm/server.js +41 -43
  704. package/hooks/sqliteRuntime.js +4 -4
  705. package/package.json +1 -1
  706. package/src/cli/api/client.js +31 -0
  707. package/src/cli/menus/providers.js +240 -5
  708. package/src/cli/menus/settings.js +33 -0
  709. package/app/.next/server/chunks/2049.js +0 -1
  710. package/app/.next/server/chunks/2371.js +0 -1
  711. package/app/.next/server/chunks/4116.js +0 -1
  712. package/app/.next/server/chunks/4839.js +0 -1
  713. package/app/.next/server/chunks/4892.js +0 -13
  714. package/app/.next/server/chunks/523.js +0 -1
  715. package/app/.next/server/chunks/5978.js +0 -1
  716. package/app/.next/server/chunks/6890.js +0 -23
  717. package/app/.next/server/chunks/7690.js +0 -1
  718. package/app/.next/server/chunks/8367.js +0 -29
  719. package/app/.next/static/chunks/1939-d9b80a9e484ae21d.js +0 -23
  720. package/app/.next/static/chunks/4156-3a7b60c65001de9a.js +0 -7
  721. package/app/.next/static/chunks/505-34993b83fbc3f56a.js +0 -1
  722. package/app/.next/static/chunks/8035-b43a2fdebf8069b1.js +0 -3
  723. package/app/.next/static/chunks/app/(dashboard)/dashboard/basic-chat/page-cd02fe7b10810144.js +0 -1
  724. package/app/.next/static/chunks/app/(dashboard)/dashboard/profile/page-d632fe470928df04.js +0 -1
  725. package/app/.next/static/chunks/app/(dashboard)/dashboard/providers/page-6c6bb4f9b3b7e5f8.js +0 -1
  726. package/app/.next/static/chunks/app/(dashboard)/dashboard/usage/page-92b9dd8c50ab5e50.js +0 -1
  727. package/app/.next/static/chunks/app/_global-error/page-5ea305bd1a1dc348.js +0 -1
  728. package/app/.next/static/chunks/app/api/auth/login/route-5ea305bd1a1dc348.js +0 -1
  729. package/app/.next/static/chunks/app/api/auth/logout/route-5ea305bd1a1dc348.js +0 -1
  730. package/app/.next/static/chunks/app/api/cli-tools/all-statuses/route-5ea305bd1a1dc348.js +0 -1
  731. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/alias/route-5ea305bd1a1dc348.js +0 -1
  732. package/app/.next/static/chunks/app/api/cli-tools/antigravity-mitm/route-5ea305bd1a1dc348.js +0 -1
  733. package/app/.next/static/chunks/app/api/cli-tools/claude-settings/route-5ea305bd1a1dc348.js +0 -1
  734. package/app/.next/static/chunks/app/api/cli-tools/codex-settings/route-5ea305bd1a1dc348.js +0 -1
  735. package/app/.next/static/chunks/app/api/cli-tools/copilot-settings/route-5ea305bd1a1dc348.js +0 -1
  736. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-registry/route-5ea305bd1a1dc348.js +0 -1
  737. package/app/.next/static/chunks/app/api/cli-tools/cowork-mcp-tools/route-5ea305bd1a1dc348.js +0 -1
  738. package/app/.next/static/chunks/app/api/cli-tools/cowork-settings/route-5ea305bd1a1dc348.js +0 -1
  739. package/app/.next/static/chunks/app/api/cli-tools/droid-settings/route-5ea305bd1a1dc348.js +0 -1
  740. package/app/.next/static/chunks/app/api/cli-tools/hermes-settings/route-5ea305bd1a1dc348.js +0 -1
  741. package/app/.next/static/chunks/app/api/cli-tools/openclaw-settings/route-5ea305bd1a1dc348.js +0 -1
  742. package/app/.next/static/chunks/app/api/cli-tools/opencode-settings/route-5ea305bd1a1dc348.js +0 -1
  743. package/app/.next/static/chunks/app/api/cloud/auth/route-5ea305bd1a1dc348.js +0 -1
  744. package/app/.next/static/chunks/app/api/cloud/credentials/update/route-5ea305bd1a1dc348.js +0 -1
  745. package/app/.next/static/chunks/app/api/cloud/model/resolve/route-5ea305bd1a1dc348.js +0 -1
  746. package/app/.next/static/chunks/app/api/cloud/models/alias/route-5ea305bd1a1dc348.js +0 -1
  747. package/app/.next/static/chunks/app/api/combos/[id]/route-5ea305bd1a1dc348.js +0 -1
  748. package/app/.next/static/chunks/app/api/combos/route-5ea305bd1a1dc348.js +0 -1
  749. package/app/.next/static/chunks/app/api/health/route-5ea305bd1a1dc348.js +0 -1
  750. package/app/.next/static/chunks/app/api/init/route-5ea305bd1a1dc348.js +0 -1
  751. package/app/.next/static/chunks/app/api/keys/[id]/route-5ea305bd1a1dc348.js +0 -1
  752. package/app/.next/static/chunks/app/api/keys/route-5ea305bd1a1dc348.js +0 -1
  753. package/app/.next/static/chunks/app/api/locale/route-5ea305bd1a1dc348.js +0 -1
  754. package/app/.next/static/chunks/app/api/media-providers/tts/deepgram/voices/route-5ea305bd1a1dc348.js +0 -1
  755. package/app/.next/static/chunks/app/api/media-providers/tts/elevenlabs/voices/route-5ea305bd1a1dc348.js +0 -1
  756. package/app/.next/static/chunks/app/api/media-providers/tts/inworld/voices/route-5ea305bd1a1dc348.js +0 -1
  757. package/app/.next/static/chunks/app/api/media-providers/tts/voices/route-5ea305bd1a1dc348.js +0 -1
  758. package/app/.next/static/chunks/app/api/models/alias/route-5ea305bd1a1dc348.js +0 -1
  759. package/app/.next/static/chunks/app/api/models/availability/route-5ea305bd1a1dc348.js +0 -1
  760. package/app/.next/static/chunks/app/api/models/custom/route-5ea305bd1a1dc348.js +0 -1
  761. package/app/.next/static/chunks/app/api/models/disabled/route-5ea305bd1a1dc348.js +0 -1
  762. package/app/.next/static/chunks/app/api/models/route-5ea305bd1a1dc348.js +0 -1
  763. package/app/.next/static/chunks/app/api/models/test/route-5ea305bd1a1dc348.js +0 -1
  764. package/app/.next/static/chunks/app/api/oauth/[provider]/[action]/route-5ea305bd1a1dc348.js +0 -1
  765. package/app/.next/static/chunks/app/api/oauth/cursor/auto-import/route-5ea305bd1a1dc348.js +0 -1
  766. package/app/.next/static/chunks/app/api/oauth/cursor/import/route-5ea305bd1a1dc348.js +0 -1
  767. package/app/.next/static/chunks/app/api/oauth/gitlab/pat/route-5ea305bd1a1dc348.js +0 -1
  768. package/app/.next/static/chunks/app/api/oauth/iflow/cookie/route-5ea305bd1a1dc348.js +0 -1
  769. package/app/.next/static/chunks/app/api/oauth/kiro/auto-import/route-5ea305bd1a1dc348.js +0 -1
  770. package/app/.next/static/chunks/app/api/oauth/kiro/import/route-5ea305bd1a1dc348.js +0 -1
  771. package/app/.next/static/chunks/app/api/oauth/kiro/social-authorize/route-5ea305bd1a1dc348.js +0 -1
  772. package/app/.next/static/chunks/app/api/oauth/kiro/social-exchange/route-5ea305bd1a1dc348.js +0 -1
  773. package/app/.next/static/chunks/app/api/pricing/route-5ea305bd1a1dc348.js +0 -1
  774. package/app/.next/static/chunks/app/api/provider-nodes/[id]/route-5ea305bd1a1dc348.js +0 -1
  775. package/app/.next/static/chunks/app/api/provider-nodes/route-5ea305bd1a1dc348.js +0 -1
  776. package/app/.next/static/chunks/app/api/provider-nodes/validate/route-5ea305bd1a1dc348.js +0 -1
  777. package/app/.next/static/chunks/app/api/providers/[id]/models/route-5ea305bd1a1dc348.js +0 -1
  778. package/app/.next/static/chunks/app/api/providers/[id]/route-5ea305bd1a1dc348.js +0 -1
  779. package/app/.next/static/chunks/app/api/providers/[id]/test/route-5ea305bd1a1dc348.js +0 -1
  780. package/app/.next/static/chunks/app/api/providers/[id]/test-models/route-5ea305bd1a1dc348.js +0 -1
  781. package/app/.next/static/chunks/app/api/providers/client/route-5ea305bd1a1dc348.js +0 -1
  782. package/app/.next/static/chunks/app/api/providers/kilo/free-models/route-5ea305bd1a1dc348.js +0 -1
  783. package/app/.next/static/chunks/app/api/providers/route-5ea305bd1a1dc348.js +0 -1
  784. package/app/.next/static/chunks/app/api/providers/suggested-models/route-5ea305bd1a1dc348.js +0 -1
  785. package/app/.next/static/chunks/app/api/providers/test-batch/route-5ea305bd1a1dc348.js +0 -1
  786. package/app/.next/static/chunks/app/api/providers/validate/route-5ea305bd1a1dc348.js +0 -1
  787. package/app/.next/static/chunks/app/api/proxy-pools/[id]/route-5ea305bd1a1dc348.js +0 -1
  788. package/app/.next/static/chunks/app/api/proxy-pools/[id]/test/route-5ea305bd1a1dc348.js +0 -1
  789. package/app/.next/static/chunks/app/api/proxy-pools/route-5ea305bd1a1dc348.js +0 -1
  790. package/app/.next/static/chunks/app/api/proxy-pools/vercel-deploy/route-5ea305bd1a1dc348.js +0 -1
  791. package/app/.next/static/chunks/app/api/settings/database/route-5ea305bd1a1dc348.js +0 -1
  792. package/app/.next/static/chunks/app/api/settings/proxy-test/route-5ea305bd1a1dc348.js +0 -1
  793. package/app/.next/static/chunks/app/api/settings/require-login/route-5ea305bd1a1dc348.js +0 -1
  794. package/app/.next/static/chunks/app/api/settings/route-5ea305bd1a1dc348.js +0 -1
  795. package/app/.next/static/chunks/app/api/shutdown/route-5ea305bd1a1dc348.js +0 -1
  796. package/app/.next/static/chunks/app/api/tags/route-5ea305bd1a1dc348.js +0 -1
  797. package/app/.next/static/chunks/app/api/translator/console-logs/route-5ea305bd1a1dc348.js +0 -1
  798. package/app/.next/static/chunks/app/api/translator/console-logs/stream/route-5ea305bd1a1dc348.js +0 -1
  799. package/app/.next/static/chunks/app/api/translator/load/route-5ea305bd1a1dc348.js +0 -1
  800. package/app/.next/static/chunks/app/api/translator/save/route-5ea305bd1a1dc348.js +0 -1
  801. package/app/.next/static/chunks/app/api/translator/send/route-5ea305bd1a1dc348.js +0 -1
  802. package/app/.next/static/chunks/app/api/translator/translate/route-5ea305bd1a1dc348.js +0 -1
  803. package/app/.next/static/chunks/app/api/tunnel/disable/route-5ea305bd1a1dc348.js +0 -1
  804. package/app/.next/static/chunks/app/api/tunnel/enable/route-5ea305bd1a1dc348.js +0 -1
  805. package/app/.next/static/chunks/app/api/tunnel/status/route-5ea305bd1a1dc348.js +0 -1
  806. package/app/.next/static/chunks/app/api/tunnel/tailscale-check/route-5ea305bd1a1dc348.js +0 -1
  807. package/app/.next/static/chunks/app/api/tunnel/tailscale-disable/route-5ea305bd1a1dc348.js +0 -1
  808. package/app/.next/static/chunks/app/api/tunnel/tailscale-enable/route-5ea305bd1a1dc348.js +0 -1
  809. package/app/.next/static/chunks/app/api/tunnel/tailscale-install/route-5ea305bd1a1dc348.js +0 -1
  810. package/app/.next/static/chunks/app/api/tunnel/tailscale-login/route-5ea305bd1a1dc348.js +0 -1
  811. package/app/.next/static/chunks/app/api/tunnel/tailscale-start-daemon/route-5ea305bd1a1dc348.js +0 -1
  812. package/app/.next/static/chunks/app/api/usage/[connectionId]/route-5ea305bd1a1dc348.js +0 -1
  813. package/app/.next/static/chunks/app/api/usage/chart/route-5ea305bd1a1dc348.js +0 -1
  814. package/app/.next/static/chunks/app/api/usage/history/route-5ea305bd1a1dc348.js +0 -1
  815. package/app/.next/static/chunks/app/api/usage/providers/route-5ea305bd1a1dc348.js +0 -1
  816. package/app/.next/static/chunks/app/api/usage/request-details/route-5ea305bd1a1dc348.js +0 -1
  817. package/app/.next/static/chunks/app/api/usage/request-logs/route-5ea305bd1a1dc348.js +0 -1
  818. package/app/.next/static/chunks/app/api/usage/stats/route-5ea305bd1a1dc348.js +0 -1
  819. package/app/.next/static/chunks/app/api/usage/stream/route-5ea305bd1a1dc348.js +0 -1
  820. package/app/.next/static/chunks/app/api/v1/api/chat/route-5ea305bd1a1dc348.js +0 -1
  821. package/app/.next/static/chunks/app/api/v1/audio/speech/route-5ea305bd1a1dc348.js +0 -1
  822. package/app/.next/static/chunks/app/api/v1/audio/transcriptions/route-5ea305bd1a1dc348.js +0 -1
  823. package/app/.next/static/chunks/app/api/v1/audio/voices/route-5ea305bd1a1dc348.js +0 -1
  824. package/app/.next/static/chunks/app/api/v1/chat/completions/route-5ea305bd1a1dc348.js +0 -1
  825. package/app/.next/static/chunks/app/api/v1/embeddings/route-5ea305bd1a1dc348.js +0 -1
  826. package/app/.next/static/chunks/app/api/v1/images/generations/route-5ea305bd1a1dc348.js +0 -1
  827. package/app/.next/static/chunks/app/api/v1/messages/count_tokens/route-5ea305bd1a1dc348.js +0 -1
  828. package/app/.next/static/chunks/app/api/v1/messages/route-5ea305bd1a1dc348.js +0 -1
  829. package/app/.next/static/chunks/app/api/v1/models/[kind]/route-5ea305bd1a1dc348.js +0 -1
  830. package/app/.next/static/chunks/app/api/v1/models/info/route-5ea305bd1a1dc348.js +0 -1
  831. package/app/.next/static/chunks/app/api/v1/models/route-5ea305bd1a1dc348.js +0 -1
  832. package/app/.next/static/chunks/app/api/v1/responses/compact/route-5ea305bd1a1dc348.js +0 -1
  833. package/app/.next/static/chunks/app/api/v1/responses/route-5ea305bd1a1dc348.js +0 -1
  834. package/app/.next/static/chunks/app/api/v1/route-5ea305bd1a1dc348.js +0 -1
  835. package/app/.next/static/chunks/app/api/v1/search/route-5ea305bd1a1dc348.js +0 -1
  836. package/app/.next/static/chunks/app/api/v1/web/fetch/route-5ea305bd1a1dc348.js +0 -1
  837. package/app/.next/static/chunks/app/api/v1beta/models/[...path]/route-5ea305bd1a1dc348.js +0 -1
  838. package/app/.next/static/chunks/app/api/v1beta/models/route-5ea305bd1a1dc348.js +0 -1
  839. package/app/.next/static/chunks/app/api/version/route-5ea305bd1a1dc348.js +0 -1
  840. package/app/.next/static/chunks/app/api/version/shutdown/route-5ea305bd1a1dc348.js +0 -1
  841. package/app/.next/static/chunks/app/api/version/update/route-5ea305bd1a1dc348.js +0 -1
  842. package/app/.next/static/chunks/app/callback/page-80c520a5e353c3ac.js +0 -1
  843. package/app/.next/static/chunks/app/layout-c47481f46f5ae72b.js +0 -1
  844. package/app/.next/static/chunks/app/login/page-2f45309b2d2ca209.js +0 -1
  845. package/app/.next/static/chunks/app/manifest.webmanifest/route-5ea305bd1a1dc348.js +0 -1
  846. package/app/.next/static/chunks/app/page-5ea305bd1a1dc348.js +0 -1
  847. package/app/.next/static/chunks/next/dist/client/components/builtin/app-error-5ea305bd1a1dc348.js +0 -1
  848. package/app/.next/static/chunks/next/dist/client/components/builtin/forbidden-5ea305bd1a1dc348.js +0 -1
  849. package/app/.next/static/chunks/next/dist/client/components/builtin/not-found-5ea305bd1a1dc348.js +0 -1
  850. package/app/.next/static/chunks/next/dist/client/components/builtin/unauthorized-5ea305bd1a1dc348.js +0 -1
  851. package/app/.next/static/css/8c050f20c62e3425.css +0 -1
  852. package/app/.next/static/zRbzYKfSwZoKLIJvdVXO-/_buildManifest.js +0 -1
  853. /package/app/.next/static/{zRbzYKfSwZoKLIJvdVXO- → xjtYx1FfVtGAPQbE4LiMu}/_ssgManifest.js +0 -0
@@ -1,13 +0,0 @@
1
- exports.id=4892,exports.ids=[4892],exports.modules={20819:(a,b,c)=>{"use strict";c.d(b,{Xx:()=>j,exportSettings:()=>k,getSettings:()=>i});var d=c(90602),e=c(25456);let f={cloudEnabled:!1,tunnelEnabled:!1,tunnelUrl:"",tunnelProvider:"cloudflare",tailscaleEnabled:!1,tailscaleUrl:"",stickyRoundRobinLimit:3,providerStrategies:{},comboStrategy:"fallback",comboStickyRoundRobinLimit:1,comboStrategies:{},requireLogin:!0,tunnelDashboardAccess:!0,enableObservability:!0,observabilityMaxRecords:1e3,observabilityBatchSize:20,observabilityFlushIntervalMs:5e3,observabilityMaxJsonSize:5,outboundProxyEnabled:!1,outboundProxyUrl:"",outboundNoProxy:"",mitmRouterBaseUrl:"http://localhost:20128",dnsToolEnabled:{},rtkEnabled:!0,cavemanEnabled:!1,cavemanLevel:"full"};async function g(){let a=(await (0,d.c)()).get("SELECT data FROM settings WHERE id = 1");return a?(0,e.q)(a.data,{}):{}}function h(a){let b={...f,...a||{}};for(let[a,c]of Object.entries(f))void 0===b[a]&&("outboundProxyEnabled"===a&&"string"==typeof b.outboundProxyUrl&&b.outboundProxyUrl.trim()?b[a]=!0:b[a]=c);return b}async function i(){return h(await g())}async function j(a){let b,c=await (0,d.c)();return c.transaction(()=>{let d=c.get("SELECT data FROM settings WHERE id = 1");b={...d?(0,e.q)(d.data,{}):{},...a},c.run("INSERT INTO settings(id, data) VALUES(1, ?) ON CONFLICT(id) DO UPDATE SET data = excluded.data",[(0,e.s)(b)])}),h(b)}async function k(){return await g()}},24429:()=>{},25456:(a,b,c)=>{"use strict";function d(a,b=null){if(null==a)return b;if("string"!=typeof a)return a;try{return JSON.parse(a)}catch{return b}}function e(a){return JSON.stringify(a??null)}c.d(b,{q:()=>d,s:()=>e})},42928:(a,b,c)=>{"use strict";c.r(b),c.d(b,{createApiKey:()=>i,deleteApiKey:()=>k,getApiKeyById:()=>h,getApiKeys:()=>g,updateApiKey:()=>j,validateApiKey:()=>l});var d=c(37873),e=c(90602);function f(a){return a?{id:a.id,key:a.key,name:a.name,machineId:a.machineId,isActive:1===a.isActive||!0===a.isActive,createdAt:a.createdAt}:null}async function g(){return(await (0,e.c)()).all("SELECT * FROM apiKeys ORDER BY createdAt ASC").map(f)}async function h(a){return f((await (0,e.c)()).get("SELECT * FROM apiKeys WHERE id = ?",[a]))}async function i(a,b){if(!b)throw Error("machineId is required");let f=await (0,e.c)(),{generateApiKeyWithMachine:g}=await c.e(64).then(c.bind(c,50064)),h=g(b),i={id:(0,d.A)(),name:a,key:h.key,machineId:b,isActive:!0,createdAt:new Date().toISOString()};return f.run("INSERT INTO apiKeys(id, key, name, machineId, isActive, createdAt) VALUES(?, ?, ?, ?, ?, ?)",[i.id,i.key,i.name,i.machineId,1,i.createdAt]),i}async function j(a,b){let c=await (0,e.c)(),d=null;return c.transaction(()=>{let e=c.get("SELECT * FROM apiKeys WHERE id = ?",[a]);if(!e)return;let g={...f(e),...b};c.run("UPDATE apiKeys SET key = ?, name = ?, machineId = ?, isActive = ? WHERE id = ?",[g.key,g.name,g.machineId,+!!g.isActive,a]),d=g}),d}async function k(a){let b=(await (0,e.c)()).run("DELETE FROM apiKeys WHERE id = ?",[a]);return(b?.changes??0)>0}async function l(a){let b=(await (0,e.c)()).get("SELECT isActive FROM apiKeys WHERE key = ?",[a]);return!!b&&(1===b.isActive||!0===b.isActive)}},51412:(a,b,c)=>{"use strict";c.d(b,{S8:()=>H,E5:()=>af,bI:()=>g.cleanupProviderConnections,Iq:()=>q.createApiKey,jd:()=>v,iE:()=>g.createProviderConnection,i0:()=>h.createProviderNode,ZO:()=>n,Lh:()=>q.deleteApiKey,CG:()=>x,uL:()=>I,fv:()=>E,fK:()=>g.deleteProviderConnection,op:()=>g.deleteProviderConnectionsByProvider,Pc:()=>h.deleteProviderNode,Yd:()=>p,tm:()=>O,oF:()=>P,zP:()=>as,rg:()=>aa,yg:()=>q.getApiKeyById,PX:()=>q.getApiKeys,j$:()=>ae,L:()=>t,Dj:()=>u,Uv:()=>s,uv:()=>G,vF:()=>N,c:()=>J,OM:()=>C,r4:()=>L.r4,Mc:()=>g.getProviderConnectionById,P:()=>g.getProviderConnections,Qu:()=>h.getProviderNodeById,Fh:()=>h.getProviderNodes,hr:()=>m,ui:()=>l,Zx:()=>ag,SL:()=>aq,mt:()=>f.getSettings,BY:()=>ad,K1:()=>at,VT:()=>L.VT,yF:()=>L.yF,ox:()=>ap,sZ:()=>ab,L9:()=>K,o5:()=>D,_V:()=>W,uw:()=>_,XW:()=>q.updateApiKey,oG:()=>w,KJ:()=>L.KJ,rj:()=>g.updateProviderConnection,ho:()=>h.updateProviderNode,Q_:()=>o,Xx:()=>f.Xx,ek:()=>q.validateApiKey});var d=c(90602),e=c(25456),f=c(20819),g=c(98673),h=c(85885),i=c(37873);function j(a){return a?{...(0,e.q)(a.data,{}),id:a.id,isActive:1===a.isActive||!0===a.isActive,testStatus:a.testStatus,createdAt:a.createdAt,updatedAt:a.updatedAt}:null}function k(a,b){let c=function(a){let{id:b,isActive:c,testStatus:d,createdAt:f,updatedAt:g,...h}=a;return{id:b,isActive:+(!1!==c),testStatus:d??null,data:(0,e.s)(h),createdAt:f,updatedAt:g}}(b);a.run(`INSERT INTO proxyPools(id, isActive, testStatus, data, createdAt, updatedAt)
2
- VALUES(?, ?, ?, ?, ?, ?)
3
- ON CONFLICT(id) DO UPDATE SET
4
- isActive=excluded.isActive, testStatus=excluded.testStatus,
5
- data=excluded.data, updatedAt=excluded.updatedAt`,[c.id,c.isActive,c.testStatus,c.data,c.createdAt,c.updatedAt])}async function l(a={}){let b=await (0,d.c)(),c=[],e=[];void 0!==a.isActive&&(c.push("isActive = ?"),e.push(+!!a.isActive)),a.testStatus&&(c.push("testStatus = ?"),e.push(a.testStatus));let f=`SELECT * FROM proxyPools${c.length?` WHERE ${c.join(" AND ")}`:""}`,g=b.all(f,e).map(j);return g.sort((a,b)=>new Date(b.updatedAt||0)-new Date(a.updatedAt||0)),g}async function m(a){return j((await (0,d.c)()).get("SELECT * FROM proxyPools WHERE id = ?",[a]))}async function n(a){let b=await (0,d.c)(),c=new Date().toISOString(),e={id:a.id||(0,i.A)(),name:a.name,proxyUrl:a.proxyUrl,noProxy:a.noProxy||"",type:a.type||"http",isActive:void 0===a.isActive||a.isActive,strictProxy:!0===a.strictProxy,testStatus:a.testStatus||"unknown",lastTestedAt:a.lastTestedAt||null,lastError:a.lastError||null,createdAt:c,updatedAt:c};return k(b,e),e}async function o(a,b){let c=await (0,d.c)(),e=null;return c.transaction(()=>{let d=c.get("SELECT * FROM proxyPools WHERE id = ?",[a]);if(!d)return;let f={...j(d),...b,updatedAt:new Date().toISOString()};k(c,f),e=f}),e}async function p(a){let b=await (0,d.c)(),c=null;return b.transaction(()=>{let d=b.get("SELECT * FROM proxyPools WHERE id = ?",[a]);d&&(c=j(d),b.run("DELETE FROM proxyPools WHERE id = ?",[a]))}),c}var q=c(42928);function r(a){return a?{id:a.id,name:a.name,kind:a.kind,models:(0,e.q)(a.models,[]),createdAt:a.createdAt,updatedAt:a.updatedAt}:null}async function s(){return(await (0,d.c)()).all("SELECT * FROM combos ORDER BY createdAt ASC").map(r)}async function t(a){return r((await (0,d.c)()).get("SELECT * FROM combos WHERE id = ?",[a]))}async function u(a){return r((await (0,d.c)()).get("SELECT * FROM combos WHERE name = ?",[a]))}async function v(a){let b=await (0,d.c)(),c=new Date().toISOString(),f={id:(0,i.A)(),name:a.name,kind:a.kind||null,models:a.models||[],createdAt:c,updatedAt:c};return b.run("INSERT INTO combos(id, name, kind, models, createdAt, updatedAt) VALUES(?, ?, ?, ?, ?, ?)",[f.id,f.name,f.kind,(0,e.s)(f.models),f.createdAt,f.updatedAt]),f}async function w(a,b){let c=await (0,d.c)(),f=null;return c.transaction(()=>{let d=c.get("SELECT * FROM combos WHERE id = ?",[a]);if(!d)return;let g={...r(d),...b,updatedAt:new Date().toISOString()};c.run("UPDATE combos SET name = ?, kind = ?, models = ?, updatedAt = ? WHERE id = ?",[g.name,g.kind,(0,e.s)(g.models||[]),g.updatedAt,a]),f=g}),f}async function x(a){let b=(await (0,d.c)()).run("DELETE FROM combos WHERE id = ?",[a]);return(b?.changes??0)>0}var y=c(61034);let z=(0,y.U)("modelAliases"),A=(0,y.U)("customModels"),B=(0,y.U)("mitmAlias");async function C(){return await z.getAll()}async function D(a,b){await z.set(a,b)}async function E(a){await z.remove(a)}function F(a,b,c){return`${a}|${b}|${c}`}async function G(){return Object.values(await A.getAll())}async function H({providerAlias:a,id:b,type:c="llm",name:f}){let g=F(a,b,c),h=await (0,d.c)(),i=!1;return h.transaction(()=>{if(h.get("SELECT 1 FROM kv WHERE scope = 'customModels' AND key = ?",[g]))return;let d=(0,e.s)({providerAlias:a,id:b,type:c,name:f||b});h.run("INSERT INTO kv(scope, key, value) VALUES('customModels', ?, ?)",[g,d]),i=!0}),i}async function I({providerAlias:a,id:b,type:c="llm"}){await A.remove(F(a,b,c))}async function J(a){return a?await B.get(a)||{}:await B.getAll()}async function K(a,b){await B.set(a,b||{})}var L=c(98366);let M="disabledModels";async function N(){let a=(await (0,d.c)()).all("SELECT key, value FROM kv WHERE scope = ?",[M]),b={};for(let c of a)b[c.key]=(0,e.q)(c.value,[]);return b}async function O(a,b){if(!a||!Array.isArray(b))return;let c=await (0,d.c)();c.transaction(()=>{let d=c.get("SELECT value FROM kv WHERE scope = ? AND key = ?",[M,a]),f=[...new Set([...d&&(0,e.q)(d.value,[])||[],...b])];c.run("INSERT INTO kv(scope, key, value) VALUES(?, ?, ?) ON CONFLICT(scope, key) DO UPDATE SET value = excluded.value",[M,a,(0,e.s)(f)])})}async function P(a,b){if(!a)return;let c=await (0,d.c)();c.transaction(()=>{if(!Array.isArray(b)||0===b.length)return void c.run("DELETE FROM kv WHERE scope = ? AND key = ?",[M,a]);let d=c.get("SELECT value FROM kv WHERE scope = ? AND key = ?",[M,a]),f=d&&(0,e.q)(d.value,[])||[],g=new Set(b),h=f.filter(a=>!g.has(a));0===h.length?c.run("DELETE FROM kv WHERE scope = ? AND key = ?",[M,a]):c.run("INSERT INTO kv(scope, key, value) VALUES(?, ?, ?) ON CONFLICT(scope, key) DO UPDATE SET value = excluded.value",[M,a,(0,e.s)(h)])})}var Q=c(94735);c(75582);global._pendingRequests||(global._pendingRequests={byModel:{},byAccount:{}}),global._lastErrorProvider||(global._lastErrorProvider={provider:"",ts:0}),global._statsEmitter||(global._statsEmitter=new Q.EventEmitter,global._statsEmitter.setMaxListeners(50)),global._pendingTimers||(global._pendingTimers={}),global._recentRing||(global._recentRing={items:[],initialized:!1}),global._connectionMapCache||(global._connectionMapCache={map:{},ts:0});let R=global._pendingRequests,S=global._lastErrorProvider,T=global._pendingTimers,U=global._recentRing,V=global._connectionMapCache,W=global._statsEmitter;function X(a,b,c){a[b]||(a[b]={requests:0,promptTokens:0,completionTokens:0,cost:0}),a[b].requests+=c.requests||1,a[b].promptTokens+=c.promptTokens||0,a[b].completionTokens+=c.completionTokens||0,a[b].cost+=c.cost||0,c.meta&&Object.assign(a[b],c.meta)}async function Y(){if(Date.now()-V.ts<3e4)return V.map;try{let{getProviderConnections:a}=await Promise.resolve().then(c.bind(c,98673)),b=await a(),d={};for(let a of b)d[a.id]=a.name||a.email||a.id;V.map=d,V.ts=Date.now()}catch{}return V.map}async function Z(){if(!U.initialized){U.initialized=!0;try{U.items=(await (0,d.c)()).all("SELECT timestamp, provider, model, connectionId, apiKey, endpoint, cost, status, tokens FROM usageHistory ORDER BY id DESC LIMIT ?",[50]).reverse().map(a=>({timestamp:a.timestamp,provider:a.provider,model:a.model,connectionId:a.connectionId,apiKey:a.apiKey,endpoint:a.endpoint,cost:a.cost,status:a.status,tokens:(0,e.q)(a.tokens,{})}))}catch{}}}async function $(a,b,d){if(!d||!a||!b)return 0;try{let{getPricingForModel:e}=await Promise.resolve().then(c.bind(c,98366)),f=await e(a,b);if(!f)return 0;let g=0,h=d.prompt_tokens||d.input_tokens||0,i=d.cached_tokens||d.cache_read_input_tokens||0,j=Math.max(0,h-i);if(g+=j*(f.input/1e6),i>0){let a=f.cached||f.input;g+=a/1e6*i}let k=d.completion_tokens||d.output_tokens||0;g+=k*(f.output/1e6);let l=d.reasoning_tokens||0;if(l>0){let a=f.reasoning||f.output;g+=a/1e6*l}let m=d.cache_creation_input_tokens||0;if(m>0){let a=f.cache_creation||f.input;g+=a/1e6*m}return g}catch(a){return console.error("Error calculating cost:",a),0}}function _(a,b,c,d,e=!1){let f=b?`${a} (${b})`:a,g=`${c}|${f}`;R.byModel[f]||(R.byModel[f]=0),R.byModel[f]=Math.max(0,R.byModel[f]+(d?1:-1)),0===R.byModel[f]&&delete R.byModel[f],c&&(R.byAccount[c]||(R.byAccount[c]={}),R.byAccount[c][f]||(R.byAccount[c][f]=0),R.byAccount[c][f]=Math.max(0,R.byAccount[c][f]+(d?1:-1)),0===R.byAccount[c][f]&&(delete R.byAccount[c][f],0===Object.keys(R.byAccount[c]).length&&delete R.byAccount[c])),d?(clearTimeout(T[g]),T[g]=setTimeout(()=>{delete T[g],R.byModel[f]>0&&(R.byModel[f]=0),c&&R.byAccount[c]?.[f]>0&&(R.byAccount[c][f]=0),W.emit("pending")},6e4)):(clearTimeout(T[g]),delete T[g]),!d&&e&&b&&(S.provider=b.toLowerCase(),S.ts=Date.now());let h=new Date().toLocaleTimeString("en-US",{hour12:!1,hour:"2-digit",minute:"2-digit",second:"2-digit"});console.log(`[${h}] [PENDING] ${d?"START":"END"}${e?" (ERROR)":""} | provider=${b} | model=${a}`),W.emit("pending")}async function aa(){let a=[],b=await Y();for(let[c,d]of Object.entries(R.byAccount))for(let[e,f]of Object.entries(d))if(f>0){let d=b[c]||`Account ${c.slice(0,8)}...`,g=e.match(/^(.*) \((.*)\)$/);a.push({model:g?g[1]:e,provider:g?g[2]:"unknown",account:d,count:f})}await Z();let c=new Set;return{activeRequests:a,recentRequests:[...U.items].sort((a,b)=>new Date(b.timestamp)-new Date(a.timestamp)).map(a=>{let b=a.tokens||{};return{timestamp:a.timestamp,model:a.model,provider:a.provider||"",promptTokens:b.prompt_tokens||b.input_tokens||0,completionTokens:b.completion_tokens||b.output_tokens||0,status:a.status||"ok"}}).filter(a=>{if(0===a.promptTokens&&0===a.completionTokens)return!1;let b=a.timestamp?a.timestamp.slice(0,16):"",d=`${a.model}|${a.provider}|${a.promptTokens}|${a.completionTokens}|${b}`;return!c.has(d)&&(c.add(d),!0)}).slice(0,20),errorProvider:Date.now()-S.ts<1e4?S.provider:""}}async function ab(a){try{let b=await (0,d.c)();a.timestamp||(a.timestamp=new Date().toISOString()),a.cost=await $(a.provider,a.model,a.tokens);let c=a.tokens||{},f=c.prompt_tokens||c.input_tokens||0,g=c.completion_tokens||c.output_tokens||0;b.transaction(()=>{var d;let h,i,j,k,l,m,n,o,p,q;b.run("INSERT INTO usageHistory(timestamp, provider, model, connectionId, apiKey, endpoint, promptTokens, completionTokens, cost, status, tokens, meta) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",[a.timestamp,a.provider||null,a.model||null,a.connectionId||null,a.apiKey||null,a.endpoint||null,f,g,a.cost||0,a.status||"ok",(0,e.s)(c),(0,e.s)({})]);let r=(h=(d=a.timestamp)?new Date(d):new Date,`${h.getFullYear()}-${String(h.getMonth()+1).padStart(2,"0")}-${String(h.getDate()).padStart(2,"0")}`),s=b.get("SELECT data FROM usageDaily WHERE dateKey = ?",[r]),t=s?(0,e.q)(s.data,{}):{requests:0,promptTokens:0,completionTokens:0,cost:0,byProvider:{},byModel:{},byAccount:{},byApiKey:{},byEndpoint:{}};i=a.tokens?.prompt_tokens||a.tokens?.input_tokens||0,j=a.tokens?.completion_tokens||a.tokens?.output_tokens||0,k=a.cost||0,l={promptTokens:i,completionTokens:j,cost:k},t.requests=(t.requests||0)+1,t.promptTokens=(t.promptTokens||0)+i,t.completionTokens=(t.completionTokens||0)+j,t.cost=(t.cost||0)+k,t.byProvider||={},t.byModel||={},t.byAccount||={},t.byApiKey||={},t.byEndpoint||={},a.provider&&X(t.byProvider,a.provider,l),m=a.provider?`${a.model}|${a.provider}`:a.model,X(t.byModel,m,{...l,meta:{rawModel:a.model,provider:a.provider}}),a.connectionId&&X(t.byAccount,a.connectionId,{...l,meta:{rawModel:a.model,provider:a.provider}}),n=a.apiKey&&"string"==typeof a.apiKey?a.apiKey:"local-no-key",o=`${n}|${a.model}|${a.provider||"unknown"}`,X(t.byApiKey,o,{...l,meta:{rawModel:a.model,provider:a.provider,apiKey:a.apiKey||null}}),p=a.endpoint||"Unknown",q=`${p}|${a.model}|${a.provider||"unknown"}`,X(t.byEndpoint,q,{...l,meta:{endpoint:p,rawModel:a.model,provider:a.provider}}),b.run("INSERT INTO usageDaily(dateKey, data) VALUES(?, ?) ON CONFLICT(dateKey) DO UPDATE SET data = excluded.data",[r,(0,e.s)(t)]);let u=b.get("SELECT value FROM _meta WHERE key = 'totalRequestsLifetime'"),v=(u?parseInt(u.value,10):0)+1;b.run("INSERT INTO _meta(key, value) VALUES('totalRequestsLifetime', ?) ON CONFLICT(key) DO UPDATE SET value = excluded.value",[String(v)])}),U.items.push(a),U.items.length>50&&(U.items=U.items.slice(-50)),W.emit("update")}catch(a){console.error("Failed to save usage stats:",a)}}function ac(a,b){if(null==b)return a.all("SELECT dateKey, data FROM usageDaily");let c=new Date,d=new Date(c.getFullYear(),c.getMonth(),c.getDate()-b+1),e=`${d.getFullYear()}-${String(d.getMonth()+1).padStart(2,"0")}-${String(d.getDate()).padStart(2,"0")}`;return a.all("SELECT dateKey, data FROM usageDaily WHERE dateKey >= ?",[e])}async function ad(a="all"){let b=await (0,d.c)(),[{getProviderConnections:f},{getApiKeys:g},{getProviderNodes:h}]=await Promise.all([Promise.resolve().then(c.bind(c,98673)),Promise.resolve().then(c.bind(c,42928)),Promise.resolve().then(c.bind(c,85885))]),i=[];try{i=await f()}catch{}let j={};for(let a of i)j[a.id]=a.name||a.email||a.id;let k={};try{for(let a of(await h()))a.id&&a.name&&(k[a.id]=a.name)}catch{}let l=[];try{l=await g()}catch{}let m={};for(let a of l)m[a.key]={name:a.name,id:a.id,createdAt:a.createdAt};let n=b.all("SELECT timestamp, provider, model, tokens, status FROM usageHistory ORDER BY id DESC LIMIT 100"),o=new Set,p={totalRequests:0,totalPromptTokens:0,totalCompletionTokens:0,totalCost:0,byProvider:{},byModel:{},byAccount:{},byApiKey:{},byEndpoint:{},last10Minutes:[],pending:R,activeRequests:[],recentRequests:n.map(a=>{let b=(0,e.q)(a.tokens,{})||{};return{timestamp:a.timestamp,model:a.model,provider:a.provider||"",promptTokens:b.prompt_tokens||b.input_tokens||0,completionTokens:b.completion_tokens||b.output_tokens||0,status:a.status||"ok"}}).filter(a=>{if(0===a.promptTokens&&0===a.completionTokens)return!1;let b=a.timestamp?a.timestamp.slice(0,16):"",c=`${a.model}|${a.provider}|${a.promptTokens}|${a.completionTokens}|${b}`;return!o.has(c)&&(o.add(c),!0)}).slice(0,20),errorProvider:Date.now()-S.ts<1e4?S.provider:""};for(let[a,b]of Object.entries(R.byAccount))for(let[c,d]of Object.entries(b))if(d>0){let b=j[a]||`Account ${a.slice(0,8)}...`,e=c.match(/^(.*) \((.*)\)$/);p.activeRequests.push({model:e?e[1]:c,provider:e?e[2]:"unknown",account:b,count:d})}let q=new Date,r=new Date(6e4*Math.floor(q.getTime()/6e4)),s=new Date(r.getTime()-54e4),t={};for(let a=0;a<10;a++){let b=r.getTime()-(9-a)*6e4;t[b]={requests:0,promptTokens:0,completionTokens:0,cost:0},p.last10Minutes.push(t[b])}for(let a of b.all("SELECT timestamp, promptTokens, completionTokens, cost FROM usageHistory WHERE timestamp >= ? AND timestamp <= ?",[s.toISOString(),q.toISOString()])){let b=6e4*Math.floor(new Date(a.timestamp).getTime()/6e4);t[b]&&(t[b].requests++,t[b].promptTokens+=a.promptTokens||0,t[b].completionTokens+=a.completionTokens||0,t[b].cost+=a.cost||0)}if("24h"!==a){let c={"7d":7,"30d":30,"60d":60}[a]||null;for(let a of ac(b,c)){let b=a.dateKey,c=(0,e.q)(a.data,{});for(let[a,b]of(p.totalPromptTokens+=c.promptTokens||0,p.totalCompletionTokens+=c.completionTokens||0,p.totalCost+=c.cost||0,Object.entries(c.byProvider||{})))p.byProvider[a]||(p.byProvider[a]={requests:0,promptTokens:0,completionTokens:0,cost:0}),p.byProvider[a].requests+=b.requests||0,p.byProvider[a].promptTokens+=b.promptTokens||0,p.byProvider[a].completionTokens+=b.completionTokens||0,p.byProvider[a].cost+=b.cost||0;for(let[a,d]of Object.entries(c.byModel||{})){let c=d.rawModel||a.split("|")[0],e=d.provider||a.split("|")[1]||"",f=e?`${c} (${e})`:c,g=k[e]||e;p.byModel[f]||(p.byModel[f]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:c,provider:g,lastUsed:b}),p.byModel[f].requests+=d.requests||0,p.byModel[f].promptTokens+=d.promptTokens||0,p.byModel[f].completionTokens+=d.completionTokens||0,p.byModel[f].cost+=d.cost||0,b>(p.byModel[f].lastUsed||"")&&(p.byModel[f].lastUsed=b)}for(let[a,d]of Object.entries(c.byAccount||{})){let c=j[a]||`Account ${a.slice(0,8)}...`,e=d.rawModel||"",f=d.provider||"",g=k[f]||f,h=`${e} (${f} - ${c})`;p.byAccount[h]||(p.byAccount[h]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:e,provider:g,connectionId:a,accountName:c,lastUsed:b}),p.byAccount[h].requests+=d.requests||0,p.byAccount[h].promptTokens+=d.promptTokens||0,p.byAccount[h].completionTokens+=d.completionTokens||0,p.byAccount[h].cost+=d.cost||0,b>(p.byAccount[h].lastUsed||"")&&(p.byAccount[h].lastUsed=b)}for(let[a,d]of Object.entries(c.byApiKey||{})){let c=d.rawModel||"",e=d.provider||"",f=k[e]||e,g=d.apiKey,h=g?m[g]:null,i=h?.name||(g?g.slice(0,8)+"...":"Local (No API Key)"),j=g||"local-no-key";p.byApiKey[a]||(p.byApiKey[a]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:c,provider:f,apiKey:g,keyName:i,apiKeyKey:j,lastUsed:b}),p.byApiKey[a].requests+=d.requests||0,p.byApiKey[a].promptTokens+=d.promptTokens||0,p.byApiKey[a].completionTokens+=d.completionTokens||0,p.byApiKey[a].cost+=d.cost||0,b>(p.byApiKey[a].lastUsed||"")&&(p.byApiKey[a].lastUsed=b)}for(let[a,d]of Object.entries(c.byEndpoint||{})){let c=d.endpoint||a.split("|")[0]||"Unknown",e=d.rawModel||"",f=d.provider||"",g=k[f]||f;p.byEndpoint[a]||(p.byEndpoint[a]={requests:0,promptTokens:0,completionTokens:0,cost:0,endpoint:c,rawModel:e,provider:g,lastUsed:b}),p.byEndpoint[a].requests+=d.requests||0,p.byEndpoint[a].promptTokens+=d.promptTokens||0,p.byEndpoint[a].completionTokens+=d.completionTokens||0,p.byEndpoint[a].cost+=d.cost||0,b>(p.byEndpoint[a].lastUsed||"")&&(p.byEndpoint[a].lastUsed=b)}}let d=c?Date.now()-864e5*c:0;for(let a of b.all("SELECT timestamp, provider, model, connectionId, apiKey, endpoint FROM usageHistory WHERE timestamp >= ?",[new Date(d).toISOString()])){let b=a.timestamp,c=a.provider?`${a.model} (${a.provider})`:a.model;if(p.byModel[c]&&new Date(b)>new Date(p.byModel[c].lastUsed)&&(p.byModel[c].lastUsed=b),a.connectionId){let c=j[a.connectionId]||`Account ${a.connectionId.slice(0,8)}...`,d=`${a.model} (${a.provider} - ${c})`;p.byAccount[d]&&new Date(b)>new Date(p.byAccount[d].lastUsed)&&(p.byAccount[d].lastUsed=b)}let d=a.apiKey&&"string"==typeof a.apiKey?`${a.apiKey}|${a.model}|${a.provider||"unknown"}`:"local-no-key";p.byApiKey[d]&&new Date(b)>new Date(p.byApiKey[d].lastUsed)&&(p.byApiKey[d].lastUsed=b);let e=a.endpoint||"Unknown",f=`${e}|${a.model}|${a.provider||"unknown"}`;p.byEndpoint[f]&&new Date(b)>new Date(p.byEndpoint[f].lastUsed)&&(p.byEndpoint[f].lastUsed=b)}}else{let a=new Date(Date.now()-864e5).toISOString();for(let c of b.all("SELECT timestamp, provider, model, connectionId, apiKey, endpoint, promptTokens, completionTokens, cost, tokens FROM usageHistory WHERE timestamp >= ?",[a])){let a=(0,e.q)(c.tokens,{})||{},b=a.prompt_tokens||0,d=a.completion_tokens||0,f=c.cost||0,g=k[c.provider]||c.provider;p.totalPromptTokens+=b,p.totalCompletionTokens+=d,p.totalCost+=f,p.byProvider[c.provider]||(p.byProvider[c.provider]={requests:0,promptTokens:0,completionTokens:0,cost:0}),p.byProvider[c.provider].requests++,p.byProvider[c.provider].promptTokens+=b,p.byProvider[c.provider].completionTokens+=d,p.byProvider[c.provider].cost+=f;let h=c.provider?`${c.model} (${c.provider})`:c.model;if(p.byModel[h]||(p.byModel[h]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:c.model,provider:g,lastUsed:c.timestamp}),p.byModel[h].requests++,p.byModel[h].promptTokens+=b,p.byModel[h].completionTokens+=d,p.byModel[h].cost+=f,new Date(c.timestamp)>new Date(p.byModel[h].lastUsed)&&(p.byModel[h].lastUsed=c.timestamp),c.connectionId){let a=j[c.connectionId]||`Account ${c.connectionId.slice(0,8)}...`,e=`${c.model} (${c.provider} - ${a})`;p.byAccount[e]||(p.byAccount[e]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:c.model,provider:g,connectionId:c.connectionId,accountName:a,lastUsed:c.timestamp}),p.byAccount[e].requests++,p.byAccount[e].promptTokens+=b,p.byAccount[e].completionTokens+=d,p.byAccount[e].cost+=f,new Date(c.timestamp)>new Date(p.byAccount[e].lastUsed)&&(p.byAccount[e].lastUsed=c.timestamp)}if(c.apiKey&&"string"==typeof c.apiKey){let a=m[c.apiKey],e=a?.name||c.apiKey.slice(0,8)+"...",h=`${c.apiKey}|${c.model}|${c.provider||"unknown"}`;p.byApiKey[h]||(p.byApiKey[h]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:c.model,provider:g,apiKey:c.apiKey,keyName:e,apiKeyKey:c.apiKey,lastUsed:c.timestamp});let i=p.byApiKey[h];i.requests++,i.promptTokens+=b,i.completionTokens+=d,i.cost+=f,new Date(c.timestamp)>new Date(i.lastUsed)&&(i.lastUsed=c.timestamp)}else{p.byApiKey["local-no-key"]||(p.byApiKey["local-no-key"]={requests:0,promptTokens:0,completionTokens:0,cost:0,rawModel:c.model,provider:g,apiKey:null,keyName:"Local (No API Key)",apiKeyKey:"local-no-key",lastUsed:c.timestamp});let a=p.byApiKey["local-no-key"];a.requests++,a.promptTokens+=b,a.completionTokens+=d,a.cost+=f,new Date(c.timestamp)>new Date(a.lastUsed)&&(a.lastUsed=c.timestamp)}let i=c.endpoint||"Unknown",l=`${i}|${c.model}|${c.provider||"unknown"}`;p.byEndpoint[l]||(p.byEndpoint[l]={requests:0,promptTokens:0,completionTokens:0,cost:0,endpoint:i,rawModel:c.model,provider:g,lastUsed:c.timestamp});let n=p.byEndpoint[l];n.requests++,n.promptTokens+=b,n.completionTokens+=d,n.cost+=f,new Date(c.timestamp)>new Date(n.lastUsed)&&(n.lastUsed=c.timestamp)}}return p.totalRequests=Object.values(p.byProvider).reduce((a,b)=>a+(b.requests||0),0),p}async function ae(a="7d"){let b=await (0,d.c)(),c=Date.now();if("24h"===a){let a=c-864e5,d=Array.from({length:24},(b,c)=>({label:new Date(a+36e5*c).toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit",hour12:!1}),tokens:0,cost:0}));for(let e of b.all("SELECT timestamp, promptTokens, completionTokens, cost FROM usageHistory WHERE timestamp >= ?",[new Date(a).toISOString()])){let b=new Date(e.timestamp).getTime();if(b<a||b>c)continue;let f=Math.min(Math.floor((b-a)/36e5),23);d[f].tokens+=(e.promptTokens||0)+(e.completionTokens||0),d[f].cost+=e.cost||0}return d}let f="7d"===a?7:"30d"===a?30:60,g=new Date,h=ac(b,f),i={};for(let a of h)i[a.dateKey]=(0,e.q)(a.data,{});return Array.from({length:f},(a,b)=>{let c=new Date(g);c.setDate(c.getDate()-(f-1-b));let d=i[`${c.getFullYear()}-${String(c.getMonth()+1).padStart(2,"0")}-${String(c.getDate()).padStart(2,"0")}`];return{label:c.toLocaleDateString("en-US",{month:"short",day:"numeric"}),tokens:d?(d.promptTokens||0)+(d.completionTokens||0):0,cost:d&&d.cost||0}})}async function af(){}async function ag(a=200){try{let b=(0,d.c)().all("SELECT timestamp, provider, model, connectionId, promptTokens, completionTokens, status, tokens FROM usageHistory ORDER BY id DESC LIMIT ?",[a]);if(!b.length)return[];let f={};try{let{getProviderConnections:a}=await Promise.resolve().then(c.bind(c,98673));for(let b of(await a()))f[b.id]=b.name||b.email||""}catch{}return b.map(a=>{let b=function(a=new Date){let b=a=>String(a).padStart(2,"0");return`${b(a.getDate())}-${b(a.getMonth()+1)}-${a.getFullYear()} ${b(a.getHours())}:${b(a.getMinutes())}:${b(a.getSeconds())}`}(new Date(a.timestamp)),c=a.provider?.toUpperCase()||"-",d=a.model||"-",g=f[a.connectionId]||(a.connectionId?a.connectionId.slice(0,8):"-"),h=a.tokens?(0,e.q)(a.tokens,{}):{},i=a.promptTokens??h.prompt_tokens??"-",j=a.completionTokens??h.completion_tokens??"-";return`${b} | ${d} | ${c} | ${g} | ${i} | ${j} | ${a.status||"-"}`})}catch(a){return console.error("[usageRepo] getRecentLogs failed:",a.message),[]}}let ah=null,ai=0;async function aj(){if(ah&&Date.now()-ai<5e3)return ah;try{let{getSettings:a}=await Promise.resolve().then(c.bind(c,20819)),b=await a(),d="false"!==process.env.OBSERVABILITY_ENABLED;ah={enabled:"boolean"==typeof b.enableObservability?b.enableObservability:d,maxRecords:b.observabilityMaxRecords||parseInt(process.env.OBSERVABILITY_MAX_RECORDS||String(200),10),batchSize:b.observabilityBatchSize||parseInt(process.env.OBSERVABILITY_BATCH_SIZE||String(20),10),flushIntervalMs:b.observabilityFlushIntervalMs||parseInt(process.env.OBSERVABILITY_FLUSH_INTERVAL_MS||String(5e3),10),maxJsonSize:1024*(b.observabilityMaxJsonSize||parseInt(process.env.OBSERVABILITY_MAX_JSON_SIZE||"5",10))}}catch{ah={enabled:!1,maxRecords:200,batchSize:20,flushIntervalMs:5e3,maxJsonSize:5120}}return ai=Date.now(),ah}let ak=[],al=null,am=!1;function an(a,b){let c=JSON.stringify(a||{});return c.length>b?{_truncated:!0,_originalSize:c.length,_preview:c.substring(0,200)}:a||{}}async function ao(){if(!am&&0!==ak.length){am=!0;try{for(;ak.length>0;){let a=ak.splice(0,ak.length),b=await (0,d.c)(),c=await aj();b.transaction(()=>{for(let d of a){d.id||(d.id=function(a){let b=new Date().toISOString(),c=Math.random().toString(36).substring(2,8),d=a?a.replace(/[^a-zA-Z0-9-]/g,"-"):"unknown";return`${b}-${c}-${d}`}(d.model)),d.timestamp||(d.timestamp=new Date().toISOString()),d.request?.headers&&(d.request.headers=function(a){if(!a||"object"!=typeof a)return{};let b=["authorization","x-api-key","cookie","token","api-key"],c={...a};for(let a of Object.keys(c))b.some(b=>a.toLowerCase().includes(b))&&delete c[a];return c}(d.request.headers));let a={id:d.id,provider:d.provider||null,model:d.model||null,connectionId:d.connectionId||null,timestamp:d.timestamp,status:d.status||null,latency:d.latency||{},tokens:d.tokens||{},request:an(d.request,c.maxJsonSize),providerRequest:an(d.providerRequest,c.maxJsonSize),providerResponse:an(d.providerResponse,c.maxJsonSize),response:an(d.response,c.maxJsonSize)};b.run("INSERT INTO requestDetails(id, timestamp, provider, model, connectionId, status, data) VALUES(?, ?, ?, ?, ?, ?, ?) ON CONFLICT(id) DO UPDATE SET timestamp = excluded.timestamp, provider = excluded.provider, model = excluded.model, connectionId = excluded.connectionId, status = excluded.status, data = excluded.data",[a.id,a.timestamp,a.provider,a.model,a.connectionId,a.status,(0,e.s)(a)])}let d=b.get("SELECT COUNT(*) as c FROM requestDetails");d&&d.c>c.maxRecords&&b.run("DELETE FROM requestDetails WHERE id IN (SELECT id FROM requestDetails ORDER BY timestamp ASC LIMIT ?)",[d.c-c.maxRecords])})}}catch(a){console.error("[requestDetailsRepo] Batch write failed:",a)}finally{am=!1}}}async function ap(a){let b=await aj();b.enabled&&(ak.push(a),ak.length>=b.batchSize?(al&&(clearTimeout(al),al=null),ao().catch(a=>console.error("[requestDetailsRepo] flush err:",a))):al||(al=setTimeout(()=>{al=null,ao().catch(()=>{})},b.flushIntervalMs)))}async function aq(a={}){let b=await (0,d.c)(),c=[],f=[];a.provider&&(c.push("provider = ?"),f.push(a.provider)),a.model&&(c.push("model = ?"),f.push(a.model)),a.connectionId&&(c.push("connectionId = ?"),f.push(a.connectionId)),a.status&&(c.push("status = ?"),f.push(a.status)),a.startDate&&(c.push("timestamp >= ?"),f.push(new Date(a.startDate).toISOString())),a.endDate&&(c.push("timestamp <= ?"),f.push(new Date(a.endDate).toISOString()));let g=c.length?`WHERE ${c.join(" AND ")}`:"",h=b.get(`SELECT COUNT(*) as c FROM requestDetails ${g}`,f),i=h?h.c:0,j=a.page||1,k=a.pageSize||50,l=Math.ceil(i/k);return{details:b.all(`SELECT data FROM requestDetails ${g} ORDER BY timestamp DESC LIMIT ? OFFSET ?`,[...f,k,(j-1)*k]).map(a=>(0,e.q)(a.data,{})),pagination:{page:j,pageSize:k,totalItems:i,totalPages:l,hasNext:j<l,hasPrev:j>1}}}let ar=async()=>{al&&(clearTimeout(al),al=null),ak.length>0&&await ao()};async function as(){let a=await (0,d.c)(),{exportSettings:b}=await Promise.resolve().then(c.bind(c,20819)),f={settings:await b(),providerConnections:a.all("SELECT * FROM providerConnections").map(a=>({...(0,e.q)(a.data,{}),id:a.id,provider:a.provider,authType:a.authType,name:a.name,email:a.email,priority:a.priority,isActive:1===a.isActive,createdAt:a.createdAt,updatedAt:a.updatedAt})),providerNodes:a.all("SELECT * FROM providerNodes").map(a=>({...(0,e.q)(a.data,{}),id:a.id,type:a.type,name:a.name,createdAt:a.createdAt,updatedAt:a.updatedAt})),proxyPools:a.all("SELECT * FROM proxyPools").map(a=>({...(0,e.q)(a.data,{}),id:a.id,isActive:1===a.isActive,testStatus:a.testStatus,createdAt:a.createdAt,updatedAt:a.updatedAt})),apiKeys:a.all("SELECT * FROM apiKeys").map(a=>({id:a.id,key:a.key,name:a.name,machineId:a.machineId,isActive:1===a.isActive,createdAt:a.createdAt})),combos:a.all("SELECT * FROM combos").map(a=>({id:a.id,name:a.name,kind:a.kind,models:(0,e.q)(a.models,[]),createdAt:a.createdAt,updatedAt:a.updatedAt})),modelAliases:{},customModels:[],mitmAlias:{},pricing:{}};for(let b of a.all("SELECT key, value FROM kv WHERE scope = 'modelAliases'"))f.modelAliases[b.key]=(0,e.q)(b.value);for(let b of a.all("SELECT key, value FROM kv WHERE scope = 'customModels'"))f.customModels.push((0,e.q)(b.value));for(let b of a.all("SELECT key, value FROM kv WHERE scope = 'mitmAlias'"))f.mitmAlias[b.key]=(0,e.q)(b.value);for(let b of a.all("SELECT key, value FROM kv WHERE scope = 'pricing'"))f.pricing[b.key]=(0,e.q)(b.value);return f}async function at(a){if(!a||"object"!=typeof a||Array.isArray(a))throw Error("Invalid database payload");let b=await (0,d.c)();return b.transaction(()=>{for(let c of(b.run("DELETE FROM settings"),b.run("DELETE FROM providerConnections"),b.run("DELETE FROM providerNodes"),b.run("DELETE FROM proxyPools"),b.run("DELETE FROM apiKeys"),b.run("DELETE FROM combos"),b.run("DELETE FROM kv WHERE scope IN ('modelAliases', 'customModels', 'mitmAlias', 'pricing')"),a.settings&&b.run("INSERT INTO settings(id, data) VALUES(1, ?) ON CONFLICT(id) DO UPDATE SET data = excluded.data",[(0,e.s)(a.settings)]),a.providerConnections||[])){let{id:a,provider:d,authType:f,name:g,email:h,priority:i,isActive:j,createdAt:k,updatedAt:l,...m}=c;b.run("INSERT OR REPLACE INTO providerConnections(id, provider, authType, name, email, priority, isActive, data, createdAt, updatedAt) VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?)",[a,d,f||"oauth",g||null,h||null,i||null,+(!1!==j),(0,e.s)(m),k||new Date().toISOString(),l||new Date().toISOString()])}for(let c of a.providerNodes||[]){let{id:a,type:d,name:f,createdAt:g,updatedAt:h,...i}=c;b.run("INSERT OR REPLACE INTO providerNodes(id, type, name, data, createdAt, updatedAt) VALUES(?, ?, ?, ?, ?, ?)",[a,d||null,f||null,(0,e.s)(i),g||new Date().toISOString(),h||new Date().toISOString()])}for(let c of a.proxyPools||[]){let{id:a,isActive:d,testStatus:f,createdAt:g,updatedAt:h,...i}=c;b.run("INSERT OR REPLACE INTO proxyPools(id, isActive, testStatus, data, createdAt, updatedAt) VALUES(?, ?, ?, ?, ?, ?)",[a,+(!1!==d),f||"unknown",(0,e.s)(i),g||new Date().toISOString(),h||new Date().toISOString()])}for(let c of a.apiKeys||[])b.run("INSERT OR REPLACE INTO apiKeys(id, key, name, machineId, isActive, createdAt) VALUES(?, ?, ?, ?, ?, ?)",[c.id,c.key,c.name||null,c.machineId||null,+(!1!==c.isActive),c.createdAt||new Date().toISOString()]);for(let c of a.combos||[])b.run("INSERT OR REPLACE INTO combos(id, name, kind, models, createdAt, updatedAt) VALUES(?, ?, ?, ?, ?, ?)",[c.id,c.name,c.kind||null,(0,e.s)(c.models||[]),c.createdAt||new Date().toISOString(),c.updatedAt||new Date().toISOString()]);for(let[c,d]of Object.entries(a.modelAliases||{}))b.run("INSERT OR REPLACE INTO kv(scope, key, value) VALUES('modelAliases', ?, ?)",[c,(0,e.s)(d)]);for(let c of a.customModels||[]){let a=`${c.providerAlias}|${c.id}|${c.type||"llm"}`;b.run("INSERT OR REPLACE INTO kv(scope, key, value) VALUES('customModels', ?, ?)",[a,(0,e.s)(c)])}for(let[c,d]of Object.entries(a.mitmAlias||{}))b.run("INSERT OR REPLACE INTO kv(scope, key, value) VALUES('mitmAlias', ?, ?)",[c,(0,e.s)(d||{})]);for(let[c,d]of Object.entries(a.pricing||{}))b.run("INSERT OR REPLACE INTO kv(scope, key, value) VALUES('pricing', ?, ?)",[c,(0,e.s)(d||{})])}),await as()}process.off("beforeExit",ar),process.off("SIGINT",ar),process.off("SIGTERM",ar),process.off("exit",ar),process.on("beforeExit",ar),process.on("SIGINT",ar),process.on("SIGTERM",ar),process.on("exit",ar)},59278:(a,b,c)=>{"use strict";c.d(b,{AL:()=>j,HG:()=>i,Jh:()=>m,KQ:()=>k,Or:()=>l});var d=c(76760),e=c.n(d),f=c(73024),g=c.n(f),h=c(81372);let i=e().join(h.n,"db"),j=e().join(i,"data.sqlite"),k=e().join(i,"backups"),l={main:e().join(h.n,"db.json"),usage:e().join(h.n,"usage.json"),disabled:e().join(h.n,"disabledModels.json"),details:e().join(h.n,"request-details.json")};function m(){for(let a of[h.n,i,k])g().existsSync(a)||g().mkdirSync(a,{recursive:!0})}},61034:(a,b,c)=>{"use strict";c.d(b,{U:()=>f});var d=c(90602),e=c(25456);function f(a){return{async get(b,c=null){let f=(await (0,d.c)()).get("SELECT value FROM kv WHERE scope = ? AND key = ?",[a,b]);return f?(0,e.q)(f.value,c):c},async getAll(){let b=(await (0,d.c)()).all("SELECT key, value FROM kv WHERE scope = ?",[a]),c={};for(let a of b)c[a.key]=(0,e.q)(a.value);return c},async set(b,c){(await (0,d.c)()).run("INSERT INTO kv(scope, key, value) VALUES(?, ?, ?) ON CONFLICT(scope, key) DO UPDATE SET value = excluded.value",[a,b,(0,e.s)(c)])},async setMany(b){let c=await (0,d.c)();c.transaction(()=>{for(let[d,f]of Object.entries(b))c.run("INSERT INTO kv(scope, key, value) VALUES(?, ?, ?) ON CONFLICT(scope, key) DO UPDATE SET value = excluded.value",[a,d,(0,e.s)(f)])})},async remove(b){(await (0,d.c)()).run("DELETE FROM kv WHERE scope = ? AND key = ?",[a,b])},async clear(){(await (0,d.c)()).run("DELETE FROM kv WHERE scope = ?",[a])}}}},64749:()=>{},75582:(a,b,c)=>{"use strict";function d(a,b,c=null){let e=a.get("SELECT value FROM _meta WHERE key = ?",[b]);return e?e.value:c}function e(a,b,c){a.run("INSERT INTO _meta(key, value) VALUES(?, ?) ON CONFLICT(key) DO UPDATE SET value = excluded.value",[b,String(c)])}c.d(b,{dy:()=>d,np:()=>e}),c(90602)},81372:(a,b,c)=>{"use strict";c.d(b,{n:()=>i});var d=c(33873),e=c.n(d),f=c(21820),g=c.n(f);let h="9router",i=process.env.DATA_DIR?process.env.DATA_DIR:"win32"===process.platform?e().join(process.env.APPDATA||e().join(g().homedir(),"AppData","Roaming"),h):e().join(g().homedir(),`.${h}`)},85885:(a,b,c)=>{"use strict";c.r(b),c.d(b,{createProviderNode:()=>k,deleteProviderNode:()=>m,getProviderNodeById:()=>j,getProviderNodes:()=>i,updateProviderNode:()=>l});var d=c(37873),e=c(90602),f=c(25456);function g(a){return a?{...(0,f.q)(a.data,{}),id:a.id,type:a.type,name:a.name,createdAt:a.createdAt,updatedAt:a.updatedAt}:null}function h(a,b){let c=function(a){let{id:b,type:c,name:d,createdAt:e,updatedAt:g,...h}=a;return{id:b,type:c??null,name:d??null,data:(0,f.s)(h),createdAt:e,updatedAt:g}}(b);a.run(`INSERT INTO providerNodes(id, type, name, data, createdAt, updatedAt)
6
- VALUES(?, ?, ?, ?, ?, ?)
7
- ON CONFLICT(id) DO UPDATE SET
8
- type=excluded.type, name=excluded.name, data=excluded.data, updatedAt=excluded.updatedAt`,[c.id,c.type,c.name,c.data,c.createdAt,c.updatedAt])}async function i(a={}){let b=await (0,e.c)(),c=[],d=[];a.type&&(c.push("type = ?"),d.push(a.type));let f=`SELECT * FROM providerNodes${c.length?` WHERE ${c.join(" AND ")}`:""}`;return b.all(f,d).map(g)}async function j(a){return g((await (0,e.c)()).get("SELECT * FROM providerNodes WHERE id = ?",[a]))}async function k(a){let b=await (0,e.c)(),c=new Date().toISOString(),f={id:a.id||(0,d.A)(),type:a.type,name:a.name,prefix:a.prefix,apiType:a.apiType,baseUrl:a.baseUrl,createdAt:c,updatedAt:c};return h(b,f),f}async function l(a,b){let c=await (0,e.c)(),d=null;return c.transaction(()=>{let e=c.get("SELECT * FROM providerNodes WHERE id = ?",[a]);if(!e)return;let f={...g(e),...b,updatedAt:new Date().toISOString()};h(c,f),d=f}),d}async function m(a){let b=await (0,e.c)(),c=null;return b.transaction(()=>{let d=b.get("SELECT * FROM providerNodes WHERE id = ?",[a]);d&&(c=g(d),b.run("DELETE FROM providerNodes WHERE id = ?",[a]))}),c}},90602:(a,b,c)=>{"use strict";c.d(b,{c:()=>k});var d=c(59278);global._dbAdapter||(global._dbAdapter={instance:null,initPromise:null,logged:!1});let e=global._dbAdapter;async function f(){if(!process.versions.bun)return null;try{let{createBunSqliteAdapter:a}=await c.e(8495).then(c.bind(c,18495));return await a(d.AL)}catch(a){return console.warn(`[DB] bun:sqlite unavailable: ${a.message}`),null}}async function g(){if(process.versions.bun)return null;try{let{createBetterSqliteAdapter:a}=await c.e(3630).then(c.bind(c,3630));return a(d.AL)}catch(a){return console.warn(`[DB] better-sqlite3 unavailable: ${a.message}`),null}}async function h(){if(process.versions.bun)return null;let[a,b]=process.versions.node.split(".").map(Number);if(a<22||22===a&&b<5)return null;try{let{createNodeSqliteAdapter:a}=await c.e(7292).then(c.bind(c,37292));return await a(d.AL)}catch(a){return console.warn(`[DB] node:sqlite unavailable: ${a.message}`),null}}async function i(){try{let{createSqlJsAdapter:a}=await c.e(7061).then(c.bind(c,87061));return await a(d.AL)}catch(a){return console.warn(`[DB] sql.js unavailable: ${a.message}`),null}}async function j(){(0,d.Jh)();let a=await f();if(a||(a=await g()),a||(a=await h()),a||(a=await i()),!a)throw Error("[DB] No SQLite driver available (bun/better/node/sql.js all failed)");e.logged||(console.log(`[DB] Driver: ${a.driver} | file: ${d.AL}`),e.logged=!0);let{runMigrationOnce:b}=await c.e(7171).then(c.bind(c,47171));return await b(a),a}async function k(){return e.instance?e.instance:(e.initPromise||(e.initPromise=j().then(a=>(e.instance=a,a))),e.initPromise)}},98366:(a,b,c)=>{"use strict";c.d(b,{KJ:()=>l,VT:()=>n,getPricingForModel:()=>k,r4:()=>j,yF:()=>m});var d=c(90602),e=c(25456);let f=(0,c(61034).U)("pricing"),g={value:null,expiresAt:0};function h(){g={value:null,expiresAt:0}}async function i(){return await f.getAll()}async function j(){let a=Date.now();if(g.value&&g.expiresAt>a)return g.value;let b=await i(),{PROVIDER_PRICING:d}=await c.e(1249).then(c.bind(c,61249)),e={};for(let[a,c]of Object.entries(d))if(e[a]={...c},b[a])for(let[c,d]of Object.entries(b[a]))e[a][c]=e[a][c]?{...e[a][c],...d}:d;for(let[a,c]of Object.entries(b))if(e[a])for(let[b,d]of Object.entries(c))e[a][b]||(e[a][b]=d);else e[a]={...c};return g={value:e,expiresAt:a+5e3},e}async function k(a,b){if(!b)return null;let d=await i();if(a&&d[a]?.[b])return d[a][b];let{getPricingForModel:e}=await c.e(1249).then(c.bind(c,61249));return e(a,b)}async function l(a){let b=await (0,d.c)();return b.transaction(()=>{for(let[c,d]of Object.entries(a)){let a=b.get("SELECT value FROM kv WHERE scope = 'pricing' AND key = ?",[c]),f={...a&&(0,e.q)(a.value,{})||{}};for(let[a,b]of Object.entries(d))f[a]=b;b.run("INSERT INTO kv(scope, key, value) VALUES('pricing', ?, ?) ON CONFLICT(scope, key) DO UPDATE SET value = excluded.value",[c,(0,e.s)(f)])}}),h(),await i()}async function m(a,b){if(!a)return await i();let c=await (0,d.c)();return c.transaction(()=>{if(!b)return void c.run("DELETE FROM kv WHERE scope = 'pricing' AND key = ?",[a]);let d=c.get("SELECT value FROM kv WHERE scope = 'pricing' AND key = ?",[a]),f=d&&(0,e.q)(d.value,{})||{};delete f[b],0===Object.keys(f).length?c.run("DELETE FROM kv WHERE scope = 'pricing' AND key = ?",[a]):c.run("INSERT INTO kv(scope, key, value) VALUES('pricing', ?, ?) ON CONFLICT(scope, key) DO UPDATE SET value = excluded.value",[a,(0,e.s)(f)])}),h(),await i()}async function n(){return await f.clear(),h(),{}}},98673:(a,b,c)=>{"use strict";c.r(b),c.d(b,{cleanupProviderConnections:()=>r,createProviderConnection:()=>m,deleteProviderConnection:()=>o,deleteProviderConnectionsByProvider:()=>p,getProviderConnectionById:()=>k,getProviderConnections:()=>j,reorderProviderConnections:()=>q,updateProviderConnection:()=>n});var d=c(37873),e=c(90602),f=c(25456);let g=["displayName","email","globalPriority","defaultModel","accessToken","refreshToken","expiresAt","tokenType","scope","projectId","apiKey","testStatus","lastTested","lastError","lastErrorAt","rateLimitedUntil","expiresIn","errorCode","consecutiveUseCount"];function h(a){return a?{...(0,f.q)(a.data,{}),id:a.id,provider:a.provider,authType:a.authType,name:a.name,email:a.email,priority:a.priority,isActive:1===a.isActive||!0===a.isActive,createdAt:a.createdAt,updatedAt:a.updatedAt}:null}function i(a,b){let c=function(a){let{id:b,provider:c,authType:d,name:e,email:g,priority:h,isActive:i,createdAt:j,updatedAt:k,...l}=a;return{id:b,provider:c,authType:d,name:e??null,email:g??null,priority:h??null,isActive:+(!1!==i),data:(0,f.s)(l),createdAt:j,updatedAt:k}}(b);a.run(`INSERT INTO providerConnections(id, provider, authType, name, email, priority, isActive, data, createdAt, updatedAt)
9
- VALUES(?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
10
- ON CONFLICT(id) DO UPDATE SET
11
- provider=excluded.provider, authType=excluded.authType, name=excluded.name,
12
- email=excluded.email, priority=excluded.priority, isActive=excluded.isActive,
13
- data=excluded.data, updatedAt=excluded.updatedAt`,[c.id,c.provider,c.authType,c.name,c.email,c.priority,c.isActive,c.data,c.createdAt,c.updatedAt])}async function j(a={}){let b=await (0,e.c)(),c=[],d=[];a.provider&&(c.push("provider = ?"),d.push(a.provider)),void 0!==a.isActive&&(c.push("isActive = ?"),d.push(+!!a.isActive));let f=`SELECT * FROM providerConnections${c.length?` WHERE ${c.join(" AND ")}`:""}`,g=b.all(f,d).map(h);return g.sort((a,b)=>(a.priority||999)-(b.priority||999)),g}async function k(a){return h((await (0,e.c)()).get("SELECT * FROM providerConnections WHERE id = ?",[a]))}function l(a,b){let c=a.all("SELECT * FROM providerConnections WHERE provider = ?",[b]).map(h);c.sort((a,b)=>{let c=(a.priority||0)-(b.priority||0);return 0!==c?c:new Date(b.updatedAt||0)-new Date(a.updatedAt||0)}),c.forEach((b,c)=>{a.run("UPDATE providerConnections SET priority = ? WHERE id = ?",[c+1,b.id])})}async function m(a){let b,c=await (0,e.c)(),f=new Date().toISOString();return c.transaction(()=>{let e=c.all("SELECT * FROM providerConnections WHERE provider = ?",[a.provider]).map(h),j=null;if("oauth"===a.authType&&a.email?j=e.find(b=>"oauth"===b.authType&&b.email===a.email):"apikey"===a.authType&&a.name&&(j=e.find(b=>"apikey"===b.authType&&b.name===a.name)),j){let d={...j,...a,updatedAt:f};i(c,d),b=d;return}let k=a.name||null;k||"oauth"!==a.authType||(k=a.email||`Account ${e.length+1}`);let m=a.priority;m||(m=e.reduce((a,b)=>Math.max(a,b.priority||0),0)+1);let n={id:(0,d.A)(),provider:a.provider,authType:a.authType||"oauth",name:k,priority:m,isActive:void 0===a.isActive||a.isActive,createdAt:f,updatedAt:f};for(let b of g)void 0!==a[b]&&null!==a[b]&&(n[b]=a[b]);a.providerSpecificData&&Object.keys(a.providerSpecificData).length>0&&(n.providerSpecificData=a.providerSpecificData),void 0!==a.email&&(n.email=a.email),i(c,n),l(c,a.provider),b=n}),b}async function n(a,b){let c,d=await (0,e.c)();return d.transaction(()=>{let e=d.get("SELECT * FROM providerConnections WHERE id = ?",[a]);if(!e){c=null;return}let f=h(e),g={...f,...b,updatedAt:new Date().toISOString()};i(d,g),void 0!==b.priority&&l(d,f.provider),c=g}),c}async function o(a){let b=await (0,e.c)(),c=!1;return b.transaction(()=>{let d=b.get("SELECT provider FROM providerConnections WHERE id = ?",[a]);d&&(b.run("DELETE FROM providerConnections WHERE id = ?",[a]),l(b,d.provider),c=!0)}),c}async function p(a){let b=await (0,e.c)(),c=b.get("SELECT COUNT(*) AS n FROM providerConnections WHERE provider = ?",[a]);return b.run("DELETE FROM providerConnections WHERE provider = ?",[a]),c?.n||0}async function q(a){let b=await (0,e.c)();b.transaction(()=>l(b,a))}async function r(){let a=await (0,e.c)(),b=["displayName","email","globalPriority","defaultModel","accessToken","refreshToken","expiresAt","tokenType","scope","projectId","apiKey","testStatus","lastTested","lastError","lastErrorAt","rateLimitedUntil","expiresIn","consecutiveUseCount"],c=0;return a.transaction(()=>{for(let d of a.all("SELECT * FROM providerConnections")){let e=h(d),f=!1;for(let a of b)(null===e[a]||void 0===e[a])&&a in e&&(delete e[a],c++,f=!0);e.providerSpecificData&&0===Object.keys(e.providerSpecificData).length&&(delete e.providerSpecificData,c++,f=!0),f&&i(a,e)}}),c}}};
@@ -1 +0,0 @@
1
- "use strict";exports.id=523,exports.ids=[523],exports.modules={80523:(a,b,c)=>{c.d(b,{SignJWT:()=>d.P,importPKCS8:()=>l});var d=c(87690),e=c(10550),f=c(78679);let g=(a,b)=>{if(a.byteLength!==b.length)return!1;for(let c=0;c<a.byteLength;c++)if(a[c]!==b[c])return!1;return!0},h=a=>{let b=a.data[a.pos++];if(128&b){let c=127&b,d=0;for(let b=0;b<c;b++)d=d<<8|a.data[a.pos++];return d}return b},i=(a,b,c)=>{if(a.data[a.pos++]!==b)throw Error(c)},j=(a,b)=>{let c=a.data.subarray(a.pos,a.pos+b);return a.pos+=b,c},k=async(a,b,c,d)=>{let e,g,h="spki"===a,i=()=>h?["verify"]:["sign"];switch(c){case"PS256":case"PS384":case"PS512":e={name:"RSA-PSS",hash:`SHA-${c.slice(-3)}`},g=i();break;case"RS256":case"RS384":case"RS512":e={name:"RSASSA-PKCS1-v1_5",hash:`SHA-${c.slice(-3)}`},g=i();break;case"RSA-OAEP":case"RSA-OAEP-256":case"RSA-OAEP-384":case"RSA-OAEP-512":e={name:"RSA-OAEP",hash:`SHA-${parseInt(c.slice(-3),10)||1}`},g=h?["encrypt","wrapKey"]:["decrypt","unwrapKey"];break;case"ES256":case"ES384":case"ES512":e={name:"ECDSA",namedCurve:({ES256:"P-256",ES384:"P-384",ES512:"P-521"})[c]},g=i();break;case"ECDH-ES":case"ECDH-ES+A128KW":case"ECDH-ES+A192KW":case"ECDH-ES+A256KW":try{let a=d.getNamedCurve(b);e="X25519"===a?{name:"X25519"}:{name:"ECDH",namedCurve:a}}catch(a){throw new f.T0("Invalid or unsupported key format")}g=h?[]:["deriveBits"];break;case"Ed25519":case"EdDSA":e={name:"Ed25519"},g=i();break;case"ML-DSA-44":case"ML-DSA-65":case"ML-DSA-87":e={name:c},g=i();break;default:throw new f.T0('Invalid or unsupported "alg" (Algorithm) value')}return crypto.subtle.importKey(a,b,e,d?.extractable??!!h,g)};async function l(a,b,c){let d,f,l;if("string"!=typeof a||0!==a.indexOf("-----BEGIN PRIVATE KEY-----"))throw TypeError('"pkcs8" must be PKCS#8 formatted string');return d=/(?:-----(?:BEGIN|END) PRIVATE KEY-----|\s)/g,f=(0,e.y)(a.replace(d,"")),l=c,b?.startsWith?.("ECDH-ES")&&((l||={}).getNamedCurve=a=>{let b,c={data:a,pos:0};return i(c,48,"Invalid PKCS#8 structure"),h(c),i(c,2,"Expected version field"),b=h(c),c.pos+=b,i(c,48,"Expected algorithm identifier"),h(c),c.pos,(a=>{let b,c=(i(a,6,"Expected algorithm OID"),b=h(a),j(a,b));if(g(c,[43,101,110]))return"X25519";if(!g(c,[42,134,72,206,61,2,1]))throw Error("Unsupported key algorithm");i(a,6,"Expected curve OID");let d=h(a),e=j(a,d);for(let{name:a,oid:b}of[{name:"P-256",oid:[42,134,72,206,61,3,1,7]},{name:"P-384",oid:[43,129,4,0,34]},{name:"P-521",oid:[43,129,4,0,35]}])if(g(e,b))return a;throw Error("Unsupported named curve")})(c)}),k("pkcs8",f,b,l)}}};