omniroute 1.4.10 → 1.4.11
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/app-path-routes-manifest.json +34 -34
- package/app/.next/build-manifest.json +2 -2
- package/app/.next/prerender-manifest.json +3 -3
- package/app/.next/server/app/(dashboard)/dashboard/analytics/page.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-log/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.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.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/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/profile/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/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/translator/page.js +4 -4
- package/app/.next/server/app/(dashboard)/dashboard/translator/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/(dashboard)/dashboard/usage/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/_global-error.html +2 -2
- package/app/.next/server/app/_global-error.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
- package/app/.next/server/app/_global-error.segments/_global-error.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/auth/login/route.js +1 -1
- package/app/.next/server/app/api/auth/login/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/auth/logout/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/auth/status/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cache/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cache/stats/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/antigravity-mitm/alias/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/antigravity-mitm/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/antigravity-mitm/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/backups/route.js +1 -1
- package/app/.next/server/app/api/cli-tools/backups/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/claude-settings/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/claude-settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/cline-settings/route.js +1 -1
- package/app/.next/server/app/api/cli-tools/cline-settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/codex-profiles/route.js +1 -1
- package/app/.next/server/app/api/cli-tools/codex-profiles/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/codex-settings/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/codex-settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/droid-settings/route.js +1 -1
- package/app/.next/server/app/api/cli-tools/droid-settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/guide-settings/[toolId]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/kilo-settings/route.js +1 -1
- package/app/.next/server/app/api/cli-tools/kilo-settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/openclaw-settings/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/openclaw-settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/runtime/[toolId]/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/runtime/[toolId]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cli-tools/status/route.js +2 -2
- package/app/.next/server/app/api/cli-tools/status/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cloud/auth/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cloud/credentials/update/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cloud/model/resolve/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/cloud/models/alias/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/combos/[id]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/combos/metrics/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/combos/route.js +1 -1
- package/app/.next/server/app/api/combos/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/combos/test/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/compliance/audit-log/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/db-backups/export/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/db-backups/exportAll/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/db-backups/import/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/db-backups/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/evals/[suiteId]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/evals/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/fallback/chains/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/init/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/keys/[id]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/keys/route.js +1 -1
- package/app/.next/server/app/api/keys/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/logs/console/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/models/alias/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/models/availability/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/models/catalog/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/models/route.js +1 -1
- package/app/.next/server/app/api/models/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/monitoring/health/route.js +1 -1
- package/app/.next/server/app/api/monitoring/health/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/[provider]/[action]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/cursor/auto-import/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/cursor/import/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/kiro/auto-import/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/kiro/import/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/kiro/social-authorize/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/oauth/kiro/social-exchange/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/policies/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/pricing/defaults/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/pricing/models/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/pricing/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/provider-metrics/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/provider-models/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/provider-nodes/[id]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/provider-nodes/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/provider-nodes/validate/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/[id]/models/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/[id]/test/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/client/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/route.js +1 -1
- package/app/.next/server/app/api/providers/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/test-batch/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/providers/validate/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/rate-limit/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/rate-limits/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/resilience/reset/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/resilience/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/restart/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/sessions/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/combo-defaults/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/ip-filter/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/proxy/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/proxy/test/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/require-login/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/route.js +1 -1
- package/app/.next/server/app/api/settings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/system-prompt/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/settings/thinking-budget/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/shutdown/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/storage/health/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/sync/cloud/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/sync/initialize/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/tags/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/telemetry/summary/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/token-health/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/translator/detect/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/translator/history/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/translator/load/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/translator/save/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/translator/send/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/translator/translate/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/[connectionId]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/analytics/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/budget/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/call-logs/[id]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/call-logs/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/history/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/logs/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/proxy-logs/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/usage/request-logs/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/api/chat/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/audio/speech/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/audio/transcriptions/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/chat/completions/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/embeddings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/images/generations/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/messages/count_tokens/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/messages/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/models/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/moderations/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/providers/[provider]/chat/completions/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/providers/[provider]/embeddings/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/providers/[provider]/images/generations/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/rerank/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/responses/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1beta/models/[...path]/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/api/v1beta/models/route_client-reference-manifest.js +1 -1
- package/app/.next/server/app/callback/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app/docs/page.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.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.js +1 -1
- package/app/.next/server/app/login/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/terms/page_client-reference-manifest.js +1 -1
- package/app/.next/server/app-paths-manifest.json +34 -34
- package/app/.next/server/chunks/1259.js +1 -1
- package/app/.next/server/chunks/1960.js +1 -1
- package/app/.next/server/chunks/1990.js +1 -1
- package/app/.next/server/chunks/3498.js +5 -3
- package/app/.next/server/chunks/9824.js +2 -2
- package/app/.next/server/pages/500.html +2 -2
- 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/{5846-bac355f56b136439.js → 5846-19c878280decbd16.js} +1 -1
- package/app/.next/static/chunks/{993-961f6e199b93539a.js → 993-e3050ebfd4f5032f.js} +1 -1
- package/app/.next/static/chunks/app/(dashboard)/dashboard/analytics/page-a50474b6ebdf468a.js +1 -0
- package/app/.next/static/chunks/app/(dashboard)/dashboard/costs/page-08f3ed204d01b6a0.js +1 -0
- package/app/.next/static/chunks/app/(dashboard)/dashboard/limits/page-fbe1442b61df950a.js +1 -0
- package/app/.next/static/chunks/app/(dashboard)/dashboard/translator/page-b351778975cb8622.js +4 -0
- package/app/.next/static/chunks/app/forgot-password/page-a440e0c1675842bf.js +1 -0
- package/app/.next/static/chunks/app/login/page-164f6b6b41167c5a.js +1 -0
- package/app/package.json +1 -1
- package/package.json +1 -1
- package/app/.next/static/chunks/app/(dashboard)/dashboard/analytics/page-3fcbbdb2221f0b0c.js +0 -1
- package/app/.next/static/chunks/app/(dashboard)/dashboard/costs/page-f256689b8410bd74.js +0 -1
- package/app/.next/static/chunks/app/(dashboard)/dashboard/limits/page-a5a48afa8c125ada.js +0 -1
- package/app/.next/static/chunks/app/(dashboard)/dashboard/translator/page-75c8b38a55e13042.js +0 -4
- package/app/.next/static/chunks/app/forgot-password/page-057ea91c6f140e0b.js +0 -1
- package/app/.next/static/chunks/app/login/page-c1d7bfab91a7877c.js +0 -1
- /package/app/.next/static/{8UAle4UTGR7gIVofXmh_1 → g7Mie-iq39oZ7ts610YtL}/_buildManifest.js +0 -0
- /package/app/.next/static/{8UAle4UTGR7gIVofXmh_1 → g7Mie-iq39oZ7ts610YtL}/_ssgManifest.js +0 -0
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
exports.id=1259,exports.ids=[1259],exports.modules={3845:(a,b,c)=>{var d={"./en.json":[31960,1960],"./pt-BR.json":[41990,1990]};function e(a){if(!c.o(d,a))return Promise.resolve().then(()=>{var b=Error("Cannot find module '"+a+"'");throw b.code="MODULE_NOT_FOUND",b});var b=d[a],e=b[0];return c.e(b[1]).then(()=>c.t(e,19))}e.keys=()=>Object.keys(d),e.id=3845,a.exports=e},7224:(a,b,c)=>{Promise.resolve().then(c.bind(c,67045))},8979:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call the default export of \"/home/runner/work/OmniRoute/OmniRoute/src/app/not-found.tsx\" from the server, but it's on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/app/not-found.tsx","default")},12608:(a,b,c)=>{Promise.resolve().then(c.bind(c,8979))},17084:(a,b,c)=>{"use strict";c.d(b,{Q2:()=>o,DI:()=>l,fg:()=>j,MA:()=>p,IS:()=>h,zN:()=>i,JH:()=>k,wb:()=>s,wG:()=>r,zt:()=>q,gb:()=>n,mq:()=>m});var d=c(60258);let e=d.Ikc({id:d.YjP().min(1),alias:d.YjP().min(1),name:d.YjP().min(1),icon:d.YjP().min(1),color:d.YjP().regex(/^#[0-9A-Fa-f]{6}$/,"Must be a valid hex color (#RRGGBB)"),textIcon:d.YjP().optional(),website:d.YjP().url().optional(),passthroughModels:d.zMY().optional()}),f=d.g1P(d.YjP(),e);function g(a,b){let c=f.safeParse(a);if(!c.success){let a=c.error.issues.map(a=>` ${a.path.join(".")}: ${a.message}`).join("\n");throw console.error(`[PROVIDER VALIDATION] ${b} has invalid entries:
|
|
2
|
-
${a}`),Error(`Provider validation failed for ${b}`)}}let h={iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4"},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"}},i={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B"},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"}},j={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"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim"},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"}},k="openai-compatible-",l="anthropic-compatible-";function m(a){return"string"==typeof a&&a.startsWith(k)}function n(a){return"string"==typeof a&&a.startsWith(l)}let o={...h,...i,...j},p={oauth:{id:"oauth",name:"OAuth",icon:"lock"},apikey:{id:"apikey",name:"API Key",icon:"key"}};function q(a){for(let b of Object.values(o))if(b.alias===a||b.id===a)return b;return null}function r(a){let b=o[a];return b?.alias||a}Object.values(o).reduce((a,b)=>(a[b.alias]=b.id,a),{}),Object.values(o).reduce((a,b)=>(a[b.id]=b.alias,a),{});let s=["antigravity","kiro","github","codex","claude"];g(h,"FREE_PROVIDERS"),g(i,"OAUTH_PROVIDERS"),g(j,"APIKEY_PROVIDERS")},21280:(a,b,c)=>{"use strict";c.d(b,{S_:()=>m});var d=c(22901),e=c(87068);let f="[HealthCheck]",g=null,h=0,i=null;async function j(){let a=Date.now();return null!==g&&a-h<3e4?g:null!==i?i:i=(async()=>{try{let b=await (0,d.V7)();return g=!0===b.hideHealthCheckLogs,h=a,g}catch{return!1}finally{i=null}})()}function k(a,...b){j().then(c=>{c||console.log(a,...b)})}function l(a,...b){j().then(c=>{c||console.error(a,...b)})}function m(){g=null,h=0}let n=!1;async function o(){try{let a=await (0,d.getProviderConnections)({authType:"oauth"});if(!a||0===a.length)return;for(let b of a)try{await p(b)}catch(a){l(`${f} Error checking ${b.name||b.id}:`,a.message)}}catch(a){l(`${f} Sweep error:`,a.message)}}async function p(a){let b=a.healthCheckInterval??60;if(b<=0||!a.isActive||!a.refreshToken||"string"!=typeof a.refreshToken||"expired"===a.testStatus)return;if(!(0,e.Ny)(a.provider)){let b=new Date().toISOString();await (0,d.rj)(a.id,{lastHealthCheckAt:b}),k(`${f} Skipping ${a.provider}/${a.name||a.email||a.id} (refresh unsupported)`);return}let c=a.lastHealthCheckAt?new Date(a.lastHealthCheckAt).getTime():0;if(Date.now()-c<60*b*1e3)return;k(`${f} Refreshing ${a.provider}/${a.name||a.email||a.id} (interval: ${b}min)`);let g={refreshToken:a.refreshToken,accessToken:a.accessToken,expiresAt:a.tokenExpiresAt,providerSpecificData:a.providerSpecificData},h=await j(),i=await (0,e.iD)(a.provider,g,{info:(a,b)=>{h||console.log(`${f} [${a}] ${b}`)},warn:(a,b)=>{h||console.warn(`${f} [${a}] ${b}`)},error:(a,b,c)=>{h||console.error(`${f} [${a}] ${b}`,c||"")}}),m=new Date().toISOString();if((0,e.jT)(i)){await (0,d.rj)(a.id,{lastHealthCheckAt:m,testStatus:"expired",lastError:`Refresh token consumed (${i.error}). Please re-authenticate this account.`,lastErrorAt:m,lastErrorType:i.error,lastErrorSource:"oauth",errorCode:i.error,isActive:!1,refreshToken:null}),l(`${f} ✗ ${a.provider}/${a.name||a.email||a.id} — Refresh token is permanently invalid (${i.error}). Connection deactivated. Re-authenticate to restore.`);return}if(i&&i.accessToken){let b={accessToken:i.accessToken,lastHealthCheckAt:m,testStatus:"active",lastError:null,lastErrorAt:null,lastErrorType:null,lastErrorSource:null,errorCode:null};i.refreshToken&&(b.refreshToken=i.refreshToken),i.expiresIn&&(b.tokenExpiresAt=new Date(Date.now()+1e3*i.expiresIn).toISOString()),await (0,d.rj)(a.id,b),k(`${f} ✓ ${a.provider}/${a.name||a.email||a.id} refreshed`)}else await (0,d.rj)(a.id,{lastHealthCheckAt:m,testStatus:"error",lastError:"Health check: token refresh failed",lastErrorAt:m,lastErrorType:"token_refresh_failed",lastErrorSource:"oauth",errorCode:"refresh_failed"}),function(a,...b){j().then(c=>{c||console.warn(a,...b)})}(`${f} ✗ ${a.provider}/${a.name||a.email||a.id} refresh failed`)}n=!0,k(`${f} Starting proactive token health-check (tick every 60s)`),setTimeout(()=>{o(),setInterval(o,6e4)},1e4)},32444:(a,b,c)=>{"use strict";c.d(b,{ThemeProvider:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call ThemeProvider() from the server but ThemeProvider is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/shared/components/ThemeProvider.tsx","ThemeProvider")},34017:(a,b,c)=>{"use strict";c.d(b,{A:()=>g});var d=c(29389),e=c(65573);let f=["en","pt-BR"],g=(0,d.A)(async()=>{let a=await (0,e.UL)(),b=a.get("NEXT_LOCALE")?.value||"";b||(b=(await (0,e.b3)()).get("x-locale")||""),f.includes(b)||(b="en");let d=(await c(3845)(`./${b}.json`)).default;return{locale:b,messages:d}})},39710:(a,b,c)=>{Promise.resolve().then(c.bind(c,97507))},44438:(a,b,c)=>{Promise.resolve().then(c.bind(c,64385))},47695:(a,b,c)=>{"use strict";c.d(b,{A:()=>g});var d=c(31417),e=c(300),f=c(73959);let g=(0,d.v)()((0,e.Zr)((a,b)=>({theme:f.B2.defaultTheme,setTheme:b=>{a({theme:b})},toggleTheme:()=>{let c="dark"===b().theme?"light":"dark";a({theme:c})},initTheme:()=>{b().theme}}),{name:f.B2.storageKey}))},47825:(a,b,c)=>{"use strict";c.d(b,{KC:()=>d.KC,Xg:()=>d.Xg});var d=c(97319);Object.entries(c(17084).Q2).filter(([,a])=>a.passthroughModels).map(([a])=>a),Object.entries(d.vq).flatMap(([a,b])=>b.map(b=>({provider:a,model:b.id,name:b.name})))},49226:(a,b,c)=>{"use strict";c.d(b,{A:()=>k});var d=c(90357),e=c(22901);let f=process.env.BASE_URL||process.env.NEXT_PUBLIC_BASE_URL||process.env.NEXT_PUBLIC_APP_URL||"http://localhost:20128";class g{constructor(a=null,b=15){this.machineId=a,this.intervalMinutes=b,this.intervalId=null}async initializeMachineId(){this.machineId||(this.machineId=await (0,d.Xj)())}async start(){this.intervalId||(await this.initializeMachineId(),setTimeout(()=>{this.syncWithRetry().catch(()=>{})},3e4),this.intervalId=setInterval(()=>{this.syncWithRetry().catch(()=>{})},60*this.intervalMinutes*1e3))}stop(){this.intervalId&&(clearInterval(this.intervalId),this.intervalId=null)}async syncWithRetry(a=1){for(let b=1;b<=a;b++)try{return await this.sync()}catch(d){if(b===a)return null;let c=Math.min(1e3*Math.pow(2,b),1e4);await new Promise(a=>setTimeout(a,c))}}async sync(){if(!await (0,e.Nx)())return null;await this.initializeMachineId();let a=await fetch(`${f}/api/sync/cloud`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machineId:this.machineId,action:"sync"})});if(!a.ok)throw Error((await a.json().catch(()=>({}))).error||"Sync failed");return await a.json()}isRunning(){return null!==this.intervalId}}let h=null;async function i(a=null,b=15){return h||(h=new g(a,b)),h}async function j(){try{await (0,e.bI)();let a=await i(null,15);return await a.start(),a}catch(a){throw console.error("[CloudSync] Error initializing scheduler:",a),a}}a=c.hmd(a),c.c[c.s]===a&&j().catch(a=>console.error("[CloudSync] init failed:",a));let k=j},61135:()=>{},64385:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call the default export of \"/home/runner/work/OmniRoute/OmniRoute/src/app/error.tsx\" from the server, but it's on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/app/error.tsx","default")},67045:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>e});var d=c(48249);function e({error:a,reset:b}){return(0,d.jsx)("html",{lang:"en",children:(0,d.jsx)("body",{className:"flex flex-col items-center justify-center min-h-screen p-6 bg-[#0a0a0f] text-[#e0e0e0] font-[system-ui,-apple-system,sans-serif] text-center m-0",children:(0,d.jsxs)("main",{role:"alert","aria-live":"assertive",className:"flex flex-col items-center",children:[(0,d.jsx)("div",{className:"text-[64px] mb-4","aria-hidden":"true",children:"⚠️"}),(0,d.jsx)("h1",{className:"text-[28px] font-bold mb-2",children:"Something went wrong"}),(0,d.jsx)("p",{className:"text-[15px] text-[#888] max-w-[400px] leading-relaxed mb-6",children:"An unexpected error occurred. This has been logged and our team will investigate."}),!1,(0,d.jsx)("button",{onClick:b,"aria-label":"Retry loading the page",className:"px-8 py-3 rounded-[10px] text-white border-none text-sm font-semibold cursor-pointer transition-transform duration-200 shadow-[0_4px_16px_rgba(99,102,241,0.3)] hover:-translate-y-0.5 bg-gradient-to-br from-[#6366f1] to-[#8b5cf6] focus:outline-2 focus:outline-offset-2 focus:outline-[#6366f1]",children:"Try Again"})]})})})}},69199:(a,b,c)=>{Promise.resolve().then(c.bind(c,86392)),Promise.resolve().then(c.bind(c,32444))},73857:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>g});var d=c(48249),e=c(2116),f=c.n(e);function g(){return(0,d.jsxs)("div",{className:"flex flex-col items-center justify-center min-h-screen p-6 bg-bg text-text-main text-center",role:"main","aria-labelledby":"not-found-title",children:[(0,d.jsx)("div",{className:"text-[96px] font-extrabold leading-none mb-2 bg-gradient-to-br from-primary to-primary-hover bg-clip-text text-transparent","aria-hidden":"true",children:"404"}),(0,d.jsx)("h1",{id:"not-found-title",className:"text-2xl font-semibold mb-2",children:"Page not found"}),(0,d.jsx)("p",{className:"text-[15px] text-text-muted max-w-[400px] leading-relaxed mb-8",children:"The page you're looking for doesn't exist or has been moved."}),(0,d.jsx)(f(),{href:"/dashboard",className:"px-8 py-3 rounded-xl text-white text-sm font-medium no-underline transition-all duration-200 shadow-warm hover:-translate-y-0.5 bg-gradient-to-br from-primary to-primary-hover hover:shadow-elevated focus:outline-2 focus:outline-offset-2 focus:outline-primary","aria-label":"Return to dashboard",children:"Go to Dashboard"})]})}},73959:(a,b,c)=>{"use strict";c.d(b,{Q2:()=>d.Q2,fg:()=>d.fg,vQ:()=>e,MA:()=>d.MA,zN:()=>d.zN,B2:()=>f});var d=c(17084);c(47825);let e={name:"OmniRoute",description:"AI Gateway for Multi-Provider LLMs",version:"1.4.10"},f={storageKey:"theme",defaultTheme:"system"}},75146:(a,b,c)=>{"use strict";c.d(b,{ThemeProvider:()=>f});var d=c(48249);c(67484);var e=c(47695);function f({children:a}){let{initTheme:b}=(0,e.A)();return(0,d.jsx)(d.Fragment,{children:a})}},76160:(a,b,c)=>{Promise.resolve().then(c.bind(c,73857))},76537:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>l,metadata:()=>k});var d=c(5735),e=c(50609),f=c.n(e);c(61135);var g=c(32444);c(91057);var h=c(68625),i=c(62026),j=c(28440);let k={title:"OmniRoute — AI Gateway for Multi-Provider LLMs",description:"OmniRoute is an AI gateway for multi-provider LLMs. One endpoint for all your AI providers.",icons:{icon:"/favicon.svg",apple:"/apple-touch-icon.svg"}};async function l({children:a}){let b=await (0,i.A)(),c=await (0,j.A)();return(0,d.jsxs)("html",{lang:b,suppressHydrationWarning:!0,children:[(0,d.jsxs)("head",{children:[(0,d.jsx)("link",{rel:"preconnect",href:"https://fonts.googleapis.com"}),(0,d.jsx)("link",{rel:"preconnect",href:"https://fonts.gstatic.com",crossOrigin:"anonymous"}),(0,d.jsx)("link",{href:"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&display=swap",rel:"stylesheet"})]}),(0,d.jsxs)("body",{className:`${f().variable} font-sans antialiased`,suppressHydrationWarning:!0,children:[(0,d.jsx)("a",{href:"#main-content",className:"sr-only focus:not-sr-only focus:absolute focus:top-2 focus:left-2 focus:z-50 focus:px-4 focus:py-2 focus:bg-[#6366f1] focus:text-white focus:rounded-lg focus:text-sm focus:font-semibold focus:shadow-lg",children:"Skip to content"}),(0,d.jsx)(h.A,{locale:b,messages:c,children:(0,d.jsx)(g.ThemeProvider,{children:a})})]})]})}},77447:(a,b,c)=>{Promise.resolve().then(c.bind(c,62626)),Promise.resolve().then(c.bind(c,75146))},79369:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,60440,23)),Promise.resolve().then(c.t.bind(c,84342,23)),Promise.resolve().then(c.t.bind(c,82265,23)),Promise.resolve().then(c.t.bind(c,35421,23)),Promise.resolve().then(c.t.bind(c,61335,23)),Promise.resolve().then(c.t.bind(c,70664,23)),Promise.resolve().then(c.bind(c,74661))},81227:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call the default export of \"/home/runner/work/OmniRoute/OmniRoute/src/app/global-error.tsx\" from the server, but it's on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/app/global-error.tsx","default")},89097:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,15098,23)),Promise.resolve().then(c.t.bind(c,47644,23)),Promise.resolve().then(c.t.bind(c,33859,23)),Promise.resolve().then(c.t.bind(c,98099,23)),Promise.resolve().then(c.t.bind(c,16237,23)),Promise.resolve().then(c.t.bind(c,98562,23)),Promise.resolve().then(c.t.bind(c,36675,23))},90357:(a,b,c)=>{"use strict";c.d(b,{Xj:()=>e});var d=c(19713);async function e(a=null){let b=a||process.env.MACHINE_ID_SALT||"endpoint-proxy-salt";try{let a=(0,d.machineIdSync)();return(await Promise.resolve().then(c.t.bind(c,55511,23))).createHash("sha256").update(a+b).digest("hex").substring(0,16)}catch(a){return console.log("Error getting machine ID:",a),crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(a){let b=16*Math.random()|0;return("x"==a?b:3&b|8).toString(16)})}}},91057:(a,b,c)=>{"use strict";var d=c(49226);c(21280);let e=!1;(async function(){if(!e)try{await (0,d.A)(),e=!0}catch(a){console.error("[ServerInit] Error initializing cloud sync:",a)}return e})().catch(a=>console.error("[CloudSync] ensure failed:",a))},97319:(a,b,c)=>{"use strict";c.d(b,{Xg:()=>g,vq:()=>f,KC:()=>h});let d={claude:{id:"claude",alias:"cc",format:"claude",executor:"default",baseUrl:"https://api.anthropic.com/v1/messages",urlSuffix:"?beta=true",authType:"oauth",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14,fine-grained-tool-streaming-2025-05-14,context-management-2025-06-27","Anthropic-Dangerous-Direct-Browser-Access":"true","User-Agent":"claude-cli/1.0.83 (external, cli)","X-App":"cli","X-Stainless-Helper-Method":"stream","X-Stainless-Retry-Count":"0","X-Stainless-Runtime-Version":"v24.3.0","X-Stainless-Package-Version":"0.55.1","X-Stainless-Runtime":"node","X-Stainless-Lang":"js","X-Stainless-Arch":"arm64","X-Stainless-Os":"MacOS","X-Stainless-Timeout":"60"},oauth:{clientIdEnv:"CLAUDE_OAUTH_CLIENT_ID",clientIdDefault:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",tokenUrl:"https://console.anthropic.com/v1/oauth/token"},models:[{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-opus-4-5-20251101",name:"Claude 4.5 Opus"},{id:"claude-sonnet-4-5-20250929",name:"Claude 4.5 Sonnet"},{id:"claude-haiku-4-5-20251001",name:"Claude 4.5 Haiku"}]},gemini:{id:"gemini",alias:"gemini",format:"gemini",executor:"default",baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",urlBuilder:(a,b,c)=>`${a}/${b}:${c?"streamGenerateContent?alt=sse":"generateContent"}`,authType:"apikey",authHeader:"x-goog-api-key",oauth:{clientIdEnv:"GEMINI_OAUTH_CLIENT_ID",clientIdDefault:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecretEnv:"GEMINI_OAUTH_CLIENT_SECRET",clientSecretDefault:"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"},models:[{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"}]},"gemini-cli":{id:"gemini-cli",alias:"gc",format:"gemini-cli",executor:"gemini-cli",baseUrl:"https://cloudcode-pa.googleapis.com/v1internal",urlBuilder:(a,b,c)=>`${a}:${c?"streamGenerateContent?alt=sse":"generateContent"}`,authType:"oauth",authHeader:"bearer",oauth:{clientIdEnv:"GEMINI_CLI_OAUTH_CLIENT_ID",clientIdDefault:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecretEnv:"GEMINI_CLI_OAUTH_CLIENT_SECRET",clientSecretDefault:"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"},models:[{id:"gemini-3-flash-preview",name:"Gemini 3 Flash Preview"},{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"}]},codex:{id:"codex",alias:"cx",format:"openai-responses",executor:"codex",baseUrl:"https://chatgpt.com/backend-api/codex/responses",authType:"oauth",authHeader:"bearer",headers:{Version:"0.92.0","Openai-Beta":"responses=experimental","User-Agent":"codex-cli/0.92.0 (Windows 10.0.26100; x64)"},oauth:{clientIdEnv:"CODEX_OAUTH_CLIENT_ID",clientIdDefault:"app_EMoamEEZ73f0CkXaXp7hrann",clientSecretEnv:"CODEX_OAUTH_CLIENT_SECRET",clientSecretDefault:"",tokenUrl:"https://auth.openai.com/oauth/token"},models:[{id:"gpt-5.3-codex",name:"GPT 5.3 Codex"},{id:"gpt-5.3-codex-xhigh",name:"GPT 5.3 Codex (xHigh)"},{id:"gpt-5.3-codex-high",name:"GPT 5.3 Codex (High)"},{id:"gpt-5.3-codex-low",name:"GPT 5.3 Codex (Low)"},{id:"gpt-5.3-codex-none",name:"GPT 5.3 Codex (None)"},{id:"gpt-5.1-codex-mini",name:"GPT 5.1 Codex Mini"},{id:"gpt-5.1-codex-mini-high",name:"GPT 5.1 Codex Mini (High)"},{id:"gpt-5.2-codex",name:"GPT 5.2 Codex"},{id:"gpt-5.2",name:"GPT 5.2"},{id:"gpt-5.1-codex-max",name:"GPT 5.1 Codex Max"},{id:"gpt-5.1-codex",name:"GPT 5.1 Codex"},{id:"gpt-5.1",name:"GPT 5.1"},{id:"gpt-5-codex",name:"GPT 5 Codex"},{id:"gpt-5-codex-mini",name:"GPT 5 Codex Mini"}]},qwen:{id:"qwen",alias:"qw",format:"openai",executor:"default",baseUrl:"https://portal.qwen.ai/v1/chat/completions",authType:"oauth",authHeader:"bearer",headers:{"User-Agent":"google-api-nodejs-client/9.15.1","X-Goog-Api-Client":"gl-node/22.17.0"},oauth:{clientIdEnv:"QWEN_OAUTH_CLIENT_ID",clientIdDefault:"f0304373b74a44d2b584a3fb70ca9e56",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",authUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code"},models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus"},{id:"qwen3-coder-flash",name:"Qwen3 Coder Flash"},{id:"vision-model",name:"Qwen3 Vision Model"}]},iflow:{id:"iflow",alias:"if",format:"openai",executor:"iflow",baseUrl:"https://apis.iflow.cn/v1/chat/completions",authType:"oauth",authHeader:"bearer",headers:{"User-Agent":"iFlow-Cli"},oauth:{clientIdEnv:"IFLOW_OAUTH_CLIENT_ID",clientIdDefault:"10009311001",clientSecretEnv:"IFLOW_OAUTH_CLIENT_SECRET",clientSecretDefault:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://iflow.cn/oauth/token",authUrl:"https://iflow.cn/oauth"},models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus"},{id:"kimi-k2",name:"Kimi K2"},{id:"kimi-k2-thinking",name:"Kimi K2 Thinking"},{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"deepseek-r1",name:"DeepSeek R1"},{id:"deepseek-v3.2-chat",name:"DeepSeek V3.2 Chat"},{id:"deepseek-v3.2-reasoner",name:"DeepSeek V3.2 Reasoner"},{id:"minimax-m2.1",name:"MiniMax M2.1"},{id:"glm-4.7",name:"GLM 4.7"}]},antigravity:{id:"antigravity",alias:"ag",format:"antigravity",executor:"antigravity",baseUrls:["https://daily-cloudcode-pa.googleapis.com","https://cloudcode-pa.googleapis.com"],urlBuilder:(a,b,c)=>`${a}${c?"/v1internal:streamGenerateContent?alt=sse":"/v1internal:generateContent"}`,authType:"oauth",authHeader:"bearer",headers:{"User-Agent":"antigravity/1.104.0 darwin/arm64"},oauth:{clientIdEnv:"ANTIGRAVITY_OAUTH_CLIENT_ID",clientIdDefault:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecretEnv:"ANTIGRAVITY_OAUTH_CLIENT_SECRET",clientSecretDefault:"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"},models:[{id:"claude-opus-4-6-thinking",name:"Claude Opus 4.6 Thinking"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6"},{id:"gemini-3.1-pro-high",name:"Gemini 3.1 Pro High"},{id:"gemini-3.1-pro-low",name:"Gemini 3.1 Pro Low"},{id:"gemini-3-flash",name:"Gemini 3 Flash"},{id:"gpt-oss-120b-medium",name:"GPT OSS 120B Medium"}]},github:{id:"github",alias:"gh",format:"openai",executor:"github",baseUrl:"https://api.githubcopilot.com/chat/completions",responsesBaseUrl:"https://api.githubcopilot.com/responses",authType:"oauth",authHeader:"bearer",headers:{"copilot-integration-id":"vscode-chat","editor-version":"vscode/1.107.1","editor-plugin-version":"copilot-chat/0.26.7","user-agent":"GitHubCopilotChat/0.26.7","openai-intent":"conversation-panel","x-github-api-version":"2025-04-01","x-vscode-user-agent-library-version":"electron-fetch","X-Initiator":"user",Accept:"application/json","Content-Type":"application/json"},models:[{id:"gpt-4.1",name:"GPT-4.1"},{id:"gpt-4o",name:"GPT-4o"},{id:"gpt-4o-mini",name:"GPT-4o Mini"},{id:"gpt-4",name:"GPT-4"},{id:"gpt-3.5-turbo",name:"GPT-3.5 Turbo"},{id:"gpt-5",name:"GPT-5"},{id:"gpt-5-mini",name:"GPT-5 Mini"},{id:"gpt-5-codex",name:"GPT-5 Codex",targetFormat:"openai-responses"},{id:"gpt-5.1",name:"GPT-5.1"},{id:"gpt-5.1-codex",name:"GPT-5.1 Codex",targetFormat:"openai-responses"},{id:"gpt-5.1-codex-mini",name:"GPT-5.1 Codex Mini",targetFormat:"openai-responses"},{id:"gpt-5.1-codex-max",name:"GPT-5.1 Codex Max",targetFormat:"openai-responses"},{id:"gpt-5.2",name:"GPT-5.2"},{id:"gpt-5.2-codex",name:"GPT-5.2 Codex",targetFormat:"openai-responses"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5"},{id:"claude-opus-4.1",name:"Claude Opus 4.1"},{id:"claude-opus-4.6",name:"Claude Opus 4.6"},{id:"claude-opus-4-5-20251101",name:"Claude Opus 4.5 (Full ID)"},{id:"claude-sonnet-4",name:"Claude Sonnet 4"},{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-3-flash-preview",name:"Gemini 3 Flash Preview"},{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"grok-code-fast-1",name:"Grok Code Fast 1"},{id:"oswe-vscode-prime",name:"Raptor Mini"}]},kiro:{id:"kiro",alias:"kr",format:"kiro",executor:"kiro",baseUrl:"https://codewhisperer.us-east-1.amazonaws.com/generateAssistantResponse",authType:"oauth",authHeader:"bearer",headers:{"Content-Type":"application/json",Accept:"application/vnd.amazon.eventstream","X-Amz-Target":"AmazonCodeWhispererStreamingService.GenerateAssistantResponse","User-Agent":"AWS-SDK-JS/3.0.0 kiro-ide/1.0.0","X-Amz-User-Agent":"aws-sdk-js/3.0.0 kiro-ide/1.0.0"},oauth:{tokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authUrl:"https://prod.us-east-1.auth.desktop.kiro.dev"},models:[{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5"}]},cursor:{id:"cursor",alias:"cu",format:"cursor",executor:"cursor",baseUrl:"https://api2.cursor.sh",chatPath:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",authType:"oauth",authHeader:"bearer",headers:{"connect-accept-encoding":"gzip","connect-protocol-version":"1","Content-Type":"application/connect+proto","User-Agent":"connect-es/1.6.1"},clientVersion:"1.1.3",models:[{id:"default",name:"Auto (Server Picks)"},{id:"claude-4.5-opus-high-thinking",name:"Claude 4.5 Opus High Thinking"},{id:"claude-4.5-opus-high",name:"Claude 4.5 Opus High"},{id:"claude-4.5-sonnet-thinking",name:"Claude 4.5 Sonnet Thinking"},{id:"claude-4.5-sonnet",name:"Claude 4.5 Sonnet"},{id:"claude-4.5-haiku",name:"Claude 4.5 Haiku"},{id:"claude-4.5-opus",name:"Claude 4.5 Opus"},{id:"gpt-5.2-codex",name:"GPT 5.2 Codex"}]},openai:{id:"openai",alias:"openai",format:"openai",executor:"default",baseUrl:"https://api.openai.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"gpt-4o",name:"GPT-4o"},{id:"gpt-4o-mini",name:"GPT-4o Mini"},{id:"gpt-4-turbo",name:"GPT-4 Turbo"},{id:"o1",name:"O1"},{id:"o1-mini",name:"O1 Mini"}]},anthropic:{id:"anthropic",alias:"anthropic",format:"claude",executor:"default",baseUrl:"https://api.anthropic.com/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01"},models:[{id:"claude-sonnet-4-20250514",name:"Claude Sonnet 4"},{id:"claude-opus-4-20250514",name:"Claude Opus 4"},{id:"claude-3-5-sonnet-20241022",name:"Claude 3.5 Sonnet"}]},openrouter:{id:"openrouter",alias:"openrouter",format:"openai",executor:"default",baseUrl:"https://openrouter.ai/api/v1/chat/completions",authType:"apikey",authHeader:"bearer",headers:{"HTTP-Referer":"https://endpoint-proxy.local","X-Title":"Endpoint Proxy"},models:[{id:"auto",name:"Auto (Best Available)"}]},glm:{id:"glm",alias:"glm",format:"claude",executor:"default",baseUrl:"https://api.z.ai/api/anthropic/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},models:[{id:"glm-4.7-flash",name:"GLM 4.7 Flash"},{id:"glm-4.7",name:"GLM 4.7"},{id:"glm-4.6v",name:"GLM 4.6V (Vision)"},{id:"glm-4.6",name:"GLM 4.6"},{id:"glm-4.5v",name:"GLM 4.5V (Vision)"},{id:"glm-4.5",name:"GLM 4.5"},{id:"glm-4.5-air",name:"GLM 4.5 Air"},{id:"glm-4-32b",name:"GLM 4 32B"}]},kimi:{id:"kimi",alias:"kimi",format:"openai",executor:"default",baseUrl:"https://api.moonshot.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"kimi-k2.5-thinking",name:"Kimi K2.5 Thinking"},{id:"kimi-latest",name:"Kimi Latest"}]},"kimi-coding":{id:"kimi-coding",alias:"kmc",format:"claude",executor:"default",baseUrl:"https://api.kimi.com/coding/v1/messages",urlSuffix:"?beta=true",authType:"oauth",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},oauth:{clientIdEnv:"KIMI_CODING_OAUTH_CLIENT_ID",clientIdDefault:"17e5f671-d194-4dfb-9706-5516cb48c098",tokenUrl:"https://auth.kimi.com/api/oauth/token",refreshUrl:"https://auth.kimi.com/api/oauth/token",authUrl:"https://auth.kimi.com/api/oauth/device_authorization"},models:[{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"kimi-k2.5-thinking",name:"Kimi K2.5 Thinking"},{id:"kimi-latest",name:"Kimi Latest"}]},kilocode:{id:"kilocode",alias:"kc",format:"openrouter",executor:"openrouter",baseUrl:"https://api.kilo.ai/api/openrouter/chat/completions",modelsUrl:"https://api.kilo.ai/api/openrouter/models",authType:"oauth",authHeader:"Authorization",authPrefix:"Bearer ",oauth:{initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},models:[{id:"openrouter/free",name:"Free Models Router"},{id:"qwen/qwen3-vl-235b-a22b-thinking",name:"Qwen3 VL 235B A22B Thinking"},{id:"qwen/qwen3-235b-a22b-thinking-2507",name:"Qwen3 235B A22B Thinking 2507"},{id:"qwen/qwen3-vl-30b-a3b-thinking",name:"Qwen3 VL 30B A3B Thinking"},{id:"stepfun/step-3.5-flash:free",name:"StepFun Step 3.5 Flash"},{id:"arcee-ai/trinity-large-preview:free",name:"Arcee AI Trinity Large Preview"},{id:"openai/gpt-4o-mini",name:"GPT-4o Mini"},{id:"openai/gpt-4.1-nano",name:"GPT-4.1 Nano"},{id:"openai/gpt-5-nano",name:"GPT-5 Nano"},{id:"openai/gpt-5-mini",name:"GPT-5 Mini"},{id:"anthropic/claude-3-haiku",name:"Claude 3 Haiku"},{id:"google/gemini-2.0-flash",name:"Gemini 2.0 Flash"},{id:"google/gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"},{id:"deepseek/deepseek-chat-v3.1",name:"DeepSeek V3.1"},{id:"deepseek/deepseek-v3.2",name:"DeepSeek V3.2"},{id:"meta-llama/llama-3.3-70b-instruct",name:"Llama 3.3 70B"},{id:"meta-llama/llama-4-scout",name:"Llama 4 Scout"},{id:"meta-llama/llama-4-maverick",name:"Llama 4 Maverick"},{id:"qwen/qwen3-8b",name:"Qwen3 8B"},{id:"qwen/qwen3-32b",name:"Qwen3 32B"},{id:"qwen/qwen3-coder",name:"Qwen3 Coder 480B"},{id:"qwen/qwq-32b",name:"QwQ 32B"},{id:"mistralai/mistral-small-24b-instruct-2501",name:"Mistral Small 3"},{id:"mistralai/mistral-7b-instruct",name:"Mistral 7B"},{id:"x-ai/grok-code-fast-1",name:"Grok Code Fast 1"},{id:"moonshotai/kimi-k2.5",name:"Kimi K2.5"}],passthroughModels:!0},cline:{id:"cline",alias:"cl",format:"openai",executor:"openai",baseUrl:"https://api.cline.bot/api/v1/chat/completions",authType:"oauth",authHeader:"Authorization",authPrefix:"Bearer ",oauth:{tokenUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh",authUrl:"https://api.cline.bot/api/v1/auth/authorize"},extraHeaders:{"HTTP-Referer":"https://cline.bot","X-Title":"Cline"},models:[{id:"anthropic/claude-sonnet-4-20250514",name:"Claude Sonnet 4"},{id:"anthropic/claude-opus-4-20250514",name:"Claude Opus 4"},{id:"google/gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"google/gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"openai/gpt-4.1",name:"GPT-4.1"},{id:"openai/o3",name:"o3"},{id:"deepseek/deepseek-chat",name:"DeepSeek Chat"}],passthroughModels:!0},minimax:{id:"minimax",alias:"minimax",format:"claude",executor:"default",baseUrl:"https://api.minimax.io/anthropic/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},models:[{id:"MiniMax-M2.1",name:"MiniMax M2.1"}]},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",format:"claude",executor:"default",baseUrl:"https://api.minimaxi.com/anthropic/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},models:[{id:"MiniMax-M2.1",name:"MiniMax M2.1"}]},deepseek:{id:"deepseek",alias:"ds",format:"openai",executor:"default",baseUrl:"https://api.deepseek.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"deepseek-chat",name:"DeepSeek V3.2 Chat"},{id:"deepseek-reasoner",name:"DeepSeek V3.2 Reasoner"}]},groq:{id:"groq",alias:"groq",format:"openai",executor:"default",baseUrl:"https://api.groq.com/openai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"llama-3.3-70b-versatile",name:"Llama 3.3 70B"},{id:"meta-llama/llama-4-maverick-17b-128e-instruct",name:"Llama 4 Maverick"},{id:"qwen/qwen3-32b",name:"Qwen3 32B"},{id:"openai/gpt-oss-120b",name:"GPT-OSS 120B"}]},xai:{id:"xai",alias:"xai",format:"openai",executor:"default",baseUrl:"https://api.x.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"grok-4",name:"Grok 4"},{id:"grok-4-fast-reasoning",name:"Grok 4 Fast Reasoning"},{id:"grok-code-fast-1",name:"Grok Code Fast"},{id:"grok-3",name:"Grok 3"}]},mistral:{id:"mistral",alias:"mistral",format:"openai",executor:"default",baseUrl:"https://api.mistral.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"mistral-large-latest",name:"Mistral Large 3"},{id:"codestral-latest",name:"Codestral"},{id:"mistral-medium-latest",name:"Mistral Medium 3"}]},perplexity:{id:"perplexity",alias:"pplx",format:"openai",executor:"default",baseUrl:"https://api.perplexity.ai/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"sonar-pro",name:"Sonar Pro"},{id:"sonar",name:"Sonar"}]},together:{id:"together",alias:"together",format:"openai",executor:"default",baseUrl:"https://api.together.xyz/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"meta-llama/Llama-3.3-70B-Instruct-Turbo",name:"Llama 3.3 70B Turbo"},{id:"deepseek-ai/DeepSeek-R1",name:"DeepSeek R1"},{id:"Qwen/Qwen3-235B-A22B",name:"Qwen3 235B"},{id:"meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",name:"Llama 4 Maverick"}]},fireworks:{id:"fireworks",alias:"fireworks",format:"openai",executor:"default",baseUrl:"https://api.fireworks.ai/inference/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"accounts/fireworks/models/deepseek-v3p1",name:"DeepSeek V3.1"},{id:"accounts/fireworks/models/llama-v3p3-70b-instruct",name:"Llama 3.3 70B"},{id:"accounts/fireworks/models/qwen3-235b-a22b",name:"Qwen3 235B"}]},cerebras:{id:"cerebras",alias:"cerebras",format:"openai",executor:"default",baseUrl:"https://api.cerebras.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"gpt-oss-120b",name:"GPT OSS 120B"},{id:"zai-glm-4.7",name:"ZAI GLM 4.7"},{id:"llama-3.3-70b",name:"Llama 3.3 70B"},{id:"llama-4-scout-17b-16e-instruct",name:"Llama 4 Scout"},{id:"qwen-3-235b-a22b-instruct-2507",name:"Qwen3 235B A22B"},{id:"qwen-3-32b",name:"Qwen3 32B"}]},cohere:{id:"cohere",alias:"cohere",format:"openai",executor:"default",baseUrl:"https://api.cohere.com/v2/chat",authType:"apikey",authHeader:"bearer",models:[{id:"command-r-plus-08-2024",name:"Command R+ (Aug 2024)"},{id:"command-r-08-2024",name:"Command R (Aug 2024)"},{id:"command-a-03-2025",name:"Command A (Mar 2025)"}]},nvidia:{id:"nvidia",alias:"nvidia",format:"openai",executor:"default",baseUrl:"https://integrate.api.nvidia.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"moonshotai/kimi-k2.5",name:"Kimi K2.5"},{id:"z-ai/glm4.7",name:"GLM 4.7"},{id:"deepseek-ai/deepseek-v3.2",name:"DeepSeek V3.2"},{id:"nvidia/llama-3.3-70b-instruct",name:"Llama 3.3 70B"},{id:"meta/llama-4-maverick-17b-128e-instruct",name:"Llama 4 Maverick"},{id:"deepseek/deepseek-r1",name:"DeepSeek R1"}]},nebius:{id:"nebius",alias:"nebius",format:"openai",executor:"default",baseUrl:"https://api.tokenfactory.nebius.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"meta-llama/Llama-3.3-70B-Instruct",name:"Llama 3.3 70B Instruct"}]},siliconflow:{id:"siliconflow",alias:"siliconflow",format:"openai",executor:"default",baseUrl:"https://api.siliconflow.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"deepseek-ai/DeepSeek-V3.2",name:"DeepSeek V3.2"},{id:"deepseek-ai/DeepSeek-V3.1",name:"DeepSeek V3.1"},{id:"deepseek-ai/DeepSeek-R1",name:"DeepSeek R1"},{id:"Qwen/Qwen3-235B-A22B-Instruct-2507",name:"Qwen3 235B"},{id:"Qwen/Qwen3-Coder-480B-A35B-Instruct",name:"Qwen3 Coder 480B"},{id:"Qwen/Qwen3-32B",name:"Qwen3 32B"},{id:"moonshotai/Kimi-K2.5",name:"Kimi K2.5"},{id:"zai-org/GLM-4.7",name:"GLM 4.7"},{id:"openai/gpt-oss-120b",name:"GPT OSS 120B"},{id:"baidu/ERNIE-4.5-300B-A47B",name:"ERNIE 4.5 300B"}]},hyperbolic:{id:"hyperbolic",alias:"hyp",format:"openai",executor:"default",baseUrl:"https://api.hyperbolic.xyz/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"Qwen/QwQ-32B",name:"QwQ 32B"},{id:"deepseek-ai/DeepSeek-R1",name:"DeepSeek R1"},{id:"deepseek-ai/DeepSeek-V3",name:"DeepSeek V3"},{id:"meta-llama/Llama-3.3-70B-Instruct",name:"Llama 3.3 70B"},{id:"meta-llama/Llama-3.2-3B-Instruct",name:"Llama 3.2 3B"},{id:"Qwen/Qwen2.5-72B-Instruct",name:"Qwen 2.5 72B"},{id:"Qwen/Qwen2.5-Coder-32B-Instruct",name:"Qwen 2.5 Coder 32B"},{id:"NousResearch/Hermes-3-Llama-3.1-70B",name:"Hermes 3 70B"}]}},e=new Map;for(let a of Object.values(d))a.alias&&a.alias!==a.id&&e.set(a.alias,a);let f=function(){let a={};for(let b of Object.values(d))if(b.models&&b.models.length>0){let c=b.alias||b.id;a[c]||(a[c]=b.models)}return a}(),g=function(){let a={};for(let b of Object.values(d))a[b.id]=b.alias||b.id;return a}();function h(a){return f[g[a]||a]||[]}},97496:(a,b,c)=>{Promise.resolve().then(c.bind(c,81227))},97507:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>e});var d=c(48249);function e({error:a,reset:b}){return(0,d.jsxs)("div",{className:"flex flex-col items-center justify-center min-h-[60vh] p-6 text-center",role:"alert","aria-live":"assertive",children:[(0,d.jsx)("div",{className:"text-[64px] mb-4","aria-hidden":"true",children:"\uD83D\uDD27"}),(0,d.jsx)("h1",{className:"text-[28px] font-bold mb-2 text-[var(--color-text-main)]",children:"Internal Server Error"}),(0,d.jsx)("p",{className:"text-[15px] text-[var(--color-text-muted)] max-w-[400px] leading-relaxed mb-2",children:"Something went wrong while processing your request. Our team has been notified and is working on a fix."}),a?.digest&&(0,d.jsxs)("p",{className:"text-xs text-[var(--color-text-muted)] mb-6 font-mono",children:["Error ID: ",a.digest]}),!1,(0,d.jsxs)("div",{className:"flex gap-3",children:[(0,d.jsx)("button",{onClick:b,"aria-label":"Retry loading the page",className:"px-6 py-2.5 rounded-lg text-white text-sm font-semibold cursor-pointer transition-all duration-200 bg-[var(--color-accent)] hover:bg-[var(--color-accent-hover)] focus:outline-2 focus:outline-offset-2 focus:outline-[var(--color-accent)]",children:"Try Again"}),(0,d.jsx)("a",{href:"/dashboard",className:"px-6 py-2.5 rounded-lg text-[var(--color-text-main)] text-sm font-semibold cursor-pointer transition-all duration-200 border border-[var(--color-border)] hover:bg-[var(--color-bg-alt)] no-underline focus:outline-2 focus:outline-offset-2 focus:outline-[var(--color-accent)]","aria-label":"Return to dashboard",children:"Go to Dashboard"})]})]})}}};
|
|
2
|
+
${a}`),Error(`Provider validation failed for ${b}`)}}let h={iflow:{id:"iflow",alias:"if",name:"iFlow AI",icon:"water_drop",color:"#6366F1"},qwen:{id:"qwen",alias:"qw",name:"Qwen Code",icon:"psychology",color:"#10B981"},"gemini-cli":{id:"gemini-cli",alias:"gc",name:"Gemini CLI",icon:"terminal",color:"#4285F4"},kiro:{id:"kiro",alias:"kr",name:"Kiro AI",icon:"psychology_alt",color:"#FF6B35"}},i={claude:{id:"claude",alias:"cc",name:"Claude Code",icon:"smart_toy",color:"#D97757"},antigravity:{id:"antigravity",alias:"ag",name:"Antigravity",icon:"rocket_launch",color:"#F59E0B"},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"}},j={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"},kimi:{id:"kimi",alias:"kimi",name:"Kimi",icon:"psychology",color:"#1E3A8A",textIcon:"KM",website:"https://kimi.moonshot.cn"},minimax:{id:"minimax",alias:"minimax",name:"Minimax Coding",icon:"memory",color:"#7C3AED",textIcon:"MM",website:"https://www.minimaxi.com"},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",name:"Minimax (China)",icon:"memory",color:"#DC2626",textIcon:"MC",website:"https://www.minimaxi.com"},openai:{id:"openai",alias:"openai",name:"OpenAI",icon:"auto_awesome",color:"#10A37F",textIcon:"OA",website:"https://platform.openai.com"},anthropic:{id:"anthropic",alias:"anthropic",name:"Anthropic",icon:"smart_toy",color:"#D97757",textIcon:"AN",website:"https://console.anthropic.com"},gemini:{id:"gemini",alias:"gemini",name:"Gemini",icon:"diamond",color:"#4285F4",textIcon:"GE",website:"https://ai.google.dev"},deepseek:{id:"deepseek",alias:"ds",name:"DeepSeek",icon:"bolt",color:"#4D6BFE",textIcon:"DS",website:"https://deepseek.com"},groq:{id:"groq",alias:"groq",name:"Groq",icon:"speed",color:"#F55036",textIcon:"GQ",website:"https://groq.com"},xai:{id:"xai",alias:"xai",name:"xAI (Grok)",icon:"auto_awesome",color:"#1DA1F2",textIcon:"XA",website:"https://x.ai"},mistral:{id:"mistral",alias:"mistral",name:"Mistral",icon:"air",color:"#FF7000",textIcon:"MI",website:"https://mistral.ai"},perplexity:{id:"perplexity",alias:"pplx",name:"Perplexity",icon:"search",color:"#20808D",textIcon:"PP",website:"https://www.perplexity.ai"},together:{id:"together",alias:"together",name:"Together AI",icon:"group_work",color:"#0F6FFF",textIcon:"TG",website:"https://www.together.ai"},fireworks:{id:"fireworks",alias:"fireworks",name:"Fireworks AI",icon:"local_fire_department",color:"#7B2EF2",textIcon:"FW",website:"https://fireworks.ai"},cerebras:{id:"cerebras",alias:"cerebras",name:"Cerebras",icon:"memory",color:"#FF4F00",textIcon:"CB",website:"https://www.cerebras.ai"},cohere:{id:"cohere",alias:"cohere",name:"Cohere",icon:"hub",color:"#39594D",textIcon:"CO",website:"https://cohere.com"},nvidia:{id:"nvidia",alias:"nvidia",name:"NVIDIA NIM",icon:"developer_board",color:"#76B900",textIcon:"NV",website:"https://developer.nvidia.com/nim"},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"}},k="openai-compatible-",l="anthropic-compatible-";function m(a){return"string"==typeof a&&a.startsWith(k)}function n(a){return"string"==typeof a&&a.startsWith(l)}let o={...h,...i,...j},p={oauth:{id:"oauth",name:"OAuth",icon:"lock"},apikey:{id:"apikey",name:"API Key",icon:"key"}};function q(a){for(let b of Object.values(o))if(b.alias===a||b.id===a)return b;return null}function r(a){let b=o[a];return b?.alias||a}Object.values(o).reduce((a,b)=>(a[b.alias]=b.id,a),{}),Object.values(o).reduce((a,b)=>(a[b.id]=b.alias,a),{});let s=["antigravity","kiro","github","codex","claude"];g(h,"FREE_PROVIDERS"),g(i,"OAUTH_PROVIDERS"),g(j,"APIKEY_PROVIDERS")},21280:(a,b,c)=>{"use strict";c.d(b,{S_:()=>m});var d=c(22901),e=c(87068);let f="[HealthCheck]",g=null,h=0,i=null;async function j(){let a=Date.now();return null!==g&&a-h<3e4?g:null!==i?i:i=(async()=>{try{let b=await (0,d.V7)();return g=!0===b.hideHealthCheckLogs,h=a,g}catch{return!1}finally{i=null}})()}function k(a,...b){j().then(c=>{c||console.log(a,...b)})}function l(a,...b){j().then(c=>{c||console.error(a,...b)})}function m(){g=null,h=0}let n=!1;async function o(){try{let a=await (0,d.getProviderConnections)({authType:"oauth"});if(!a||0===a.length)return;for(let b of a)try{await p(b)}catch(a){l(`${f} Error checking ${b.name||b.id}:`,a.message)}}catch(a){l(`${f} Sweep error:`,a.message)}}async function p(a){let b=a.healthCheckInterval??60;if(b<=0||!a.isActive||!a.refreshToken||"string"!=typeof a.refreshToken||"expired"===a.testStatus)return;if(!(0,e.Ny)(a.provider)){let b=new Date().toISOString();await (0,d.rj)(a.id,{lastHealthCheckAt:b}),k(`${f} Skipping ${a.provider}/${a.name||a.email||a.id} (refresh unsupported)`);return}let c=a.lastHealthCheckAt?new Date(a.lastHealthCheckAt).getTime():0;if(Date.now()-c<60*b*1e3)return;k(`${f} Refreshing ${a.provider}/${a.name||a.email||a.id} (interval: ${b}min)`);let g={refreshToken:a.refreshToken,accessToken:a.accessToken,expiresAt:a.tokenExpiresAt,providerSpecificData:a.providerSpecificData},h=await j(),i=await (0,e.iD)(a.provider,g,{info:(a,b)=>{h||console.log(`${f} [${a}] ${b}`)},warn:(a,b)=>{h||console.warn(`${f} [${a}] ${b}`)},error:(a,b,c)=>{h||console.error(`${f} [${a}] ${b}`,c||"")}}),m=new Date().toISOString();if((0,e.jT)(i)){await (0,d.rj)(a.id,{lastHealthCheckAt:m,testStatus:"expired",lastError:`Refresh token consumed (${i.error}). Please re-authenticate this account.`,lastErrorAt:m,lastErrorType:i.error,lastErrorSource:"oauth",errorCode:i.error,isActive:!1,refreshToken:null}),l(`${f} ✗ ${a.provider}/${a.name||a.email||a.id} — Refresh token is permanently invalid (${i.error}). Connection deactivated. Re-authenticate to restore.`);return}if(i&&i.accessToken){let b={accessToken:i.accessToken,lastHealthCheckAt:m,testStatus:"active",lastError:null,lastErrorAt:null,lastErrorType:null,lastErrorSource:null,errorCode:null};i.refreshToken&&(b.refreshToken=i.refreshToken),i.expiresIn&&(b.tokenExpiresAt=new Date(Date.now()+1e3*i.expiresIn).toISOString()),await (0,d.rj)(a.id,b),k(`${f} ✓ ${a.provider}/${a.name||a.email||a.id} refreshed`)}else await (0,d.rj)(a.id,{lastHealthCheckAt:m,testStatus:"error",lastError:"Health check: token refresh failed",lastErrorAt:m,lastErrorType:"token_refresh_failed",lastErrorSource:"oauth",errorCode:"refresh_failed"}),function(a,...b){j().then(c=>{c||console.warn(a,...b)})}(`${f} ✗ ${a.provider}/${a.name||a.email||a.id} refresh failed`)}n=!0,k(`${f} Starting proactive token health-check (tick every 60s)`),setTimeout(()=>{o(),setInterval(o,6e4)},1e4)},32444:(a,b,c)=>{"use strict";c.d(b,{ThemeProvider:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call ThemeProvider() from the server but ThemeProvider is on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/shared/components/ThemeProvider.tsx","ThemeProvider")},34017:(a,b,c)=>{"use strict";c.d(b,{A:()=>g});var d=c(29389),e=c(65573);let f=["en","pt-BR"],g=(0,d.A)(async()=>{let a=await (0,e.UL)(),b=a.get("NEXT_LOCALE")?.value||"";b||(b=(await (0,e.b3)()).get("x-locale")||""),f.includes(b)||(b="en");let d=(await c(3845)(`./${b}.json`)).default;return{locale:b,messages:d}})},39710:(a,b,c)=>{Promise.resolve().then(c.bind(c,97507))},44438:(a,b,c)=>{Promise.resolve().then(c.bind(c,64385))},47695:(a,b,c)=>{"use strict";c.d(b,{A:()=>g});var d=c(31417),e=c(300),f=c(73959);let g=(0,d.v)()((0,e.Zr)((a,b)=>({theme:f.B2.defaultTheme,setTheme:b=>{a({theme:b})},toggleTheme:()=>{let c="dark"===b().theme?"light":"dark";a({theme:c})},initTheme:()=>{b().theme}}),{name:f.B2.storageKey}))},47825:(a,b,c)=>{"use strict";c.d(b,{KC:()=>d.KC,Xg:()=>d.Xg});var d=c(97319);Object.entries(c(17084).Q2).filter(([,a])=>a.passthroughModels).map(([a])=>a),Object.entries(d.vq).flatMap(([a,b])=>b.map(b=>({provider:a,model:b.id,name:b.name})))},49226:(a,b,c)=>{"use strict";c.d(b,{A:()=>k});var d=c(90357),e=c(22901);let f=process.env.BASE_URL||process.env.NEXT_PUBLIC_BASE_URL||process.env.NEXT_PUBLIC_APP_URL||"http://localhost:20128";class g{constructor(a=null,b=15){this.machineId=a,this.intervalMinutes=b,this.intervalId=null}async initializeMachineId(){this.machineId||(this.machineId=await (0,d.Xj)())}async start(){this.intervalId||(await this.initializeMachineId(),setTimeout(()=>{this.syncWithRetry().catch(()=>{})},3e4),this.intervalId=setInterval(()=>{this.syncWithRetry().catch(()=>{})},60*this.intervalMinutes*1e3))}stop(){this.intervalId&&(clearInterval(this.intervalId),this.intervalId=null)}async syncWithRetry(a=1){for(let b=1;b<=a;b++)try{return await this.sync()}catch(d){if(b===a)return null;let c=Math.min(1e3*Math.pow(2,b),1e4);await new Promise(a=>setTimeout(a,c))}}async sync(){if(!await (0,e.Nx)())return null;await this.initializeMachineId();let a=await fetch(`${f}/api/sync/cloud`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({machineId:this.machineId,action:"sync"})});if(!a.ok)throw Error((await a.json().catch(()=>({}))).error||"Sync failed");return await a.json()}isRunning(){return null!==this.intervalId}}let h=null;async function i(a=null,b=15){return h||(h=new g(a,b)),h}async function j(){try{await (0,e.bI)();let a=await i(null,15);return await a.start(),a}catch(a){throw console.error("[CloudSync] Error initializing scheduler:",a),a}}a=c.hmd(a),c.c[c.s]===a&&j().catch(a=>console.error("[CloudSync] init failed:",a));let k=j},61135:()=>{},64385:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call the default export of \"/home/runner/work/OmniRoute/OmniRoute/src/app/error.tsx\" from the server, but it's on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/app/error.tsx","default")},67045:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>e});var d=c(48249);function e({error:a,reset:b}){return(0,d.jsx)("html",{lang:"en",children:(0,d.jsx)("body",{className:"flex flex-col items-center justify-center min-h-screen p-6 bg-[#0a0a0f] text-[#e0e0e0] font-[system-ui,-apple-system,sans-serif] text-center m-0",children:(0,d.jsxs)("main",{role:"alert","aria-live":"assertive",className:"flex flex-col items-center",children:[(0,d.jsx)("div",{className:"text-[64px] mb-4","aria-hidden":"true",children:"⚠️"}),(0,d.jsx)("h1",{className:"text-[28px] font-bold mb-2",children:"Something went wrong"}),(0,d.jsx)("p",{className:"text-[15px] text-[#888] max-w-[400px] leading-relaxed mb-6",children:"An unexpected error occurred. This has been logged and our team will investigate."}),!1,(0,d.jsx)("button",{onClick:b,"aria-label":"Retry loading the page",className:"px-8 py-3 rounded-[10px] text-white border-none text-sm font-semibold cursor-pointer transition-transform duration-200 shadow-[0_4px_16px_rgba(99,102,241,0.3)] hover:-translate-y-0.5 bg-gradient-to-br from-[#6366f1] to-[#8b5cf6] focus:outline-2 focus:outline-offset-2 focus:outline-[#6366f1]",children:"Try Again"})]})})})}},69199:(a,b,c)=>{Promise.resolve().then(c.bind(c,86392)),Promise.resolve().then(c.bind(c,32444))},73857:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>g});var d=c(48249),e=c(2116),f=c.n(e);function g(){return(0,d.jsxs)("div",{className:"flex flex-col items-center justify-center min-h-screen p-6 bg-bg text-text-main text-center",role:"main","aria-labelledby":"not-found-title",children:[(0,d.jsx)("div",{className:"text-[96px] font-extrabold leading-none mb-2 bg-gradient-to-br from-primary to-primary-hover bg-clip-text text-transparent","aria-hidden":"true",children:"404"}),(0,d.jsx)("h1",{id:"not-found-title",className:"text-2xl font-semibold mb-2",children:"Page not found"}),(0,d.jsx)("p",{className:"text-[15px] text-text-muted max-w-[400px] leading-relaxed mb-8",children:"The page you're looking for doesn't exist or has been moved."}),(0,d.jsx)(f(),{href:"/dashboard",className:"px-8 py-3 rounded-xl text-white text-sm font-medium no-underline transition-all duration-200 shadow-warm hover:-translate-y-0.5 bg-gradient-to-br from-primary to-primary-hover hover:shadow-elevated focus:outline-2 focus:outline-offset-2 focus:outline-primary","aria-label":"Return to dashboard",children:"Go to Dashboard"})]})}},73959:(a,b,c)=>{"use strict";c.d(b,{Q2:()=>d.Q2,fg:()=>d.fg,vQ:()=>e,MA:()=>d.MA,zN:()=>d.zN,B2:()=>f});var d=c(17084);c(47825);let e={name:"OmniRoute",description:"AI Gateway for Multi-Provider LLMs",version:"1.4.11"},f={storageKey:"theme",defaultTheme:"system"}},75146:(a,b,c)=>{"use strict";c.d(b,{ThemeProvider:()=>f});var d=c(48249);c(67484);var e=c(47695);function f({children:a}){let{initTheme:b}=(0,e.A)();return(0,d.jsx)(d.Fragment,{children:a})}},76160:(a,b,c)=>{Promise.resolve().then(c.bind(c,73857))},76537:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>l,metadata:()=>k});var d=c(5735),e=c(50609),f=c.n(e);c(61135);var g=c(32444);c(91057);var h=c(68625),i=c(62026),j=c(28440);let k={title:"OmniRoute — AI Gateway for Multi-Provider LLMs",description:"OmniRoute is an AI gateway for multi-provider LLMs. One endpoint for all your AI providers.",icons:{icon:"/favicon.svg",apple:"/apple-touch-icon.svg"}};async function l({children:a}){let b=await (0,i.A)(),c=await (0,j.A)();return(0,d.jsxs)("html",{lang:b,suppressHydrationWarning:!0,children:[(0,d.jsxs)("head",{children:[(0,d.jsx)("link",{rel:"preconnect",href:"https://fonts.googleapis.com"}),(0,d.jsx)("link",{rel:"preconnect",href:"https://fonts.gstatic.com",crossOrigin:"anonymous"}),(0,d.jsx)("link",{href:"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@20..48,100..700,0..1,-50..200&display=swap",rel:"stylesheet"})]}),(0,d.jsxs)("body",{className:`${f().variable} font-sans antialiased`,suppressHydrationWarning:!0,children:[(0,d.jsx)("a",{href:"#main-content",className:"sr-only focus:not-sr-only focus:absolute focus:top-2 focus:left-2 focus:z-50 focus:px-4 focus:py-2 focus:bg-[#6366f1] focus:text-white focus:rounded-lg focus:text-sm focus:font-semibold focus:shadow-lg",children:"Skip to content"}),(0,d.jsx)(h.A,{locale:b,messages:c,children:(0,d.jsx)(g.ThemeProvider,{children:a})})]})]})}},77447:(a,b,c)=>{Promise.resolve().then(c.bind(c,62626)),Promise.resolve().then(c.bind(c,75146))},79369:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,60440,23)),Promise.resolve().then(c.t.bind(c,84342,23)),Promise.resolve().then(c.t.bind(c,82265,23)),Promise.resolve().then(c.t.bind(c,35421,23)),Promise.resolve().then(c.t.bind(c,61335,23)),Promise.resolve().then(c.t.bind(c,70664,23)),Promise.resolve().then(c.bind(c,74661))},81227:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>d});let d=(0,c(77943).registerClientReference)(function(){throw Error("Attempted to call the default export of \"/home/runner/work/OmniRoute/OmniRoute/src/app/global-error.tsx\" from the server, but it's on the client. It's not possible to invoke a client function from the server, it can only be rendered as a Component or passed to props of a Client Component.")},"/home/runner/work/OmniRoute/OmniRoute/src/app/global-error.tsx","default")},89097:(a,b,c)=>{Promise.resolve().then(c.t.bind(c,15098,23)),Promise.resolve().then(c.t.bind(c,47644,23)),Promise.resolve().then(c.t.bind(c,33859,23)),Promise.resolve().then(c.t.bind(c,98099,23)),Promise.resolve().then(c.t.bind(c,16237,23)),Promise.resolve().then(c.t.bind(c,98562,23)),Promise.resolve().then(c.t.bind(c,36675,23))},90357:(a,b,c)=>{"use strict";c.d(b,{Xj:()=>e});var d=c(19713);async function e(a=null){let b=a||process.env.MACHINE_ID_SALT||"endpoint-proxy-salt";try{let a=(0,d.machineIdSync)();return(await Promise.resolve().then(c.t.bind(c,55511,23))).createHash("sha256").update(a+b).digest("hex").substring(0,16)}catch(a){return console.log("Error getting machine ID:",a),crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,function(a){let b=16*Math.random()|0;return("x"==a?b:3&b|8).toString(16)})}}},91057:(a,b,c)=>{"use strict";var d=c(49226);c(21280);let e=!1;(async function(){if(!e)try{await (0,d.A)(),e=!0}catch(a){console.error("[ServerInit] Error initializing cloud sync:",a)}return e})().catch(a=>console.error("[CloudSync] ensure failed:",a))},97319:(a,b,c)=>{"use strict";c.d(b,{Xg:()=>g,vq:()=>f,KC:()=>h});let d={claude:{id:"claude",alias:"cc",format:"claude",executor:"default",baseUrl:"https://api.anthropic.com/v1/messages",urlSuffix:"?beta=true",authType:"oauth",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,oauth-2025-04-20,interleaved-thinking-2025-05-14,fine-grained-tool-streaming-2025-05-14,context-management-2025-06-27","Anthropic-Dangerous-Direct-Browser-Access":"true","User-Agent":"claude-cli/1.0.83 (external, cli)","X-App":"cli","X-Stainless-Helper-Method":"stream","X-Stainless-Retry-Count":"0","X-Stainless-Runtime-Version":"v24.3.0","X-Stainless-Package-Version":"0.55.1","X-Stainless-Runtime":"node","X-Stainless-Lang":"js","X-Stainless-Arch":"arm64","X-Stainless-Os":"MacOS","X-Stainless-Timeout":"60"},oauth:{clientIdEnv:"CLAUDE_OAUTH_CLIENT_ID",clientIdDefault:"9d1c250a-e61b-44d9-88ed-5944d1962f5e",tokenUrl:"https://console.anthropic.com/v1/oauth/token"},models:[{id:"claude-opus-4-6",name:"Claude Opus 4.6"},{id:"claude-opus-4-5-20251101",name:"Claude 4.5 Opus"},{id:"claude-sonnet-4-5-20250929",name:"Claude 4.5 Sonnet"},{id:"claude-haiku-4-5-20251001",name:"Claude 4.5 Haiku"}]},gemini:{id:"gemini",alias:"gemini",format:"gemini",executor:"default",baseUrl:"https://generativelanguage.googleapis.com/v1beta/models",urlBuilder:(a,b,c)=>`${a}/${b}:${c?"streamGenerateContent?alt=sse":"generateContent"}`,authType:"apikey",authHeader:"x-goog-api-key",oauth:{clientIdEnv:"GEMINI_OAUTH_CLIENT_ID",clientIdDefault:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecretEnv:"GEMINI_OAUTH_CLIENT_SECRET",clientSecretDefault:"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"},models:[{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"}]},"gemini-cli":{id:"gemini-cli",alias:"gc",format:"gemini-cli",executor:"gemini-cli",baseUrl:"https://cloudcode-pa.googleapis.com/v1internal",urlBuilder:(a,b,c)=>`${a}:${c?"streamGenerateContent?alt=sse":"generateContent"}`,authType:"oauth",authHeader:"bearer",oauth:{clientIdEnv:"GEMINI_CLI_OAUTH_CLIENT_ID",clientIdDefault:"681255809395-oo8ft2oprdrnp9e3aqf6av3hmdib135j.apps.googleusercontent.com",clientSecretEnv:"GEMINI_CLI_OAUTH_CLIENT_SECRET",clientSecretDefault:"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"},models:[{id:"gemini-3-flash-preview",name:"Gemini 3 Flash Preview"},{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"}]},codex:{id:"codex",alias:"cx",format:"openai-responses",executor:"codex",baseUrl:"https://chatgpt.com/backend-api/codex/responses",authType:"oauth",authHeader:"bearer",headers:{Version:"0.92.0","Openai-Beta":"responses=experimental","User-Agent":"codex-cli/0.92.0 (Windows 10.0.26100; x64)"},oauth:{clientIdEnv:"CODEX_OAUTH_CLIENT_ID",clientIdDefault:"app_EMoamEEZ73f0CkXaXp7hrann",clientSecretEnv:"CODEX_OAUTH_CLIENT_SECRET",clientSecretDefault:"",tokenUrl:"https://auth.openai.com/oauth/token"},models:[{id:"gpt-5.3-codex",name:"GPT 5.3 Codex"},{id:"gpt-5.3-codex-xhigh",name:"GPT 5.3 Codex (xHigh)"},{id:"gpt-5.3-codex-high",name:"GPT 5.3 Codex (High)"},{id:"gpt-5.3-codex-low",name:"GPT 5.3 Codex (Low)"},{id:"gpt-5.3-codex-none",name:"GPT 5.3 Codex (None)"},{id:"gpt-5.1-codex-mini",name:"GPT 5.1 Codex Mini"},{id:"gpt-5.1-codex-mini-high",name:"GPT 5.1 Codex Mini (High)"},{id:"gpt-5.2-codex",name:"GPT 5.2 Codex"},{id:"gpt-5.2",name:"GPT 5.2"},{id:"gpt-5.1-codex-max",name:"GPT 5.1 Codex Max"},{id:"gpt-5.1-codex",name:"GPT 5.1 Codex"},{id:"gpt-5.1",name:"GPT 5.1"},{id:"gpt-5-codex",name:"GPT 5 Codex"},{id:"gpt-5-codex-mini",name:"GPT 5 Codex Mini"}]},qwen:{id:"qwen",alias:"qw",format:"openai",executor:"default",baseUrl:"https://portal.qwen.ai/v1/chat/completions",authType:"oauth",authHeader:"bearer",headers:{"User-Agent":"google-api-nodejs-client/9.15.1","X-Goog-Api-Client":"gl-node/22.17.0"},oauth:{clientIdEnv:"QWEN_OAUTH_CLIENT_ID",clientIdDefault:"f0304373b74a44d2b584a3fb70ca9e56",tokenUrl:"https://chat.qwen.ai/api/v1/oauth2/token",authUrl:"https://chat.qwen.ai/api/v1/oauth2/device/code"},models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus"},{id:"qwen3-coder-flash",name:"Qwen3 Coder Flash"},{id:"vision-model",name:"Qwen3 Vision Model"}]},iflow:{id:"iflow",alias:"if",format:"openai",executor:"iflow",baseUrl:"https://apis.iflow.cn/v1/chat/completions",authType:"oauth",authHeader:"bearer",headers:{"User-Agent":"iFlow-Cli"},oauth:{clientIdEnv:"IFLOW_OAUTH_CLIENT_ID",clientIdDefault:"10009311001",clientSecretEnv:"IFLOW_OAUTH_CLIENT_SECRET",clientSecretDefault:"4Z3YjXycVsQvyGF1etiNlIBB4RsqSDtW",tokenUrl:"https://iflow.cn/oauth/token",authUrl:"https://iflow.cn/oauth"},models:[{id:"qwen3-coder-plus",name:"Qwen3 Coder Plus"},{id:"kimi-k2",name:"Kimi K2"},{id:"kimi-k2-thinking",name:"Kimi K2 Thinking"},{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"deepseek-r1",name:"DeepSeek R1"},{id:"deepseek-v3.2-chat",name:"DeepSeek V3.2 Chat"},{id:"deepseek-v3.2-reasoner",name:"DeepSeek V3.2 Reasoner"},{id:"minimax-m2.1",name:"MiniMax M2.1"},{id:"glm-4.7",name:"GLM 4.7"}]},antigravity:{id:"antigravity",alias:"ag",format:"antigravity",executor:"antigravity",baseUrls:["https://daily-cloudcode-pa.googleapis.com","https://cloudcode-pa.googleapis.com"],urlBuilder:(a,b,c)=>`${a}${c?"/v1internal:streamGenerateContent?alt=sse":"/v1internal:generateContent"}`,authType:"oauth",authHeader:"bearer",headers:{"User-Agent":"antigravity/1.104.0 darwin/arm64"},oauth:{clientIdEnv:"ANTIGRAVITY_OAUTH_CLIENT_ID",clientIdDefault:"1071006060591-tmhssin2h21lcre235vtolojh4g403ep.apps.googleusercontent.com",clientSecretEnv:"ANTIGRAVITY_OAUTH_CLIENT_SECRET",clientSecretDefault:"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"},models:[{id:"claude-opus-4-6-thinking",name:"Claude Opus 4.6 Thinking"},{id:"claude-sonnet-4-6",name:"Claude Sonnet 4.6"},{id:"gemini-3.1-pro-high",name:"Gemini 3.1 Pro High"},{id:"gemini-3.1-pro-low",name:"Gemini 3.1 Pro Low"},{id:"gemini-3-flash",name:"Gemini 3 Flash"},{id:"gpt-oss-120b-medium",name:"GPT OSS 120B Medium"}]},github:{id:"github",alias:"gh",format:"openai",executor:"github",baseUrl:"https://api.githubcopilot.com/chat/completions",responsesBaseUrl:"https://api.githubcopilot.com/responses",authType:"oauth",authHeader:"bearer",headers:{"copilot-integration-id":"vscode-chat","editor-version":"vscode/1.107.1","editor-plugin-version":"copilot-chat/0.26.7","user-agent":"GitHubCopilotChat/0.26.7","openai-intent":"conversation-panel","x-github-api-version":"2025-04-01","x-vscode-user-agent-library-version":"electron-fetch","X-Initiator":"user",Accept:"application/json","Content-Type":"application/json"},models:[{id:"gpt-4.1",name:"GPT-4.1"},{id:"gpt-4o",name:"GPT-4o"},{id:"gpt-4o-mini",name:"GPT-4o Mini"},{id:"gpt-4",name:"GPT-4"},{id:"gpt-3.5-turbo",name:"GPT-3.5 Turbo"},{id:"gpt-5",name:"GPT-5"},{id:"gpt-5-mini",name:"GPT-5 Mini"},{id:"gpt-5-codex",name:"GPT-5 Codex",targetFormat:"openai-responses"},{id:"gpt-5.1",name:"GPT-5.1"},{id:"gpt-5.1-codex",name:"GPT-5.1 Codex",targetFormat:"openai-responses"},{id:"gpt-5.1-codex-mini",name:"GPT-5.1 Codex Mini",targetFormat:"openai-responses"},{id:"gpt-5.1-codex-max",name:"GPT-5.1 Codex Max",targetFormat:"openai-responses"},{id:"gpt-5.2",name:"GPT-5.2"},{id:"gpt-5.2-codex",name:"GPT-5.2 Codex",targetFormat:"openai-responses"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5"},{id:"claude-opus-4.1",name:"Claude Opus 4.1"},{id:"claude-opus-4.6",name:"Claude Opus 4.6"},{id:"claude-opus-4-5-20251101",name:"Claude Opus 4.5 (Full ID)"},{id:"claude-sonnet-4",name:"Claude Sonnet 4"},{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5"},{id:"gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"gemini-3-flash-preview",name:"Gemini 3 Flash Preview"},{id:"gemini-3-pro-preview",name:"Gemini 3 Pro Preview"},{id:"grok-code-fast-1",name:"Grok Code Fast 1"},{id:"oswe-vscode-prime",name:"Raptor Mini"}]},kiro:{id:"kiro",alias:"kr",format:"kiro",executor:"kiro",baseUrl:"https://codewhisperer.us-east-1.amazonaws.com/generateAssistantResponse",authType:"oauth",authHeader:"bearer",headers:{"Content-Type":"application/json",Accept:"application/vnd.amazon.eventstream","X-Amz-Target":"AmazonCodeWhispererStreamingService.GenerateAssistantResponse","User-Agent":"AWS-SDK-JS/3.0.0 kiro-ide/1.0.0","X-Amz-User-Agent":"aws-sdk-js/3.0.0 kiro-ide/1.0.0"},oauth:{tokenUrl:"https://prod.us-east-1.auth.desktop.kiro.dev/refreshToken",authUrl:"https://prod.us-east-1.auth.desktop.kiro.dev"},models:[{id:"claude-sonnet-4.5",name:"Claude Sonnet 4.5"},{id:"claude-haiku-4.5",name:"Claude Haiku 4.5"}]},cursor:{id:"cursor",alias:"cu",format:"cursor",executor:"cursor",baseUrl:"https://api2.cursor.sh",chatPath:"/aiserver.v1.ChatService/StreamUnifiedChatWithTools",authType:"oauth",authHeader:"bearer",headers:{"connect-accept-encoding":"gzip","connect-protocol-version":"1","Content-Type":"application/connect+proto","User-Agent":"connect-es/1.6.1"},clientVersion:"1.1.3",models:[{id:"default",name:"Auto (Server Picks)"},{id:"claude-4.5-opus-high-thinking",name:"Claude 4.5 Opus High Thinking"},{id:"claude-4.5-opus-high",name:"Claude 4.5 Opus High"},{id:"claude-4.5-sonnet-thinking",name:"Claude 4.5 Sonnet Thinking"},{id:"claude-4.5-sonnet",name:"Claude 4.5 Sonnet"},{id:"claude-4.5-haiku",name:"Claude 4.5 Haiku"},{id:"claude-4.5-opus",name:"Claude 4.5 Opus"},{id:"gpt-5.2-codex",name:"GPT 5.2 Codex"}]},openai:{id:"openai",alias:"openai",format:"openai",executor:"default",baseUrl:"https://api.openai.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"gpt-4o",name:"GPT-4o"},{id:"gpt-4o-mini",name:"GPT-4o Mini"},{id:"gpt-4-turbo",name:"GPT-4 Turbo"},{id:"o1",name:"O1"},{id:"o1-mini",name:"O1 Mini"}]},anthropic:{id:"anthropic",alias:"anthropic",format:"claude",executor:"default",baseUrl:"https://api.anthropic.com/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01"},models:[{id:"claude-sonnet-4-20250514",name:"Claude Sonnet 4"},{id:"claude-opus-4-20250514",name:"Claude Opus 4"},{id:"claude-3-5-sonnet-20241022",name:"Claude 3.5 Sonnet"}]},openrouter:{id:"openrouter",alias:"openrouter",format:"openai",executor:"default",baseUrl:"https://openrouter.ai/api/v1/chat/completions",authType:"apikey",authHeader:"bearer",headers:{"HTTP-Referer":"https://endpoint-proxy.local","X-Title":"Endpoint Proxy"},models:[{id:"auto",name:"Auto (Best Available)"}]},glm:{id:"glm",alias:"glm",format:"claude",executor:"default",baseUrl:"https://api.z.ai/api/anthropic/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},models:[{id:"glm-4.7-flash",name:"GLM 4.7 Flash"},{id:"glm-4.7",name:"GLM 4.7"},{id:"glm-4.6v",name:"GLM 4.6V (Vision)"},{id:"glm-4.6",name:"GLM 4.6"},{id:"glm-4.5v",name:"GLM 4.5V (Vision)"},{id:"glm-4.5",name:"GLM 4.5"},{id:"glm-4.5-air",name:"GLM 4.5 Air"},{id:"glm-4-32b",name:"GLM 4 32B"}]},kimi:{id:"kimi",alias:"kimi",format:"openai",executor:"default",baseUrl:"https://api.moonshot.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"kimi-k2.5-thinking",name:"Kimi K2.5 Thinking"},{id:"kimi-latest",name:"Kimi Latest"}]},"kimi-coding":{id:"kimi-coding",alias:"kmc",format:"claude",executor:"default",baseUrl:"https://api.kimi.com/coding/v1/messages",urlSuffix:"?beta=true",authType:"oauth",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},oauth:{clientIdEnv:"KIMI_CODING_OAUTH_CLIENT_ID",clientIdDefault:"17e5f671-d194-4dfb-9706-5516cb48c098",tokenUrl:"https://auth.kimi.com/api/oauth/token",refreshUrl:"https://auth.kimi.com/api/oauth/token",authUrl:"https://auth.kimi.com/api/oauth/device_authorization"},models:[{id:"kimi-k2.5",name:"Kimi K2.5"},{id:"kimi-k2.5-thinking",name:"Kimi K2.5 Thinking"},{id:"kimi-latest",name:"Kimi Latest"}]},kilocode:{id:"kilocode",alias:"kc",format:"openrouter",executor:"openrouter",baseUrl:"https://api.kilo.ai/api/openrouter/chat/completions",modelsUrl:"https://api.kilo.ai/api/openrouter/models",authType:"oauth",authHeader:"Authorization",authPrefix:"Bearer ",oauth:{initiateUrl:"https://api.kilo.ai/api/device-auth/codes",pollUrlBase:"https://api.kilo.ai/api/device-auth/codes"},models:[{id:"openrouter/free",name:"Free Models Router"},{id:"qwen/qwen3-vl-235b-a22b-thinking",name:"Qwen3 VL 235B A22B Thinking"},{id:"qwen/qwen3-235b-a22b-thinking-2507",name:"Qwen3 235B A22B Thinking 2507"},{id:"qwen/qwen3-vl-30b-a3b-thinking",name:"Qwen3 VL 30B A3B Thinking"},{id:"stepfun/step-3.5-flash:free",name:"StepFun Step 3.5 Flash"},{id:"arcee-ai/trinity-large-preview:free",name:"Arcee AI Trinity Large Preview"},{id:"openai/gpt-4o-mini",name:"GPT-4o Mini"},{id:"openai/gpt-4.1-nano",name:"GPT-4.1 Nano"},{id:"openai/gpt-5-nano",name:"GPT-5 Nano"},{id:"openai/gpt-5-mini",name:"GPT-5 Mini"},{id:"anthropic/claude-3-haiku",name:"Claude 3 Haiku"},{id:"google/gemini-2.0-flash",name:"Gemini 2.0 Flash"},{id:"google/gemini-2.5-flash-lite",name:"Gemini 2.5 Flash Lite"},{id:"deepseek/deepseek-chat-v3.1",name:"DeepSeek V3.1"},{id:"deepseek/deepseek-v3.2",name:"DeepSeek V3.2"},{id:"meta-llama/llama-3.3-70b-instruct",name:"Llama 3.3 70B"},{id:"meta-llama/llama-4-scout",name:"Llama 4 Scout"},{id:"meta-llama/llama-4-maverick",name:"Llama 4 Maverick"},{id:"qwen/qwen3-8b",name:"Qwen3 8B"},{id:"qwen/qwen3-32b",name:"Qwen3 32B"},{id:"qwen/qwen3-coder",name:"Qwen3 Coder 480B"},{id:"qwen/qwq-32b",name:"QwQ 32B"},{id:"mistralai/mistral-small-24b-instruct-2501",name:"Mistral Small 3"},{id:"mistralai/mistral-7b-instruct",name:"Mistral 7B"},{id:"x-ai/grok-code-fast-1",name:"Grok Code Fast 1"},{id:"moonshotai/kimi-k2.5",name:"Kimi K2.5"}],passthroughModels:!0},cline:{id:"cline",alias:"cl",format:"openai",executor:"openai",baseUrl:"https://api.cline.bot/api/v1/chat/completions",authType:"oauth",authHeader:"Authorization",authPrefix:"Bearer ",oauth:{tokenUrl:"https://api.cline.bot/api/v1/auth/token",refreshUrl:"https://api.cline.bot/api/v1/auth/refresh",authUrl:"https://api.cline.bot/api/v1/auth/authorize"},extraHeaders:{"HTTP-Referer":"https://cline.bot","X-Title":"Cline"},models:[{id:"anthropic/claude-sonnet-4-20250514",name:"Claude Sonnet 4"},{id:"anthropic/claude-opus-4-20250514",name:"Claude Opus 4"},{id:"google/gemini-2.5-pro",name:"Gemini 2.5 Pro"},{id:"google/gemini-2.5-flash",name:"Gemini 2.5 Flash"},{id:"openai/gpt-4.1",name:"GPT-4.1"},{id:"openai/o3",name:"o3"},{id:"deepseek/deepseek-chat",name:"DeepSeek Chat"}],passthroughModels:!0},minimax:{id:"minimax",alias:"minimax",format:"claude",executor:"default",baseUrl:"https://api.minimax.io/anthropic/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},models:[{id:"MiniMax-M2.1",name:"MiniMax M2.1"}]},"minimax-cn":{id:"minimax-cn",alias:"minimax-cn",format:"claude",executor:"default",baseUrl:"https://api.minimaxi.com/anthropic/v1/messages",urlSuffix:"?beta=true",authType:"apikey",authHeader:"x-api-key",headers:{"Anthropic-Version":"2023-06-01","Anthropic-Beta":"claude-code-20250219,interleaved-thinking-2025-05-14"},models:[{id:"MiniMax-M2.1",name:"MiniMax M2.1"}]},deepseek:{id:"deepseek",alias:"ds",format:"openai",executor:"default",baseUrl:"https://api.deepseek.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"deepseek-chat",name:"DeepSeek V3.2 Chat"},{id:"deepseek-reasoner",name:"DeepSeek V3.2 Reasoner"}]},groq:{id:"groq",alias:"groq",format:"openai",executor:"default",baseUrl:"https://api.groq.com/openai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"llama-3.3-70b-versatile",name:"Llama 3.3 70B"},{id:"meta-llama/llama-4-maverick-17b-128e-instruct",name:"Llama 4 Maverick"},{id:"qwen/qwen3-32b",name:"Qwen3 32B"},{id:"openai/gpt-oss-120b",name:"GPT-OSS 120B"}]},xai:{id:"xai",alias:"xai",format:"openai",executor:"default",baseUrl:"https://api.x.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"grok-4",name:"Grok 4"},{id:"grok-4-fast-reasoning",name:"Grok 4 Fast Reasoning"},{id:"grok-code-fast-1",name:"Grok Code Fast"},{id:"grok-3",name:"Grok 3"}]},mistral:{id:"mistral",alias:"mistral",format:"openai",executor:"default",baseUrl:"https://api.mistral.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"mistral-large-latest",name:"Mistral Large 3"},{id:"codestral-latest",name:"Codestral"},{id:"mistral-medium-latest",name:"Mistral Medium 3"}]},perplexity:{id:"perplexity",alias:"pplx",format:"openai",executor:"default",baseUrl:"https://api.perplexity.ai/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"sonar-pro",name:"Sonar Pro"},{id:"sonar",name:"Sonar"}]},together:{id:"together",alias:"together",format:"openai",executor:"default",baseUrl:"https://api.together.xyz/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"meta-llama/Llama-3.3-70B-Instruct-Turbo",name:"Llama 3.3 70B Turbo"},{id:"deepseek-ai/DeepSeek-R1",name:"DeepSeek R1"},{id:"Qwen/Qwen3-235B-A22B",name:"Qwen3 235B"},{id:"meta-llama/Llama-4-Maverick-17B-128E-Instruct-FP8",name:"Llama 4 Maverick"}]},fireworks:{id:"fireworks",alias:"fireworks",format:"openai",executor:"default",baseUrl:"https://api.fireworks.ai/inference/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"accounts/fireworks/models/deepseek-v3p1",name:"DeepSeek V3.1"},{id:"accounts/fireworks/models/llama-v3p3-70b-instruct",name:"Llama 3.3 70B"},{id:"accounts/fireworks/models/qwen3-235b-a22b",name:"Qwen3 235B"}]},cerebras:{id:"cerebras",alias:"cerebras",format:"openai",executor:"default",baseUrl:"https://api.cerebras.ai/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"gpt-oss-120b",name:"GPT OSS 120B"},{id:"zai-glm-4.7",name:"ZAI GLM 4.7"},{id:"llama-3.3-70b",name:"Llama 3.3 70B"},{id:"llama-4-scout-17b-16e-instruct",name:"Llama 4 Scout"},{id:"qwen-3-235b-a22b-instruct-2507",name:"Qwen3 235B A22B"},{id:"qwen-3-32b",name:"Qwen3 32B"}]},cohere:{id:"cohere",alias:"cohere",format:"openai",executor:"default",baseUrl:"https://api.cohere.com/v2/chat",authType:"apikey",authHeader:"bearer",models:[{id:"command-r-plus-08-2024",name:"Command R+ (Aug 2024)"},{id:"command-r-08-2024",name:"Command R (Aug 2024)"},{id:"command-a-03-2025",name:"Command A (Mar 2025)"}]},nvidia:{id:"nvidia",alias:"nvidia",format:"openai",executor:"default",baseUrl:"https://integrate.api.nvidia.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"moonshotai/kimi-k2.5",name:"Kimi K2.5"},{id:"z-ai/glm4.7",name:"GLM 4.7"},{id:"deepseek-ai/deepseek-v3.2",name:"DeepSeek V3.2"},{id:"nvidia/llama-3.3-70b-instruct",name:"Llama 3.3 70B"},{id:"meta/llama-4-maverick-17b-128e-instruct",name:"Llama 4 Maverick"},{id:"deepseek/deepseek-r1",name:"DeepSeek R1"}]},nebius:{id:"nebius",alias:"nebius",format:"openai",executor:"default",baseUrl:"https://api.tokenfactory.nebius.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"meta-llama/Llama-3.3-70B-Instruct",name:"Llama 3.3 70B Instruct"}]},siliconflow:{id:"siliconflow",alias:"siliconflow",format:"openai",executor:"default",baseUrl:"https://api.siliconflow.com/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"deepseek-ai/DeepSeek-V3.2",name:"DeepSeek V3.2"},{id:"deepseek-ai/DeepSeek-V3.1",name:"DeepSeek V3.1"},{id:"deepseek-ai/DeepSeek-R1",name:"DeepSeek R1"},{id:"Qwen/Qwen3-235B-A22B-Instruct-2507",name:"Qwen3 235B"},{id:"Qwen/Qwen3-Coder-480B-A35B-Instruct",name:"Qwen3 Coder 480B"},{id:"Qwen/Qwen3-32B",name:"Qwen3 32B"},{id:"moonshotai/Kimi-K2.5",name:"Kimi K2.5"},{id:"zai-org/GLM-4.7",name:"GLM 4.7"},{id:"openai/gpt-oss-120b",name:"GPT OSS 120B"},{id:"baidu/ERNIE-4.5-300B-A47B",name:"ERNIE 4.5 300B"}]},hyperbolic:{id:"hyperbolic",alias:"hyp",format:"openai",executor:"default",baseUrl:"https://api.hyperbolic.xyz/v1/chat/completions",authType:"apikey",authHeader:"bearer",models:[{id:"Qwen/QwQ-32B",name:"QwQ 32B"},{id:"deepseek-ai/DeepSeek-R1",name:"DeepSeek R1"},{id:"deepseek-ai/DeepSeek-V3",name:"DeepSeek V3"},{id:"meta-llama/Llama-3.3-70B-Instruct",name:"Llama 3.3 70B"},{id:"meta-llama/Llama-3.2-3B-Instruct",name:"Llama 3.2 3B"},{id:"Qwen/Qwen2.5-72B-Instruct",name:"Qwen 2.5 72B"},{id:"Qwen/Qwen2.5-Coder-32B-Instruct",name:"Qwen 2.5 Coder 32B"},{id:"NousResearch/Hermes-3-Llama-3.1-70B",name:"Hermes 3 70B"}]}},e=new Map;for(let a of Object.values(d))a.alias&&a.alias!==a.id&&e.set(a.alias,a);let f=function(){let a={};for(let b of Object.values(d))if(b.models&&b.models.length>0){let c=b.alias||b.id;a[c]||(a[c]=b.models)}return a}(),g=function(){let a={};for(let b of Object.values(d))a[b.id]=b.alias||b.id;return a}();function h(a){return f[g[a]||a]||[]}},97496:(a,b,c)=>{Promise.resolve().then(c.bind(c,81227))},97507:(a,b,c)=>{"use strict";c.r(b),c.d(b,{default:()=>e});var d=c(48249);function e({error:a,reset:b}){return(0,d.jsxs)("div",{className:"flex flex-col items-center justify-center min-h-[60vh] p-6 text-center",role:"alert","aria-live":"assertive",children:[(0,d.jsx)("div",{className:"text-[64px] mb-4","aria-hidden":"true",children:"\uD83D\uDD27"}),(0,d.jsx)("h1",{className:"text-[28px] font-bold mb-2 text-[var(--color-text-main)]",children:"Internal Server Error"}),(0,d.jsx)("p",{className:"text-[15px] text-[var(--color-text-muted)] max-w-[400px] leading-relaxed mb-2",children:"Something went wrong while processing your request. Our team has been notified and is working on a fix."}),a?.digest&&(0,d.jsxs)("p",{className:"text-xs text-[var(--color-text-muted)] mb-6 font-mono",children:["Error ID: ",a.digest]}),!1,(0,d.jsxs)("div",{className:"flex gap-3",children:[(0,d.jsx)("button",{onClick:b,"aria-label":"Retry loading the page",className:"px-6 py-2.5 rounded-lg text-white text-sm font-semibold cursor-pointer transition-all duration-200 bg-[var(--color-accent)] hover:bg-[var(--color-accent-hover)] focus:outline-2 focus:outline-offset-2 focus:outline-[var(--color-accent)]",children:"Try Again"}),(0,d.jsx)("a",{href:"/dashboard",className:"px-6 py-2.5 rounded-lg text-[var(--color-text-main)] text-sm font-semibold cursor-pointer transition-all duration-200 border border-[var(--color-border)] hover:bg-[var(--color-bg-alt)] no-underline focus:outline-2 focus:outline-offset-2 focus:outline-[var(--color-accent)]","aria-label":"Return to dashboard",children:"Go to Dashboard"})]})]})}}};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";exports.id=1960,exports.ids=[1960],exports.modules={31960:a=>{a.exports=JSON.parse('{"common":{"save":"Save","cancel":"Cancel","delete":"Delete","loading":"Loading...","error":"An error occurred","success":"Success","confirm":"Are you sure?","refresh":"Refresh","close":"Close","add":"Add","edit":"Edit","search":"Search","back":"Back","next":"Next","submit":"Submit","reset":"Reset","copy":"Copy","copied":"Copied!","enabled":"Enabled","disabled":"Disabled","active":"Active","inactive":"Inactive","noData":"No data available","configure":"Configure","manage":"Manage","name":"Name","actions":"Actions","status":"Status","type":"Type","model":"Model","models":"models","provider":"Provider","account":"Account","time":"Time","details":"Details","created":"Created","lastUsed":"Last Used","loadMore":"Load More","noResults":"No results found","reloadPage":"Reload Page","connected":"Connected","disconnected":"Disconnected","notConfigured":"Not configured","testConnection":"Test Connection","enable":"Enable","disable":"Disable","columns":"Columns","newest":"Newest","oldest":"Oldest","all":"All","none":"None","yes":"Yes","no":"No","warning":"Warning","note":"Note","free":"Free","skipToContent":"Skip to content"},"sidebar":{"home":"Home","dashboard":"Dashboard","providers":"Providers","combos":"Combos","usage":"Usage","analytics":"Analytics","costs":"Costs","health":"Health","limits":"Limits & Quotas","cliTools":"CLI Tools","settings":"Settings","translator":"Translator","docs":"Docs","issues":"Issues","endpoint":"Endpoint","apiManager":"API Manager","logs":"Logs","auditLog":"Audit Log","shutdown":"Shutdown","restart":"Restart","shutdownConfirm":"Shut down OmniRoute?","restartConfirm":"Restart OmniRoute?","version":"v{version}","debug":"Debug","system":"System","help":"Help","serverDisconnected":"Server Disconnected","serverDisconnectedMsg":"The proxy server has been stopped or is restarting.","expandSidebar":"Expand sidebar","collapseSidebar":"Collapse sidebar"},"header":{"logout":"Logout","language":"Language","providers":"Providers","providerDescription":"Manage your AI provider connections","combos":"Combos","comboDescription":"Model combos with fallback","usage":"Usage & Analytics","usageDescription":"Monitor your API usage, token consumption, and request logs","analytics":"Analytics","analyticsDescription":"Charts, trends, and evaluation insights","cliTools":"CLI Tools","cliToolsDescription":"Configure CLI tools","home":"Home","homeDescription":"Welcome to OmniRoute","endpoint":"Endpoint","endpointDescription":"API endpoint configuration","settings":"Settings","settingsDescription":"Manage your preferences","openaiCompatible":"OpenAI Compatible","anthropicCompatible":"Anthropic Compatible"},"home":{"quickStart":"Quick Start","quickStartDesc":"Get up and running in 4 steps. Connect providers, route models, monitor everything.","fullDocs":"Full Docs","step1Title":"1. Create API key","step1Desc":"Go to {endpoint} → Registered Keys. Generate one key per environment.","step2Title":"2. Connect providers","step2Desc":"Add accounts in {providers}. Supports OAuth, API Key, and free tiers.","step3Title":"3. Point your client","step3Desc":"Set base URL to {url} in your IDE or API client.","step4Title":"4. Monitor & optimize","step4Desc":"Track tokens, cost and errors in {logs} and {analytics}.","providersOverview":"Providers Overview","configuredOf":"{configured} configured of {total} available providers","noModelsAvailable":"No models available for this provider.","configureFirst":"Configure a connection first in {providers}","configureProvider":"Configure Provider","modelAvailable":"{count} model available","modelsAvailable":"{count} models available","connectionsActive":"{count} connection active","connectionsActivePlural":"{count} connections active","copyModelName":"Copy model name","documentation":"Documentation","healthMonitor":"Health Monitor","reportIssue":"Report issue","activeError":"{active} active \xb7 {errors} error"},"analytics":{"title":"Analytics","overviewDescription":"Monitor your API usage patterns, token consumption, costs, and activity trends across all providers and models.","evalsDescription":"Run evaluation suites to test and validate your LLM endpoints. Compare model quality, detect regressions, and benchmark latency.","overview":"Overview","evals":"Evals"},"apiManager":{"title":"API Keys","createKey":"Create API Key","key":"Key","revokeKey":"Revoke Key","revokeConfirm":"Are you sure you want to revoke this API key?","noKeys":"No API keys yet","noKeysDesc":"Create your first API key to authenticate requests to your endpoint","keyLabel":"Key Label","permissions":"Permissions","expiresAt":"Expires","never":"Never","revoke":"Revoke","showKey":"Show Key","hideKey":"Hide Key","copyKey":"Copy API Key","allModels":"All models","selectedModels":"Selected Models","readOnly":"Read Only","fullAccess":"Full Access","keyManagement":"API Key Management","keyManagementDesc":"Create and manage API keys for authenticating requests to your endpoint","totalKeys":"Total Keys","restricted":"Restricted","totalRequests":"Total Requests","modelsAvailable":"Models Available","registeredKeys":"Registered Keys","keysRegistered":"{count} keys registered","keyRegistered":"{count} key registered","keysSecurityNote":"Each key isolates usage tracking and can be revoked independently. Keys are masked after creation for security.","createFirstKey":"Create Your First Key","name":"Name","usage":"Usage","created":"Created","actions":"Actions","reqs":"reqs","neverUsed":"Never used","deleteConfirm":"Delete this API key?","usageTips":"Usage Tips","tipAuth":"Use API keys in the Authorization header as Bearer YOUR_KEY","tipSecure":"Keys are only shown once during creation — store them securely","tipSeparate":"Create separate keys for different clients or environments","tipRestrict":"Restrict keys to specific models for better security and cost control","keyName":"Key Name","keyNamePlaceholder":"e.g., Production Key, Development Key","keyNameDesc":"Choose a descriptive name to identify this key\'s purpose","keyCreated":"API Key Created","keyCreatedSuccess":"Key created successfully!","keyCreatedNote":"Copy and store this key now — it won\'t be shown again.","done":"Done","savePermissions":"Save Permissions","allowAll":"Allow All","restrict":"Restrict","allowAllInfo":"This key can access all available models.","restrictInfo":"This key can access {selected} of {total} models.","selected":"{count} selected","all":"All","clear":"Clear","searchModels":"Search models by name or provider...","noModelsFound":"No models found","keyNameRequired":"Key name is required","keyNameTooLong":"Key name must be {max} characters or less","keyNameInvalid":"Key name can only contain letters, numbers, spaces, hyphens, and underscores","model":"{count} model","models":"{count} models","permissionsTitle":"Permissions: {name}","allowAllDesc":"This key can access all available models.","restrictDesc":"This key can access {selectedCount} of {totalModels} models.","selectedCount":"{count} selected"},"auditLog":{"title":"Audit Log","searchPlaceholder":"Search actions...","action":"Action","actor":"Actor","target":"Target","ipAddress":"IP Address","timestamp":"Timestamp","noEntries":"No audit entries found","filterByAction":"Filter by action...","filterByActor":"Filter by actor...","description":"Administrative actions and security events","showing":"Showing {count} entries (offset {offset})","previous":"Previous"},"cliTools":{"title":"CLI Tools","noActiveProviders":"No active providers","noActiveProvidersDesc":"Please add and connect providers first to configure CLI tools.","mapModels":"Map Models","testConnection":"Test Connection","connectionStatus":"Connection Status","configureEndpoint":"Configure Endpoint","instructions":"Instructions","modelMapping":"Model Mapping","baseUrl":"Base URL","apiKey":"API Key"},"combos":{"title":"Combos","description":"Create model combos with weighted routing and fallback support","createCombo":"Create Combo","editCombo":"Edit Combo","deleteCombo":"Delete Combo","noModels":"No models","noModelsYet":"No models added yet","addModel":"Add Model","addModelToCombo":"Add Model to Combo","routingStrategy":"Routing Strategy","maxRetries":"Max Retries","timeout":"Timeout (ms)","healthcheck":"Healthcheck","priority":"Priority","fallback":"Fallback","roundRobin":"Round Robin","random":"Random","leastLatency":"Least Latency","comboName":"Combo Name","comboNamePlaceholder":"my-combo","deleteConfirm":"Delete this combo?","noCombosYet":"No combos yet","comboCreated":"Combo created successfully","comboUpdated":"Combo updated successfully","comboDeleted":"Combo deleted","failedCreate":"Failed to create combo","failedUpdate":"Failed to update combo","errorCreating":"Error creating combo","errorUpdating":"Error updating combo","errorDeleting":"Error deleting combo","testFailed":"Test request failed","failedToggle":"Failed to toggle combo","testResults":"Test Results — {name}","resolvedBy":"Resolved by:","more":"+{count} more","reqs":"reqs","success":"success","proxyConfigured":"Proxy configured","copyComboName":"Copy combo name","enableCombo":"Enable combo","disableCombo":"Disable combo","testCombo":"Test combo","duplicate":"Duplicate","proxyConfig":"Proxy configuration","nameRequired":"Name is required","nameInvalid":"Only letters, numbers, -, _, / and . allowed","nameHint":"Letters, numbers, -, _, / and . allowed","priorityDesc":"Sequential fallback: tries model 1 first, then 2, etc.","weightedDesc":"Distributes traffic by weight percentage with fallback","roundRobinDesc":"Circular distribution: each request goes to the next model in rotation","randomDesc":"Uniform random selection, then fallback to remaining models","leastUsedDesc":"Picks the model with fewest requests, balancing load over time","costOptimizedDesc":"Routes to the cheapest model first based on pricing","models":"Models","autoBalance":"Auto-balance","advancedSettings":"Advanced Settings","retryDelay":"Retry Delay (ms)","concurrencyPerModel":"Concurrency / Model","queueTimeout":"Queue Timeout (ms)","advancedHint":"Leave empty to use global defaults. These override per-provider settings.","saving":"Saving...","weighted":"Weighted","leastUsed":"Least-Used","costOpt":"Cost-Opt"},"costs":{"title":"Costs","budget":"Budget","totalCost":"Total Cost","breakdown":"Cost Breakdown","noData":"No cost data","byModel":"By Model","byProvider":"By Provider"},"endpoint":{"title":"API Endpoint","available":"Available Endpoints","cloudProxy":"Cloud Proxy","disableConfirm":"Are you sure you want to disable cloud proxy?","baseUrl":"Base URL","apiKeyLabel":"API Key","registeredKeys":"Registered Keys","chatCompletions":"Chat Completions","responses":"Responses","listModels":"List Models","usingCloudProxy":"Using Cloud Proxy","usingLocalServer":"Using Local Server","machineId":"Machine ID: {id}...","disableCloud":"Disable Cloud","enableCloud":"Enable Cloud","modelsAcrossEndpoints":"{models} models across {endpoints} endpoints","chatDesc":"Streaming & non-streaming chat with all providers","embeddings":"Embeddings","embeddingsDesc":"Text embeddings for search & RAG pipelines","imageGeneration":"Image Generation","imageDesc":"Generate images from text prompts","rerank":"Rerank","rerankDesc":"Rerank documents by relevance to a query","audioTranscription":"Audio Transcription","audioTranscriptionDesc":"Transcribe audio files to text (Whisper)","textToSpeech":"Text to Speech","textToSpeechDesc":"Convert text to natural-sounding speech","moderations":"Moderations","moderationsDesc":"Content moderation and safety classification","enableCloudTitle":"Enable Cloud Proxy","whatYouGet":"What you will get","cloudBenefitAccess":"Access your API from anywhere in the world","cloudBenefitShare":"Share endpoint with your team easily","cloudBenefitPorts":"No need to open ports or configure firewall","cloudBenefitEdge":"Fast global edge network","cloudSessionNote":"Cloud will keep your auth session for 1 day. If not used, it will be automatically deleted.","cloudUnstableNote":"Cloud is currently unstable with Claude Code OAuth in some cases.","cloudConnected":"Cloud Proxy connected!","connectingToCloud":"Connecting to cloud...","verifyingConnection":"Verifying connection...","connecting":"Connecting...","verifying":"Verifying...","connected":"Connected!","disableCloudTitle":"Disable Cloud Proxy","disableWarning":"All auth sessions will be deleted from cloud.","syncingData":"Syncing latest data...","disablingCloud":"Disabling cloud...","syncing":"Syncing...","disabling":"Disabling...","cloudConnectedVerified":"Cloud Proxy connected and verified!","connectedVerificationPending":"Connected — verification pending","cloudDisabledSuccess":"Cloud disabled successfully","syncedSuccess":"Synced successfully","failedDisable":"Failed to disable cloud","failedEnable":"Failed to enable cloud"},"health":{"title":"System Health","description":"Real-time monitoring of your OmniRoute instance","healthy":"Healthy","degraded":"Degraded","down":"Down","uptime":"Uptime","memory":"Memory","memoryRss":"Memory (RSS)","heap":"Heap","cpu":"CPU","database":"Database","version":"Version","lastCheck":"Last Check","providerHealth":"Provider Health","systemMetrics":"System Metrics","tokenHealth":"Token Health","refreshAll":"Refresh All","checkNow":"Check Now","loadingHealth":"Loading health data...","failedToLoad":"Failed to load health data: {error}","retry":"Retry","allOperational":"All systems operational","issuesDetected":"System issues detected","latency":"Latency","totalRequests":"Total requests","noDataYet":"No data yet","promptCache":"Prompt Cache","entries":"Entries","hitRate":"Hit Rate","hitsMisses":"Hits / Misses","signatureCache":"Signature Cache","recovering":"Recovering","noCBData":"No circuit breaker data available. Make some requests first.","issuesLabel":"Issues Detected","operational":"Operational","failures":"{count} failure","failuresPlural":"{count} failures","lastFailure":"Last","rateLimitStatus":"Rate Limit Status","activeLimiters":"{count} active limiter","activeLimitersPlural":"{count} active limiters","queued":"Queued","running":"running","activeLockouts":"Active Lockouts","resetConfirm":"Reset all circuit breakers to healthy state? This will clear all failure counts and restore all providers to operational status.","resetting":"Resetting...","resetAll":"Reset All","until":"Until {time}"},"limits":{"title":"Limits & Quotas","rateLimit":"Rate Limit","remaining":"Remaining","requestsPerMinute":"Requests/min","tokensPerMinute":"Tokens/min","dailyLimit":"Daily Limit"},"logs":{"title":"Logs","requestLogs":"Request Logs","proxyLogs":"Proxy Logs","auditLog":"Audit Log","console":"Console","auditLogDesc":"Administrative actions and security events","loading":"Loading...","refresh":"Refresh","filterByAction":"Filter by action...","filterByActor":"Filter by actor...","search":"Search","timestamp":"Timestamp","action":"Action","actor":"Actor","target":"Target","details":"Details","noEntries":"No audit log entries found","previous":"Previous","next":"Next"},"onboarding":{"welcome":"Welcome","security":"Security","test":"Test","ready":"Ready!","setPassword":"Set Password","addProvider":"Add your first provider","getStarted":"Get Started","skip":"Skip","skipWizard":"Skip wizard entirely","skipPassword":"Skip password setup","skipAndContinue":"Skip & Continue","passwordLabel":"Password","confirmPassword":"Confirm Password","enterPassword":"Enter password","confirmPasswordPlaceholder":"Confirm password","passwordsMismatch":"Passwords do not match","setupComplete":"Setup Complete!","goToDashboard":"Go to Dashboard →","welcomeDesc":"OmniRoute is your local AI API proxy. It routes requests to multiple AI providers with load balancing, failover, and usage tracking.","multiProvider":"Multi-Provider","usageTracking":"Usage Tracking","apiKeyMgmt":"API Key Mgmt","securityDesc":"Set a password to protect your dashboard, or skip for now.","providerDesc":"Connect your first AI provider. You can add more later.","apiKeyRequired":"API Key (required)","customUrlOptional":"Custom URL (optional)","testDesc":"Let\'s verify your provider connection works.","runTest":"Run Connection Test","testingConnection":"Testing connection...","connectionSuccessful":"Connection successful! Your provider is ready.","noProviderFound":"No provider found. You can add one from the dashboard later.","testFailed":"Test failed, but you can configure this later.","couldNotTest":"Could not test right now. You can test from the dashboard.","doneDesc":"You\'re all set! Your OmniRoute instance is configured and ready to proxy AI requests.","yourEndpoint":"Your endpoint:","continue":"Continue","retry":"Retry","failedSetPassword":"Failed to set password. Try again.","failedAddProvider":"Failed to add provider. Try again.","connectionError":"Connection error. Please try again."},"providers":{"title":"Providers","addProvider":"Add Provider","editProvider":"Edit Provider","deleteProvider":"Delete Provider","noProviders":"No providers configured","modelAvailability":"Model Availability","accounts":"Accounts","newAccount":"New Account","deleteConfirm":"Are you sure you want to delete this provider?","testing":"Testing...","testSuccess":"Connection successful","testFailed":"Connection failed","available":"Available","unavailable":"Unavailable","unknown":"Unknown","oauthProviders":"OAuth Providers","freeProviders":"Free Providers","apiKeyProviders":"API Key Providers","compatibleProviders":"API Key Compatible Providers","testAll":"Test All","testAllOAuth":"Test all OAuth connections","testAllFree":"Test all Free connections","testAllApiKey":"Test all API Key connections","testAllCompatible":"Test all Compatible connections","connected":"{count} Connected","errorCount":"{count} Error ({code})","errorCountNoCode":"{count} Error","noConnections":"No connections","disabled":"Disabled","enableProvider":"Enable provider","disableProvider":"Disable provider","testResults":"Test Results","noCompatibleYet":"No compatible providers added yet","compatibleHint":"Use the buttons above to add OpenAI or Anthropic compatible endpoints","addOpenAICompatible":"Add OpenAI Compatible","addAnthropicCompatible":"Add Anthropic Compatible","addNewProvider":"Add New Provider","backToProviders":"Back to Providers","configureNewProvider":"Configure a new AI provider to use with your applications.","selectProvider":"Select a provider","selectedProvider":"Selected provider","authMethod":"Authentication Method","apiKeyRequired":"API Key is required","selectProviderRequired":"Please select a provider","enterApiKey":"Enter your API key","apiKeySecure":"Your API key will be encrypted and stored securely.","oauth2Connect":"Connect with OAuth2","oauth2Desc":"Connect your account using OAuth2 authentication.","displayName":"Display Name","displayNamePlaceholder":"e.g., Production API, Dev Environment","displayNameHint":"Optional. A friendly name to identify this configuration.","active":"Active","activeDescription":"Enable this provider for use in your applications","createProvider":"Create Provider","failedCreate":"Failed to create provider","errorOccurred":"An error occurred. Please try again.","modelStatus":"Model Status","allModelsOperational":"All models operational","modelsWithIssues":"{count} model(s) with issues","allModelsNormal":"All models are responding normally.","cooldownCleared":"Cooldown cleared for {model}","failedClearCooldown":"Failed to clear cooldown","loadingAvailability":"Loading model availability...","clearCooldown":"Clear","clearing":"Clearing...","providerTestFailed":"Provider test failed","allTestsPassed":"All {total} tests passed","testSummary":"{passed}/{total} passed, {failed} failed","nameLabel":"Name","prefixLabel":"Prefix","baseUrlLabel":"Base URL","apiTypeLabel":"API Type","prefixHint":"Required. Unique prefix for model names.","nameHint":"Required. A friendly label for this node.","baseUrlHint":"Required. Provider API base URL.","validateConnection":"Validate Connection","validating":"Validating...","connectionValid":"Connection is valid!","connectionFailed":"Connection failed. Check URL and key.","testKeyLabel":"Test API Key","testKeyPlaceholder":"sk-... (for validation only)","providerNotFound":"Provider not found","deleteConnectionConfirm":"Delete this connection?","failedSetAlias":"Failed to set alias","failedSaveConnection":"Failed to save connection","failedSaveConnectionRetry":"Failed to save connection. Please try again.","failedRetestConnection":"Failed to retest connection","deleteCompatibleNodeConfirm":"Delete this {type} Compatible node?","anthropicCompatibleDetails":"Anthropic Compatible Details","openaiCompatibleDetails":"OpenAI Compatible Details","messagesApi":"Messages API","responsesApi":"Responses API","chatCompletions":"Chat Completions","importingModels":"Importing...","importFromModels":"Import from /models","addConnectionToImport":"Add a connection to enable importing.","noModelsConfigured":"No models configured","connectionCount":"{count} connection(s)","fetchingModels":"Fetching available models...","failedFetchModels":"Failed to fetch models","noModelsFound":"No models found","importFailed":"Import failed","noNewModelsAdded":"No new models were added.","adding":"Adding...","importingModelsTitle":"Importing Models","copyModel":"Copy model","removeModel":"Remove model","rateLimitProtected":"Protected","rateLimitUnprotected":"Unprotected","enableRateLimitProtection":"Click to enable rate limit protection","disableRateLimitProtection":"Click to disable rate limit protection","productionKey":"Production Key","enterNewApiKey":"Enter new API key","optional":"Optional"},"settings":{"title":"Settings","general":"General","security":"Security","appearance":"Appearance","routing":"Routing","cache":"Cache","resilience":"Resilience","systemPrompt":"System Prompt","thinkingBudget":"Thinking Budget","proxy":"Proxy","pricing":"Pricing","storage":"Storage","policies":"Policies","ipFilter":"IP Filter","comboDefaults":"Combo Defaults","fallbackChains":"Fallback Chains","changePassword":"Change Password","enablePassword":"Enable Password","darkMode":"Dark Mode","lightMode":"Light Mode","systemTheme":"System Theme","enableCache":"Enable Cache","cacheTTL":"Cache TTL","maxCacheSize":"Max Cache Size","clearCache":"Clear Cache","cacheHits":"Cache Hits","cacheMisses":"Cache Misses","hitRate":"Hit Rate","cacheEntries":"Cache Entries","circuitBreaker":"Circuit Breaker","retryPolicy":"Retry Policy","maxRetries":"Max Retries","retryDelay":"Retry Delay","timeoutMs":"Timeout (ms)","enableSystemPrompt":"Enable System Prompt","systemPromptText":"System Prompt Text","enableThinking":"Enable Thinking","maxThinkingTokens":"Max Thinking Tokens","enableProxy":"Enable Proxy","proxyUrl":"Proxy URL","pricingRates":"Pricing Rates Format","currentPricing":"Current Pricing Overview","loadingPricing":"Loading pricing data...","noPricing":"No pricing data available","input":"Input","output":"Output","cached":"Cached","reasoning":"Reasoning","cacheCreation":"Cache Creation","customPricing":"Custom Pricing","databaseSize":"Database Size","backupDb":"Backup Database","restoreDb":"Restore Database","exportData":"Export Data","importData":"Import Data","clearData":"Clear All Data","clearDataConfirm":"This will permanently delete all data. Are you sure?","enableRequestLogs":"Enable Request Logs","logRetention":"Log Retention","ipWhitelist":"IP Whitelist","ipBlacklist":"IP Blacklist","addIP":"Add IP","savedSuccessfully":"Settings saved successfully","ai":"AI","advanced":"Advanced","localMode":"Local Mode — All data stored on your machine","switchThemes":"Switch between light and dark themes","hideHealthLogs":"Hide Health Check Logs","hideHealthLogsDesc":"When ON, suppress [HealthCheck] messages in server console","promptCache":"Prompt Cache","flushCache":"Flush Cache","flushing":"Flushing…","size":"Size","hits":"Hits","evictions":"Evictions","loadingCacheStats":"Loading cache stats…","globalProxy":"Global Proxy","globalProxyDesc":"Configure a global outbound proxy for all API calls. Individual providers, combos, and keys can override this.","noGlobalProxy":"No global proxy configured","configure":"Configure","globalSystemPrompt":"Global System Prompt","systemPromptDesc":"Injected into all requests at proxy level","saved":"Saved","systemPromptPlaceholder":"Enter system prompt to inject into all requests...","systemPromptHint":"This prompt is prepended to the system message of every request. Use for global instructions, safety guidelines, or response formatting rules.","chars":"{count} chars","thinkingBudgetTitle":"Thinking Budget","thinkingBudgetDesc":"Control AI reasoning token usage across all requests","passthrough":"Passthrough","passthroughDesc":"No changes — client controls thinking budget","auto":"Auto","autoDesc":"Strip all thinking config — let provider decide","custom":"Custom","customDesc":"Set a fixed token budget for all requests","adaptive":"Adaptive","adaptiveDesc":"Scale budget based on request complexity","tokenBudget":"Token Budget","tokens":"tokens","baseEffortLevel":"Base Effort Level","adaptiveHint":"Adaptive mode scales from this base level based on message count, tool usage, and prompt length.","requireLogin":"Require login","requireLoginDesc":"When ON, dashboard requires password. When OFF, access without login.","currentPassword":"Current Password","enterCurrentPassword":"Enter current password","newPassword":"New Password","enterNewPassword":"Enter new password","confirmPassword":"Confirm New Password","confirmPasswordPlaceholder":"Confirm new password","passwordsNoMatch":"Passwords do not match","passwordUpdated":"Password updated successfully","failedUpdatePassword":"Failed to update password","errorOccurred":"An error occurred","updatePassword":"Update Password","setPassword":"Set Password","apiEndpointProtection":"API Endpoint Protection","requireAuthModels":"Require API key for /models","requireAuthModelsDesc":"When ON, the /v1/models endpoint returns 404 for unauthenticated requests. Prevents model discovery by unauthorized users.","blockedProviders":"Blocked Providers","blockedProvidersDesc":"Hide specific providers from the /v1/models response. Blocked providers will not appear in model listings.","providersBlocked":"{count} provider(s) blocked from /models","routingStrategy":"Routing Strategy","fillFirst":"Fill First","fillFirstDesc":"Use accounts in priority order","roundRobin":"Round Robin","roundRobinDesc":"Cycle through all accounts","p2c":"P2C","p2cDesc":"Pick 2 random, use the healthier one","random":"Random","randomDesc":"Random account each request","leastUsed":"Least Used","leastUsedDesc":"Pick least recently used account","costOpt":"Cost Opt","costOptDesc":"Prefer cheapest available account","stickyLimit":"Sticky Limit","stickyLimitDesc":"Calls per account before switching","modelAliases":"Model Aliases","modelAliasesDesc":"Wildcard patterns to remap model names • Use * and ?","pattern":"Pattern","targetModel":"Target Model","add":"+ Add","session":"Session","status":"Status","authenticated":"Authenticated","guest":"Guest","loginTime":"Login Time","sessionAge":"Session Age","browser":"Browser","clearLocalData":"Clear Local Data","logout":"Logout","clearLocalDataConfirm":"Clear all local data? This will reset your preferences.","ipAccessControl":"IP Access Control","ipAccessControlDesc":"Block or allow specific IP addresses","addIpAddress":"Add IP Address","block":"+ Block","allow":"+ Allow","blocked":"Blocked ({count})","allowed":"Allowed ({count})","temporaryBans":"Temporary Bans ({count})","minLeft":"{min}m left","auditLog":"Audit Log","searchAuditLogs":"Search audit logs...","failedLoadAuditLog":"Failed to load audit log","noAuditEvents":"No audit events found","action":"Action","actor":"Actor","details":"Details","time":"Time","fallbackChainsTitle":"Fallback Chains","fallbackChainsDesc":"Define provider fallback order per model","addChain":"+ Add Chain","modelName":"Model Name","providersCommaSeparated":"Providers (comma-separated, in priority order)","createChain":"Create Chain","noFallbackChains":"No Fallback Chains","noFallbackChainsDesc":"Create a chain to define provider fallback order for a model.","loadingFallbackChains":"Loading fallback chains...","deleteChainConfirm":"Delete fallback chain for \\"{model}\\"?","chainCreated":"Chain created for {model}","chainDeleted":"Chain deleted for {model}","failedCreateChain":"Failed to create chain","failedDeleteChain":"Failed to delete chain","fillModelAndProviders":"Please fill model name and providers","addAtLeastOneProvider":"Add at least one provider","comboDefaultsTitle":"Combo Defaults","globalComboConfig":"Global combo configuration","defaultStrategy":"Default Strategy","defaultStrategyDesc":"Applied to new combos without explicit strategy","priority":"Priority","weighted":"Weighted","healthCheck":"Health Check","healthCheckDesc":"Pre-check provider availability","trackMetrics":"Track Metrics","trackMetricsDesc":"Record per-combo request metrics","providerOverrides":"Provider Overrides","providerOverridesDesc":"Override timeout and retries per provider. Provider settings override global defaults.","retries":"retries","ms":"ms","saveComboDefaults":"Save Combo Defaults","maxNestingDepth":"Max Nesting Depth","concurrencyPerModel":"Concurrency / Model","queueTimeout":"Queue Timeout (ms)","providerProfiles":"Provider Profiles","providerProfilesDesc":"Separate resilience settings for OAuth (session-based) and API Key (metered) providers. OAuth providers have stricter thresholds due to lower rate limits.","oauthProviders":"OAuth Providers","apiKeyProviders":"API Key Providers","transientCooldown":"Transient Cooldown","rateLimitCooldown":"Rate Limit Cooldown","maxBackoffLevel":"Max Backoff Level","cbThreshold":"CB Threshold","cbResetTime":"CB Reset Time","rateLimiting":"Rate Limiting","rateLimitingDesc":"API Key providers are automatically rate-limited with safe defaults. Limits are learned from response headers and adapt over time.","defaultSafetyNet":"Default Safety Net","rpm":"RPM","minGap":"Min Gap","maxConcurrent":"Max Concurrent","activeLimiters":"Active Limiters","noActiveLimiters":"No active rate limiters yet.","reservoir":"Reservoir","running":"Running","queued":"Queued","circuitBreakers":"Circuit Breakers","tripped":"{count} tripped","healthy":"{count} healthy","resetAll":"Reset All","noCircuitBreakers":"No circuit breakers active yet. They are created automatically when requests flow through the combo pipeline.","failures":"{count} failure(s)","policiesLocked":"Policies & Locked Identifiers","allOperational":"All systems operational — no lockouts or tripped breakers","loadingPolicies":"Loading policies...","lockedIdentifiers":"Locked Identifiers","forceUnlock":"Force Unlock","unlocking":"Unlocking...","failedUnlock":"Failed to unlock","loadingResilience":"Loading resilience status...","retry":"Retry","systemStorage":"System & Storage","allDataLocal":"All data stored locally on your machine","databasePath":"Database Path","exportDatabase":"Export Database","exportAll":"Export All (.tar.gz)","importDatabase":"Import Database","confirmDbImport":"Confirm Database Import","confirmDbImportDesc":"This will replace all current data with the content from {file}. A backup will be created automatically before the import.","yesImport":"Yes, Import","lastBackup":"Last Backup","noBackupYet":"No backup yet","backupNow":"Backup Now","backupRestore":"Backup & Restore","viewBackups":"View Backups","hide":"Hide","backupRetentionDesc":"Database snapshots are created automatically before restore and every 15 minutes when data changes. Retention: 24 hourly + 30 daily backups with smart rotation.","loadingBackups":"Loading backups...","noBackupsYet":"No backups available yet. Backups will be created automatically when data changes.","backupsAvailable":"{count} backup(s) available","refresh":"Refresh","confirm":"Confirm?","yes":"Yes","no":"No","restore":"Restore","invalidFileType":"Invalid file type. Only .sqlite files are accepted.","noChangesSinceBackup":"No changes since last backup","backupFailed":"Backup failed","restoreFailed":"Restore failed","importFailed":"Import failed","errorDuringRestore":"An error occurred during restore","errorDuringImport":"An error occurred during import","modelPricing":"Model Pricing","modelPricingDesc":"Configure cost rates per model • All rates in $/1M tokens","providers":"Providers","registry":"Registry","priced":"Priced","searchProvidersModels":"Search providers or models...","showAll":"Show All","noProvidersMatch":"No providers match your search.","howPricingWorks":"How Pricing Works","cacheWrite":"Cache Write","unsaved":"unsaved","resetDefaults":"Reset Defaults","saveProvider":"Save Provider","saving":"Saving...","model":"Model","models":"models","withPricing":"with pricing configured","policiesCircuitBreakers":"Policies & Circuit Breakers","activeIssuesDetected":"Active issues detected","off":"Off","resetPricingConfirm":"Reset all pricing for {provider} to defaults?","pricingDescInput":"Input: tokens sent to the model","pricingDescOutput":"Output: tokens generated","pricingDescCached":"Cached: reused input (~50% of input rate)","pricingDescReasoning":"Reasoning: thinking tokens (falls back to Output)","pricingDescCacheWrite":"Cache Write: creating cache entries (falls back to Input)","pricingDescFormula":"Cost = (input \xd7 input_rate) + (output \xd7 output_rate) + (cached \xd7 cached_rate) per million tokens.","pricingSettingsTitle":"Pricing Settings","totalModels":"Total Models","active":"Active","costCalculation":"Cost Calculation","costCalculationDesc":"Costs are calculated based on token usage and pricing rates configured for each model.","pricingFormat":"Pricing Format","pricingFormatDesc":"All rates are in $/1M tokens (dollars per million tokens).","tokenTypes":"Token Types","inputTokenDesc":"Standard prompt tokens","outputTokenDesc":"Completion/response tokens","cachedTokenDesc":"Cached input tokens (typically 50% of input rate)","reasoningTokenDesc":"Special reasoning/thinking tokens (fallback to output rate)","cacheCreationTokenDesc":"Tokens used to create cache entries (fallback to input rate)","customPricingNote":"You can override default pricing for specific models. Custom overrides take priority over auto-detected pricing.","editPricing":"Edit Pricing","viewFullDetails":"View Full Details"},"translator":{"title":"Translator","realtime":"Real-Time Translation Activity","chatTester":"Chat Tester","testBench":"Test Bench","recentTranslations":"Recent Translations","noTranslations":"No translations yet","source":"Source","target":"Target","latency":"Latency","formatConverter":"Format Converter","input":"Input","output":"Output","exampleTemplates":"Example Templates","compatibilityTester":"Compatibility Tester","compatibilityReport":"Compatibility Report","pipelineDebugger":"Pipeline Debugger","translationPipeline":"Translation Pipeline","pipelineVisualization":"Pipeline visualization"},"usage":{"title":"Usage","budgetManagement":"Budget Management","apiKey":"API Key","thisMonth":"This Month","setLimits":"Set Limits","totalRequests":"Total requests","noDataYet":"No data yet","entries":"Entries","hitRate":"Hit Rate","hitsMisses":"Hits / Misses","circuitBreakers":"Circuit Breakers","lockedIPs":"Locked IPs","howItWorks":"How It Works","define":"Define","run":"Run","evaluate":"Evaluate","evalSuites":"Evaluation Suites","modelEvals":"Model Evaluations","modelLockouts":"Model Lockouts","noLockouts":"No models currently locked","activeSessions":"Active Sessions","noSessions":"No active sessions","sessionsHint":"Sessions appear as requests flow through the proxy","session":"Session","age":"Age","requests":"Requests","connection":"Connection","providerLimits":"Provider Limits","noProviders":"No Providers Connected","modelQuotas":"Model Quotas","noQuotaData":"No quota data","noQuotaDataAvailable":"No quota data available"},"modals":{"waitingAuth":"Waiting for Authorization","verificationUrl":"Verification URL","yourCode":"Your Code","remoteAccess":"Remote access:","connectedSuccess":"Connected Successfully!","connectionFailed":"Connection Failed","chooseAuthMethod":"Choose your authentication method:","awsBuilderId":"AWS Builder ID","awsIamIdentity":"AWS IAM Identity Center","googleAccount":"Google Account","githubAccount":"GitHub Account","importToken":"Import Token","pasteToken":"Paste refresh token from Kiro IDE.","awsRegion":"AWS Region","autoDetecting":"Auto-detecting tokens...","readingFromCache":"Reading from AWS SSO cache","readingFromCursor":"Reading from Cursor IDE database","initializing":"Initializing...","pricingConfig":"Pricing Configuration","loadingPricing":"Loading pricing data...","pricingRatesFormat":"Pricing Rates Format","noPricingData":"No pricing data available","noModelsFound":"No models found"},"loggers":{"allProviders":"All Providers","allModels":"All Models","allAccounts":"All Accounts","allApiKeys":"All API Keys","allTypes":"All Types","allLevels":"All Levels","modelAZ":"Model A-Z","modelZA":"Model Z-A","loadingLogs":"Loading logs...","loadingProxyLogs":"Loading proxy logs...","noLogEntries":"No log entries found","noPayloadData":"No payload data available for this log entry.","proxyEvent":"Proxy Event","proxy":"Proxy","level":"Level","directNative":"Direct (native)","combo":"Combo","inputTokens":"I:","outputTokens":"O:"},"stats":{"usageOverview":"Usage Overview","outputTokens":"Output Tokens","totalCost":"Total Cost","usageByModel":"Usage by Model","usageByAccount":"Usage by Account","failedToLoad":"Failed to load usage statistics.","tokenHealth":"Token Health","totalOAuth":"Total OAuth","healthy":"Healthy","errored":"Errored","lastCheck":"Last check","noData":"No data","share":"Share","unableToLoad":"Unable to load system metrics","product":"Product","resources":"Resources","company":"Company"},"auth":{"welcome":"Welcome","signIn":"Sign in","enterPassword":"Enter your password to continue","password":"Password","unifiedProxy":"Unified AI API Proxy","passwordNotEnabled":"Password protection is not enabled","resetPassword":"Reset Password","resetDescription":"Choose a method to recover access to your dashboard","stopServer":"Stop the OmniRoute server","processing":"Processing...","pleaseWait":"Please wait while we complete the authorization.","authSuccess":"Authorization Successful!","copyUrl":"Copy This URL","accessDenied":"Access Denied","forgotPassword":"Forgot password?"},"landing":{"allProviders":"All AI Providers","oneEndpoint":"One Endpoint","powerfulFeatures":"Powerful Features","howItWorks":"How OmniRoute Works","installOmniRoute":"Install OmniRoute","openDashboard":"Open Dashboard","routeRequests":"Route Requests","dataLocation":"Data Location:","getStarted":"Get Started","product":"Product","resources":"Resources","legal":"Legal","interactiveDiagram":"Interactive diagram visible on desktop"},"docs":{"title":"Documentation","quickStart":"Quick Start","features":"Features","supportedProviders":"Supported Providers","commonUseCases":"Common Use Cases","clientCompatibility":"Client Compatibility","apiReference":"API Reference","method":"Method","path":"Path","notes":"Notes","modelPrefixes":"Model Prefixes","prefix":"Prefix","troubleshooting":"Troubleshooting","supportsChat":"Supports both chat and responses endpoints.","oauthAutoRefresh":"OAuth connection with automatic token refresh.","fullStreaming":"Full streaming support for all models."},"legal":{"privacyPolicy":"Privacy Policy","termsOfService":"Terms of Service","providerConfigurations":"Provider configurations","apiKeys":"API keys","usageLogs":"Usage logs","applicationSettings":"Application settings","viewExportAnalytics":"View and export usage analytics","clearHistory":"Clear usage history at any time","configureRetention":"Configure log retention policies","backupRestore":"Back up and restore your database"}}')}};
|
|
1
|
+
"use strict";exports.id=1960,exports.ids=[1960],exports.modules={31960:a=>{a.exports=JSON.parse('{"common":{"save":"Save","cancel":"Cancel","delete":"Delete","loading":"Loading...","error":"An error occurred","success":"Success","confirm":"Are you sure?","refresh":"Refresh","close":"Close","add":"Add","edit":"Edit","search":"Search","back":"Back","next":"Next","submit":"Submit","reset":"Reset","copy":"Copy","copied":"Copied!","enabled":"Enabled","disabled":"Disabled","active":"Active","inactive":"Inactive","noData":"No data available","configure":"Configure","manage":"Manage","name":"Name","actions":"Actions","status":"Status","type":"Type","model":"Model","models":"models","provider":"Provider","account":"Account","time":"Time","details":"Details","created":"Created","lastUsed":"Last Used","loadMore":"Load More","noResults":"No results found","reloadPage":"Reload Page","connected":"Connected","disconnected":"Disconnected","notConfigured":"Not configured","testConnection":"Test Connection","enable":"Enable","disable":"Disable","columns":"Columns","newest":"Newest","oldest":"Oldest","all":"All","none":"None","yes":"Yes","no":"No","warning":"Warning","note":"Note","free":"Free","skipToContent":"Skip to content"},"sidebar":{"home":"Home","dashboard":"Dashboard","providers":"Providers","combos":"Combos","usage":"Usage","analytics":"Analytics","costs":"Costs","health":"Health","limits":"Limits & Quotas","cliTools":"CLI Tools","settings":"Settings","translator":"Translator","docs":"Docs","issues":"Issues","endpoint":"Endpoint","apiManager":"API Manager","logs":"Logs","auditLog":"Audit Log","shutdown":"Shutdown","restart":"Restart","shutdownConfirm":"Shut down OmniRoute?","restartConfirm":"Restart OmniRoute?","version":"v{version}","debug":"Debug","system":"System","help":"Help","serverDisconnected":"Server Disconnected","serverDisconnectedMsg":"The proxy server has been stopped or is restarting.","expandSidebar":"Expand sidebar","collapseSidebar":"Collapse sidebar"},"header":{"logout":"Logout","language":"Language","providers":"Providers","providerDescription":"Manage your AI provider connections","combos":"Combos","comboDescription":"Model combos with fallback","usage":"Usage & Analytics","usageDescription":"Monitor your API usage, token consumption, and request logs","analytics":"Analytics","analyticsDescription":"Charts, trends, and evaluation insights","cliTools":"CLI Tools","cliToolsDescription":"Configure CLI tools","home":"Home","homeDescription":"Welcome to OmniRoute","endpoint":"Endpoint","endpointDescription":"API endpoint configuration","settings":"Settings","settingsDescription":"Manage your preferences","openaiCompatible":"OpenAI Compatible","anthropicCompatible":"Anthropic Compatible"},"home":{"quickStart":"Quick Start","quickStartDesc":"Get up and running in 4 steps. Connect providers, route models, monitor everything.","fullDocs":"Full Docs","step1Title":"1. Create API key","step1Desc":"Go to {endpoint} → Registered Keys. Generate one key per environment.","step2Title":"2. Connect providers","step2Desc":"Add accounts in {providers}. Supports OAuth, API Key, and free tiers.","step3Title":"3. Point your client","step3Desc":"Set base URL to {url} in your IDE or API client.","step4Title":"4. Monitor & optimize","step4Desc":"Track tokens, cost and errors in {logs} and {analytics}.","providersOverview":"Providers Overview","configuredOf":"{configured} configured of {total} available providers","noModelsAvailable":"No models available for this provider.","configureFirst":"Configure a connection first in {providers}","configureProvider":"Configure Provider","modelAvailable":"{count} model available","modelsAvailable":"{count} models available","connectionsActive":"{count} connection active","connectionsActivePlural":"{count} connections active","copyModelName":"Copy model name","documentation":"Documentation","healthMonitor":"Health Monitor","reportIssue":"Report issue","activeError":"{active} active \xb7 {errors} error"},"analytics":{"title":"Analytics","overviewDescription":"Monitor your API usage patterns, token consumption, costs, and activity trends across all providers and models.","evalsDescription":"Run evaluation suites to test and validate your LLM endpoints. Compare model quality, detect regressions, and benchmark latency.","overview":"Overview","evals":"Evals"},"apiManager":{"title":"API Keys","createKey":"Create API Key","key":"Key","revokeKey":"Revoke Key","revokeConfirm":"Are you sure you want to revoke this API key?","noKeys":"No API keys yet","noKeysDesc":"Create your first API key to authenticate requests to your endpoint","keyLabel":"Key Label","permissions":"Permissions","expiresAt":"Expires","never":"Never","revoke":"Revoke","showKey":"Show Key","hideKey":"Hide Key","copyKey":"Copy API Key","allModels":"All models","selectedModels":"Selected Models","readOnly":"Read Only","fullAccess":"Full Access","keyManagement":"API Key Management","keyManagementDesc":"Create and manage API keys for authenticating requests to your endpoint","totalKeys":"Total Keys","restricted":"Restricted","totalRequests":"Total Requests","modelsAvailable":"Models Available","registeredKeys":"Registered Keys","keysRegistered":"{count} keys registered","keyRegistered":"{count} key registered","keysSecurityNote":"Each key isolates usage tracking and can be revoked independently. Keys are masked after creation for security.","createFirstKey":"Create Your First Key","name":"Name","usage":"Usage","created":"Created","actions":"Actions","reqs":"reqs","neverUsed":"Never used","deleteConfirm":"Delete this API key?","usageTips":"Usage Tips","tipAuth":"Use API keys in the Authorization header as Bearer YOUR_KEY","tipSecure":"Keys are only shown once during creation — store them securely","tipSeparate":"Create separate keys for different clients or environments","tipRestrict":"Restrict keys to specific models for better security and cost control","keyName":"Key Name","keyNamePlaceholder":"e.g., Production Key, Development Key","keyNameDesc":"Choose a descriptive name to identify this key\'s purpose","keyCreated":"API Key Created","keyCreatedSuccess":"Key created successfully!","keyCreatedNote":"Copy and store this key now — it won\'t be shown again.","done":"Done","savePermissions":"Save Permissions","allowAll":"Allow All","restrict":"Restrict","allowAllInfo":"This key can access all available models.","restrictInfo":"This key can access {selected} of {total} models.","selected":"{count} selected","all":"All","clear":"Clear","searchModels":"Search models by name or provider...","noModelsFound":"No models found","keyNameRequired":"Key name is required","keyNameTooLong":"Key name must be {max} characters or less","keyNameInvalid":"Key name can only contain letters, numbers, spaces, hyphens, and underscores","model":"{count} model","models":"{count} models","permissionsTitle":"Permissions: {name}","allowAllDesc":"This key can access all available models.","restrictDesc":"This key can access {selectedCount} of {totalModels} models.","selectedCount":"{count} selected"},"auditLog":{"title":"Audit Log","searchPlaceholder":"Search actions...","action":"Action","actor":"Actor","target":"Target","ipAddress":"IP Address","timestamp":"Timestamp","noEntries":"No audit entries found","filterByAction":"Filter by action...","filterByActor":"Filter by actor...","description":"Administrative actions and security events","showing":"Showing {count} entries (offset {offset})","previous":"Previous"},"cliTools":{"title":"CLI Tools","noActiveProviders":"No active providers","noActiveProvidersDesc":"Please add and connect providers first to configure CLI tools.","mapModels":"Map Models","testConnection":"Test Connection","connectionStatus":"Connection Status","configureEndpoint":"Configure Endpoint","instructions":"Instructions","modelMapping":"Model Mapping","baseUrl":"Base URL","apiKey":"API Key"},"combos":{"title":"Combos","description":"Create model combos with weighted routing and fallback support","createCombo":"Create Combo","editCombo":"Edit Combo","deleteCombo":"Delete Combo","noModels":"No models","noModelsYet":"No models added yet","addModel":"Add Model","addModelToCombo":"Add Model to Combo","routingStrategy":"Routing Strategy","maxRetries":"Max Retries","timeout":"Timeout (ms)","healthcheck":"Healthcheck","priority":"Priority","fallback":"Fallback","roundRobin":"Round Robin","random":"Random","leastLatency":"Least Latency","comboName":"Combo Name","comboNamePlaceholder":"my-combo","deleteConfirm":"Delete this combo?","noCombosYet":"No combos yet","comboCreated":"Combo created successfully","comboUpdated":"Combo updated successfully","comboDeleted":"Combo deleted","failedCreate":"Failed to create combo","failedUpdate":"Failed to update combo","errorCreating":"Error creating combo","errorUpdating":"Error updating combo","errorDeleting":"Error deleting combo","testFailed":"Test request failed","failedToggle":"Failed to toggle combo","testResults":"Test Results — {name}","resolvedBy":"Resolved by:","more":"+{count} more","reqs":"reqs","success":"success","proxyConfigured":"Proxy configured","copyComboName":"Copy combo name","enableCombo":"Enable combo","disableCombo":"Disable combo","testCombo":"Test combo","duplicate":"Duplicate","proxyConfig":"Proxy configuration","nameRequired":"Name is required","nameInvalid":"Only letters, numbers, -, _, / and . allowed","nameHint":"Letters, numbers, -, _, / and . allowed","priorityDesc":"Sequential fallback: tries model 1 first, then 2, etc.","weightedDesc":"Distributes traffic by weight percentage with fallback","roundRobinDesc":"Circular distribution: each request goes to the next model in rotation","randomDesc":"Uniform random selection, then fallback to remaining models","leastUsedDesc":"Picks the model with fewest requests, balancing load over time","costOptimizedDesc":"Routes to the cheapest model first based on pricing","models":"Models","autoBalance":"Auto-balance","advancedSettings":"Advanced Settings","retryDelay":"Retry Delay (ms)","concurrencyPerModel":"Concurrency / Model","queueTimeout":"Queue Timeout (ms)","advancedHint":"Leave empty to use global defaults. These override per-provider settings.","saving":"Saving...","weighted":"Weighted","leastUsed":"Least-Used","costOpt":"Cost-Opt"},"costs":{"title":"Costs","budget":"Budget","totalCost":"Total Cost","breakdown":"Cost Breakdown","noData":"No cost data","byModel":"By Model","byProvider":"By Provider"},"endpoint":{"title":"API Endpoint","available":"Available Endpoints","cloudProxy":"Cloud Proxy","disableConfirm":"Are you sure you want to disable cloud proxy?","baseUrl":"Base URL","apiKeyLabel":"API Key","registeredKeys":"Registered Keys","chatCompletions":"Chat Completions","responses":"Responses","listModels":"List Models","usingCloudProxy":"Using Cloud Proxy","usingLocalServer":"Using Local Server","machineId":"Machine ID: {id}...","disableCloud":"Disable Cloud","enableCloud":"Enable Cloud","modelsAcrossEndpoints":"{models} models across {endpoints} endpoints","chatDesc":"Streaming & non-streaming chat with all providers","embeddings":"Embeddings","embeddingsDesc":"Text embeddings for search & RAG pipelines","imageGeneration":"Image Generation","imageDesc":"Generate images from text prompts","rerank":"Rerank","rerankDesc":"Rerank documents by relevance to a query","audioTranscription":"Audio Transcription","audioTranscriptionDesc":"Transcribe audio files to text (Whisper)","textToSpeech":"Text to Speech","textToSpeechDesc":"Convert text to natural-sounding speech","moderations":"Moderations","moderationsDesc":"Content moderation and safety classification","enableCloudTitle":"Enable Cloud Proxy","whatYouGet":"What you will get","cloudBenefitAccess":"Access your API from anywhere in the world","cloudBenefitShare":"Share endpoint with your team easily","cloudBenefitPorts":"No need to open ports or configure firewall","cloudBenefitEdge":"Fast global edge network","cloudSessionNote":"Cloud will keep your auth session for 1 day. If not used, it will be automatically deleted.","cloudUnstableNote":"Cloud is currently unstable with Claude Code OAuth in some cases.","cloudConnected":"Cloud Proxy connected!","connectingToCloud":"Connecting to cloud...","verifyingConnection":"Verifying connection...","connecting":"Connecting...","verifying":"Verifying...","connected":"Connected!","disableCloudTitle":"Disable Cloud Proxy","disableWarning":"All auth sessions will be deleted from cloud.","syncingData":"Syncing latest data...","disablingCloud":"Disabling cloud...","syncing":"Syncing...","disabling":"Disabling...","cloudConnectedVerified":"Cloud Proxy connected and verified!","connectedVerificationPending":"Connected — verification pending","cloudDisabledSuccess":"Cloud disabled successfully","syncedSuccess":"Synced successfully","failedDisable":"Failed to disable cloud","failedEnable":"Failed to enable cloud"},"health":{"title":"System Health","description":"Real-time monitoring of your OmniRoute instance","healthy":"Healthy","degraded":"Degraded","down":"Down","uptime":"Uptime","memory":"Memory","memoryRss":"Memory (RSS)","heap":"Heap","cpu":"CPU","database":"Database","version":"Version","lastCheck":"Last Check","providerHealth":"Provider Health","systemMetrics":"System Metrics","tokenHealth":"Token Health","refreshAll":"Refresh All","checkNow":"Check Now","loadingHealth":"Loading health data...","failedToLoad":"Failed to load health data: {error}","retry":"Retry","allOperational":"All systems operational","issuesDetected":"System issues detected","latency":"Latency","totalRequests":"Total requests","noDataYet":"No data yet","promptCache":"Prompt Cache","entries":"Entries","hitRate":"Hit Rate","hitsMisses":"Hits / Misses","signatureCache":"Signature Cache","recovering":"Recovering","noCBData":"No circuit breaker data available. Make some requests first.","issuesLabel":"Issues Detected","operational":"Operational","failures":"{count} failure","failuresPlural":"{count} failures","lastFailure":"Last","rateLimitStatus":"Rate Limit Status","activeLimiters":"{count} active limiter","activeLimitersPlural":"{count} active limiters","queued":"Queued","running":"running","activeLockouts":"Active Lockouts","resetConfirm":"Reset all circuit breakers to healthy state? This will clear all failure counts and restore all providers to operational status.","resetting":"Resetting...","resetAll":"Reset All","until":"Until {time}"},"limits":{"title":"Limits & Quotas","rateLimit":"Rate Limit","remaining":"Remaining","requestsPerMinute":"Requests/min","tokensPerMinute":"Tokens/min","dailyLimit":"Daily Limit"},"logs":{"title":"Logs","requestLogs":"Request Logs","proxyLogs":"Proxy Logs","auditLog":"Audit Log","console":"Console","auditLogDesc":"Administrative actions and security events","loading":"Loading...","refresh":"Refresh","filterByAction":"Filter by action...","filterByActor":"Filter by actor...","search":"Search","timestamp":"Timestamp","action":"Action","actor":"Actor","target":"Target","details":"Details","noEntries":"No audit log entries found","previous":"Previous","next":"Next"},"onboarding":{"welcome":"Welcome","security":"Security","test":"Test","ready":"Ready!","setPassword":"Set Password","addProvider":"Add your first provider","getStarted":"Get Started","skip":"Skip","skipWizard":"Skip wizard entirely","skipPassword":"Skip password setup","skipAndContinue":"Skip & Continue","passwordLabel":"Password","confirmPassword":"Confirm Password","enterPassword":"Enter password","confirmPasswordPlaceholder":"Confirm password","passwordsMismatch":"Passwords do not match","setupComplete":"Setup Complete!","goToDashboard":"Go to Dashboard →","welcomeDesc":"OmniRoute is your local AI API proxy. It routes requests to multiple AI providers with load balancing, failover, and usage tracking.","multiProvider":"Multi-Provider","usageTracking":"Usage Tracking","apiKeyMgmt":"API Key Mgmt","securityDesc":"Set a password to protect your dashboard, or skip for now.","providerDesc":"Connect your first AI provider. You can add more later.","apiKeyRequired":"API Key (required)","customUrlOptional":"Custom URL (optional)","testDesc":"Let\'s verify your provider connection works.","runTest":"Run Connection Test","testingConnection":"Testing connection...","connectionSuccessful":"Connection successful! Your provider is ready.","noProviderFound":"No provider found. You can add one from the dashboard later.","testFailed":"Test failed, but you can configure this later.","couldNotTest":"Could not test right now. You can test from the dashboard.","doneDesc":"You\'re all set! Your OmniRoute instance is configured and ready to proxy AI requests.","yourEndpoint":"Your endpoint:","continue":"Continue","retry":"Retry","failedSetPassword":"Failed to set password. Try again.","failedAddProvider":"Failed to add provider. Try again.","connectionError":"Connection error. Please try again."},"providers":{"title":"Providers","addProvider":"Add Provider","editProvider":"Edit Provider","deleteProvider":"Delete Provider","noProviders":"No providers configured","modelAvailability":"Model Availability","accounts":"Accounts","newAccount":"New Account","deleteConfirm":"Are you sure you want to delete this provider?","testing":"Testing...","testSuccess":"Connection successful","testFailed":"Connection failed","available":"Available","unavailable":"Unavailable","unknown":"Unknown","oauthProviders":"OAuth Providers","freeProviders":"Free Providers","apiKeyProviders":"API Key Providers","compatibleProviders":"API Key Compatible Providers","testAll":"Test All","testAllOAuth":"Test all OAuth connections","testAllFree":"Test all Free connections","testAllApiKey":"Test all API Key connections","testAllCompatible":"Test all Compatible connections","connected":"{count} Connected","errorCount":"{count} Error ({code})","errorCountNoCode":"{count} Error","noConnections":"No connections","disabled":"Disabled","enableProvider":"Enable provider","disableProvider":"Disable provider","testResults":"Test Results","noCompatibleYet":"No compatible providers added yet","compatibleHint":"Use the buttons above to add OpenAI or Anthropic compatible endpoints","addOpenAICompatible":"Add OpenAI Compatible","addAnthropicCompatible":"Add Anthropic Compatible","addNewProvider":"Add New Provider","backToProviders":"Back to Providers","configureNewProvider":"Configure a new AI provider to use with your applications.","selectProvider":"Select a provider","selectedProvider":"Selected provider","authMethod":"Authentication Method","apiKeyRequired":"API Key is required","selectProviderRequired":"Please select a provider","enterApiKey":"Enter your API key","apiKeySecure":"Your API key will be encrypted and stored securely.","oauth2Connect":"Connect with OAuth2","oauth2Desc":"Connect your account using OAuth2 authentication.","displayName":"Display Name","displayNamePlaceholder":"e.g., Production API, Dev Environment","displayNameHint":"Optional. A friendly name to identify this configuration.","active":"Active","activeDescription":"Enable this provider for use in your applications","cancel":"Cancel","createProvider":"Create Provider","failedCreate":"Failed to create provider","errorOccurred":"An error occurred. Please try again.","modelStatus":"Model Status","allModelsOperational":"All models operational","modelsWithIssues":"{count} model(s) with issues","allModelsNormal":"All models are responding normally.","cooldownCleared":"Cooldown cleared for {model}","failedClearCooldown":"Failed to clear cooldown","loadingAvailability":"Loading model availability...","clearCooldown":"Clear","clearing":"Clearing...","providerTestFailed":"Provider test failed","allTestsPassed":"All {total} tests passed","testSummary":"{passed}/{total} passed, {failed} failed","nameLabel":"Name","prefixLabel":"Prefix","baseUrlLabel":"Base URL","apiTypeLabel":"API Type","prefixHint":"Required. Unique prefix for model names.","nameHint":"Required. A friendly label for this node.","baseUrlHint":"Required. Provider API base URL.","validateConnection":"Validate Connection","validating":"Validating...","connectionValid":"Connection is valid!","connectionFailed":"Connection failed. Check URL and key.","testKeyLabel":"Test API Key","testKeyPlaceholder":"sk-... (for validation only)","providerNotFound":"Provider not found","deleteConnectionConfirm":"Delete this connection?","failedSetAlias":"Failed to set alias","failedSaveConnection":"Failed to save connection","failedSaveConnectionRetry":"Failed to save connection. Please try again.","failedRetestConnection":"Failed to retest connection","deleteCompatibleNodeConfirm":"Delete this {type} Compatible node?","anthropicCompatibleDetails":"Anthropic Compatible Details","openaiCompatibleDetails":"OpenAI Compatible Details","messagesApi":"Messages API","responsesApi":"Responses API","chatCompletions":"Chat Completions","importingModels":"Importing...","importFromModels":"Import from /models","addConnectionToImport":"Add a connection to enable importing.","noModelsConfigured":"No models configured","connectionCount":"{count} connection(s)","fetchingModels":"Fetching available models...","failedFetchModels":"Failed to fetch models","noModelsFound":"No models found","importFailed":"Import failed","noNewModelsAdded":"No new models were added.","adding":"Adding...","importingModelsTitle":"Importing Models","copyModel":"Copy model","removeModel":"Remove model","rateLimitProtected":"Protected","rateLimitUnprotected":"Unprotected","enableRateLimitProtection":"Click to enable rate limit protection","disableRateLimitProtection":"Click to disable rate limit protection","productionKey":"Production Key","enterNewApiKey":"Enter new API key","optional":"Optional"},"settings":{"title":"Settings","general":"General","security":"Security","appearance":"Appearance","routing":"Routing","cache":"Cache","resilience":"Resilience","systemPrompt":"System Prompt","thinkingBudget":"Thinking Budget","proxy":"Proxy","pricing":"Pricing","storage":"Storage","policies":"Policies","ipFilter":"IP Filter","comboDefaults":"Combo Defaults","fallbackChains":"Fallback Chains","changePassword":"Change Password","enablePassword":"Enable Password","darkMode":"Dark Mode","lightMode":"Light Mode","systemTheme":"System Theme","enableCache":"Enable Cache","cacheTTL":"Cache TTL","maxCacheSize":"Max Cache Size","clearCache":"Clear Cache","cacheHits":"Cache Hits","cacheMisses":"Cache Misses","hitRate":"Hit Rate","cacheEntries":"Cache Entries","circuitBreaker":"Circuit Breaker","retryPolicy":"Retry Policy","maxRetries":"Max Retries","retryDelay":"Retry Delay","timeoutMs":"Timeout (ms)","enableSystemPrompt":"Enable System Prompt","systemPromptText":"System Prompt Text","enableThinking":"Enable Thinking","maxThinkingTokens":"Max Thinking Tokens","enableProxy":"Enable Proxy","proxyUrl":"Proxy URL","pricingRates":"Pricing Rates Format","currentPricing":"Current Pricing Overview","loadingPricing":"Loading pricing data...","noPricing":"No pricing data available","input":"Input","output":"Output","cached":"Cached","reasoning":"Reasoning","cacheCreation":"Cache Creation","customPricing":"Custom Pricing","databaseSize":"Database Size","backupDb":"Backup Database","restoreDb":"Restore Database","exportData":"Export Data","importData":"Import Data","clearData":"Clear All Data","clearDataConfirm":"This will permanently delete all data. Are you sure?","enableRequestLogs":"Enable Request Logs","logRetention":"Log Retention","ipWhitelist":"IP Whitelist","ipBlacklist":"IP Blacklist","addIP":"Add IP","savedSuccessfully":"Settings saved successfully","ai":"AI","advanced":"Advanced","localMode":"Local Mode — All data stored on your machine","switchThemes":"Switch between light and dark themes","hideHealthLogs":"Hide Health Check Logs","hideHealthLogsDesc":"When ON, suppress [HealthCheck] messages in server console","promptCache":"Prompt Cache","flushCache":"Flush Cache","flushing":"Flushing…","size":"Size","hits":"Hits","evictions":"Evictions","loadingCacheStats":"Loading cache stats…","globalProxy":"Global Proxy","globalProxyDesc":"Configure a global outbound proxy for all API calls. Individual providers, combos, and keys can override this.","noGlobalProxy":"No global proxy configured","configure":"Configure","globalSystemPrompt":"Global System Prompt","systemPromptDesc":"Injected into all requests at proxy level","saved":"Saved","systemPromptPlaceholder":"Enter system prompt to inject into all requests...","systemPromptHint":"This prompt is prepended to the system message of every request. Use for global instructions, safety guidelines, or response formatting rules.","chars":"{count} chars","thinkingBudgetTitle":"Thinking Budget","thinkingBudgetDesc":"Control AI reasoning token usage across all requests","passthrough":"Passthrough","passthroughDesc":"No changes — client controls thinking budget","auto":"Auto","autoDesc":"Strip all thinking config — let provider decide","custom":"Custom","customDesc":"Set a fixed token budget for all requests","adaptive":"Adaptive","adaptiveDesc":"Scale budget based on request complexity","tokenBudget":"Token Budget","tokens":"tokens","baseEffortLevel":"Base Effort Level","adaptiveHint":"Adaptive mode scales from this base level based on message count, tool usage, and prompt length.","requireLogin":"Require login","requireLoginDesc":"When ON, dashboard requires password. When OFF, access without login.","currentPassword":"Current Password","enterCurrentPassword":"Enter current password","newPassword":"New Password","enterNewPassword":"Enter new password","confirmPassword":"Confirm New Password","confirmPasswordPlaceholder":"Confirm new password","passwordsNoMatch":"Passwords do not match","passwordUpdated":"Password updated successfully","failedUpdatePassword":"Failed to update password","errorOccurred":"An error occurred","updatePassword":"Update Password","setPassword":"Set Password","apiEndpointProtection":"API Endpoint Protection","requireAuthModels":"Require API key for /models","requireAuthModelsDesc":"When ON, the /v1/models endpoint returns 404 for unauthenticated requests. Prevents model discovery by unauthorized users.","blockedProviders":"Blocked Providers","blockedProvidersDesc":"Hide specific providers from the /v1/models response. Blocked providers will not appear in model listings.","providersBlocked":"{count} provider(s) blocked from /models","routingStrategy":"Routing Strategy","fillFirst":"Fill First","fillFirstDesc":"Use accounts in priority order","roundRobin":"Round Robin","roundRobinDesc":"Cycle through all accounts","p2c":"P2C","p2cDesc":"Pick 2 random, use the healthier one","random":"Random","randomDesc":"Random account each request","leastUsed":"Least Used","leastUsedDesc":"Pick least recently used account","costOpt":"Cost Opt","costOptDesc":"Prefer cheapest available account","stickyLimit":"Sticky Limit","stickyLimitDesc":"Calls per account before switching","modelAliases":"Model Aliases","modelAliasesDesc":"Wildcard patterns to remap model names • Use * and ?","pattern":"Pattern","targetModel":"Target Model","add":"+ Add","session":"Session","status":"Status","authenticated":"Authenticated","guest":"Guest","loginTime":"Login Time","sessionAge":"Session Age","browser":"Browser","clearLocalData":"Clear Local Data","logout":"Logout","clearLocalDataConfirm":"Clear all local data? This will reset your preferences.","ipAccessControl":"IP Access Control","ipAccessControlDesc":"Block or allow specific IP addresses","addIpAddress":"Add IP Address","block":"+ Block","allow":"+ Allow","blocked":"Blocked ({count})","allowed":"Allowed ({count})","temporaryBans":"Temporary Bans ({count})","minLeft":"{min}m left","auditLog":"Audit Log","searchAuditLogs":"Search audit logs...","failedLoadAuditLog":"Failed to load audit log","noAuditEvents":"No audit events found","action":"Action","actor":"Actor","details":"Details","time":"Time","fallbackChainsTitle":"Fallback Chains","fallbackChainsDesc":"Define provider fallback order per model","addChain":"+ Add Chain","modelName":"Model Name","providersCommaSeparated":"Providers (comma-separated, in priority order)","createChain":"Create Chain","noFallbackChains":"No Fallback Chains","noFallbackChainsDesc":"Create a chain to define provider fallback order for a model.","loadingFallbackChains":"Loading fallback chains...","deleteChainConfirm":"Delete fallback chain for \\"{model}\\"?","chainCreated":"Chain created for {model}","chainDeleted":"Chain deleted for {model}","failedCreateChain":"Failed to create chain","failedDeleteChain":"Failed to delete chain","fillModelAndProviders":"Please fill model name and providers","addAtLeastOneProvider":"Add at least one provider","comboDefaultsTitle":"Combo Defaults","globalComboConfig":"Global combo configuration","defaultStrategy":"Default Strategy","defaultStrategyDesc":"Applied to new combos without explicit strategy","priority":"Priority","weighted":"Weighted","healthCheck":"Health Check","healthCheckDesc":"Pre-check provider availability","trackMetrics":"Track Metrics","trackMetricsDesc":"Record per-combo request metrics","providerOverrides":"Provider Overrides","providerOverridesDesc":"Override timeout and retries per provider. Provider settings override global defaults.","retries":"retries","ms":"ms","saveComboDefaults":"Save Combo Defaults","maxNestingDepth":"Max Nesting Depth","concurrencyPerModel":"Concurrency / Model","queueTimeout":"Queue Timeout (ms)","providerProfiles":"Provider Profiles","providerProfilesDesc":"Separate resilience settings for OAuth (session-based) and API Key (metered) providers. OAuth providers have stricter thresholds due to lower rate limits.","oauthProviders":"OAuth Providers","apiKeyProviders":"API Key Providers","transientCooldown":"Transient Cooldown","rateLimitCooldown":"Rate Limit Cooldown","maxBackoffLevel":"Max Backoff Level","cbThreshold":"CB Threshold","cbResetTime":"CB Reset Time","rateLimiting":"Rate Limiting","rateLimitingDesc":"API Key providers are automatically rate-limited with safe defaults. Limits are learned from response headers and adapt over time.","defaultSafetyNet":"Default Safety Net","rpm":"RPM","minGap":"Min Gap","maxConcurrent":"Max Concurrent","activeLimiters":"Active Limiters","noActiveLimiters":"No active rate limiters yet.","reservoir":"Reservoir","running":"Running","queued":"Queued","circuitBreakers":"Circuit Breakers","tripped":"{count} tripped","healthy":"{count} healthy","resetAll":"Reset All","noCircuitBreakers":"No circuit breakers active yet. They are created automatically when requests flow through the combo pipeline.","failures":"{count} failure(s)","policiesLocked":"Policies & Locked Identifiers","allOperational":"All systems operational — no lockouts or tripped breakers","loadingPolicies":"Loading policies...","lockedIdentifiers":"Locked Identifiers","forceUnlock":"Force Unlock","unlocking":"Unlocking...","failedUnlock":"Failed to unlock","loadingResilience":"Loading resilience status...","retry":"Retry","systemStorage":"System & Storage","allDataLocal":"All data stored locally on your machine","databasePath":"Database Path","exportDatabase":"Export Database","exportAll":"Export All (.tar.gz)","importDatabase":"Import Database","confirmDbImport":"Confirm Database Import","confirmDbImportDesc":"This will replace all current data with the content from {file}. A backup will be created automatically before the import.","yesImport":"Yes, Import","lastBackup":"Last Backup","noBackupYet":"No backup yet","backupNow":"Backup Now","backupRestore":"Backup & Restore","viewBackups":"View Backups","hide":"Hide","backupRetentionDesc":"Database snapshots are created automatically before restore and every 15 minutes when data changes. Retention: 24 hourly + 30 daily backups with smart rotation.","loadingBackups":"Loading backups...","noBackupsYet":"No backups available yet. Backups will be created automatically when data changes.","backupsAvailable":"{count} backup(s) available","refresh":"Refresh","confirm":"Confirm?","yes":"Yes","no":"No","restore":"Restore","invalidFileType":"Invalid file type. Only .sqlite files are accepted.","noChangesSinceBackup":"No changes since last backup","backupFailed":"Backup failed","restoreFailed":"Restore failed","importFailed":"Import failed","errorDuringRestore":"An error occurred during restore","errorDuringImport":"An error occurred during import","modelPricing":"Model Pricing","modelPricingDesc":"Configure cost rates per model • All rates in $/1M tokens","providers":"Providers","registry":"Registry","priced":"Priced","searchProvidersModels":"Search providers or models...","showAll":"Show All","noProvidersMatch":"No providers match your search.","howPricingWorks":"How Pricing Works","cacheWrite":"Cache Write","unsaved":"unsaved","resetDefaults":"Reset Defaults","saveProvider":"Save Provider","saving":"Saving...","model":"Model","models":"models","withPricing":"with pricing configured","policiesCircuitBreakers":"Policies & Circuit Breakers","activeIssuesDetected":"Active issues detected","off":"Off","resetPricingConfirm":"Reset all pricing for {provider} to defaults?","pricingDescInput":"Input: tokens sent to the model","pricingDescOutput":"Output: tokens generated","pricingDescCached":"Cached: reused input (~50% of input rate)","pricingDescReasoning":"Reasoning: thinking tokens (falls back to Output)","pricingDescCacheWrite":"Cache Write: creating cache entries (falls back to Input)","pricingDescFormula":"Cost = (input \xd7 input_rate) + (output \xd7 output_rate) + (cached \xd7 cached_rate) per million tokens.","pricingSettingsTitle":"Pricing Settings","totalModels":"Total Models","active":"Active","costCalculation":"Cost Calculation","costCalculationDesc":"Costs are calculated based on token usage and pricing rates configured for each model.","pricingFormat":"Pricing Format","pricingFormatDesc":"All rates are in $/1M tokens (dollars per million tokens).","tokenTypes":"Token Types","inputTokenDesc":"Standard prompt tokens","outputTokenDesc":"Completion/response tokens","cachedTokenDesc":"Cached input tokens (typically 50% of input rate)","reasoningTokenDesc":"Special reasoning/thinking tokens (fallback to output rate)","cacheCreationTokenDesc":"Tokens used to create cache entries (fallback to input rate)","customPricingNote":"You can override default pricing for specific models. Custom overrides take priority over auto-detected pricing.","editPricing":"Edit Pricing","viewFullDetails":"View Full Details"},"translator":{"title":"Translator","realtime":"Real-Time Translation Activity","chatTester":"Chat Tester","testBench":"Test Bench","recentTranslations":"Recent Translations","noTranslations":"No translations yet","source":"Source","target":"Target","time":"Time","model":"Model","status":"Status","latency":"Latency","formatConverter":"Format Converter","input":"Input","output":"Output","exampleTemplates":"Example Templates","compatibilityTester":"Compatibility Tester","compatibilityReport":"Compatibility Report","pipelineDebugger":"Pipeline Debugger","translationPipeline":"Translation Pipeline","pipelineVisualization":"Pipeline visualization"},"usage":{"title":"Usage","budgetManagement":"Budget Management","apiKey":"API Key","thisMonth":"This Month","setLimits":"Set Limits","totalRequests":"Total requests","noDataYet":"No data yet","entries":"Entries","hitRate":"Hit Rate","hitsMisses":"Hits / Misses","circuitBreakers":"Circuit Breakers","lockedIPs":"Locked IPs","howItWorks":"How It Works","define":"Define","run":"Run","evaluate":"Evaluate","evalSuites":"Evaluation Suites","modelEvals":"Model Evaluations","modelLockouts":"Model Lockouts","noLockouts":"No models currently locked","activeSessions":"Active Sessions","noSessions":"No active sessions","sessionsHint":"Sessions appear as requests flow through the proxy","session":"Session","age":"Age","requests":"Requests","connection":"Connection","providerLimits":"Provider Limits","noProviders":"No Providers Connected","account":"Account","modelQuotas":"Model Quotas","lastUsed":"Last Used","actions":"Actions","noQuotaData":"No quota data","noQuotaDataAvailable":"No quota data available"},"modals":{"waitingAuth":"Waiting for Authorization","verificationUrl":"Verification URL","yourCode":"Your Code","remoteAccess":"Remote access:","connectedSuccess":"Connected Successfully!","connectionFailed":"Connection Failed","chooseAuthMethod":"Choose your authentication method:","awsBuilderId":"AWS Builder ID","awsIamIdentity":"AWS IAM Identity Center","googleAccount":"Google Account","githubAccount":"GitHub Account","importToken":"Import Token","pasteToken":"Paste refresh token from Kiro IDE.","awsRegion":"AWS Region","autoDetecting":"Auto-detecting tokens...","readingFromCache":"Reading from AWS SSO cache","readingFromCursor":"Reading from Cursor IDE database","initializing":"Initializing...","pricingConfig":"Pricing Configuration","loadingPricing":"Loading pricing data...","pricingRatesFormat":"Pricing Rates Format","noPricingData":"No pricing data available","noModelsFound":"No models found"},"loggers":{"allProviders":"All Providers","allModels":"All Models","allAccounts":"All Accounts","allApiKeys":"All API Keys","allTypes":"All Types","allLevels":"All Levels","modelAZ":"Model A-Z","modelZA":"Model Z-A","loadingLogs":"Loading logs...","loadingProxyLogs":"Loading proxy logs...","noLogEntries":"No log entries found","noPayloadData":"No payload data available for this log entry.","proxyEvent":"Proxy Event","proxy":"Proxy","level":"Level","directNative":"Direct (native)","combo":"Combo","inputTokens":"I:","outputTokens":"O:"},"stats":{"usageOverview":"Usage Overview","outputTokens":"Output Tokens","totalCost":"Total Cost","usageByModel":"Usage by Model","usageByAccount":"Usage by Account","failedToLoad":"Failed to load usage statistics.","tokenHealth":"Token Health","totalOAuth":"Total OAuth","healthy":"Healthy","warning":"Warning","errored":"Errored","lastCheck":"Last check","noData":"No data","share":"Share","unableToLoad":"Unable to load system metrics","product":"Product","resources":"Resources","company":"Company"},"auth":{"welcome":"Welcome","signIn":"Sign in","enterPassword":"Enter your password to continue","password":"Password","unifiedProxy":"Unified AI API Proxy","passwordNotEnabled":"Password protection is not enabled","resetPassword":"Reset Password","resetDescription":"Choose a method to recover access to your dashboard","stopServer":"Stop the OmniRoute server","processing":"Processing...","pleaseWait":"Please wait while we complete the authorization.","authSuccess":"Authorization Successful!","copyUrl":"Copy This URL","accessDenied":"Access Denied","forgotPassword":"Forgot password?"},"landing":{"allProviders":"All AI Providers","oneEndpoint":"One Endpoint","powerfulFeatures":"Powerful Features","howItWorks":"How OmniRoute Works","installOmniRoute":"Install OmniRoute","openDashboard":"Open Dashboard","routeRequests":"Route Requests","dataLocation":"Data Location:","getStarted":"Get Started","product":"Product","resources":"Resources","legal":"Legal","interactiveDiagram":"Interactive diagram visible on desktop"},"docs":{"title":"Documentation","quickStart":"Quick Start","features":"Features","supportedProviders":"Supported Providers","commonUseCases":"Common Use Cases","clientCompatibility":"Client Compatibility","apiReference":"API Reference","method":"Method","path":"Path","notes":"Notes","modelPrefixes":"Model Prefixes","prefix":"Prefix","troubleshooting":"Troubleshooting","supportsChat":"Supports both chat and responses endpoints.","oauthAutoRefresh":"OAuth connection with automatic token refresh.","fullStreaming":"Full streaming support for all models."},"legal":{"privacyPolicy":"Privacy Policy","termsOfService":"Terms of Service","providerConfigurations":"Provider configurations","apiKeys":"API keys","usageLogs":"Usage logs","applicationSettings":"Application settings","viewExportAnalytics":"View and export usage analytics","clearHistory":"Clear usage history at any time","configureRetention":"Configure log retention policies","backupRestore":"Back up and restore your database"}}')}};
|