{"id":46248970,"url":"https://github.com/diegosouzapw/OmniRoute","last_synced_at":"2026-03-04T08:00:38.246Z","repository":{"id":338299336,"uuid":"1157102282","full_name":"diegosouzapw/OmniRoute","owner":"diegosouzapw","description":"OmniRoute is an AI gateway for multi-provider LLMs: an OpenAI-compatible endpoint with smart routing, load balancing, retries, and fallbacks. Add policies, rate limits, caching, and observability for reliable, cost-aware inference.","archived":false,"fork":false,"pushed_at":"2026-02-28T14:53:52.000Z","size":37597,"stargazers_count":85,"open_issues_count":3,"forks_count":18,"subscribers_count":0,"default_branch":"main","last_synced_at":"2026-02-28T15:49:11.984Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/diegosouzapw.png","metadata":{"files":{"readme":"README.ar.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":"AGENTS.md","dco":null,"cla":null}},"created_at":"2026-02-13T12:38:31.000Z","updated_at":"2026-02-28T15:03:56.000Z","dependencies_parsed_at":"2026-02-26T00:01:24.751Z","dependency_job_id":null,"html_url":"https://github.com/diegosouzapw/OmniRoute","commit_stats":null,"previous_names":["diegosouzapw/omniroute"],"tags_count":53,"template":false,"template_full_name":null,"purl":"pkg:github/diegosouzapw/OmniRoute","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diegosouzapw%2FOmniRoute","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diegosouzapw%2FOmniRoute/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diegosouzapw%2FOmniRoute/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diegosouzapw%2FOmniRoute/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/diegosouzapw","download_url":"https://codeload.github.com/diegosouzapw/OmniRoute/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/diegosouzapw%2FOmniRoute/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29991043,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-03-02T01:47:34.672Z","status":"online","status_checked_at":"2026-03-02T02:00:07.342Z","response_time":60,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2026-03-03T22:00:28.519Z","updated_at":"2026-03-04T08:00:38.236Z","avatar_url":"https://github.com/diegosouzapw.png","language":"TypeScript","funding_links":[],"categories":["LLMOps","AI Gateway/Aggregator","🛡️ AI Gateways, Proxies \u0026 Agent Security","Design Primitives","TypeScript","ai-agents","Productivity Tools","🤖 AI-Related Tools","Quick Comparison","*Ops for AI"],"sub_categories":["LLM Gateways \u0026 Proxies","Task Runners \u0026 Orchestration","Research Assistant","Other Cloud Provider Credits","LLMOps"],"readme":"\u003cdiv align=\"center\"\u003e\n  \u003cimg src=\"./docs/screenshots/MainOmniRoute.png\" alt=\"OmniRoute Dashboard\" width=\"800\"/\u003e\n  \n  # 🚀 OmniRoute — بوابة الذكاء الاصطناعي المجانية\n\n### لا تتوقف أبدًا عن البرمجة. التوجيه الذكي إلى **نماذج الذكاء الاصطناعي المجانية ومنخفضة التكلفة** مع الرجوع التلقائي.\n\n_وكيل واجهة برمجة التطبيقات العالمي الخاص بك — نقطة نهاية واحدة، وأكثر من 36 موفرًا، بدون أي توقف عن العمل._\n\n**إكمالات الدردشة • التضمينات • إنشاء الصور • الصوت • إعادة الترتيب • 100% TypeScript**\n\n---\n\n### 🤖 موفر الذكاء الاصطناعي المجاني لوكلاء البرمجة المفضلين لديك\n\n_قم بتوصيل أي أداة IDE أو CLI مدعومة بالذكاء الاصطناعي من خلال OmniRoute - بوابة واجهة برمجة التطبيقات المجانية للترميز غير المحدود._\n\n  \u003ctable\u003e\n    \u003ctr\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/cline/cline\"\u003e\n          \u003cimg src=\"./public/providers/openclaw.png\" alt=\"OpenClaw\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eOpenClaw\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 205K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/HKUDS/nanobot\"\u003e\n          \u003cimg src=\"./public/providers/nanobot.png\" alt=\"NanoBot\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eNanoBot\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 20.9K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/sipeed/picoclaw\"\u003e\n          \u003cimg src=\"./public/providers/picoclaw.jpg\" alt=\"PicoClaw\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003ePicoClaw\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 14.6K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/zeroclaw-labs/zeroclaw\"\u003e\n          \u003cimg src=\"./public/providers/zeroclaw.png\" alt=\"ZeroClaw\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eZeroClaw\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 9.9K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/nearai/ironclaw\"\u003e\n          \u003cimg src=\"./public/providers/ironclaw.png\" alt=\"IronClaw\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eIronClaw\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 2.1K\u003c/sub\u003e\n      \u003c/td\u003e\n    \u003c/tr\u003e\n    \u003ctr\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/anomalyco/opencode\"\u003e\n          \u003cimg src=\"./public/providers/opencode.svg\" alt=\"OpenCode\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eOpenCode\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 106K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/openai/codex\"\u003e\n          \u003cimg src=\"./public/providers/codex.png\" alt=\"Codex CLI\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eCodex CLI\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 60.8K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/anthropics/claude-code\"\u003e\n          \u003cimg src=\"./public/providers/claude.png\" alt=\"Claude Code\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eClaude Code\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 67.3K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/google-gemini/gemini-cli\"\u003e\n          \u003cimg src=\"./public/providers/gemini-cli.png\" alt=\"Gemini CLI\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eGemini CLI\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 94.7K\u003c/sub\u003e\n      \u003c/td\u003e\n      \u003ctd align=\"center\" width=\"110\"\u003e\n        \u003ca href=\"https://github.com/Kilo-Org/kilocode\"\u003e\n          \u003cimg src=\"./public/providers/kilocode.png\" alt=\"Kilo Code\" width=\"48\"/\u003e\u003cbr/\u003e\n          \u003cb\u003eKilo Code\u003c/b\u003e\n        \u003c/a\u003e\u003cbr/\u003e\n        \u003csub\u003e⭐ 15.5K\u003c/sub\u003e\n      \u003c/td\u003e\n    \u003c/tr\u003e\n  \u003c/table\u003e\n\n\u003csub\u003e📡 يتصل جميع الوكلاء عبر \u003ccode\u003ehttp://localhost:20128/v1\u003c/code\u003e أو \u003ccode\u003ehttp://cloud.omniroute.online/v1\u003c/code\u003e - تكوين واحد ونماذج غير محدودة و الحصة\u003c/sub\u003e\n\n---\n\n[![npm version](https://img.shields.io/npm/v/omniroute?color=cb3837\u0026logo=npm)](https://www.npmjs.com/package/omniroute)\n[![Docker Hub](https://img.shields.io/docker/v/diegosouzapw/omniroute?label=Docker%20Hub\u0026logo=docker\u0026color=2496ED)](https://hub.docker.com/r/diegosouzapw/omniroute)\n[![License](https://img.shields.io/github/license/diegosouzapw/OmniRoute)](https://github.com/diegosouzapw/OmniRoute/blob/main/LICENSE)\n[![Website](https://img.shields.io/badge/Website-omniroute.online-blue?logo=google-chrome\u0026logoColor=white)](https://omniroute.online)\n[![WhatsApp](https://img.shields.io/badge/WhatsApp-Community-25D366?logo=whatsapp\u0026logoColor=white)](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t)\n\n[🌐 الموقع](https://omniroute.online) • [🚀 البداية السريعة](#-بداية-سريعة) • [💡 الميزات](#-الميزات-الرئيسية) • [📖 التوثيق](#-التوثيق) • [💰 الأسعار](#-لمحة-سريعة-عن-الأسعار) • [💬 WhatsApp](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t)\n\n🌐 **متوفر باللغات:** 🇺🇸 [English](README.md) | 🇧🇷 [Português (Brasil)](README.pt-BR.md) | 🇪🇸 [Español](README.es.md) | 🇫🇷 [Français](README.fr.md) | 🇮🇹 [Italiano](README.it.md) | 🇷🇺 [Русский](README.ru.md) | 🇨🇳 [中文 (简体)](README.zh-CN.md) | 🇩🇪 [Deutsch](README.de.md) | 🇮🇳 [हिन्दी](README.in.md) | 🇹🇭 [ไทย](README.th.md) | 🇺🇦 [Українська](README.uk-UA.md) | 🇸🇦 [العربية](README.ar.md) | 🇯🇵 [日本語](README.ja.md) | 🇻🇳 [Tiếng Việt](README.vi.md) | 🇧🇬 [Български](README.bg.md) | 🇩🇰 [Dansk](README.da.md) | 🇫🇮 [Suomi](README.fi.md) | 🇮🇱 [עברית](README.he.md) | 🇭🇺 [Magyar](README.hu.md) | 🇮🇩 [Bahasa Indonesia](README.id.md) | 🇰🇷 [한국어](README.ko.md) | 🇲🇾 [Bahasa Melayu](README.ms.md) | 🇳🇱 [Nederlands](README.nl.md) | 🇳🇴 [Norsk](README.no.md) | 🇵🇹 [Português (Portugal)](README.pt.md) | 🇷🇴 [Română](README.ro.md) | 🇵🇱 [Polski](README.pl.md) | 🇸🇰 [Slovenčina](README.sk.md) | 🇸🇪 [Svenska](README.sv.md) | 🇵🇭 [Filipino](README.phi.md)\n\n\u003c/div\u003e\n\n---\n\n## 🤔 لماذا OmniRoute؟\n\n**توقف عن إهدار المال وضرب الحدود:**\n\n- \u003cimg src=\"https://img.shields.io/badge/✗-e74c3c?style=flat-square\" height=\"16\"/\u003e تنتهي صلاحية حصة الاشتراك غير المستخدمة كل شهر\n- \u003cimg src=\"https://img.shields.io/badge/✗-e74c3c?style=flat-square\" height=\"16\"/\u003e حدود الأسعار تمنعك من الترميز المتوسط\n- \u003cimg src=\"https://img.shields.io/badge/✗-e74c3c?style=flat-square\" height=\"16\"/\u003e واجهات برمجة التطبيقات باهظة الثمن (20-50 دولارًا شهريًا لكل مزود)\n- \u003cimg src=\"https://img.shields.io/badge/✗-e74c3c?style=flat-square\" height=\"16\"/\u003e التبديل اليدوي بين مقدمي الخدمة\n\n** OmniRoute يحل هذا: **\n\n- ✅ **تعظيم الاشتراكات** - تتبع الحصة، استخدم كل جزء منها قبل إعادة التعيين\n- ✅ **الرجوع التلقائي** - الاشتراك → مفتاح واجهة برمجة التطبيقات → رخيص → مجاني، بدون توقف\n- ✅ **حسابات متعددة** - جولة روبن بين الحسابات لكل مزود\n- ✅ **عالمي** - يعمل مع Claude Code وCodex وGemini CLI وCursor وCline وOpenClaw وأي أداة CLI\n\n---\n\n## 🔄 كيف يعمل\n\n```\n┌─────────────┐\n│  Your CLI   │  (Claude Code, Codex, Gemini CLI, OpenClaw, Cursor, Cline...)\n│   Tool      │\n└──────┬──────┘\n       │ http://localhost:20128/v1\n       ↓\n┌─────────────────────────────────────────┐\n│           OmniRoute (Smart Router)        │\n│  • Format translation (OpenAI ↔ Claude) │\n│  • Quota tracking + Embeddings + Images │\n│  • Auto token refresh                   │\n└──────┬──────────────────────────────────┘\n       │\n       ├─→ [Tier 1: SUBSCRIPTION] Claude Code, Codex, Gemini CLI\n       │   ↓ quota exhausted\n       ├─→ [Tier 2: API KEY] DeepSeek, Groq, xAI, Mistral, NVIDIA NIM, etc.\n       │   ↓ budget limit\n       ├─→ [Tier 3: CHEAP] GLM ($0.6/1M), MiniMax ($0.2/1M)\n       │   ↓ budget limit\n       └─→ [Tier 4: FREE] iFlow, Qwen, Kiro (unlimited)\n\nResult: Never stop coding, minimal cost\n```\n\n---\n\n## 🎯 What OmniRoute Solves — 16 Real Pain Points\n\n\u003e **Every developer using AI tools faces these problems daily.** OmniRoute was built to solve them all — from cost overruns to regional blocks, from broken OAuth flows to zero observability.\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e💸 1. \"I pay for an expensive subscription but still get interrupted by limits\"\u003c/b\u003e\u003c/summary\u003e\n\nDevelopers pay $20–200/month for Claude Pro, Codex Pro, or GitHub Copilot. Even paying, quota has a ceiling — 5h of usage, weekly limits, or per-minute rate limits. Mid-coding session, the provider stops responding and the developer loses flow and productivity.\n\n**How OmniRoute solves it:**\n\n- **Smart 4-Tier Fallback** — If subscription quota runs out, automatically redirects to API Key → Cheap → Free with zero manual intervention\n- **Real-Time Quota Tracking** — Shows token consumption in real-time with reset countdown (5h, daily, weekly)\n- **Multi-Account Support** — Multiple accounts per provider with auto round-robin — when one runs out, switches to the next\n- **Custom Combos** — Customizable fallback chains with 6 balancing strategies (fill-first, round-robin, P2C, random, least-used, cost-optimized)\n- **Codex Business Quotas** — Business/Team workspace quota monitoring directly in the dashboard\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔌 2. \"I need to use multiple providers but each has a different API\"\u003c/b\u003e\u003c/summary\u003e\n\nOpenAI uses one format, Claude (Anthropic) uses another, Gemini yet another. If a dev wants to test models from different providers or fallback between them, they need to reconfigure SDKs, change endpoints, deal with incompatible formats. Custom providers (FriendLI, NIM) have non-standard model endpoints.\n\n**How OmniRoute solves it:**\n\n- **Unified Endpoint** — A single `http://localhost:20128/v1` serves as proxy for all 36+ providers\n- **Format Translation** — Automatic and transparent: OpenAI ↔ Claude ↔ Gemini ↔ Responses API\n- **Response Sanitization** — Strips non-standard fields (`x_groq`, `usage_breakdown`, `service_tier`) that break OpenAI SDK v1.83+\n- **Role Normalization** — Converts `developer` → `system` for non-OpenAI providers; `system` → `user` for GLM/ERNIE\n- **Think Tag Extraction** — Extracts `\u003cthink\u003e` blocks from models like DeepSeek R1 into standardized `reasoning_content`\n- **Structured Output for Gemini** — `json_schema` → `responseMimeType`/`responseSchema` automatic conversion\n- **`stream` defaults to `false`** — Aligns with OpenAI spec, avoiding unexpected SSE in Python/Rust/Go SDKs\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🌐 3. \"My AI provider blocks my region/country\"\u003c/b\u003e\u003c/summary\u003e\n\nProviders like OpenAI/Codex block access from certain geographic regions. Users get errors like `unsupported_country_region_territory` during OAuth and API connections. This is especially frustrating for developers from developing countries.\n\n**How OmniRoute solves it:**\n\n- **3-Level Proxy Config** — Configurable proxy at 3 levels: global (all traffic), per-provider (one provider only), and per-connection/key\n- **Color-Coded Proxy Badges** — Visual indicators: 🟢 global proxy, 🟡 provider proxy, 🔵 connection proxy, always showing the IP\n- **OAuth Token Exchange Through Proxy** — OAuth flow also goes through the proxy, solving `unsupported_country_region_territory`\n- **Connection Tests via Proxy** — Connection tests use the configured proxy (no more direct bypass)\n- **SOCKS5 Support** — Full SOCKS5 proxy support for outbound routing\n- **TLS Fingerprint Spoofing** — Browser-like TLS fingerprint via `wreq-js` to bypass bot detection\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🆓 4. \"I want to use AI for coding but I have no money\"\u003c/b\u003e\u003c/summary\u003e\n\nNot everyone can pay $20–200/month for AI subscriptions. Students, devs from emerging countries, hobbyists, and freelancers need access to quality models at zero cost.\n\n**How OmniRoute solves it:**\n\n- **Free Tier Providers Built-in** — Native support for 100% free providers: iFlow (8 unlimited models), Qwen (3 unlimited models), Kiro (Claude for free), Gemini CLI (180K/month free)\n- **Free-Only Combos** — Chain `gc/gemini-3-flash → if/kimi-k2-thinking → qw/qwen3-coder-plus` = $0/month with zero downtime\n- **NVIDIA NIM Free Credits** — 1000 free credits integrated\n- **Cost Optimized Strategy** — Routing strategy that automatically chooses the cheapest available provider\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔒 5. \"I need to protect my AI gateway from unauthorized access\"\u003c/b\u003e\u003c/summary\u003e\n\nWhen exposing an AI gateway to the network (LAN, VPS, Docker), anyone with the address can consume the developer's tokens/quota. Without protection, APIs are vulnerable to misuse, prompt injection, and abuse.\n\n**How OmniRoute solves it:**\n\n- **API Key Management** — Generation, rotation, and scoping per provider with a dedicated `/dashboard/api-manager` page\n- **Model-Level Permissions** — Restrict API keys to specific models (`openai/*`, wildcard patterns), with Allow All/Restrict toggle\n- **API Endpoint Protection** — Require a key for `/v1/models` and block specific providers from the listing\n- **Auth Guard + CSRF Protection** — All dashboard routes protected with `withAuth` middleware + CSRF tokens\n- **Rate Limiter** — Per-IP rate limiting with configurable windows\n- **IP Filtering** — Allowlist/blocklist for access control\n- **Prompt Injection Guard** — Sanitization against malicious prompt patterns\n- **AES-256-GCM Encryption** — Credentials encrypted at rest\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🛑 6. \"My provider went down and I lost my coding flow\"\u003c/b\u003e\u003c/summary\u003e\n\nAI providers can become unstable, return 5xx errors, or hit temporary rate limits. If a dev depends on a single provider, they're interrupted. Without circuit breakers, repeated retries can crash the application.\n\n**How OmniRoute solves it:**\n\n- **Circuit Breaker per-provider** — Auto-open/close with configurable thresholds and cooldown (Closed/Open/Half-Open)\n- **Exponential Backoff** — Progressive retry delays\n- **Anti-Thundering Herd** — Mutex + semaphore protection against concurrent retry storms\n- **Combo Fallback Chains** — If the primary provider fails, automatically falls through the chain with no intervention\n- **Combo Circuit Breaker** — Auto-disables failing providers within a combo chain\n- **Health Dashboard** — Uptime monitoring, circuit breaker states, lockouts, cache stats, p50/p95/p99 latency\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔧 7. \"Configuring each AI tool is tedious and repetitive\"\u003c/b\u003e\u003c/summary\u003e\n\nDevelopers use Cursor, Claude Code, Codex CLI, OpenClaw, Gemini CLI, Kilo Code... Each tool needs a different config (API endpoint, key, model). Reconfiguring when switching providers or models is a waste of time.\n\n**How OmniRoute solves it:**\n\n- **CLI Tools Dashboard** — Dedicated page with one-click setup for Claude Code, Codex CLI, OpenClaw, Kilo Code, Antigravity, Cline\n- **GitHub Copilot Config Generator** — Generates `chatLanguageModels.json` for VS Code with bulk model selection\n- **Onboarding Wizard** — Guided 4-step setup for first-time users\n- **One endpoint, all models** — Configure `http://localhost:20128/v1` once, access 36+ providers\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔑 8. \"Managing OAuth tokens from multiple providers is hell\"\u003c/b\u003e\u003c/summary\u003e\n\nClaude Code, Codex, Gemini CLI, Copilot — all use OAuth 2.0 with expiring tokens. Developers need to re-authenticate constantly, deal with `client_secret is missing`, `redirect_uri_mismatch`, and failures on remote servers. OAuth on LAN/VPS is particularly problematic.\n\n**How OmniRoute solves it:**\n\n- **Auto Token Refresh** — OAuth tokens refresh in background before expiration\n- **OAuth 2.0 (PKCE) Built-in** — Automatic flow for Claude Code, Codex, Gemini CLI, Copilot, Kiro, Qwen, iFlow\n- **Multi-Account OAuth** — Multiple accounts per provider via JWT/ID token extraction\n- **OAuth LAN/Remote Fix** — Private IP detection for `redirect_uri` + manual URL mode for remote servers\n- **OAuth Behind Nginx** — Uses `window.location.origin` for reverse proxy compatibility\n- **Remote OAuth Guide** — Step-by-step guide for Google Cloud credentials on VPS/Docker\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e📊 9. \"I don't know how much I'm spending or where\"\u003c/b\u003e\u003c/summary\u003e\n\nDevelopers use multiple paid providers but have no unified view of spending. Each provider has its own billing dashboard, but there's no consolidated view. Unexpected costs can pile up.\n\n**How OmniRoute solves it:**\n\n- **Cost Analytics Dashboard** — Per-token cost tracking and budget management per provider\n- **Budget Limits per Tier** — Spending ceiling per tier that triggers automatic fallback\n- **Per-Model Pricing Configuration** — Configurable prices per model\n- **Usage Statistics Per API Key** — Request count and last-used timestamp per key\n- **Analytics Dashboard** — Stat cards, model usage chart, provider table with success rates and latency\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🐛 10. \"I can't diagnose errors and problems in AI calls\"\u003c/b\u003e\u003c/summary\u003e\n\nWhen a call fails, the dev doesn't know if it was a rate limit, expired token, wrong format, or provider error. Fragmented logs across different terminals. Without observability, debugging is trial-and-error.\n\n**How OmniRoute solves it:**\n\n- **Unified Logs Dashboard** — 4 tabs: Request Logs, Proxy Logs, Audit Logs, Console\n- **Console Log Viewer** — Real-time terminal-style viewer with color-coded levels, auto-scroll, search, filter\n- **SQLite Proxy Logs** — Persistent logs that survive server restarts\n- **Translator Playground** — 4 debugging modes: Playground (format translation), Chat Tester (round-trip), Test Bench (batch), Live Monitor (real-time)\n- **Request Telemetry** — p50/p95/p99 latency + X-Request-Id tracing\n- **File-Based Logging with Rotation** — Console interceptor captures everything to JSON log with size-based rotation\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🏗️ 11. \"Deploying and maintaining the gateway is complex\"\u003c/b\u003e\u003c/summary\u003e\n\nInstalling, configuring, and maintaining an AI proxy across different environments (local, VPS, Docker, cloud) is labor-intensive. Problems like hardcoded paths, `EACCES` on directories, port conflicts, and cross-platform builds add friction.\n\n**How OmniRoute solves it:**\n\n- **npm global install** — `npm install -g omniroute \u0026\u0026 omniroute` — done\n- **Docker Multi-Platform** — AMD64 + ARM64 native (Apple Silicon, AWS Graviton, Raspberry Pi)\n- **Docker Compose Profiles** — `base` (no CLI tools) and `cli` (with Claude Code, Codex, OpenClaw)\n- **Electron Desktop App** — Native app for Windows/macOS/Linux with system tray, auto-start, offline mode\n- **Split-Port Mode** — API and Dashboard on separate ports for advanced scenarios (reverse proxy, container networking)\n- **Cloud Sync** — Config synchronization across devices via Cloudflare Workers\n- **DB Backups** — Automatic backup, restore, export and import of all settings\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🌍 12. \"The interface is English-only and my team doesn't speak English\"\u003c/b\u003e\u003c/summary\u003e\n\nTeams in non-English-speaking countries, especially in Latin America, Asia, and Europe, struggle with English-only interfaces. Language barriers reduce adoption and increase configuration errors.\n\n**How OmniRoute solves it:**\n\n- **Dashboard i18n — 30 Languages** — All 500+ keys translated including Arabic, Bulgarian, Danish, German, Spanish, Finnish, French, Hebrew, Hindi, Hungarian, Indonesian, Italian, Japanese, Korean, Malay, Dutch, Norwegian, Polish, Portuguese (PT/BR), Romanian, Russian, Slovak, Swedish, Thai, Ukrainian, Vietnamese, Chinese, Filipino, English\n- **RTL Support** — Right-to-left support for Arabic and Hebrew\n- **Multi-Language READMEs** — 30 complete documentation translations\n- **Language Selector** — Globe icon in header for real-time switching\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔄 13. \"I need more than chat — I need embeddings, images, audio\"\u003c/b\u003e\u003c/summary\u003e\n\nAI isn't just chat completion. Devs need to generate images, transcribe audio, create embeddings for RAG, rerank documents, and moderate content. Each API has a different endpoint and format.\n\n**How OmniRoute solves it:**\n\n- **Embeddings** — `/v1/embeddings` with 6 providers and 9+ models\n- **Image Generation** — `/v1/images/generations` with 4 providers and 9+ models\n- **Audio Transcription** — `/v1/audio/transcriptions` — Whisper-compatible\n- **Text-to-Speech** — `/v1/audio/speech` — Multi-provider audio synthesis\n- **Moderations** — `/v1/moderations` — Content safety checks\n- **Reranking** — `/v1/rerank` — Document relevance reranking\n- **Responses API** — Full `/v1/responses` support for Codex\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🧪 14. \"I have no way to test and compare quality across models\"\u003c/b\u003e\u003c/summary\u003e\n\nDevelopers want to know which model is best for their use case — code, translation, reasoning — but comparing manually is slow. No integrated eval tools exist.\n\n**How OmniRoute solves it:**\n\n- **LLM Evaluations** — Golden set testing with 10 pre-loaded cases covering greetings, math, geography, code generation, JSON compliance, translation, markdown, safety refusal\n- **4 Match Strategies** — `exact`, `contains`, `regex`, `custom` (JS function)\n- **Translator Playground Test Bench** — Batch testing with multiple inputs and expected outputs, cross-provider comparison\n- **Chat Tester** — Full round-trip with visual response rendering\n- **Live Monitor** — Real-time stream of all requests flowing through the proxy\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e📈 15. \"I need to scale without losing performance\"\u003c/b\u003e\u003c/summary\u003e\n\nAs request volume grows, without caching the same questions generate duplicate costs. Without idempotency, duplicate requests waste processing. Per-provider rate limits must be respected.\n\n**How OmniRoute solves it:**\n\n- **Semantic Cache** — Two-tier cache (signature + semantic) reduces cost and latency\n- **Request Idempotency** — 5s deduplication window for identical requests\n- **Rate Limit Detection** — Per-provider RPM, min gap, and max concurrent tracking\n- **Editable Rate Limits** — Configurable defaults in Settings → Resilience with persistence\n- **API Key Validation Cache** — 3-tier cache for production performance\n- **Health Dashboard with Telemetry** — p50/p95/p99 latency, cache stats, uptime\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🤖 16. \"I want to control model behavior globally\"\u003c/b\u003e\u003c/summary\u003e\n\nDevelopers who want all responses in a specific language, with a specific tone, or want to limit reasoning tokens. Configuring this in every tool/request is impractical.\n\n**How OmniRoute solves it:**\n\n- **System Prompt Injection** — Global prompt applied to all requests\n- **Thinking Budget Validation** — Reasoning token allocation control per request (passthrough, auto, custom, adaptive)\n- **6 Routing Strategies** — Global strategies that determine how requests are distributed\n- **Wildcard Router** — `provider/*` patterns route dynamically to any provider\n- **Combo Enable/Disable Toggle** — Toggle combos directly from the dashboard\n- **Provider Toggle** — Enable/disable all connections for a provider with one click\n- **Blocked Providers** — Exclude specific providers from `/v1/models` listing\n\n\u003c/details\u003e\n\n## ⚡ بداية سريعة\n\n**1. التثبيت عالميًا:**\n\n```bash\nnpm install -g omniroute\nomniroute\n```\n\n🎉 تفتح لوحة التحكم في `http://localhost:20128`\n\n| الأمر                   | الوصف                                     |\n| ----------------------- | ----------------------------------------- |\n| `omniroute`             | بدء تشغيل الخادم (المنفذ الافتراضي 20128) |\n| `omniroute --port 3000` | استخدم المنفذ المخصص                      |\n| `omniroute --no-open`   | لا تفتح المتصفح تلقائيًا                  |\n| `omniroute --help`      | عرض المساعدة                              |\n\n**2. الاتصال بمزود مجاني: **\n\nلوحة التحكم → الموفرون → الاتصال **Claude Code** أو **Antigravity** → تسجيل الدخول OAuth → تم!\n\n**3. استخدم في أداة CLI الخاصة بك:**\n\n```\nClaude Code/Codex/Gemini CLI/OpenClaw/Cursor/Cline Settings:\n  Endpoint: http://localhost:20128/v1\n  API Key: [copy from dashboard]\n  Model: if/kimi-k2-thinking\n```\n\n**هذا كل شيء!** ابدأ البرمجة باستخدام نماذج الذكاء الاصطناعي المجانية.\n\n** البديل - تشغيل من المصدر: **\n\n```bash\ncp .env.example .env\nnpm install\nPORT=20128 NEXT_PUBLIC_BASE_URL=http://localhost:20128 npm run dev\n```\n\n---\n\n## 🐳 عامل الميناء\n\nOmniRoute متاح كصورة Docker عامة على [Docker Hub](https://hub.docker.com/r/diegosouzapw/omniroute).\n\n**الجري السريع:**\n\n```bash\ndocker run -d \\\n  --name omniroute \\\n  --restart unless-stopped \\\n  -p 20128:20128 \\\n  -v omniroute-data:/app/data \\\n  diegosouzapw/omniroute:latest\n```\n\n** مع ملف البيئة: **\n\n```bash\n# Copy and edit .env first\ncp .env.example .env\n\ndocker run -d \\\n  --name omniroute \\\n  --restart unless-stopped \\\n  --env-file .env \\\n  -p 20128:20128 \\\n  -v omniroute-data:/app/data \\\n  diegosouzapw/omniroute:latest\n```\n\n**استخدام Docker Compose:**\n\n```bash\n# Base profile (no CLI tools)\ndocker compose --profile base up -d\n\n# CLI profile (Claude Code, Codex, OpenClaw built-in)\ndocker compose --profile cli up -d\n```\n\n| صورة                     | العلامة  | الحجم         | الوصف            |\n| ------------------------ | -------- | ------------- | ---------------- |\n| `diegosouzapw/omniroute` | `latest` | ~250 ميجابايت | أحدث إصدار مستقر |\n| `diegosouzapw/omniroute` | `1.0.3`  | ~250 ميجابايت | النسخة الحالية   |\n\n---\n\n---\n\n## 🖥️ تطبيق سطح المكتب — غير متصل ومتاح دائمًا\n\n\u003e 🆕 **جديد!** أصبح OmniRoute متاحًا الآن كـ **تطبيق سطح مكتب أصلي** لنظام Windows وmacOS وLinux.\n\n- 🖥️ **نافذة أصلية** — نافذة مخصصة مع تكامل شريط النظام\n- 🔄 **بدء تلقائي** — تشغيل OmniRoute عند تسجيل الدخول\n- 🔔 **إشعارات أصلية** — تنبيهات عند نفاد الحصة\n- ⚡ **تثبيت بنقرة واحدة** — NSIS (Windows)، DMG (macOS)، AppImage (Linux)\n- 🌐 **وضع غير متصل** — يعمل بالكامل بدون إنترنت\n\n```bash\nnpm run electron:dev           # وضع التطوير\nnpm run electron:build:win     # Windows (.exe)\nnpm run electron:build:mac     # macOS (.dmg)\nnpm run electron:build:linux   # Linux (.AppImage)\n```\n\n📖 التوثيق الكامل: [`electron/README.md`](electron/README.md)\n\n---\n\n## 💰 لمحة سريعة عن الأسعار\n\n| الطبقة                             | مقدم                         | التكلفة                | إعادة ضبط الحصص         | الأفضل لـ                 |\n| ---------------------------------- | ---------------------------- | ---------------------- | ----------------------- | ------------------------- |\n| **💳الإشتراك**                     | كلود كود (برو)               | 20 دولارًا شهريًا      | 5 ساعات + أسبوعي        | اشتركت بالفعل             |\n|                                    | الدستور الغذائي (زائد / برو) | 20-200 دولار شهريًا    | 5 ساعات + أسبوعي        | مستخدمي OpenAI            |\n|                                    | الجوزاء CLI                  | **مجاني**              | 180 ألف/شهر + 1 ألف/يوم | الجميع!                   |\n|                                    | جيثب مساعد الطيار            | 10-19 دولارًا شهريًا   | شهري                    | مستخدمي جيثب              |\n| **🔑 مفتاح واجهة برمجة التطبيقات** | نفيديا نيم                   | **مجانًا** (1000 نقطة) | لمرة واحدة              | اختبار المستوى المجاني    |\n|                                    | ديب سيك                      | الدفع لكل استخدام      | لا شيء                  | أفضل سعر/جودة             |\n|                                    | جروك                         | طبقة مجانية + مدفوعة   | معدل محدود              | الاستدلال فائق السرعة     |\n|                                    | xAI (جروك)                   | الدفع لكل استخدام      | لا شيء                  | نماذج جروك                |\n|                                    | ميسترال                      | طبقة مجانية + مدفوعة   | معدل محدود              | الذكاء الاصطناعي الأوروبي |\n|                                    | اوبن راوتر                   | الدفع لكل استخدام      | لا شيء                  | أكثر من 100 موديل         |\n| **💰 رخيص**                        | جي إل إم-4.7                 | 0.6 دولار/1 مليون      | يوميا 10 صباحا          | نسخة احتياطية للميزانية   |\n|                                    | ميني ماكس M2.1               | 0.2 دولار/1 مليون      | المتداول لمدة 5 ساعات   | الخيار الأرخص             |\n|                                    | كيمي ك2                      | 9 دولارات شهريًا مسطحة | 10 مليون رمز/شهر        | التكلفة المتوقعة          |\n| **🆓مجانًا**                       | اي فلو                       | $0                     | غير محدود               | 8 نماذج مجانية            |\n|                                    | كوين                         | $0                     | غير محدود               | 3 نماذج مجانية            |\n|                                    | كيرو                         | $0                     | غير محدود               | كلود مجاني                |\n\n**💡 نصيحة احترافية:** ابدأ مع مجموعة Gemini CLI (180 ألفًا مجانًا شهريًا) + مجموعة iFlow (مجانية غير محدودة) = تكلفة 0 دولار!\n\n---\n\n## 💡 الميزات الرئيسية\n\n### 🧠 التوجيه الأساسي والذكاء\n\n| ميزة                              | ماذا يفعل                                                                                      |\n| --------------------------------- | ---------------------------------------------------------------------------------------------- |\n| 🎯 **احتياطي ذكي من 4 طبقات**     | المسار التلقائي: الاشتراك → مفتاح API → رخيص → مجاني                                           |\n| 📊 **تتبع الحصص في الوقت الفعلي** | عدد الرموز الحية + إعادة تعيين العد التنازلي لكل مزود                                          |\n| 🔄 **تنسيق الترجمة**              | OpenAI ↔ كلود ↔ الجوزاء ↔ المؤشر ↔ كيرو سلس + تعقيم الاستجابة                                  |\n| 👥 **دعم الحسابات المتعددة**      | حسابات متعددة لكل مزود مع اختيار ذكي                                                           |\n| 🔄 **تحديث تلقائي للرمز**         | يتم تحديث رموز OAuth المميزة تلقائيًا من خلال إعادة المحاولة                                   |\n| 🎨 **مجموعات مخصصة**              | 6 إستراتيجيات: التعبئة أولاً، الجولة روبن، P2C، عشوائي، الأقل استخدامًا، الأمثل من حيث التكلفة |\n| 🧩 **نماذج مخصصة**                | أضف أي معرف نموذج إلى أي مزود                                                                  |\n| 🌐 **جهاز توجيه Wildcard**        | قم بتوجيه أنماط `provider/*` إلى أي مزود ديناميكيًا                                            |\n| 🧠 **ميزانية التفكير**            | أوضاع العبور والتلقائي والمخصص والتكيفي لنماذج الاستدلال                                       |\n| 🔀 **Model Aliases**              | Auto-forward deprecated model IDs to current replacements (built-in + custom)                  |\n| ⚡ **Background Degradation**     | Auto-route background tasks (titles, summaries) to cheaper models                              |\n| 💬 **الحقن الفوري للنظام**        | يتم تطبيق موجه النظام العالمي على كافة الطلبات                                                 |\n| 📄 **Responses API**              | دعم واجهة برمجة تطبيقات استجابات OpenAI الكاملة (`/v1/responses`) لـ Codex                     |\n\n### 🎵 واجهات برمجة التطبيقات متعددة الوسائط\n\n| ميزة                       | ماذا يفعل                                                 |\n| -------------------------- | --------------------------------------------------------- |\n| 🖼️ **إنشاء الصور**         | `/v1/images/generations` — 4 مقدمي خدمات، أكثر من 9 نماذج |\n| 📐 **المضامين**            | `/v1/embeddings` — 6 مقدمي خدمات، أكثر من 9 نماذج         |\n| 🎤 **نسخ صوتي**            | `/v1/audio/transcriptions` — متوافق مع الهمس              |\n| 🔊 **تحويل النص إلى كلام** | `/v1/audio/speech` — تركيب صوتي متعدد الموفرين            |\n| 🛡️ **اعتدالات**            | `/v1/moderations` — فحوصات سلامة المحتوى                  |\n| 🔀 **إعادة الترتيب**       | `/v1/rerank` — إعادة ترتيب مدى صلة الوثيقة                |\n\n### 🛡️ المرونة والأمان\n\n| ميزة                                          | ماذا يفعل                                                                                   |\n| --------------------------------------------- | ------------------------------------------------------------------------------------------- |\n| 🔌 **قاطع الدائرة**                           | فتح/إغلاق تلقائي لكل مزود مع حدود قابلة للتكوين                                             |\n| 🛡️ **القطيع المضاد للرعد**                    | الحد الأقصى لمعدل Mutex + الإشارة لموفري مفاتيح API                                         |\n| 🧠 **ذاكرة التخزين المؤقت الدلالية**          | ذاكرة التخزين المؤقت ذات المستويين (التوقيع + الدلالي) تقلل التكلفة وزمن الوصول             |\n| ⚡ **طلب العجز**                              | نافذة 5s dedup للطلبات المكررة                                                              |\n| 🔒 **انتحال بصمة الإصبع TLS**                 | تجاوز اكتشاف الروبوتات المستندة إلى TLS عبر wreq-js                                         |\n| 🌐 **تصفية IP**                               | القائمة المسموح بها/القائمة المحظورة للتحكم في الوصول إلى واجهة برمجة التطبيقات             |\n| 📊 **حدود المعدل القابلة للتحرير**            | عدد الدورات في الدقيقة القابل للتكوين والفجوة الدنيا والحد الأقصى المتزامن على مستوى النظام |\n| 💾 **Rate Limit Persistence**                 | Learned limits survive restarts via SQLite with 60s debounce + 24h staleness                |\n| 🔄 **Token Refresh Resilience**               | Per-provider circuit breaker (5 fails→30min) + 30s timeout per attempt                      |\n| 🛡 **حماية نقطة نهاية واجهة برمجة التطبيقات** | بوابة المصادقة + حظر الموفر لنقطة النهاية `/models`                                         |\n| 🔒 **رؤية الوكيل**                            | شارات مرمزة بالألوان: 🟢 عالمية، 🟡 مزود، 🔵 لكل اتصال مع عرض IP                            |\n| 🌐 ** تكوين الوكيل ذو 3 مستويات **            | قم بتكوين الوكلاء على المستوى العالمي أو لكل مزود أو لكل اتصال                              |\n\n### 📊 إمكانية الملاحظة والتحليلات\n\n| ميزة                                 | ماذا يفعل                                                                                    |\n| ------------------------------------ | -------------------------------------------------------------------------------------------- |\n| 📝 **تسجيل الطلبات**                 | وضع التصحيح مع سجلات الطلب/الاستجابة الكاملة                                                 |\n| 💾 **سجلات وكيل SQLite**             | تستمر سجلات الوكيل المستمرة في إعادة تشغيل الخادم                                            |\n| 📊 **لوحة التحكم التحليلية**         | مدعوم من إعادة التخطيط: بطاقات إحصائيات، مخطط استخدام النموذج، جدول الموفر                   |\n| 📈 **تتبع التقدم**                   | الاشتراك في أحداث تقدم SSE للبث                                                              |\n| 🧪 **تقييمات ماجستير إدارة الأعمال** | اختبار المجموعة الذهبية مع 4 إستراتيجيات المباراة                                            |\n| 🔍 **طلب القياس عن بعد**             | تجميع زمن الوصول p50/p95/p99 + تتبع معرف طلب X                                               |\n| 📋 **لوحة تحكم السجلات**             | صفحة موحدة مكونة من 4 علامات تبويب: سجلات الطلب، وسجلات الوكيل، وسجلات التدقيق، ووحدة التحكم |\n| 🖥️ **عارض سجل وحدة التحكم**          | عارض على النمط الطرفي في الوقت الفعلي مع مرشح المستوى والبحث والتمرير التلقائي               |\n| 📑 ** التسجيل المعتمد على الملفات ** | يلتقط جهاز اعتراض وحدة التحكم جميع المخرجات إلى ملف سجل JSON بالتدوير                        |\n| 🏥 **لوحة المعلومات الصحية**         | وقت تشغيل النظام، حالات قاطع الدائرة، عمليات الإغلاق، إحصائيات ذاكرة التخزين المؤقت          |\n| 💰 **تتبع التكلفة**                  | إدارة الميزانية + تكوين التسعير لكل نموذج                                                    |\n\n### ☁️ النشر والمزامنة\n\n| ميزة                                      | ماذا يفعل                                                                     |\n| ----------------------------------------- | ----------------------------------------------------------------------------- |\n| 💾 **المزامنة السحابية**                  | مزامنة التكوين عبر الأجهزة عبر Cloudflare Workers                             |\n| 🌐 **النشر في أي مكان**                   | المضيف المحلي، VPS، Docker، عمال Cloudflare                                   |\n| 🔑 **إدارة مفاتيح واجهة برمجة التطبيقات** | إنشاء مفاتيح واجهة برمجة التطبيقات وتدويرها ونطاقها لكل مزود                  |\n| 🧙 **معالج الإعداد**                      | إعداد إرشادي من 4 خطوات للمستخدمين لأول مرة                                   |\n| 🔧 **لوحة تحكم أدوات CLI**                | بنقرة واحدة قم بتكوين Claude، Codex، Cline، OpenClaw، Kilo، Antigravity       |\n| 🔄 **النسخ الاحتياطية لقاعدة البيانات**   | النسخ الاحتياطي التلقائي والاستعادة والتصدير والاستيراد لجميع الإعدادات       |\n| 🌐 **التدويل**                            | i18n الكامل مع دعم next-intl — الإنجليزية + البرتغالية (البرازيل)             |\n| 🌍 **محدد اللغة**                         | أيقونة الكرة الأرضية في رأس الصفحة للتبديل بين اللغات في الوقت الفعلي (🇺🇸/🇧🇷) |\n| 📂 **دليل البيانات المخصصة**              | `DATA_DIR` env var لتجاوز مسار التخزين الافتراضي `~/.omniroute`               |\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e📖 تفاصيل الميزة\u003c/b\u003e\u003c/summary\u003e\n\n### 🎯 نظام احتياطي ذكي مكون من 4 طبقات\n\nإنشاء مجموعات باستخدام خيار الرجوع التلقائي:\n\n```\nCombo: \"my-coding-stack\"\n  1. cc/claude-opus-4-6        (your subscription)\n  2. nvidia/llama-3.3-70b      (free NVIDIA API)\n  3. glm/glm-4.7               (cheap backup, $0.6/1M)\n  4. if/kimi-k2-thinking       (free fallback)\n\n→ Auto switches when quota runs out or errors occur\n```\n\n### 📊 تتبع الحصص في الوقت الحقيقي\n\n- استهلاك الرمز المميز لكل مزود\n- إعادة ضبط العد التنازلي (5 ساعات، يوميًا، أسبوعيًا)\n- تقدير التكلفة للمستويات المدفوعة\n- تقارير الإنفاق الشهرية\n\n### 🔄 ترجمة التنسيق\n\nترجمة سلسة بين الصيغ:\n\n- **OpenAI** ↔ **Claude** ↔ **Gemini** ↔ **استجابات OpenAI**\n- ترسل أداة CLI الخاصة بك تنسيق OpenAI ← يترجم OmniRoute ← يتلقى الموفر التنسيق الأصلي\n- يعمل مع أي أداة تدعم نقاط نهاية OpenAI المخصصة\n- **تطهير الاستجابة** - يزيل الحقول غير القياسية من أجل توافق صارم مع OpenAI SDK\n- **تطبيع الدور** — `developer` → `system` لغير OpenAI؛ `system` → `user` لطرز GLM/ERNIE\n- **استخراج علامة التفكير** — كتل `\u003cthink\u003e` → `reasoning_content` لنماذج التفكير\n- **الإخراج المنظم** — `json_schema` → الجوزاء `responseMimeType`/`responseSchema`\n\n### 👥 دعم الحسابات المتعددة\n\n- إضافة حسابات متعددة لكل مزود\n- التوجيه التلقائي أو التوجيه على أساس الأولوية\n- الرجوع إلى الحساب التالي عندما يصل أحد إلى الحصة\n\n### 🔄 التحديث التلقائي للرموز\n\n- يتم تحديث رموز OAuth المميزة تلقائيًا قبل انتهاء الصلاحية\n- لا حاجة لإعادة المصادقة اليدوية\n- تجربة سلسة عبر جميع مقدمي الخدمة\n\n### 🎨 مجموعات مخصصة\n\n- إنشاء مجموعات نماذج غير محدودة\n- 6 إستراتيجيات: التعبئة أولاً، جولة روبن، قوة الاختيارين، العشوائية، الأقل استخدامًا، الأمثل من حيث التكلفة\n- مشاركة المجموعات عبر الأجهزة باستخدام Cloud Sync\n\n### 🏥 لوحة المعلومات الصحية\n\n- حالة النظام (وقت التشغيل، الإصدار، استخدام الذاكرة)\n- حالات قاطع الدائرة لكل مزود (مغلق/مفتوح/نصف مفتوح)\n- حالة الحد الأقصى للسعر وعمليات الإغلاق النشطة\n- إحصائيات ذاكرة التخزين المؤقت للتوقيع\n- قياس الكمون عن بعد (ص50/ص95/ص99) + ذاكرة تخزين مؤقت سريعة\n- إعادة ضبط الحالة الصحية بنقرة واحدة\n\n### 🔧 ملعب المترجم\n\nيشتمل OmniRoute على ساحة مترجم قوية مدمجة مع **4 أوضاع** لتصحيح الأخطاء واختبار ومراقبة ترجمات واجهة برمجة التطبيقات:\n\n| الوضع                 | الوصف                                                                                                                                                                                                                            |\n| --------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |\n| **💻 الملعب**         | ترجمة التنسيق المباشر - الصق أي نص طلب واجهة برمجة التطبيقات (API) وشاهد على الفور كيف يقوم OmniRoute بترجمته بين تنسيقات الموفر (OpenAI ↔ Claude ↔ Gemini ↔ Responses API). يتضمن أمثلة على القوالب والكشف التلقائي عن التنسيق. |\n| **💬 اختبار الدردشة** | أرسل طلبات دردشة حقيقية من خلال OmniRoute وشاهد الرحلة الكاملة ذهابًا وإيابًا: مدخلاتك، والطلب المترجم، واستجابة الموفر، والرد المترجم. لا تقدر بثمن للتحقق من صحة توجيه التحرير والسرد.                                         |\n| **🧪 مقعد الاختبار**  | وضع الاختبار المجمع - حدد حالات اختبار متعددة بمدخلات مختلفة ومخرجات متوقعة، وقم بتشغيلها كلها مرة واحدة، وقارن النتائج عبر الموفرين والنماذج.                                                                                   |\n| **📱 مراقب مباشر**    | مراقبة الطلبات في الوقت الفعلي - شاهد الطلبات الواردة أثناء تدفقها عبر OmniRoute، وشاهد ترجمات التنسيق التي تحدث مباشرة، وحدد المشكلات على الفور.                                                                                |\n\n**الوصول:** لوحة المعلومات ← المترجم (الشريط الجانبي)\n\n### 💾 المزامنة السحابية\n\n- موفري المزامنة والمجموعات والإعدادات عبر الأجهزة\n- مزامنة الخلفية التلقائية\n- تخزين مشفر آمن\n\n\u003c/details\u003e\n\n---\n\n## 🎯 حالات الاستخدام\n\n### الحالة 1: \"لدي اشتراك Claude Pro\"\n\n**المشكلة:** تنتهي صلاحية الحصة غير المستخدمة، وحدود المعدل أثناء عملية الترميز المكثف\n\n```\nCombo: \"maximize-claude\"\n  1. cc/claude-opus-4-6        (use subscription fully)\n  2. glm/glm-4.7               (cheap backup when quota out)\n  3. if/kimi-k2-thinking       (free emergency fallback)\n\nMonthly cost: $20 (subscription) + ~$5 (backup) = $25 total\nvs. $20 + hitting limits = frustration\n```\n\n### الحالة 2: \"أريد تكلفة صفرية\"\n\n**المشكلة:** لا أستطيع تحمل تكلفة الاشتراكات، وتحتاج إلى ترميز يعتمد على الذكاء الاصطناعي\n\n```\nCombo: \"free-forever\"\n  1. gc/gemini-3-flash         (180K free/month)\n  2. if/kimi-k2-thinking       (unlimited free)\n  3. qw/qwen3-coder-plus       (unlimited free)\n\nMonthly cost: $0\nQuality: Production-ready models\n```\n\n### الحالة 3: \"أحتاج إلى تشفير على مدار 24 ساعة طوال أيام الأسبوع، دون انقطاع\"\n\n**المشكلة:** المواعيد النهائية، لا أستطيع تحمل فترات التوقف عن العمل\n\n```\nCombo: \"always-on\"\n  1. cc/claude-opus-4-6        (best quality)\n  2. cx/gpt-5.2-codex          (second subscription)\n  3. glm/glm-4.7               (cheap, resets daily)\n  4. minimax/MiniMax-M2.1      (cheapest, 5h reset)\n  5. if/kimi-k2-thinking       (free unlimited)\n\nResult: 5 layers of fallback = zero downtime\n```\n\n### الحالة 4: \"أريد ذكاءً اصطناعيًا مجانيًا في OpenClaw\"\n\n**المشكلة:** تحتاج إلى مساعد الذكاء الاصطناعي في تطبيقات المراسلة، مجانًا تمامًا\n\n```\nCombo: \"openclaw-free\"\n  1. if/glm-4.7                (unlimited free)\n  2. if/minimax-m2.1           (unlimited free)\n  3. if/kimi-k2-thinking       (unlimited free)\n\nMonthly cost: $0\nAccess via: WhatsApp, Telegram, Slack, Discord, iMessage, Signal...\n```\n\n---\n\n## 📖 دليل الإعداد\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e💳 موفري الاشتراك\u003c/b\u003e\u003c/summary\u003e\n\n### كلود كود (برو/ماكس)\n\n```bash\nDashboard → Providers → Connect Claude Code\n→ OAuth login → Auto token refresh\n→ 5-hour + weekly quota tracking\n\nModels:\n  cc/claude-opus-4-6\n  cc/claude-sonnet-4-5-20250929\n  cc/claude-haiku-4-5-20251001\n```\n\n**نصيحة احترافية:** استخدم Opus للمهام المعقدة، وSonnet للسرعة. OmniRoute يتتبع الحصة لكل نموذج!\n\n### OpenAI Codex (Plus/Pro)\n\n```bash\nDashboard → Providers → Connect Codex\n→ OAuth login (port 1455)\n→ 5-hour + weekly reset\n\nModels:\n  cx/gpt-5.2-codex\n  cx/gpt-5.1-codex-max\n```\n\n### Gemini CLI (180 ألفًا شهريًا مجانًا!)\n\n```bash\nDashboard → Providers → Connect Gemini CLI\n→ Google OAuth\n→ 180K completions/month + 1K/day\n\nModels:\n  gc/gemini-3-flash-preview\n  gc/gemini-2.5-pro\n```\n\n**أفضل قيمة:** طبقة مجانية ضخمة! استخدم هذا قبل المستويات المدفوعة.\n\n### مساعد جيثب\n\n```bash\nDashboard → Providers → Connect GitHub\n→ OAuth via GitHub\n→ Monthly reset (1st of month)\n\nModels:\n  gh/gpt-5\n  gh/claude-4.5-sonnet\n  gh/gemini-3-pro\n```\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔑 موفري مفاتيح واجهة برمجة التطبيقات\u003c/b\u003e\u003c/summary\u003e\n\n### NVIDIA NIM (1000 نقطة مجانية!)\n\n1. قم بالتسجيل: [build.nvidia.com](https://build.nvidia.com)\n2. احصل على مفتاح واجهة برمجة التطبيقات (API) مجانًا (يتضمن 1000 نقطة استدلال)\n3. لوحة المعلومات → إضافة موفر → NVIDIA NIM:\n   - مفتاح واجهة برمجة التطبيقات: `nvapi-your-key`\n\n**النماذج:** `nvidia/llama-3.3-70b-instruct`، `nvidia/mistral-7b-instruct`، وأكثر من 50 طرازًا آخر\n\n**نصيحة احترافية:** واجهة برمجة التطبيقات المتوافقة مع OpenAI — تعمل بسلاسة مع ترجمة تنسيق OmniRoute!\n\n### ديب سيك\n\n1. قم بالتسجيل: [platform.deepseek.com](https://platform.deepseek.com)\n2. احصل على مفتاح API\n3. لوحة المعلومات → إضافة موفر → DeepSeek\n\n**النماذج:** `deepseek/deepseek-chat`, `deepseek/deepseek-coder`\n\n### Groq (الطبقة المجانية متاحة!)\n\n1. قم بالتسجيل: [console.groq.com](https://console.groq.com)\n2. احصل على مفتاح API (الطبقة المجانية متضمنة)\n3. لوحة المعلومات → إضافة موفر → Groq\n\n**النماذج:** `groq/llama-3.3-70b`, `groq/mixtral-8x7b`\n\n**نصيحة احترافية:** استنتاج فائق السرعة — الأفضل للبرمجة في الوقت الفعلي!\n\n### OpenRouter (+100 موديل)\n\n1. قم بالتسجيل: [openrouter.ai](https://openrouter.ai)\n2. احصل على مفتاح API\n3. لوحة المعلومات → إضافة موفر → OpenRouter\n\n**النماذج:** يمكنك الوصول إلى أكثر من 100 نموذج من جميع المزودين الرئيسيين من خلال مفتاح واجهة برمجة التطبيقات (API) واحد.\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e💰 مقدمو الخدمة الرخيصة (النسخ الاحتياطي)\u003c/b\u003e\u003c/summary\u003e\n\n### GLM-4.7 (إعادة التعيين اليومي، 0.6 دولار/1 مليون)\n\n1. قم بالتسجيل: [Zhipu AI](https://open.bigmodel.cn/)\n2. احصل على مفتاح API من خطة الترميز\n3. لوحة المعلومات → إضافة مفتاح واجهة برمجة التطبيقات:\n   - المزود: `glm`\n   - مفتاح واجهة برمجة التطبيقات: `your-key`\n\n**الاستخدام:** `glm/glm-4.7`\n\n**نصيحة احترافية:** توفر خطة البرمجة حصة 3× بتكلفة 1/7! إعادة الضبط يوميًا الساعة 10:00 صباحًا.\n\n### MiniMax M2.1 (إعادة الضبط لمدة 5 ساعات، 0.20 دولار/1 مليون)\n\n1. قم بالتسجيل: [MiniMax](https://www.minimax.io/)\n2. احصل على مفتاح API\n3. لوحة المعلومات → إضافة مفتاح API\n\n**الاستخدام:** `minimax/MiniMax-M2.1`\n\n**نصيحة احترافية:** الخيار الأرخص للسياق الطويل (مليون رمز)!\n\n### كيمي K2 (شقة بقيمة 9 دولارات شهريًا)\n\n1. الاشتراك: [Moonshot AI](https://platform.moonshot.ai/)\n2. احصل على مفتاح API\n3. لوحة المعلومات → إضافة مفتاح API\n\n**الاستخدام:** `kimi/kimi-latest`\n\n**نصيحة احترافية:** سعر ثابت قدره 9 دولارات شهريًا مقابل 10 ملايين رمز مميز = 0.90 دولارًا أمريكيًا/مليون تكلفة فعالة!\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🆓 موفرو الخدمة المجانية (النسخ الاحتياطي في حالات الطوارئ)\u003c/b\u003e\u003c/summary\u003e\n\n### iFlow (8 نماذج مجانية)\n\n```bash\nDashboard → Connect iFlow\n→ iFlow OAuth login\n→ Unlimited usage\n\nModels:\n  if/kimi-k2-thinking\n  if/qwen3-coder-plus\n  if/glm-4.7\n  if/minimax-m2\n  if/deepseek-r1\n```\n\n### كوين (3 موديلات مجانية)\n\n```bash\nDashboard → Connect Qwen\n→ Device code authorization\n→ Unlimited usage\n\nModels:\n  qw/qwen3-coder-plus\n  qw/qwen3-coder-flash\n```\n\n### كيرو (كلود فري)\n\n```bash\nDashboard → Connect Kiro\n→ AWS Builder ID or Google/GitHub\n→ Unlimited usage\n\nModels:\n  kr/claude-sonnet-4.5\n  kr/claude-haiku-4.5\n```\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🎨 إنشاء مجموعات\u003c/b\u003e\u003c/summary\u003e\n\n### مثال 1: زيادة الاشتراك إلى الحد الأقصى → النسخ الاحتياطي الرخيص\n\n```\nDashboard → Combos → Create New\n\nName: premium-coding\nModels:\n  1. cc/claude-opus-4-6 (Subscription primary)\n  2. glm/glm-4.7 (Cheap backup, $0.6/1M)\n  3. minimax/MiniMax-M2.1 (Cheapest fallback, $0.20/1M)\n\nUse in CLI: premium-coding\n```\n\n### المثال 2: مجاني فقط (بدون تكلفة)\n\n```\nName: free-combo\nModels:\n  1. gc/gemini-3-flash-preview (180K free/month)\n  2. if/kimi-k2-thinking (unlimited)\n  3. qw/qwen3-coder-plus (unlimited)\n\nCost: $0 forever!\n```\n\n\u003c/details\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003e🔧 تكامل واجهة سطر الأوامر\u003c/b\u003e\u003c/summary\u003e\n\n### بيئة تطوير متكاملة للمؤشر\n\n```\nSettings → Models → Advanced:\n  OpenAI API Base URL: http://localhost:20128/v1\n  OpenAI API Key: [from OmniRoute dashboard]\n  Model: cc/claude-opus-4-6\n```\n\n### كلود كود\n\nاستخدم صفحة **أدوات CLI** في لوحة المعلومات للتكوين بنقرة واحدة، أو قم بتحرير `~/.claude/settings.json` يدويًا.\n\n### كوديكس سطر الأوامر\n\n```bash\nexport OPENAI_BASE_URL=\"http://localhost:20128\"\nexport OPENAI_API_KEY=\"your-omniroute-api-key\"\n\ncodex \"your prompt\"\n```\n\n### OpenClaw\n\n**الخيار 1 — لوحة التحكم (مستحسن):**\n\n```\nDashboard → CLI Tools → OpenClaw → Select Model → Apply\n```\n\n**الخيار 2 — يدويًا:** تحرير `~/.openclaw/openclaw.json`:\n\n```json\n{\n  \"models\": {\n    \"providers\": {\n      \"omniroute\": {\n        \"baseUrl\": \"http://127.0.0.1:20128/v1\",\n        \"apiKey\": \"sk_omniroute\",\n        \"api\": \"openai-completions\"\n      }\n    }\n  }\n}\n```\n\n\u003e **ملاحظة:** يعمل OpenClaw فقط مع OmniRoute المحلي. استخدم `127.0.0.1` بدلاً من `localhost` لتجنب مشكلات دقة IPv6.\n\n### كلاين / متابعة / RooCode\n\n```\nSettings → API Configuration:\n  Provider: OpenAI Compatible\n  Base URL: http://localhost:20128/v1\n  API Key: [from OmniRoute dashboard]\n  Model: if/kimi-k2-thinking\n```\n\n\u003c/details\u003e\n\n---\n\n## 🧪 التقييمات (التقييمات)\n\nيشتمل OmniRoute على إطار تقييم مدمج لاختبار جودة استجابة LLM مقابل المجموعة الذهبية. يمكنك الوصول إليه عبر **Analytics → Evals** في لوحة التحكم.\n\n### الطقم الذهبي المدمج\n\nتحتوي \"OmniRoute Golden Set\" المحملة مسبقًا على 10 حالات اختبار تغطي:\n\n- تحياتي، الرياضيات، الجغرافيا، توليد التعليمات البرمجية\n- الامتثال لتنسيق JSON والترجمة وتخفيض السعر\n- رفض السلامة (المحتوى الضار)، العد، المنطق المنطقي\n\n### استراتيجيات التقييم\n\n| استراتيجية | الوصف                                                         | مثال                             |\n| ---------- | ------------------------------------------------------------- | -------------------------------- |\n| `exact`    | يجب أن يتطابق الإخراج تمامًا مع                               | `\"4\"`                            |\n| `contains` | يجب أن يحتوي الإخراج على سلسلة فرعية (غير حساسة لحالة الأحرف) | `\"Paris\"`                        |\n| `regex`    | يجب أن يتطابق الإخراج مع نمط regex                            | `\"1.*2.*3\"`                      |\n| `custom`   | ترجع دالة JS المخصصة صواب/خطأ                                 | `(output) =\u003e output.length \u003e 10` |\n\n---\n\n## 🐛 استكشاف الأخطاء وإصلاحها\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003eانقر لتوسيع دليل استكشاف الأخطاء وإصلاحها\u003c/b\u003e\u003c/summary\u003e\n\n**\"نموذج اللغة لم يقدم رسائل\"**\n\n- استنفدت حصة الموفر → تحقق من تعقب حصة الموفر في لوحة المعلومات\n- الحل: استخدم خيار التحرير والسرد الاحتياطي أو قم بالتبديل إلى مستوى أرخص\n\n** الحد من المعدل **\n\n- حصة الاشتراك المحددة → الرجوع إلى GLM/MiniMax\n- إضافة التحرير والسرد: `cc/claude-opus-4-6 → glm/glm-4.7 → if/kimi-k2-thinking`\n\n** انتهت صلاحية رمز OAuth **\n\n- يتم التحديث تلقائيًا بواسطة OmniRoute\n- إذا استمرت المشكلات: لوحة المعلومات → الموفر → إعادة الاتصال\n\n**تكاليف مرتفعة**\n\n- التحقق من إحصائيات الاستخدام في لوحة المعلومات → التكاليف\n- تبديل النموذج الأساسي إلى GLM/MiniMax\n- استخدم الطبقة المجانية (Gemini CLI، iFlow) للمهام غير الحرجة\n\n** لوحة المعلومات تفتح على منفذ خاطئ **\n\n- اضبط `PORT=20128` و`NEXT_PUBLIC_BASE_URL=http://localhost:20128`\n\n**أخطاء المزامنة السحابية**\n\n- تحقق من نقاط `BASE_URL` لمثيلك قيد التشغيل\n- تحقق من نقاط `CLOUD_URL` إلى نقطة نهاية السحابة المتوقعة\n- احتفظ بقيم `NEXT_PUBLIC_*` متوافقة مع القيم من جانب الخادم\n\n**تسجيل الدخول الأول لا يعمل**\n\n- تحقق من `INITIAL_PASSWORD` في `.env`\n- في حالة عدم تعيينها، تكون كلمة المرور الاحتياطية هي `123456`\n\n** لا توجد سجلات الطلب **\n\n- اضبط `ENABLE_REQUEST_LOGS=true` في `.env`\n\n**يظهر اختبار الاتصال \"غير صالح\" لمقدمي الخدمات المتوافقين مع OpenAI**\n\n- لا يكشف العديد من مقدمي الخدمة عن نقطة النهاية `/models`\n- يتضمن OmniRoute v1.0.6+ التحقق الاحتياطي من خلال إكمال الدردشة\n- تأكد من أن عنوان URL الأساسي يتضمن اللاحقة `/v1`\n\n### 🔐 OAuth em Servidor Remoto (إعداد OAuth عن بعد)\n\n\u003ca name=\"oauth-em-servidor-remoto\"\u003e\u003c/a\u003e\n\n\u003e **⚠️ هام لمستخدمي OmniRoute على VPS/Docker/servidor عن بعد**\n\n### لماذا OAuth يفعل Antigravity / Gemini CLI في الخوادم البعيدة؟\n\nتم إثبات **Antigravity** e **Gemini CLI** باستخدام **Google OAuth 2.0** للمصادقة. تطلب Google أن يتم استخدام `redirect_uri` دون تدفق OAuth ** على وجه التحديد ** إلى معرفات URI السابقة للمسح في تطبيق Google Cloud Console.\n\nنظرًا لأن اعتمادات OAuth المُدمجة ليست في OmniRoute، فهي عبارة عن سجلات \\*\\*apenas لـ عندما تصل إلى OmniRoute من خادم بعيد (على سبيل المثال: `https://omniroute.meuservidor.com`)، تحصل Google على مصادقة عبر:\n\n```\nError 400: redirect_uri_mismatch\n```\n\n### الحل: تكوين OAuth الخاص بك\n\nيجب عليك إنشاء **OAuth 2.0 Client ID** على Google Cloud Console باستخدام URI لخادمك.\n\n#### باسو باسو\n\n**1. الوصول إلى Google Cloud Console**\n\nالعبرة: [https://console.cloud.google.com/apis/credentials](https://console.cloud.google.com/apis/credentials)\n\n**2. طلب معرف عميل OAuth 2.0 **\n\n- انقر على **\"+ إنشاء بيانات الاعتماد\"** → **\"معرف عميل OAuth\"**\n- نوع التطبيق: **\"تطبيق ويب\"**\n- الاسم: اسم escolha qualquer (على سبيل المثال: `OmniRoute Remote`)\n\n**3. Adicione كمحددات URI لإعادة التوجيه المعتمدة**\n\nليس هناك مجال **\"عناوين URI لإعادة التوجيه المعتمدة\"**، أضف:\n\n```\nhttps://seu-servidor.com/callback\n```\n\n\u003e استبدال `seu-servidor.com` بنطاقك أو IP الخاص بخادمك (بما في ذلك البوابة الضرورية، على سبيل المثال: `http://45.33.32.156:20128/callback`).\n\n**4. حفظ ونسخ كمعتمدة**\n\nوبعد ذلك، قم بإنشاء أو عرض Google o **معرف العميل** أو **سر العميل**.\n\n**5. تكوين كمتغيرات البيئة **\n\nلا يوجد `.env` (أو متغيرات بيئة Docker):\n\n```bash\n# Para Antigravity:\nANTIGRAVITY_OAUTH_CLIENT_ID=seu-client-id.apps.googleusercontent.com\nANTIGRAVITY_OAUTH_CLIENT_SECRET=GOCSPX-seu-secret\n\n# Para Gemini CLI:\nGEMINI_OAUTH_CLIENT_ID=seu-client-id.apps.googleusercontent.com\nGEMINI_OAUTH_CLIENT_SECRET=GOCSPX-seu-secret\nGEMINI_CLI_OAUTH_CLIENT_SECRET=GOCSPX-seu-secret\n```\n\n**6. Reinicie أو OmniRoute**\n\n```bash\n# Se usando npm:\nnpm run dev\n\n# Se usando Docker:\ndocker restart omniroute\n```\n\n**7. خيمة تواصل جديدة**\n\nلوحة المعلومات → الموفرون → Antigravity (ou Gemini CLI) → OAuth\n\nAgora o Google redirecionará corretamente para `https://seu-servidor.com/callback` e a autenticação funcionará.\n\n---\n\n### الحل المؤقت (لم يتم تكوين الاعتمادات الخاصة)\n\nإذا لم ترغب في إنشاء بيانات اعتماد خاصة بك منذ الآن، فمن الممكن استخدام التدفق **دليل URL**:\n\n1. يفتح OmniRoute عنوان URL لتفويض Google\n2. قم بتفويض Google لإعادة التوجيه إلى `localhost` (لا يوجد خادم عن بعد)\n3. **انسخ عنوان URL كاملاً** من شريط الإدخال في متصفحك (حتى لا يتم نقل الصفحة)\n4. هذا هو عنوان URL الذي يظهر في وضع الاتصال بـ OmniRoute\n5. انقر على **\"الاتصال\"**\n\n\u003e يعمل هذا الحل البديل لأن رمز التفويض الموجود على عنوان URL يكون صالحًا بشكل مستقل لإعادة التوجيه حيث يتم تحميله أو لا.\n\n\u003c/details\u003e\n\n---\n\n## 🛠️ تيك ستاك\n\n- **وقت التشغيل**: Node.js 18–22 LTS (⚠️ Node.js 24+ **غير مدعومة** — `better-sqlite3` الثنائيات الأصلية غير متوافقة)\n- **اللغة**: TypeScript 5.9 — **TypeScript بنسبة 100%** عبر `src/` و`open-sse/` (الإصدار 1.0.6)\n- **الإطار**: Next.js 16 + React 19 + Tailwind CSS 4\n- **قاعدة البيانات**: LowDB (JSON) + SQLite (حالة المجال + سجلات الوكيل)\n- **البث**: الأحداث المرسلة من الخادم (SSE)\n- **المصادقة**: OAuth 2.0 (PKCE) + JWT + مفاتيح API\n- **الاختبار**: مشغل اختبار Node.js (أكثر من 368 اختبارًا للوحدة)\n- **CI/CD**: إجراءات GitHub (نشر npm التلقائي + Docker Hub عند الإصدار)\n- **الموقع الإلكتروني**: [omniroute.online](https://omniroute.online)\n- **الحزمة**: [npmjs.com/package/omniroute](https://www.npmjs.com/package/omniroute)\n- **عامل الميناء**: [hub.docker.com/r/diegosouzapw/omniroute](https://hub.docker.com/r/diegosouzapw/omniroute)\n- **المرونة**: قاطع الدائرة الكهربائية، والتراجع الأسي، وقطيع مضاد للرعد، وانتحال TLS\n\n---\n\n## 📖 التوثيق\n\n| وثيقة                                        | الوصف                                         |\n| -------------------------------------------- | --------------------------------------------- |\n| [User Guide](docs/USER_GUIDE.md)             | مقدمو الخدمات، والمجموعات، وتكامل CLI، والنشر |\n| [API Reference](docs/API_REFERENCE.md)       | جميع نقاط النهاية مع الأمثلة                  |\n| [Troubleshooting](docs/TROUBLESHOOTING.md)   | المشاكل والحلول الشائعة                       |\n| [Architecture](docs/ARCHITECTURE.md)         | بنية النظام والداخلية                         |\n| [Contributing](CONTRIBUTING.md)              | إعداد التطوير والمبادئ التوجيهية              |\n| [OpenAPI Spec](docs/openapi.yaml)            | مواصفات OpenAPI 3.0                           |\n| [Security Policy](SECURITY.md)               | الإبلاغ عن الثغرات الأمنية والممارسات الأمنية |\n| [VM Deployment](docs/VM_DEPLOYMENT_GUIDE.md) | الدليل الكامل: إعداد VM + nginx + Cloudflare  |\n| [Features Gallery](docs/FEATURES.md)         | جولة لوحة القيادة المرئية مع لقطات الشاشة     |\n\n### 📸 معاينة لوحة التحكم\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cb\u003eانقر لرؤية لقطات شاشة لوحة المعلومات\u003c/b\u003e\u003c/summary\u003e\n\n| صفحة                  | لقطة شاشة                                         |\n| --------------------- | ------------------------------------------------- |\n| ** مقدمو الخدمة **    | ![Providers](docs/screenshots/01-providers.png)   |\n| **المجموعات**         | ![Combos](docs/screenshots/02-combos.png)         |\n| **تحليلات**           | ![Analytics](docs/screenshots/03-analytics.png)   |\n| **الصحة**             | ![Health](docs/screenshots/04-health.png)         |\n| **مترجم**             | ![Translator](docs/screenshots/05-translator.png) |\n| **الإعدادات**         | ![Settings](docs/screenshots/06-settings.png)     |\n| **أدوات سطر الأوامر** | ![CLI Tools](docs/screenshots/07-cli-tools.png)   |\n| **سجلات الاستخدام**   | ![Usage](docs/screenshots/08-usage.png)           |\n| **نقطة النهاية**      | ![Endpoint](docs/screenshots/09-endpoint.png)     |\n\n\u003c/details\u003e\n\n---\n\n## 🗺️خريطة الطريق\n\nيحتوي OmniRoute على **210+ ميزات مخطط لها** عبر مراحل تطوير متعددة. فيما يلي المجالات الرئيسية:\n\n| الفئة                       | الميزات المخططة | أبرز الأحداث                                                                                                                                  |\n| --------------------------- | --------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |\n| 🧠 **التوجيه والاستخبارات** | 25+             | التوجيه ذو زمن الاستجابة الأقل، والتوجيه القائم على العلامات، والاختبار المبدئي للحصة، واختيار حساب P2C                                       |\n| 🔒 **الأمان والامتثال**     | 20+             | تقوية SSRF، وإخفاء بيانات الاعتماد، والحد الأقصى للمعدل لكل نقطة نهاية، وتحديد نطاق مفتاح الإدارة                                             |\n| 📊 **قابلية الملاحظة**      | 15+             | تكامل OpenTelemetry ومراقبة الحصص في الوقت الفعلي وتتبع التكلفة لكل نموذج                                                                     |\n| 🔄 **تكامل الموفر**         | 20+             | تسجيل النموذج الديناميكي، فترات تهدئة الموفر، الدستور الغذائي متعدد الحسابات، تحليل حصة الطيار المساعد                                        |\n| ⚡ **الأداء**               | 15+             | طبقة ذاكرة التخزين المؤقت المزدوجة، ذاكرة التخزين المؤقت السريعة، ذاكرة التخزين المؤقت للاستجابة، استمرار البث، واجهة برمجة التطبيقات الدفعية |\n| 🌐 **النظام البيئي**        | 10+             | WebSocket API، إعادة تحميل التكوين السريع، مخزن التكوين الموزع، الوضع التجاري                                                                 |\n\n### 🔜قريبا\n\n- 🔗 **تكامل OpenCode** — دعم الموفر الأصلي لـ OpenCode AI IDE للترميز\n- 🔗 **تكامل TRAE** — الدعم الكامل لإطار تطوير TRAE AI\n- 📦 **Batch API** — معالجة الدفعات غير المتزامنة للطلبات المجمعة\n- 🎯 **التوجيه المعتمد على العلامات** — توجيه الطلبات بناءً على العلامات المخصصة والبيانات الوصفية\n- 💰 **إستراتيجية أقل تكلفة** — تحديد أرخص مزود متاح تلقائيًا\n\n\u003e 📝 مواصفات الميزات الكاملة متوفرة في [link](docs/new-features/) (217 مواصفات تفصيلية)\n\n---\n\n## 📧 الدعم\n\n\u003e 💬 **انضم إلى مجتمعنا!** [WhatsApp Group](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t) — احصل على المساعدة وشارك النصائح وابق على اطلاع.\n\n- **الموقع الإلكتروني**: [omniroute.online](https://omniroute.online)\n- **جيثب**: [github.com/diegosouzapw/OmniRoute](https://github.com/diegosouzapw/OmniRoute)\n- **المشاكل**: [github.com/diegosouzapw/OmniRoute/issues](https://github.com/diegosouzapw/OmniRoute/issues)\n- **واتساب**: [Community Group](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t)\n- **المشروع الأصلي**: [9router by decolua](https://github.com/decolua/9router)\n\n---\n\n## 👥 المساهمون\n\n[![Contributors](https://contrib.rocks/image?repo=diegosouzapw/OmniRoute\u0026max=100\u0026columns=20\u0026anon=1)](https://github.com/diegosouzapw/OmniRoute/graphs/contributors)\n\n### كيفية المساهمة\n\n1. شوكة المستودع\n2. قم بإنشاء فرع الميزات الخاص بك (`git checkout -b feature/amazing-feature`)\n3. تنفيذ التغييرات (`git commit -m 'Add amazing feature'`)\n4. ادفع إلى الفرع (`git push origin feature/amazing-feature`)\n5. افتح طلب السحب\n\nراجع [CONTRIBUTING.md](CONTRIBUTING.md) للحصول على إرشادات مفصلة.\n\n### إطلاق نسخة جديدة\n\n```bash\n# Create a release — npm publish happens automatically\ngh release create v1.0.6 --title \"v1.0.6\" --generate-notes\n```\n\n---\n\n## 📊 تاريخ النجوم\n\n\u003ca href=\"https://star-history.com/#diegosouzapw/OmniRoute\u0026Date\"\u003e\n \u003cpicture\u003e\n   \u003csource media=\"(prefers-color-scheme: dark)\" srcset=\"https://api.star-history.com/svg?repos=diegosouzapw/OmniRoute\u0026type=Date\u0026theme=dark\" /\u003e\n   \u003csource media=\"(prefers-color-scheme: light)\" srcset=\"https://api.star-history.com/svg?repos=diegosouzapw/OmniRoute\u0026type=Date\" /\u003e\n   \u003cimg alt=\"Star History Chart\" src=\"https://api.star-history.com/svg?repos=diegosouzapw/OmniRoute\u0026type=Date\" /\u003e\n \u003c/picture\u003e\n\u003c/a\u003e\n\n---\n\n## 🙏 شكر وتقدير\n\nشكر خاص لـ **[9router](https://github.com/decolua/9router)** بواسطة **[decolua](https://github.com/decolua)** — المشروع الأصلي الذي ألهم هذه الشوكة. يعتمد OmniRoute على هذا الأساس المذهل مع ميزات إضافية وواجهات برمجة التطبيقات متعددة الوسائط وإعادة كتابة TypeScript كاملة.\n\nشكر خاص لـ **[CLIProxyAPI](https://github.com/router-for-me/CLIProxyAPI)** — تطبيق Go الأصلي الذي ألهم منفذ JavaScript هذا.\n\n---\n\n## 📄 الترخيص\n\nترخيص MIT - راجع [LICENSE](LICENSE) للحصول على التفاصيل.\n\n---\n\n---\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdiegosouzapw%2FOmniRoute","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdiegosouzapw%2FOmniRoute","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdiegosouzapw%2FOmniRoute/lists"}