16 KiB
API Reference (Bahasa Melayu)
🌐 Languages: 🇺🇸 English · 🇪🇸 es · 🇫🇷 fr · 🇩🇪 de · 🇮🇹 it · 🇷🇺 ru · 🇨🇳 zh-CN · 🇯🇵 ja · 🇰🇷 ko · 🇸🇦 ar · 🇮🇳 hi · 🇮🇳 in · 🇹🇭 th · 🇻🇳 vi · 🇮🇩 id · 🇲🇾 ms · 🇳🇱 nl · 🇵🇱 pl · 🇸🇪 sv · 🇳🇴 no · 🇩🇰 da · 🇫🇮 fi · 🇵🇹 pt · 🇷🇴 ro · 🇭🇺 hu · 🇧🇬 bg · 🇸🇰 sk · 🇺🇦 uk-UA · 🇮🇱 he · 🇵🇭 phi · 🇧🇷 pt-BR · 🇨🇿 cs · 🇹🇷 tr
Rujukan lengkap untuk semua titik akhir API OmniRoute.---
Table of Contents
- Sembang Selesai
- Pembenaman
- [Penjanaan Imej](#penjanaan imej)
- Senarai Model
- [Titik Tamat Keserasian](#titik akhir keserasian)
- Cache Semantik
- [Papan Pemuka & Pengurusan](#papan pemuka--pengurusan)
- Pemprosesan Permintaan
- Pengesahan---
Chat Completions
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
}
Custom Headers
| Pengepala | Arah | Penerangan |
|---|---|---|
X-OmniRoute-No-Cache |
Permintaan | Tetapkan kepada true untuk memintas cache |
X-OmniRoute-Progress |
Permintaan | Tetapkan kepada true untuk acara kemajuan |
Id-Sesi-X |
Permintaan | Kunci sesi melekit untuk perkaitan sesi luaran |
x_session_id |
Permintaan | Varian garis bawah juga diterima (HTTP langsung) |
Kunci Idempotensi |
Permintaan | Kekunci dedup (tetingkap 5s) |
Id-Permintaan-X |
Permintaan | Kunci pelupusan alternatif |
X-OmniRoute-Cache |
Maklum balas | HIT atau MISS (bukan penstriman) |
X-OmniRoute-Idempotent |
Maklum balas | benar jika dinyahduplikasi |
X-OmniRoute-Progress |
Maklum balas | didayakan jika penjejakan kemajuan pada |
Id-Sesi-X-OmniRoute |
Maklum balas | ID sesi berkesan digunakan oleh OmniRoute |
Nota Nginx: jika anda bergantung pada pengepala underscore (contohnya
x_session_id), dayakanunderscores_in_headers on;.---
Embeddings
POST /v1/embeddings
Authorization: Bearer your-api-key
Content-Type: application/json
{
"model": "nebius/Qwen/Qwen3-Embedding-8B",
"input": "The food was delicious"
}
Pembekal yang tersedia: Nebius, OpenAI, Mistral, Together AI, Fireworks, NVIDIA.```bash
List all embedding models
GET /v1/embeddings
---
## Image Generation
```bash
POST /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"
}
Pembekal tersedia: OpenAI (DALL-E), xAI (Grok Image), Together AI (FLUX), Fireworks AI.```bash
List all image models
GET /v1/images/generations
---
## List Models
```bash
GET /v1/models
Authorization: Bearer your-api-key
→ Returns all chat, embedding, and image models + combos in OpenAI format
Compatibility Endpoints
| Kaedah | Laluan | Format | |
|---|---|---|---|
| POS | /v1/sembang/penyelesaian |
OpenAI | |
| POS | /v1/mesej |
Antroppik | |
| POS | /v1/respons |
Respons OpenAI | |
| POS | /v1/benam |
OpenAI | |
| POS | /v1/imej/generasi |
OpenAI | |
| DAPATKAN | /v1/model |
OpenAI | |
| POS | /v1/message/count_token |
Antroppik | |
| DAPATKAN | /v1beta/model |
Gemini | |
| POS | /v1beta/models/{...path} |
Gemini menjanaKandungan | |
| POS | /v1/api/sembang |
Ollama | ### Dedicated Provider Routes |
POST /v1/providers/{provider}/chat/completions
POST /v1/providers/{provider}/embeddings
POST /v1/providers/{provider}/images/generations
Awalan pembekal ditambah secara automatik jika tiada. Model yang tidak sepadan mengembalikan 400.---
Semantic Cache
# Get cache stats
GET /api/cache/stats
# Clear all caches
DELETE /api/cache/stats
Contoh jawapan:```json { "semanticCache": { "memorySize": 42, "memoryMaxSize": 500, "dbSize": 128, "hitRate": 0.65 }, "idempotency": { "activeKeys": 3, "windowMs": 5000 } }
---
## Dashboard & Management
### Authentication
| Titik akhir | Kaedah | Penerangan |
| ---------------------------- | ------- | ---------------------- |
| `/api/auth/log masuk` | POS | Log masuk |
| `/api/auth/logout` | POS | Log keluar |
| `/api/setting/require-login` | DAPATKAN/LETAK | Togol log masuk diperlukan |### Provider Management
| Titik akhir | Kaedah | Penerangan |
| ---------------------------- | --------------- | ------------------------- |
| `/api/penyedia` | DAPATKAN/POS | Senaraikan / buat pembekal |
| `/api/penyedia/[id]` | DAPATKAN/LETAK/PADAM | Urus pembekal |
| `/api/penyedia/[id]/ujian` | POS | Sambungan pembekal ujian |
| `/api/providers/[id]/models` | DAPATKAN | Senaraikan model pembekal |
| `/api/providers/validate` | POS | Sahkan konfigurasi pembekal |
| `/api/provider-nodes*` | Pelbagai | Pengurusan nod pembekal |
| `/api/provider-models` | DAPATKAN/POST/PADAM | Model tersuai |### OAuth Flows
| Titik akhir | Kaedah | Penerangan |
| -------------------------------- | ------- | ------------------------ |
| `/api/oauth/[penyedia]/[tindakan]` | Pelbagai | OAuth khusus pembekal |### Routing & Config
| Titik akhir | Kaedah | Penerangan |
| ---------------------- | -------- | ---------------------------- |
| `/api/models/alias` | DAPATKAN/POS | Alias model |
| `/api/models/catalog` | DAPATKAN | Semua model mengikut pembekal + jenis |
| `/api/combos*` | Pelbagai | Pengurusan kombo |
| `/api/keys*` | Pelbagai | Pengurusan kunci API |
| `/api/pricing` | DAPATKAN | Harga model |### Usage & Analytics
| Titik akhir | Kaedah | Penerangan |
| --------------------------- | ------ | -------------------- |
| `/api/usage/history` | DAPATKAN | Sejarah penggunaan |
| `/api/usage/logs` | DAPATKAN | Log penggunaan |
| `/api/usage/request-logs` | DAPATKAN | Log peringkat permintaan |
| `/api/usage/[connectionId]` | DAPATKAN | Penggunaan setiap sambungan |### Settings
| Titik akhir | Kaedah | Penerangan |
| ------------------------------- | ------------- | ----------------------- |
| `/api/setting` | DAPATKAN/LETAK/PATCH | Tetapan umum |
| `/api/setting/proksi` | DAPATKAN/LETAK | Konfigurasi proksi rangkaian |
| `/api/settings/proxy/test` | POS | Uji sambungan proksi |
| `/api/setting/penapis-ip` | DAPATKAN/LETAK | Senarai dibenarkan/senarai sekatan IP |
| `/api/setting/thinking-budget` | DAPATKAN/LETAK | Belanjawan token penaakulan |
| `/api/setting/system-prompt` | DAPATKAN/LETAK | Gesaan sistem global |### Monitoring
| Titik akhir | Kaedah | Penerangan |
| ------------------------- | ---------- | --------------------------------------------------------------------------------------------------- |
| `/api/sessions` | DAPATKAN | Penjejakan sesi aktif |
| `/api/rate-limits` | DAPATKAN | Had kadar setiap akaun |
| `/api/pemantauan/kesihatan` | DAPATKAN | Semakan kesihatan + ringkasan pembekal (`catalogCount`, `configuredCount`, `activeCount`, `monitoredCount`) |
| `/api/cache/stats` | DAPATKAN/PADAM | Statistik cache / kosongkan |### Backup & Export/Import
| Titik akhir | Kaedah | Penerangan |
| --------------------------- | ------ | ---------------------------------------------------- |
| `/api/db-backups` | DAPATKAN | Senaraikan sandaran yang tersedia |
| `/api/db-backups` | LETAK | Buat sandaran manual |
| `/api/db-backups` | POS | Pulihkan daripada sandaran khusus |
| `/api/db-backups/eksport` | DAPATKAN | Muat turun pangkalan data sebagai fail .sqlite |
| `/api/db-backups/import` | POS | Muat naik fail .sqlite untuk menggantikan pangkalan data |
| `/api/db-backups/exportAll` | DAPATKAN | Muat turun sandaran penuh sebagai arkib .tar.gz |### Cloud Sync
| Titik akhir | Kaedah | Penerangan |
| ----------------------- | ------- | ---------------------- |
| `/api/sync/cloud` | Pelbagai | Operasi penyegerakan awan |
| `/api/sync/initialize` | POS | Mulakan penyegerakan |
| `/api/cloud/*` | Pelbagai | Pengurusan awan |### Tunnels
| Titik akhir | Kaedah | Penerangan |
| -------------------------- | ------ | ---------------------------------------------------------------------- |
| `/api/tunnels/cloudflared` | DAPATKAN | Baca status pemasangan/masa jalan Cloudflare Quick Tunnel untuk papan pemuka |
| `/api/tunnels/cloudflared` | POS | Dayakan atau lumpuhkan Cloudflare Quick Tunnel (`action=enable/disable`) |### CLI Tools
| Titik akhir | Kaedah | Penerangan |
| ---------------------------------- | ------ | ------------------- |
| `/api/cli-tools/claude-settings` | DAPATKAN | Status CLI Claude |
| `/api/cli-tools/codex-settings` | DAPATKAN | Status Codex CLI |
| `/api/cli-tools/droid-settings` | DAPATKAN | Status Droid CLI |
| `/api/cli-tools/openclaw-settings` | DAPATKAN | Status OpenClaw CLI |
| `/api/cli-tools/runtime/[toolId]` | DAPATKAN | Masa jalan CLI generik |
Respons CLI termasuk: `dipasang`, `boleh dijalankan`, `perintah`, `commandPath`, `runtimeMode`, `sebab`.### ACP Agents
| Titik akhir | Kaedah | Penerangan |
| ----------------- | ------ | -------------------------------------------------------- |
| `/api/acp/agen` | DAPATKAN | Senaraikan semua ejen yang dikesan (terbina dalam + tersuai) dengan status |
| `/api/acp/agen` | POS | Tambahkan ejen tersuai atau muat semula cache pengesanan |
| `/api/acp/agen` | PADAM | Alih keluar ejen tersuai mengikut param pertanyaan `id` |
GET respons termasuk `ejen[]` (id, nama, perduaan, versi, dipasang, protokol, isCustom) dan `ringkasan` (jumlah, dipasang, notFound, terbina Dalam, tersuai).### Resilience & Rate Limits
| Titik akhir | Kaedah | Penerangan |
| ------------------------ | --------- | ------------------------------- |
| `/api/ketahanan` | DAPATKAN/PATCH | Dapatkan/kemas kini profil ketahanan |
| `/api/resilience/reset` | POS | Tetapkan semula pemutus litar |
| `/api/rate-limits` | DAPATKAN | Status had kadar setiap akaun |
| `/api/rate-limit` | DAPATKAN | Konfigurasi had kadar global |### Evals
| Titik akhir | Kaedah | Penerangan |
| ------------ | -------- | --------------------------------- |
| `/api/evals` | DAPATKAN/POS | Senaraikan suite eval / penilaian jalankan |### Policies
| Titik akhir | Kaedah | Penerangan |
| --------------- | --------------- | ------------------------ |
| `/api/dasar` | DAPATKAN/POST/PADAM | Urus dasar penghalaan |### Compliance
| Titik akhir | Kaedah | Penerangan |
| --------------------------- | ------ | ---------------------------- |
| `/api/compliance/audit-log` | DAPATKAN | Log audit pematuhan (N terakhir) |### v1beta (Gemini-Compatible)
| Titik akhir | Kaedah | Penerangan |
| -------------------------- | ------ | --------------------------------- |
| `/v1beta/model` | DAPATKAN | Senaraikan model dalam format Gemini |
| `/v1beta/models/{...path}` | POS | Gemini `generateContent` titik akhir |
Titik akhir ini mencerminkan format API Gemini untuk pelanggan yang mengharapkan keserasian SDK Gemini asli.### Internal / System APIs
| Titik akhir | Kaedah | Penerangan |
| --------------- | ------ | ---------------------------------------------------- |
| `/api/init` | DAPATKAN | Semakan permulaan aplikasi (digunakan pada larian pertama) |
| `/api/tags` | DAPATKAN | Tag model yang serasi dengan Ollama (untuk pelanggan Ollama) |
| `/api/restart` | POS | Pencetus pelayan anggun mulakan semula |
| `/api/shutdown` | POS | Cetuskan penutupan pelayan yang anggun |
>**Nota:**Titik akhir ini digunakan secara dalaman oleh sistem atau untuk keserasian pelanggan Ollama. Mereka biasanya tidak dipanggil oleh pengguna akhir.---
## Audio Transcription
```bash
POST /v1/audio/transcriptions
Authorization: Bearer your-api-key
Content-Type: multipart/form-data
Transkripsikan fail audio menggunakan Deepgram atau AssemblyAI.
Permintaan:```bash
curl -X POST http://localhost:20128/v1/audio/transcriptions
-H "Authorization: Bearer your-api-key"
-F "file=@recording.mp3"
-F "model=deepgram/nova-3"
**Jawapan:**```json
{
"text": "Hello, this is the transcribed audio content.",
"task": "transcribe",
"language": "en",
"duration": 12.5
}
Pembekal yang disokong:deepgram/nova-3, assemblyai/best.
Format yang disokong:mp3, wav, m4a, flac, ogg, webm.---
Ollama Compatibility
Untuk pelanggan yang menggunakan format API Ollama:```bash
Chat endpoint (Ollama format)
POST /v1/api/chat
Model listing (Ollama format)
GET /api/tags
Permintaan diterjemahkan secara automatik antara Ollama dan format dalaman.---
## Telemetry
```bash
# Get latency telemetry summary (p50/p95/p99 per provider)
GET /api/telemetry/summary
Jawapan:```json { "providers": { "claudeCode": { "p50": 245, "p95": 890, "p99": 1200, "count": 150 }, "github": { "p50": 180, "p95": 620, "p99": 950, "count": 320 } } }
---
## Budget
```bash
# 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"
}
Model Availability
# 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"
}
Request Processing
- Pelanggan menghantar permintaan kepada
/v1/* - Pengendali laluan memanggil
handleChat,handleEmbedding,handleAudioTranscriptionatauhandleImageGeneration - Model telah diselesaikan (pembekal langsung/model atau alias/kombo)
- Bukti kelayakan dipilih daripada DB tempatan dengan penapisan ketersediaan akaun
- Untuk sembang:
handleChatCore— pengesanan format, terjemahan, semakan cache, semakan mati pucuk - Pelaksana pembekal menghantar permintaan huluan
- Respons diterjemahkan kembali kepada format pelanggan (sembang) atau dikembalikan seperti sedia ada (benam/imej/audio)
- Penggunaan / pembalakan direkodkan
- Fallback terpakai pada ralat mengikut peraturan kombo
Rujukan seni bina penuh: ARCHITECTURE.md---
Authentication
- Laluan papan pemuka (
/papan pemuka/*) menggunakan kukiauth_token - Log masuk menggunakan cincang kata laluan yang disimpan; sandarkan kepada
INITIAL_PASSWORD requireLoginboleh togol melalui/api/settings/require-login- Laluan
/v1/*secara pilihan memerlukan kunci API Pembawa apabilaREQUIRE_API_KEY=true