🌐 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
Volledige referentie voor alle OmniRoute API-eindpunten.
- Chat Completions
- Embeddings
- Image Generation
- List Models
- Compatibility Endpoints
- Semantic Cache
- Dashboard & Management
- Request Processing
- Authentication
POST /v1/chat/completions
Authorization: Bearer your-api-key
Content-Type: application/json
{
"model": "cc/claude-opus-4-6",
"messages": [
{"role": "user", "content": "Write a function to..."}
],
"stream": true
}| Kop | Richting | Beschrijving |
|---|---|---|
X-OmniRoute-No-Cache |
Verzoek | Stel in op true om cache te omzeilen |
X-OmniRoute-Progress |
Verzoek | Ingesteld op true voor voortgangsgebeurtenissen |
Idempotency-Key |
Verzoek | Ontdubbelingssleutel (5s-venster) |
X-Request-Id |
Verzoek | Alternatieve ontdubbelsleutel |
X-OmniRoute-Cache |
Reactie | HIT of MISS (niet-streaming) |
X-OmniRoute-Idempotent |
Reactie | true indien ontdubbeld |
X-OmniRoute-Progress |
Reactie | enabled als voortgangsregistratie op |
POST /v1/embeddings
Authorization: Bearer your-api-key
Content-Type: application/json
{
"model": "nebius/Qwen/Qwen3-Embedding-8B",
"input": "The food was delicious"
}Beschikbare providers: Nebius, OpenAI, Mistral, Together AI, Fireworks, NVIDIA.
# List all embedding models
GET /v1/embeddingsPOST /v1/images/generations
Authorization: Bearer your-api-key
Content-Type: application/json
{
"model": "openai/dall-e-3",
"prompt": "A beautiful sunset over mountains",
"size": "1024x1024"
}Beschikbare providers: OpenAI (DALL-E), xAI (Grok Image), Together AI (FLUX), Fireworks AI.
# List all image models
GET /v1/images/generationsGET /v1/models
Authorization: Bearer your-api-key
→ Returns all chat, embedding, and image models + combos in OpenAI format| Werkwijze | Pad | Formaat |
|---|---|---|
| POST | /v1/chat/completions |
Open AI |
| POST | /v1/messages |
Antropisch |
| POST | /v1/responses |
OpenAI-reacties |
| POST | /v1/embeddings |
Open AI |
| POST | /v1/images/generations |
Open AI |
| KRIJG | /v1/models |
Open AI |
| POST | /v1/messages/count_tokens |
Antropisch |
| KRIJG | /v1beta/models |
Tweeling |
| POST | /v1beta/models/{...path} |
Tweelingen genererenInhoud |
| POST | /v1/api/chat |
Ollama |
POST /v1/providers/{provider}/chat/completions
POST /v1/providers/{provider}/embeddings
POST /v1/providers/{provider}/images/generationsHet providervoorvoegsel wordt automatisch toegevoegd als het ontbreekt. Niet-overeenkomende modellen retourneren 400.
# Get cache stats
GET /api/cache
# Clear all caches
DELETE /api/cacheVoorbeeld van een antwoord:
{
"semanticCache": {
"memorySize": 42,
"memoryMaxSize": 500,
"dbSize": 128,
"hitRate": 0.65
},
"idempotency": {
"activeKeys": 3,
"windowMs": 5000
}
}| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/auth/login |
POST | Inloggen |
/api/auth/logout |
POST | Uitloggen |
/api/settings/require-login |
KRIJG/ZET | Schakel inloggen vereist |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/providers |
KRIJGEN/POST | Providers weergeven / aanmaken |
/api/providers/[id] |
KRIJGEN/ZET/VERWIJDEREN | Beheer een aanbieder |
/api/providers/[id]/test |
POST | Providerverbinding testen |
/api/providers/[id]/models |
KRIJG | Providermodellen weergeven |
/api/providers/validate |
POST | Providerconfiguratie valideren |
/api/provider-nodes* |
Diverse | Beheer van providerknooppunten |
/api/provider-models |
KRIJGEN/POST/VERWIJDEREN | Aangepaste modellen |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/oauth/[provider]/[action] |
Diverse | Providerspecifieke OAuth |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/models/alias |
KRIJGEN/POST | Modelaliassen |
/api/models/catalog |
KRIJG | Alle modellen per aanbieder + type |
/api/combos* |
Diverse | Combinatiebeheer |
/api/keys* |
Diverse | API-sleutelbeheer |
/api/pricing |
KRIJG | Modelprijzen |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/usage/history |
KRIJG | Gebruiksgeschiedenis |
/api/usage/logs |
KRIJG | Gebruikslogboeken |
/api/usage/request-logs |
KRIJG | Logboeken op aanvraagniveau |
/api/usage/[connectionId] |
KRIJG | Gebruik per verbinding |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/settings |
KRIJG/ZET | Algemene instellingen |
/api/settings/proxy |
KRIJG/ZET | Netwerkproxyconfiguratie |
/api/settings/proxy/test |
POST | Proxyverbinding testen |
/api/settings/ip-filter |
KRIJG/ZET | IP-toelatingslijst/blokkeerlijst |
/api/settings/thinking-budget |
KRIJG/ZET | Redeneren tokenbudget |
/api/settings/system-prompt |
KRIJG/ZET | Globale systeemprompt |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/sessions |
KRIJG | Actieve sessietracking |
/api/rate-limits |
KRIJG | Tarieflimieten per account |
/api/monitoring/health |
KRIJG | Gezondheidscontrole |
/api/cache |
OPHALEN/VERWIJDEREN | Cachestatistieken / wissen |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/db-backups |
KRIJG | Beschikbare back-ups weergeven |
/api/db-backups |
ZET | Maak een handmatige back-up |
/api/db-backups |
POST | Herstellen vanaf een specifieke back-up |
/api/db-backups/export |
KRIJG | Database downloaden als .sqlite-bestand |
/api/db-backups/import |
POST | Upload .sqlite-bestand om database te vervangen |
/api/db-backups/exportAll |
KRIJG | Volledige back-up downloaden als .tar.gz-archief |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/sync/cloud |
Diverse | Cloudsynchronisatiebewerkingen |
/api/sync/initialize |
POST | Synchronisatie initialiseren |
/api/cloud/* |
Diverse | Cloudbeheer |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/cli-tools/claude-settings |
KRIJG | Claude CLI-status |
/api/cli-tools/codex-settings |
KRIJG | Codex CLI-status |
/api/cli-tools/droid-settings |
KRIJG | Droid CLI-status |
/api/cli-tools/openclaw-settings |
KRIJG | OpenClaw CLI-status |
/api/cli-tools/runtime/[toolId] |
KRIJG | Algemene CLI-runtime |
CLI-reacties omvatten: installed, runnable, command, commandPath, runtimeMode, reason.
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/resilience |
KRIJG/ZET | Veerkrachtprofielen ophalen/bijwerken |
/api/resilience/reset |
POST | Stroomonderbrekers resetten |
/api/rate-limits |
KRIJG | Status van tarieflimiet per account |
/api/rate-limit |
KRIJG | Configuratie van globale tarieflimieten |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/evals |
KRIJGEN/POST | Evaluatiesuites weergeven / evaluatie uitvoeren |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/policies |
KRIJGEN/POST/VERWIJDEREN | Routingbeleid beheren |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/compliance/audit-log |
KRIJG | Nalevingsauditlogboek (laatste N) |
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/v1beta/models |
KRIJG | Lijstmodellen in Gemini-formaat |
/v1beta/models/{...path} |
POST | Gemini generateContent eindpunt |
Deze eindpunten weerspiegelen het API-formaat van Gemini voor klanten die native Gemini SDK-compatibiliteit verwachten.
| Eindpunt | Werkwijze | Beschrijving |
|---|---|---|
/api/init |
KRIJG | Initialisatiecontrole van applicatie (gebruikt bij eerste run) |
/api/tags |
KRIJG | Ollama-compatibele modeltags (voor Ollama-klanten) |
/api/restart |
POST | Trigger een sierlijke herstart van de server |
/api/shutdown |
POST | Trigger een elegante serveruitschakeling |
Opmerking: Deze eindpunten worden intern gebruikt door het systeem of voor Ollama-clientcompatibiliteit. Ze worden doorgaans niet door eindgebruikers gebeld.
POST /v1/audio/transcriptions
Authorization: Bearer your-api-key
Content-Type: multipart/form-dataTranscribeer audiobestanden met Deepgram of AssemblyAI.
Verzoek:
curl -X POST http://localhost:20128/v1/audio/transcriptions \
-H "Authorization: Bearer your-api-key" \
-F "file=@recording.mp3" \
-F "model=deepgram/nova-3"Reactie:
{
"text": "Hello, this is the transcribed audio content.",
"task": "transcribe",
"language": "en",
"duration": 12.5
}Ondersteunde providers: deepgram/nova-3, assemblyai/best.
Ondersteunde formaten: mp3, wav, m4a, flac, ogg, webm.
Voor klanten die het API-formaat van Ollama gebruiken:
# Chat endpoint (Ollama format)
POST /v1/api/chat
# Model listing (Ollama format)
GET /api/tagsVerzoeken worden automatisch vertaald tussen Ollama en interne formaten.
# Get latency telemetry summary (p50/p95/p99 per provider)
GET /api/telemetry/summaryReactie:
{
"providers": {
"claudeCode": { "p50": 245, "p95": 890, "p99": 1200, "count": 150 },
"github": { "p50": 180, "p95": 620, "p99": 950, "count": 320 }
}
}# Get budget status for all API keys
GET /api/usage/budget
# Set or update a budget
POST /api/usage/budget
Content-Type: application/json
{
"keyId": "key-123",
"limit": 50.00,
"period": "monthly"
}# Get real-time model availability across all providers
GET /api/models/availability
# Check availability for a specific model
POST /api/models/availability
Content-Type: application/json
{
"model": "claude-sonnet-4-5-20250929"
}- Klant stuurt verzoek naar
/v1/* - Route-handleraanroepen
handleChat,handleEmbedding,handleAudioTranscriptionofhandleImageGeneration - Model is opgelost (directe provider/model of alias/combo)
- Inloggegevens geselecteerd uit lokale DB met filtering van accountbeschikbaarheid
- Voor chat:
handleChatCore— formaatdetectie, vertaling, cachecontrole, idempotentiecontrole - Provider-uitvoerder verzendt een upstream-verzoek
- Antwoord terugvertaald naar clientformaat (chat) of geretourneerd zoals het is (insluitingen/afbeeldingen/audio)
- Verbruik/logboekregistratie
- Fallback is van toepassing op fouten volgens comboregels
Volledige architectuurreferentie: link
- Dashboardroutes (
/dashboard/*) gebruikenauth_tokencookie - Inloggen maakt gebruik van opgeslagen wachtwoord-hash; terugval naar
INITIAL_PASSWORD requireLoginschakelbaar via/api/settings/require-login- Voor
/v1/*routes is optioneel een Bearer API-sleutel vereist wanneerREQUIRE_API_KEY=true