🌐 Languages: 🇺🇸 English | 🇧🇷 Português (Brasil) | 🇪🇸 Español | 🇫🇷 Français | 🇮🇹 Italiano | 🇷🇺 Русский | 🇨🇳 中文 (简体) | 🇩🇪 Deutsch | 🇮🇳 हिन्दी | 🇹🇭 ไทย | 🇺🇦 Українська | 🇸🇦 العربية | 🇯🇵 日本語 | 🇻🇳 Tiếng Việt | 🇧🇬 Български | 🇩🇰 Dansk | 🇫🇮 Suomi | 🇮🇱 עברית | 🇭🇺 Magyar | 🇮🇩 Bahasa Indonesia | 🇰🇷 한국어 | 🇲🇾 Bahasa Melayu | 🇳🇱 Nederlands | 🇳🇴 Norsk | 🇵🇹 Português (Portugal) | 🇷🇴 Română | 🇵🇱 Polski | 🇸🇰 Slovenčina | 🇸🇪 Svenska | 🇵🇭 Filipino
Terakhir diperbarui: 18-02-2026
OmniRoute adalah gateway dan dasbor perutean AI lokal yang dibangun di Next.js.
Ini menyediakan satu titik akhir yang kompatibel dengan OpenAI (/v1/*) dan merutekan lalu lintas di beberapa penyedia upstream dengan terjemahan, fallback, penyegaran token, dan pelacakan penggunaan.
Kemampuan inti:
- Permukaan API yang kompatibel dengan OpenAI untuk CLI/alat (28 penyedia)
- Permintaan/tanggapan terjemahan lintas format penyedia
- Model kombo fallback (urutan multi-model)
- Penggantian tingkat akun (multi-akun per penyedia)
- Manajemen koneksi penyedia kunci OAuth + API
- Menyematkan generasi melalui
/v1/embeddings(6 penyedia, 9 model) - Pembuatan gambar melalui
/v1/images/generations(4 penyedia, 9 model) - Pikirkan penguraian tag (
<think>...</think>) untuk model penalaran - Sanitasi respons untuk kompatibilitas OpenAI SDK yang ketat
- Normalisasi peran (pengembang→sistem, sistem→pengguna) untuk kompatibilitas lintas penyedia
- Konversi keluaran terstruktur (json_schema → Gemini responSchema)
- Persistensi lokal untuk penyedia, kunci, alias, kombo, pengaturan, harga
- Pelacakan penggunaan/biaya dan pencatatan permintaan
- Sinkronisasi cloud opsional untuk sinkronisasi multi-perangkat/negara
- Daftar IP yang diizinkan/daftar blokir untuk kontrol akses API
- Memikirkan manajemen anggaran (passthrough/otomatis/custom/adaptif)
- Injeksi cepat sistem global
- Pelacakan sesi dan sidik jari
- Pembatasan tarif yang ditingkatkan per akun dengan profil khusus penyedia
- Pola pemutus sirkuit untuk ketahanan penyedia
- Perlindungan kawanan anti guntur dengan penguncian mutex
- Cache deduplikasi permintaan berbasis tanda tangan
- Lapisan domain: ketersediaan model, aturan biaya, kebijakan fallback, kebijakan lockout
- Persistensi status domain (cache tulis SQLite untuk fallback, anggaran, penguncian, pemutus sirkuit)
- Mesin kebijakan untuk evaluasi permintaan terpusat (lockout → anggaran → fallback)
- Minta telemetri dengan agregasi latensi p50/p95/p99
- ID Korelasi (X-Request-Id) untuk penelusuran ujung ke ujung
- Pencatatan audit kepatuhan dengan opt-out per kunci API
- Kerangka evaluasi untuk penjaminan mutu LLM
- Dasbor UI ketahanan dengan status pemutus sirkuit waktu nyata
- Penyedia OAuth modular (12 modul individual di bawah
src/lib/oauth/providers/)
Model waktu proses utama:
- Rute aplikasi Next.js di bawah
src/app/api/*mengimplementasikan API dasbor dan API kompatibilitas - Inti SSE/perutean bersama di
src/sse/*+open-sse/*menangani eksekusi, terjemahan, streaming, fallback, dan penggunaan penyedia
- Waktu aktif gateway lokal
- API manajemen dasbor
- Otentikasi penyedia dan penyegaran token
- Minta terjemahan dan streaming SSE
- Status lokal + persistensi penggunaan
- Orkestrasi sinkronisasi cloud opsional
- Implementasi layanan cloud di belakang
NEXT_PUBLIC_CLOUD_URL - Penyedia SLA/bidang kontrol di luar proses lokal
- Biner CLI eksternal itu sendiri (Claude CLI, Codex CLI, dll.)
flowchart LR
subgraph Clients[Developer Clients]
C1[Claude Code]
C2[Codex CLI]
C3[OpenClaw / Droid / Cline / Continue / Roo]
C4[Custom OpenAI-compatible clients]
BROWSER[Browser Dashboard]
end
subgraph Router[OmniRoute Local Process]
API[V1 Compatibility API\n/v1/*]
DASH[Dashboard + Management API\n/api/*]
CORE[SSE + Translation Core\nopen-sse + src/sse]
DB[(db.json)]
UDB[(usage.json + log.txt)]
end
subgraph Upstreams[Upstream Providers]
P1[OAuth Providers\nClaude/Codex/Gemini/Qwen/iFlow/GitHub/Kiro/Cursor/Antigravity]
P2[API Key Providers\nOpenAI/Anthropic/OpenRouter/GLM/Kimi/MiniMax\nDeepSeek/Groq/xAI/Mistral/Perplexity\nTogether/Fireworks/Cerebras/Cohere/NVIDIA]
P3[Compatible Nodes\nOpenAI-compatible / Anthropic-compatible]
end
subgraph Cloud[Optional Cloud Sync]
CLOUD[Cloud Sync Endpoint\nNEXT_PUBLIC_CLOUD_URL]
end
C1 --> API
C2 --> API
C3 --> API
C4 --> API
BROWSER --> DASH
API --> CORE
DASH --> DB
CORE --> DB
CORE --> UDB
CORE --> P1
CORE --> P2
CORE --> P3
DASH --> CLOUD
Direktori utama:
src/app/api/v1/*dansrc/app/api/v1beta/*untuk API kompatibilitassrc/app/api/*untuk API manajemen/konfigurasi- Selanjutnya penulisan ulang di
next.config.mjspeta/v1/*menjadi/api/v1/*
Rute kompatibilitas penting:
src/app/api/v1/chat/completions/route.tssrc/app/api/v1/messages/route.tssrc/app/api/v1/responses/route.tssrc/app/api/v1/models/route.ts— termasuk model khusus dengancustom: truesrc/app/api/v1/embeddings/route.ts— generasi penyematan (6 penyedia)src/app/api/v1/images/generations/route.ts— pembuatan gambar (4+ penyedia termasuk Antigravity/Nebius)src/app/api/v1/messages/count_tokens/route.tssrc/app/api/v1/providers/[provider]/chat/completions/route.ts— obrolan khusus per penyediasrc/app/api/v1/providers/[provider]/embeddings/route.ts— penyematan khusus per penyediasrc/app/api/v1/providers/[provider]/images/generations/route.ts— gambar khusus per penyediasrc/app/api/v1beta/models/route.tssrc/app/api/v1beta/models/[...path]/route.ts
Domain manajemen:
- Otentikasi/pengaturan:
src/app/api/auth/*,src/app/api/settings/* - Penyedia/koneksi:
src/app/api/providers* - Node penyedia:
src/app/api/provider-nodes* - Model khusus:
src/app/api/provider-models(GET/POST/DELETE) - Katalog model:
src/app/api/models/catalog(GET) - Konfigurasi proxy:
src/app/api/settings/proxy(GET/PUT/DELETE) +src/app/api/settings/proxy/test(POST) - OAuth:
src/app/api/oauth/* - Kunci/alias/kombo/harga:
src/app/api/keys*,src/app/api/models/alias,src/app/api/combos*,src/app/api/pricing - Penggunaan:
src/app/api/usage/* - Sinkronisasi/cloud:
src/app/api/sync/*,src/app/api/cloud/* - Pembantu perkakas CLI:
src/app/api/cli-tools/* - Filter IP:
src/app/api/settings/ip-filter(DAPATKAN/PUT) - Memikirkan anggaran:
src/app/api/settings/thinking-budget(GET/PUT) - Perintah sistem:
src/app/api/settings/system-prompt(GET/PUT) - Sesi:
src/app/api/sessions(DAPATKAN) - Batas tarif:
src/app/api/rate-limits(GET) - Ketahanan:
src/app/api/resilience(GET/PATCH) — profil penyedia, pemutus sirkuit, status batas kecepatan - Reset ketahanan:
src/app/api/resilience/reset(POST) — reset pemutus + cooldown - Statistik cache:
src/app/api/cache/stats(DAPATKAN/HAPUS) - Ketersediaan model:
src/app/api/models/availability(GET/POST) - Telemetri:
src/app/api/telemetry/summary(GET) - Anggaran:
src/app/api/usage/budget(DAPATKAN/POST) - Rantai cadangan:
src/app/api/fallback/chains(GET/POST/DELETE) - Audit kepatuhan:
src/app/api/compliance/audit-log(GET) - Nilai:
src/app/api/evals(GET/POST),src/app/api/evals/[suiteId](GET) - Kebijakan:
src/app/api/policies(DAPATKAN/POST)
Modul aliran utama:
- Entri:
src/sse/handlers/chat.ts - Orkestrasi inti:
open-sse/handlers/chatCore.ts - Adaptor eksekusi penyedia:
open-sse/executors/* - Deteksi format/konfigurasi penyedia:
open-sse/services/provider.ts - Model penguraian/penyelesaian:
src/sse/services/model.ts,open-sse/services/model.ts - Logika penggantian akun:
open-sse/services/accountFallback.ts - Registri terjemahan:
open-sse/translator/index.ts - Transformasi aliran:
open-sse/utils/stream.ts,open-sse/utils/streamHandler.ts - Ekstraksi/normalisasi penggunaan:
open-sse/utils/usageTracking.ts - Pikirkan pengurai tag:
open-sse/utils/thinkTagParser.ts - Pengendali penyematan:
open-sse/handlers/embeddings.ts - Menanamkan registri penyedia:
open-sse/config/embeddingRegistry.ts - Pengendali pembuatan gambar:
open-sse/handlers/imageGeneration.ts - Registri penyedia gambar:
open-sse/config/imageRegistry.ts - Sanitasi respons:
open-sse/handlers/responseSanitizer.ts - Normalisasi peran:
open-sse/services/roleNormalizer.ts
Layanan (logika bisnis):
- Pemilihan/penilaian akun:
open-sse/services/accountSelector.ts - Manajemen siklus hidup konteks:
open-sse/services/contextManager.ts - Penegakan filter IP:
open-sse/services/ipFilter.ts - Pelacakan sesi:
open-sse/services/sessionManager.ts - Permintaan deduplikasi:
open-sse/services/signatureCache.ts - Injeksi cepat sistem:
open-sse/services/systemPrompt.ts - Memikirkan pengelolaan anggaran:
open-sse/services/thinkingBudget.ts - Perutean model karakter pengganti:
open-sse/services/wildcardRouter.ts - Manajemen batas tarif:
open-sse/services/rateLimitManager.ts - Pemutus arus:
open-sse/services/circuitBreaker.ts
Modul lapisan domain:
- Ketersediaan model:
src/lib/domain/modelAvailability.ts - Aturan biaya/anggaran:
src/lib/domain/costRules.ts - Kebijakan penggantian:
src/lib/domain/fallbackPolicy.ts - Penyelesai kombo:
src/lib/domain/comboResolver.ts - Kebijakan penguncian:
src/lib/domain/lockoutPolicy.ts - Mesin kebijakan:
src/domain/policyEngine.ts— penguncian terpusat → anggaran → evaluasi cadangan - Katalog kode kesalahan:
src/lib/domain/errorCodes.ts - ID Permintaan:
src/lib/domain/requestId.ts - Batas waktu pengambilan:
src/lib/domain/fetchTimeout.ts - Permintaan telemetri:
src/lib/domain/requestTelemetry.ts - Kepatuhan/audit:
src/lib/domain/compliance/index.ts - Pelari evaluasi:
src/lib/domain/evalRunner.ts - Persistensi status domain:
src/lib/db/domainState.ts— SQLite CRUD untuk rantai cadangan, anggaran, riwayat biaya, status penguncian, pemutus sirkuit
Modul penyedia OAuth (12 file individual di bawah src/lib/oauth/providers/):
- Indeks registri:
src/lib/oauth/providers/index.ts - Penyedia perorangan:
claude.ts,codex.ts,gemini.ts,antigravity.ts,iflow.ts,qwen.ts,kimi-coding.ts,github.ts,kiro.ts,cursor.ts,kilocode.ts,cline.ts - Pembungkus tipis:
src/lib/oauth/providers.ts— mengekspor ulang dari masing-masing modul
DB negara bagian utama:
src/lib/localDb.ts- file:
${DATA_DIR}/db.json(atau$XDG_CONFIG_HOME/omniroute/db.jsonbila disetel, jika tidak~/.omniroute/db.json) - entitas: penyediaConnections, penyediaNodes, modelAliases, kombo, apiKeys, pengaturan, harga, customModels, proxyConfig, ipFilter, thinkingBudget, systemPrompt
DB Penggunaan:
src/lib/usageDb.ts- file:
${DATA_DIR}/usage.json,${DATA_DIR}/log.txt,${DATA_DIR}/call_logs/ - mengikuti kebijakan direktori dasar yang sama dengan
localDb(DATA_DIR, laluXDG_CONFIG_HOME/omniroutebila disetel) - didekomposisi menjadi sub-modul terfokus:
migrations.ts,usageHistory.ts,costCalculator.ts,usageStats.ts,callLogs.ts
DB Status Domain (SQLite):
src/lib/db/domainState.ts— Operasi CRUD untuk status domain- Tabel (dibuat di
src/lib/db/core.ts):domain_fallback_chains,domain_budgets,domain_cost_history,domain_lockout_state,domain_circuit_breakers - Pola cache write-through: Peta dalam memori bersifat otoritatif saat runtime; mutasi ditulis secara sinkron ke SQLite; keadaan dipulihkan dari DB pada start dingin
- Otentikasi cookie dasbor:
src/proxy.ts,src/app/api/auth/login/route.ts - Pembuatan/verifikasi kunci API:
src/shared/utils/apiKey.ts - Rahasia penyedia tetap ada di
providerConnectionsentri - Dukungan proxy keluar melalui
open-sse/utils/proxyFetch.ts(env vars) danopen-sse/utils/networkProxy.ts(dapat dikonfigurasi per penyedia atau global)
- Penjadwal init:
src/lib/initCloudSync.ts,src/shared/services/initializeCloudSync.ts - Tugas berkala:
src/shared/services/cloudSyncScheduler.ts - Rute kontrol:
src/app/api/sync/cloud/route.ts
sequenceDiagram
autonumber
participant Client as CLI/SDK Client
participant Route as /api/v1/chat/completions
participant Chat as src/sse/handlers/chat
participant Core as open-sse/handlers/chatCore
participant Model as Model Resolver
participant Auth as Credential Selector
participant Exec as Provider Executor
participant Prov as Upstream Provider
participant Stream as Stream Translator
participant Usage as usageDb
Client->>Route: POST /v1/chat/completions
Route->>Chat: handleChat(request)
Chat->>Model: parse/resolve model or combo
alt Combo model
Chat->>Chat: iterate combo models (handleComboChat)
end
Chat->>Auth: getProviderCredentials(provider)
Auth-->>Chat: active account + tokens/api key
Chat->>Core: handleChatCore(body, modelInfo, credentials)
Core->>Core: detect source format
Core->>Core: translate request to target format
Core->>Exec: execute(provider, transformedBody)
Exec->>Prov: upstream API call
Prov-->>Exec: SSE/JSON response
Exec-->>Core: response + metadata
alt 401/403
Core->>Exec: refreshCredentials()
Exec-->>Core: updated tokens
Core->>Exec: retry request
end
Core->>Stream: translate/normalize stream to client format
Stream-->>Client: SSE chunks / JSON response
Stream->>Usage: extract usage + persist history/log
flowchart TD
A[Incoming model string] --> B{Is combo name?}
B -- Yes --> C[Load combo models sequence]
B -- No --> D[Single model path]
C --> E[Try model N]
E --> F[Resolve provider/model]
D --> F
F --> G[Select account credentials]
G --> H{Credentials available?}
H -- No --> I[Return provider unavailable]
H -- Yes --> J[Execute request]
J --> K{Success?}
K -- Yes --> L[Return response]
K -- No --> M{Fallback-eligible error?}
M -- No --> N[Return error]
M -- Yes --> O[Mark account unavailable cooldown]
O --> P{Another account for provider?}
P -- Yes --> G
P -- No --> Q{In combo with next model?}
Q -- Yes --> E
Q -- No --> R[Return all unavailable]
Keputusan cadangan didorong oleh open-sse/services/accountFallback.ts menggunakan kode status dan heuristik pesan kesalahan.
sequenceDiagram
autonumber
participant UI as Dashboard UI
participant OAuth as /api/oauth/[provider]/[action]
participant ProvAuth as Provider Auth Server
participant DB as localDb
participant Test as /api/providers/[id]/test
participant Exec as Provider Executor
UI->>OAuth: GET authorize or device-code
OAuth->>ProvAuth: create auth/device flow
ProvAuth-->>OAuth: auth URL or device code payload
OAuth-->>UI: flow data
UI->>OAuth: POST exchange or poll
OAuth->>ProvAuth: token exchange/poll
ProvAuth-->>OAuth: access/refresh tokens
OAuth->>DB: createProviderConnection(oauth data)
OAuth-->>UI: success + connection id
UI->>Test: POST /api/providers/[id]/test
Test->>Exec: validate credentials / optional refresh
Exec-->>Test: valid or refreshed token info
Test->>DB: update status/tokens/errors
Test-->>UI: validation result
Penyegaran selama lalu lintas langsung dijalankan di dalam open-sse/handlers/chatCore.ts melalui pelaksana refreshCredentials().
sequenceDiagram
autonumber
participant UI as Endpoint Page UI
participant Sync as /api/sync/cloud
participant DB as localDb
participant Cloud as External Cloud Sync
participant Claude as ~/.claude/settings.json
UI->>Sync: POST action=enable
Sync->>DB: set cloudEnabled=true
Sync->>DB: ensure API key exists
Sync->>Cloud: POST /sync/{machineId} (providers/aliases/combos/keys)
Cloud-->>Sync: sync result
Sync->>Cloud: GET /{machineId}/v1/verify
Sync-->>UI: enabled + verification status
UI->>Sync: POST action=sync
Sync->>Cloud: POST /sync/{machineId}
Cloud-->>Sync: remote data
Sync->>DB: update newer local tokens/status
Sync-->>UI: synced
UI->>Sync: POST action=disable
Sync->>DB: set cloudEnabled=false
Sync->>Cloud: DELETE /sync/{machineId}
Sync->>Claude: switch ANTHROPIC_BASE_URL back to local (if needed)
Sync-->>UI: disabled
Sinkronisasi berkala dipicu oleh CloudSyncScheduler saat cloud diaktifkan.
erDiagram
SETTINGS ||--o{ PROVIDER_CONNECTION : controls
PROVIDER_NODE ||--o{ PROVIDER_CONNECTION : backs_compatible_provider
PROVIDER_CONNECTION ||--o{ USAGE_ENTRY : emits_usage
SETTINGS {
boolean cloudEnabled
number stickyRoundRobinLimit
boolean requireLogin
string password_hash
string fallbackStrategy
json rateLimitDefaults
json providerProfiles
}
PROVIDER_CONNECTION {
string id
string provider
string authType
string name
number priority
boolean isActive
string apiKey
string accessToken
string refreshToken
string expiresAt
string testStatus
string lastError
string rateLimitedUntil
json providerSpecificData
}
PROVIDER_NODE {
string id
string type
string name
string prefix
string apiType
string baseUrl
}
MODEL_ALIAS {
string alias
string targetModel
}
COMBO {
string id
string name
string[] models
}
API_KEY {
string id
string name
string key
string machineId
}
USAGE_ENTRY {
string provider
string model
number prompt_tokens
number completion_tokens
string connectionId
string timestamp
}
CUSTOM_MODEL {
string id
string name
string providerId
}
PROXY_CONFIG {
string global
json providers
}
IP_FILTER {
string mode
string[] allowlist
string[] blocklist
}
THINKING_BUDGET {
string mode
number customBudget
string effortLevel
}
SYSTEM_PROMPT {
boolean enabled
string prompt
string position
}
File penyimpanan fisik:
- status utama:
${DATA_DIR}/db.json(atau$XDG_CONFIG_HOME/omniroute/db.jsonjika disetel, jika tidak~/.omniroute/db.json) - statistik penggunaan:
${DATA_DIR}/usage.json - baris log permintaan:
${DATA_DIR}/log.txt - sesi debug penerjemah/permintaan opsional:
<repo>/logs/...
flowchart LR
subgraph LocalHost[Developer Host]
CLI[CLI Tools]
Browser[Dashboard Browser]
end
subgraph ContainerOrProcess[OmniRoute Runtime]
Next[Next.js Server\nPORT=20128]
Core[SSE Core + Executors]
MainDB[(db.json)]
UsageDB[(usage.json/log.txt)]
end
subgraph External[External Services]
Providers[AI Providers]
SyncCloud[Cloud Sync Service]
end
CLI --> Next
Browser --> Next
Next --> Core
Next --> MainDB
Core --> MainDB
Core --> UsageDB
Core --> Providers
Next --> SyncCloud
src/app/api/v1/*,src/app/api/v1beta/*: API kompatibilitassrc/app/api/v1/providers/[provider]/*: rute khusus per penyedia (obrolan, penyematan, gambar)src/app/api/providers*: penyedia CRUD, validasi, pengujiansrc/app/api/provider-nodes*: manajemen node khusus yang kompatibelsrc/app/api/provider-models: manajemen model khusus (CRUD)src/app/api/models/catalog: API katalog model lengkap (semua jenis dikelompokkan berdasarkan penyedia)src/app/api/oauth/*: OAuth/kode perangkat mengalirsrc/app/api/keys*: siklus hidup kunci API lokalsrc/app/api/models/alias: manajemen aliassrc/app/api/combos*: manajemen kombo cadangansrc/app/api/pricing: penggantian harga untuk penghitungan biayasrc/app/api/settings/proxy: konfigurasi proksi (GET/PUT/DELETE)src/app/api/settings/proxy/test: uji konektivitas proxy keluar (POST)src/app/api/usage/*: API penggunaan dan logsrc/app/api/sync/*+src/app/api/cloud/*: sinkronisasi cloud dan pembantu yang menghadap cloudsrc/app/api/cli-tools/*: penulis/pemeriksa konfigurasi CLI lokalsrc/app/api/settings/ip-filter: Daftar IP yang diizinkan/daftar blokir (GET/PUT)src/app/api/settings/thinking-budget: memikirkan konfigurasi anggaran token (GET/PUT)src/app/api/settings/system-prompt: perintah sistem global (GET/PUT)src/app/api/sessions: daftar sesi aktif (GET)src/app/api/rate-limits: status batas tarif per akun (GET)
src/sse/handlers/chat.ts: penguraian permintaan, penanganan kombo, putaran pemilihan akunopen-sse/handlers/chatCore.ts: terjemahan, pengiriman eksekutor, penanganan coba lagi/segarkan, pengaturan streamingopen-sse/executors/*: perilaku format dan jaringan khusus penyedia
open-sse/translator/index.ts: registrasi dan orkestrasi penerjemah- Permintaan penerjemah:
open-sse/translator/request/* - Penerjemah tanggapan:
open-sse/translator/response/* - Konstanta format:
open-sse/translator/formats.ts
src/lib/localDb.ts: konfigurasi/status persistensrc/lib/usageDb.ts: riwayat penggunaan dan log permintaan bergulir
Setiap penyedia memiliki pelaksana khusus yang memperluas BaseExecutor (di open-sse/executors/base.ts), yang menyediakan pembuatan URL, konstruksi header, percobaan ulang dengan backoff eksponensial, kait penyegaran kredensial, dan metode orkestrasi execute().
| Pelaksana | Penyedia | Penanganan Khusus |
|---|---|---|
DefaultExecutor |
OpenAI, Claude, Gemini, Qwen, iFlow, OpenRouter, GLM, Kimi, MiniMax, DeepSeek, Groq, xAI, Mistral, Kebingungan, Bersama, Kembang Api, Cerebras, Cohere, NVIDIA | Konfigurasi URL/tajuk dinamis per penyedia |
AntigravityExecutor |
Google Antigravitasi | ID proyek/sesi khusus, Coba Lagi-Setelah penguraian |
CodexExecutor |
Kodeks OpenAI | Menyuntikkan instruksi sistem, memaksakan upaya penalaran |
CursorExecutor |
IDE Kursor | Protokol ConnectRPC, pengkodean Protobuf, penandatanganan permintaan melalui checksum |
GithubExecutor |
Kopilot GitHub | Penyegaran token kopilot, header yang meniru VSCode |
KiroExecutor |
AWS CodeWhisperer/Kiro | Format biner AWS EventStream → konversi SSE |
GeminiCLIExecutor |
CLI Gemini | Siklus penyegaran token Google OAuth |
Semua penyedia lain (termasuk node khusus yang kompatibel) menggunakan DefaultExecutor.
| Penyedia | Format | Otentikasi | Aliran | Non-Aliran | Penyegaran Token | API Penggunaan |
|---|---|---|---|---|---|---|
| Claude | claude | Kunci API / OAuth | ✅ | ✅ | ✅ | |
| kembar | gemilang | Kunci API / OAuth | ✅ | ✅ | ✅ | |
| CLI Gemini | gemini-cli | OAuth | ✅ | ✅ | ✅ | |
| Antigravitasi | antigravitasi | OAuth | ✅ | ✅ | ✅ | ✅ API kuota penuh |
| OpenAI | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Kodeks | openai-responses | OAuth | ✅ dipaksa | ❌ | ✅ | ✅ Batas tarif |
| Kopilot GitHub | buka | OAuth + Token Kopilot | ✅ | ✅ | ✅ | ✅ Cuplikan kuota |
| Kursor | kursor | Checksum khusus | ✅ | ✅ | ❌ | ❌ |
| Kiro | kiri | AWSSSO OIDC | ✅ (Aliran Acara) | ❌ | ✅ | ✅ Batasan penggunaan |
| Qwen | buka | OAuth | ✅ | ✅ | ✅ | |
| iFlow | buka | OAuth (Dasar) | ✅ | ✅ | ✅ | |
| BukaRouter | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| GLM/Kimi/MiniMax | claude | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Pencarian Dalam | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Bagus | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| xAI (Grok) | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Mistral | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Kebingungan | openai | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Bersama AI | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| AI kembang api | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| Otak | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| menyatu | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
| NVIDIA NIM | buka | Kunci API | ✅ | ✅ | ❌ | ❌ |
Format sumber yang terdeteksi meliputi:
openaiopenai-responsesclaudegemini
Format sasaran meliputi:
- Obrolan/Respon OpenAI
- Claude
- Amplop Gemini/Gemini-CLI/Antigravitasi
- Kiro
- Kursor
Penerjemahan menggunakan OpenAI sebagai format hub — semua konversi melalui OpenAI sebagai perantara:
Source Format → OpenAI (hub) → Target Format
Terjemahan dipilih secara dinamis berdasarkan bentuk muatan sumber dan format target penyedia.
Lapisan pemrosesan tambahan dalam alur terjemahan:
- Sanitasi respons — Menghapus kolom non-standar dari respons format OpenAI (streaming dan non-streaming) untuk memastikan kepatuhan SDK yang ketat
- Normalisasi peran — Mengonversi
developer→systemuntuk target non-OpenAI; menggabungkansystem→useruntuk model yang menolak peran sistem (GLM, ERNIE) - Pikirkan ekstraksi tag — Mengurai
<think>...</think>blok dari konten ke dalam bidangreasoning_content - Output terstruktur — Mengonversi OpenAI
response_format.json_schemamenjadiresponseMimeType+responseSchemaGemini
| Titik akhir | Format | Penangan |
|---|---|---|
POST /v1/chat/completions |
Obrolan OpenAI | src/sse/handlers/chat.ts |
POST /v1/messages |
Pesan Claude | Penangan yang sama (terdeteksi otomatis) |
POST /v1/responses |
Tanggapan OpenAI | open-sse/handlers/responsesHandler.ts |
POST /v1/embeddings |
Penyematan OpenAI | open-sse/handlers/embeddings.ts |
GET /v1/embeddings |
Daftar model | Rute API |
POST /v1/images/generations |
Gambar OpenAI | open-sse/handlers/imageGeneration.ts |
GET /v1/images/generations |
Daftar model | Rute API |
POST /v1/providers/{provider}/chat/completions |
Obrolan OpenAI | Per penyedia khusus dengan validasi model |
POST /v1/providers/{provider}/embeddings |
Penyematan OpenAI | Per penyedia khusus dengan validasi model |
POST /v1/providers/{provider}/images/generations |
Gambar OpenAI | Per penyedia khusus dengan validasi model |
POST /v1/messages/count_tokens |
Jumlah Token Claude | Rute API |
GET /v1/models |
Daftar Model OpenAI | Rute API (obrolan + penyematan + gambar + model khusus) |
GET /api/models/catalog |
Katalog | Semua model dikelompokkan berdasarkan penyedia + tipe |
POST /v1beta/models/*:streamGenerateContent |
Gemini asli | Rute API |
GET/PUT/DELETE /api/settings/proxy |
Konfigurasi Proksi | Konfigurasi proksi jaringan |
POST /api/settings/proxy/test |
Konektivitas Proksi | Titik akhir pengujian kesehatan/konektivitas proxy |
GET/POST/DELETE /api/provider-models |
Model Khusus | Manajemen model khusus per penyedia |
Penangan bypass (open-sse/utils/bypassHandler.ts) mencegat permintaan "sekali pakai" yang diketahui dari Claude CLI — ping pemanasan, ekstraksi judul, dan jumlah token — dan mengembalikan respons palsu tanpa menggunakan token penyedia upstream. Ini dipicu hanya ketika User-Agent berisi claude-cli.
Logger permintaan (open-sse/utils/requestLogger.ts) menyediakan pipeline debug logging 7 tahap, dinonaktifkan secara default, diaktifkan melalui ENABLE_REQUEST_LOGS=true:
1_req_client.json → 2_req_source.json → 3_req_openai.json → 4_req_target.json
→ 5_res_provider.txt → 6_res_openai.txt → 7_res_client.txt
File ditulis ke <repo>/logs/<session>/ untuk setiap sesi permintaan.
- cooldown akun penyedia pada kesalahan sementara/rate/auth
- penggantian akun sebelum permintaan gagal
- penggantian model kombo ketika jalur model/penyedia saat ini habis
- pra-periksa dan segarkan dengan coba lagi untuk penyedia yang dapat disegarkan
- 401/403 percobaan ulang setelah upaya penyegaran di jalur inti
- pengontrol aliran yang sadar akan pemutusan hubungan
- aliran terjemahan dengan flush akhir aliran dan penanganan
[DONE] - penggantian estimasi penggunaan ketika metadata penggunaan penyedia tidak ada
- kesalahan sinkronisasi muncul tetapi runtime lokal terus berlanjut
- penjadwal memiliki logika yang mampu mencoba ulang, namun eksekusi berkala saat ini memanggil sinkronisasi upaya tunggal secara default
- Migrasi/perbaikan bentuk DB untuk kunci yang hilang
- perlindungan reset JSON yang rusak untuk localDb dan usageDb
Sumber visibilitas waktu proses:
- log konsol dari
src/sse/utils/logger.ts - agregat penggunaan per permintaan di
usage.json - status permintaan tekstual masuk
log.txt - log permintaan/terjemahan dalam opsional di bawah
logs/ketikaENABLE_REQUEST_LOGS=true - titik akhir penggunaan dasbor (
/api/usage/*) untuk konsumsi UI
- Rahasia JWT (
JWT_SECRET) mengamankan verifikasi/penandatanganan cookie sesi dasbor - Penggantian kata sandi awal (
INITIAL_PASSWORD, default123456) harus diganti dalam penerapan nyata - Rahasia HMAC kunci API (
API_KEY_SECRET) mengamankan format kunci API lokal yang dihasilkan - Rahasia penyedia (kunci/token API) disimpan di DB lokal dan harus dilindungi di tingkat sistem file
- Titik akhir sinkronisasi cloud mengandalkan autentikasi kunci API + semantik id mesin
Variabel lingkungan yang aktif digunakan oleh kode:
- Aplikasi/autentikasi:
JWT_SECRET,INITIAL_PASSWORD - Penyimpanan:
DATA_DIR - Perilaku node yang kompatibel:
ALLOW_MULTI_CONNECTIONS_PER_COMPAT_NODE - Penggantian basis penyimpanan opsional (Linux/macOS ketika
DATA_DIRtidak disetel):XDG_CONFIG_HOME - Pencirian keamanan:
API_KEY_SECRET,MACHINE_ID_SALT - Pencatatan:
ENABLE_REQUEST_LOGS - URL sinkronisasi/cloud:
NEXT_PUBLIC_BASE_URL,NEXT_PUBLIC_CLOUD_URL - Proksi keluar:
HTTP_PROXY,HTTPS_PROXY,ALL_PROXY,NO_PROXYdan varian huruf kecil - Bendera fitur SOCKS5:
ENABLE_SOCKS5_PROXY,NEXT_PUBLIC_ENABLE_SOCKS5_PROXY - Pembantu platform/runtime (bukan konfigurasi khusus aplikasi):
APPDATA,NODE_ENV,PORT,HOSTNAME
usageDbdanlocalDbsekarang berbagi kebijakan direktori dasar yang sama (DATA_DIR->XDG_CONFIG_HOME/omniroute->~/.omniroute) dengan migrasi file lama./api/v1/route.tsmengembalikan daftar model statis dan bukan sumber model utama yang digunakan oleh/v1/models.- Pencatat permintaan menulis header/isi lengkap saat diaktifkan; memperlakukan direktori log sebagai sensitif.
- Perilaku cloud bergantung pada
NEXT_PUBLIC_BASE_URLyang benar dan jangkauan titik akhir cloud. - Direktori
open-sse/diterbitkan sebagai@omniroute/open-ssepaket ruang kerja npm. Kode sumber mengimpornya melalui@omniroute/open-sse/...(diselesaikan oleh Next.jstranspilePackages). Jalur file dalam dokumen ini masih menggunakan nama direktoriopen-sse/untuk konsistensi. - Bagan di dasbor menggunakan Recharts (berbasis SVG) untuk visualisasi analitik interaktif yang mudah diakses (diagram batang penggunaan model, tabel perincian penyedia dengan tingkat keberhasilan).
- Tes E2E menggunakan Playwright (
tests/e2e/), dijalankan melaluinpm run test:e2e. Pengujian unit menggunakan Node.js test runner (tests/unit/), dijalankan melaluinpm run test:plan3. Kode sumber di bawahsrc/adalah TypeScript (.ts/.tsx); ruang kerjaopen-sse/tetap JavaScript (.js). - Halaman pengaturan disusun dalam 5 tab: Keamanan, Perutean (6 strategi global: isi dulu, round-robin, p2c, acak, jarang digunakan, optimal biaya), Ketahanan (batas kecepatan yang dapat diedit, pemutus sirkuit, kebijakan), AI (anggaran berpikir, perintah sistem, cache cepat), Lanjutan (proxy).
- Bangun dari sumber:
npm run build - Bangun gambar Docker:
docker build -t omniroute . - Mulai layanan dan verifikasi:
GET /api/settingsGET /api/v1/models- URL dasar target CLI harus
http://<host>:20128/v1ketikaPORT=20128