n9router 0.3.90 → 0.3.93
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/app-path-routes-manifest.json +3 -0
- package/.next/standalone/.next/build-manifest.json +3 -3
- package/.next/standalone/.next/routes-manifest.json +18 -0
- package/.next/standalone/.next/server/app/(dashboard)/dashboard/basic-chat/page.js +1 -1
- 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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +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 +11 -11
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +11 -11
- 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 +6 -6
- 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 +2 -2
- 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/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route.js +11 -0
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/antigravity-tools/import-refresh-tokens/route_client-reference-manifest.js +3 -0
- 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/cli-tools/claude-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/claude-settings/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/codex-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/codex-settings/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/droid-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/droid-settings/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/openclaw-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/openclaw-settings/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/opencode-settings/route.js +1 -1
- package/.next/standalone/.next/server/app/api/cli-tools/opencode-settings/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 +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/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/internal/request-detail/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/internal/request-detail/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/internal/request-detail/route.js +8 -0
- package/.next/standalone/.next/server/app/api/internal/request-detail/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/internal/request-detail/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/internal/request-detail/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route.js +8 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/internal/usage/route_client-reference-manifest.js +3 -0
- 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 +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/auto-import/route.js +1 -1
- package/.next/standalone/.next/server/app/api/oauth/cursor/auto-import/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 +4 -4
- 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 +2 -2
- 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 +4 -4
- 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 +4 -4
- 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 +2 -2
- 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 +2 -2
- 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 +3 -3
- package/.next/standalone/.next/server/app/api/v1beta/models/[...path]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/api/version/route.js +2 -2
- package/.next/standalone/.next/server/app/callback/page.js +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 +13 -13
- package/.next/standalone/.next/server/app/callback.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/callback.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/callback.segments/_index.segment.rsc +6 -6
- package/.next/standalone/.next/server/app/callback.segments/_tree.segment.rsc +2 -2
- 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 +14 -14
- 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 +14 -14
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/basic-chat.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/cli-tools.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/cli-tools.rsc +14 -14
- 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 +14 -14
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/cli-tools.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/combos.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/combos.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/combos.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/endpoint.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/endpoint.rsc +14 -14
- 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 +14 -14
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/endpoint.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/mitm.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/mitm.rsc +14 -14
- 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 +14 -14
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/mitm.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/profile.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/profile.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/profile.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/providers/new.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/providers/new.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/providers/new.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/providers.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/providers.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/providers.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/proxy-pools.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/quota.html +2 -2
- package/.next/standalone/.next/server/app/dashboard/quota.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/quota.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/settings/pricing/page.js +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 +13 -13
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_full.segment.rsc +13 -13
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/settings/pricing.segments/_tree.segment.rsc +2 -2
- 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 +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/translator.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard/usage.html +1 -1
- package/.next/standalone/.next/server/app/dashboard/usage.rsc +15 -15
- 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 +15 -15
- 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 +6 -6
- package/.next/standalone/.next/server/app/dashboard/usage.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/dashboard.html +1 -1
- package/.next/standalone/.next/server/app/dashboard.rsc +14 -14
- 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 +14 -14
- package/.next/standalone/.next/server/app/dashboard.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/dashboard.segments/_index.segment.rsc +6 -6
- package/.next/standalone/.next/server/app/dashboard.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.html +1 -1
- package/.next/standalone/.next/server/app/index.rsc +11 -11
- package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +11 -11
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +6 -6
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/landing/page.js +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 +13 -13
- package/.next/standalone/.next/server/app/landing.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/landing.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/landing.segments/_index.segment.rsc +6 -6
- package/.next/standalone/.next/server/app/landing.segments/_tree.segment.rsc +2 -2
- 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 +1 -1
- 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 +13 -13
- package/.next/standalone/.next/server/app/login.segments/_full.segment.rsc +13 -13
- package/.next/standalone/.next/server/app/login.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/login.segments/_index.segment.rsc +6 -6
- package/.next/standalone/.next/server/app/login.segments/_tree.segment.rsc +2 -2
- 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 +1 -1
- 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/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/chunks/0zjb_server_app_api_antigravity-tools_import-refresh-tokens_route_actions_0jn9smo.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0-7rakw._.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]__01rpshu._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0d5yskq._.js → [root-of-the-server]__04phkrb._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__053j5al._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__067b5fv._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__09pq~46._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__09u3y1w._.js +1 -1
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0jh1if9._.js → [root-of-the-server]__0_8qd4-._.js} +2 -2
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__00d92lv._.js → [root-of-the-server]__0_qom9~._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0azf4gz._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b56uvi._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b802lh._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0bcktr4._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0cix-zv._.js +1 -1
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0g.slg5._.js → [root-of-the-server]__0e27kvj._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0gglkh-._.js +4 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0sr3x1r._.js → [root-of-the-server]__0gicxvd._.js} +2 -2
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0a872qj._.js → [root-of-the-server]__0i_45tv._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0inxxu0._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0ju9vfb._.js +3 -0
- 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]__0m.zwk_._.js +1 -1
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0vccex-._.js → [root-of-the-server]__0mcgcwu._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0pwrfp1._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0r6q4qf._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0szv.g3._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0uw3x8s._.js +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0vbd~f-._.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 +3 -0
- package/.next/standalone/.next/server/chunks/_0_ovl1h._.js +3 -0
- package/.next/standalone/.next/server/chunks/{_0fqqr7l._.js → _0vq-0-m._.js} +2 -2
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_internal_request-detail_route_actions_0l0f~.x.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_internal_usage_route_actions_058gklf.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0kjg_-d._.js → [root-of-the-server]__13ps.wr._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_0x_me2y._.js → _04v6e-j._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/_0c8m5sm._.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/_0fd4.es._.js +5 -0
- package/.next/standalone/.next/server/chunks/ssr/_13z1.b_._.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/src_0_xhepz._.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/src_app_(dashboard)_dashboard_providers_[id]_page_0-3xvzc.js +4 -1
- package/.next/standalone/.next/server/chunks/ssr/src_app_(dashboard)_dashboard_usage_page_0fz7awb.js +1 -1
- package/.next/standalone/.next/server/chunks/ssr/src_shared_constants_cliTools_09iru_o.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/standalone/.next/static/chunks/0-rta-yheghf7.js +1 -0
- package/.next/standalone/.next/static/chunks/{0~p0472sbmye6.js → 0deg-_syv13xx.js} +1 -1
- package/.next/standalone/.next/static/chunks/0h~4je-_gk7-5.css +1 -0
- package/.next/standalone/.next/static/chunks/{17~_6lx17xr8z.js → 0j6650zqytl.z.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0pwbnjvdm7lt_.js → 0lqwk82lneihh.js} +2 -2
- package/.next/standalone/.next/static/chunks/{148_2lu2ra629.js → 11jq77q6zkl40.js} +1 -1
- package/.next/standalone/.next/static/chunks/127zo11qzv8-9.js +4 -0
- package/.next/{static/chunks/06l6ck_q1o~m9.js → standalone/.next/static/chunks/16r2wq4pvci67.js} +1 -1
- package/.next/standalone/AGENTS.md +136 -0
- package/.next/standalone/docs/token_swap.png +0 -0
- package/.next/standalone/docs/token_swap_guide.md +21 -0
- package/.next/standalone/mitm/server.js +51 -5
- package/.next/standalone/mitm/usageTracker.js +524 -0
- package/.next/standalone/package-lock.json +2 -2
- package/.next/standalone/package.json +1 -1
- package/.next/standalone/src/app/(dashboard)/dashboard/providers/[id]/page.js +123 -8
- package/.next/standalone/src/app/(dashboard)/dashboard/usage/components/RequestDetailsTab.js +13 -2
- package/.next/standalone/src/app/api/antigravity-tools/import-refresh-tokens/route.js +218 -0
- package/.next/standalone/src/app/api/internal/request-detail/route.js +45 -0
- package/.next/standalone/src/app/api/internal/usage/route.js +59 -0
- package/.next/standalone/src/mitm/server.js +51 -5
- package/.next/standalone/src/mitm/usageTracker.js +524 -0
- package/.next/static/chunks/0-rta-yheghf7.js +1 -0
- package/.next/static/chunks/{0~p0472sbmye6.js → 0deg-_syv13xx.js} +1 -1
- package/.next/static/chunks/0h~4je-_gk7-5.css +1 -0
- package/.next/static/chunks/{17~_6lx17xr8z.js → 0j6650zqytl.z.js} +1 -1
- package/.next/static/chunks/{0pwbnjvdm7lt_.js → 0lqwk82lneihh.js} +2 -2
- package/.next/static/chunks/{148_2lu2ra629.js → 11jq77q6zkl40.js} +1 -1
- package/.next/static/chunks/127zo11qzv8-9.js +4 -0
- package/.next/{standalone/.next/static/chunks/06l6ck_q1o~m9.js → static/chunks/16r2wq4pvci67.js} +1 -1
- package/package.json +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__081rpq_._.js +0 -4
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0b7zcdl._.js +0 -3
- package/.next/standalone/.next/server/chunks/_019vwuu._.js +0 -3
- package/.next/standalone/.next/static/chunks/026p3rpdycbyo.css +0 -1
- package/.next/standalone/.next/static/chunks/0b285gqd-hcvu.js +0 -1
- package/.next/standalone/.next/static/chunks/121._9x_i3s-~.js +0 -1
- package/.next/static/chunks/026p3rpdycbyo.css +0 -1
- package/.next/static/chunks/0b285gqd-hcvu.js +0 -1
- package/.next/static/chunks/121._9x_i3s-~.js +0 -1
- /package/.next/standalone/.next/static/{eALv8q_pKhx9-bE-9KiDB → b_Drjo0YdAiFCInKT62q9}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{eALv8q_pKhx9-bE-9KiDB → b_Drjo0YdAiFCInKT62q9}/_clientMiddlewareManifest.js +0 -0
- /package/.next/standalone/.next/static/{eALv8q_pKhx9-bE-9KiDB → b_Drjo0YdAiFCInKT62q9}/_ssgManifest.js +0 -0
- /package/.next/static/{eALv8q_pKhx9-bE-9KiDB → b_Drjo0YdAiFCInKT62q9}/_buildManifest.js +0 -0
- /package/.next/static/{eALv8q_pKhx9-bE-9KiDB → b_Drjo0YdAiFCInKT62q9}/_clientMiddlewareManifest.js +0 -0
- /package/.next/static/{eALv8q_pKhx9-bE-9KiDB → b_Drjo0YdAiFCInKT62q9}/_ssgManifest.js +0 -0
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},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),a=e.i(57764);async function s(e,t,r){for(let a=0;a<t;a++)try{return await e()}catch(e){if(a<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class n{#e;#t;#r=!1;#a=null;#s=null;#n=null;#i=null;#o(e){return this.#i=e,this.#n||=new Promise((e,t)=>{this.#s=[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 s(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#a?.[0]()}catch(e){throw e instanceof Error&&this.#a?.[1](e),e}finally{if(this.#r=!1,this.#a=this.#s,this.#s=this.#n=null,null!==this.#i){let e=this.#i;this.#i=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,a.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.#o(e):this.#l(e)}}class i{#e;#d;constructor(e){this.#e=e,this.#d=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.#d.write(e)}}class o{#u;#c;#p;constructor(e,{parse:t,stringify:r}){this.#u=new i(e),this.#c=t,this.#p=r}async read(){let e=await this.#u.read();return null===e?null:this.#c(e)}write(e){return this.#u.write(this.#p(e))}}e.s(["JSONFile",0,class extends o{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},92509,(e,t,r)=>{t.exports=e.x("url",()=>require("url"))},33703,e=>{"use strict";var t=e.i(22593);e.i(21023);var r=e.i(67059),a=e.i(50227),s=e.i(60526),n=e.i(2157);let i="u">typeof caches&&"object"==typeof caches,o=function(){if(i)return"/tmp";if(process.env.DATA_DIR)return process.env.DATA_DIR;process.platform;let e=s.default.homedir();return a.default.join(e,".n9router")}(),l=i?null:a.default.join(o,"request-details.json");i||n.default.existsSync(o)||n.default.mkdirSync(o,{recursive:!0});let d=null;async function u(){if(i)return null;if(!d){let e=new r.JSONFile(l),a=new t.Low(e,{records:[]});await a.read(),a.data?.records||(a.data={records:[]}),d=a}return d}let c=null,p=0;async function h(){if(c&&Date.now()-p<5e3)return c;try{let{getSettings:t}=await e.A(62724),r=await t(),a="false"!==process.env.OBSERVABILITY_ENABLED;c={enabled:"boolean"==typeof r.enableObservability?r.enableObservability:a,maxRecords:r.observabilityMaxRecords||parseInt(process.env.OBSERVABILITY_MAX_RECORDS||String(200),10),batchSize:r.observabilityBatchSize||parseInt(process.env.OBSERVABILITY_BATCH_SIZE||String(20),10),flushIntervalMs:r.observabilityFlushIntervalMs||parseInt(process.env.OBSERVABILITY_FLUSH_INTERVAL_MS||String(5e3),10),maxJsonSize:1024*(r.observabilityMaxJsonSize||parseInt(process.env.OBSERVABILITY_MAX_JSON_SIZE||"5",10))}}catch{c={enabled:!1,maxRecords:200,batchSize:20,flushIntervalMs:5e3,maxJsonSize:5120}}return p=Date.now(),c}let f=[],m=null,x=!1;async function w(){if(!i&&!x&&0!==f.length){x=!0;try{let e=[...f];f=[];let t=await u(),r=await h();for(let a of e){a.id||(a.id=function(e){let t=new Date().toISOString(),r=Math.random().toString(36).substring(2,8),a=e?e.replace(/[^a-zA-Z0-9-]/g,"-"):"unknown";return`${t}-${r}-${a}`}(a.model)),a.timestamp||(a.timestamp=new Date().toISOString()),a.request?.headers&&(a.request.headers=function(e){if(!e||"object"!=typeof e)return{};let t=["authorization","x-api-key","cookie","token","api-key"],r={...e};for(let e of Object.keys(r))t.some(t=>e.toLowerCase().includes(t))&&delete r[e];return r}(a.request.headers));let e={id:a.id,provider:a.provider||null,model:a.model||null,connectionId:a.connectionId||null,timestamp:a.timestamp,status:a.status||null,latency:a.latency||{},tokens:a.tokens||{},request:a.request||{},providerRequest:a.providerRequest||{},providerResponse:a.providerResponse||{},response:a.response||{}},s=r.maxJsonSize;for(let t of["request","providerRequest","providerResponse","response"]){let r=JSON.stringify(e[t]);r.length>s&&(e[t]={_truncated:!0,_originalSize:r.length,_preview:r.substring(0,200)})}let n=t.data.records.findIndex(t=>t.id===e.id);-1!==n?t.data.records[n]=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>r.maxRecords&&(t.data.records=t.data.records.slice(0,r.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{x=!1}}}async function v(e){if(i)return;let t=await h();t.enabled&&(f.push(e),f.length>=t.batchSize?(await w(),m&&(clearTimeout(m),m=null)):m||(m=setTimeout(()=>{w().catch(()=>{}),m=null},t.flushIntervalMs)))}async function g(e={}){if(i)return{details:[],pagination:{page:1,pageSize:50,totalItems:0,totalPages:0,hasNext:!1,hasPrev:!1}};let t=[...(await u()).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 r=t.length,a=e.page||1,s=e.pageSize||50,n=Math.ceil(r/s);return{details:t.slice((a-1)*s,a*s),pagination:{page:a,pageSize:s,totalItems:r,totalPages:n,hasNext:a<n,hasPrev:a>1}}}let R=async()=>{m&&(clearTimeout(m),m=null),f.length>0&&await w()};i||(process.off("beforeExit",R),process.off("SIGINT",R),process.off("SIGTERM",R),process.off("exit",R),process.on("beforeExit",R),process.on("SIGINT",R),process.on("SIGTERM",R),process.on("exit",R)),e.s(["getRequestDetails",0,g,"saveRequestDetail",0,v])},67339,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),s=e.i(59756),n=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),h=e.i(70101),f=e.i(26937),m=e.i(10372),x=e.i(93695);e.i(20232);var w=e.i(220),v=e.i(89171),g=e.i(48582);let R=new Set(["24h","7d","30d","60d","all"]);async function y(e){try{let{searchParams:t}=new URL(e.url),r=t.get("period")||"7d";if(!R.has(r))return v.NextResponse.json({error:"Invalid period"},{status:400});let a=await (0,g.getUsageStats)(r);return v.NextResponse.json(a)}catch(e){return console.error("[API] Failed to get usage stats:",e),v.NextResponse.json({error:"Failed to fetch usage stats"},{status:500})}}e.s(["GET",0,y,"dynamic",0,"force-dynamic"],66682);var S=e.i(66682);let b=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/usage/stats/route",pathname:"/api/usage/stats",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/usage/stats/route.js",nextConfigOutput:"standalone",userland:S,...{}}),{workAsyncStorage:E,workUnitAsyncStorage:I,serverHooks:A}=b;async function q(e,t,a){a.requestMeta&&(0,s.setRequestMeta)(e,a.requestMeta),b.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let v="/api/usage/stats/route";v=v.replace(/\/index$/,"")||"/";let g=await b.prepare(e,t,{srcPage:v,multiZoneDraftMode:!1});if(!g)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:R,params:y,nextConfig:S,parsedUrl:E,isDraftMode:I,prerenderManifest:A,routerServerContext:q,isOnDemandRevalidate:T,revalidateOnlyGenerated:D,resolvedPathname:N,clientReferenceManifest:_,serverActionsManifest:C}=g,O=(0,o.normalizeAppPath)(v),k=!!(A.dynamicRoutes[O]||A.routes[N]),P=async()=>((null==q?void 0:q.render404)?await q.render404(e,t,E,!1):t.end("This page could not be found"),null);if(k&&!I){let e=!!A.routes[N],t=A.dynamicRoutes[O];if(t&&!1===t.fallback&&!e){if(S.adapterPath)return await P();throw new x.NoFallbackError}}let j=null;!k||b.isDev||I||(j="/index"===(j=N)?"/":j);let M=!0===b.isDev||!k,B=k&&!M;C&&_&&(0,i.setManifestsSingleton)({page:v,clientReferenceManifest:_,serverActionsManifest:C});let U=e.method||"GET",F=(0,n.getTracer)(),L=F.getActiveScopeSpan(),H=!!(null==q?void 0:q.isWrappedByNextServer),z=!!(0,s.getRequestMeta)(e,"minimalMode"),$=(0,s.getRequestMeta)(e,"incrementalCache")||await b.getIncrementalCache(e,S,A,z);null==$||$.resetRequestCache(),globalThis.__incrementalCache=$;let J={params:y,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!S.experimental.authInterrupts},cacheComponents:!!S.cacheComponents,supportsDynamicResponse:M,incrementalCache:$,cacheLifeProfiles:S.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,s)=>b.onRequestError(e,t,a,s,q)},sharedContext:{buildId:R}},V=new l.NodeNextRequest(e),G=new l.NodeNextResponse(t),K=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let s,i=async e=>b.handle(K,J).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=F.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.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 a=r.get("next.route");if(a){let t=`${U} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t),s&&s!==e&&(s.setAttribute("http.route",a),s.updateName(t))}else e.updateName(`${U} ${v}`)}),o=async s=>{var n,o;let l=async({previousCacheEntry:r})=>{try{if(!z&&T&&D&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await i(s);e.fetchMetrics=J.renderOpts.fetchMetrics;let o=J.renderOpts.pendingWaitUntil;o&&a.waitUntil&&(a.waitUntil(o),o=void 0);let l=J.renderOpts.collectedTags;if(!k)return await (0,p.sendResponse)(V,G,n,J.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(n.headers);l&&(t[m.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==J.renderOpts.collectedRevalidate&&!(J.renderOpts.collectedRevalidate>=m.INFINITE_CACHE)&&J.renderOpts.collectedRevalidate,a=void 0===J.renderOpts.collectedExpire||J.renderOpts.collectedExpire>=m.INFINITE_CACHE?void 0:J.renderOpts.collectedExpire;return{value:{kind:w.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await b.onRequestError(e,t,{routerKind:"App Router",routePath:v,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:B,isOnDemandRevalidate:T})},!1,q),t}},d=await b.handleResponse({req:e,nextConfig:S,cacheKey:j,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:T,revalidateOnlyGenerated:D,responseGenerator:l,waitUntil:a.waitUntil,isMinimalMode:z});if(!k)return null;if((null==d||null==(n=d.value)?void 0:n.kind)!==w.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(o=d.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",T?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),I&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let u=(0,h.fromNodeOutgoingHttpHeaders)(d.value.headers);return z&&k||u.delete(m.NEXT_CACHE_TAGS_HEADER),!d.cacheControl||t.getHeader("Cache-Control")||u.get("Cache-Control")||u.set("Cache-Control",(0,f.getCacheControlHeader)(d.cacheControl)),await (0,p.sendResponse)(V,G,new Response(d.value.body,{headers:u,status:d.value.status||200})),null};H&&L?await o(L):(s=F.getActiveScopeSpan(),await F.withPropagatedContext(e.headers,()=>F.trace(u.BaseServerSpan.handleRequest,{spanName:`${U} ${v}`,kind:n.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},o),void 0,!H))}catch(t){if(t instanceof x.NoFallbackError||await b.onRequestError(e,t,{routerKind:"App Router",routePath:O,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:B,isOnDemandRevalidate:T})},!1,q),k)throw t;return await (0,p.sendResponse)(V,G,new Response(null,{status:500})),null}}e.s(["handler",0,q,"patchFetch",0,function(){return(0,a.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:I})},"routeModule",0,b,"serverHooks",0,A,"workAsyncStorage",0,E,"workUnitAsyncStorage",0,I],67339)},62724,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0z2s2kh._.js","server/chunks/_0amvca6._.js"].map(t=>e.l(t))).then(()=>t(26753)))}];
|
|
1
|
+
module.exports=[46786,(e,t,r)=>{t.exports=e.x("os",()=>require("os"))},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),a=e.i(57764);async function s(e,t,r){for(let a=0;a<t;a++)try{return await e()}catch(e){if(a<t-1)await new Promise(e=>setTimeout(e,r));else throw e}}class n{#e;#t;#r=!1;#a=null;#s=null;#n=null;#i=null;#o(e){return this.#i=e,this.#n||=new Promise((e,t)=>{this.#s=[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 s(async()=>{await (0,t.rename)(this.#t,this.#e)},10,100),this.#a?.[0]()}catch(e){throw e instanceof Error&&this.#a?.[1](e),e}finally{if(this.#r=!1,this.#a=this.#s,this.#s=this.#n=null,null!==this.#i){let e=this.#i;this.#i=null,await this.write(e)}}}constructor(e){this.#e=e,this.#t=function(e){let t=e instanceof URL?(0,a.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.#o(e):this.#l(e)}}class i{#e;#d;constructor(e){this.#e=e,this.#d=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.#d.write(e)}}class o{#u;#c;#p;constructor(e,{parse:t,stringify:r}){this.#u=new i(e),this.#c=t,this.#p=r}async read(){let e=await this.#u.read();return null===e?null:this.#c(e)}write(e){return this.#u.write(this.#p(e))}}e.s(["JSONFile",0,class extends o{constructor(e){super(e,{parse:JSON.parse,stringify:e=>JSON.stringify(e,null,2)})}}],67059),e.s([],21023)},92509,(e,t,r)=>{t.exports=e.x("url",()=>require("url"))},33703,e=>{"use strict";var t=e.i(22593);e.i(21023);var r=e.i(67059),a=e.i(50227),s=e.i(60526),n=e.i(2157);let i="u">typeof caches&&"object"==typeof caches,o=function(){if(i)return"/tmp";if(process.env.DATA_DIR)return process.env.DATA_DIR;process.platform;let e=s.default.homedir();return a.default.join(e,".n9router")}(),l=i?null:a.default.join(o,"request-details.json");i||n.default.existsSync(o)||n.default.mkdirSync(o,{recursive:!0});let d=null;async function u(){if(i)return null;if(!d){let e=new r.JSONFile(l),a=new t.Low(e,{records:[]});await a.read(),a.data?.records||(a.data={records:[]}),d=a}return d}let c=null,p=0;async function h(){if(c&&Date.now()-p<5e3)return c;try{let{getSettings:t}=await e.A(62724),r=await t(),a="false"!==process.env.OBSERVABILITY_ENABLED;c={enabled:"boolean"==typeof r.enableObservability?r.enableObservability:a,maxRecords:r.observabilityMaxRecords||parseInt(process.env.OBSERVABILITY_MAX_RECORDS||String(200),10),batchSize:r.observabilityBatchSize||parseInt(process.env.OBSERVABILITY_BATCH_SIZE||String(20),10),flushIntervalMs:r.observabilityFlushIntervalMs||parseInt(process.env.OBSERVABILITY_FLUSH_INTERVAL_MS||String(5e3),10),maxJsonSize:1024*(r.observabilityMaxJsonSize||parseInt(process.env.OBSERVABILITY_MAX_JSON_SIZE||"5",10))}}catch{c={enabled:!1,maxRecords:200,batchSize:20,flushIntervalMs:5e3,maxJsonSize:5120}}return p=Date.now(),c}let f=[],m=null,x=!1;async function w(){if(!i&&!x&&0!==f.length){x=!0;try{let e=[...f];f=[];let t=await u(),r=await h();for(let a of e){a.id||(a.id=function(e){let t=new Date().toISOString(),r=Math.random().toString(36).substring(2,8),a=e?e.replace(/[^a-zA-Z0-9-]/g,"-"):"unknown";return`${t}-${r}-${a}`}(a.model)),a.timestamp||(a.timestamp=new Date().toISOString()),a.request?.headers&&(a.request.headers=function(e){if(!e||"object"!=typeof e)return{};let t=["authorization","x-api-key","cookie","token","api-key"],r={...e};for(let e of Object.keys(r))t.some(t=>e.toLowerCase().includes(t))&&delete r[e];return r}(a.request.headers));let e={id:a.id,provider:a.provider||null,model:a.model||null,connectionId:a.connectionId||null,timestamp:a.timestamp,status:a.status||null,latency:a.latency||{},tokens:a.tokens||{},request:a.request||{},providerRequest:a.providerRequest||{},providerResponse:a.providerResponse||{},response:a.response||{}},s=r.maxJsonSize;for(let t of["request","providerRequest","providerResponse","response"]){let r=JSON.stringify(e[t]);r.length>s&&(e[t]={_truncated:!0,_originalSize:r.length,_preview:r.substring(0,200)})}let n=t.data.records.findIndex(t=>t.id===e.id);-1!==n?t.data.records[n]=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>r.maxRecords&&(t.data.records=t.data.records.slice(0,r.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{x=!1}}}async function v(e){if(i)return;let t=await h();t.enabled&&(f.push(e),f.length>=t.batchSize?(await w(),m&&(clearTimeout(m),m=null)):m||(m=setTimeout(()=>{w().catch(()=>{}),m=null},t.flushIntervalMs)))}async function g(e={}){if(i)return{details:[],pagination:{page:1,pageSize:50,totalItems:0,totalPages:0,hasNext:!1,hasPrev:!1}};let t=[...(await u()).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 r=t.length,a=e.page||1,s=e.pageSize||50,n=Math.ceil(r/s);return{details:t.slice((a-1)*s,a*s),pagination:{page:a,pageSize:s,totalItems:r,totalPages:n,hasNext:a<n,hasPrev:a>1}}}async function R(e){return i?null:(await u()).data.records.find(t=>t.id===e)||null}let y=async()=>{m&&(clearTimeout(m),m=null),f.length>0&&await w()};i||(process.off("beforeExit",y),process.off("SIGINT",y),process.off("SIGTERM",y),process.off("exit",y),process.on("beforeExit",y),process.on("SIGINT",y),process.on("SIGTERM",y),process.on("exit",y)),e.s(["getRequestDetailById",0,R,"getRequestDetails",0,g,"saveRequestDetail",0,v])},67339,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),s=e.i(59756),n=e.i(61916),i=e.i(74677),o=e.i(69741),l=e.i(16795),d=e.i(87718),u=e.i(95169),c=e.i(47587),p=e.i(66012),h=e.i(70101),f=e.i(26937),m=e.i(10372),x=e.i(93695);e.i(20232);var w=e.i(220),v=e.i(89171),g=e.i(48582);let R=new Set(["24h","7d","30d","60d","all"]);async function y(e){try{let{searchParams:t}=new URL(e.url),r=t.get("period")||"7d";if(!R.has(r))return v.NextResponse.json({error:"Invalid period"},{status:400});let a=await (0,g.getUsageStats)(r);return v.NextResponse.json(a)}catch(e){return console.error("[API] Failed to get usage stats:",e),v.NextResponse.json({error:"Failed to fetch usage stats"},{status:500})}}e.s(["GET",0,y,"dynamic",0,"force-dynamic"],66682);var S=e.i(66682);let b=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/usage/stats/route",pathname:"/api/usage/stats",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/usage/stats/route.js",nextConfigOutput:"standalone",userland:S,...{}}),{workAsyncStorage:E,workUnitAsyncStorage:I,serverHooks:q}=b;async function A(e,t,a){a.requestMeta&&(0,s.setRequestMeta)(e,a.requestMeta),b.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let v="/api/usage/stats/route";v=v.replace(/\/index$/,"")||"/";let g=await b.prepare(e,t,{srcPage:v,multiZoneDraftMode:!1});if(!g)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:R,params:y,nextConfig:S,parsedUrl:E,isDraftMode:I,prerenderManifest:q,routerServerContext:A,isOnDemandRevalidate:D,revalidateOnlyGenerated:T,resolvedPathname:N,clientReferenceManifest:_,serverActionsManifest:C}=g,O=(0,o.normalizeAppPath)(v),k=!!(q.dynamicRoutes[O]||q.routes[N]),P=async()=>((null==A?void 0:A.render404)?await A.render404(e,t,E,!1):t.end("This page could not be found"),null);if(k&&!I){let e=!!q.routes[N],t=q.dynamicRoutes[O];if(t&&!1===t.fallback&&!e){if(S.adapterPath)return await P();throw new x.NoFallbackError}}let j=null;!k||b.isDev||I||(j="/index"===(j=N)?"/":j);let M=!0===b.isDev||!k,B=k&&!M;C&&_&&(0,i.setManifestsSingleton)({page:v,clientReferenceManifest:_,serverActionsManifest:C});let U=e.method||"GET",F=(0,n.getTracer)(),L=F.getActiveScopeSpan(),H=!!(null==A?void 0:A.isWrappedByNextServer),z=!!(0,s.getRequestMeta)(e,"minimalMode"),$=(0,s.getRequestMeta)(e,"incrementalCache")||await b.getIncrementalCache(e,S,q,z);null==$||$.resetRequestCache(),globalThis.__incrementalCache=$;let J={params:y,previewProps:q.preview,renderOpts:{experimental:{authInterrupts:!!S.experimental.authInterrupts},cacheComponents:!!S.cacheComponents,supportsDynamicResponse:M,incrementalCache:$,cacheLifeProfiles:S.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,s)=>b.onRequestError(e,t,a,s,A)},sharedContext:{buildId:R}},V=new l.NodeNextRequest(e),G=new l.NodeNextResponse(t),K=d.NextRequestAdapter.fromNodeNextRequest(V,(0,d.signalFromNodeResponse)(t));try{let s,i=async e=>b.handle(K,J).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=F.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==u.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 a=r.get("next.route");if(a){let t=`${U} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t),s&&s!==e&&(s.setAttribute("http.route",a),s.updateName(t))}else e.updateName(`${U} ${v}`)}),o=async s=>{var n,o;let l=async({previousCacheEntry:r})=>{try{if(!z&&D&&T&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await i(s);e.fetchMetrics=J.renderOpts.fetchMetrics;let o=J.renderOpts.pendingWaitUntil;o&&a.waitUntil&&(a.waitUntil(o),o=void 0);let l=J.renderOpts.collectedTags;if(!k)return await (0,p.sendResponse)(V,G,n,J.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(n.headers);l&&(t[m.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==J.renderOpts.collectedRevalidate&&!(J.renderOpts.collectedRevalidate>=m.INFINITE_CACHE)&&J.renderOpts.collectedRevalidate,a=void 0===J.renderOpts.collectedExpire||J.renderOpts.collectedExpire>=m.INFINITE_CACHE?void 0:J.renderOpts.collectedExpire;return{value:{kind:w.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await b.onRequestError(e,t,{routerKind:"App Router",routePath:v,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:B,isOnDemandRevalidate:D})},!1,A),t}},d=await b.handleResponse({req:e,nextConfig:S,cacheKey:j,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:q,isRoutePPREnabled:!1,isOnDemandRevalidate:D,revalidateOnlyGenerated:T,responseGenerator:l,waitUntil:a.waitUntil,isMinimalMode:z});if(!k)return null;if((null==d||null==(n=d.value)?void 0:n.kind)!==w.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(o=d.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",D?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),I&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let u=(0,h.fromNodeOutgoingHttpHeaders)(d.value.headers);return z&&k||u.delete(m.NEXT_CACHE_TAGS_HEADER),!d.cacheControl||t.getHeader("Cache-Control")||u.get("Cache-Control")||u.set("Cache-Control",(0,f.getCacheControlHeader)(d.cacheControl)),await (0,p.sendResponse)(V,G,new Response(d.value.body,{headers:u,status:d.value.status||200})),null};H&&L?await o(L):(s=F.getActiveScopeSpan(),await F.withPropagatedContext(e.headers,()=>F.trace(u.BaseServerSpan.handleRequest,{spanName:`${U} ${v}`,kind:n.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},o),void 0,!H))}catch(t){if(t instanceof x.NoFallbackError||await b.onRequestError(e,t,{routerKind:"App Router",routePath:O,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:B,isOnDemandRevalidate:D})},!1,A),k)throw t;return await (0,p.sendResponse)(V,G,new Response(null,{status:500})),null}}e.s(["handler",0,A,"patchFetch",0,function(){return(0,a.patchFetch)({workAsyncStorage:E,workUnitAsyncStorage:I})},"routeModule",0,b,"serverHooks",0,q,"workAsyncStorage",0,E,"workUnitAsyncStorage",0,I],67339)},62724,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0z2s2kh._.js","server/chunks/_0amvca6._.js"].map(t=>e.l(t))).then(()=>t(26753)))}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__0-7rakw._.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 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.90",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.93",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.90",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.93",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
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports=[86345,e=>{"use strict";let r={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},t={[r.BAD_REQUEST]:{type:"invalid_request_error",code:"bad_request"},[r.UNAUTHORIZED]:{type:"authentication_error",code:"invalid_api_key"},[r.FORBIDDEN]:{type:"permission_error",code:"insufficient_quota"},[r.NOT_FOUND]:{type:"invalid_request_error",code:"model_not_found"},[r.NOT_ACCEPTABLE]:{type:"invalid_request_error",code:"model_not_supported"},[r.RATE_LIMITED]:{type:"rate_limit_error",code:"rate_limit_exceeded"},[r.SERVER_ERROR]:{type:"server_error",code:"internal_server_error"},[r.BAD_GATEWAY]:{type:"server_error",code:"bad_gateway"},[r.SERVICE_UNAVAILABLE]:{type:"server_error",code:"service_unavailable"},[r.GATEWAY_TIMEOUT]:{type:"server_error",code:"gateway_timeout"}},o={[r.BAD_REQUEST]:"Bad request",[r.UNAUTHORIZED]:"Invalid API key provided",[r.FORBIDDEN]:"You exceeded your current quota",[r.NOT_FOUND]:"Model not found",[r.NOT_ACCEPTABLE]:"Model not supported",[r.RATE_LIMITED]:"Rate limit exceeded",[r.SERVER_ERROR]:"Internal server error",[r.BAD_GATEWAY]:"Bad gateway - upstream provider error",[r.SERVICE_UNAVAILABLE]:"Service temporarily unavailable",[r.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,o,"DEFAULT_MAX_TOKENS",0,64e3,"DEFAULT_MIN_TOKENS",0,32e3,"DEFAULT_RETRY_CONFIG",0,{429:2,503:0,502:0},"ERROR_TYPES",0,t,"HTTP_STATUS",0,r,"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 r=e.i(88947),t=e.i(86345);let o="u">typeof caches&&"object"==typeof caches,a=globalThis.fetch,n=new Map,s=new Map,i=["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"],l=["8.8.8.8","8.8.4.4"];function c(e){return null==e?"":String(e).trim()}async function u(r){let o=s.get(r);if(o&&Date.now()<o.expiry)return o.ip;try{let o=await e.A(57408),{promisify:a}=await e.A(34777),n=new o.Resolver;n.setServers(l);let i=a(n.resolve4.bind(n)),c=await i(r);return s.set(r,{ip:c[0],expiry:Date.now()+t.MEMORY_CONFIG.dnsCacheTtlMs}),c[0]}catch(e){return console.warn(`[ProxyFetch] DNS resolve failed for ${r}:`,e.message),null}}function d(e,r){let t,o=c(r);if(!o)return!1;try{t=new URL(e).hostname.toLowerCase()}catch{return!1}return o.split(",").map(e=>e.trim().toLowerCase()).filter(Boolean).some(e=>"*"===e||(e.startsWith(".")?t.endsWith(e)||t===e.slice(1):t===e||t.endsWith(`.${e}`)))}function _(e){let r=c(e);if(!r)return null;try{return new URL(r),r}catch{return`http://${r}`}}async function p(r){let o=_(r);if(!o)return null;if(!n.has(o)){n.size>=t.MEMORY_CONFIG.proxyDispatchersMaxSize&&n.delete(n.keys().next().value);let{ProxyAgent:r}=await e.A(4217);n.set(o,new r({uri:o}))}return n.get(o)}async function E(t,o,a){let n=await e.A(67955),s=await e.A(8884),i=n.default??n,l=s.default??s;return new Promise((e,n)=>{let s=new l.Socket;s.connect(443,o,()=>{let o={socket:s,servername:t.hostname,rejectUnauthorized:!1,path:t.pathname+t.search,method:a.method||"POST",headers:{...a.headers,Host:t.hostname}},l=i.request(o,t=>{let o={ok:t.statusCode>=200&&t.statusCode<300,status:t.statusCode,statusText:t.statusMessage,headers:new Map(Object.entries(t.headers)),body:r.Readable.toWeb(t),text:async()=>{let e=[];for await(let r of t)e.push(r);return Buffer.concat(e).toString()},json:async()=>JSON.parse(await o.text())};e(o)});l.on("error",n),a.body&&l.write("string"==typeof a.body?a.body:JSON.stringify(a.body)),l.end()}),s.on("error",n)})}async function y(e,r={},t=null){let o="string"==typeof e?e:e.toString(),n=function(e,r){if(r?.enabled!==!0&&r?.connectionProxyEnabled!==!0)return null;let t=c(r?.url??r?.connectionProxyUrl);if(!t)return null;let o=c(r?.noProxy??r?.connectionNoProxy);return o&&d(e,o)?null:_(t)}(o,t),s=n?null:_(function(e){let r;if(d(e,process.env.NO_PROXY||process.env.no_proxy))return null;try{r=new URL(e).protocol}catch{return null}return"https:"===r?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}(o)),l=n||s;if(function(e){try{let r=new URL(e).hostname;return i.some(e=>r.includes(e))}catch{return!1}}(o)){if(l)try{let t=await p(l);return await a(e,{...r,dispatcher:t})}catch(e){if(t?.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(o),t=await u(e.hostname);if(t)return await E(e,t,r)}catch(e){console.warn(`[ProxyFetch] MITM bypass failed: ${e.message}`)}}if(l)try{let t=await p(l);return await a(e,{...r,dispatcher:t})}catch(e){if(t?.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 a(e,r)}async function h(e,r={}){return y(e,r,null)}o||globalThis.fetch===h||(globalThis.fetch=h),e.s(["proxyAwareFetch",0,y])},57408,e=>{e.v(r=>Promise.all(["server/chunks/[externals]_dns_0.vnpcu._.js"].map(r=>e.l(r))).then(()=>r(79594)))},34777,e=>{e.v(e=>Promise.resolve().then(()=>e(24361)))},4217,e=>{e.v(e=>Promise.resolve().then(()=>e(36689)))},67955,e=>{e.v(r=>Promise.all(["server/chunks/[externals]_https_0kkoal9._.js"].map(r=>e.l(r))).then(()=>r(24836)))},8884,e=>{e.v(r=>Promise.all(["server/chunks/[externals]_net_0o7rvl7._.js"].map(r=>e.l(r))).then(()=>r(4446)))}];
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__01rpshu._.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
module.exports=[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"))},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"))},
|
|
1
|
+
module.exports=[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"))},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"))},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},24868,(e,t,r)=>{t.exports=e.x("fs/promises",()=>require("fs/promises"))},97953,(e,t,r)=>{"use strict";t.exports=e.r(42315).vendored["react-rsc"].ReactServerDOMTurbopackServer},45015,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"registerServerReference",{enumerable:!0,get:function(){return a.registerServerReference}});let a=e.r(97953)},95975,(e,t,r)=>{"use strict";function a(e){for(let t=0;t<e.length;t++){let r=e[t];if("function"!=typeof r)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof r}.
|
|
2
2
|
Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"ensureServerEntryExports",{enumerable:!0,get:function(){return a}})},80253,e=>{"use strict";var t=e.i(47909),r=e.i(74017),a=e.i(96250),n=e.i(59756),s=e.i(61916),o=e.i(74677),i=e.i(69741),l=e.i(16795),u=e.i(87718),d=e.i(95169),c=e.i(47587),p=e.i(66012),f=e.i(70101),R=e.i(26937),h=e.i(10372),x=e.i(93695);e.i(20232);var g=e.i(220),v=e.i(45015),E=e.i(89171),y=e.i(33405),m=e.i(24361),w=e.i(24868),N=e.i(14747),_=e.i(46786),O=e.i(95975);let A=(0,m.promisify)(y.exec),T=()=>{let e=_.default.homedir();return N.default.join(e,".claude","settings.json")},C=async()=>{try{return _.default.platform(),await A("command -v claude",{windowsHide:!0}),!0}catch{return!1}},S=async()=>{try{let e=T(),t=await w.default.readFile(e,"utf-8");return JSON.parse(t)}catch(e){if("ENOENT"===e.code)return null;throw e}};async function b(){try{if(!await C())return E.NextResponse.json({installed:!1,settings:null,message:"Claude CLI is not installed"});let e=await S(),t=!!e?.env?.ANTHROPIC_BASE_URL;return E.NextResponse.json({installed:!0,settings:e,has9Router:t,settingsPath:T()})}catch(e){return console.log("Error checking claude settings:",e),E.NextResponse.json({error:"Failed to check claude settings"},{status:500})}}async function P(e){try{let{env:t}=await e.json();if(!t||"object"!=typeof t)return E.NextResponse.json({error:"Invalid env object"},{status:400});let r=T(),a=N.default.dirname(r);await w.default.mkdir(a,{recursive:!0});let n={};try{let e=await w.default.readFile(r,"utf-8");n=JSON.parse(e)}catch(e){if("ENOENT"!==e.code)throw e}t.ANTHROPIC_BASE_URL&&(t.ANTHROPIC_BASE_URL=t.ANTHROPIC_BASE_URL.endsWith("/v1")?t.ANTHROPIC_BASE_URL:`${t.ANTHROPIC_BASE_URL}/v1`);let s={...n,env:{...n.env||{},...t}};return await w.default.writeFile(r,JSON.stringify(s,null,2)),E.NextResponse.json({success:!0,message:"Settings updated successfully"})}catch(e){return console.log("Error updating claude settings:",e),E.NextResponse.json({error:"Failed to update claude settings"},{status:500})}}let j=["ANTHROPIC_BASE_URL","ANTHROPIC_AUTH_TOKEN","ANTHROPIC_DEFAULT_OPUS_MODEL","ANTHROPIC_DEFAULT_SONNET_MODEL","ANTHROPIC_DEFAULT_HAIKU_MODEL","API_TIMEOUT_MS"];async function I(){try{let e=T(),t={};try{let r=await w.default.readFile(e,"utf-8");t=JSON.parse(r)}catch(e){if("ENOENT"===e.code)return E.NextResponse.json({success:!0,message:"No settings file to reset"});throw e}return t.env&&(j.forEach(e=>{delete t.env[e]}),0===Object.keys(t.env).length&&delete t.env),await w.default.writeFile(e,JSON.stringify(t,null,2)),E.NextResponse.json({success:!0,message:"Settings reset successfully"})}catch(e){return console.log("Error resetting claude settings:",e),E.NextResponse.json({error:"Failed to reset claude settings"},{status:500})}}(0,O.ensureServerEntryExports)([b,P,I]),(0,v.registerServerReference)(b,"00f4652385409a78f7491fb87a8dfa94ad05e7345a",null),(0,v.registerServerReference)(P,"40480922261db22fcfa99cb3a8255516369eb76937",null),(0,v.registerServerReference)(I,"00818e7f0ea57a5a94922c0774ba09e822c42432be",null),e.s(["DELETE",0,I,"GET",0,b,"POST",0,P],19901);var H=e.i(19901);let U=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/cli-tools/claude-settings/route",pathname:"/api/cli-tools/claude-settings",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/cli-tools/claude-settings/route.js",nextConfigOutput:"standalone",userland:H,...{}}),{workAsyncStorage:q,workUnitAsyncStorage:k,serverHooks:M}=U;async function D(e,t,a){a.requestMeta&&(0,n.setRequestMeta)(e,a.requestMeta),U.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let v="/api/cli-tools/claude-settings/route";v=v.replace(/\/index$/,"")||"/";let E=await U.prepare(e,t,{srcPage:v,multiZoneDraftMode:!1});if(!E)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:y,params:m,nextConfig:w,parsedUrl:N,isDraftMode:_,prerenderManifest:O,routerServerContext:A,isOnDemandRevalidate:T,revalidateOnlyGenerated:C,resolvedPathname:S,clientReferenceManifest:b,serverActionsManifest:P}=E,j=(0,i.normalizeAppPath)(v),I=!!(O.dynamicRoutes[j]||O.routes[S]),H=async()=>((null==A?void 0:A.render404)?await A.render404(e,t,N,!1):t.end("This page could not be found"),null);if(I&&!_){let e=!!O.routes[S],t=O.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(w.adapterPath)return await H();throw new x.NoFallbackError}}let q=null;!I||U.isDev||_||(q="/index"===(q=S)?"/":q);let k=!0===U.isDev||!I,M=I&&!k;P&&b&&(0,o.setManifestsSingleton)({page:v,clientReferenceManifest:b,serverActionsManifest:P});let D=e.method||"GET",L=(0,s.getTracer)(),F=L.getActiveScopeSpan(),B=!!(null==A?void 0:A.isWrappedByNextServer),$=!!(0,n.getRequestMeta)(e,"minimalMode"),K=(0,n.getRequestMeta)(e,"incrementalCache")||await U.getIncrementalCache(e,w,O,$);null==K||K.resetRequestCache(),globalThis.__incrementalCache=K;let J={params:m,previewProps:O.preview,renderOpts:{experimental:{authInterrupts:!!w.experimental.authInterrupts},cacheComponents:!!w.cacheComponents,supportsDynamicResponse:k,incrementalCache:K,cacheLifeProfiles:w.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,n)=>U.onRequestError(e,t,a,n,A)},sharedContext:{buildId:y}},G=new l.NodeNextRequest(e),W=new l.NodeNextResponse(t),X=u.NextRequestAdapter.fromNodeNextRequest(G,(0,u.signalFromNodeResponse)(t));try{let n,o=async e=>U.handle(X,J).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=L.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 a=r.get("next.route");if(a){let t=`${D} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":t}),e.updateName(t),n&&n!==e&&(n.setAttribute("http.route",a),n.updateName(t))}else e.updateName(`${D} ${v}`)}),i=async n=>{var s,i;let l=async({previousCacheEntry:r})=>{try{if(!$&&T&&C&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let s=await o(n);e.fetchMetrics=J.renderOpts.fetchMetrics;let i=J.renderOpts.pendingWaitUntil;i&&a.waitUntil&&(a.waitUntil(i),i=void 0);let l=J.renderOpts.collectedTags;if(!I)return await (0,p.sendResponse)(G,W,s,J.renderOpts.pendingWaitUntil),null;{let e=await s.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(s.headers);l&&(t[h.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==J.renderOpts.collectedRevalidate&&!(J.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&J.renderOpts.collectedRevalidate,a=void 0===J.renderOpts.collectedExpire||J.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:J.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:s.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:a}}}}catch(t){throw(null==r?void 0:r.isStale)&&await U.onRequestError(e,t,{routerKind:"App Router",routePath:v,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:T})},!1,A),t}},u=await U.handleResponse({req:e,nextConfig:w,cacheKey:q,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:O,isRoutePPREnabled:!1,isOnDemandRevalidate:T,revalidateOnlyGenerated:C,responseGenerator:l,waitUntil:a.waitUntil,isMinimalMode:$});if(!I)return null;if((null==u||null==(s=u.value)?void 0:s.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(i=u.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});$||t.setHeader("x-nextjs-cache",T?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),_&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return $&&I||d.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,R.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(G,W,new Response(u.value.body,{headers:d,status:u.value.status||200})),null};B&&F?await i(F):(n=L.getActiveScopeSpan(),await L.withPropagatedContext(e.headers,()=>L.trace(d.BaseServerSpan.handleRequest,{spanName:`${D} ${v}`,kind:s.SpanKind.SERVER,attributes:{"http.method":D,"http.target":e.url}},i),void 0,!B))}catch(t){if(t instanceof x.NoFallbackError||await U.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:T})},!1,A),I)throw t;return await (0,p.sendResponse)(G,W,new Response(null,{status:500})),null}}e.s(["handler",0,D,"patchFetch",0,function(){return(0,a.patchFetch)({workAsyncStorage:q,workUnitAsyncStorage:k})},"routeModule",0,U,"serverHooks",0,M,"workAsyncStorage",0,q,"workUnitAsyncStorage",0,k],80253)}];
|
|
3
3
|
|
|
4
|
-
//# sourceMappingURL=%5Broot-of-the-server%
|
|
4
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__04phkrb._.js.map
|