n9router 0.3.94 → 0.3.95
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.
- package/.next/standalone/.next/BUILD_ID +1 -1
- package/.next/standalone/.next/build-manifest.json +3 -3
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/basic-chat/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/basic-chat/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/cli-tools/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/combos/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/console-log/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/console-log/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/endpoint/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/mitm/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/mitm/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/profile/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/profile/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/[id]/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/new/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/proxy-pools/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/proxy-pools/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/quota/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/quota/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/translator/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/usage/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_global-error.html +1 -1
- package/.next/standalone/.next/server/app/_global-error.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_not-found.html +1 -1
- package/.next/standalone/.next/server/app/_not-found.rsc +10 -10
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +10 -10
- package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/api/antigravity-tools/import/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/auth/login/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/antigravity-mitm/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cloud/auth/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cloud/credentials/update/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cloud/model/resolve/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cloud/models/alias/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/combos/[id]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/combos/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/init/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/internal/request-detail/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/internal/usage/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/keys/[id]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/keys/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/models/alias/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/models/availability/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/models/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/models/test/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/oauth/[provider]/[action]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/oauth/cursor/import/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/oauth/gitlab/pat/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/oauth/iflow/cookie/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/oauth/kiro/import/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/oauth/kiro/social-exchange/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/pricing/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/provider-nodes/[id]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/provider-nodes/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/[id]/models/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/[id]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/[id]/test/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/[id]/test-models/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/client/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/test-batch/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/providers/validate/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/proxy-pools/[id]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/proxy-pools/[id]/test/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/proxy-pools/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/settings/database/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/settings/require-login/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/settings/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/translator/send/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/translator/translate/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/tunnel/disable/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/tunnel/enable/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/tunnel/status/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/[connectionId]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/chart/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/history/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/logs/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/providers/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/request-details/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/request-logs/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/stats/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/usage/stream/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1/api/chat/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1/chat/completions/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1/embeddings/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1/messages/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1/models/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1/responses/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/callback/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/callback/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/callback.html +1 -1
- package/.next/standalone/.next/server/app/callback.rsc +12 -12
- package/.next/standalone/.next/server/app/callback.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/callback.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/callback.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/callback.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/callback.segments/callback/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/callback.segments/callback.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/basic-chat.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/basic-chat.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat/__PAGE__.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard/basic-chat.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/cli-tools.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/cli-tools.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools/__PAGE__.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard/cli-tools.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/combos.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/combos.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard/combos.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/combos.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/combos.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/combos.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/combos.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/endpoint.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/endpoint.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint/__PAGE__.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard/endpoint.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/mitm.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/mitm.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm/__PAGE__.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard/mitm.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/profile.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/profile.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard/profile.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/profile.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/profile.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/profile.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/profile.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/providers/new.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/providers/new.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers/new.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/providers.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/providers.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard/providers.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/providers.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/providers.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/providers.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/providers.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard/proxy-pools.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/quota.html +2 -2
- package/.next/standalone/.next/server/app/dashboard/quota.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard/quota.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/quota.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/quota.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/quota.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/quota.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/settings/pricing/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings/pricing.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard/settings.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/translator.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/translator.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard/translator.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/translator.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/translator.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/translator.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/translator.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard/usage.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/usage.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard/usage.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard/usage.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/usage.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/dashboard/usage.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard/usage.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/dashboard.html +1 -1
- package/.next/standalone/.next/server/app/dashboard.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard/__PAGE__.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk/dashboard.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/dashboard.segments/!KGRhc2hib2FyZCk.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/dashboard.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/dashboard.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/index.html +1 -1
- package/.next/standalone/.next/server/app/index.rsc +10 -10
- package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +10 -10
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/landing/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/landing/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/landing.html +1 -1
- package/.next/standalone/.next/server/app/landing.rsc +12 -12
- package/.next/standalone/.next/server/app/landing.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/landing.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/landing.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/landing.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/landing.segments/landing/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/landing.segments/landing.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/login/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/login/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/login.html +1 -1
- package/.next/standalone/.next/server/app/login.rsc +12 -12
- package/.next/standalone/.next/server/app/login.segments/_full.segment.rsc +12 -12
- package/.next/standalone/.next/server/app/login.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/login.segments/_index.segment.rsc +5 -5
- package/.next/standalone/.next/server/app/login.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/login.segments/login/__PAGE__.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/login.segments/login.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0.yvcis._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0148t9m._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b802lh._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0kpc-o6._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0lc~.sk._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0lp_pm5._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0pwrfp1._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0uw3x8s._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0y.reft._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0y5ae.7._.js +1 -1
- package/.next/standalone/.next/server/chunks/_0__-aqg._.js +1 -1
- package/.next/standalone/.next/server/chunks/_0_ovl1h._.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/src_0_xhepz._.js +1 -1
- package/.next/standalone/.next/server/middleware-build-manifest.js +3 -3
- package/.next/standalone/.next/server/pages/404.html +1 -1
- package/.next/standalone/.next/server/pages/500.html +1 -1
- package/.next/{static/chunks/02suuzz60dp3d.js → standalone/.next/static/chunks/11q6656-lc_oz.js} +1 -1
- package/.next/standalone/mitm/server.js +3 -2
- package/.next/standalone/mitm/tokenPool.js +108 -8
- package/.next/standalone/package-lock.json +2 -2
- package/.next/standalone/package.json +1 -1
- package/.next/standalone/plans/tauri-app/01-scope-and-architecture.md +218 -0
- package/.next/standalone/plans/tauri-app/02-backend-plan.md +237 -0
- package/.next/standalone/plans/tauri-app/03-tauri-native-plan.md +194 -0
- package/.next/standalone/plans/tauri-app/04-react-ui-plan.md +155 -0
- package/.next/standalone/plans/tauri-app/05-delivery-phases.md +171 -0
- package/.next/standalone/plans/tauri-app/README.md +87 -0
- package/.next/standalone/src/mitm/server.js +3 -2
- package/.next/standalone/src/mitm/tokenPool.js +108 -8
- package/.next/{standalone/.next/static/chunks/02suuzz60dp3d.js → static/chunks/11q6656-lc_oz.js} +1 -1
- package/package.json +1 -1
- /package/.next/standalone/.next/static/{SBId4_Ewcg0cJ2p2zlKeg → 03mW5vaG0Fogum-tDkkOQ}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{SBId4_Ewcg0cJ2p2zlKeg → 03mW5vaG0Fogum-tDkkOQ}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/.next/static/{SBId4_Ewcg0cJ2p2zlKeg → 03mW5vaG0Fogum-tDkkOQ}/_ssgManifest.js +0 -0
- /package/.next/static/{SBId4_Ewcg0cJ2p2zlKeg → 03mW5vaG0Fogum-tDkkOQ}/_buildManifest.js +0 -0
- /package/.next/static/{SBId4_Ewcg0cJ2p2zlKeg → 03mW5vaG0Fogum-tDkkOQ}/_clientMiddlewareManifest.js +0 -0
- /package/.next/static/{SBId4_Ewcg0cJ2p2zlKeg → 03mW5vaG0Fogum-tDkkOQ}/_ssgManifest.js +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function a(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class i{#e;#t;#r=!1;#o=null;#a=null;#i=null;#n=null;#s(e){return this.#n=e,this.#i||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#i?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#a,this.#a=this.#i=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new i(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new n(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},85063,e=>{"use strict";e.i(46786);let t={clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile","https://www.googleapis.com/auth/cclog","https://www.googleapis.com/auth/experimentsandconfigs"],apiEndpoint:"https://cloudcode-pa.googleapis.com",apiVersion:"v1internal",loadCodeAssistEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:loadCodeAssist",onboardUserEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:onboardUser",loadCodeAssistUserAgent:"google-api-nodejs-client/9.15.1",loadCodeAssistApiClient:"google-cloud-sdk vscode_cloudshelleditor/0.1",loadCodeAssistClientMetadata:JSON.stringify({ideType:"IDE_UNSPECIFIED",platform:"PLATFORM_UNSPECIFIED",pluginType:"GEMINI"})},r={clientId:process.env.KIMI_CODING_OAUTH_CLIENT_ID||"17e5f671-d194-4dfb-9706-5516cb48c098",deviceCodeUrl:"https://auth.kimi.com/api/oauth/device_authorization",tokenUrl:"https://auth.kimi.com/api/oauth/token"};e.s(["ANTIGRAVITY_CONFIG",0,t,"CLAUDE_CONFIG",0,{clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",authorizeUrl:"https://claude.ai/oauth/authorize",tokenUrl:"https://api.anthropic.com/v1/oauth/token",scopes:["org:create_api_key","user:profile","user:inference"],codeChallengeMethod:"S256"},"CLINE_CONFIG",0,{appBaseUrl:"https://app.cline.bot",apiBaseUrl:"https://api.cline.bot",authorizeUrl:"https://api.cline.bot/api/v1/auth/authorize",tokenExchangeUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},"CODEBUDDY_CONFIG",0,{baseUrl:"https://copilot.tencent.com",stateUrl:"https://copilot.tencent.com/v2/plugin/auth/state",tokenUrl:"https://copilot.tencent.com/v2/plugin/auth/token",refreshUrl:"https://copilot.tencent.com/v2/plugin/auth/token/refresh",userAgent:"CLI/2.63.2 CodeBuddy/2.63.2",platform:"CLI",pollInterval:5e3},"CODEX_CONFIG",0,{clientId:"app_EMoamEEZ73f0CkXaXp7hrann",authorizeUrl:"https://auth.openai.com/oauth/authorize",tokenUrl:"https://auth.openai.com/oauth/token",scope:"openid profile email offline_access",codeChallengeMethod:"S256",extraParams:{id_token_add_organizations:"true",codex_cli_simplified_flow:"true",originator:"codex_cli_rs"}},"CURSOR_CONFIG",0,{apiEndpoint:"https://api2.cursor.sh",chatEndpoint:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",modelsEndpoint:"/aiserver.v1.AiService/GetDefaultModelNudgeData",api3Endpoint:"https://api3.cursor.sh",agentEndpoint:"https://agent.api5.cursor.sh",agentNonPrivacyEndpoint:"https://agentn.api5.cursor.sh",clientVersion:"0.48.6",clientType:"ide",tokenStoragePaths:{linux:"~/.config/Cursor/User/globalStorage/state.vscdb",macos:"/Users/<user>/Library/Application Support/Cursor/User/globalStorage/state.vscdb",windows:"%APPDATA%\\Cursor\\User\\globalStorage\\state.vscdb"},dbKeys:{accessToken:"cursorAuth/accessToken",machineId:"storage.serviceMachineId"}},"GEMINI_CONFIG",0,{clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile"]},"GITHUB_CONFIG",0,{clientId:"Iv1.b507a08c87ecfe98",deviceCodeUrl:"https://github.com/login/device/code",tokenUrl:"https://github.com/login/oauth/access_token",userInfoUrl:"https://api.github.com/user",scopes:"read:user",apiVersion:"2022-11-28",copilotTokenUrl:"https://api.github.com/copilot_internal/v2/token",userAgent:"GitHubCopilotChat/0.26.7",editorVersion:"vscode/1.85.0",editorPluginVersion:"copilot-chat/0.26.7"},"GITLAB_CONFIG",0,{defaultBaseUrl:"https://gitlab.com",authorizeUrlPath:"/oauth/authorize",tokenUrlPath:"/oauth/token",userInfoUrlPath:"/api/v4/user",scope:"api read_user",codeChallengeMethod:"S256"},"IFLOW_CONFIG",0,{clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",authorizeUrl:"https://iflow.cn/oauth",tokenUrl:"https://iflow.cn/oauth/token",userInfoUrl:"https://iflow.cn/api/oauth/getUserInfo",extraParams:{loginMethod:"phone",type:"phone"}},"KILOCODE_CONFIG",0,{apiBaseUrl:"https://api.kilo.ai",initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},"KIMI_CODING_CONFIG",0,r,"KIRO_CONFIG",0,{ssoOidcEndpoint:"https://oidc.us-east-1.amazonaws.com",registerClientUrl:"https://oidc.us-east-1.amazonaws.com/client/register",deviceAuthUrl:"https://oidc.us-east-1.amazonaws.com/device_authorization",tokenUrl:"https://oidc.us-east-1.amazonaws.com/token",startUrl:"https://view.awsapps.com/start",clientName:"kiro-oauth-client",clientType:"public",scopes:["codewhisperer:completions","codewhisperer:analysis","codewhisperer:conversations"],grantTypes:["urn:ietf:params:oauth:grant-type:device_code","refresh_token"],issuerUrl:"https://identitycenter.amazonaws.com/ssoins-722374e8c3c8e6c6",socialAuthEndpoint:"https://prod.us-east-1.auth.desktop.kiro.dev",socialLoginUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/login",socialTokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/oauth/token",socialRefreshUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authMethods:["builder-id","idc","google","github","import"]},"QODER_CONFIG",0,{apiBaseUrl:"https://api2.qoder.sh",deviceTokenUrl:"https://api2.qoder.sh/api/v1/deviceToken/poll",deviceRefreshUrl:"https://api2.qoder.sh/api/v1/deviceToken/refresh",refreshUrl:"https://api2.qoder.sh/api/v3/user/refresh_token",userInfoUrl:"https://api2.qoder.sh/api/v1/userinfo",statusUrl:"https://api2.qoder.sh/api/v3/user/status",loginUrl:"https://qoder.com/login"},"QWEN_CONFIG",0,{clientId:"f0304373b74a44d2b584a3fb70ca9e56",deviceCodeUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",scope:"openid profile email model.completion",codeChallengeMethod:"S256"}])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},i="openai-compatible-",n="anthropic-compatible-",s={...t,...r,...o,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,i,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(i)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.94",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,r={}){let o,a=(o=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${o}`:"",i={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...r};return a&&(i.Authorization=a),i}])},1102,e=>{"use strict";e.i(69789);var t=e.i(26753);function r(e){return null==e?"":String(e).trim()}async function o(e={}){let a=r(e?.proxyPoolId),i="__none__"===a?"":a,n=function(e={}){let t=e?.connectionProxyEnabled===!0;return{connectionProxyEnabled:t,connectionProxyUrl:r(e?.connectionProxyUrl),connectionNoProxy:r(e?.connectionNoProxy)}}(e);if(i){let e=await (0,t.getProxyPoolById)(i),o=r(e?.proxyUrl),a=r(e?.noProxy);if(e&&!0===e.isActive&&o)return{source:"pool",proxyPoolId:i,proxyPool:e,connectionProxyEnabled:!0,connectionProxyUrl:o,connectionNoProxy:a,strictProxy:!0===e.strictProxy}}return n.connectionProxyEnabled&&n.connectionProxyUrl?{source:"legacy",proxyPoolId:i||null,proxyPool:null,...n}:{source:"none",proxyPoolId:i||null,proxyPool:null,...n}}e.s(["resolveConnectionProxyConfig",0,o])},78500,(e,t,r)=>{t.exports=e.x("node:async_hooks",()=>require("node:async_hooks"))},60709,e=>{"use strict";var t=e.i(36689);function r(e){return null==e?"":String(e).trim()}async function o({proxyUrl:e,testUrl:a,timeoutMs:i}={}){let n,s=r(e);if(!s)return{ok:!1,status:400,error:"proxyUrl is required"};let l=r(a)||"https://google.com/",c=Number(i),d=Number.isFinite(c)&&c>0?Math.min(c,3e4):8e3;try{try{n=new t.ProxyAgent({uri:s})}catch(e){return{ok:!1,status:400,error:`Invalid proxy URL: ${e?.message||String(e)}`}}let e=new AbortController,r=Date.now(),o=setTimeout(()=>e.abort(),d);try{let o=await (0,t.fetch)(l,{method:"HEAD",dispatcher:n,signal:e.signal,headers:{"User-Agent":"9Router"}});return{ok:o.ok,status:o.status,statusText:o.statusText,url:l,elapsedMs:Date.now()-r}}catch(t){let e=t?.name==="AbortError"?"Proxy test timed out":function(e){if(!e)return"Unknown error";let t=e?.message||String(e),r=e?.cause?.code||e?.code,o=e?.cause?.message;return o&&o!==t?r?`${t}: ${o} (${r})`:`${t}: ${o}`:r&&!t.includes(r)?`${t} (${r})`:t}(t);return{ok:!1,status:500,error:e}}finally{clearTimeout(o)}}finally{try{await n?.close?.()}catch{}}}e.s(["testProxyUrl",0,o])},21122,e=>{"use strict";var t=e.i(26753),r=e.i(1102),o=e.i(60709),a=e.i(88077),i=e.i(20491),n=e.i(85063),s=e.i(26406);let l={claude:{checkExpiry:!0,refreshable:!0},codex:{url:"https://chatgpt.com/backend-api/codex/responses",method:"POST",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"Content-Type":"application/json",originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},body:JSON.stringify({model:"gpt-5.3-codex",input:[],stream:!1,store:!1}),acceptStatuses:[400],refreshable:!0},"gemini-cli":{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},antigravity:{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},github:{url:"https://api.github.com/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"User-Agent":"9Router",Accept:"application/vnd.github+json"}},iflow:{buildUrl:e=>`https://iflow.cn/api/oauth/getUserInfo?accessToken=${encodeURIComponent(e)}`,method:"GET",noAuth:!0},qwen:{checkExpiry:!0,refreshable:!0},kiro:{checkExpiry:!0,refreshable:!0},"kimi-coding":{checkExpiry:!0,refreshable:!1},cursor:{tokenExists:!0},kilocode:{url:`${n.KILOCODE_CONFIG.apiBaseUrl}/api/profile`,method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},cline:{refreshable:!0},gitlab:{url:"https://gitlab.com/api/v4/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},codebuddy:{tokenExists:!0}};async function c(e){return await fetch("https://api.cline.bot/api/v1/users/me",{method:"GET",headers:(0,s.buildClineHeaders)(e,{Accept:"application/json"})})}async function d(e){let t=e.provider,r=e.refreshToken;if(!r)return null;try{if("gemini-cli"===t||"antigravity"===t){let e="gemini-cli"===t?n.GEMINI_CONFIG:n.ANTIGRAVITY_CONFIG,o=await fetch("https://oauth2.googleapis.com/token",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e.clientId,client_secret:e.clientSecret,grant_type:"refresh_token",refresh_token:r})});if(!o.ok)return null;let a=await o.json();return{accessToken:a.access_token,expiresIn:a.expires_in,refreshToken:a.refresh_token||r}}if("codex"===t){let e=await fetch(n.CODEX_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",client_id:n.CODEX_CONFIG.clientId,refresh_token:r})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("claude"===t){let e=await fetch(n.CLAUDE_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:r,client_id:n.CLAUDE_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("kiro"===t){let t=e.providerSpecificData||{},o=t.clientId||e.clientId,a=t.clientSecret||e.clientSecret,i=t.region||e.region;if(o&&a){let e=`https://oidc.${i||"us-east-1"}.amazonaws.com/token`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientId:o,clientSecret:a,refreshToken:r,grantType:"refresh_token"})});if(!t.ok)return null;let n=await t.json();return{accessToken:n.accessToken,expiresIn:n.expiresIn||3600,refreshToken:n.refreshToken||r}}let s=await fetch(n.KIRO_CONFIG.socialRefreshUrl,{method:"POST",headers:{"Content-Type":"application/json","User-Agent":"kiro-cli/1.0.0"},body:JSON.stringify({refreshToken:r})});if(!s.ok)return null;let l=await s.json();return{accessToken:l.accessToken,expiresIn:l.expiresIn||3600,refreshToken:l.refreshToken||r}}if("qwen"===t){let e=await fetch(n.QWEN_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:r,client_id:n.QWEN_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("cline"===t){let e=await fetch(n.CLINE_CONFIG.refreshUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({refreshToken:r,grantType:"refresh_token",clientType:"extension"})});if(!e.ok)return null;let t=await e.json(),o=t?.data||t,a=o?.expiresAt?Math.max(1,Math.floor((new Date(o.expiresAt).getTime()-Date.now())/1e3)):3600;return{accessToken:o?.accessToken,expiresIn:a,refreshToken:o?.refreshToken||r}}return null}catch(e){return console.log(`Error refreshing ${t} token:`,e.message),null}}async function p(e,t=null){var r;let o=l[e.provider];if(!o)return{valid:!1,error:"Provider test not supported",refreshed:!1};if(!e.accessToken)return{valid:!1,error:"No access token",refreshed:!1};if(o.tokenExists)return{valid:!0,error:null,refreshed:!1,newTokens:null};let a=e.accessToken,i=!1,n=null,s=!!(r=e).expiresAt&&new Date(r.expiresAt).getTime()<=Date.now()+3e5;if(o.refreshable&&s&&e.refreshToken){let t=await d(e);if(!t)return{valid:!1,error:"Token expired and refresh failed",refreshed:!1};a=t.accessToken,i=!0,n=t}if(o.checkExpiry)return i?{valid:!0,error:null,refreshed:i,newTokens:n}:s?{valid:!1,error:"Token expired",refreshed:!1}:{valid:!0,error:null,refreshed:!1,newTokens:null};if("cline"===e.provider){let t=async e=>{let t=await c(e);return t.ok?{valid:!0,error:null,refreshed:i,newTokens:n}:401===t.status?{valid:!1,error:"Token invalid or revoked",refreshed:i}:403===t.status?{valid:!1,error:"Access denied",refreshed:i}:{valid:!1,error:`API returned ${t.status}`,refreshed:i}},r=await t(a);if(r.valid||"Token invalid or revoked"!==r.error||!e.refreshToken)return r;let o=await d(e);return o?.accessToken?(i=!0,n=o,a=o.accessToken,await t(a)):{valid:!1,error:"Token invalid or revoked",refreshed:!1}}try{let r=o.buildUrl?o.buildUrl(a):o.url,s=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a}`,...o.extraHeaders},l={method:o.method,headers:s};o.body&&(l.body=o.body);let c=await u(r,l,t);if(c.ok||o.acceptStatuses&&o.acceptStatuses.includes(c.status))return{valid:!0,error:null,refreshed:i,newTokens:n};if(401===c.status&&o.refreshable&&!i&&e.refreshToken){let a=await d(e);if(a){let e=o.buildUrl?o.buildUrl(a.accessToken):r,i=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a.accessToken}`,...o.extraHeaders},n={method:o.method,headers:i};o.body&&(n.body=o.body);let s=await u(e,n,t);if(s.ok||o.acceptStatuses&&o.acceptStatuses.includes(s.status))return{valid:!0,error:null,refreshed:!0,newTokens:a}}return{valid:!1,error:"Token invalid or revoked",refreshed:!1}}if(401===c.status)return{valid:!1,error:"Token invalid or revoked",refreshed:i};if(403===c.status)return{valid:!1,error:"Access denied",refreshed:i};return{valid:!1,error:`API returned ${c.status}`,refreshed:i}}catch(e){return{valid:!1,error:e.message,refreshed:i}}}async function u(t,r={},o=null){if(!o?.connectionProxyEnabled||!o?.connectionProxyUrl)return fetch(t,r);let{proxyAwareFetch:a}=await e.A(27349);return a(t,r,{connectionProxyEnabled:!0,connectionProxyUrl:o.connectionProxyUrl,connectionNoProxy:o.connectionNoProxy||""})}async function h(e,t=null){if((0,a.isOpenAICompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{let o=await u(`${r.replace(/\/$/,"")}/models`,{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}if((0,a.isAnthropicCompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{(r=r.replace(/\/$/,"")).endsWith("/messages")&&(r=r.slice(0,-9));let o=await u(`${r}/models`,{headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}try{switch(e.provider){case"openai":{let r=await u("https://api.openai.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"anthropic":{let r=await u("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"claude-3-haiku-20240307",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"gemini":{let r=await u(`https://generativelanguage.googleapis.com/v1/models?key=${e.apiKey}`,{},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"openrouter":{let r=await u("https://openrouter.ai/api/v1/auth/key",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"glm":{let r=await u("https://api.z.ai/api/anthropic/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"glm-cn":{let r=await u("https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"minimax":case"minimax-cn":{let r=await u({minimax:"https://api.minimax.io/anthropic/v1/messages","minimax-cn":"https://api.minimaxi.com/anthropic/v1/messages"}[e.provider],{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"minimax-m2",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"kimi":{let r=await u("https://api.kimi.com/coding/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"kimi-latest",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"alicode":case"alicode-intl":{let r="alicode-intl"===e.provider?"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions":"https://coding.dashscope.aliyuncs.com/v1/chat/completions",o=await u(r,{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:(0,i.getDefaultModel)(e.provider),max_tokens:1,messages:[{role:"user",content:"test"}]})},t),a=401!==o.status&&403!==o.status;return{valid:a,error:a?null:"Invalid API key"}}case"deepseek":{let r=await u("https://api.deepseek.com/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"groq":{let r=await u("https://api.groq.com/openai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"mistral":{let r=await u("https://api.mistral.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"xai":{let r=await u("https://api.x.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nvidia":{let r=await u("https://integrate.api.nvidia.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"perplexity":{let r=await u("https://api.perplexity.ai/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"together":{let r=await u("https://api.together.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"fireworks":{let r=await u("https://api.fireworks.ai/inference/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cerebras":{let r=await u("https://api.cerebras.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cohere":{let r=await u("https://api.cohere.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nebius":{let r=await u("https://api.studio.nebius.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"siliconflow":{let r=await u("https://api.siliconflow.cn/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"hyperbolic":{let r=await u("https://api.hyperbolic.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"ollama":{let t=await fetch("https://ollama.com/api/tags",{headers:{Authorization:`Bearer ${e.apiKey}`}});return{valid:t.ok,error:t.ok?null:"Invalid API key"}}case"ollama-local":{let e=await fetch("http://localhost:11434/api/tags");return{valid:e.ok,error:e.ok?null:"Ollama not running on localhost:11434"}}case"deepgram":{let r=await u("https://api.deepgram.com/v1/projects",{headers:{Authorization:`Token ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"assemblyai":{let r=await u("https://api.assemblyai.com/v1/account",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nanobanana":{let r=await u("https://api.nanobananaapi.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"chutes":{let r=await u("https://llm.chutes.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}default:return{valid:!1,error:"Provider test not supported"}}}catch(e){return{valid:!1,error:e.message}}}async function m(e){let a,i=await (0,t.getProviderConnectionById)(e);if(!i)return{valid:!1,error:"Connection not found",latencyMs:0,testedAt:new Date().toISOString()};let n=await (0,r.resolveConnectionProxyConfig)(i.providerSpecificData||{});if(n.connectionProxyEnabled&&n.connectionProxyUrl){let r=await (0,o.testProxyUrl)({proxyUrl:n.connectionProxyUrl});if(!r.ok){let o=r.error||`Proxy test failed with status ${r.status}`;return await (0,t.updateProviderConnection)(e,{testStatus:"error",lastError:o,lastErrorAt:new Date().toISOString()}),{valid:!1,error:o,latencyMs:0,testedAt:new Date().toISOString()}}}let s=Date.now();a="apikey"===i.authType?await h(i,n):await p(i,n);let l=Date.now()-s,c={testStatus:a.valid?"active":"error",lastError:a.valid?null:a.error,lastErrorAt:a.valid?null:new Date().toISOString()};return a.refreshed&&a.newTokens&&(c.accessToken=a.newTokens.accessToken,a.newTokens.refreshToken&&(c.refreshToken=a.newTokens.refreshToken),a.newTokens.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*a.newTokens.expiresIn).toISOString())),await (0,t.updateProviderConnection)(e,c),{valid:a.valid,error:a.error,latencyMs:l,testedAt:new Date().toISOString()}}e.s(["testSingleConnection",0,m])},56945,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),i=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),h=e.i(70101),m=e.i(26937),f=e.i(10372),v=e.i(93695);e.i(20232);var g=e.i(220),y=e.i(89171);e.i(69789);var k=e.i(26753),w=e.i(88077),x=e.i(21122);function I(e,t=null){if(t?.authType)return"oauth"===t.authType?w.FREE_PROVIDERS[e]?"free":"oauth":t.authType;return w.FREE_PROVIDERS[e]?"free":w.OAUTH_PROVIDERS[e]?"oauth":w.APIKEY_PROVIDERS[e]?"apikey":"string"==typeof e&&(e.startsWith(w.OPENAI_COMPATIBLE_PREFIX)||e.startsWith(w.ANTHROPIC_COMPATIBLE_PREFIX))?"compatible":"apikey"}async function b(e){try{let{mode:t,providerId:r}=await e.json();if(!t)return y.NextResponse.json({error:"mode is required"},{status:400});let o=await (0,k.getProviderConnections)({isActive:!0}),a=[];if("provider"===t&&r)a=o.filter(e=>e.provider===r);else if("oauth"===t)a=o.filter(e=>"oauth"===I(e.provider,e));else if("free"===t)a=o.filter(e=>"free"===I(e.provider,e));else if("apikey"===t)a=o.filter(e=>"apikey"===I(e.provider,e));else if("compatible"===t)a=o.filter(e=>{var t;return t=e.provider,"string"==typeof t&&(t.startsWith(w.OPENAI_COMPATIBLE_PREFIX)||t.startsWith(w.ANTHROPIC_COMPATIBLE_PREFIX))});else{if("all"!==t)return y.NextResponse.json({error:"Invalid mode. Use: provider, oauth, free, apikey, compatible, all"},{status:400});a=o}if(0===a.length)return y.NextResponse.json({mode:t,providerId:r||null,results:[],summary:{total:0,passed:0,failed:0},testedAt:new Date().toISOString()});let i=[];for(let e of a)try{let t=await (0,x.testSingleConnection)(e.id);i.push({provider:e.provider,connectionId:e.id,connectionName:e.name||e.email||e.provider,authType:e.authType||I(e.provider,e),valid:t.valid,latencyMs:t.latencyMs||0,error:t.error||null,diagnosis:t.diagnosis||null,statusCode:t.statusCode||null,testedAt:t.testedAt||new Date().toISOString()})}catch(t){i.push({provider:e.provider,connectionId:e.id,connectionName:e.name||e.email||e.provider,authType:e.authType||I(e.provider,e),valid:!1,latencyMs:0,error:t.message,diagnosis:{type:"network_error",source:"local",code:null,message:t.message},statusCode:null,testedAt:new Date().toISOString()})}return y.NextResponse.json({mode:t,providerId:r||null,results:i,testedAt:new Date().toISOString(),summary:{total:i.length,passed:i.filter(e=>e.valid).length,failed:i.filter(e=>!e.valid).length}})}catch(e){return console.log("Error in batch test:",e),y.NextResponse.json({error:"Batch test failed"},{status:500})}}e.s(["POST",0,b],4525);var A=e.i(4525);let P=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/providers/test-batch/route",pathname:"/api/providers/test-batch",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/test-batch/route.js",nextConfigOutput:"standalone",userland:A,...{}}),{workAsyncStorage:C,workUnitAsyncStorage:T,serverHooks:E}=P;async function _(e,t,o){o.requestMeta&&(0,a.setRequestMeta)(e,o.requestMeta),P.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/providers/test-batch/route";y=y.replace(/\/index$/,"")||"/";let k=await P.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!k)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:I,parsedUrl:b,isDraftMode:A,prerenderManifest:C,routerServerContext:T,isOnDemandRevalidate:E,revalidateOnlyGenerated:_,resolvedPathname:O,clientReferenceManifest:U,serverActionsManifest:S}=k,N=(0,s.normalizeAppPath)(y),R=!!(C.dynamicRoutes[N]||C.routes[O]),F=async()=>((null==T?void 0:T.render404)?await T.render404(e,t,b,!1):t.end("This page could not be found"),null);if(R&&!A){let e=!!C.routes[O],t=C.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await F();throw new v.NoFallbackError}}let D=null;!R||P.isDev||A||(D="/index"===(D=O)?"/":D);let B=!0===P.isDev||!R,q=R&&!B;S&&U&&(0,n.setManifestsSingleton)({page:y,clientReferenceManifest:U,serverActionsManifest:S});let G=e.method||"GET",M=(0,i.getTracer)(),j=M.getActiveScopeSpan(),$=!!(null==T?void 0:T.isWrappedByNextServer),z=!!(0,a.getRequestMeta)(e,"minimalMode"),K=(0,a.getRequestMeta)(e,"incrementalCache")||await P.getIncrementalCache(e,I,C,z);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let L={params:x,previewProps:C.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:B,incrementalCache:K,cacheLifeProfiles:I.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>P.onRequestError(e,t,o,a,T)},sharedContext:{buildId:w}},H=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=c.NextRequestAdapter.fromNodeNextRequest(H,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>P.handle(X,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=M.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${G} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",o),a.updateName(t))}else e.updateName(`${G} ${y}`)}),s=async a=>{var i,s;let l=async({previousCacheEntry:r})=>{try{if(!z&&E&&_&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await n(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let s=L.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=L.renderOpts.collectedTags;if(!R)return await (0,u.sendResponse)(H,V,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,o=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await P.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:E})},!1,T),t}},c=await P.handleResponse({req:e,nextConfig:I,cacheKey:D,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:E,revalidateOnlyGenerated:_,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:z});if(!R)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",E?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return z&&R||d.delete(f.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)(H,V,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};$&&j?await s(j):(a=M.getActiveScopeSpan(),await M.withPropagatedContext(e.headers,()=>M.trace(d.BaseServerSpan.handleRequest,{spanName:`${G} ${y}`,kind:i.SpanKind.SERVER,attributes:{"http.method":G,"http.target":e.url}},s),void 0,!$))}catch(t){if(t instanceof v.NoFallbackError||await P.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:E})},!1,T),R)throw t;return await (0,u.sendResponse)(H,V,new Response(null,{status:500})),null}}e.s(["handler",0,_,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:C,workUnitAsyncStorage:T})},"routeModule",0,P,"serverHooks",0,E,"workAsyncStorage",0,C,"workUnitAsyncStorage",0,T],56945)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))},27349,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__09aoffc._.js"].map(t=>e.l(t))).then(()=>t(13061)))}];
|
|
1
|
+
module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function a(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class i{#e;#t;#r=!1;#o=null;#a=null;#i=null;#n=null;#s(e){return this.#n=e,this.#i||=new Promise((e,t)=>{this.#a=[e,t]}),new Promise((e,t)=>{this.#i?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await a(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#a,this.#a=this.#i=null,null!==this.#n){let e=this.#n;this.#n=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class n{#e;#c;constructor(e){this.#e=e,this.#c=new i(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new n(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},85063,e=>{"use strict";e.i(46786);let t={clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile","https://www.googleapis.com/auth/cclog","https://www.googleapis.com/auth/experimentsandconfigs"],apiEndpoint:"https://cloudcode-pa.googleapis.com",apiVersion:"v1internal",loadCodeAssistEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:loadCodeAssist",onboardUserEndpoint:"https://cloudcode-pa.googleapis.com/v1internal:onboardUser",loadCodeAssistUserAgent:"google-api-nodejs-client/9.15.1",loadCodeAssistApiClient:"google-cloud-sdk vscode_cloudshelleditor/0.1",loadCodeAssistClientMetadata:JSON.stringify({ideType:"IDE_UNSPECIFIED",platform:"PLATFORM_UNSPECIFIED",pluginType:"GEMINI"})},r={clientId:process.env.KIMI_CODING_OAUTH_CLIENT_ID||"17e5f671-d194-4dfb-9706-5516cb48c098",deviceCodeUrl:"https://auth.kimi.com/api/oauth/device_authorization",tokenUrl:"https://auth.kimi.com/api/oauth/token"};e.s(["ANTIGRAVITY_CONFIG",0,t,"CLAUDE_CONFIG",0,{clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",authorizeUrl:"https://claude.ai/oauth/authorize",tokenUrl:"https://api.anthropic.com/v1/oauth/token",scopes:["org:create_api_key","user:profile","user:inference"],codeChallengeMethod:"S256"},"CLINE_CONFIG",0,{appBaseUrl:"https://app.cline.bot",apiBaseUrl:"https://api.cline.bot",authorizeUrl:"https://api.cline.bot/api/v1/auth/authorize",tokenExchangeUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},"CODEBUDDY_CONFIG",0,{baseUrl:"https://copilot.tencent.com",stateUrl:"https://copilot.tencent.com/v2/plugin/auth/state",tokenUrl:"https://copilot.tencent.com/v2/plugin/auth/token",refreshUrl:"https://copilot.tencent.com/v2/plugin/auth/token/refresh",userAgent:"CLI/2.63.2 CodeBuddy/2.63.2",platform:"CLI",pollInterval:5e3},"CODEX_CONFIG",0,{clientId:"app_EMoamEEZ73f0CkXaXp7hrann",authorizeUrl:"https://auth.openai.com/oauth/authorize",tokenUrl:"https://auth.openai.com/oauth/token",scope:"openid profile email offline_access",codeChallengeMethod:"S256",extraParams:{id_token_add_organizations:"true",codex_cli_simplified_flow:"true",originator:"codex_cli_rs"}},"CURSOR_CONFIG",0,{apiEndpoint:"https://api2.cursor.sh",chatEndpoint:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",modelsEndpoint:"/aiserver.v1.AiService/GetDefaultModelNudgeData",api3Endpoint:"https://api3.cursor.sh",agentEndpoint:"https://agent.api5.cursor.sh",agentNonPrivacyEndpoint:"https://agentn.api5.cursor.sh",clientVersion:"0.48.6",clientType:"ide",tokenStoragePaths:{linux:"~/.config/Cursor/User/globalStorage/state.vscdb",macos:"/Users/<user>/Library/Application Support/Cursor/User/globalStorage/state.vscdb",windows:"%APPDATA%\\Cursor\\User\\globalStorage\\state.vscdb"},dbKeys:{accessToken:"cursorAuth/accessToken",machineId:"storage.serviceMachineId"}},"GEMINI_CONFIG",0,{clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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",authorizeUrl:"https://accounts.google.com/o/oauth2/v2/auth",tokenUrl:"https://oauth2.googleapis.com/token",userInfoUrl:"https://www.googleapis.com/oauth2/v1/userinfo",scopes:["https://www.googleapis.com/auth/cloud-platform","https://www.googleapis.com/auth/userinfo.email","https://www.googleapis.com/auth/userinfo.profile"]},"GITHUB_CONFIG",0,{clientId:"Iv1.b507a08c87ecfe98",deviceCodeUrl:"https://github.com/login/device/code",tokenUrl:"https://github.com/login/oauth/access_token",userInfoUrl:"https://api.github.com/user",scopes:"read:user",apiVersion:"2022-11-28",copilotTokenUrl:"https://api.github.com/copilot_internal/v2/token",userAgent:"GitHubCopilotChat/0.26.7",editorVersion:"vscode/1.85.0",editorPluginVersion:"copilot-chat/0.26.7"},"GITLAB_CONFIG",0,{defaultBaseUrl:"https://gitlab.com",authorizeUrlPath:"/oauth/authorize",tokenUrlPath:"/oauth/token",userInfoUrlPath:"/api/v4/user",scope:"api read_user",codeChallengeMethod:"S256"},"IFLOW_CONFIG",0,{clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",authorizeUrl:"https://iflow.cn/oauth",tokenUrl:"https://iflow.cn/oauth/token",userInfoUrl:"https://iflow.cn/api/oauth/getUserInfo",extraParams:{loginMethod:"phone",type:"phone"}},"KILOCODE_CONFIG",0,{apiBaseUrl:"https://api.kilo.ai",initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},"KIMI_CODING_CONFIG",0,r,"KIRO_CONFIG",0,{ssoOidcEndpoint:"https://oidc.us-east-1.amazonaws.com",registerClientUrl:"https://oidc.us-east-1.amazonaws.com/client/register",deviceAuthUrl:"https://oidc.us-east-1.amazonaws.com/device_authorization",tokenUrl:"https://oidc.us-east-1.amazonaws.com/token",startUrl:"https://view.awsapps.com/start",clientName:"kiro-oauth-client",clientType:"public",scopes:["codewhisperer:completions","codewhisperer:analysis","codewhisperer:conversations"],grantTypes:["urn:ietf:params:oauth:grant-type:device_code","refresh_token"],issuerUrl:"https://identitycenter.amazonaws.com/ssoins-722374e8c3c8e6c6",socialAuthEndpoint:"https://prod.us-east-1.auth.desktop.kiro.dev",socialLoginUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/login",socialTokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/oauth/token",socialRefreshUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authMethods:["builder-id","idc","google","github","import"]},"QODER_CONFIG",0,{apiBaseUrl:"https://api2.qoder.sh",deviceTokenUrl:"https://api2.qoder.sh/api/v1/deviceToken/poll",deviceRefreshUrl:"https://api2.qoder.sh/api/v1/deviceToken/refresh",refreshUrl:"https://api2.qoder.sh/api/v3/user/refresh_token",userInfoUrl:"https://api2.qoder.sh/api/v1/userinfo",statusUrl:"https://api2.qoder.sh/api/v3/user/status",loginUrl:"https://qoder.com/login"},"QWEN_CONFIG",0,{clientId:"f0304373b74a44d2b584a3fb70ca9e56",deviceCodeUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",scope:"openid profile email model.completion",codeChallengeMethod:"S256"}])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},a={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},i="openai-compatible-",n="anthropic-compatible-",s={...t,...r,...o,...a};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,n,"APIKEY_PROVIDERS",0,a,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,i,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(i)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.95",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,r={}){let o,a=(o=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${o}`:"",i={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...r};return a&&(i.Authorization=a),i}])},1102,e=>{"use strict";e.i(69789);var t=e.i(26753);function r(e){return null==e?"":String(e).trim()}async function o(e={}){let a=r(e?.proxyPoolId),i="__none__"===a?"":a,n=function(e={}){let t=e?.connectionProxyEnabled===!0;return{connectionProxyEnabled:t,connectionProxyUrl:r(e?.connectionProxyUrl),connectionNoProxy:r(e?.connectionNoProxy)}}(e);if(i){let e=await (0,t.getProxyPoolById)(i),o=r(e?.proxyUrl),a=r(e?.noProxy);if(e&&!0===e.isActive&&o)return{source:"pool",proxyPoolId:i,proxyPool:e,connectionProxyEnabled:!0,connectionProxyUrl:o,connectionNoProxy:a,strictProxy:!0===e.strictProxy}}return n.connectionProxyEnabled&&n.connectionProxyUrl?{source:"legacy",proxyPoolId:i||null,proxyPool:null,...n}:{source:"none",proxyPoolId:i||null,proxyPool:null,...n}}e.s(["resolveConnectionProxyConfig",0,o])},78500,(e,t,r)=>{t.exports=e.x("node:async_hooks",()=>require("node:async_hooks"))},60709,e=>{"use strict";var t=e.i(36689);function r(e){return null==e?"":String(e).trim()}async function o({proxyUrl:e,testUrl:a,timeoutMs:i}={}){let n,s=r(e);if(!s)return{ok:!1,status:400,error:"proxyUrl is required"};let l=r(a)||"https://google.com/",c=Number(i),d=Number.isFinite(c)&&c>0?Math.min(c,3e4):8e3;try{try{n=new t.ProxyAgent({uri:s})}catch(e){return{ok:!1,status:400,error:`Invalid proxy URL: ${e?.message||String(e)}`}}let e=new AbortController,r=Date.now(),o=setTimeout(()=>e.abort(),d);try{let o=await (0,t.fetch)(l,{method:"HEAD",dispatcher:n,signal:e.signal,headers:{"User-Agent":"9Router"}});return{ok:o.ok,status:o.status,statusText:o.statusText,url:l,elapsedMs:Date.now()-r}}catch(t){let e=t?.name==="AbortError"?"Proxy test timed out":function(e){if(!e)return"Unknown error";let t=e?.message||String(e),r=e?.cause?.code||e?.code,o=e?.cause?.message;return o&&o!==t?r?`${t}: ${o} (${r})`:`${t}: ${o}`:r&&!t.includes(r)?`${t} (${r})`:t}(t);return{ok:!1,status:500,error:e}}finally{clearTimeout(o)}}finally{try{await n?.close?.()}catch{}}}e.s(["testProxyUrl",0,o])},21122,e=>{"use strict";var t=e.i(26753),r=e.i(1102),o=e.i(60709),a=e.i(88077),i=e.i(20491),n=e.i(85063),s=e.i(26406);let l={claude:{checkExpiry:!0,refreshable:!0},codex:{url:"https://chatgpt.com/backend-api/codex/responses",method:"POST",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"Content-Type":"application/json",originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},body:JSON.stringify({model:"gpt-5.3-codex",input:[],stream:!1,store:!1}),acceptStatuses:[400],refreshable:!0},"gemini-cli":{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},antigravity:{url:"https://www.googleapis.com/oauth2/v1/userinfo?alt=json",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",refreshable:!0},github:{url:"https://api.github.com/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer ",extraHeaders:{"User-Agent":"9Router",Accept:"application/vnd.github+json"}},iflow:{buildUrl:e=>`https://iflow.cn/api/oauth/getUserInfo?accessToken=${encodeURIComponent(e)}`,method:"GET",noAuth:!0},qwen:{checkExpiry:!0,refreshable:!0},kiro:{checkExpiry:!0,refreshable:!0},"kimi-coding":{checkExpiry:!0,refreshable:!1},cursor:{tokenExists:!0},kilocode:{url:`${n.KILOCODE_CONFIG.apiBaseUrl}/api/profile`,method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},cline:{refreshable:!0},gitlab:{url:"https://gitlab.com/api/v4/user",method:"GET",authHeader:"Authorization",authPrefix:"Bearer "},codebuddy:{tokenExists:!0}};async function c(e){return await fetch("https://api.cline.bot/api/v1/users/me",{method:"GET",headers:(0,s.buildClineHeaders)(e,{Accept:"application/json"})})}async function d(e){let t=e.provider,r=e.refreshToken;if(!r)return null;try{if("gemini-cli"===t||"antigravity"===t){let e="gemini-cli"===t?n.GEMINI_CONFIG:n.ANTIGRAVITY_CONFIG,o=await fetch("https://oauth2.googleapis.com/token",{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({client_id:e.clientId,client_secret:e.clientSecret,grant_type:"refresh_token",refresh_token:r})});if(!o.ok)return null;let a=await o.json();return{accessToken:a.access_token,expiresIn:a.expires_in,refreshToken:a.refresh_token||r}}if("codex"===t){let e=await fetch(n.CODEX_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams({grant_type:"refresh_token",client_id:n.CODEX_CONFIG.clientId,refresh_token:r})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("claude"===t){let e=await fetch(n.CLAUDE_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({grant_type:"refresh_token",refresh_token:r,client_id:n.CLAUDE_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("kiro"===t){let t=e.providerSpecificData||{},o=t.clientId||e.clientId,a=t.clientSecret||e.clientSecret,i=t.region||e.region;if(o&&a){let e=`https://oidc.${i||"us-east-1"}.amazonaws.com/token`,t=await fetch(e,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({clientId:o,clientSecret:a,refreshToken:r,grantType:"refresh_token"})});if(!t.ok)return null;let n=await t.json();return{accessToken:n.accessToken,expiresIn:n.expiresIn||3600,refreshToken:n.refreshToken||r}}let s=await fetch(n.KIRO_CONFIG.socialRefreshUrl,{method:"POST",headers:{"Content-Type":"application/json","User-Agent":"kiro-cli/1.0.0"},body:JSON.stringify({refreshToken:r})});if(!s.ok)return null;let l=await s.json();return{accessToken:l.accessToken,expiresIn:l.expiresIn||3600,refreshToken:l.refreshToken||r}}if("qwen"===t){let e=await fetch(n.QWEN_CONFIG.tokenUrl,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded",Accept:"application/json"},body:new URLSearchParams({grant_type:"refresh_token",refresh_token:r,client_id:n.QWEN_CONFIG.clientId})});if(!e.ok)return null;let t=await e.json();return{accessToken:t.access_token,expiresIn:t.expires_in,refreshToken:t.refresh_token||r}}if("cline"===t){let e=await fetch(n.CLINE_CONFIG.refreshUrl,{method:"POST",headers:{"Content-Type":"application/json",Accept:"application/json"},body:JSON.stringify({refreshToken:r,grantType:"refresh_token",clientType:"extension"})});if(!e.ok)return null;let t=await e.json(),o=t?.data||t,a=o?.expiresAt?Math.max(1,Math.floor((new Date(o.expiresAt).getTime()-Date.now())/1e3)):3600;return{accessToken:o?.accessToken,expiresIn:a,refreshToken:o?.refreshToken||r}}return null}catch(e){return console.log(`Error refreshing ${t} token:`,e.message),null}}async function p(e,t=null){var r;let o=l[e.provider];if(!o)return{valid:!1,error:"Provider test not supported",refreshed:!1};if(!e.accessToken)return{valid:!1,error:"No access token",refreshed:!1};if(o.tokenExists)return{valid:!0,error:null,refreshed:!1,newTokens:null};let a=e.accessToken,i=!1,n=null,s=!!(r=e).expiresAt&&new Date(r.expiresAt).getTime()<=Date.now()+3e5;if(o.refreshable&&s&&e.refreshToken){let t=await d(e);if(!t)return{valid:!1,error:"Token expired and refresh failed",refreshed:!1};a=t.accessToken,i=!0,n=t}if(o.checkExpiry)return i?{valid:!0,error:null,refreshed:i,newTokens:n}:s?{valid:!1,error:"Token expired",refreshed:!1}:{valid:!0,error:null,refreshed:!1,newTokens:null};if("cline"===e.provider){let t=async e=>{let t=await c(e);return t.ok?{valid:!0,error:null,refreshed:i,newTokens:n}:401===t.status?{valid:!1,error:"Token invalid or revoked",refreshed:i}:403===t.status?{valid:!1,error:"Access denied",refreshed:i}:{valid:!1,error:`API returned ${t.status}`,refreshed:i}},r=await t(a);if(r.valid||"Token invalid or revoked"!==r.error||!e.refreshToken)return r;let o=await d(e);return o?.accessToken?(i=!0,n=o,a=o.accessToken,await t(a)):{valid:!1,error:"Token invalid or revoked",refreshed:!1}}try{let r=o.buildUrl?o.buildUrl(a):o.url,s=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a}`,...o.extraHeaders},l={method:o.method,headers:s};o.body&&(l.body=o.body);let c=await u(r,l,t);if(c.ok||o.acceptStatuses&&o.acceptStatuses.includes(c.status))return{valid:!0,error:null,refreshed:i,newTokens:n};if(401===c.status&&o.refreshable&&!i&&e.refreshToken){let a=await d(e);if(a){let e=o.buildUrl?o.buildUrl(a.accessToken):r,i=o.noAuth?{...o.extraHeaders}:{[o.authHeader]:`${o.authPrefix}${a.accessToken}`,...o.extraHeaders},n={method:o.method,headers:i};o.body&&(n.body=o.body);let s=await u(e,n,t);if(s.ok||o.acceptStatuses&&o.acceptStatuses.includes(s.status))return{valid:!0,error:null,refreshed:!0,newTokens:a}}return{valid:!1,error:"Token invalid or revoked",refreshed:!1}}if(401===c.status)return{valid:!1,error:"Token invalid or revoked",refreshed:i};if(403===c.status)return{valid:!1,error:"Access denied",refreshed:i};return{valid:!1,error:`API returned ${c.status}`,refreshed:i}}catch(e){return{valid:!1,error:e.message,refreshed:i}}}async function u(t,r={},o=null){if(!o?.connectionProxyEnabled||!o?.connectionProxyUrl)return fetch(t,r);let{proxyAwareFetch:a}=await e.A(27349);return a(t,r,{connectionProxyEnabled:!0,connectionProxyUrl:o.connectionProxyUrl,connectionNoProxy:o.connectionNoProxy||""})}async function h(e,t=null){if((0,a.isOpenAICompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{let o=await u(`${r.replace(/\/$/,"")}/models`,{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}if((0,a.isAnthropicCompatibleProvider)(e.provider)){let r=e.providerSpecificData?.baseUrl;if(!r)return{valid:!1,error:"Missing base URL"};try{(r=r.replace(/\/$/,"")).endsWith("/messages")&&(r=r.slice(0,-9));let o=await u(`${r}/models`,{headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e.apiKey}`}},t);return{valid:o.ok,error:o.ok?null:"Invalid API key or base URL"}}catch(e){return{valid:!1,error:e.message}}}try{switch(e.provider){case"openai":{let r=await u("https://api.openai.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"anthropic":{let r=await u("https://api.anthropic.com/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"claude-3-haiku-20240307",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"gemini":{let r=await u(`https://generativelanguage.googleapis.com/v1/models?key=${e.apiKey}`,{},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"openrouter":{let r=await u("https://openrouter.ai/api/v1/auth/key",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"glm":{let r=await u("https://api.z.ai/api/anthropic/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"glm-cn":{let r=await u("https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:"glm-4.7",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"minimax":case"minimax-cn":{let r=await u({minimax:"https://api.minimax.io/anthropic/v1/messages","minimax-cn":"https://api.minimaxi.com/anthropic/v1/messages"}[e.provider],{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"minimax-m2",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"kimi":{let r=await u("https://api.kimi.com/coding/v1/messages",{method:"POST",headers:{"x-api-key":e.apiKey,"anthropic-version":"2023-06-01","content-type":"application/json"},body:JSON.stringify({model:"kimi-latest",max_tokens:1,messages:[{role:"user",content:"test"}]})},t),o=401!==r.status&&403!==r.status;return{valid:o,error:o?null:"Invalid API key"}}case"alicode":case"alicode-intl":{let r="alicode-intl"===e.provider?"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions":"https://coding.dashscope.aliyuncs.com/v1/chat/completions",o=await u(r,{method:"POST",headers:{Authorization:`Bearer ${e.apiKey}`,"content-type":"application/json"},body:JSON.stringify({model:(0,i.getDefaultModel)(e.provider),max_tokens:1,messages:[{role:"user",content:"test"}]})},t),a=401!==o.status&&403!==o.status;return{valid:a,error:a?null:"Invalid API key"}}case"deepseek":{let r=await u("https://api.deepseek.com/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"groq":{let r=await u("https://api.groq.com/openai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"mistral":{let r=await u("https://api.mistral.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"xai":{let r=await u("https://api.x.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nvidia":{let r=await u("https://integrate.api.nvidia.com/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"perplexity":{let r=await u("https://api.perplexity.ai/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"together":{let r=await u("https://api.together.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"fireworks":{let r=await u("https://api.fireworks.ai/inference/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cerebras":{let r=await u("https://api.cerebras.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"cohere":{let r=await u("https://api.cohere.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nebius":{let r=await u("https://api.studio.nebius.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"siliconflow":{let r=await u("https://api.siliconflow.cn/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"hyperbolic":{let r=await u("https://api.hyperbolic.xyz/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"ollama":{let t=await fetch("https://ollama.com/api/tags",{headers:{Authorization:`Bearer ${e.apiKey}`}});return{valid:t.ok,error:t.ok?null:"Invalid API key"}}case"ollama-local":{let e=await fetch("http://localhost:11434/api/tags");return{valid:e.ok,error:e.ok?null:"Ollama not running on localhost:11434"}}case"deepgram":{let r=await u("https://api.deepgram.com/v1/projects",{headers:{Authorization:`Token ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"assemblyai":{let r=await u("https://api.assemblyai.com/v1/account",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"nanobanana":{let r=await u("https://api.nanobananaapi.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}case"chutes":{let r=await u("https://llm.chutes.ai/v1/models",{headers:{Authorization:`Bearer ${e.apiKey}`}},t);return{valid:r.ok,error:r.ok?null:"Invalid API key"}}default:return{valid:!1,error:"Provider test not supported"}}}catch(e){return{valid:!1,error:e.message}}}async function m(e){let a,i=await (0,t.getProviderConnectionById)(e);if(!i)return{valid:!1,error:"Connection not found",latencyMs:0,testedAt:new Date().toISOString()};let n=await (0,r.resolveConnectionProxyConfig)(i.providerSpecificData||{});if(n.connectionProxyEnabled&&n.connectionProxyUrl){let r=await (0,o.testProxyUrl)({proxyUrl:n.connectionProxyUrl});if(!r.ok){let o=r.error||`Proxy test failed with status ${r.status}`;return await (0,t.updateProviderConnection)(e,{testStatus:"error",lastError:o,lastErrorAt:new Date().toISOString()}),{valid:!1,error:o,latencyMs:0,testedAt:new Date().toISOString()}}}let s=Date.now();a="apikey"===i.authType?await h(i,n):await p(i,n);let l=Date.now()-s,c={testStatus:a.valid?"active":"error",lastError:a.valid?null:a.error,lastErrorAt:a.valid?null:new Date().toISOString()};return a.refreshed&&a.newTokens&&(c.accessToken=a.newTokens.accessToken,a.newTokens.refreshToken&&(c.refreshToken=a.newTokens.refreshToken),a.newTokens.expiresIn&&(c.expiresAt=new Date(Date.now()+1e3*a.newTokens.expiresIn).toISOString())),await (0,t.updateProviderConnection)(e,c),{valid:a.valid,error:a.error,latencyMs:l,testedAt:new Date().toISOString()}}e.s(["testSingleConnection",0,m])},56945,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),a=e.i(59756),i=e.i(61916),n=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),h=e.i(70101),m=e.i(26937),f=e.i(10372),v=e.i(93695);e.i(20232);var g=e.i(220),y=e.i(89171);e.i(69789);var k=e.i(26753),w=e.i(88077),x=e.i(21122);function I(e,t=null){if(t?.authType)return"oauth"===t.authType?w.FREE_PROVIDERS[e]?"free":"oauth":t.authType;return w.FREE_PROVIDERS[e]?"free":w.OAUTH_PROVIDERS[e]?"oauth":w.APIKEY_PROVIDERS[e]?"apikey":"string"==typeof e&&(e.startsWith(w.OPENAI_COMPATIBLE_PREFIX)||e.startsWith(w.ANTHROPIC_COMPATIBLE_PREFIX))?"compatible":"apikey"}async function b(e){try{let{mode:t,providerId:r}=await e.json();if(!t)return y.NextResponse.json({error:"mode is required"},{status:400});let o=await (0,k.getProviderConnections)({isActive:!0}),a=[];if("provider"===t&&r)a=o.filter(e=>e.provider===r);else if("oauth"===t)a=o.filter(e=>"oauth"===I(e.provider,e));else if("free"===t)a=o.filter(e=>"free"===I(e.provider,e));else if("apikey"===t)a=o.filter(e=>"apikey"===I(e.provider,e));else if("compatible"===t)a=o.filter(e=>{var t;return t=e.provider,"string"==typeof t&&(t.startsWith(w.OPENAI_COMPATIBLE_PREFIX)||t.startsWith(w.ANTHROPIC_COMPATIBLE_PREFIX))});else{if("all"!==t)return y.NextResponse.json({error:"Invalid mode. Use: provider, oauth, free, apikey, compatible, all"},{status:400});a=o}if(0===a.length)return y.NextResponse.json({mode:t,providerId:r||null,results:[],summary:{total:0,passed:0,failed:0},testedAt:new Date().toISOString()});let i=[];for(let e of a)try{let t=await (0,x.testSingleConnection)(e.id);i.push({provider:e.provider,connectionId:e.id,connectionName:e.name||e.email||e.provider,authType:e.authType||I(e.provider,e),valid:t.valid,latencyMs:t.latencyMs||0,error:t.error||null,diagnosis:t.diagnosis||null,statusCode:t.statusCode||null,testedAt:t.testedAt||new Date().toISOString()})}catch(t){i.push({provider:e.provider,connectionId:e.id,connectionName:e.name||e.email||e.provider,authType:e.authType||I(e.provider,e),valid:!1,latencyMs:0,error:t.message,diagnosis:{type:"network_error",source:"local",code:null,message:t.message},statusCode:null,testedAt:new Date().toISOString()})}return y.NextResponse.json({mode:t,providerId:r||null,results:i,testedAt:new Date().toISOString(),summary:{total:i.length,passed:i.filter(e=>e.valid).length,failed:i.filter(e=>!e.valid).length}})}catch(e){return console.log("Error in batch test:",e),y.NextResponse.json({error:"Batch test failed"},{status:500})}}e.s(["POST",0,b],4525);var A=e.i(4525);let P=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/providers/test-batch/route",pathname:"/api/providers/test-batch",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/test-batch/route.js",nextConfigOutput:"standalone",userland:A,...{}}),{workAsyncStorage:C,workUnitAsyncStorage:T,serverHooks:E}=P;async function _(e,t,o){o.requestMeta&&(0,a.setRequestMeta)(e,o.requestMeta),P.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/providers/test-batch/route";y=y.replace(/\/index$/,"")||"/";let k=await P.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!k)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:I,parsedUrl:b,isDraftMode:A,prerenderManifest:C,routerServerContext:T,isOnDemandRevalidate:E,revalidateOnlyGenerated:_,resolvedPathname:O,clientReferenceManifest:U,serverActionsManifest:S}=k,N=(0,s.normalizeAppPath)(y),R=!!(C.dynamicRoutes[N]||C.routes[O]),F=async()=>((null==T?void 0:T.render404)?await T.render404(e,t,b,!1):t.end("This page could not be found"),null);if(R&&!A){let e=!!C.routes[O],t=C.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await F();throw new v.NoFallbackError}}let D=null;!R||P.isDev||A||(D="/index"===(D=O)?"/":D);let B=!0===P.isDev||!R,q=R&&!B;S&&U&&(0,n.setManifestsSingleton)({page:y,clientReferenceManifest:U,serverActionsManifest:S});let G=e.method||"GET",M=(0,i.getTracer)(),j=M.getActiveScopeSpan(),$=!!(null==T?void 0:T.isWrappedByNextServer),z=!!(0,a.getRequestMeta)(e,"minimalMode"),K=(0,a.getRequestMeta)(e,"incrementalCache")||await P.getIncrementalCache(e,I,C,z);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let L={params:x,previewProps:C.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:B,incrementalCache:K,cacheLifeProfiles:I.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,a)=>P.onRequestError(e,t,o,a,T)},sharedContext:{buildId:w}},H=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=c.NextRequestAdapter.fromNodeNextRequest(H,(0,c.signalFromNodeResponse)(t));try{let a,n=async e=>P.handle(X,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=M.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${G} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),a&&a!==e&&(a.setAttribute("http.route",o),a.updateName(t))}else e.updateName(`${G} ${y}`)}),s=async a=>{var i,s;let l=async({previousCacheEntry:r})=>{try{if(!z&&E&&_&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await n(a);e.fetchMetrics=L.renderOpts.fetchMetrics;let s=L.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=L.renderOpts.collectedTags;if(!R)return await (0,u.sendResponse)(H,V,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,o=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await P.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:E})},!1,T),t}},c=await P.handleResponse({req:e,nextConfig:I,cacheKey:D,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:E,revalidateOnlyGenerated:_,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:z});if(!R)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",E?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return z&&R||d.delete(f.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)(H,V,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};$&&j?await s(j):(a=M.getActiveScopeSpan(),await M.withPropagatedContext(e.headers,()=>M.trace(d.BaseServerSpan.handleRequest,{spanName:`${G} ${y}`,kind:i.SpanKind.SERVER,attributes:{"http.method":G,"http.target":e.url}},s),void 0,!$))}catch(t){if(t instanceof v.NoFallbackError||await P.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:E})},!1,T),R)throw t;return await (0,u.sendResponse)(H,V,new Response(null,{status:500})),null}}e.s(["handler",0,_,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:C,workUnitAsyncStorage:T})},"routeModule",0,P,"serverHooks",0,E,"workAsyncStorage",0,C,"workUnitAsyncStorage",0,T],56945)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))},27349,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__09aoffc._.js"].map(t=>e.l(t))).then(()=>t(13061)))}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__0.yvcis._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function i(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class n{#e;#t;#r=!1;#o=null;#i=null;#n=null;#a=null;#s(e){return this.#a=e,this.#n||=new Promise((e,t)=>{this.#i=[e,t]}),new Promise((e,t)=>{this.#n?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await i(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#i,this.#i=this.#n=null,null!==this.#a){let e=this.#a;this.#a=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class a{#e;#c;constructor(e){this.#e=e,this.#c=new n(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new a(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},i={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},n="openai-compatible-",a="anthropic-compatible-",s={...t,...r,...o,...i};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,a,"APIKEY_PROVIDERS",0,i,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,n,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(a)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.94",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},53526,e=>{"use strict";var t=e.i(20491);Object.entries(e.i(88077).AI_PROVIDERS).filter(([,e])=>e.passthroughModels).map(([e])=>e);let r=Object.entries(t.PROVIDER_MODELS).flatMap(([e,t])=>t.map(t=>({provider:e,model:t.id,name:t.name})));e.s(["AI_MODELS",0,r])},55870,e=>{"use strict";var t=e.i(12943);e.i(88077),e.i(53526),t.default.version,e.s(["CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3}])},2604,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),i=e.i(59756),n=e.i(61916),a=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),m=e.i(70101),h=e.i(26937),x=e.i(10372),f=e.i(93695);e.i(20232);var w=e.i(220),v=e.i(89171);e.i(69789);var y=e.i(26753);e.i(55870);var b=e.i(88077);async function g(e){if(null==e||""===e||"__none__"===e)return{proxyPoolId:null};let t=String(e).trim();return t?await (0,y.getProxyPoolById)(t)?{proxyPoolId:t}:{error:"Proxy pool not found"}:{proxyPoolId:null}}async function I(){try{let e=await (0,y.getProviderConnections)(),t={};try{for(let e of(await (0,y.getProviderNodes)()))e.id&&e.name&&(t[e.id]=e.name)}catch{}let r=e.map(e=>{let r=(0,b.isOpenAICompatibleProvider)(e.provider)||(0,b.isAnthropicCompatibleProvider)(e.provider)?t[e.provider]||e.providerSpecificData?.nodeName||e.provider:e.name;return{...e,name:r,apiKey:void 0,accessToken:void 0,refreshToken:void 0,idToken:void 0}});return v.NextResponse.json({connections:r})}catch(e){return console.log("Error fetching providers:",e),v.NextResponse.json({error:"Failed to fetch providers"},{status:500})}}async function P(e){try{let t=await e.json(),{provider:r,apiKey:o,name:i,priority:n,globalPriority:a,defaultModel:s,testStatus:l}=t,c=function(e={}){let t=e?.connectionProxyEnabled===!0,r="string"==typeof e?.connectionProxyUrl?e.connectionProxyUrl.trim():"",o="string"==typeof e?.connectionNoProxy?e.connectionNoProxy.trim():"";return t&&!r?{error:"Connection proxy URL is required when connection proxy is enabled"}:{connectionProxyEnabled:t,connectionProxyUrl:r,connectionNoProxy:o}}(t);if(c.error)return v.NextResponse.json({error:c.error},{status:400});let d=await g(t.proxyPoolId);if(d.error)return v.NextResponse.json({error:d.error},{status:400});let p=d.proxyPoolId,u=b.APIKEY_PROVIDERS[r]||b.FREE_TIER_PROVIDERS[r]||(0,b.isOpenAICompatibleProvider)(r)||(0,b.isAnthropicCompatibleProvider)(r);if(!r||!u)return v.NextResponse.json({error:"Invalid provider"},{status:400});if(!o)return v.NextResponse.json({error:"API Key is required"},{status:400});if(!i)return v.NextResponse.json({error:"Name is required"},{status:400});let m=null;if((0,b.isOpenAICompatibleProvider)(r)){let e=await (0,y.getProviderNodeById)(r);if(!e)return v.NextResponse.json({error:"OpenAI Compatible node not found"},{status:404});if((await (0,y.getProviderConnections)({provider:r})).length>0)return v.NextResponse.json({error:"Only one connection is allowed for this OpenAI Compatible node"},{status:400});m={prefix:e.prefix,apiType:e.apiType,baseUrl:e.baseUrl,nodeName:e.name}}else if((0,b.isAnthropicCompatibleProvider)(r)){let e=await (0,y.getProviderNodeById)(r);if(!e)return v.NextResponse.json({error:"Anthropic Compatible node not found"},{status:404});if((await (0,y.getProviderConnections)({provider:r})).length>0)return v.NextResponse.json({error:"Only one connection is allowed for this Anthropic Compatible node"},{status:400});m={prefix:e.prefix,baseUrl:e.baseUrl,nodeName:e.name}}let h={...m||{},connectionProxyEnabled:c.connectionProxyEnabled,connectionProxyUrl:c.connectionProxyUrl,connectionNoProxy:c.connectionNoProxy};null!==p&&(h.proxyPoolId=p);let x={...await (0,y.createProviderConnection)({provider:r,authType:"apikey",name:i,apiKey:o,priority:n||1,globalPriority:a||null,defaultModel:s||null,providerSpecificData:h,isActive:!0,testStatus:l||"unknown"})};return delete x.apiKey,v.NextResponse.json({connection:x},{status:201})}catch(e){return console.log("Error creating provider:",e),v.NextResponse.json({error:"Failed to create provider"},{status:500})}}e.s(["GET",0,I,"POST",0,P,"dynamic",0,"force-dynamic"],61352);var R=e.i(61352);let A=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/providers/route",pathname:"/api/providers",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/route.js",nextConfigOutput:"standalone",userland:R,...{}}),{workAsyncStorage:E,workUnitAsyncStorage:C,serverHooks:N}=A;async function O(e,t,o){o.requestMeta&&(0,i.setRequestMeta)(e,o.requestMeta),A.isDev&&(0,i.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let v="/api/providers/route";v=v.replace(/\/index$/,"")||"/";let y=await A.prepare(e,t,{srcPage:v,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:b,params:g,nextConfig:I,parsedUrl:P,isDraftMode:R,prerenderManifest:E,routerServerContext:C,isOnDemandRevalidate:N,revalidateOnlyGenerated:O,resolvedPathname:_,clientReferenceManifest:F,serverActionsManifest:k}=y,D=(0,s.normalizeAppPath)(v),q=!!(E.dynamicRoutes[D]||E.routes[_]),S=async()=>((null==C?void 0:C.render404)?await C.render404(e,t,P,!1):t.end("This page could not be found"),null);if(q&&!R){let e=!!E.routes[_],t=E.dynamicRoutes[D];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await S();throw new f.NoFallbackError}}let T=null;!q||A.isDev||R||(T="/index"===(T=_)?"/":T);let j=!0===A.isDev||!q,M=q&&!j;k&&F&&(0,a.setManifestsSingleton)({page:v,clientReferenceManifest:F,serverActionsManifest:k});let U=e.method||"GET",B=(0,n.getTracer)(),L=B.getActiveScopeSpan(),G=!!(null==C?void 0:C.isWrappedByNextServer),V=!!(0,i.getRequestMeta)(e,"minimalMode"),H=(0,i.getRequestMeta)(e,"incrementalCache")||await A.getIncrementalCache(e,I,E,V);null==H||H.resetRequestCache(),globalThis.__incrementalCache=H;let K={params:g,previewProps:E.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:j,incrementalCache:H,cacheLifeProfiles:I.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,i)=>A.onRequestError(e,t,o,i,C)},sharedContext:{buildId:b}},$=new l.NodeNextRequest(e),X=new l.NodeNextResponse(t),W=c.NextRequestAdapter.fromNodeNextRequest($,(0,c.signalFromNodeResponse)(t));try{let i,a=async e=>A.handle(W,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=B.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${U} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),i&&i!==e&&(i.setAttribute("http.route",o),i.updateName(t))}else e.updateName(`${U} ${v}`)}),s=async i=>{var n,s;let l=async({previousCacheEntry:r})=>{try{if(!V&&N&&O&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await a(i);e.fetchMetrics=K.renderOpts.fetchMetrics;let s=K.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=K.renderOpts.collectedTags;if(!q)return await (0,u.sendResponse)($,X,n,K.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(n.headers);l&&(t[x.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=x.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,o=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=x.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:w.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await A.onRequestError(e,t,{routerKind:"App Router",routePath:v,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:N})},!1,C),t}},c=await A.handleResponse({req:e,nextConfig:I,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:N,revalidateOnlyGenerated:O,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:V});if(!q)return null;if((null==c||null==(n=c.value)?void 0:n.kind)!==w.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});V||t.setHeader("x-nextjs-cache",N?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),R&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,m.fromNodeOutgoingHttpHeaders)(c.value.headers);return V&&q||d.delete(x.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,h.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)($,X,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};G&&L?await s(L):(i=B.getActiveScopeSpan(),await B.withPropagatedContext(e.headers,()=>B.trace(d.BaseServerSpan.handleRequest,{spanName:`${U} ${v}`,kind:n.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},s),void 0,!G))}catch(t){if(t instanceof f.NoFallbackError||await A.onRequestError(e,t,{routerKind:"App Router",routePath:D,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:N})},!1,C),q)throw t;return await (0,u.sendResponse)($,X,new Response(null,{status:500})),null}}e.s(["handler",0,O,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:C})},"routeModule",0,A,"serverHooks",0,N,"workAsyncStorage",0,E,"workUnitAsyncStorage",0,C],2604)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))}];
|
|
1
|
+
module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},24361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},12714,(e,t,r)=>{t.exports=e.x("node:fs/promises",()=>require("node:fs/promises"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},57764,(e,t,r)=>{t.exports=e.x("node:url",()=>require("node:url"))},27699,(e,t,r)=>{t.exports=e.x("events",()=>require("events"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},22593,67059,21023,e=>{"use strict";e.s(["Low",0,class{adapter;data;constructor(e,t){!function(e,t){if(void 0===e)throw Error("lowdb: missing adapter");if(void 0===t)throw Error("lowdb: missing default data")}(e,t),this.adapter=e,this.data=t}async read(){let e=await this.adapter.read();e&&(this.data=e)}async write(){this.data&&await this.adapter.write(this.data)}async update(e){e(this.data),await this.write()}}],22593),e.i(2157);var t=e.i(12714),r=e.i(50227),o=e.i(57764);async function i(e,t,r){for(let o=0;o<t;o++)try{return await e()}catch(e){if(o<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class n{#e;#t;#r=!1;#o=null;#i=null;#n=null;#a=null;#s(e){return this.#a=e,this.#n||=new Promise((e,t)=>{this.#i=[e,t]}),new Promise((e,t)=>{this.#n?.then(e).catch(t)})}async #l(e){this.#r=!0;try{await (0,t.writeFile)(this.#t,e,"utf-8"),await i(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#o?.[0]()}catch(e){throw e instanceof Error&&this.#o?.[1](e),e}finally{if(this.#r=!1,this.#o=this.#i,this.#i=this.#n=null,null!==this.#a){let e=this.#a;this.#a=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,o.fileURLToPath)(e):e.toString();return(0,r.join)((0,r.dirname)(t),`.${(0,r.basename)(t)}.tmp`)}(e)}async write(e){return this.#r?this.#s(e):this.#l(e)}}class a{#e;#c;constructor(e){this.#e=e,this.#c=new n(e)}async read(){let e;try{e=await (0,t.readFile)(this.#e,"utf-8")}catch(e){if("ENOENT"===e.code)return null;throw e}return e}write(e){return this.#c.write(e)}}class s{#d;#p;#u;constructor(e,{parse:t,stringify:r}){this.#d=new a(e),this.#p=t,this.#u=r}async read(){let e=await this.#d.read();return null===e?null:this.#p(e)}write(e){return this.#d.write(this.#u(e))}}e.s(["JSONFile",0,class extends s{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},66680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},88947,(e,t,r)=>{t.exports=e.x("stream",()=>require("stream"))},12249,(e,t,r)=>{t.exports=e.x("constants",()=>require("constants"))},49719,(e,t,r)=>{t.exports=e.x("assert",()=>require("assert"))},69789,e=>{"use strict";e.i(26753),e.s([])},88077,e=>{"use strict";let t={kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationNotice:"Google has tightened Gemini CLI abuse detection and restricted Pro models to paid accounts (Mar 25, 2026). Using this provider may violate ToS and risk account bans."},iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"}},r={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai",notice:{text:"Free tier: 27+ free models, no credit card needed, 200 req/day. After $10 credit: 1,000 req/day.",apiKeyUrl:"https://openrouter.ai/settings/keys"},modelsFetcher:{url:"https://openrouter.ai/api/v1/models",type:"openrouter-free"}},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim",notice:{text:"Free access for NVIDIA Developer Program members (prototyping & testing).",apiKeyUrl:"https://build.nvidia.com/settings/api-keys"}},ollama:{id:"ollama",alias:"ollama",name:"Ollama Cloud",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com",notice:{text:"Free tier: light usage, 1 cloud model at a time (limits reset every 5h & 7d). Pro $20/mo · Max $100/mo.",apiKeyUrl:"https://ollama.com/settings/keys"}},vertex:{id:"vertex",alias:"vx",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VX",website:"https://cloud.google.com/vertex-ai",notice:{text:"New Google Cloud accounts get $300 free credits. Requires GCP project + Service Account with Vertex AI API enabled.",apiKeyUrl:"https://console.cloud.google.com/iam-admin/serviceaccounts"}}},o={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B",deprecated:!0,deprecationNotice:"Antigravity has tightened abuse detection and restricted model access. Using this provider may violate ToS and risk account bans."},codex:{id:"codex",alias:"cx",name:"OpenAI Codex",icon:"code",color:"#3B82F6"},github:{id:"github",alias:"gh",name:"GitHub Copilot",icon:"code",color:"#333333"},cursor:{id:"cursor",alias:"cu",name:"Cursor IDE",icon:"edit_note",color:"#00D4AA"},kilocode:{id:"kilocode",alias:"kc",name:"Kilo Code",icon:"code",color:"#FF6B35",textIcon:"KC"},cline:{id:"cline",alias:"cl",name:"Cline",icon:"smart_toy",color:"#5B9BD5",textIcon:"CL"}},i={glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"glm-cn":{id:"glm-cn",alias:"glm-cn",name:"GLM (China)",icon:"code",color:"#DC2626",textIcon:"GC",website:"https://open.bigmodel.cn"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},alicode:{id:"alicode",alias:"alicode",name:"Alibaba",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nebius:{id:"nebius",alias:"nebius",name:"Nebius AI",icon:"cloud",color:"#6C5CE7",textIcon:"NB",website:"https://nebius.com"},siliconflow:{id:"siliconflow",alias:"siliconflow",name:"SiliconFlow",icon:"cloud_queue",color:"#5B6EF5",textIcon:"SF",website:"https://cloud.siliconflow.com"},hyperbolic:{id:"hyperbolic",alias:"hyp",name:"Hyperbolic",icon:"bolt",color:"#00D4FF",textIcon:"HY",website:"https://hyperbolic.xyz"},deepgram:{id:"deepgram",alias:"dg",name:"Deepgram",icon:"mic",color:"#13EF93",textIcon:"DG",website:"https://deepgram.com"},assemblyai:{id:"assemblyai",alias:"aai",name:"AssemblyAI",icon:"record_voice_over",color:"#0062FF",textIcon:"AA",website:"https://assemblyai.com"},nanobanana:{id:"nanobanana",alias:"nb",name:"NanoBanana",icon:"image",color:"#FFD700",textIcon:"NB",website:"https://nanobananaapi.ai"},chutes:{id:"chutes",alias:"ch",name:"Chutes AI",icon:"water_drop",color:"#ffffffff",textIcon:"CH",website:"https://chutes.ai"},"ollama-local":{id:"ollama-local",alias:"ollama-local",name:"Ollama Local",icon:"cloud",color:"#ffffffff",textIcon:"OL",website:"https://ollama.com"},"vertex-partner":{id:"vertex-partner",alias:"vxp",name:"Vertex Partner",icon:"cloud",color:"#34A853",textIcon:"VP",website:"https://cloud.google.com/vertex-ai/generative-ai/docs/partner-models/use-partner-models"}},n="openai-compatible-",a="anthropic-compatible-",s={...t,...r,...o,...i};function l(e){for(let t of Object.values(s))if(t.alias===e||t.id===e)return t;return null}Object.values(s).reduce((e,t)=>(e[t.alias]=t.id,e),{}),Object.values(s).reduce((e,t)=>(e[t.id]=t.alias,e),{}),e.s(["AI_PROVIDERS",0,s,"ANTHROPIC_COMPATIBLE_PREFIX",0,a,"APIKEY_PROVIDERS",0,i,"FREE_PROVIDERS",0,t,"FREE_TIER_PROVIDERS",0,r,"OAUTH_PROVIDERS",0,o,"OPENAI_COMPATIBLE_PREFIX",0,n,"getProviderAlias",0,function(e){let t=s[e];return t?.alias||e},"getProviderByAlias",0,l,"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(a)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(n)},"resolveProviderId",0,function(e){let t=l(e);return t?.id||e}])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.95",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},53526,e=>{"use strict";var t=e.i(20491);Object.entries(e.i(88077).AI_PROVIDERS).filter(([,e])=>e.passthroughModels).map(([e])=>e);let r=Object.entries(t.PROVIDER_MODELS).flatMap(([e,t])=>t.map(t=>({provider:e,model:t.id,name:t.name})));e.s(["AI_MODELS",0,r])},55870,e=>{"use strict";var t=e.i(12943);e.i(88077),e.i(53526),t.default.version,e.s(["CONSOLE_LOG_CONFIG",0,{maxLines:200,pollIntervalMs:1e3}])},2604,e=>{"use strict";var t=e.i(47909),r=e.i(74017),o=e.i(96250),i=e.i(59756),n=e.i(61916),a=e.i(74677),s=e.i(69741),l=e.i(16795),c=e.i(87718),d=e.i(95169),p=e.i(47587),u=e.i(66012),m=e.i(70101),h=e.i(26937),x=e.i(10372),f=e.i(93695);e.i(20232);var w=e.i(220),v=e.i(89171);e.i(69789);var y=e.i(26753);e.i(55870);var b=e.i(88077);async function g(e){if(null==e||""===e||"__none__"===e)return{proxyPoolId:null};let t=String(e).trim();return t?await (0,y.getProxyPoolById)(t)?{proxyPoolId:t}:{error:"Proxy pool not found"}:{proxyPoolId:null}}async function I(){try{let e=await (0,y.getProviderConnections)(),t={};try{for(let e of(await (0,y.getProviderNodes)()))e.id&&e.name&&(t[e.id]=e.name)}catch{}let r=e.map(e=>{let r=(0,b.isOpenAICompatibleProvider)(e.provider)||(0,b.isAnthropicCompatibleProvider)(e.provider)?t[e.provider]||e.providerSpecificData?.nodeName||e.provider:e.name;return{...e,name:r,apiKey:void 0,accessToken:void 0,refreshToken:void 0,idToken:void 0}});return v.NextResponse.json({connections:r})}catch(e){return console.log("Error fetching providers:",e),v.NextResponse.json({error:"Failed to fetch providers"},{status:500})}}async function P(e){try{let t=await e.json(),{provider:r,apiKey:o,name:i,priority:n,globalPriority:a,defaultModel:s,testStatus:l}=t,c=function(e={}){let t=e?.connectionProxyEnabled===!0,r="string"==typeof e?.connectionProxyUrl?e.connectionProxyUrl.trim():"",o="string"==typeof e?.connectionNoProxy?e.connectionNoProxy.trim():"";return t&&!r?{error:"Connection proxy URL is required when connection proxy is enabled"}:{connectionProxyEnabled:t,connectionProxyUrl:r,connectionNoProxy:o}}(t);if(c.error)return v.NextResponse.json({error:c.error},{status:400});let d=await g(t.proxyPoolId);if(d.error)return v.NextResponse.json({error:d.error},{status:400});let p=d.proxyPoolId,u=b.APIKEY_PROVIDERS[r]||b.FREE_TIER_PROVIDERS[r]||(0,b.isOpenAICompatibleProvider)(r)||(0,b.isAnthropicCompatibleProvider)(r);if(!r||!u)return v.NextResponse.json({error:"Invalid provider"},{status:400});if(!o)return v.NextResponse.json({error:"API Key is required"},{status:400});if(!i)return v.NextResponse.json({error:"Name is required"},{status:400});let m=null;if((0,b.isOpenAICompatibleProvider)(r)){let e=await (0,y.getProviderNodeById)(r);if(!e)return v.NextResponse.json({error:"OpenAI Compatible node not found"},{status:404});if((await (0,y.getProviderConnections)({provider:r})).length>0)return v.NextResponse.json({error:"Only one connection is allowed for this OpenAI Compatible node"},{status:400});m={prefix:e.prefix,apiType:e.apiType,baseUrl:e.baseUrl,nodeName:e.name}}else if((0,b.isAnthropicCompatibleProvider)(r)){let e=await (0,y.getProviderNodeById)(r);if(!e)return v.NextResponse.json({error:"Anthropic Compatible node not found"},{status:404});if((await (0,y.getProviderConnections)({provider:r})).length>0)return v.NextResponse.json({error:"Only one connection is allowed for this Anthropic Compatible node"},{status:400});m={prefix:e.prefix,baseUrl:e.baseUrl,nodeName:e.name}}let h={...m||{},connectionProxyEnabled:c.connectionProxyEnabled,connectionProxyUrl:c.connectionProxyUrl,connectionNoProxy:c.connectionNoProxy};null!==p&&(h.proxyPoolId=p);let x={...await (0,y.createProviderConnection)({provider:r,authType:"apikey",name:i,apiKey:o,priority:n||1,globalPriority:a||null,defaultModel:s||null,providerSpecificData:h,isActive:!0,testStatus:l||"unknown"})};return delete x.apiKey,v.NextResponse.json({connection:x},{status:201})}catch(e){return console.log("Error creating provider:",e),v.NextResponse.json({error:"Failed to create provider"},{status:500})}}e.s(["GET",0,I,"POST",0,P,"dynamic",0,"force-dynamic"],61352);var R=e.i(61352);let A=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/providers/route",pathname:"/api/providers",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/route.js",nextConfigOutput:"standalone",userland:R,...{}}),{workAsyncStorage:E,workUnitAsyncStorage:C,serverHooks:N}=A;async function O(e,t,o){o.requestMeta&&(0,i.setRequestMeta)(e,o.requestMeta),A.isDev&&(0,i.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let v="/api/providers/route";v=v.replace(/\/index$/,"")||"/";let y=await A.prepare(e,t,{srcPage:v,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==o.waitUntil||o.waitUntil.call(o,Promise.resolve()),null;let{buildId:b,params:g,nextConfig:I,parsedUrl:P,isDraftMode:R,prerenderManifest:E,routerServerContext:C,isOnDemandRevalidate:N,revalidateOnlyGenerated:O,resolvedPathname:_,clientReferenceManifest:F,serverActionsManifest:k}=y,D=(0,s.normalizeAppPath)(v),q=!!(E.dynamicRoutes[D]||E.routes[_]),S=async()=>((null==C?void 0:C.render404)?await C.render404(e,t,P,!1):t.end("This page could not be found"),null);if(q&&!R){let e=!!E.routes[_],t=E.dynamicRoutes[D];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await S();throw new f.NoFallbackError}}let T=null;!q||A.isDev||R||(T="/index"===(T=_)?"/":T);let j=!0===A.isDev||!q,M=q&&!j;k&&F&&(0,a.setManifestsSingleton)({page:v,clientReferenceManifest:F,serverActionsManifest:k});let U=e.method||"GET",B=(0,n.getTracer)(),L=B.getActiveScopeSpan(),G=!!(null==C?void 0:C.isWrappedByNextServer),V=!!(0,i.getRequestMeta)(e,"minimalMode"),H=(0,i.getRequestMeta)(e,"incrementalCache")||await A.getIncrementalCache(e,I,E,V);null==H||H.resetRequestCache(),globalThis.__incrementalCache=H;let K={params:g,previewProps:E.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:j,incrementalCache:H,cacheLifeProfiles:I.cacheLife,waitUntil:o.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,o,i)=>A.onRequestError(e,t,o,i,C)},sharedContext:{buildId:b}},$=new l.NodeNextRequest(e),X=new l.NodeNextResponse(t),W=c.NextRequestAdapter.fromNodeNextRequest($,(0,c.signalFromNodeResponse)(t));try{let i,a=async e=>A.handle(W,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=B.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let o=r.get("next.route");if(o){let t=`${U} ${o}`;e.setAttributes({"next.route":o,"http.route":o,"next.span_name":t}),e.updateName(t),i&&i!==e&&(i.setAttribute("http.route",o),i.updateName(t))}else e.updateName(`${U} ${v}`)}),s=async i=>{var n,s;let l=async({previousCacheEntry:r})=>{try{if(!V&&N&&O&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await a(i);e.fetchMetrics=K.renderOpts.fetchMetrics;let s=K.renderOpts.pendingWaitUntil;s&&o.waitUntil&&(o.waitUntil(s),s=void 0);let l=K.renderOpts.collectedTags;if(!q)return await (0,u.sendResponse)($,X,n,K.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(n.headers);l&&(t[x.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=x.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,o=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=x.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:w.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:o}}}}catch(t){throw(null==r?void 0:r.isStale)&&await A.onRequestError(e,t,{routerKind:"App Router",routePath:v,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:N})},!1,C),t}},c=await A.handleResponse({req:e,nextConfig:I,cacheKey:T,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:N,revalidateOnlyGenerated:O,responseGenerator:l,waitUntil:o.waitUntil,isMinimalMode:V});if(!q)return null;if((null==c||null==(n=c.value)?void 0:n.kind)!==w.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(s=c.value)?void 0:s.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});V||t.setHeader("x-nextjs-cache",N?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),R&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,m.fromNodeOutgoingHttpHeaders)(c.value.headers);return V&&q||d.delete(x.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,h.getCacheControlHeader)(c.cacheControl)),await (0,u.sendResponse)($,X,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};G&&L?await s(L):(i=B.getActiveScopeSpan(),await B.withPropagatedContext(e.headers,()=>B.trace(d.BaseServerSpan.handleRequest,{spanName:`${U} ${v}`,kind:n.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},s),void 0,!G))}catch(t){if(t instanceof f.NoFallbackError||await A.onRequestError(e,t,{routerKind:"App Router",routePath:D,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:N})},!1,C),q)throw t;return await (0,u.sendResponse)($,X,new Response(null,{status:500})),null}}e.s(["handler",0,O,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:C})},"routeModule",0,A,"serverHooks",0,N,"workAsyncStorage",0,E,"workUnitAsyncStorage",0,C],2604)},36498,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0kaoh2i._.js"].map(t=>e.l(t))).then(()=>t(21297)))},66510,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_0oa_fz9.js"].map(t=>e.l(t))).then(()=>t(28628)))}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__0148t9m._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[92509,(e,t,a)=>{t.exports=e.x("url",()=>require("url"))},33703,e=>{"use strict";var t=e.i(22593);e.i(21023);var a=e.i(67059),r=e.i(50227),o=e.i(60526),s=e.i(2157);let i="u">typeof caches&&"object"==typeof caches,n=function(){if(i)return"/tmp";if(process.env.DATA_DIR)return process.env.DATA_DIR;process.platform;let e=o.default.homedir();return r.default.join(e,".n9router")}(),c=i?null:r.default.join(n,"request-details.json");i||s.default.existsSync(n)||s.default.mkdirSync(n,{recursive:!0});let l=null;async function p(){if(i)return null;if(!l){let e=new a.JSONFile(c),r=new t.Low(e,{records:[]});await r.read(),r.data?.records||(r.data={records:[]}),l=r}return l}let d=null,u=0;async function h(){if(d&&Date.now()-u<5e3)return d;try{let{getSettings:t}=await e.A(62724),a=await t(),r="false"!==process.env.OBSERVABILITY_ENABLED;d={enabled:"boolean"==typeof a.enableObservability?a.enableObservability:r,maxRecords:a.observabilityMaxRecords||parseInt(process.env.OBSERVABILITY_MAX_RECORDS||String(200),10),batchSize:a.observabilityBatchSize||parseInt(process.env.OBSERVABILITY_BATCH_SIZE||String(20),10),flushIntervalMs:a.observabilityFlushIntervalMs||parseInt(process.env.OBSERVABILITY_FLUSH_INTERVAL_MS||String(5e3),10),maxJsonSize:1024*(a.observabilityMaxJsonSize||parseInt(process.env.OBSERVABILITY_MAX_JSON_SIZE||"5",10))}}catch{d={enabled:!1,maxRecords:200,batchSize:20,flushIntervalMs:5e3,maxJsonSize:5120}}return u=Date.now(),d}let m=[],f=null,b=!1;async function g(){if(!i&&!b&&0!==m.length){b=!0;try{let e=[...m];m=[];let t=await p(),a=await h();for(let r of e){r.id||(r.id=function(e){let t=new Date().toISOString(),a=Math.random().toString(36).substring(2,8),r=e?e.replace(/[^a-zA-Z0-9-]/g,"-"):"unknown";return`${t}-${a}-${r}`}(r.model)),r.timestamp||(r.timestamp=new Date().toISOString()),r.request?.headers&&(r.request.headers=function(e){if(!e||"object"!=typeof e)return{};let t=["authorization","x-api-key","cookie","token","api-key"],a={...e};for(let e of Object.keys(a))t.some(t=>e.toLowerCase().includes(t))&&delete a[e];return a}(r.request.headers));let e={id:r.id,provider:r.provider||null,model:r.model||null,connectionId:r.connectionId||null,timestamp:r.timestamp,status:r.status||null,latency:r.latency||{},tokens:r.tokens||{},request:r.request||{},providerRequest:r.providerRequest||{},providerResponse:r.providerResponse||{},response:r.response||{}},o=a.maxJsonSize;for(let t of["request","providerRequest","providerResponse","response"]){let a=JSON.stringify(e[t]);a.length>o&&(e[t]={_truncated:!0,_originalSize:a.length,_preview:a.substring(0,200)})}let s=t.data.records.findIndex(t=>t.id===e.id);-1!==s?t.data.records[s]=e:t.data.records.push(e)}for(t.data.records.sort((e,t)=>new Date(t.timestamp)-new Date(e.timestamp)),t.data.records.length>a.maxRecords&&(t.data.records=t.data.records.slice(0,a.maxRecords));t.data.records.length>1&&!(0x3200000>=Buffer.byteLength(JSON.stringify(t.data),"utf8"));)t.data.records=t.data.records.slice(0,Math.floor(t.data.records.length/2));await t.write()}catch(e){console.error("[requestDetailsDb] Batch write failed:",e)}finally{b=!1}}}async function v(e){if(i)return;let t=await h();t.enabled&&(m.push(e),m.length>=t.batchSize?(await g(),f&&(clearTimeout(f),f=null)):f||(f=setTimeout(()=>{g().catch(()=>{}),f=null},t.flushIntervalMs)))}async function y(e={}){if(i)return{details:[],pagination:{page:1,pageSize:50,totalItems:0,totalPages:0,hasNext:!1,hasPrev:!1}};let t=[...(await p()).data.records];e.provider&&(t=t.filter(t=>t.provider===e.provider)),e.model&&(t=t.filter(t=>t.model===e.model)),e.connectionId&&(t=t.filter(t=>t.connectionId===e.connectionId)),e.status&&(t=t.filter(t=>t.status===e.status)),e.startDate&&(t=t.filter(t=>new Date(t.timestamp)>=new Date(e.startDate))),e.endDate&&(t=t.filter(t=>new Date(t.timestamp)<=new Date(e.endDate))),t.sort((e,t)=>new Date(t.timestamp)-new Date(e.timestamp));let a=t.length,r=e.page||1,o=e.pageSize||50,s=Math.ceil(a/o);return{details:t.slice((r-1)*o,r*o),pagination:{page:r,pageSize:o,totalItems:a,totalPages:s,hasNext:r<s,hasPrev:r>1}}}async function E(e){return i?null:(await p()).data.records.find(t=>t.id===e)||null}let w=async()=>{f&&(clearTimeout(f),f=null),m.length>0&&await g()};i||(process.off("beforeExit",w),process.off("SIGINT",w),process.off("SIGTERM",w),process.off("exit",w),process.on("beforeExit",w),process.on("SIGINT",w),process.on("SIGTERM",w),process.on("exit",w)),e.s(["getRequestDetailById",0,E,"getRequestDetails",0,y,"saveRequestDetail",0,v])},77452,e=>{"use strict";var t=e.i(46786);let a={"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},r="https://api.kimi.com/coding/v1/messages",o={claude:{baseUrl:"https://api.anthropic.com/v1/messages",format:"claude",retry:{429:0},headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14,fine-grained-tool-streaming-2025-05-14,context-management-2025-06-27,prompt-caching-scope-2026-01-05","Anthropic-Dangerous-Direct-Browser-Access":"true","User-Agent":"claude-cli/2.1.63 (external, cli)","X-App":"cli","X-Stainless-Helper-Method":"stream","X-Stainless-Retry-Count":"0","X-Stainless-Runtime-Version":"v24.3.0","X-Stainless-Package-Version":"0.74.0","X-Stainless-Runtime":"node","X-Stainless-Lang":"js","X-Stainless-Arch":function(){switch((0,t.arch)()){case"x64":return"x64";case"arm64":return"arm64";case"ia32":return"x86";default:return`other::${(0,t.arch)()}`}}(),"X-Stainless-Os":function(){switch((0,t.platform)()){case"darwin":return"MacOS";case"win32":return"Windows";case"linux":return"Linux";case"freebsd":return"FreeBSD";default:return`Other::${(0,t.platform)()}`}}(),"X-Stainless-Timeout":"600"},clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",tokenUrl:"https://api.anthropic.com/v1/oauth/token"},gemini:{baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",format:"gemini",clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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"},"gemini-cli":{baseUrl:"https://cloudcode-pa.googleapis.com/v1internal",format:"gemini-cli",clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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"},codex:{baseUrl:"https://chatgpt.com/backend-api/codex/responses",format:"openai-responses",headers:{originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},clientId:"app_EMoamEEZ73f0CkXaXp7hrann",clientSecret:"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",tokenUrl:"https://auth.openai.com/oauth/token"},qwen:{baseUrl:"https://portal.qwen.ai/v1/chat/completions",format:"openai",headers:{"User-Agent":"google-api-nodejs-client/9.15.1","X-Goog-Api-Client":"gl-node/22.17.0"},clientId:"f0304373b74a44d2b584a3fb70ca9e56",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",authUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code"},iflow:{baseUrl:"https://apis.iflow.cn/v1/chat/completions",format:"openai",headers:{"User-Agent":"iFlow-Cli"},clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://iflow.cn/oauth/token",authUrl:"https://iflow.cn/oauth"},qoder:{baseUrl:"https://api.qoder.com/v1/chat/completions",format:"openai",headers:{"User-Agent":"Qoder-Cli"},clientId:process.env.QODER_OAUTH_CLIENT_ID||"10009311001",clientSecret:process.env.QODER_OAUTH_CLIENT_SECRET||"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://api.qoder.com/oauth/token",authUrl:"https://qoder.com/oauth/authorize"},antigravity:{baseUrls:["https://daily-cloudcode-pa.googleapis.com","https://daily-cloudcode-pa.sandbox.googleapis.com"],format:"antigravity",headers:{"User-Agent":`antigravity/1.107.0 ${(0,t.platform)()}/${(0,t.arch)()}`},clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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"},openrouter:{baseUrl:"https://openrouter.ai/api/v1/chat/completions",format:"openai",headers:{"HTTP-Referer":"https://endpoint-proxy.local","X-Title":"Endpoint Proxy"}},openai:{baseUrl:"https://api.openai.com/v1/chat/completions",format:"openai"},glm:{baseUrl:"https://api.z.ai/api/anthropic/v1/messages",format:"claude",headers:{...a}},"glm-cn":{baseUrl:"https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",format:"openai",headers:{}},kimi:{baseUrl:r,format:"claude",headers:{...a}},minimax:{baseUrl:"https://api.minimax.io/anthropic/v1/messages",format:"claude",headers:{...a}},"minimax-cn":{baseUrl:"https://api.minimaxi.com/anthropic/v1/messages",format:"claude",headers:{...a}},alicode:{baseUrl:"https://coding.dashscope.aliyuncs.com/v1/chat/completions",format:"openai",headers:{}},"alicode-intl":{baseUrl:"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions",format:"openai",headers:{}},github:{baseUrl:"https://api.githubcopilot.com/chat/completions",responsesUrl:"https://api.githubcopilot.com/responses",format:"openai",headers:{"copilot-integration-id":"vscode-chat","editor-version":"vscode/1.110.0","editor-plugin-version":"copilot-chat/0.38.0","user-agent":"GitHubCopilotChat/0.38.0","openai-intent":"conversation-panel","x-github-api-version":"2025-04-01","x-vscode-user-agent-library-version":"electron-fetch","X-Initiator":"user",Accept:"application/json","Content-Type":"application/json"},clientId:"Iv1.b507a08c87ecfe98"},kiro:{baseUrl:"https://codewhisperer.us-east-1.amazonaws.com/generateAssistantResponse",format:"kiro",headers:{"Content-Type":"application/json",Accept:"application/vnd.amazon.eventstream","X-Amz-Target":"AmazonCodeWhispererStreamingService.GenerateAssistantResponse","User-Agent":"AWS-SDK-JS/3.0.0 kiro-ide/1.0.0","X-Amz-User-Agent":"aws-sdk-js/3.0.0 kiro-ide/1.0.0"},tokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authUrl:"https://prod.us-east-1.auth.desktop.kiro.dev"},cursor:{baseUrl:"https://api2.cursor.sh",chatPath:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",format:"cursor",headers:{"connect-accept-encoding":"gzip","connect-protocol-version":"1","Content-Type":"application/connect+proto","User-Agent":"connect-es/1.6.1"},clientVersion:"1.1.3"},"kimi-coding":{baseUrl:r,format:"claude",headers:{...a},clientId:"17e5f671-d194-4dfb-9706-5516cb48c098",tokenUrl:"https://auth.kimi.com/api/oauth/token",refreshUrl:"https://auth.kimi.com/api/oauth/token"},kilocode:{baseUrl:"https://api.kilo.ai/api/openrouter/chat/completions",format:"openai",headers:{}},opencode:{baseUrl:"http://localhost:4096/v1/chat/completions",format:"openai",headers:{}},cline:{baseUrl:"https://api.cline.bot/api/v1/chat/completions",format:"openai",headers:{"HTTP-Referer":"https://cline.bot","X-Title":"Cline"},tokenUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},nvidia:{baseUrl:"https://integrate.api.nvidia.com/v1/chat/completions",format:"openai"},anthropic:{baseUrl:"https://api.anthropic.com/v1/messages",format:"claude",headers:{...a}},deepseek:{baseUrl:"https://api.deepseek.com/chat/completions",format:"openai"},groq:{baseUrl:"https://api.groq.com/openai/v1/chat/completions",format:"openai"},xai:{baseUrl:"https://api.x.ai/v1/chat/completions",format:"openai"},mistral:{baseUrl:"https://api.mistral.ai/v1/chat/completions",format:"openai"},perplexity:{baseUrl:"https://api.perplexity.ai/chat/completions",format:"openai"},together:{baseUrl:"https://api.together.xyz/v1/chat/completions",format:"openai"},fireworks:{baseUrl:"https://api.fireworks.ai/inference/v1/chat/completions",format:"openai"},cerebras:{baseUrl:"https://api.cerebras.ai/v1/chat/completions",format:"openai"},cohere:{baseUrl:"https://api.cohere.ai/v1/chat/completions",format:"openai"},nebius:{baseUrl:"https://api.studio.nebius.ai/v1/chat/completions",format:"openai"},siliconflow:{baseUrl:"https://api.siliconflow.cn/v1/chat/completions",format:"openai"},hyperbolic:{baseUrl:"https://api.hyperbolic.xyz/v1/chat/completions",format:"openai"},deepgram:{baseUrl:"https://api.deepgram.com/v1/listen",format:"openai"},assemblyai:{baseUrl:"https://api.assemblyai.com/v1/audio/transcriptions",format:"openai"},nanobanana:{baseUrl:"https://api.nanobananaapi.ai/v1/chat/completions",format:"openai"},chutes:{baseUrl:"https://llm.chutes.ai/v1/chat/completions",format:"openai"},ollama:{baseUrl:"https://ollama.com/api/chat",format:"ollama"},"ollama-local":{baseUrl:"http://localhost:11434/api/chat",format:"ollama"},vertex:{baseUrl:"https://aiplatform.googleapis.com",format:"vertex"},"vertex-partner":{baseUrl:"https://aiplatform.googleapis.com",format:"openai"},gitlab:{baseUrl:"https://gitlab.com/api/v4/chat/completions",format:"openai"},codebuddy:{baseUrl:"https://copilot.tencent.com/v1/chat/completions",format:"openai"}};e.s(["PROVIDERS",0,o])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.94",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,a={}){let r,o=(r=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${r}`:"",s={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...a};return o&&(s.Authorization=o),s}])},86345,e=>{"use strict";let t={BAD_REQUEST:400,UNAUTHORIZED:401,PAYMENT_REQUIRED:402,FORBIDDEN:403,NOT_FOUND:404,NOT_ACCEPTABLE:406,REQUEST_TIMEOUT:408,RATE_LIMITED:429,SERVER_ERROR:500,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504},a={[t.BAD_REQUEST]:{type:"invalid_request_error",code:"bad_request"},[t.UNAUTHORIZED]:{type:"authentication_error",code:"invalid_api_key"},[t.FORBIDDEN]:{type:"permission_error",code:"insufficient_quota"},[t.NOT_FOUND]:{type:"invalid_request_error",code:"model_not_found"},[t.NOT_ACCEPTABLE]:{type:"invalid_request_error",code:"model_not_supported"},[t.RATE_LIMITED]:{type:"rate_limit_error",code:"rate_limit_exceeded"},[t.SERVER_ERROR]:{type:"server_error",code:"internal_server_error"},[t.BAD_GATEWAY]:{type:"server_error",code:"bad_gateway"},[t.SERVICE_UNAVAILABLE]:{type:"server_error",code:"service_unavailable"},[t.GATEWAY_TIMEOUT]:{type:"server_error",code:"gateway_timeout"}},r={[t.BAD_REQUEST]:"Bad request",[t.UNAUTHORIZED]:"Invalid API key provided",[t.FORBIDDEN]:"You exceeded your current quota",[t.NOT_FOUND]:"Model not found",[t.NOT_ACCEPTABLE]:"Model not supported",[t.RATE_LIMITED]:"Rate limit exceeded",[t.SERVER_ERROR]:"Internal server error",[t.BAD_GATEWAY]:"Bad gateway - upstream provider error",[t.SERVICE_UNAVAILABLE]:"Service temporarily unavailable",[t.GATEWAY_TIMEOUT]:"Gateway timeout"};e.s(["BACKOFF_CONFIG",0,{base:1e3,max:12e4,maxLevel:15},"COOLDOWN_MS",0,{unauthorized:12e4,paymentRequired:12e4,notFound:12e4,transient:3e4,requestNotAllowed:5e3,rateLimit:12e4,serviceUnavailable:2e3,authExpired:12e4},"DEFAULT_ERROR_MESSAGES",0,r,"DEFAULT_MAX_TOKENS",0,64e3,"DEFAULT_MIN_TOKENS",0,32e3,"DEFAULT_RETRY_CONFIG",0,{429:2,503:0,502:0},"ERROR_TYPES",0,a,"HTTP_STATUS",0,t,"MEMORY_CONFIG",0,{sessionTtlMs:72e5,sessionCleanupIntervalMs:18e5,dnsCacheTtlMs:3e5,proxyDispatchersMaxSize:20},"RETRY_CONFIG",0,{maxAttempts:2,delayMs:2e3},"SKIP_PATTERNS",0,["Please write a 5-10 word title for the following conversation:"]])},13061,e=>{"use strict";var t=e.i(88947),a=e.i(86345);let r="u">typeof caches&&"object"==typeof caches,o=globalThis.fetch,s=new Map,i=new Map,n=["cloudcode-pa.googleapis.com","daily-cloudcode-pa.googleapis.com","api.individual.githubcopilot.com","q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com","api2.cursor.sh"],c=["8.8.8.8","8.8.4.4"];function l(e){return null==e?"":String(e).trim()}async function p(t){let r=i.get(t);if(r&&Date.now()<r.expiry)return r.ip;try{let r=await e.A(57408),{promisify:o}=await e.A(34777),s=new r.Resolver;s.setServers(c);let n=o(s.resolve4.bind(s)),l=await n(t);return i.set(t,{ip:l[0],expiry:Date.now()+a.MEMORY_CONFIG.dnsCacheTtlMs}),l[0]}catch(e){return console.warn(`[ProxyFetch] DNS resolve failed for ${t}:`,e.message),null}}function d(e,t){let a,r=l(t);if(!r)return!1;try{a=new URL(e).hostname.toLowerCase()}catch{return!1}return r.split(",").map(e=>e.trim().toLowerCase()).filter(Boolean).some(e=>"*"===e||(e.startsWith(".")?a.endsWith(e)||a===e.slice(1):a===e||a.endsWith(`.${e}`)))}function u(e){let t=l(e);if(!t)return null;try{return new URL(t),t}catch{return`http://${t}`}}async function h(t){let r=u(t);if(!r)return null;if(!s.has(r)){s.size>=a.MEMORY_CONFIG.proxyDispatchersMaxSize&&s.delete(s.keys().next().value);let{ProxyAgent:t}=await e.A(4217);s.set(r,new t({uri:r}))}return s.get(r)}async function m(a,r,o){let s=await e.A(67955),i=await e.A(8884),n=s.default??s,c=i.default??i;return new Promise((e,s)=>{let i=new c.Socket;i.connect(443,r,()=>{let r={socket:i,servername:a.hostname,rejectUnauthorized:!1,path:a.pathname+a.search,method:o.method||"POST",headers:{...o.headers,Host:a.hostname}},c=n.request(r,a=>{let r={ok:a.statusCode>=200&&a.statusCode<300,status:a.statusCode,statusText:a.statusMessage,headers:new Map(Object.entries(a.headers)),body:t.Readable.toWeb(a),text:async()=>{let e=[];for await(let t of a)e.push(t);return Buffer.concat(e).toString()},json:async()=>JSON.parse(await r.text())};e(r)});c.on("error",s),o.body&&c.write("string"==typeof o.body?o.body:JSON.stringify(o.body)),c.end()}),i.on("error",s)})}async function f(e,t={},a=null){let r="string"==typeof e?e:e.toString(),s=function(e,t){if(t?.enabled!==!0&&t?.connectionProxyEnabled!==!0)return null;let a=l(t?.url??t?.connectionProxyUrl);if(!a)return null;let r=l(t?.noProxy??t?.connectionNoProxy);return r&&d(e,r)?null:u(a)}(r,a),i=s?null:u(function(e){let t;if(d(e,process.env.NO_PROXY||process.env.no_proxy))return null;try{t=new URL(e).protocol}catch{return null}return"https:"===t?process.env.HTTPS_PROXY||process.env.https_proxy||process.env.ALL_PROXY||process.env.all_proxy:process.env.HTTP_PROXY||process.env.http_proxy||process.env.ALL_PROXY||process.env.all_proxy}(r)),c=s||i;if(function(e){try{let t=new URL(e).hostname;return n.some(e=>t.includes(e))}catch{return!1}}(r)){if(c)try{let a=await h(c);return await o(e,{...t,dispatcher:a})}catch(e){if(a?.strictProxy===!0)throw Error(`[ProxyFetch] Proxy required but failed (strictProxy=true): ${e.message}`);console.warn(`[ProxyFetch] Proxy failed, falling back to direct bypass: ${e.message}`)}try{let e=new URL(r),a=await p(e.hostname);if(a)return await m(e,a,t)}catch(e){console.warn(`[ProxyFetch] MITM bypass failed: ${e.message}`)}}if(c)try{let a=await h(c);return await o(e,{...t,dispatcher:a})}catch(e){if(a?.strictProxy===!0)throw Error(`[ProxyFetch] Proxy required but failed (strictProxy=true): ${e.message}`);console.warn(`[ProxyFetch] Proxy failed, falling back to direct: ${e.message}`)}return o(e,t)}async function b(e,t={}){return f(e,t,null)}r||globalThis.fetch===b||(globalThis.fetch=b),e.s(["proxyAwareFetch",0,f])}];
|
|
1
|
+
module.exports=[92509,(e,t,a)=>{t.exports=e.x("url",()=>require("url"))},33703,e=>{"use strict";var t=e.i(22593);e.i(21023);var a=e.i(67059),r=e.i(50227),o=e.i(60526),s=e.i(2157);let i="u">typeof caches&&"object"==typeof caches,n=function(){if(i)return"/tmp";if(process.env.DATA_DIR)return process.env.DATA_DIR;process.platform;let e=o.default.homedir();return r.default.join(e,".n9router")}(),c=i?null:r.default.join(n,"request-details.json");i||s.default.existsSync(n)||s.default.mkdirSync(n,{recursive:!0});let l=null;async function p(){if(i)return null;if(!l){let e=new a.JSONFile(c),r=new t.Low(e,{records:[]});await r.read(),r.data?.records||(r.data={records:[]}),l=r}return l}let d=null,u=0;async function h(){if(d&&Date.now()-u<5e3)return d;try{let{getSettings:t}=await e.A(62724),a=await t(),r="false"!==process.env.OBSERVABILITY_ENABLED;d={enabled:"boolean"==typeof a.enableObservability?a.enableObservability:r,maxRecords:a.observabilityMaxRecords||parseInt(process.env.OBSERVABILITY_MAX_RECORDS||String(200),10),batchSize:a.observabilityBatchSize||parseInt(process.env.OBSERVABILITY_BATCH_SIZE||String(20),10),flushIntervalMs:a.observabilityFlushIntervalMs||parseInt(process.env.OBSERVABILITY_FLUSH_INTERVAL_MS||String(5e3),10),maxJsonSize:1024*(a.observabilityMaxJsonSize||parseInt(process.env.OBSERVABILITY_MAX_JSON_SIZE||"5",10))}}catch{d={enabled:!1,maxRecords:200,batchSize:20,flushIntervalMs:5e3,maxJsonSize:5120}}return u=Date.now(),d}let m=[],f=null,b=!1;async function g(){if(!i&&!b&&0!==m.length){b=!0;try{let e=[...m];m=[];let t=await p(),a=await h();for(let r of e){r.id||(r.id=function(e){let t=new Date().toISOString(),a=Math.random().toString(36).substring(2,8),r=e?e.replace(/[^a-zA-Z0-9-]/g,"-"):"unknown";return`${t}-${a}-${r}`}(r.model)),r.timestamp||(r.timestamp=new Date().toISOString()),r.request?.headers&&(r.request.headers=function(e){if(!e||"object"!=typeof e)return{};let t=["authorization","x-api-key","cookie","token","api-key"],a={...e};for(let e of Object.keys(a))t.some(t=>e.toLowerCase().includes(t))&&delete a[e];return a}(r.request.headers));let e={id:r.id,provider:r.provider||null,model:r.model||null,connectionId:r.connectionId||null,timestamp:r.timestamp,status:r.status||null,latency:r.latency||{},tokens:r.tokens||{},request:r.request||{},providerRequest:r.providerRequest||{},providerResponse:r.providerResponse||{},response:r.response||{}},o=a.maxJsonSize;for(let t of["request","providerRequest","providerResponse","response"]){let a=JSON.stringify(e[t]);a.length>o&&(e[t]={_truncated:!0,_originalSize:a.length,_preview:a.substring(0,200)})}let s=t.data.records.findIndex(t=>t.id===e.id);-1!==s?t.data.records[s]=e:t.data.records.push(e)}for(t.data.records.sort((e,t)=>new Date(t.timestamp)-new Date(e.timestamp)),t.data.records.length>a.maxRecords&&(t.data.records=t.data.records.slice(0,a.maxRecords));t.data.records.length>1&&!(0x3200000>=Buffer.byteLength(JSON.stringify(t.data),"utf8"));)t.data.records=t.data.records.slice(0,Math.floor(t.data.records.length/2));await t.write()}catch(e){console.error("[requestDetailsDb] Batch write failed:",e)}finally{b=!1}}}async function v(e){if(i)return;let t=await h();t.enabled&&(m.push(e),m.length>=t.batchSize?(await g(),f&&(clearTimeout(f),f=null)):f||(f=setTimeout(()=>{g().catch(()=>{}),f=null},t.flushIntervalMs)))}async function y(e={}){if(i)return{details:[],pagination:{page:1,pageSize:50,totalItems:0,totalPages:0,hasNext:!1,hasPrev:!1}};let t=[...(await p()).data.records];e.provider&&(t=t.filter(t=>t.provider===e.provider)),e.model&&(t=t.filter(t=>t.model===e.model)),e.connectionId&&(t=t.filter(t=>t.connectionId===e.connectionId)),e.status&&(t=t.filter(t=>t.status===e.status)),e.startDate&&(t=t.filter(t=>new Date(t.timestamp)>=new Date(e.startDate))),e.endDate&&(t=t.filter(t=>new Date(t.timestamp)<=new Date(e.endDate))),t.sort((e,t)=>new Date(t.timestamp)-new Date(e.timestamp));let a=t.length,r=e.page||1,o=e.pageSize||50,s=Math.ceil(a/o);return{details:t.slice((r-1)*o,r*o),pagination:{page:r,pageSize:o,totalItems:a,totalPages:s,hasNext:r<s,hasPrev:r>1}}}async function E(e){return i?null:(await p()).data.records.find(t=>t.id===e)||null}let w=async()=>{f&&(clearTimeout(f),f=null),m.length>0&&await g()};i||(process.off("beforeExit",w),process.off("SIGINT",w),process.off("SIGTERM",w),process.off("exit",w),process.on("beforeExit",w),process.on("SIGINT",w),process.on("SIGTERM",w),process.on("exit",w)),e.s(["getRequestDetailById",0,E,"getRequestDetails",0,y,"saveRequestDetail",0,v])},77452,e=>{"use strict";var t=e.i(46786);let a={"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},r="https://api.kimi.com/coding/v1/messages",o={claude:{baseUrl:"https://api.anthropic.com/v1/messages",format:"claude",retry:{429:0},headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14,fine-grained-tool-streaming-2025-05-14,context-management-2025-06-27,prompt-caching-scope-2026-01-05","Anthropic-Dangerous-Direct-Browser-Access":"true","User-Agent":"claude-cli/2.1.63 (external, cli)","X-App":"cli","X-Stainless-Helper-Method":"stream","X-Stainless-Retry-Count":"0","X-Stainless-Runtime-Version":"v24.3.0","X-Stainless-Package-Version":"0.74.0","X-Stainless-Runtime":"node","X-Stainless-Lang":"js","X-Stainless-Arch":function(){switch((0,t.arch)()){case"x64":return"x64";case"arm64":return"arm64";case"ia32":return"x86";default:return`other::${(0,t.arch)()}`}}(),"X-Stainless-Os":function(){switch((0,t.platform)()){case"darwin":return"MacOS";case"win32":return"Windows";case"linux":return"Linux";case"freebsd":return"FreeBSD";default:return`Other::${(0,t.platform)()}`}}(),"X-Stainless-Timeout":"600"},clientId:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",tokenUrl:"https://api.anthropic.com/v1/oauth/token"},gemini:{baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",format:"gemini",clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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"},"gemini-cli":{baseUrl:"https://cloudcode-pa.googleapis.com/v1internal",format:"gemini-cli",clientId:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecret:"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"},codex:{baseUrl:"https://chatgpt.com/backend-api/codex/responses",format:"openai-responses",headers:{originator:"codex-cli","User-Agent":"codex-cli/1.0.18 (macOS; arm64)"},clientId:"app_EMoamEEZ73f0CkXaXp7hrann",clientSecret:"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",tokenUrl:"https://auth.openai.com/oauth/token"},qwen:{baseUrl:"https://portal.qwen.ai/v1/chat/completions",format:"openai",headers:{"User-Agent":"google-api-nodejs-client/9.15.1","X-Goog-Api-Client":"gl-node/22.17.0"},clientId:"f0304373b74a44d2b584a3fb70ca9e56",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",authUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code"},iflow:{baseUrl:"https://apis.iflow.cn/v1/chat/completions",format:"openai",headers:{"User-Agent":"iFlow-Cli"},clientId:"10009311001",clientSecret:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://iflow.cn/oauth/token",authUrl:"https://iflow.cn/oauth"},qoder:{baseUrl:"https://api.qoder.com/v1/chat/completions",format:"openai",headers:{"User-Agent":"Qoder-Cli"},clientId:process.env.QODER_OAUTH_CLIENT_ID||"10009311001",clientSecret:process.env.QODER_OAUTH_CLIENT_SECRET||"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://api.qoder.com/oauth/token",authUrl:"https://qoder.com/oauth/authorize"},antigravity:{baseUrls:["https://daily-cloudcode-pa.googleapis.com","https://daily-cloudcode-pa.sandbox.googleapis.com"],format:"antigravity",headers:{"User-Agent":`antigravity/1.107.0 ${(0,t.platform)()}/${(0,t.arch)()}`},clientId:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecret:"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"},openrouter:{baseUrl:"https://openrouter.ai/api/v1/chat/completions",format:"openai",headers:{"HTTP-Referer":"https://endpoint-proxy.local","X-Title":"Endpoint Proxy"}},openai:{baseUrl:"https://api.openai.com/v1/chat/completions",format:"openai"},glm:{baseUrl:"https://api.z.ai/api/anthropic/v1/messages",format:"claude",headers:{...a}},"glm-cn":{baseUrl:"https://open.bigmodel.cn/api/coding/paas/v4/chat/completions",format:"openai",headers:{}},kimi:{baseUrl:r,format:"claude",headers:{...a}},minimax:{baseUrl:"https://api.minimax.io/anthropic/v1/messages",format:"claude",headers:{...a}},"minimax-cn":{baseUrl:"https://api.minimaxi.com/anthropic/v1/messages",format:"claude",headers:{...a}},alicode:{baseUrl:"https://coding.dashscope.aliyuncs.com/v1/chat/completions",format:"openai",headers:{}},"alicode-intl":{baseUrl:"https://coding-intl.dashscope.aliyuncs.com/v1/chat/completions",format:"openai",headers:{}},github:{baseUrl:"https://api.githubcopilot.com/chat/completions",responsesUrl:"https://api.githubcopilot.com/responses",format:"openai",headers:{"copilot-integration-id":"vscode-chat","editor-version":"vscode/1.110.0","editor-plugin-version":"copilot-chat/0.38.0","user-agent":"GitHubCopilotChat/0.38.0","openai-intent":"conversation-panel","x-github-api-version":"2025-04-01","x-vscode-user-agent-library-version":"electron-fetch","X-Initiator":"user",Accept:"application/json","Content-Type":"application/json"},clientId:"Iv1.b507a08c87ecfe98"},kiro:{baseUrl:"https://codewhisperer.us-east-1.amazonaws.com/generateAssistantResponse",format:"kiro",headers:{"Content-Type":"application/json",Accept:"application/vnd.amazon.eventstream","X-Amz-Target":"AmazonCodeWhispererStreamingService.GenerateAssistantResponse","User-Agent":"AWS-SDK-JS/3.0.0 kiro-ide/1.0.0","X-Amz-User-Agent":"aws-sdk-js/3.0.0 kiro-ide/1.0.0"},tokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authUrl:"https://prod.us-east-1.auth.desktop.kiro.dev"},cursor:{baseUrl:"https://api2.cursor.sh",chatPath:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",format:"cursor",headers:{"connect-accept-encoding":"gzip","connect-protocol-version":"1","Content-Type":"application/connect+proto","User-Agent":"connect-es/1.6.1"},clientVersion:"1.1.3"},"kimi-coding":{baseUrl:r,format:"claude",headers:{...a},clientId:"17e5f671-d194-4dfb-9706-5516cb48c098",tokenUrl:"https://auth.kimi.com/api/oauth/token",refreshUrl:"https://auth.kimi.com/api/oauth/token"},kilocode:{baseUrl:"https://api.kilo.ai/api/openrouter/chat/completions",format:"openai",headers:{}},opencode:{baseUrl:"http://localhost:4096/v1/chat/completions",format:"openai",headers:{}},cline:{baseUrl:"https://api.cline.bot/api/v1/chat/completions",format:"openai",headers:{"HTTP-Referer":"https://cline.bot","X-Title":"Cline"},tokenUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh"},nvidia:{baseUrl:"https://integrate.api.nvidia.com/v1/chat/completions",format:"openai"},anthropic:{baseUrl:"https://api.anthropic.com/v1/messages",format:"claude",headers:{...a}},deepseek:{baseUrl:"https://api.deepseek.com/chat/completions",format:"openai"},groq:{baseUrl:"https://api.groq.com/openai/v1/chat/completions",format:"openai"},xai:{baseUrl:"https://api.x.ai/v1/chat/completions",format:"openai"},mistral:{baseUrl:"https://api.mistral.ai/v1/chat/completions",format:"openai"},perplexity:{baseUrl:"https://api.perplexity.ai/chat/completions",format:"openai"},together:{baseUrl:"https://api.together.xyz/v1/chat/completions",format:"openai"},fireworks:{baseUrl:"https://api.fireworks.ai/inference/v1/chat/completions",format:"openai"},cerebras:{baseUrl:"https://api.cerebras.ai/v1/chat/completions",format:"openai"},cohere:{baseUrl:"https://api.cohere.ai/v1/chat/completions",format:"openai"},nebius:{baseUrl:"https://api.studio.nebius.ai/v1/chat/completions",format:"openai"},siliconflow:{baseUrl:"https://api.siliconflow.cn/v1/chat/completions",format:"openai"},hyperbolic:{baseUrl:"https://api.hyperbolic.xyz/v1/chat/completions",format:"openai"},deepgram:{baseUrl:"https://api.deepgram.com/v1/listen",format:"openai"},assemblyai:{baseUrl:"https://api.assemblyai.com/v1/audio/transcriptions",format:"openai"},nanobanana:{baseUrl:"https://api.nanobananaapi.ai/v1/chat/completions",format:"openai"},chutes:{baseUrl:"https://llm.chutes.ai/v1/chat/completions",format:"openai"},ollama:{baseUrl:"https://ollama.com/api/chat",format:"ollama"},"ollama-local":{baseUrl:"http://localhost:11434/api/chat",format:"ollama"},vertex:{baseUrl:"https://aiplatform.googleapis.com",format:"vertex"},"vertex-partner":{baseUrl:"https://aiplatform.googleapis.com",format:"openai"},gitlab:{baseUrl:"https://gitlab.com/api/v4/chat/completions",format:"openai"},codebuddy:{baseUrl:"https://copilot.tencent.com/v1/chat/completions",format:"openai"}};e.s(["PROVIDERS",0,o])},12943,e=>{"use strict";e.s(["default",0,{name:"n9router",version:"0.3.95",description:"Self-hosted AI routing gateway — local proxy for Claude, Gemini, OpenAI and 40+ providers",keywords:["ai","llm","proxy","router","claude","openai","gemini","cursor"],homepage:"https://github.com/nightwalker89/n9router",repository:{type:"git",url:"https://github.com/nightwalker89/n9router.git"},config:{appName:"n9router"},license:"MIT",bin:{n9router:"./bin/n9router.js"},files:["bin/",".next/standalone/",".next/static/","public/"],scripts:{dev:"next dev --webpack --port 20128",build:"cross-env NODE_ENV=production next build",start:"cross-env NODE_ENV=production next start","dev:bun":"bun --bun next dev --webpack --port 20128","build:bun":"NODE_ENV=production bun --bun next build --webpack","start:bun":"NODE_ENV=production bun ./.next/standalone/server.js","publish:npm":"./scripts/publish-npm.sh","publish:npm:dry":"./scripts/publish-npm.sh --dry-run"},dependencies:{"@monaco-editor/react":"^4.7.0","@xyflow/react":"^12.10.1",bcryptjs:"^3.0.3",confbox:"^0.2.4",express:"^5.2.1",fs:"^0.0.1-security","http-proxy-middleware":"^3.0.5",jose:"^6.1.3",lowdb:"^7.0.1","monaco-editor":"^0.55.1",next:"^16.1.6","node-forge":"^1.3.3","node-machine-id":"^1.1.12",open:"^11.0.0",ora:"^9.1.0","proper-lockfile":"^4.1.2",react:"19.2.4","react-dom":"19.2.4","react-is":"^16.13.1",recharts:"^3.7.0",selfsigned:"^5.5.0","socks-proxy-agent":"^8.0.5","sql.js":"^1.14.1",undici:"^7.19.2",uuid:"^13.0.0",zustand:"^5.0.10"},optionalDependencies:{"better-sqlite3":"^12.6.2"},devDependencies:{"@tailwindcss/postcss":"^4.1.18","cross-env":"^10.1.0",eslint:"^9","eslint-config-next":"16.1.6",postcss:"^8.5.6",tailwindcss:"^4"}}])},26406,e=>{"use strict";let t=e.i(12943).default.version||"0.0.0";e.s(["buildClineHeaders",0,function(e,a={}){let r,o=(r=function(e){if("string"!=typeof e)return"";let t=e.trim();return t?t.startsWith("workos:")?t:`workos:${t}`:""}(e))?`Bearer ${r}`:"",s={"HTTP-Referer":"https://cline.bot","X-Title":"Cline","User-Agent":`9Router/${t}`,"X-PLATFORM":process.platform||"unknown","X-PLATFORM-VERSION":process.version||"unknown","X-CLIENT-TYPE":"9router","X-CLIENT-VERSION":t,"X-CORE-VERSION":t,"X-IS-MULTIROOT":"false",...a};return o&&(s.Authorization=o),s}])},86345,e=>{"use strict";let t={BAD_REQUEST:400,UNAUTHORIZED:401,PAYMENT_REQUIRED:402,FORBIDDEN:403,NOT_FOUND:404,NOT_ACCEPTABLE:406,REQUEST_TIMEOUT:408,RATE_LIMITED:429,SERVER_ERROR:500,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504},a={[t.BAD_REQUEST]:{type:"invalid_request_error",code:"bad_request"},[t.UNAUTHORIZED]:{type:"authentication_error",code:"invalid_api_key"},[t.FORBIDDEN]:{type:"permission_error",code:"insufficient_quota"},[t.NOT_FOUND]:{type:"invalid_request_error",code:"model_not_found"},[t.NOT_ACCEPTABLE]:{type:"invalid_request_error",code:"model_not_supported"},[t.RATE_LIMITED]:{type:"rate_limit_error",code:"rate_limit_exceeded"},[t.SERVER_ERROR]:{type:"server_error",code:"internal_server_error"},[t.BAD_GATEWAY]:{type:"server_error",code:"bad_gateway"},[t.SERVICE_UNAVAILABLE]:{type:"server_error",code:"service_unavailable"},[t.GATEWAY_TIMEOUT]:{type:"server_error",code:"gateway_timeout"}},r={[t.BAD_REQUEST]:"Bad request",[t.UNAUTHORIZED]:"Invalid API key provided",[t.FORBIDDEN]:"You exceeded your current quota",[t.NOT_FOUND]:"Model not found",[t.NOT_ACCEPTABLE]:"Model not supported",[t.RATE_LIMITED]:"Rate limit exceeded",[t.SERVER_ERROR]:"Internal server error",[t.BAD_GATEWAY]:"Bad gateway - upstream provider error",[t.SERVICE_UNAVAILABLE]:"Service temporarily unavailable",[t.GATEWAY_TIMEOUT]:"Gateway timeout"};e.s(["BACKOFF_CONFIG",0,{base:1e3,max:12e4,maxLevel:15},"COOLDOWN_MS",0,{unauthorized:12e4,paymentRequired:12e4,notFound:12e4,transient:3e4,requestNotAllowed:5e3,rateLimit:12e4,serviceUnavailable:2e3,authExpired:12e4},"DEFAULT_ERROR_MESSAGES",0,r,"DEFAULT_MAX_TOKENS",0,64e3,"DEFAULT_MIN_TOKENS",0,32e3,"DEFAULT_RETRY_CONFIG",0,{429:2,503:0,502:0},"ERROR_TYPES",0,a,"HTTP_STATUS",0,t,"MEMORY_CONFIG",0,{sessionTtlMs:72e5,sessionCleanupIntervalMs:18e5,dnsCacheTtlMs:3e5,proxyDispatchersMaxSize:20},"RETRY_CONFIG",0,{maxAttempts:2,delayMs:2e3},"SKIP_PATTERNS",0,["Please write a 5-10 word title for the following conversation:"]])},13061,e=>{"use strict";var t=e.i(88947),a=e.i(86345);let r="u">typeof caches&&"object"==typeof caches,o=globalThis.fetch,s=new Map,i=new Map,n=["cloudcode-pa.googleapis.com","daily-cloudcode-pa.googleapis.com","api.individual.githubcopilot.com","q.us-east-1.amazonaws.com","codewhisperer.us-east-1.amazonaws.com","api2.cursor.sh"],c=["8.8.8.8","8.8.4.4"];function l(e){return null==e?"":String(e).trim()}async function p(t){let r=i.get(t);if(r&&Date.now()<r.expiry)return r.ip;try{let r=await e.A(57408),{promisify:o}=await e.A(34777),s=new r.Resolver;s.setServers(c);let n=o(s.resolve4.bind(s)),l=await n(t);return i.set(t,{ip:l[0],expiry:Date.now()+a.MEMORY_CONFIG.dnsCacheTtlMs}),l[0]}catch(e){return console.warn(`[ProxyFetch] DNS resolve failed for ${t}:`,e.message),null}}function d(e,t){let a,r=l(t);if(!r)return!1;try{a=new URL(e).hostname.toLowerCase()}catch{return!1}return r.split(",").map(e=>e.trim().toLowerCase()).filter(Boolean).some(e=>"*"===e||(e.startsWith(".")?a.endsWith(e)||a===e.slice(1):a===e||a.endsWith(`.${e}`)))}function u(e){let t=l(e);if(!t)return null;try{return new URL(t),t}catch{return`http://${t}`}}async function h(t){let r=u(t);if(!r)return null;if(!s.has(r)){s.size>=a.MEMORY_CONFIG.proxyDispatchersMaxSize&&s.delete(s.keys().next().value);let{ProxyAgent:t}=await e.A(4217);s.set(r,new t({uri:r}))}return s.get(r)}async function m(a,r,o){let s=await e.A(67955),i=await e.A(8884),n=s.default??s,c=i.default??i;return new Promise((e,s)=>{let i=new c.Socket;i.connect(443,r,()=>{let r={socket:i,servername:a.hostname,rejectUnauthorized:!1,path:a.pathname+a.search,method:o.method||"POST",headers:{...o.headers,Host:a.hostname}},c=n.request(r,a=>{let r={ok:a.statusCode>=200&&a.statusCode<300,status:a.statusCode,statusText:a.statusMessage,headers:new Map(Object.entries(a.headers)),body:t.Readable.toWeb(a),text:async()=>{let e=[];for await(let t of a)e.push(t);return Buffer.concat(e).toString()},json:async()=>JSON.parse(await r.text())};e(r)});c.on("error",s),o.body&&c.write("string"==typeof o.body?o.body:JSON.stringify(o.body)),c.end()}),i.on("error",s)})}async function f(e,t={},a=null){let r="string"==typeof e?e:e.toString(),s=function(e,t){if(t?.enabled!==!0&&t?.connectionProxyEnabled!==!0)return null;let a=l(t?.url??t?.connectionProxyUrl);if(!a)return null;let r=l(t?.noProxy??t?.connectionNoProxy);return r&&d(e,r)?null:u(a)}(r,a),i=s?null:u(function(e){let t;if(d(e,process.env.NO_PROXY||process.env.no_proxy))return null;try{t=new URL(e).protocol}catch{return null}return"https:"===t?process.env.HTTPS_PROXY||process.env.https_proxy||process.env.ALL_PROXY||process.env.all_proxy:process.env.HTTP_PROXY||process.env.http_proxy||process.env.ALL_PROXY||process.env.all_proxy}(r)),c=s||i;if(function(e){try{let t=new URL(e).hostname;return n.some(e=>t.includes(e))}catch{return!1}}(r)){if(c)try{let a=await h(c);return await o(e,{...t,dispatcher:a})}catch(e){if(a?.strictProxy===!0)throw Error(`[ProxyFetch] Proxy required but failed (strictProxy=true): ${e.message}`);console.warn(`[ProxyFetch] Proxy failed, falling back to direct bypass: ${e.message}`)}try{let e=new URL(r),a=await p(e.hostname);if(a)return await m(e,a,t)}catch(e){console.warn(`[ProxyFetch] MITM bypass failed: ${e.message}`)}}if(c)try{let a=await h(c);return await o(e,{...t,dispatcher:a})}catch(e){if(a?.strictProxy===!0)throw Error(`[ProxyFetch] Proxy required but failed (strictProxy=true): ${e.message}`);console.warn(`[ProxyFetch] Proxy failed, falling back to direct: ${e.message}`)}return o(e,t)}async function b(e,t={}){return f(e,t,null)}r||globalThis.fetch===b||(globalThis.fetch=b),e.s(["proxyAwareFetch",0,f])}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__0b802lh._.js.map
|