omniroute 3.4.5 → 3.4.6
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/app/.next/BUILD_ID +1 -1
- package/app/.next/build-manifest.json +3 -3
- package/app/.next/prerender-manifest.json +3 -3
- package/app/.next/server/app/(dashboard)/dashboard/agents/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/analytics/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/api-manager/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/audit/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/auto-combo/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/cache/page.js.nft.json +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/cache/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/cli-tools/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/combos/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/costs/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/endpoint/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/health/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/limits/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/logs/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/media/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/memory/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/onboarding/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/playground/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/providers/[id]/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/providers/new/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/providers/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/search-tools/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/settings/page.js.nft.json +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/settings/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/settings/pricing/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/skills/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/400/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/401/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/403/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/408/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/429/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/500/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/502/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/503/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/_global-error.html +1 -1
- package/app/.next/server/app/_global-error.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/app/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/monitoring/health/route.js +3 -3
- package/app/.next/server/app/api/provider-models/route.js +2 -2
- package/app/.next/server/app/api/provider-nodes/[id]/route.js +2 -2
- package/app/.next/server/app/api/provider-nodes/route.js +3 -3
- package/app/.next/server/app/api/provider-nodes/validate/route.js +1 -1
- package/app/.next/server/app/api/providers/[id]/models/route.js +1 -1
- package/app/.next/server/app/api/providers/[id]/models/route.js.nft.json +1 -1
- package/app/.next/server/app/api/providers/[id]/sync-models/route.js +3 -3
- package/app/.next/server/app/api/providers/[id]/sync-models/route.js.nft.json +1 -1
- package/app/.next/server/app/api/providers/[id]/test/route.js +6 -6
- package/app/.next/server/app/api/providers/route.js +4 -4
- package/app/.next/server/app/api/providers/route.js.nft.json +1 -1
- package/app/.next/server/app/api/providers/test-batch/route.js +5 -5
- package/app/.next/server/app/api/providers/test-batch/route.js.nft.json +1 -1
- package/app/.next/server/app/api/providers/validate/route.js +1 -1
- package/app/.next/server/app/api/system/version/route.js.nft.json +1 -1
- package/app/.next/server/app/api/usage/[connectionId]/route.js +2 -2
- package/app/.next/server/app/api/usage/provider-limits/route.js +5 -5
- package/app/.next/server/app/api/usage/provider-limits/route.js.nft.json +1 -1
- package/app/.next/server/app/api/v1/models/route.js +4 -4
- package/app/.next/server/app/api/v1/models/route.js.nft.json +1 -1
- package/app/.next/server/app/api/v1/route.js +4 -4
- package/app/.next/server/app/api/v1/route.js.nft.json +1 -1
- package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/docs/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/forbidden/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/forgot-password/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/landing/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/login/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/maintenance/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/offline/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/privacy/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/status/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/terms/page_client-reference-manifest.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0.7zz6j._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0.lz97q._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0.m9_5-._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__00-bzx_._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__00hsd7k._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__00i_ryi._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__01fudn9._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__024slax._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__030_-af._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__03gl9dh._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__03x69ll._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__047np0t._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__04lc9.m._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__05u48b-._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__06dr~pl._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__06hr_sx._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__06r5eje._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__07.ui7z._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__075j.5s._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__07ju0wx._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__07wj.c4._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__08-9vz.._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0908q-_._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__09blmoy._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__09c50mp._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0a.3c_r._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0bkx9sd._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0c4v_hg._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0c5t729._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0cem6i6._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0d-qyrk._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0d-rd-n._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0djfz6n._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0dmb7bd._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0e7dp.z._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0el_v65._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0enebbv._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0enecpa._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0eps0zu._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0fbv0zh._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0fmf-tk._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0fw0v5q._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0g0b9au._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0gukblk._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0h-q5l0._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0h1fgwr._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0h86b7i._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0h~a5f1._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0irqapk._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0j0ez8_._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0jacr87._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0jnihz9._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0jp3yj4._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0llqbda._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0m-356c._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0mj7x5~._.js +8 -8
- package/app/.next/server/chunks/[root-of-the-server]__0mpnloa._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0n-~kvf._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0n.gjo8._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0n0nara._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0ncz8xj._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0oph175._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0p3a7_l._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0pl_899._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0prott7._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0pwiejj._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0pxqo8v._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0q04t~4._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0q9h_5u._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0qaruz-._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0qka2s7._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0rnvi83._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0rpwwig._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0rs2ec_._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0s1dq3.._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0s1ya.l._.js +5 -5
- package/app/.next/server/chunks/[root-of-the-server]__0svm~lc._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0t83olx._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0tsl88m._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0uctzvq._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0vkqjj1._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0vwq47l._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0vx1juw._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0vzvfbd._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0w39cdo._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0wc__c~._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0y2h760._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0y_c7uk._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__0~8fltv._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__0~dj8ev._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__10.x-iq._.js +4 -4
- package/app/.next/server/chunks/[root-of-the-server]__10e1a_z._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__10o_k-p._.js +2 -2
- package/app/.next/server/chunks/[root-of-the-server]__10smy7g._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__11wa4b~._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__11xpr8u._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__122-jdl._.js +8 -8
- package/app/.next/server/chunks/[root-of-the-server]__12e9-l1._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__12gh.g1._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__136nal9._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__13_i443._.js +1 -1
- package/app/.next/server/chunks/[root-of-the-server]__13c-d_4._.js +2 -2
- package/app/.next/server/chunks/_0-jnvci._.js +1 -1
- package/app/.next/server/chunks/_0-~thzo._.js +1 -1
- package/app/.next/server/chunks/_00.pgsp._.js +1 -1
- package/app/.next/server/chunks/_013gowh._.js +1 -1
- package/app/.next/server/chunks/{_03c-j3o._.js → _02~yzex._.js} +2 -2
- package/app/.next/server/chunks/_036lxbr._.js +1 -1
- package/app/.next/server/chunks/_05reh6o._.js +1 -1
- package/app/.next/server/chunks/_0a3.3sc._.js +1 -1
- package/app/.next/server/chunks/_0c.abwr._.js +1 -1
- package/app/.next/server/chunks/_0due8oe._.js +2 -2
- package/app/.next/server/chunks/_0h-j8c2._.js +1 -1
- package/app/.next/server/chunks/_0k43pd6._.js +3 -3
- package/app/.next/server/chunks/_0vx-r0i._.js +2 -2
- package/app/.next/server/chunks/_10.rw9f._.js +1 -1
- package/app/.next/server/chunks/_13mo7j5._.js +1 -1
- package/app/.next/server/chunks/src_0f_le~m._.js +1 -1
- package/app/.next/server/chunks/ssr/_008ht2n._.js +2 -2
- package/app/.next/server/chunks/ssr/_0oo1f90._.js +2 -2
- package/app/.next/server/chunks/ssr/_0~laquj._.js +1 -1
- package/app/.next/server/chunks/ssr/src_04gjot1._.js +1 -1
- package/app/.next/server/chunks/ssr/src_app_(dashboard)_dashboard_cache_04_vca6._.js +1 -1
- package/app/.next/server/chunks/ssr/{src_app_(dashboard)_dashboard_settings_0ni3aus._.js → src_app_(dashboard)_dashboard_settings_09gq48u._.js} +2 -2
- package/app/.next/server/chunks/ssr/src_i18n_messages_en_json_[json]_cjs_13rg.m2._.js +1 -1
- package/app/.next/server/chunks/ssr/src_i18n_messages_pt-BR_json_[json]_cjs_01n5fvn._.js +1 -1
- package/app/.next/server/chunks/ssr/src_i18n_messages_pt_json_[json]_cjs_0fwb8p.._.js +1 -1
- package/app/.next/server/chunks/ssr/src_shared_0jy4djq._.js +3 -0
- package/app/.next/server/chunks/ssr/src_shared_components_0v5o286._.js +3 -0
- package/app/.next/server/middleware-build-manifest.js +3 -3
- package/app/.next/server/pages/500.html +1 -1
- package/app/.next/server/server-reference-manifest.js +1 -1
- package/app/.next/server/server-reference-manifest.json +1 -1
- package/app/.next/static/chunks/{03~_6b5~n101_.js → 0.ap2gsi3d-1e.js} +1 -1
- package/app/.next/static/chunks/08iujr48xci8k.js +1 -0
- package/app/.next/static/chunks/{0up_y.7qkqwxz.js → 08n6n76lz~vt6.js} +1 -1
- package/app/.next/static/chunks/{060zmf~qn1q6y.js → 0f611s~575pn8.js} +1 -1
- package/app/.next/static/chunks/0y5kx9rgeb6~_.js +1 -0
- package/app/.next/static/chunks/13xz-222deqiy.js +1 -0
- package/app/CHANGELOG.md +18 -0
- package/app/docs/openapi.yaml +1 -1
- package/app/llm.txt +2 -2
- package/app/open-sse/handlers/chatCore.ts +2 -2
- package/app/open-sse/package.json +1 -1
- package/app/open-sse/translator/request/claude-to-gemini.ts +17 -0
- package/app/open-sse/translator/request/openai-to-gemini.ts +14 -3
- package/app/open-sse/utils/stream.ts +2 -2
- package/app/package-lock.json +3 -3
- package/app/package.json +1 -1
- package/app/src/app/(dashboard)/dashboard/cache/components/CacheTrends.tsx +19 -12
- package/app/src/app/(dashboard)/dashboard/cache/page.tsx +0 -3
- package/app/src/app/(dashboard)/dashboard/memory/page.tsx +20 -20
- package/app/src/i18n/messages/en.json +55 -1
- package/app/src/i18n/messages/pt-BR.json +53 -0
- package/app/src/i18n/messages/pt.json +54 -1
- package/app/src/shared/constants/providers.ts +40 -0
- package/app/src/shared/constants/sidebarVisibility.ts +6 -0
- package/app/src/shared/utils/circuitBreaker.ts +14 -4
- package/package.json +1 -1
- package/app/.next/server/chunks/ssr/src_05ekey-._.js +0 -3
- package/app/.next/server/chunks/ssr/src_100xxow._.js +0 -3
- package/app/.next/static/chunks/05tcrkqknq.20.js +0 -1
- package/app/.next/static/chunks/0eng4c9gz1s4..js +0 -1
- package/app/.next/static/chunks/0go~kwn1zgxnd.js +0 -1
- /package/app/.next/static/{Dbb1D6OoD7WlyZuPBm3L6 → ImZm5czz4prt8gnJPx7vv}/_buildManifest.js +0 -0
- /package/app/.next/static/{Dbb1D6OoD7WlyZuPBm3L6 → ImZm5czz4prt8gnJPx7vv}/_clientMiddlewareManifest.js +0 -0
- /package/app/.next/static/{Dbb1D6OoD7WlyZuPBm3L6 → ImZm5czz4prt8gnJPx7vv}/_ssgManifest.js +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
module.exports=[918622,(e,t,a)=>{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"))},556704,(e,t,a)=>{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"))},832319,(e,t,a)=>{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"))},324725,(e,t,a)=>{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"))},270406,(e,t,a)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},193695,(e,t,a)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},442315,(e,t,a)=>{"use strict";t.exports=e.r(918622)},347540,(e,t,a)=>{"use strict";t.exports=e.r(442315).vendored["react-rsc"].React},819481,(e,t,a)=>{"use strict";var r=Object.defineProperty,i=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,n=Object.prototype.hasOwnProperty,s={},l={RequestCookies:()=>v,ResponseCookies:()=>f,parseCookie:()=>u,parseSetCookie:()=>p,stringifyCookie:()=>d};for(var c in l)r(s,c,{get:l[c],enumerable:!0});function d(e){var t;let a=["path"in e&&e.path&&`Path=${e.path}`,"expires"in e&&(e.expires||0===e.expires)&&`Expires=${("number"==typeof e.expires?new Date(e.expires):e.expires).toUTCString()}`,"maxAge"in e&&"number"==typeof e.maxAge&&`Max-Age=${e.maxAge}`,"domain"in e&&e.domain&&`Domain=${e.domain}`,"secure"in e&&e.secure&&"Secure","httpOnly"in e&&e.httpOnly&&"HttpOnly","sameSite"in e&&e.sameSite&&`SameSite=${e.sameSite}`,"partitioned"in e&&e.partitioned&&"Partitioned","priority"in e&&e.priority&&`Priority=${e.priority}`].filter(Boolean),r=`${e.name}=${encodeURIComponent(null!=(t=e.value)?t:"")}`;return 0===a.length?r:`${r}; ${a.join("; ")}`}function u(e){let t=new Map;for(let a of e.split(/; */)){if(!a)continue;let e=a.indexOf("=");if(-1===e){t.set(a,"true");continue}let[r,i]=[a.slice(0,e),a.slice(e+1)];try{t.set(r,decodeURIComponent(null!=i?i:"true"))}catch{}}return t}function p(e){if(!e)return;let[[t,a],...r]=u(e),{domain:i,expires:o,httponly:n,maxage:s,path:l,samesite:c,secure:d,partitioned:p,priority:v}=Object.fromEntries(r.map(([e,t])=>[e.toLowerCase().replace(/-/g,""),t]));{var f,y,g={name:t,value:decodeURIComponent(a),domain:i,...o&&{expires:new Date(o)},...n&&{httpOnly:!0},..."string"==typeof s&&{maxAge:Number(s)},path:l,...c&&{sameSite:h.includes(f=(f=c).toLowerCase())?f:void 0},...d&&{secure:!0},...v&&{priority:m.includes(y=(y=v).toLowerCase())?y:void 0},...p&&{partitioned:!0}};let e={};for(let t in g)g[t]&&(e[t]=g[t]);return e}}t.exports=((e,t,a)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let s of o(t))n.call(e,s)||void 0===s||r(e,s,{get:()=>t[s],enumerable:!(a=i(t,s))||a.enumerable});return e})(r({},"__esModule",{value:!0}),s);var h=["strict","lax","none"],m=["low","medium","high"],v=class{constructor(e){this._parsed=new Map,this._headers=e;const t=e.get("cookie");if(t)for(const[e,a]of u(t))this._parsed.set(e,{name:e,value:a})}[Symbol.iterator](){return this._parsed[Symbol.iterator]()}get size(){return this._parsed.size}get(...e){let t="string"==typeof e[0]?e[0]:e[0].name;return this._parsed.get(t)}getAll(...e){var t;let a=Array.from(this._parsed);if(!e.length)return a.map(([e,t])=>t);let r="string"==typeof e[0]?e[0]:null==(t=e[0])?void 0:t.name;return a.filter(([e])=>e===r).map(([e,t])=>t)}has(e){return this._parsed.has(e)}set(...e){let[t,a]=1===e.length?[e[0].name,e[0].value]:e,r=this._parsed;return r.set(t,{name:t,value:a}),this._headers.set("cookie",Array.from(r).map(([e,t])=>d(t)).join("; ")),this}delete(e){let t=this._parsed,a=Array.isArray(e)?e.map(e=>t.delete(e)):t.delete(e);return this._headers.set("cookie",Array.from(t).map(([e,t])=>d(t)).join("; ")),a}clear(){return this.delete(Array.from(this._parsed.keys())),this}[Symbol.for("edge-runtime.inspect.custom")](){return`RequestCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`}toString(){return[...this._parsed.values()].map(e=>`${e.name}=${encodeURIComponent(e.value)}`).join("; ")}},f=class{constructor(e){var t,a,r;this._parsed=new Map,this._headers=e;const i=null!=(r=null!=(a=null==(t=e.getSetCookie)?void 0:t.call(e))?a:e.get("set-cookie"))?r:[];for(const e of Array.isArray(i)?i:function(e){if(!e)return[];var t,a,r,i,o,n=[],s=0;function l(){for(;s<e.length&&/\s/.test(e.charAt(s));)s+=1;return s<e.length}for(;s<e.length;){for(t=s,o=!1;l();)if(","===(a=e.charAt(s))){for(r=s,s+=1,l(),i=s;s<e.length&&"="!==(a=e.charAt(s))&&";"!==a&&","!==a;)s+=1;s<e.length&&"="===e.charAt(s)?(o=!0,s=i,n.push(e.substring(t,r)),t=s):s=r+1}else s+=1;(!o||s>=e.length)&&n.push(e.substring(t,e.length))}return n}(i)){const t=p(e);t&&this._parsed.set(t.name,t)}}get(...e){let t="string"==typeof e[0]?e[0]:e[0].name;return this._parsed.get(t)}getAll(...e){var t;let a=Array.from(this._parsed.values());if(!e.length)return a;let r="string"==typeof e[0]?e[0]:null==(t=e[0])?void 0:t.name;return a.filter(e=>e.name===r)}has(e){return this._parsed.has(e)}set(...e){let[t,a,r]=1===e.length?[e[0].name,e[0].value,e[0]]:e,i=this._parsed;return i.set(t,function(e={name:"",value:""}){return"number"==typeof e.expires&&(e.expires=new Date(e.expires)),e.maxAge&&(e.expires=new Date(Date.now()+1e3*e.maxAge)),(null===e.path||void 0===e.path)&&(e.path="/"),e}({name:t,value:a,...r})),function(e,t){for(let[,a]of(t.delete("set-cookie"),e)){let e=d(a);t.append("set-cookie",e)}}(i,this._headers),this}delete(...e){let[t,a]="string"==typeof e[0]?[e[0]]:[e[0].name,e[0]];return this.set({...a,name:t,value:"",expires:new Date(0)})}[Symbol.for("edge-runtime.inspect.custom")](){return`ResponseCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`}toString(){return[...this._parsed.values()].map(d).join("; ")}}},677850,e=>e.a(async(t,a)=>{try{let t=await e.y("zod");e.n(t),a()}catch(e){a(e)}},!0),200392,e=>e.a(async(t,a)=>{try{var r=e.i(677850),i=t([r]);[r]=i.then?(await i)():i,r.z.object({password:r.z.string().min(1,"Password is required").max(200)}),e.s(["isValidationFailure",0,function(e){return!1===e.success},"validateBody",0,function(e,t){let a=e.safeParse(t);if(a.success)return{success:!0,data:a.data};let r=Array.isArray(a.error?.issues)?a.error.issues:[];return{success:!1,error:{message:"Invalid request",details:r.map(e=>({field:e.path.join("."),message:e.message}))}}}]),a()}catch(e){a(e)}},!1),41244,e=>{"use strict";e.s(["HIDEABLE_SIDEBAR_ITEM_IDS",0,["home","endpoints","api-manager","providers","combos","auto-combo","costs","analytics","limits","cache","cli-tools","agents","translator","playground","media","search-tools","health","logs","audit","settings","docs","issues"]])},233405,(e,t,a)=>{t.exports=e.x("child_process",()=>require("child_process"))},180725,e=>{"use strict";e.i(245272),e.s([])},102835,e=>e.a(async(t,a)=>{try{var r=e.i(677850),i=t([r]);[r]=i.then?(await i)():i;let o=r.z.object({id:r.z.string().min(1),alias:r.z.string().min(1).optional(),name:r.z.string().min(1),icon:r.z.string().min(1),color:r.z.string().regex(/^#[0-9A-Fa-f]{6}$/,"Must be a valid hex color (#RRGGBB)"),textIcon:r.z.string().optional(),website:r.z.string().url().optional(),passthroughModels:r.z.boolean().optional(),deprecated:r.z.boolean().optional(),deprecationReason:r.z.string().optional(),hasFree:r.z.boolean().optional(),freeNote:r.z.string().optional(),authHint:r.z.string().optional(),apiHint:r.z.string().optional()}),n=r.z.record(r.z.string(),o);e.s(["validateProviders",0,function(e,t){let a=n.safeParse(e);if(!a.success){let e=a.error.issues.map(e=>` ${e.path.join(".")}: ${e.message}`).join("\n");throw console.error(`[PROVIDER VALIDATION] ${t} has invalid entries:
|
|
2
|
-
${e}`),Error(`Provider validation failed for ${t}`)}}]),a()}catch(e){a(e)}},!1),963219,e=>e.a(async(t,a)=>{try{var r=e.i(102835),i=t([r]);[r]=i.then?(await i)():i;let o={qoder:{id:"qoder",alias:"if",name:"Qoder AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gemini-cli",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationReason:"Google restricts third-party OAuth usage for Gemini CLI (Mar 2026). Pro models require paid plans. Use 'gemini' (API key) provider instead."},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"}},n={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:void 0,name:"Antigravity",icon:"rocket_launch",color:"#F59E0B"},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"},"kimi-coding":{id:"kimi-coding",alias:"kmc",name:"Kimi Coding",icon:"psychology",color:"#1E40AF",textIcon:"KC"},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"}},s={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai"},glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"bailian-coding-plan":{id:"bailian-coding-plan",alias:"bcp",name:"Alibaba Coding Plan",icon:"code",color:"#FF6A00",textIcon:"BCP",website:"https://www.alibabacloud.com/help/en/model-studio/coding-plan"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},"kimi-coding-apikey":{id:"kimi-coding-apikey",alias:"kmca",name:"Kimi Coding (API Key)",icon:"psychology",color:"#1E40AF",textIcon:"KC",website:"https://kimi.com"},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",website:"https://bailian.console.aliyun.com"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi",website:"https://modelstudio.console.alibabacloud.com"},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 (Google AI Studio)",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev",hasFree:!0,freeNote:"Free forever: 1,500 req/day for Gemini 2.5 Flash — no credit card, get key at aistudio.google.com"},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",hasFree:!0,freeNote:"Free tier: 30 RPM / 14.4K RPD — no credit card"},blackbox:{id:"blackbox",alias:"bb",name:"Blackbox AI",icon:"view_in_ar",color:"#1A1A2E",textIcon:"BB",website:"https://blackbox.ai"},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",hasFree:!0,freeNote:"$25 signup credits + 3 permanently free models: Llama 3.3 70B, Vision, DeepSeek-R1 distill"},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://inference.cerebras.ai",hasFree:!0,freeNote:"Free: 1M tokens/day, 60K TPM — world's fastest inference"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://build.nvidia.com",hasFree:!0,freeNote:"Free dev access: ~40 RPM, 70+ models (Kimi K2.5, GLM 4.7, DeepSeek V3.2...)"},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"},"ollama-cloud":{id:"ollama-cloud",alias:"ollamacloud",name:"Ollama Cloud",icon:"cloud",color:"#58A6FF",textIcon:"OC",website:"https://ollama.com/settings/api-keys"},elevenlabs:{id:"elevenlabs",alias:"el",name:"ElevenLabs",icon:"record_voice_over",color:"#6C47FF",textIcon:"EL",website:"https://elevenlabs.io"},cartesia:{id:"cartesia",alias:"cartesia",name:"Cartesia",icon:"spatial_audio",color:"#FF4F8B",textIcon:"CA",website:"https://cartesia.ai"},playht:{id:"playht",alias:"playht",name:"PlayHT",icon:"play_circle",color:"#00B4D8",textIcon:"PH",website:"https://play.ht"},inworld:{id:"inworld",alias:"inworld",name:"Inworld",icon:"voice_chat",color:"#7B2EF2",textIcon:"IW",website:"https://inworld.ai"},sdwebui:{id:"sdwebui",alias:"sdwebui",name:"SD WebUI",icon:"brush",color:"#FF7043",textIcon:"SD",website:"https://github.com/AUTOMATIC1111/stable-diffusion-webui"},comfyui:{id:"comfyui",alias:"comfyui",name:"ComfyUI",icon:"account_tree",color:"#4CAF50",textIcon:"CF",website:"https://github.com/comfyanonymous/ComfyUI"},huggingface:{id:"huggingface",alias:"hf",name:"HuggingFace",icon:"face",color:"#FFD21E",textIcon:"HF",website:"https://huggingface.co",hasFree:!0,freeNote:"Free Inference API for thousands of models (Whisper, VITS, SDXL…)"},synthetic:{id:"synthetic",alias:"synthetic",name:"Synthetic",icon:"verified_user",color:"#6366F1",textIcon:"SY",website:"https://synthetic.new",passthroughModels:!0},"kilo-gateway":{id:"kilo-gateway",alias:"kg",name:"Kilo Gateway",icon:"hub",color:"#617A91",textIcon:"KG",website:"https://kilo.ai",passthroughModels:!0},vertex:{id:"vertex",alias:"vertex",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VA",website:"https://cloud.google.com/vertex-ai",authHint:"Provide Service Account JSON or OAuth access_token"},zai:{id:"zai",alias:"zai",name:"Z.AI",icon:"psychology",color:"#2563EB",textIcon:"ZA",website:"https://open.bigmodel.cn",apiHint:"API key from https://open.bigmodel.cn/usercenter/apikeys"},"perplexity-search":{id:"perplexity-search",alias:"pplx-search",name:"Perplexity Search",icon:"search",color:"#20808D",textIcon:"PS",website:"https://docs.perplexity.ai/guides/search-quickstart",authHint:"Same API key as Perplexity (pplx-...)"},"serper-search":{id:"serper-search",alias:"serper-search",name:"Serper Search",icon:"search",color:"#4285F4",textIcon:"SP",website:"https://serper.dev",authHint:"API key from serper.dev dashboard"},"brave-search":{id:"brave-search",alias:"brave-search",name:"Brave Search",icon:"travel_explore",color:"#FB542B",textIcon:"BR",website:"https://brave.com/search/api",authHint:"Subscription token from Brave Search API dashboard"},"exa-search":{id:"exa-search",alias:"exa-search",name:"Exa Search",icon:"neurology",color:"#1E40AF",textIcon:"EX",website:"https://exa.ai",authHint:"API key from dashboard.exa.ai"},"tavily-search":{id:"tavily-search",alias:"tavily-search",name:"Tavily Search",icon:"manage_search",color:"#5B4FDB",textIcon:"TV",website:"https://tavily.com",authHint:"API key from app.tavily.com (format: tvly-...)"},"opencode-zen":{id:"opencode-zen",alias:"opencode-zen",name:"OpenCode Zen",icon:"opencode",color:"#6366f1",website:"https://opencode.ai/zen"},"opencode-go":{id:"opencode-go",alias:"opencode-go",name:"OpenCode Go",icon:"opencode",color:"#6366f1",website:"https://opencode.ai/zen/go"},alibaba:{id:"alibaba",alias:"ali",name:"Alibaba Cloud (DashScope)",icon:"cloud_queue",color:"#FF6600",textIcon:"AL",website:"https://dashscope-intl.aliyuncs.com",hasFree:!1},longcat:{id:"longcat",alias:"lc",name:"LongCat AI",icon:"auto_awesome",color:"#FF6B9D",textIcon:"LC",website:"https://longcat.chat",hasFree:!0,freeNote:"50M tokens/day (Flash-Lite) + 500K/day (Chat/Thinking) — 100% free while public beta"},pollinations:{id:"pollinations",alias:"pol",name:"Pollinations AI",icon:"local_florist",color:"#4CAF50",textIcon:"PO",website:"https://pollinations.ai",hasFree:!0,freeNote:"No API key needed — access GPT-5, Claude, Gemini, DeepSeek V3, Llama 4 free (1 req/15s)"},puter:{id:"puter",alias:"pu",name:"Puter AI",icon:"cloud_circle",color:"#6366F1",textIcon:"PU",website:"https://puter.com",hasFree:!0,freeNote:"500+ models (GPT-5, Claude Opus 4, Gemini 3 Pro, Grok 4, DeepSeek V3...) — Users pay via free Puter account",passthroughModels:!0,authHint:"Get token at puter.com/dashboard → Copy Auth Token"},"cloudflare-ai":{id:"cloudflare-ai",alias:"cf",name:"Cloudflare Workers AI",icon:"cloud",color:"#F48120",textIcon:"CF",website:"https://developers.cloudflare.com/workers-ai/",hasFree:!0,freeNote:"Free 10K Neurons/day: ~150 LLM responses or 500s Whisper audio — edge inference globally",authHint:"Requires API Token AND Account ID (found at dash.cloudflare.com)"},scaleway:{id:"scaleway",alias:"scw",name:"Scaleway AI",icon:"cloud",color:"#4F0599",textIcon:"SCW",website:"https://www.scaleway.com/en/ai/generative-apis/",hasFree:!0,freeNote:"1M free tokens for new accounts — EU/GDPR compliant (Paris), Qwen3 235B & Llama 70B"},aimlapi:{id:"aimlapi",alias:"aiml",name:"AI/ML API",icon:"hub",color:"#6366F1",textIcon:"AI",website:"https://aimlapi.com",hasFree:!0,freeNote:"$0.025/day free credits — 200+ models (GPT-4o, Claude, Gemini, Llama) via single endpoint",passthroughModels:!0}},l="openai-compatible-",c="anthropic-compatible-",d="anthropic-compatible-cc-",u={...o,...n,...s,cliproxyapi:{id:"cliproxyapi",alias:"cpa",name:"CLIProxyAPI",icon:"proxy",color:"#6366F1",textIcon:"CPA",website:"https://github.com/router-for-me/CLIProxyAPI",defaultPort:8317,healthEndpoint:"/v1/models",managementPrefix:"/v0/management",configDir:"~/.cli-proxy-api",binaryName:"cli-proxy-api",githubRepo:"router-for-me/CLIProxyAPI"}},p=Object.values(u).reduce((e,t)=>(t.alias&&(e[t.alias]=t.id),e),{});Object.values(u).reduce((e,t)=>(e[t.id]=t.alias||t.id,e),{}),(0,r.validateProviders)(o,"FREE_PROVIDERS"),(0,r.validateProviders)(n,"OAUTH_PROVIDERS"),(0,r.validateProviders)(s,"APIKEY_PROVIDERS"),e.s(["AI_PROVIDERS",0,u,"ALIAS_TO_ID",0,p,"ANTHROPIC_COMPATIBLE_PREFIX",0,c,"APIKEY_PROVIDERS",0,s,"CLAUDE_CODE_COMPATIBLE_PREFIX",0,d,"FREE_PROVIDERS",0,o,"OAUTH_PROVIDERS",0,n,"OPENAI_COMPATIBLE_PREFIX",0,l,"USAGE_SUPPORTED_PROVIDERS",0,["antigravity","gemini-cli","kiro","github","codex","claude","kimi-coding","glm"],"getProviderAlias",0,function(e){let t=u[e];return t?.alias||e},"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(c)},"isClaudeCodeCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(d)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(l)}]),a()}catch(e){a(e)}},!1),383368,e=>e.a(async(t,a)=>{try{var r=e.i(828059),i=e.i(693602),o=e.i(963219),n=e.i(679468),s=t([o]);[o]=s.then?(await s)():s;let P=new Set(["openai","openai-responses"]),C=new Set(["gemini","gemini-cli"]);function l(e){return(e||"").trim().replace(/\/$/,"")}function c(e){return{"Content-Type":"application/json",Authorization:`Bearer ${e}`}}async function d({provider:e,apiKey:t,baseUrl:a,providerSpecificData:r={},modelId:i="gpt-4o-mini",modelsUrl:n}){if(!a)return{valid:!1,error:"Missing base URL"};let s=n||function(e){let t=l(e);if(!t)return"";for(let e of["/chat/completions","/responses","/chat","/messages"])if(t.endsWith(e))return`${t.slice(0,-e.length)}/models`;return`${t}/models`}(a);if(!s)return{valid:!1,error:"Invalid models endpoint"};let u=await fetch(s,{method:"GET",headers:c(t)});if(u.ok)return{valid:!0,error:null};if(401===u.status||403===u.status)return{valid:!1,error:"Invalid API key"};let p=function(e,t,a={}){let r=l(t);return r?(0,o.isOpenAICompatibleProvider)(e)?a?.chatPath?`${r}${a.chatPath}`:a?.apiType==="responses"?`${r}/responses`:`${r}/chat/completions`:r.endsWith("/chat/completions")||r.endsWith("/responses")||r.endsWith("/chat")?r:r.endsWith("/v1")?`${r}/chat/completions`:r:""}(e,a,r);if(!p)return{valid:!1,error:`Validation failed: ${u.status}`};let h=r?.validationModelId||i,m=await fetch(p,{method:"POST",headers:c(t),body:JSON.stringify({model:h,messages:[{role:"user",content:"test"}],max_tokens:1})});return m.ok?{valid:!0,error:null}:401===m.status||403===m.status?{valid:!1,error:"Invalid API key"}:404===m.status||405===m.status?{valid:!1,error:"Provider validation endpoint not supported"}:m.status>=500?{valid:!1,error:`Provider unavailable (${m.status})`}:{valid:!0,error:null}}async function u({apiKey:e,baseUrl:t,modelId:a,headers:r={},providerSpecificData:i={}}){if(!t)return{valid:!1,error:"Missing base URL"};let o={"Content-Type":"application/json",...r};o["x-api-key"]||o["X-API-Key"]||(o["x-api-key"]=e),o["anthropic-version"]||o["Anthropic-Version"]||(o["anthropic-version"]="2023-06-01");let n=i?.validationModelId||a||"claude-3-5-sonnet-20241022",s=await fetch(t,{method:"POST",headers:o,body:JSON.stringify({model:n,max_tokens:1,messages:[{role:"user",content:"test"}]})});return 401===s.status||403===s.status?{valid:!1,error:"Invalid API key"}:{valid:!0,error:null}}async function p({apiKey:e,baseUrl:t}){if(!t)return{valid:!1,error:"Missing base URL"};let a=t.includes("?")?"&":"?",r=await fetch(`${t}${a}key=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});return r.ok?{valid:!0,error:null}:401===r.status||403===r.status?{valid:!1,error:"Invalid API key"}:{valid:!1,error:`Validation failed: ${r.status}`}}async function h({apiKey:e}){try{let t=await fetch("https://api.deepgram.com/v1/auth/token",{method:"GET",headers:{Authorization:`Token ${e}`}});if(t.ok)return{valid:!0,error:null};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!1,error:`Validation failed: ${t.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function m({apiKey:e}){try{let t=await fetch("https://api.assemblyai.com/v2/transcript?limit=1",{method:"GET",headers:{Authorization:e,"Content-Type":"application/json"}});if(t.ok)return{valid:!0,error:null};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!1,error:`Validation failed: ${t.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function v({apiKey:e}){try{let t=await fetch("https://api.nanobananaapi.ai/api/v1/nanobanana/generate",{method:"POST",headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json"},body:JSON.stringify({prompt:"test",model:"nanobanana-flash"})});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function f({apiKey:e}){try{let t=await fetch("https://api.elevenlabs.io/v1/voices",{method:"GET",headers:{"xi-api-key":e,"Content-Type":"application/json"}});if(t.ok)return{valid:!0,error:null};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!1,error:`Validation failed: ${t.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function y({apiKey:e}){try{let t=await fetch("https://api.inworld.ai/tts/v1/voice",{method:"POST",headers:{Authorization:`Basic ${e}`,"Content-Type":"application/json"},body:JSON.stringify({text:"test",modelId:"inworld-tts-1.5-mini",audioConfig:{audioEncoding:"MP3"}})});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function g({apiKey:e,providerSpecificData:t={}}){try{let a=l(t.baseUrl)||"https://coding-intl.dashscope.aliyuncs.com/apps/anthropic/v1",r=a.endsWith("/messages")?a.slice(0,-9):a,i=`${r}/messages`,o=await fetch(i,{method:"POST",headers:{"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"},body:JSON.stringify({model:"qwen3-coder-plus",max_tokens:1,messages:[{role:"user",content:"test"}]})});if(401===o.status||403===o.status)return{valid:!1,error:"Invalid API key"};if(o.status>=400&&o.status<500||o.ok)return{valid:!0,error:null};return{valid:!1,error:`Validation failed: ${o.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function b({apiKey:e,providerSpecificData:t={}}){let a=l(t.baseUrl);if(!a)return{valid:!1,error:"No base URL configured for OpenAI compatible provider"};let r="string"==typeof t?.validationModelId?t.validationModelId.trim():"",i=!1;try{let t=await fetch(`${a}/models`,{method:"GET",headers:c(e)});if(i=!0,t.ok)return{valid:!0,error:null,method:"models_endpoint"};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};if(429===t.status)return{valid:!0,error:null,method:"models_endpoint",warning:"Rate limited, but credentials are valid"}}catch{}if(!r)return{valid:!1,error:"Endpoint /models unavailable. Provide a Model ID to validate via /chat/completions."};let o=t.apiType||"chat",n=`${a}${"responses"===o?"/responses":"/chat/completions"}`;try{let t=await fetch(n,{method:"POST",headers:c(e),body:JSON.stringify({model:r,messages:[{role:"user",content:"test"}],max_tokens:1})});if(t.ok)return{valid:!0,error:null,method:"chat_completions"};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};if(429===t.status)return{valid:!0,error:null,method:"chat_completions",warning:"Rate limited, but credentials are valid"};if(400===t.status)return{valid:!0,error:null,method:"inference_available",warning:"Model ID may be invalid, but credentials are valid"};if(t.status>=400&&t.status<500)return{valid:!0,error:null,method:"inference_available"};if(t.status>=500)return{valid:!1,error:`Provider unavailable (${t.status})`}}catch{}if(!i)return{valid:!1,error:"Connection failed while testing /chat/completions"};try{let t=await fetch(a,{method:"GET",headers:c(e),signal:AbortSignal.timeout(5e3)});if(t.status<500)return{valid:!0,error:null};return{valid:!1,error:`Provider unavailable (${t.status})`}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}}async function x({apiKey:e,providerSpecificData:t={}}){var a;let r=(a=t.baseUrl,(0,i.stripAnthropicMessagesSuffix)(a||""));if(!r)return{valid:!1,error:"No base URL configured for Anthropic compatible provider"};let o={"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e}`};try{let e=await fetch((0,i.joinBaseUrlAndPath)(r,t?.modelsPath||"/models"),{method:"GET",headers:o});if(e.ok)return{valid:!0,error:null};if(401===e.status||403===e.status)return{valid:!1,error:"Invalid API key"}}catch{}let n=t?.validationModelId||"claude-3-5-sonnet-20241022";try{let e=await fetch((0,i.joinBaseUrlAndPath)(r,t?.chatPath||"/messages"),{method:"POST",headers:o,body:JSON.stringify({model:n,max_tokens:1,messages:[{role:"user",content:"test"}]})});if(401===e.status||403===e.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}}async function w({apiKey:e,providerSpecificData:t={}}){var a;let r=(a=t.baseUrl,(0,i.stripClaudeCodeCompatibleEndpointSuffix)(a||""));if(!r)return{valid:!1,error:"No base URL configured for CC Compatible provider"};let o=t?.modelsPath||i.CLAUDE_CODE_COMPATIBLE_DEFAULT_MODELS_PATH,n=t?.chatPath||i.CLAUDE_CODE_COMPATIBLE_DEFAULT_CHAT_PATH,s=(0,i.buildClaudeCodeCompatibleHeaders)(e,!1);try{let e=await fetch((0,i.joinClaudeCodeCompatibleUrl)(r,o),{method:"GET",headers:s});if(e.ok)return{valid:!0,error:null,method:"models_endpoint"};if(401===e.status||403===e.status)return{valid:!1,error:"Invalid API key"}}catch{}let l=(0,i.buildClaudeCodeCompatibleValidationPayload)(t?.validationModelId||"claude-sonnet-4-6"),c=JSON.parse(l.metadata.user_id).session_id;try{let t=await fetch((0,i.joinClaudeCodeCompatibleUrl)(r,n),{method:"POST",headers:(0,i.buildClaudeCodeCompatibleHeaders)(e,!0,c),body:JSON.stringify(l)});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};if(429===t.status)return{valid:!0,error:null,method:"cc_bridge_request",warning:"Rate limited, but credentials are valid"};if(t.status>=400&&t.status<500)return{valid:!0,error:null,method:"cc_bridge_request",warning:"Bridge request reached upstream, but the model or payload was rejected"};return{valid:t.ok,error:t.ok?null:`Validation failed: ${t.status}`,method:"cc_bridge_request"}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}}async function I(e,t){try{let a=await fetch(e,t);if(a.ok)return{valid:!0,error:null,unsupported:!1};if(401===a.status||403===a.status)return{valid:!1,error:"Invalid API key",unsupported:!1};if(a.status<500)return{valid:!0,error:null,unsupported:!1};return{valid:!1,error:`Validation failed: ${a.status}`,unsupported:!1}}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}}let k={"serper-search":e=>({url:"https://google.serper.dev/search",init:{method:"POST",headers:{"Content-Type":"application/json","X-API-Key":e},body:JSON.stringify({q:"test",num:1})}}),"brave-search":e=>({url:"https://api.search.brave.com/res/v1/web/search?q=test&count=1",init:{method:"GET",headers:{Accept:"application/json","X-Subscription-Token":e}}}),"perplexity-search":e=>({url:"https://api.perplexity.ai/search",init:{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e}`},body:JSON.stringify({query:"test",max_results:1})}}),"exa-search":e=>({url:"https://api.exa.ai/search",init:{method:"POST",headers:{"Content-Type":"application/json","x-api-key":e},body:JSON.stringify({query:"test",numResults:1})}}),"tavily-search":e=>({url:"https://api.tavily.com/search",init:{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e}`},body:JSON.stringify({query:"test",max_results:1})}})};async function A({provider:e,apiKey:t,providerSpecificData:a={}}){if(!e||!t)return{valid:!1,error:"Provider and API key required",unsupported:!1};if((0,o.isOpenAICompatibleProvider)(e))try{return await b({apiKey:t,providerSpecificData:a})}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}if((0,o.isAnthropicCompatibleProvider)(e))try{if((0,o.isClaudeCodeCompatibleProvider)(e))return await w({apiKey:t,providerSpecificData:a});return await x({apiKey:t,providerSpecificData:a})}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}let i={qoder:({apiKey:e,providerSpecificData:t})=>(0,n.validateQoderCliPat)({apiKey:e,providerSpecificData:t}),deepgram:h,assemblyai:m,nanobanana:v,elevenlabs:f,inworld:y,"bailian-coding-plan":g,longcat:async({apiKey:e})=>{try{let t=await fetch("https://api.longcat.chat/openai/v1/chat/completions",{method:"POST",headers:c(e),body:JSON.stringify({model:"longcat",messages:[{role:"user",content:"test"}],max_tokens:1})});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}},...Object.fromEntries(Object.entries(k).map(([e,t])=>[e,({apiKey:e})=>{let{url:a,init:r}=t(e);return I(a,r)}]))};if(i[e])try{return await i[e]({apiKey:t,providerSpecificData:a})}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}let s=(0,r.getRegistryEntry)(e);if(!s)return{valid:!1,error:"Provider validation not supported",unsupported:!0};let _=s.models?.[0]?.id||null,R=s.testKeyBaseUrl?{...s,baseUrl:s.testKeyBaseUrl}:s,E=function(e,t={}){return t?.baseUrl?l(t.baseUrl):e?.baseUrl?l(e.baseUrl):""}(R,a);try{if(P.has(s.format))return await d({provider:e,apiKey:t,baseUrl:E,providerSpecificData:a,modelId:_,modelsUrl:s.modelsUrl});if("claude"===s.format){let e=`${E}${s.urlSuffix||""}`,r={...s.headers||{}};return"x-api-key"===(s.authHeader||"").toLowerCase()?r["x-api-key"]=t:r.Authorization=`Bearer ${t}`,await u({apiKey:t,baseUrl:e,modelId:_,headers:r,providerSpecificData:a})}if(C.has(s.format))return await p({apiKey:t,baseUrl:E});return{valid:!1,error:"Provider validation not supported",unsupported:!0}}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}}e.s(["validateClaudeCodeCompatibleProvider",0,w,"validateProviderApiKey",0,A]),a()}catch(e){a(e)}},!1),851380,e=>e.a(async(t,a)=>{try{var r=e.i(89171);e.i(180725);var i=e.i(385498),o=e.i(963219),n=e.i(383368),s=e.i(676088),l=e.i(200392),c=t([o,n,s,l]);async function d(e){let t;try{t=await e.json()}catch{return r.NextResponse.json({error:{message:"Invalid request",details:[{field:"body",message:"Invalid JSON body"}]}},{status:400})}try{let e=(0,l.validateBody)(s.validateProviderApiKeySchema,t);if((0,l.isValidationFailure)(e))return r.NextResponse.json({error:e.error},{status:400});let{provider:a,apiKey:c,validationModelId:d}=e.data,u={validationModelId:d};if((0,o.isOpenAICompatibleProvider)(a)||(0,o.isAnthropicCompatibleProvider)(a)){let e=await (0,i.getProviderNodeById)(a);if(!e){let e=(0,o.isOpenAICompatibleProvider)(a)?"OpenAI":(0,o.isClaudeCodeCompatibleProvider)(a)?"CC":"Anthropic";return r.NextResponse.json({error:`${e} Compatible node not found`},{status:404})}u={...u,baseUrl:e.baseUrl,apiType:e.apiType,chatPath:e.chatPath,modelsPath:e.modelsPath}}let p=await (0,n.validateProviderApiKey)({provider:a,apiKey:c,providerSpecificData:u});if(p.unsupported)return r.NextResponse.json({error:"Provider validation not supported"},{status:400});return r.NextResponse.json({valid:!!p.valid,error:p.valid?null:p.error||"Invalid API key",warning:p.warning||null,method:p.method||null})}catch(e){return console.log("Error validating API key:",e),r.NextResponse.json({error:"Validation failed"},{status:500})}}[o,n,s,l]=c.then?(await c)():c,e.s(["POST",0,d]),a()}catch(e){a(e)}},!1),477929,e=>e.a(async(t,a)=>{try{var r=e.i(747909),i=e.i(174017),o=e.i(996250),n=e.i(759756),s=e.i(561916),l=e.i(174677),c=e.i(869741),d=e.i(316795),u=e.i(487718),p=e.i(995169),h=e.i(47587),m=e.i(666012),v=e.i(570101),f=e.i(626937),y=e.i(10372),g=e.i(193695);e.i(820232);var b=e.i(600220),x=e.i(851380),w=t([x]);[x]=w.then?(await w)():w;let A=new r.AppRouteRouteModule({definition:{kind:i.RouteKind.APP_ROUTE,page:"/api/providers/validate/route",pathname:"/api/providers/validate",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/validate/route.ts",nextConfigOutput:"standalone",userland:x,...{}}),{workAsyncStorage:P,workUnitAsyncStorage:C,serverHooks:k}=A;async function I(e,t,a){a.requestMeta&&(0,n.setRequestMeta)(e,a.requestMeta),A.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let r="/api/providers/validate/route";r=r.replace(/\/index$/,"")||"/";let o=await A.prepare(e,t,{srcPage:r,multiZoneDraftMode:!1});if(!o)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:x,params:w,nextConfig:I,parsedUrl:P,isDraftMode:C,prerenderManifest:k,routerServerContext:_,isOnDemandRevalidate:R,revalidateOnlyGenerated:E,resolvedPathname:S,clientReferenceManifest:O,serverActionsManifest:F}=o,T=(0,c.normalizeAppPath)(r),D=!!(k.dynamicRoutes[T]||k.routes[S]),N=async()=>((null==_?void 0:_.render404)?await _.render404(e,t,P,!1):t.end("This page could not be found"),null);if(D&&!C){let e=!!k.routes[S],t=k.dynamicRoutes[T];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await N();throw new g.NoFallbackError}}let M=null;!D||A.isDev||C||(M=S,M="/index"===M?"/":M);let $=!0===A.isDev||!D,j=D&&!$;F&&O&&(0,l.setManifestsSingleton)({page:r,clientReferenceManifest:O,serverActionsManifest:F});let B=e.method||"GET",U=(0,s.getTracer)(),q=U.getActiveScopeSpan(),L=!!(null==_?void 0:_.isWrappedByNextServer),V=!!(0,n.getRequestMeta)(e,"minimalMode"),H=(0,n.getRequestMeta)(e,"incrementalCache")||await A.getIncrementalCache(e,I,k,V);null==H||H.resetRequestCache(),globalThis.__incrementalCache=H;let G={params:w,previewProps:k.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:$,incrementalCache:H,cacheLifeProfiles:I.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,r,i)=>A.onRequestError(e,t,r,i,_)},sharedContext:{buildId:x}},z=new d.NodeNextRequest(e),K=new d.NodeNextResponse(t),W=u.NextRequestAdapter.fromNodeNextRequest(z,(0,u.signalFromNodeResponse)(t));try{let o,n=async e=>A.handle(W,G).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=U.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==p.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let i=a.get("next.route");if(i){let t=`${B} ${i}`;e.setAttributes({"next.route":i,"http.route":i,"next.span_name":t}),e.updateName(t),o&&o!==e&&(o.setAttribute("http.route",i),o.updateName(t))}else e.updateName(`${B} ${r}`)}),l=async o=>{var s,l;let c=async({previousCacheEntry:i})=>{try{if(!V&&R&&E&&!i)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let r=await n(o);e.fetchMetrics=G.renderOpts.fetchMetrics;let s=G.renderOpts.pendingWaitUntil;s&&a.waitUntil&&(a.waitUntil(s),s=void 0);let l=G.renderOpts.collectedTags;if(!D)return await (0,m.sendResponse)(z,K,r,G.renderOpts.pendingWaitUntil),null;{let e=await r.blob(),t=(0,v.toNodeOutgoingHttpHeaders)(r.headers);l&&(t[y.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==G.renderOpts.collectedRevalidate&&!(G.renderOpts.collectedRevalidate>=y.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,i=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=y.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:b.CachedRouteKind.APP_ROUTE,status:r.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:i}}}}catch(t){throw(null==i?void 0:i.isStale)&&await A.onRequestError(e,t,{routerKind:"App Router",routePath:r,routeType:"route",revalidateReason:(0,h.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:R})},!1,_),t}},d=await A.handleResponse({req:e,nextConfig:I,cacheKey:M,routeKind:i.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:k,isRoutePPREnabled:!1,isOnDemandRevalidate:R,revalidateOnlyGenerated:E,responseGenerator:c,waitUntil:a.waitUntil,isMinimalMode:V});if(!D)return null;if((null==d||null==(s=d.value)?void 0:s.kind)!==b.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(l=d.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});V||t.setHeader("x-nextjs-cache",R?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),C&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let u=(0,v.fromNodeOutgoingHttpHeaders)(d.value.headers);return V&&D||u.delete(y.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,m.sendResponse)(z,K,new Response(d.value.body,{headers:u,status:d.value.status||200})),null};L&&q?await l(q):(o=U.getActiveScopeSpan(),await U.withPropagatedContext(e.headers,()=>U.trace(p.BaseServerSpan.handleRequest,{spanName:`${B} ${r}`,kind:s.SpanKind.SERVER,attributes:{"http.method":B,"http.target":e.url}},l),void 0,!L))}catch(t){if(t instanceof g.NoFallbackError||await A.onRequestError(e,t,{routerKind:"App Router",routePath:T,routeType:"route",revalidateReason:(0,h.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:R})},!1,_),D)throw t;return await (0,m.sendResponse)(z,K,new Response(null,{status:500})),null}}e.s(["handler",0,I,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:P,workUnitAsyncStorage:C})},"routeModule",0,A,"serverHooks",0,k,"workAsyncStorage",0,P,"workUnitAsyncStorage",0,C]),a()}catch(e){a(e)}},!1),606102,e=>{e.v(e=>Promise.resolve().then(()=>e(548941)))},789543,e=>{e.v(e=>Promise.resolve().then(()=>e(385498)))},579042,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_utils_apiKey_ts_12~h.oz._.js"].map(t=>e.l(t))).then(()=>t(65448)))},49794,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_ts_0hk12it._.js"].map(t=>e.l(t))).then(()=>t(404503)))},386305,e=>{e.v(e=>Promise.resolve().then(()=>e(878947)))}];
|
|
1
|
+
module.exports=[918622,(e,t,a)=>{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"))},556704,(e,t,a)=>{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"))},832319,(e,t,a)=>{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"))},324725,(e,t,a)=>{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"))},270406,(e,t,a)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},193695,(e,t,a)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},442315,(e,t,a)=>{"use strict";t.exports=e.r(918622)},347540,(e,t,a)=>{"use strict";t.exports=e.r(442315).vendored["react-rsc"].React},819481,(e,t,a)=>{"use strict";var r=Object.defineProperty,i=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,n=Object.prototype.hasOwnProperty,s={},l={RequestCookies:()=>v,ResponseCookies:()=>f,parseCookie:()=>u,parseSetCookie:()=>p,stringifyCookie:()=>d};for(var c in l)r(s,c,{get:l[c],enumerable:!0});function d(e){var t;let a=["path"in e&&e.path&&`Path=${e.path}`,"expires"in e&&(e.expires||0===e.expires)&&`Expires=${("number"==typeof e.expires?new Date(e.expires):e.expires).toUTCString()}`,"maxAge"in e&&"number"==typeof e.maxAge&&`Max-Age=${e.maxAge}`,"domain"in e&&e.domain&&`Domain=${e.domain}`,"secure"in e&&e.secure&&"Secure","httpOnly"in e&&e.httpOnly&&"HttpOnly","sameSite"in e&&e.sameSite&&`SameSite=${e.sameSite}`,"partitioned"in e&&e.partitioned&&"Partitioned","priority"in e&&e.priority&&`Priority=${e.priority}`].filter(Boolean),r=`${e.name}=${encodeURIComponent(null!=(t=e.value)?t:"")}`;return 0===a.length?r:`${r}; ${a.join("; ")}`}function u(e){let t=new Map;for(let a of e.split(/; */)){if(!a)continue;let e=a.indexOf("=");if(-1===e){t.set(a,"true");continue}let[r,i]=[a.slice(0,e),a.slice(e+1)];try{t.set(r,decodeURIComponent(null!=i?i:"true"))}catch{}}return t}function p(e){if(!e)return;let[[t,a],...r]=u(e),{domain:i,expires:o,httponly:n,maxage:s,path:l,samesite:c,secure:d,partitioned:p,priority:v}=Object.fromEntries(r.map(([e,t])=>[e.toLowerCase().replace(/-/g,""),t]));{var f,y,g={name:t,value:decodeURIComponent(a),domain:i,...o&&{expires:new Date(o)},...n&&{httpOnly:!0},..."string"==typeof s&&{maxAge:Number(s)},path:l,...c&&{sameSite:h.includes(f=(f=c).toLowerCase())?f:void 0},...d&&{secure:!0},...v&&{priority:m.includes(y=(y=v).toLowerCase())?y:void 0},...p&&{partitioned:!0}};let e={};for(let t in g)g[t]&&(e[t]=g[t]);return e}}t.exports=((e,t,a)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let s of o(t))n.call(e,s)||void 0===s||r(e,s,{get:()=>t[s],enumerable:!(a=i(t,s))||a.enumerable});return e})(r({},"__esModule",{value:!0}),s);var h=["strict","lax","none"],m=["low","medium","high"],v=class{constructor(e){this._parsed=new Map,this._headers=e;const t=e.get("cookie");if(t)for(const[e,a]of u(t))this._parsed.set(e,{name:e,value:a})}[Symbol.iterator](){return this._parsed[Symbol.iterator]()}get size(){return this._parsed.size}get(...e){let t="string"==typeof e[0]?e[0]:e[0].name;return this._parsed.get(t)}getAll(...e){var t;let a=Array.from(this._parsed);if(!e.length)return a.map(([e,t])=>t);let r="string"==typeof e[0]?e[0]:null==(t=e[0])?void 0:t.name;return a.filter(([e])=>e===r).map(([e,t])=>t)}has(e){return this._parsed.has(e)}set(...e){let[t,a]=1===e.length?[e[0].name,e[0].value]:e,r=this._parsed;return r.set(t,{name:t,value:a}),this._headers.set("cookie",Array.from(r).map(([e,t])=>d(t)).join("; ")),this}delete(e){let t=this._parsed,a=Array.isArray(e)?e.map(e=>t.delete(e)):t.delete(e);return this._headers.set("cookie",Array.from(t).map(([e,t])=>d(t)).join("; ")),a}clear(){return this.delete(Array.from(this._parsed.keys())),this}[Symbol.for("edge-runtime.inspect.custom")](){return`RequestCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`}toString(){return[...this._parsed.values()].map(e=>`${e.name}=${encodeURIComponent(e.value)}`).join("; ")}},f=class{constructor(e){var t,a,r;this._parsed=new Map,this._headers=e;const i=null!=(r=null!=(a=null==(t=e.getSetCookie)?void 0:t.call(e))?a:e.get("set-cookie"))?r:[];for(const e of Array.isArray(i)?i:function(e){if(!e)return[];var t,a,r,i,o,n=[],s=0;function l(){for(;s<e.length&&/\s/.test(e.charAt(s));)s+=1;return s<e.length}for(;s<e.length;){for(t=s,o=!1;l();)if(","===(a=e.charAt(s))){for(r=s,s+=1,l(),i=s;s<e.length&&"="!==(a=e.charAt(s))&&";"!==a&&","!==a;)s+=1;s<e.length&&"="===e.charAt(s)?(o=!0,s=i,n.push(e.substring(t,r)),t=s):s=r+1}else s+=1;(!o||s>=e.length)&&n.push(e.substring(t,e.length))}return n}(i)){const t=p(e);t&&this._parsed.set(t.name,t)}}get(...e){let t="string"==typeof e[0]?e[0]:e[0].name;return this._parsed.get(t)}getAll(...e){var t;let a=Array.from(this._parsed.values());if(!e.length)return a;let r="string"==typeof e[0]?e[0]:null==(t=e[0])?void 0:t.name;return a.filter(e=>e.name===r)}has(e){return this._parsed.has(e)}set(...e){let[t,a,r]=1===e.length?[e[0].name,e[0].value,e[0]]:e,i=this._parsed;return i.set(t,function(e={name:"",value:""}){return"number"==typeof e.expires&&(e.expires=new Date(e.expires)),e.maxAge&&(e.expires=new Date(Date.now()+1e3*e.maxAge)),(null===e.path||void 0===e.path)&&(e.path="/"),e}({name:t,value:a,...r})),function(e,t){for(let[,a]of(t.delete("set-cookie"),e)){let e=d(a);t.append("set-cookie",e)}}(i,this._headers),this}delete(...e){let[t,a]="string"==typeof e[0]?[e[0]]:[e[0].name,e[0]];return this.set({...a,name:t,value:"",expires:new Date(0)})}[Symbol.for("edge-runtime.inspect.custom")](){return`ResponseCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`}toString(){return[...this._parsed.values()].map(d).join("; ")}}},677850,e=>e.a(async(t,a)=>{try{let t=await e.y("zod");e.n(t),a()}catch(e){a(e)}},!0),200392,e=>e.a(async(t,a)=>{try{var r=e.i(677850),i=t([r]);[r]=i.then?(await i)():i,r.z.object({password:r.z.string().min(1,"Password is required").max(200)}),e.s(["isValidationFailure",0,function(e){return!1===e.success},"validateBody",0,function(e,t){let a=e.safeParse(t);if(a.success)return{success:!0,data:a.data};let r=Array.isArray(a.error?.issues)?a.error.issues:[];return{success:!1,error:{message:"Invalid request",details:r.map(e=>({field:e.path.join("."),message:e.message}))}}}]),a()}catch(e){a(e)}},!1),41244,e=>{"use strict";e.s(["HIDEABLE_SIDEBAR_ITEM_IDS",0,["home","endpoints","api-manager","providers","combos","auto-combo","costs","analytics","limits","cache","cli-tools","agents","memory","skills","translator","playground","media","search-tools","health","logs","audit","settings","docs","issues"]])},233405,(e,t,a)=>{t.exports=e.x("child_process",()=>require("child_process"))},180725,e=>{"use strict";e.i(245272),e.s([])},102835,e=>e.a(async(t,a)=>{try{var r=e.i(677850),i=t([r]);[r]=i.then?(await i)():i;let o=r.z.object({id:r.z.string().min(1),alias:r.z.string().min(1).optional(),name:r.z.string().min(1),icon:r.z.string().min(1),color:r.z.string().regex(/^#[0-9A-Fa-f]{6}$/,"Must be a valid hex color (#RRGGBB)"),textIcon:r.z.string().optional(),website:r.z.string().url().optional(),passthroughModels:r.z.boolean().optional(),deprecated:r.z.boolean().optional(),deprecationReason:r.z.string().optional(),hasFree:r.z.boolean().optional(),freeNote:r.z.string().optional(),authHint:r.z.string().optional(),apiHint:r.z.string().optional()}),n=r.z.record(r.z.string(),o);e.s(["validateProviders",0,function(e,t){let a=n.safeParse(e);if(!a.success){let e=a.error.issues.map(e=>` ${e.path.join(".")}: ${e.message}`).join("\n");throw console.error(`[PROVIDER VALIDATION] ${t} has invalid entries:
|
|
2
|
+
${e}`),Error(`Provider validation failed for ${t}`)}}]),a()}catch(e){a(e)}},!1),963219,e=>e.a(async(t,a)=>{try{var r=e.i(102835),i=t([r]);[r]=i.then?(await i)():i;let o={qoder:{id:"qoder",alias:"if",name:"Qoder AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gemini-cli",name:"Gemini CLI",icon:"terminal",color:"#4285F4",deprecated:!0,deprecationReason:"Google restricts third-party OAuth usage for Gemini CLI (Mar 2026). Pro models require paid plans. Use 'gemini' (API key) provider instead."},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"}},n={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:void 0,name:"Antigravity",icon:"rocket_launch",color:"#F59E0B"},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"},"kimi-coding":{id:"kimi-coding",alias:"kmc",name:"Kimi Coding",icon:"psychology",color:"#1E40AF",textIcon:"KC"},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"}},s={openrouter:{id:"openrouter",alias:"openrouter",name:"OpenRouter",icon:"router",color:"#F97316",textIcon:"OR",passthroughModels:!0,website:"https://openrouter.ai"},glm:{id:"glm",alias:"glm",name:"GLM Coding",icon:"code",color:"#2563EB",textIcon:"GL",website:"https://open.bigmodel.cn"},"bailian-coding-plan":{id:"bailian-coding-plan",alias:"bcp",name:"Alibaba Coding Plan",icon:"code",color:"#FF6A00",textIcon:"BCP",website:"https://www.alibabacloud.com/help/en/model-studio/coding-plan"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},"kimi-coding-apikey":{id:"kimi-coding-apikey",alias:"kmca",name:"Kimi Coding (API Key)",icon:"psychology",color:"#1E40AF",textIcon:"KC",website:"https://kimi.com"},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",website:"https://bailian.console.aliyun.com"},"alicode-intl":{id:"alicode-intl",alias:"alicode-intl",name:"Alibaba Intl",icon:"cloud",color:"#FF6A00",textIcon:"ALi",website:"https://modelstudio.console.alibabacloud.com"},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 (Google AI Studio)",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev",hasFree:!0,freeNote:"Free forever: 1,500 req/day for Gemini 2.5 Flash — no credit card, get key at aistudio.google.com"},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",hasFree:!0,freeNote:"Free tier: 30 RPM / 14.4K RPD — no credit card"},blackbox:{id:"blackbox",alias:"bb",name:"Blackbox AI",icon:"view_in_ar",color:"#1A1A2E",textIcon:"BB",website:"https://blackbox.ai"},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",hasFree:!0,freeNote:"$25 signup credits + 3 permanently free models: Llama 3.3 70B, Vision, DeepSeek-R1 distill"},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://inference.cerebras.ai",hasFree:!0,freeNote:"Free: 1M tokens/day, 60K TPM — world's fastest inference"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://build.nvidia.com",hasFree:!0,freeNote:"Free dev access: ~40 RPM, 70+ models (Kimi K2.5, GLM 4.7, DeepSeek V3.2...)"},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"},"ollama-cloud":{id:"ollama-cloud",alias:"ollamacloud",name:"Ollama Cloud",icon:"cloud",color:"#58A6FF",textIcon:"OC",website:"https://ollama.com/settings/api-keys"},elevenlabs:{id:"elevenlabs",alias:"el",name:"ElevenLabs",icon:"record_voice_over",color:"#6C47FF",textIcon:"EL",website:"https://elevenlabs.io"},cartesia:{id:"cartesia",alias:"cartesia",name:"Cartesia",icon:"spatial_audio",color:"#FF4F8B",textIcon:"CA",website:"https://cartesia.ai"},playht:{id:"playht",alias:"playht",name:"PlayHT",icon:"play_circle",color:"#00B4D8",textIcon:"PH",website:"https://play.ht"},inworld:{id:"inworld",alias:"inworld",name:"Inworld",icon:"voice_chat",color:"#7B2EF2",textIcon:"IW",website:"https://inworld.ai"},sdwebui:{id:"sdwebui",alias:"sdwebui",name:"SD WebUI",icon:"brush",color:"#FF7043",textIcon:"SD",website:"https://github.com/AUTOMATIC1111/stable-diffusion-webui"},comfyui:{id:"comfyui",alias:"comfyui",name:"ComfyUI",icon:"account_tree",color:"#4CAF50",textIcon:"CF",website:"https://github.com/comfyanonymous/ComfyUI"},huggingface:{id:"huggingface",alias:"hf",name:"HuggingFace",icon:"face",color:"#FFD21E",textIcon:"HF",website:"https://huggingface.co",hasFree:!0,freeNote:"Free Inference API for thousands of models (Whisper, VITS, SDXL…)"},synthetic:{id:"synthetic",alias:"synthetic",name:"Synthetic",icon:"verified_user",color:"#6366F1",textIcon:"SY",website:"https://synthetic.new",passthroughModels:!0},"kilo-gateway":{id:"kilo-gateway",alias:"kg",name:"Kilo Gateway",icon:"hub",color:"#617A91",textIcon:"KG",website:"https://kilo.ai",passthroughModels:!0},vertex:{id:"vertex",alias:"vertex",name:"Vertex AI",icon:"cloud",color:"#4285F4",textIcon:"VA",website:"https://cloud.google.com/vertex-ai",authHint:"Provide Service Account JSON or OAuth access_token"},zai:{id:"zai",alias:"zai",name:"Z.AI",icon:"psychology",color:"#2563EB",textIcon:"ZA",website:"https://open.bigmodel.cn",apiHint:"API key from https://open.bigmodel.cn/usercenter/apikeys"},"perplexity-search":{id:"perplexity-search",alias:"pplx-search",name:"Perplexity Search",icon:"search",color:"#20808D",textIcon:"PS",website:"https://docs.perplexity.ai/guides/search-quickstart",authHint:"Same API key as Perplexity (pplx-...)"},"serper-search":{id:"serper-search",alias:"serper-search",name:"Serper Search",icon:"search",color:"#4285F4",textIcon:"SP",website:"https://serper.dev",authHint:"API key from serper.dev dashboard"},"brave-search":{id:"brave-search",alias:"brave-search",name:"Brave Search",icon:"travel_explore",color:"#FB542B",textIcon:"BR",website:"https://brave.com/search/api",authHint:"Subscription token from Brave Search API dashboard"},"exa-search":{id:"exa-search",alias:"exa-search",name:"Exa Search",icon:"neurology",color:"#1E40AF",textIcon:"EX",website:"https://exa.ai",authHint:"API key from dashboard.exa.ai"},"tavily-search":{id:"tavily-search",alias:"tavily-search",name:"Tavily Search",icon:"manage_search",color:"#5B4FDB",textIcon:"TV",website:"https://tavily.com",authHint:"API key from app.tavily.com (format: tvly-...)"},"opencode-zen":{id:"opencode-zen",alias:"opencode-zen",name:"OpenCode Zen",icon:"opencode",color:"#6366f1",website:"https://opencode.ai/zen"},"opencode-go":{id:"opencode-go",alias:"opencode-go",name:"OpenCode Go",icon:"opencode",color:"#6366f1",website:"https://opencode.ai/zen/go"},alibaba:{id:"alibaba",alias:"ali",name:"Alibaba Cloud (DashScope)",icon:"cloud_queue",color:"#FF6600",textIcon:"AL",website:"https://dashscope-intl.aliyuncs.com",hasFree:!1},longcat:{id:"longcat",alias:"lc",name:"LongCat AI",icon:"auto_awesome",color:"#FF6B9D",textIcon:"LC",website:"https://longcat.chat",hasFree:!0,freeNote:"50M tokens/day (Flash-Lite) + 500K/day (Chat/Thinking) — 100% free while public beta"},pollinations:{id:"pollinations",alias:"pol",name:"Pollinations AI",icon:"local_florist",color:"#4CAF50",textIcon:"PO",website:"https://pollinations.ai",hasFree:!0,freeNote:"No API key needed — access GPT-5, Claude, Gemini, DeepSeek V3, Llama 4 free (1 req/15s)"},puter:{id:"puter",alias:"pu",name:"Puter AI",icon:"cloud_circle",color:"#6366F1",textIcon:"PU",website:"https://puter.com",hasFree:!0,freeNote:"500+ models (GPT-5, Claude Opus 4, Gemini 3 Pro, Grok 4, DeepSeek V3...) — Users pay via free Puter account",passthroughModels:!0,authHint:"Get token at puter.com/dashboard → Copy Auth Token"},"cloudflare-ai":{id:"cloudflare-ai",alias:"cf",name:"Cloudflare Workers AI",icon:"cloud",color:"#F48120",textIcon:"CF",website:"https://developers.cloudflare.com/workers-ai/",hasFree:!0,freeNote:"Free 10K Neurons/day: ~150 LLM responses or 500s Whisper audio — edge inference globally",authHint:"Requires API Token AND Account ID (found at dash.cloudflare.com)"},scaleway:{id:"scaleway",alias:"scw",name:"Scaleway AI",icon:"cloud",color:"#4F0599",textIcon:"SCW",website:"https://www.scaleway.com/en/ai/generative-apis/",hasFree:!0,freeNote:"1M free tokens for new accounts — EU/GDPR compliant (Paris), Qwen3 235B & Llama 70B"},aimlapi:{id:"aimlapi",alias:"aiml",name:"AI/ML API",icon:"hub",color:"#6366F1",textIcon:"AI",website:"https://aimlapi.com",hasFree:!0,freeNote:"$0.025/day free credits — 200+ models (GPT-4o, Claude, Gemini, Llama) via single endpoint",passthroughModels:!0},novita:{id:"novita",alias:"novita",name:"Novita AI",icon:"auto_awesome",color:"#FF4081",textIcon:"NV",website:"https://novita.ai",passthroughModels:!0},piapi:{id:"piapi",alias:"pi",name:"PiAPI",icon:"api",color:"#7C4DFF",textIcon:"PI",website:"https://piapi.ai",passthroughModels:!0},getgoapi:{id:"getgoapi",alias:"ggo",name:"GoAPI",icon:"rocket_launch",color:"#FF6D00",textIcon:"GO",website:"https://api.getgoapi.com",passthroughModels:!0},laozhang:{id:"laozhang",alias:"lz",name:"LaoZhang AI",icon:"hub",color:"#FF1744",textIcon:"LZ",website:"https://api.laozhang.ai",passthroughModels:!0}},l="openai-compatible-",c="anthropic-compatible-",d="anthropic-compatible-cc-",u={...o,...n,...s,cliproxyapi:{id:"cliproxyapi",alias:"cpa",name:"CLIProxyAPI",icon:"proxy",color:"#6366F1",textIcon:"CPA",website:"https://github.com/router-for-me/CLIProxyAPI",defaultPort:8317,healthEndpoint:"/v1/models",managementPrefix:"/v0/management",configDir:"~/.cli-proxy-api",binaryName:"cli-proxy-api",githubRepo:"router-for-me/CLIProxyAPI"}},p=Object.values(u).reduce((e,t)=>(t.alias&&(e[t.alias]=t.id),e),{});Object.values(u).reduce((e,t)=>(e[t.id]=t.alias||t.id,e),{}),(0,r.validateProviders)(o,"FREE_PROVIDERS"),(0,r.validateProviders)(n,"OAUTH_PROVIDERS"),(0,r.validateProviders)(s,"APIKEY_PROVIDERS"),e.s(["AI_PROVIDERS",0,u,"ALIAS_TO_ID",0,p,"ANTHROPIC_COMPATIBLE_PREFIX",0,c,"APIKEY_PROVIDERS",0,s,"CLAUDE_CODE_COMPATIBLE_PREFIX",0,d,"FREE_PROVIDERS",0,o,"OAUTH_PROVIDERS",0,n,"OPENAI_COMPATIBLE_PREFIX",0,l,"USAGE_SUPPORTED_PROVIDERS",0,["antigravity","gemini-cli","kiro","github","codex","claude","kimi-coding","glm"],"getProviderAlias",0,function(e){let t=u[e];return t?.alias||e},"isAnthropicCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(c)},"isClaudeCodeCompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(d)},"isOpenAICompatibleProvider",0,function(e){return"string"==typeof e&&e.startsWith(l)}]),a()}catch(e){a(e)}},!1),383368,e=>e.a(async(t,a)=>{try{var r=e.i(828059),i=e.i(693602),o=e.i(963219),n=e.i(679468),s=t([o]);[o]=s.then?(await s)():s;let P=new Set(["openai","openai-responses"]),C=new Set(["gemini","gemini-cli"]);function l(e){return(e||"").trim().replace(/\/$/,"")}function c(e){return{"Content-Type":"application/json",Authorization:`Bearer ${e}`}}async function d({provider:e,apiKey:t,baseUrl:a,providerSpecificData:r={},modelId:i="gpt-4o-mini",modelsUrl:n}){if(!a)return{valid:!1,error:"Missing base URL"};let s=n||function(e){let t=l(e);if(!t)return"";for(let e of["/chat/completions","/responses","/chat","/messages"])if(t.endsWith(e))return`${t.slice(0,-e.length)}/models`;return`${t}/models`}(a);if(!s)return{valid:!1,error:"Invalid models endpoint"};let u=await fetch(s,{method:"GET",headers:c(t)});if(u.ok)return{valid:!0,error:null};if(401===u.status||403===u.status)return{valid:!1,error:"Invalid API key"};let p=function(e,t,a={}){let r=l(t);return r?(0,o.isOpenAICompatibleProvider)(e)?a?.chatPath?`${r}${a.chatPath}`:a?.apiType==="responses"?`${r}/responses`:`${r}/chat/completions`:r.endsWith("/chat/completions")||r.endsWith("/responses")||r.endsWith("/chat")?r:r.endsWith("/v1")?`${r}/chat/completions`:r:""}(e,a,r);if(!p)return{valid:!1,error:`Validation failed: ${u.status}`};let h=r?.validationModelId||i,m=await fetch(p,{method:"POST",headers:c(t),body:JSON.stringify({model:h,messages:[{role:"user",content:"test"}],max_tokens:1})});return m.ok?{valid:!0,error:null}:401===m.status||403===m.status?{valid:!1,error:"Invalid API key"}:404===m.status||405===m.status?{valid:!1,error:"Provider validation endpoint not supported"}:m.status>=500?{valid:!1,error:`Provider unavailable (${m.status})`}:{valid:!0,error:null}}async function u({apiKey:e,baseUrl:t,modelId:a,headers:r={},providerSpecificData:i={}}){if(!t)return{valid:!1,error:"Missing base URL"};let o={"Content-Type":"application/json",...r};o["x-api-key"]||o["X-API-Key"]||(o["x-api-key"]=e),o["anthropic-version"]||o["Anthropic-Version"]||(o["anthropic-version"]="2023-06-01");let n=i?.validationModelId||a||"claude-3-5-sonnet-20241022",s=await fetch(t,{method:"POST",headers:o,body:JSON.stringify({model:n,max_tokens:1,messages:[{role:"user",content:"test"}]})});return 401===s.status||403===s.status?{valid:!1,error:"Invalid API key"}:{valid:!0,error:null}}async function p({apiKey:e,baseUrl:t}){if(!t)return{valid:!1,error:"Missing base URL"};let a=t.includes("?")?"&":"?",r=await fetch(`${t}${a}key=${encodeURIComponent(e)}`,{method:"GET",headers:{"Content-Type":"application/json"}});return r.ok?{valid:!0,error:null}:401===r.status||403===r.status?{valid:!1,error:"Invalid API key"}:{valid:!1,error:`Validation failed: ${r.status}`}}async function h({apiKey:e}){try{let t=await fetch("https://api.deepgram.com/v1/auth/token",{method:"GET",headers:{Authorization:`Token ${e}`}});if(t.ok)return{valid:!0,error:null};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!1,error:`Validation failed: ${t.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function m({apiKey:e}){try{let t=await fetch("https://api.assemblyai.com/v2/transcript?limit=1",{method:"GET",headers:{Authorization:e,"Content-Type":"application/json"}});if(t.ok)return{valid:!0,error:null};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!1,error:`Validation failed: ${t.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function v({apiKey:e}){try{let t=await fetch("https://api.nanobananaapi.ai/api/v1/nanobanana/generate",{method:"POST",headers:{Authorization:`Bearer ${e}`,"Content-Type":"application/json"},body:JSON.stringify({prompt:"test",model:"nanobanana-flash"})});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function f({apiKey:e}){try{let t=await fetch("https://api.elevenlabs.io/v1/voices",{method:"GET",headers:{"xi-api-key":e,"Content-Type":"application/json"}});if(t.ok)return{valid:!0,error:null};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!1,error:`Validation failed: ${t.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function y({apiKey:e}){try{let t=await fetch("https://api.inworld.ai/tts/v1/voice",{method:"POST",headers:{Authorization:`Basic ${e}`,"Content-Type":"application/json"},body:JSON.stringify({text:"test",modelId:"inworld-tts-1.5-mini",audioConfig:{audioEncoding:"MP3"}})});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function g({apiKey:e,providerSpecificData:t={}}){try{let a=l(t.baseUrl)||"https://coding-intl.dashscope.aliyuncs.com/apps/anthropic/v1",r=a.endsWith("/messages")?a.slice(0,-9):a,i=`${r}/messages`,o=await fetch(i,{method:"POST",headers:{"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01"},body:JSON.stringify({model:"qwen3-coder-plus",max_tokens:1,messages:[{role:"user",content:"test"}]})});if(401===o.status||403===o.status)return{valid:!1,error:"Invalid API key"};if(o.status>=400&&o.status<500||o.ok)return{valid:!0,error:null};return{valid:!1,error:`Validation failed: ${o.status}`}}catch(e){return{valid:!1,error:e.message||"Validation failed"}}}async function b({apiKey:e,providerSpecificData:t={}}){let a=l(t.baseUrl);if(!a)return{valid:!1,error:"No base URL configured for OpenAI compatible provider"};let r="string"==typeof t?.validationModelId?t.validationModelId.trim():"",i=!1;try{let t=await fetch(`${a}/models`,{method:"GET",headers:c(e)});if(i=!0,t.ok)return{valid:!0,error:null,method:"models_endpoint"};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};if(429===t.status)return{valid:!0,error:null,method:"models_endpoint",warning:"Rate limited, but credentials are valid"}}catch{}if(!r)return{valid:!1,error:"Endpoint /models unavailable. Provide a Model ID to validate via /chat/completions."};let o=t.apiType||"chat",n=`${a}${"responses"===o?"/responses":"/chat/completions"}`;try{let t=await fetch(n,{method:"POST",headers:c(e),body:JSON.stringify({model:r,messages:[{role:"user",content:"test"}],max_tokens:1})});if(t.ok)return{valid:!0,error:null,method:"chat_completions"};if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};if(429===t.status)return{valid:!0,error:null,method:"chat_completions",warning:"Rate limited, but credentials are valid"};if(400===t.status)return{valid:!0,error:null,method:"inference_available",warning:"Model ID may be invalid, but credentials are valid"};if(t.status>=400&&t.status<500)return{valid:!0,error:null,method:"inference_available"};if(t.status>=500)return{valid:!1,error:`Provider unavailable (${t.status})`}}catch{}if(!i)return{valid:!1,error:"Connection failed while testing /chat/completions"};try{let t=await fetch(a,{method:"GET",headers:c(e),signal:AbortSignal.timeout(5e3)});if(t.status<500)return{valid:!0,error:null};return{valid:!1,error:`Provider unavailable (${t.status})`}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}}async function x({apiKey:e,providerSpecificData:t={}}){var a;let r=(a=t.baseUrl,(0,i.stripAnthropicMessagesSuffix)(a||""));if(!r)return{valid:!1,error:"No base URL configured for Anthropic compatible provider"};let o={"Content-Type":"application/json","x-api-key":e,"anthropic-version":"2023-06-01",Authorization:`Bearer ${e}`};try{let e=await fetch((0,i.joinBaseUrlAndPath)(r,t?.modelsPath||"/models"),{method:"GET",headers:o});if(e.ok)return{valid:!0,error:null};if(401===e.status||403===e.status)return{valid:!1,error:"Invalid API key"}}catch{}let n=t?.validationModelId||"claude-3-5-sonnet-20241022";try{let e=await fetch((0,i.joinBaseUrlAndPath)(r,t?.chatPath||"/messages"),{method:"POST",headers:o,body:JSON.stringify({model:n,max_tokens:1,messages:[{role:"user",content:"test"}]})});if(401===e.status||403===e.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}}async function w({apiKey:e,providerSpecificData:t={}}){var a;let r=(a=t.baseUrl,(0,i.stripClaudeCodeCompatibleEndpointSuffix)(a||""));if(!r)return{valid:!1,error:"No base URL configured for CC Compatible provider"};let o=t?.modelsPath||i.CLAUDE_CODE_COMPATIBLE_DEFAULT_MODELS_PATH,n=t?.chatPath||i.CLAUDE_CODE_COMPATIBLE_DEFAULT_CHAT_PATH,s=(0,i.buildClaudeCodeCompatibleHeaders)(e,!1);try{let e=await fetch((0,i.joinClaudeCodeCompatibleUrl)(r,o),{method:"GET",headers:s});if(e.ok)return{valid:!0,error:null,method:"models_endpoint"};if(401===e.status||403===e.status)return{valid:!1,error:"Invalid API key"}}catch{}let l=(0,i.buildClaudeCodeCompatibleValidationPayload)(t?.validationModelId||"claude-sonnet-4-6"),c=JSON.parse(l.metadata.user_id).session_id;try{let t=await fetch((0,i.joinClaudeCodeCompatibleUrl)(r,n),{method:"POST",headers:(0,i.buildClaudeCodeCompatibleHeaders)(e,!0,c),body:JSON.stringify(l)});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};if(429===t.status)return{valid:!0,error:null,method:"cc_bridge_request",warning:"Rate limited, but credentials are valid"};if(t.status>=400&&t.status<500)return{valid:!0,error:null,method:"cc_bridge_request",warning:"Bridge request reached upstream, but the model or payload was rejected"};return{valid:t.ok,error:t.ok?null:`Validation failed: ${t.status}`,method:"cc_bridge_request"}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}}async function I(e,t){try{let a=await fetch(e,t);if(a.ok)return{valid:!0,error:null,unsupported:!1};if(401===a.status||403===a.status)return{valid:!1,error:"Invalid API key",unsupported:!1};if(a.status<500)return{valid:!0,error:null,unsupported:!1};return{valid:!1,error:`Validation failed: ${a.status}`,unsupported:!1}}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}}let k={"serper-search":e=>({url:"https://google.serper.dev/search",init:{method:"POST",headers:{"Content-Type":"application/json","X-API-Key":e},body:JSON.stringify({q:"test",num:1})}}),"brave-search":e=>({url:"https://api.search.brave.com/res/v1/web/search?q=test&count=1",init:{method:"GET",headers:{Accept:"application/json","X-Subscription-Token":e}}}),"perplexity-search":e=>({url:"https://api.perplexity.ai/search",init:{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e}`},body:JSON.stringify({query:"test",max_results:1})}}),"exa-search":e=>({url:"https://api.exa.ai/search",init:{method:"POST",headers:{"Content-Type":"application/json","x-api-key":e},body:JSON.stringify({query:"test",numResults:1})}}),"tavily-search":e=>({url:"https://api.tavily.com/search",init:{method:"POST",headers:{"Content-Type":"application/json",Authorization:`Bearer ${e}`},body:JSON.stringify({query:"test",max_results:1})}})};async function A({provider:e,apiKey:t,providerSpecificData:a={}}){if(!e||!t)return{valid:!1,error:"Provider and API key required",unsupported:!1};if((0,o.isOpenAICompatibleProvider)(e))try{return await b({apiKey:t,providerSpecificData:a})}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}if((0,o.isAnthropicCompatibleProvider)(e))try{if((0,o.isClaudeCodeCompatibleProvider)(e))return await w({apiKey:t,providerSpecificData:a});return await x({apiKey:t,providerSpecificData:a})}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}let i={qoder:({apiKey:e,providerSpecificData:t})=>(0,n.validateQoderCliPat)({apiKey:e,providerSpecificData:t}),deepgram:h,assemblyai:m,nanobanana:v,elevenlabs:f,inworld:y,"bailian-coding-plan":g,longcat:async({apiKey:e})=>{try{let t=await fetch("https://api.longcat.chat/openai/v1/chat/completions",{method:"POST",headers:c(e),body:JSON.stringify({model:"longcat",messages:[{role:"user",content:"test"}],max_tokens:1})});if(401===t.status||403===t.status)return{valid:!1,error:"Invalid API key"};return{valid:!0,error:null}}catch(e){return{valid:!1,error:e.message||"Connection failed"}}},...Object.fromEntries(Object.entries(k).map(([e,t])=>[e,({apiKey:e})=>{let{url:a,init:r}=t(e);return I(a,r)}]))};if(i[e])try{return await i[e]({apiKey:t,providerSpecificData:a})}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}let s=(0,r.getRegistryEntry)(e);if(!s)return{valid:!1,error:"Provider validation not supported",unsupported:!0};let _=s.models?.[0]?.id||null,R=s.testKeyBaseUrl?{...s,baseUrl:s.testKeyBaseUrl}:s,E=function(e,t={}){return t?.baseUrl?l(t.baseUrl):e?.baseUrl?l(e.baseUrl):""}(R,a);try{if(P.has(s.format))return await d({provider:e,apiKey:t,baseUrl:E,providerSpecificData:a,modelId:_,modelsUrl:s.modelsUrl});if("claude"===s.format){let e=`${E}${s.urlSuffix||""}`,r={...s.headers||{}};return"x-api-key"===(s.authHeader||"").toLowerCase()?r["x-api-key"]=t:r.Authorization=`Bearer ${t}`,await u({apiKey:t,baseUrl:e,modelId:_,headers:r,providerSpecificData:a})}if(C.has(s.format))return await p({apiKey:t,baseUrl:E});return{valid:!1,error:"Provider validation not supported",unsupported:!0}}catch(e){return{valid:!1,error:e.message||"Validation failed",unsupported:!1}}}e.s(["validateClaudeCodeCompatibleProvider",0,w,"validateProviderApiKey",0,A]),a()}catch(e){a(e)}},!1),851380,e=>e.a(async(t,a)=>{try{var r=e.i(89171);e.i(180725);var i=e.i(385498),o=e.i(963219),n=e.i(383368),s=e.i(676088),l=e.i(200392),c=t([o,n,s,l]);async function d(e){let t;try{t=await e.json()}catch{return r.NextResponse.json({error:{message:"Invalid request",details:[{field:"body",message:"Invalid JSON body"}]}},{status:400})}try{let e=(0,l.validateBody)(s.validateProviderApiKeySchema,t);if((0,l.isValidationFailure)(e))return r.NextResponse.json({error:e.error},{status:400});let{provider:a,apiKey:c,validationModelId:d}=e.data,u={validationModelId:d};if((0,o.isOpenAICompatibleProvider)(a)||(0,o.isAnthropicCompatibleProvider)(a)){let e=await (0,i.getProviderNodeById)(a);if(!e){let e=(0,o.isOpenAICompatibleProvider)(a)?"OpenAI":(0,o.isClaudeCodeCompatibleProvider)(a)?"CC":"Anthropic";return r.NextResponse.json({error:`${e} Compatible node not found`},{status:404})}u={...u,baseUrl:e.baseUrl,apiType:e.apiType,chatPath:e.chatPath,modelsPath:e.modelsPath}}let p=await (0,n.validateProviderApiKey)({provider:a,apiKey:c,providerSpecificData:u});if(p.unsupported)return r.NextResponse.json({error:"Provider validation not supported"},{status:400});return r.NextResponse.json({valid:!!p.valid,error:p.valid?null:p.error||"Invalid API key",warning:p.warning||null,method:p.method||null})}catch(e){return console.log("Error validating API key:",e),r.NextResponse.json({error:"Validation failed"},{status:500})}}[o,n,s,l]=c.then?(await c)():c,e.s(["POST",0,d]),a()}catch(e){a(e)}},!1),477929,e=>e.a(async(t,a)=>{try{var r=e.i(747909),i=e.i(174017),o=e.i(996250),n=e.i(759756),s=e.i(561916),l=e.i(174677),c=e.i(869741),d=e.i(316795),u=e.i(487718),p=e.i(995169),h=e.i(47587),m=e.i(666012),v=e.i(570101),f=e.i(626937),y=e.i(10372),g=e.i(193695);e.i(820232);var b=e.i(600220),x=e.i(851380),w=t([x]);[x]=w.then?(await w)():w;let A=new r.AppRouteRouteModule({definition:{kind:i.RouteKind.APP_ROUTE,page:"/api/providers/validate/route",pathname:"/api/providers/validate",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/providers/validate/route.ts",nextConfigOutput:"standalone",userland:x,...{}}),{workAsyncStorage:P,workUnitAsyncStorage:C,serverHooks:k}=A;async function I(e,t,a){a.requestMeta&&(0,n.setRequestMeta)(e,a.requestMeta),A.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let r="/api/providers/validate/route";r=r.replace(/\/index$/,"")||"/";let o=await A.prepare(e,t,{srcPage:r,multiZoneDraftMode:!1});if(!o)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:x,params:w,nextConfig:I,parsedUrl:P,isDraftMode:C,prerenderManifest:k,routerServerContext:_,isOnDemandRevalidate:R,revalidateOnlyGenerated:E,resolvedPathname:F,clientReferenceManifest:S,serverActionsManifest:O}=o,T=(0,c.normalizeAppPath)(r),D=!!(k.dynamicRoutes[T]||k.routes[F]),N=async()=>((null==_?void 0:_.render404)?await _.render404(e,t,P,!1):t.end("This page could not be found"),null);if(D&&!C){let e=!!k.routes[F],t=k.dynamicRoutes[T];if(t&&!1===t.fallback&&!e){if(I.adapterPath)return await N();throw new g.NoFallbackError}}let M=null;!D||A.isDev||C||(M=F,M="/index"===M?"/":M);let $=!0===A.isDev||!D,j=D&&!$;O&&S&&(0,l.setManifestsSingleton)({page:r,clientReferenceManifest:S,serverActionsManifest:O});let B=e.method||"GET",U=(0,s.getTracer)(),q=U.getActiveScopeSpan(),L=!!(null==_?void 0:_.isWrappedByNextServer),V=!!(0,n.getRequestMeta)(e,"minimalMode"),z=(0,n.getRequestMeta)(e,"incrementalCache")||await A.getIncrementalCache(e,I,k,V);null==z||z.resetRequestCache(),globalThis.__incrementalCache=z;let G={params:w,previewProps:k.preview,renderOpts:{experimental:{authInterrupts:!!I.experimental.authInterrupts},cacheComponents:!!I.cacheComponents,supportsDynamicResponse:$,incrementalCache:z,cacheLifeProfiles:I.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,r,i)=>A.onRequestError(e,t,r,i,_)},sharedContext:{buildId:x}},H=new d.NodeNextRequest(e),K=new d.NodeNextResponse(t),W=u.NextRequestAdapter.fromNodeNextRequest(H,(0,u.signalFromNodeResponse)(t));try{let o,n=async e=>A.handle(W,G).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=U.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==p.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let i=a.get("next.route");if(i){let t=`${B} ${i}`;e.setAttributes({"next.route":i,"http.route":i,"next.span_name":t}),e.updateName(t),o&&o!==e&&(o.setAttribute("http.route",i),o.updateName(t))}else e.updateName(`${B} ${r}`)}),l=async o=>{var s,l;let c=async({previousCacheEntry:i})=>{try{if(!V&&R&&E&&!i)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let r=await n(o);e.fetchMetrics=G.renderOpts.fetchMetrics;let s=G.renderOpts.pendingWaitUntil;s&&a.waitUntil&&(a.waitUntil(s),s=void 0);let l=G.renderOpts.collectedTags;if(!D)return await (0,m.sendResponse)(H,K,r,G.renderOpts.pendingWaitUntil),null;{let e=await r.blob(),t=(0,v.toNodeOutgoingHttpHeaders)(r.headers);l&&(t[y.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==G.renderOpts.collectedRevalidate&&!(G.renderOpts.collectedRevalidate>=y.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,i=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=y.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:b.CachedRouteKind.APP_ROUTE,status:r.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:i}}}}catch(t){throw(null==i?void 0:i.isStale)&&await A.onRequestError(e,t,{routerKind:"App Router",routePath:r,routeType:"route",revalidateReason:(0,h.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:R})},!1,_),t}},d=await A.handleResponse({req:e,nextConfig:I,cacheKey:M,routeKind:i.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:k,isRoutePPREnabled:!1,isOnDemandRevalidate:R,revalidateOnlyGenerated:E,responseGenerator:c,waitUntil:a.waitUntil,isMinimalMode:V});if(!D)return null;if((null==d||null==(s=d.value)?void 0:s.kind)!==b.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==d||null==(l=d.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});V||t.setHeader("x-nextjs-cache",R?"REVALIDATED":d.isMiss?"MISS":d.isStale?"STALE":"HIT"),C&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let u=(0,v.fromNodeOutgoingHttpHeaders)(d.value.headers);return V&&D||u.delete(y.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,m.sendResponse)(H,K,new Response(d.value.body,{headers:u,status:d.value.status||200})),null};L&&q?await l(q):(o=U.getActiveScopeSpan(),await U.withPropagatedContext(e.headers,()=>U.trace(p.BaseServerSpan.handleRequest,{spanName:`${B} ${r}`,kind:s.SpanKind.SERVER,attributes:{"http.method":B,"http.target":e.url}},l),void 0,!L))}catch(t){if(t instanceof g.NoFallbackError||await A.onRequestError(e,t,{routerKind:"App Router",routePath:T,routeType:"route",revalidateReason:(0,h.getRevalidateReason)({isStaticGeneration:j,isOnDemandRevalidate:R})},!1,_),D)throw t;return await (0,m.sendResponse)(H,K,new Response(null,{status:500})),null}}e.s(["handler",0,I,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:P,workUnitAsyncStorage:C})},"routeModule",0,A,"serverHooks",0,k,"workAsyncStorage",0,P,"workUnitAsyncStorage",0,C]),a()}catch(e){a(e)}},!1),606102,e=>{e.v(e=>Promise.resolve().then(()=>e(548941)))},789543,e=>{e.v(e=>Promise.resolve().then(()=>e(385498)))},579042,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_utils_apiKey_ts_12~h.oz._.js"].map(t=>e.l(t))).then(()=>t(65448)))},49794,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_ts_0hk12it._.js"].map(t=>e.l(t))).then(()=>t(404503)))},386305,e=>{e.v(e=>Promise.resolve().then(()=>e(878947)))}];
|
|
3
3
|
|
|
4
4
|
//# sourceMappingURL=%5Broot-of-the-server%5D__0llqbda._.js.map
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
module.exports=[677850,e=>e.a(async(t,r)=>{try{let t=await e.y("zod");e.n(t),r()}catch(e){r(e)}},!0),200392,e=>e.a(async(t,r)=>{try{var a=e.i(677850),i=t([a]);[a]=i.then?(await i)():i,a.z.object({password:a.z.string().min(1,"Password is required").max(200)}),e.s(["isValidationFailure",0,function(e){return!1===e.success},"validateBody",0,function(e,t){let r=e.safeParse(t);if(r.success)return{success:!0,data:r.data};let a=Array.isArray(r.error?.issues)?r.error.issues:[];return{success:!1,error:{message:"Invalid request",details:a.map(e=>({field:e.path.join("."),message:e.message}))}}}]),r()}catch(e){r(e)}},!1),41244,e=>{"use strict";e.s(["HIDEABLE_SIDEBAR_ITEM_IDS",0,["home","endpoints","api-manager","providers","combos","auto-combo","costs","analytics","limits","cache","cli-tools","agents","translator","playground","media","search-tools","health","logs","audit","settings","docs","issues"]])},224361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},224010,e=>{"use strict";let t=process.env.CORS_ORIGIN||"*";e.s(["CORS_HEADERS",0,{"Access-Control-Allow-Origin":t,"Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type, Authorization, x-api-key, anthropic-version"},"CORS_ORIGIN",0,t])},249157,e=>{"use strict";var t=e.i(706901),r=e.i(161002);e.s(["debug",()=>t.debug,"error",()=>t.error,"info",()=>t.info,"maskKey",()=>r.maskKey,"request",()=>t.request,"response",()=>t.response,"stream",()=>t.stream,"warn",()=>t.warn])},573344,e=>{"use strict";let t={openai:{id:"openai",baseUrl:"https://api.openai.com/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"gpt-image-1",name:"GPT Image 1"},{id:"dall-e-3",name:"DALL-E 3"},{id:"dall-e-2",name:"DALL-E 2"}],supportedSizes:["1024x1024","1024x1792","1792x1024","256x256","512x512"]},xai:{id:"xai",baseUrl:"https://api.x.ai/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"grok-2-image-1212",name:"Grok 2 Image"}],supportedSizes:["1024x1024"]},together:{id:"together",baseUrl:"https://api.together.xyz/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"black-forest-labs/FLUX.1.1-pro",name:"FLUX 1.1 Pro"},{id:"black-forest-labs/FLUX.1-schnell-Free",name:"FLUX 1 Schnell (Free)"},{id:"stabilityai/stable-diffusion-xl-base-1.0",name:"SDXL Base 1.0"}],supportedSizes:["1024x1024","512x512"]},fireworks:{id:"fireworks",baseUrl:"https://api.fireworks.ai/inference/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"accounts/fireworks/models/flux-1-dev-fp8",name:"FLUX 1 Dev FP8"},{id:"accounts/fireworks/models/stable-diffusion-xl-1024-v1-0",name:"SDXL 1024 v1.0"}],supportedSizes:["1024x1024","512x512"]},antigravity:{id:"antigravity",baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",authType:"oauth",authHeader:"bearer",format:"gemini-image",models:[],supportedSizes:["1024x1024"]},nebius:{id:"nebius",baseUrl:"https://api.tokenfactory.nebius.com/v1/images/generations",fallbackUrl:"https://api.studio.nebius.com/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"black-forest-labs/flux-schnell",name:"FLUX.1 Schnell"},{id:"black-forest-labs/flux-dev",name:"FLUX.1 Dev"}],supportedSizes:["1024x1024","512x512"]},hyperbolic:{id:"hyperbolic",baseUrl:"https://api.hyperbolic.xyz/v1/image/generation",authType:"apikey",authHeader:"bearer",format:"hyperbolic",models:[{id:"SDXL1.0-base",name:"SDXL 1.0 Base"},{id:"SD2",name:"Stable Diffusion 2"},{id:"FLUX.1-dev",name:"FLUX.1 Dev"}],supportedSizes:["1024x1024","512x512"]},nanobanana:{id:"nanobanana",baseUrl:"https://api.nanobananaapi.ai/api/v1/nanobanana/generate",proUrl:"https://api.nanobananaapi.ai/api/v1/nanobanana/generate-pro",statusUrl:"https://api.nanobananaapi.ai/api/v1/nanobanana/record-info",authType:"apikey",authHeader:"bearer",format:"nanobanana",models:[{id:"nanobanana-flash",name:"NanoBanana Flash (Gemini 2.5 Flash)"},{id:"nanobanana-pro",name:"NanoBanana Pro (Gemini 3 Pro)"}],supportedSizes:["1024x1024","1024x1280","1024x1536","1536x1024","1280x1024"]},sdwebui:{id:"sdwebui",baseUrl:"http://localhost:7860/sdapi/v1/txt2img",authType:"none",authHeader:"none",format:"sdwebui",models:[{id:"stable-diffusion-v1-5",name:"Stable Diffusion v1.5"},{id:"sdxl-base-1.0",name:"SDXL Base 1.0"}],supportedSizes:["512x512","768x768","1024x1024"]},comfyui:{id:"comfyui",baseUrl:"http://localhost:8188",authType:"none",authHeader:"none",format:"comfyui",models:[{id:"flux-dev",name:"FLUX Dev"},{id:"sdxl",name:"SDXL"}],supportedSizes:["512x512","768x768","1024x1024"]}};e.s(["getAllImageModels",0,function(){let e=[];for(let[r,a]of Object.entries(t))for(let t of a.models)e.push({id:`${r}/${t.id}`,name:t.name,provider:r,supportedSizes:a.supportedSizes});return e},"getImageProvider",0,function(e){return t[e]||null},"parseImageModel",0,function(e){if(!e)return{provider:null,model:null};for(let[r,a]of Object.entries(t))if(e.startsWith(r+"/"))return{provider:r,model:e.slice(r.length+1)};for(let[r,a]of Object.entries(t))if(a.models.some(t=>t.id===e))return{provider:r,model:e};return{provider:null,model:e}}])},740512,e=>{"use strict";e.s(["toJsonErrorPayload",0,function e(t,r="Upstream provider error"){let a={error:{message:r,type:"upstream_error",code:"upstream_error"}};if(t&&"object"==typeof t){let e=t.error;return"string"==typeof e?{error:{message:e,type:"upstream_error",code:"upstream_error"}}:e&&"object"==typeof e?t:{error:t}}if("string"==typeof t){let i=t.trim();if(!i)return a;try{let t=JSON.parse(i);return e(t,r)}catch{return{error:{message:i,type:"upstream_error",code:"upstream_error"}}}}return a}])},333974,e=>{"use strict";function t(e){return e&&"object"==typeof e&&!Array.isArray(e)?e:{}}async function r(e,r){let a=await fetch(`${e}/prompt`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:r})});if(!a.ok){let e=await a.text();throw Error(`ComfyUI submit failed (${a.status}): ${e}`)}let i=t(await a.json()).prompt_id;if("string"!=typeof i||!i)throw Error("ComfyUI submit failed: missing prompt_id");return i}async function a(e,r,i=12e4){let o=Date.now();for(;Date.now()-o<i;){await new Promise(e=>setTimeout(e,2e3));let a=await fetch(`${e}/history/${r}`);if(!a.ok)continue;let i=t(await a.json()),o=t(i[r]);if(o&&o.outputs&&Object.keys(o.outputs).length>0)return o}throw Error(`ComfyUI prompt ${r} timed out after ${i}ms`)}async function i(e,t,r,a){let i=new URL(`${e}/view`);i.searchParams.set("filename",t),i.searchParams.set("subfolder",r),i.searchParams.set("type",a);let o=await fetch(i.toString());if(!o.ok)throw Error(`ComfyUI fetch output failed (${o.status})`);return o.arrayBuffer()}e.s(["extractComfyOutputFiles",0,function(e){let t=[];for(let r of Object.values(e.outputs||{}))for(let e of r.images||r.gifs||r.audio||[])t.push({filename:e.filename,subfolder:e.subfolder||"",type:e.type||"output"});return t},"fetchComfyOutput",0,i,"pollComfyResult",0,a,"submitComfyWorkflow",0,r])},416726,e=>e.a(async(t,r)=>{try{var a=e.i(224010),i=e.i(671528),o=e.i(287726),s=e.i(573344),n=e.i(719201),l=e.i(16023),d=e.i(706901),u=e.i(249157),p=e.i(740512),c=e.i(478847),m=e.i(676088),f=e.i(200392);e.i(245272);var h=e.i(186920),y=t([i,m,f]);async function g(){return new Response(null,{headers:{"Access-Control-Allow-Origin":a.CORS_ORIGIN,"Access-Control-Allow-Methods":"GET, POST, OPTIONS","Access-Control-Allow-Headers":"*"}})}async function v(){let e=(0,s.getAllImageModels)(),t=Math.floor(Date.now()/1e3),r=e.map(e=>({id:e.id,object:"model",created:t,owned_by:e.provider,type:"image",supported_sizes:e.supportedSizes}));try{let e=await (0,h.getAllCustomModels)();for(let[a,i]of Object.entries(e))if(Array.isArray(i))for(let e of i){if(!e?.id||!Array.isArray(e.supportedEndpoints)||!e.supportedEndpoints.includes("images"))continue;let i=`${a}/${e.id}`;r.some(e=>e.id===i)||r.push({id:i,object:"model",created:t,owned_by:a,type:"image",supported_sizes:null})}}catch{}return new Response(JSON.stringify({object:"list",data:r}),{headers:{"Content-Type":"application/json"}})}async function b(e){let t;try{t=await e.json()}catch{return d.warn("IMAGE","Invalid JSON body"),(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,"Invalid JSON body")}let r=(0,f.validateBody)(m.v1ImageGenerationSchema,t);if((0,f.isValidationFailure)(r))return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,r.error.message);let a=r.data;if("true"===process.env.REQUIRE_API_KEY){let t=(0,o.extractApiKey)(e);if(!t)return(0,n.errorResponse)(l.HTTP_STATUS.UNAUTHORIZED,"Missing API key");if(!await (0,o.isValidApiKey)(t))return(0,n.errorResponse)(l.HTTP_STATUS.UNAUTHORIZED,"Invalid API key")}let y=await (0,c.enforceApiKeyPolicy)(e,a.model);if(y.rejection)return y.rejection;let{provider:g}=(0,s.parseImageModel)(a.model),v=!1;if(!g)try{let e=await (0,h.getAllCustomModels)();for(let[t,r]of Object.entries(e))if(Array.isArray(r)){for(let e of r)if(e?.id&&Array.isArray(e.supportedEndpoints)&&e.supportedEndpoints.includes("images")&&`${t}/${e.id}`===a.model){g=t,v=!0;break}if(g)break}}catch{}if(!g)return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,`Invalid image model: ${a.model}. Use format: provider/model`);let b=(0,s.getImageProvider)(g),T=null;if(b&&"none"!==b.authType){if(!(T=await (0,o.getProviderCredentials)(g)))return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,`No credentials for image provider: ${g}`);if(T.allRateLimited)return(0,n.unavailableResponse)(l.HTTP_STATUS.RATE_LIMITED,`[${g}] All accounts rate limited`,T.retryAfter,T.retryAfterHuman)}else if(v){if(!(T=await (0,o.getProviderCredentials)(g)))return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,`No credentials for custom image provider: ${g}`);if(T.allRateLimited)return(0,n.unavailableResponse)(l.HTTP_STATUS.RATE_LIMITED,`[${g}] All accounts rate limited`,T.retryAfter,T.retryAfterHuman)}let R=await (0,i.handleImageGeneration)({body:a,credentials:T,log:u,...v&&{resolvedProvider:g}});if(R.success)return await (0,o.clearRecoveredProviderState)(T),new Response(JSON.stringify(R.data),{status:200,headers:{"Content-Type":"application/json"}});let A=(0,p.toJsonErrorPayload)(R.error,"Image generation provider error");return new Response(JSON.stringify(A),{status:R.status,headers:{"Content-Type":"application/json"}})}[i,m,f]=y.then?(await y)():y,e.s(["GET",0,v,"OPTIONS",0,g,"POST",0,b]),r()}catch(e){r(e)}},!1),463168,e=>e.a(async(t,r)=>{try{var a=e.i(747909),i=e.i(174017),o=e.i(996250),s=e.i(759756),n=e.i(561916),l=e.i(174677),d=e.i(869741),u=e.i(316795),p=e.i(487718),c=e.i(995169),m=e.i(47587),f=e.i(666012),h=e.i(570101),y=e.i(626937),g=e.i(10372),v=e.i(193695);e.i(820232);var b=e.i(600220),T=e.i(416726),R=t([T]);[T]=R.then?(await R)():R;let w=new a.AppRouteRouteModule({definition:{kind:i.RouteKind.APP_ROUTE,page:"/api/v1/images/generations/route",pathname:"/api/v1/images/generations",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/v1/images/generations/route.ts",nextConfigOutput:"standalone",userland:T,...{}}),{workAsyncStorage:S,workUnitAsyncStorage:E,serverHooks:x}=w;async function A(e,t,r){r.requestMeta&&(0,s.setRequestMeta)(e,r.requestMeta),w.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let a="/api/v1/images/generations/route";a=a.replace(/\/index$/,"")||"/";let o=await w.prepare(e,t,{srcPage:a,multiZoneDraftMode:!1});if(!o)return t.statusCode=400,t.end("Bad Request"),null==r.waitUntil||r.waitUntil.call(r,Promise.resolve()),null;let{buildId:T,params:R,nextConfig:A,parsedUrl:S,isDraftMode:E,prerenderManifest:x,routerServerContext:_,isOnDemandRevalidate:P,revalidateOnlyGenerated:U,resolvedPathname:C,clientReferenceManifest:I,serverActionsManifest:O}=o,k=(0,d.normalizeAppPath)(a),D=!!(x.dynamicRoutes[k]||x.routes[C]),H=async()=>((null==_?void 0:_.render404)?await _.render404(e,t,S,!1):t.end("This page could not be found"),null);if(D&&!E){let e=!!x.routes[C],t=x.dynamicRoutes[k];if(t&&!1===t.fallback&&!e){if(A.adapterPath)return await H();throw new v.NoFallbackError}}let N=null;!D||w.isDev||E||(N=C,N="/index"===N?"/":N);let j=!0===w.isDev||!D,L=D&&!j;O&&I&&(0,l.setManifestsSingleton)({page:a,clientReferenceManifest:I,serverActionsManifest:O});let M=e.method||"GET",$=(0,n.getTracer)(),F=$.getActiveScopeSpan(),q=!!(null==_?void 0:_.isWrappedByNextServer),z=!!(0,s.getRequestMeta)(e,"minimalMode"),B=(0,s.getRequestMeta)(e,"incrementalCache")||await w.getIncrementalCache(e,A,x,z);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let X={params:R,previewProps:x.preview,renderOpts:{experimental:{authInterrupts:!!A.experimental.authInterrupts},cacheComponents:!!A.cacheComponents,supportsDynamicResponse:j,incrementalCache:B,cacheLifeProfiles:A.cacheLife,waitUntil:r.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,i)=>w.onRequestError(e,t,a,i,_)},sharedContext:{buildId:T}},G=new u.NodeNextRequest(e),K=new u.NodeNextResponse(t),J=p.NextRequestAdapter.fromNodeNextRequest(G,(0,p.signalFromNodeResponse)(t));try{let o,s=async e=>w.handle(J,X).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=$.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==c.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 i=r.get("next.route");if(i){let t=`${M} ${i}`;e.setAttributes({"next.route":i,"http.route":i,"next.span_name":t}),e.updateName(t),o&&o!==e&&(o.setAttribute("http.route",i),o.updateName(t))}else e.updateName(`${M} ${a}`)}),l=async o=>{var n,l;let d=async({previousCacheEntry:i})=>{try{if(!z&&P&&U&&!i)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await s(o);e.fetchMetrics=X.renderOpts.fetchMetrics;let n=X.renderOpts.pendingWaitUntil;n&&r.waitUntil&&(r.waitUntil(n),n=void 0);let l=X.renderOpts.collectedTags;if(!D)return await (0,f.sendResponse)(G,K,a,X.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(a.headers);l&&(t[g.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==X.renderOpts.collectedRevalidate&&!(X.renderOpts.collectedRevalidate>=g.INFINITE_CACHE)&&X.renderOpts.collectedRevalidate,i=void 0===X.renderOpts.collectedExpire||X.renderOpts.collectedExpire>=g.INFINITE_CACHE?void 0:X.renderOpts.collectedExpire;return{value:{kind:b.CachedRouteKind.APP_ROUTE,status:a.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:i}}}}catch(t){throw(null==i?void 0:i.isStale)&&await w.onRequestError(e,t,{routerKind:"App Router",routePath:a,routeType:"route",revalidateReason:(0,m.getRevalidateReason)({isStaticGeneration:L,isOnDemandRevalidate:P})},!1,_),t}},u=await w.handleResponse({req:e,nextConfig:A,cacheKey:N,routeKind:i.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:x,isRoutePPREnabled:!1,isOnDemandRevalidate:P,revalidateOnlyGenerated:U,responseGenerator:d,waitUntil:r.waitUntil,isMinimalMode:z});if(!D)return null;if((null==u||null==(n=u.value)?void 0:n.kind)!==b.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",P?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let p=(0,h.fromNodeOutgoingHttpHeaders)(u.value.headers);return z&&D||p.delete(g.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||p.get("Cache-Control")||p.set("Cache-Control",(0,y.getCacheControlHeader)(u.cacheControl)),await (0,f.sendResponse)(G,K,new Response(u.value.body,{headers:p,status:u.value.status||200})),null};q&&F?await l(F):(o=$.getActiveScopeSpan(),await $.withPropagatedContext(e.headers,()=>$.trace(c.BaseServerSpan.handleRequest,{spanName:`${M} ${a}`,kind:n.SpanKind.SERVER,attributes:{"http.method":M,"http.target":e.url}},l),void 0,!q))}catch(t){if(t instanceof v.NoFallbackError||await w.onRequestError(e,t,{routerKind:"App Router",routePath:k,routeType:"route",revalidateReason:(0,m.getRevalidateReason)({isStaticGeneration:L,isOnDemandRevalidate:P})},!1,_),D)throw t;return await (0,f.sendResponse)(G,K,new Response(null,{status:500})),null}}e.s(["handler",0,A,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:E})},"routeModule",0,w,"serverHooks",0,x,"workAsyncStorage",0,S,"workUnitAsyncStorage",0,E]),r()}catch(e){r(e)}},!1),605589,e=>{e.v(t=>Promise.all(["server/chunks/src_lib_localDb_ts_0ml5l_h._.js"].map(t=>e.l(t))).then(()=>t(969738)))},606102,e=>{e.v(e=>Promise.resolve().then(()=>e(548941)))},789543,e=>{e.v(e=>Promise.resolve().then(()=>e(385498)))},49794,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_ts_0hk12it._.js"].map(t=>e.l(t))).then(()=>t(404503)))},386305,e=>{e.v(e=>Promise.resolve().then(()=>e(878947)))},579042,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_utils_apiKey_ts_12~h.oz._.js"].map(t=>e.l(t))).then(()=>t(65448)))}];
|
|
1
|
+
module.exports=[677850,e=>e.a(async(t,r)=>{try{let t=await e.y("zod");e.n(t),r()}catch(e){r(e)}},!0),200392,e=>e.a(async(t,r)=>{try{var a=e.i(677850),i=t([a]);[a]=i.then?(await i)():i,a.z.object({password:a.z.string().min(1,"Password is required").max(200)}),e.s(["isValidationFailure",0,function(e){return!1===e.success},"validateBody",0,function(e,t){let r=e.safeParse(t);if(r.success)return{success:!0,data:r.data};let a=Array.isArray(r.error?.issues)?r.error.issues:[];return{success:!1,error:{message:"Invalid request",details:a.map(e=>({field:e.path.join("."),message:e.message}))}}}]),r()}catch(e){r(e)}},!1),41244,e=>{"use strict";e.s(["HIDEABLE_SIDEBAR_ITEM_IDS",0,["home","endpoints","api-manager","providers","combos","auto-combo","costs","analytics","limits","cache","cli-tools","agents","memory","skills","translator","playground","media","search-tools","health","logs","audit","settings","docs","issues"]])},224361,(e,t,r)=>{t.exports=e.x("util",()=>require("util"))},224010,e=>{"use strict";let t=process.env.CORS_ORIGIN||"*";e.s(["CORS_HEADERS",0,{"Access-Control-Allow-Origin":t,"Access-Control-Allow-Methods":"GET, POST, PUT, DELETE, OPTIONS","Access-Control-Allow-Headers":"Content-Type, Authorization, x-api-key, anthropic-version"},"CORS_ORIGIN",0,t])},249157,e=>{"use strict";var t=e.i(706901),r=e.i(161002);e.s(["debug",()=>t.debug,"error",()=>t.error,"info",()=>t.info,"maskKey",()=>r.maskKey,"request",()=>t.request,"response",()=>t.response,"stream",()=>t.stream,"warn",()=>t.warn])},573344,e=>{"use strict";let t={openai:{id:"openai",baseUrl:"https://api.openai.com/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"gpt-image-1",name:"GPT Image 1"},{id:"dall-e-3",name:"DALL-E 3"},{id:"dall-e-2",name:"DALL-E 2"}],supportedSizes:["1024x1024","1024x1792","1792x1024","256x256","512x512"]},xai:{id:"xai",baseUrl:"https://api.x.ai/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"grok-2-image-1212",name:"Grok 2 Image"}],supportedSizes:["1024x1024"]},together:{id:"together",baseUrl:"https://api.together.xyz/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"black-forest-labs/FLUX.1.1-pro",name:"FLUX 1.1 Pro"},{id:"black-forest-labs/FLUX.1-schnell-Free",name:"FLUX 1 Schnell (Free)"},{id:"stabilityai/stable-diffusion-xl-base-1.0",name:"SDXL Base 1.0"}],supportedSizes:["1024x1024","512x512"]},fireworks:{id:"fireworks",baseUrl:"https://api.fireworks.ai/inference/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"accounts/fireworks/models/flux-1-dev-fp8",name:"FLUX 1 Dev FP8"},{id:"accounts/fireworks/models/stable-diffusion-xl-1024-v1-0",name:"SDXL 1024 v1.0"}],supportedSizes:["1024x1024","512x512"]},antigravity:{id:"antigravity",baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",authType:"oauth",authHeader:"bearer",format:"gemini-image",models:[],supportedSizes:["1024x1024"]},nebius:{id:"nebius",baseUrl:"https://api.tokenfactory.nebius.com/v1/images/generations",fallbackUrl:"https://api.studio.nebius.com/v1/images/generations",authType:"apikey",authHeader:"bearer",format:"openai",models:[{id:"black-forest-labs/flux-schnell",name:"FLUX.1 Schnell"},{id:"black-forest-labs/flux-dev",name:"FLUX.1 Dev"}],supportedSizes:["1024x1024","512x512"]},hyperbolic:{id:"hyperbolic",baseUrl:"https://api.hyperbolic.xyz/v1/image/generation",authType:"apikey",authHeader:"bearer",format:"hyperbolic",models:[{id:"SDXL1.0-base",name:"SDXL 1.0 Base"},{id:"SD2",name:"Stable Diffusion 2"},{id:"FLUX.1-dev",name:"FLUX.1 Dev"}],supportedSizes:["1024x1024","512x512"]},nanobanana:{id:"nanobanana",baseUrl:"https://api.nanobananaapi.ai/api/v1/nanobanana/generate",proUrl:"https://api.nanobananaapi.ai/api/v1/nanobanana/generate-pro",statusUrl:"https://api.nanobananaapi.ai/api/v1/nanobanana/record-info",authType:"apikey",authHeader:"bearer",format:"nanobanana",models:[{id:"nanobanana-flash",name:"NanoBanana Flash (Gemini 2.5 Flash)"},{id:"nanobanana-pro",name:"NanoBanana Pro (Gemini 3 Pro)"}],supportedSizes:["1024x1024","1024x1280","1024x1536","1536x1024","1280x1024"]},sdwebui:{id:"sdwebui",baseUrl:"http://localhost:7860/sdapi/v1/txt2img",authType:"none",authHeader:"none",format:"sdwebui",models:[{id:"stable-diffusion-v1-5",name:"Stable Diffusion v1.5"},{id:"sdxl-base-1.0",name:"SDXL Base 1.0"}],supportedSizes:["512x512","768x768","1024x1024"]},comfyui:{id:"comfyui",baseUrl:"http://localhost:8188",authType:"none",authHeader:"none",format:"comfyui",models:[{id:"flux-dev",name:"FLUX Dev"},{id:"sdxl",name:"SDXL"}],supportedSizes:["512x512","768x768","1024x1024"]}};e.s(["getAllImageModels",0,function(){let e=[];for(let[r,a]of Object.entries(t))for(let t of a.models)e.push({id:`${r}/${t.id}`,name:t.name,provider:r,supportedSizes:a.supportedSizes});return e},"getImageProvider",0,function(e){return t[e]||null},"parseImageModel",0,function(e){if(!e)return{provider:null,model:null};for(let[r,a]of Object.entries(t))if(e.startsWith(r+"/"))return{provider:r,model:e.slice(r.length+1)};for(let[r,a]of Object.entries(t))if(a.models.some(t=>t.id===e))return{provider:r,model:e};return{provider:null,model:e}}])},740512,e=>{"use strict";e.s(["toJsonErrorPayload",0,function e(t,r="Upstream provider error"){let a={error:{message:r,type:"upstream_error",code:"upstream_error"}};if(t&&"object"==typeof t){let e=t.error;return"string"==typeof e?{error:{message:e,type:"upstream_error",code:"upstream_error"}}:e&&"object"==typeof e?t:{error:t}}if("string"==typeof t){let i=t.trim();if(!i)return a;try{let t=JSON.parse(i);return e(t,r)}catch{return{error:{message:i,type:"upstream_error",code:"upstream_error"}}}}return a}])},333974,e=>{"use strict";function t(e){return e&&"object"==typeof e&&!Array.isArray(e)?e:{}}async function r(e,r){let a=await fetch(`${e}/prompt`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({prompt:r})});if(!a.ok){let e=await a.text();throw Error(`ComfyUI submit failed (${a.status}): ${e}`)}let i=t(await a.json()).prompt_id;if("string"!=typeof i||!i)throw Error("ComfyUI submit failed: missing prompt_id");return i}async function a(e,r,i=12e4){let o=Date.now();for(;Date.now()-o<i;){await new Promise(e=>setTimeout(e,2e3));let a=await fetch(`${e}/history/${r}`);if(!a.ok)continue;let i=t(await a.json()),o=t(i[r]);if(o&&o.outputs&&Object.keys(o.outputs).length>0)return o}throw Error(`ComfyUI prompt ${r} timed out after ${i}ms`)}async function i(e,t,r,a){let i=new URL(`${e}/view`);i.searchParams.set("filename",t),i.searchParams.set("subfolder",r),i.searchParams.set("type",a);let o=await fetch(i.toString());if(!o.ok)throw Error(`ComfyUI fetch output failed (${o.status})`);return o.arrayBuffer()}e.s(["extractComfyOutputFiles",0,function(e){let t=[];for(let r of Object.values(e.outputs||{}))for(let e of r.images||r.gifs||r.audio||[])t.push({filename:e.filename,subfolder:e.subfolder||"",type:e.type||"output"});return t},"fetchComfyOutput",0,i,"pollComfyResult",0,a,"submitComfyWorkflow",0,r])},416726,e=>e.a(async(t,r)=>{try{var a=e.i(224010),i=e.i(671528),o=e.i(287726),s=e.i(573344),n=e.i(719201),l=e.i(16023),d=e.i(706901),u=e.i(249157),p=e.i(740512),c=e.i(478847),m=e.i(676088),f=e.i(200392);e.i(245272);var h=e.i(186920),y=t([i,m,f]);async function g(){return new Response(null,{headers:{"Access-Control-Allow-Origin":a.CORS_ORIGIN,"Access-Control-Allow-Methods":"GET, POST, OPTIONS","Access-Control-Allow-Headers":"*"}})}async function v(){let e=(0,s.getAllImageModels)(),t=Math.floor(Date.now()/1e3),r=e.map(e=>({id:e.id,object:"model",created:t,owned_by:e.provider,type:"image",supported_sizes:e.supportedSizes}));try{let e=await (0,h.getAllCustomModels)();for(let[a,i]of Object.entries(e))if(Array.isArray(i))for(let e of i){if(!e?.id||!Array.isArray(e.supportedEndpoints)||!e.supportedEndpoints.includes("images"))continue;let i=`${a}/${e.id}`;r.some(e=>e.id===i)||r.push({id:i,object:"model",created:t,owned_by:a,type:"image",supported_sizes:null})}}catch{}return new Response(JSON.stringify({object:"list",data:r}),{headers:{"Content-Type":"application/json"}})}async function b(e){let t;try{t=await e.json()}catch{return d.warn("IMAGE","Invalid JSON body"),(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,"Invalid JSON body")}let r=(0,f.validateBody)(m.v1ImageGenerationSchema,t);if((0,f.isValidationFailure)(r))return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,r.error.message);let a=r.data;if("true"===process.env.REQUIRE_API_KEY){let t=(0,o.extractApiKey)(e);if(!t)return(0,n.errorResponse)(l.HTTP_STATUS.UNAUTHORIZED,"Missing API key");if(!await (0,o.isValidApiKey)(t))return(0,n.errorResponse)(l.HTTP_STATUS.UNAUTHORIZED,"Invalid API key")}let y=await (0,c.enforceApiKeyPolicy)(e,a.model);if(y.rejection)return y.rejection;let{provider:g}=(0,s.parseImageModel)(a.model),v=!1;if(!g)try{let e=await (0,h.getAllCustomModels)();for(let[t,r]of Object.entries(e))if(Array.isArray(r)){for(let e of r)if(e?.id&&Array.isArray(e.supportedEndpoints)&&e.supportedEndpoints.includes("images")&&`${t}/${e.id}`===a.model){g=t,v=!0;break}if(g)break}}catch{}if(!g)return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,`Invalid image model: ${a.model}. Use format: provider/model`);let b=(0,s.getImageProvider)(g),T=null;if(b&&"none"!==b.authType){if(!(T=await (0,o.getProviderCredentials)(g)))return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,`No credentials for image provider: ${g}`);if(T.allRateLimited)return(0,n.unavailableResponse)(l.HTTP_STATUS.RATE_LIMITED,`[${g}] All accounts rate limited`,T.retryAfter,T.retryAfterHuman)}else if(v){if(!(T=await (0,o.getProviderCredentials)(g)))return(0,n.errorResponse)(l.HTTP_STATUS.BAD_REQUEST,`No credentials for custom image provider: ${g}`);if(T.allRateLimited)return(0,n.unavailableResponse)(l.HTTP_STATUS.RATE_LIMITED,`[${g}] All accounts rate limited`,T.retryAfter,T.retryAfterHuman)}let R=await (0,i.handleImageGeneration)({body:a,credentials:T,log:u,...v&&{resolvedProvider:g}});if(R.success)return await (0,o.clearRecoveredProviderState)(T),new Response(JSON.stringify(R.data),{status:200,headers:{"Content-Type":"application/json"}});let A=(0,p.toJsonErrorPayload)(R.error,"Image generation provider error");return new Response(JSON.stringify(A),{status:R.status,headers:{"Content-Type":"application/json"}})}[i,m,f]=y.then?(await y)():y,e.s(["GET",0,v,"OPTIONS",0,g,"POST",0,b]),r()}catch(e){r(e)}},!1),463168,e=>e.a(async(t,r)=>{try{var a=e.i(747909),i=e.i(174017),o=e.i(996250),s=e.i(759756),n=e.i(561916),l=e.i(174677),d=e.i(869741),u=e.i(316795),p=e.i(487718),c=e.i(995169),m=e.i(47587),f=e.i(666012),h=e.i(570101),y=e.i(626937),g=e.i(10372),v=e.i(193695);e.i(820232);var b=e.i(600220),T=e.i(416726),R=t([T]);[T]=R.then?(await R)():R;let w=new a.AppRouteRouteModule({definition:{kind:i.RouteKind.APP_ROUTE,page:"/api/v1/images/generations/route",pathname:"/api/v1/images/generations",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/v1/images/generations/route.ts",nextConfigOutput:"standalone",userland:T,...{}}),{workAsyncStorage:S,workUnitAsyncStorage:E,serverHooks:x}=w;async function A(e,t,r){r.requestMeta&&(0,s.setRequestMeta)(e,r.requestMeta),w.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let a="/api/v1/images/generations/route";a=a.replace(/\/index$/,"")||"/";let o=await w.prepare(e,t,{srcPage:a,multiZoneDraftMode:!1});if(!o)return t.statusCode=400,t.end("Bad Request"),null==r.waitUntil||r.waitUntil.call(r,Promise.resolve()),null;let{buildId:T,params:R,nextConfig:A,parsedUrl:S,isDraftMode:E,prerenderManifest:x,routerServerContext:_,isOnDemandRevalidate:P,revalidateOnlyGenerated:U,resolvedPathname:C,clientReferenceManifest:I,serverActionsManifest:O}=o,k=(0,d.normalizeAppPath)(a),D=!!(x.dynamicRoutes[k]||x.routes[C]),H=async()=>((null==_?void 0:_.render404)?await _.render404(e,t,S,!1):t.end("This page could not be found"),null);if(D&&!E){let e=!!x.routes[C],t=x.dynamicRoutes[k];if(t&&!1===t.fallback&&!e){if(A.adapterPath)return await H();throw new v.NoFallbackError}}let N=null;!D||w.isDev||E||(N=C,N="/index"===N?"/":N);let j=!0===w.isDev||!D,L=D&&!j;O&&I&&(0,l.setManifestsSingleton)({page:a,clientReferenceManifest:I,serverActionsManifest:O});let M=e.method||"GET",$=(0,n.getTracer)(),F=$.getActiveScopeSpan(),q=!!(null==_?void 0:_.isWrappedByNextServer),z=!!(0,s.getRequestMeta)(e,"minimalMode"),B=(0,s.getRequestMeta)(e,"incrementalCache")||await w.getIncrementalCache(e,A,x,z);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let X={params:R,previewProps:x.preview,renderOpts:{experimental:{authInterrupts:!!A.experimental.authInterrupts},cacheComponents:!!A.cacheComponents,supportsDynamicResponse:j,incrementalCache:B,cacheLifeProfiles:A.cacheLife,waitUntil:r.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,a,i)=>w.onRequestError(e,t,a,i,_)},sharedContext:{buildId:T}},G=new u.NodeNextRequest(e),K=new u.NodeNextResponse(t),J=p.NextRequestAdapter.fromNodeNextRequest(G,(0,p.signalFromNodeResponse)(t));try{let o,s=async e=>w.handle(J,X).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=$.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==c.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 i=r.get("next.route");if(i){let t=`${M} ${i}`;e.setAttributes({"next.route":i,"http.route":i,"next.span_name":t}),e.updateName(t),o&&o!==e&&(o.setAttribute("http.route",i),o.updateName(t))}else e.updateName(`${M} ${a}`)}),l=async o=>{var n,l;let d=async({previousCacheEntry:i})=>{try{if(!z&&P&&U&&!i)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await s(o);e.fetchMetrics=X.renderOpts.fetchMetrics;let n=X.renderOpts.pendingWaitUntil;n&&r.waitUntil&&(r.waitUntil(n),n=void 0);let l=X.renderOpts.collectedTags;if(!D)return await (0,f.sendResponse)(G,K,a,X.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(a.headers);l&&(t[g.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==X.renderOpts.collectedRevalidate&&!(X.renderOpts.collectedRevalidate>=g.INFINITE_CACHE)&&X.renderOpts.collectedRevalidate,i=void 0===X.renderOpts.collectedExpire||X.renderOpts.collectedExpire>=g.INFINITE_CACHE?void 0:X.renderOpts.collectedExpire;return{value:{kind:b.CachedRouteKind.APP_ROUTE,status:a.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:i}}}}catch(t){throw(null==i?void 0:i.isStale)&&await w.onRequestError(e,t,{routerKind:"App Router",routePath:a,routeType:"route",revalidateReason:(0,m.getRevalidateReason)({isStaticGeneration:L,isOnDemandRevalidate:P})},!1,_),t}},u=await w.handleResponse({req:e,nextConfig:A,cacheKey:N,routeKind:i.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:x,isRoutePPREnabled:!1,isOnDemandRevalidate:P,revalidateOnlyGenerated:U,responseGenerator:d,waitUntil:r.waitUntil,isMinimalMode:z});if(!D)return null;if((null==u||null==(n=u.value)?void 0:n.kind)!==b.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});z||t.setHeader("x-nextjs-cache",P?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let p=(0,h.fromNodeOutgoingHttpHeaders)(u.value.headers);return z&&D||p.delete(g.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||p.get("Cache-Control")||p.set("Cache-Control",(0,y.getCacheControlHeader)(u.cacheControl)),await (0,f.sendResponse)(G,K,new Response(u.value.body,{headers:p,status:u.value.status||200})),null};q&&F?await l(F):(o=$.getActiveScopeSpan(),await $.withPropagatedContext(e.headers,()=>$.trace(c.BaseServerSpan.handleRequest,{spanName:`${M} ${a}`,kind:n.SpanKind.SERVER,attributes:{"http.method":M,"http.target":e.url}},l),void 0,!q))}catch(t){if(t instanceof v.NoFallbackError||await w.onRequestError(e,t,{routerKind:"App Router",routePath:k,routeType:"route",revalidateReason:(0,m.getRevalidateReason)({isStaticGeneration:L,isOnDemandRevalidate:P})},!1,_),D)throw t;return await (0,f.sendResponse)(G,K,new Response(null,{status:500})),null}}e.s(["handler",0,A,"patchFetch",0,function(){return(0,o.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:E})},"routeModule",0,w,"serverHooks",0,x,"workAsyncStorage",0,S,"workUnitAsyncStorage",0,E]),r()}catch(e){r(e)}},!1),605589,e=>{e.v(t=>Promise.all(["server/chunks/src_lib_localDb_ts_0ml5l_h._.js"].map(t=>e.l(t))).then(()=>t(969738)))},606102,e=>{e.v(e=>Promise.resolve().then(()=>e(548941)))},789543,e=>{e.v(e=>Promise.resolve().then(()=>e(385498)))},49794,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_constants_pricing_ts_0hk12it._.js"].map(t=>e.l(t))).then(()=>t(404503)))},386305,e=>{e.v(e=>Promise.resolve().then(()=>e(878947)))},579042,e=>{e.v(t=>Promise.all(["server/chunks/src_shared_utils_apiKey_ts_12~h.oz._.js"].map(t=>e.l(t))).then(()=>t(65448)))}];
|
|
2
2
|
|
|
3
3
|
//# sourceMappingURL=%5Broot-of-the-server%5D__0m-356c._.js.map
|