2075 lines
174 KiB
Markdown
2075 lines
174 KiB
Markdown
# 🚀 OmniRoute — เกตเวย์ AI ฟรี
|
||
|
||
### อย่าหยุดเขียนโค้ด การกำหนดเส้นทางอัจฉริยะไปยัง **โมเดล AI ฟรีและราคาประหยัด** พร้อมทางเลือกสำรองอัตโนมัติ
|
||
|
||
_พร็อกซี API สากลของคุณ — จุดสิ้นสุดเดียว ผู้ให้บริการมากกว่า 67 ราย เวลาหยุดทำงานเป็นศูนย์ ขณะนี้มีการจัดการตัวแทน **MCP และ A2A** แล้ว_
|
||
|
||
**การแชทเสร็จสิ้น • การฝัง • การสร้างภาพ • วิดีโอ • เพลง • เสียง • การจัดอันดับใหม่ • **การค้นหาเว็บ** • เซิร์ฟเวอร์ MCP • โปรโตคอล A2A • TypeScript 100%**
|
||
|
||
---
|
||
|
||
<div align="center">
|
||
|
||
[](https://www.npmjs.com/package/omniroute)
|
||
[](https://www.npmjs.com/package/omniroute)
|
||
[](https://hub.docker.com/r/diegosouzapw/omniroute)
|
||
[](https://hub.docker.com/r/diegosouzapw/omniroute)
|
||
[](https://github.com/diegosouzapw/OmniRoute/blob/main/LICENSE)
|
||
[](https://omniroute.online)
|
||
[](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t)
|
||
|
||
[🌐 Website](https://omniroute.online) • [🚀 Quick Start](#-quick-start) • [💡 Features](#-key-features) • [📖 Docs](#-documentation) • [💰 Pricing](#-pricing-at-a-glance) • [💬 WhatsApp](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t)
|
||
|
||
</div>
|
||
|
||
🌐 **มีจำหน่ายใน:** USA [English](README.md) | 🇧🇷 [Português (Brasil)](docs/i18n/pt-BR/README.md) | 🇪🇷 [Español](docs/i18n/es/README.md) | 🇫🇷 [Français](docs/i18n/fr/README.md) | 🇮🇹 [Italiano](docs/i18n/it/README.md) | 🇷🇺 [Русский](docs/i18n/ru/README.md) | 🇮🇷 [中文 (简体)](docs/i18n/zh-CN/README.md) | 🇩🇪 [Deutsch](docs/i18n/de/README.md) | 🇮รี [हिन्दी](docs/i18n/in/README.md) | 🇹🇭 [ไทย](docs/i18n/th/README.md) | เชอรี่ [Українська](docs/i18n/uk-UA/README.md) | 🇮🇱 [العربية](docs/i18n/ar/README.md) | [日本語](docs/i18n/ja/README.md) | 🇻🇷 [Tiếng Việt](docs/i18n/vi/README.md) | 🇧🇧 [Български](docs/i18n/bg/README.md) | 🇩🇪 [Dansk](docs/i18n/da/README.md) | 🇫🇮 [Suomi](docs/i18n/fi/README.md) | 🇮🇱 [עברית](docs/i18n/he/README.md) | 🇮🇹 [Magyar](docs/i18n/hu/README.md) | 🇮🇩 [Bahasa Indonesia](docs/i18n/id/README.md) | 🇰🇷 [한국어](docs/i18n/ko/README.md) | 🇲🇾 [Bahasa Melayu](docs/i18n/ms/README.md) | 🇮🇱 [Nederlands](docs/i18n/nl/README.md) | 🇴 [Norsk](docs/i18n/no/README.md) | 🇮🇹 [Português (Portugal)](docs/i18n/pt/README.md) | 🇷🇴 [Română](docs/i18n/ro/README.md) | 🇮🇱 [Polski](docs/i18n/pl/README.md) | 🇮🇹 [Slovenčina](docs/i18n/sk/README.md) | 🇲🇪 [Svenska](docs/i18n/sv/README.md) | 🇮🇹 [Filipino](docs/i18n/phi/README.md) | 🇮🇿 [Čeština](docs/i18n/cs/README.md)
|
||
|
||
---
|
||
|
||
## 🆕 มีอะไรใหม่ใน v3.0.0
|
||
|
||
> **กำลังอัปเกรดจากเวอร์ชัน 2.9.5?** — ดู [full CHANGELOG](CHANGELOG.md#300--2026-03-22-release-candidate--not-yet-merged-to-main) สำหรับการเปลี่ยนแปลงทั้งหมด
|
||
|
||
| พื้นที่ | เปลี่ยน |
|
||
| ----------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------- |
|
||
| 🔒 **ความปลอดภัยของ CodeQL** | แก้ไขการแจ้งเตือน CodeQL มากกว่า 10 รายการ: การทำซ้ำพหุนาม, การสุ่มที่ไม่ปลอดภัย, การแก้ไขการฉีดเชลล์ |
|
||
| ✅ **การตรวจสอบเส้นทาง** | ขณะนี้เส้นทาง API ทั้ง 176 เส้นทางได้รับการตรวจสอบความถูกต้องด้วย Zod schema + `validateBody()` — CI `check:route-validation:t06` pass |
|
||
| 🐛 **แท็ก omniModel รั่ว** | แท็ก `<omniModel>` ภายในจะไม่รั่วไหลไปยังไคลเอนต์อีกต่อไปในการตอบกลับการสตรีม SSE (#585) |
|
||
| 🔑 **API คีย์ที่ลงทะเบียน** | คีย์ API การจัดสรรอัตโนมัติผ่าน `POST /api/v1/registered-keys` พร้อมการบังคับใช้โควต้าต่อผู้ให้บริการ/บัญชี ความสามารถในการระบุตำแหน่ง พื้นที่เก็บข้อมูล SHA-256 และการรายงานปัญหา GitHub ที่เป็นตัวเลือก |
|
||
| 🎨 **ไอคอนผู้ให้บริการ** | โลโก้ผู้ให้บริการมากกว่า 130+ รายการผ่าน `@lobehub/icons` (SVG) พร้อม PNG → ห่วงโซ่ทางเลือกทั่วไป |
|
||
| 🔄 **โมเดลซิงค์อัตโนมัติ** | ตัวกำหนดเวลา 24 ชั่วโมงและสลับ UI แบบแมนนวลเพื่อซิงค์รายการโมเดลสำหรับผู้ให้บริการที่เข้ากันได้กับ OpenAI ในตัวและแบบกำหนดเอง |
|
||
| 🌐 **OpenCode Zen/Go** | ผู้ให้บริการใหม่สองรายจาก @kang-heewon ผ่าน PR #530: ระดับฟรี + ระดับการสมัครสมาชิกผ่าน `OpencodeExecutor` |
|
||
| 🐛 **ราศีเมถุน CLI OAuth** | ข้อผิดพลาดที่ดำเนินการได้เมื่อ `GEMINI_OAUTH_CLIENT_SECRET` หายไปใน Docker (เป็นข้อผิดพลาดของ Google ที่เป็นความลับ) |
|
||
| 🐛 **การกำหนดค่า OpenCode** | `saveOpenCodeConfig()` ตอนนี้เขียน TOML ไปยัง `XDG_CONFIG_HOME` | ได้อย่างถูกต้องแล้ว |
|
||
| 🐛 **ปักหมุดแทนที่โมเดล** | `body.model` ตั้งค่าอย่างถูกต้องเป็น `pinnedModel` บนการป้องกันแคชบริบท |
|
||
| 🐛 **ลูป Codex/Claude** | `tool_result` บล็อกตอนนี้แปลงเป็นข้อความเพื่อหยุดการวนซ้ำไม่สิ้นสุด |
|
||
| 🐛 **เปลี่ยนเส้นทางการเข้าสู่ระบบ** | การเข้าสู่ระบบจะไม่ค้างอีกต่อไปหลังจากข้ามการตั้งค่ารหัสผ่าน |
|
||
| 🐛 **เส้นทาง Windows** | เส้นทาง MSYS2/Git-Bash (`/c/...`) ทำให้เป็นมาตรฐาน `C:\...` โดยอัตโนมัติ |
|
||
|
||
---
|
||
|
||
## 🖼️ แดชบอร์ดหลัก
|
||
|
||
<div align="center">
|
||
<img src="./docs/screenshots/MainOmniRoute.png" alt="OmniRoute Dashboard" width="800"/>
|
||
</div>
|
||
|
||
---
|
||
|
||
## 📸 ดูตัวอย่างแดชบอร์ด
|
||
|
||
<details>
|
||
<summary><b>คลิกเพื่อดูภาพหน้าจอแดชบอร์ด</b>OMNI_TOKEN_460__
|
||
|
||
| หน้า | ภาพหน้าจอ |
|
||
| ------------------- | ------------------------------------------------- |
|
||
| **ผู้ให้บริการ** |  |
|
||
| **คอมโบ** |  |
|
||
| **การวิเคราะห์** |  |
|
||
| **สุขภาพ** |  |
|
||
| **นักแปล** |  |
|
||
| **การตั้งค่า** |  |
|
||
| **เครื่องมือ CLI** |  |
|
||
| **บันทึกการใช้งาน** |  |
|
||
| **ปลายทาง** |  |
|
||
|
||
</details>
|
||
|
||
---
|
||
|
||
### 🤖 ผู้ให้บริการ AI ฟรีสำหรับตัวแทนการเขียนโค้ดที่คุณชื่นชอบ
|
||
|
||
_เชื่อมต่อเครื่องมือ IDE หรือ CLI ที่ขับเคลื่อนด้วย AI ผ่าน OmniRoute — เกตเวย์ API ฟรีสำหรับการเข้ารหัสไม่จำกัด_
|
||
|
||
<table>
|
||
<tr>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/openclaw/openclaw">
|
||
<img src="./public/providers/openclaw.png" alt="OpenClaw" width="48"/><br/>
|
||
<b>OpenClaw</b>
|
||
</a><br/>
|
||
<sub>⭐ 205K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/HKUDS/nanobot">
|
||
<img src="./public/providers/nanobot.png" alt="NanoBot" width="48"/><br/>
|
||
<b>NanoBot</b>
|
||
</a><br/>
|
||
<sub>⭐ 20.9K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/sipeed/picoclaw">
|
||
<img src="./public/providers/picoclaw.jpg" alt="PicoClaw" width="48"/><br/>
|
||
<b>PicoClaw</b>
|
||
</a><br/>
|
||
<sub>⭐ 14.6K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/zeroclaw-labs/zeroclaw">
|
||
<img src="./public/providers/zeroclaw.png" alt="ZeroClaw" width="48"/><br/>
|
||
<b>ZeroClaw</b>
|
||
</a><br/>
|
||
<sub>⭐ 9.9K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/nearai/ironclaw">
|
||
<img src="./public/providers/ironclaw.png" alt="IronClaw" width="48"/><br/>
|
||
<b>IronClaw</b>
|
||
</a><br/>
|
||
<sub>⭐ 2.1K</sub>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/anomalyco/opencode">
|
||
<img src="./public/providers/opencode.svg" alt="OpenCode" width="48"/><br/>
|
||
<b>OpenCode</b>
|
||
</a><br/>
|
||
<sub>⭐ 106K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/openai/codex">
|
||
<img src="./public/providers/codex.png" alt="Codex CLI" width="48"/><br/>
|
||
<b>Codex CLI</b>
|
||
</a><br/>
|
||
<sub>⭐ 60.8K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/anthropics/claude-code">
|
||
<img src="./public/providers/claude.png" alt="Claude Code" width="48"/><br/>
|
||
<b>Claude Code</b>
|
||
</a><br/>
|
||
<sub>⭐ 67.3K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/google-gemini/gemini-cli">
|
||
<img src="./public/providers/gemini-cli.png" alt="Gemini CLI" width="48"/><br/>
|
||
<b>Gemini CLI</b>
|
||
</a><br/>
|
||
<sub>⭐ 94.7K</sub>
|
||
</td>
|
||
<td align="center" width="110">
|
||
<a href="https://github.com/Kilo-Org/kilocode">
|
||
<img src="./public/providers/kilocode.png" alt="Kilo Code" width="48"/><br/>
|
||
<b>Kilo Code</b>
|
||
</a><br/>
|
||
<sub>⭐ 15.5K</sub>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
<sub>📡 ตัวแทนทั้งหมดเชื่อมต่อผ่าน <code>http://localhost:20128/v1</code> หรือ <code>http://cloud.omniroute.online/v1</code> — การกำหนดค่าเดียว โมเดลไม่จำกัด และ โควต้า</sub>
|
||
|
||
---
|
||
|
||
## 🤔 ทำไมต้อง OmniRoute?
|
||
|
||
**หยุดเสียเงินและจำกัดขีดจำกัด:**
|
||
|
||
- <img src="https://img.shields.io/badge/✗-e74c3c?style=flat-square" height="16"/> โควต้าการสมัครจะหมดอายุโดยไม่ได้ใช้ทุกเดือน
|
||
- <img src="https://img.shields.io/badge/✗-e74c3c?style=flat-square" height="16"/> การจำกัดอัตราจะทำให้คุณไม่สามารถเขียนโค้ดกลางคันได้
|
||
- <img src="https://img.shields.io/badge/✗-e74c3c?style=flat-square" height="16"/> API ราคาแพง ($20-50/เดือนต่อผู้ให้บริการ)
|
||
- <img src="https://img.shields.io/badge/✗-e74c3c?style=flat-square" height="16"/> การสลับระหว่างผู้ให้บริการด้วยตนเอง
|
||
|
||
**OmniRoute แก้ปัญหานี้:**
|
||
|
||
- ✅ **เพิ่มการสมัครรับข้อมูลสูงสุด** - ติดตามโควต้า ใช้ทุกบิตก่อนรีเซ็ต
|
||
- ✅ **ทางเลือกสำรองอัตโนมัติ** - การสมัครสมาชิก → คีย์ API → ราคาถูก → ฟรี ไม่มีการหยุดทำงาน
|
||
- ✅ **หลายบัญชี** - หมุนเวียนระหว่างบัญชีต่อผู้ให้บริการ
|
||
- ✅ **สากล** - ใช้งานได้กับ Claude Code, Codex, Gemini CLI, Cursor, Cline, OpenClaw และเครื่องมือ CLI ใดๆ
|
||
|
||
---
|
||
|
||
## 📧 สนับสนุน
|
||
|
||
> 💌 **เข้าร่วมชุมชนของเรา!** [WhatsApp Group](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t) — รับความช่วยเหลือ แบ่งปันเคล็ดลับ และอัปเดตอยู่เสมอ
|
||
|
||
- **เว็บไซต์**: [omniroute.online](https://omniroute.online)
|
||
- **GitHub**: [github.com/diegosouzapw/OmniRoute](https://github.com/diegosouzapw/OmniRoute)
|
||
- **ปัญหา**: [github.com/diegosouzapw/OmniRoute/issues](https://github.com/diegosouzapw/OmniRoute/issues)
|
||
- **WhatsApp**: [Community Group](https://chat.whatsapp.com/JI7cDQ1GyaiDHhVBpLxf8b?mode=gi_t)
|
||
- **การมีส่วนร่วม**: ดู [CONTRIBUTING.md](CONTRIBUTING.md) เปิด PR หรือเลือก `good first issue`
|
||
- **โปรเจ็กต์ดั้งเดิม**: [9router by decolua](https://github.com/decolua/9router)
|
||
|
||
### 🐛 กำลังรายงานข้อผิดพลาดใช่ไหม
|
||
|
||
เมื่อเปิดปัญหา โปรดเรียกใช้คำสั่ง system-info และแนบไฟล์ที่สร้างขึ้น:
|
||
|
||
```bash
|
||
npm run system-info
|
||
```
|
||
|
||
สิ่งนี้จะสร้าง `system-info.txt` ด้วยเวอร์ชัน Node.js ของคุณ เวอร์ชัน OmniRoute รายละเอียดระบบปฏิบัติการ เครื่องมือ CLI ที่ติดตั้ง (iflow, gemini, claude, codex, antigravity, droid ฯลฯ) สถานะ Docker/PM2 และแพ็คเกจระบบ ทุกสิ่งที่เราต้องการในการทำซ้ำปัญหาของคุณอย่างรวดเร็ว แนบไฟล์โดยตรงกับปัญหา GitHub ของคุณ
|
||
|
||
---
|
||
|
||
## 🔄 มันทำงานอย่างไร
|
||
|
||
```
|
||
┌─────────────┐
|
||
│ Your CLI │ (Claude Code, Codex, Gemini CLI, OpenClaw, Cursor, Cline...)
|
||
│ Tool │
|
||
└──────┬──────┘
|
||
│ http://localhost:20128/v1
|
||
↓
|
||
┌─────────────────────────────────────────┐
|
||
│ OmniRoute (Smart Router) │
|
||
│ • Format translation (OpenAI ↔ Claude) │
|
||
│ • Quota tracking + Embeddings + Images │
|
||
│ • Auto token refresh │
|
||
└──────┬──────────────────────────────────┘
|
||
│
|
||
├─→ [Tier 1: SUBSCRIPTION] Claude Code, Codex, Gemini CLI
|
||
│ ↓ quota exhausted
|
||
├─→ [Tier 2: API KEY] DeepSeek, Groq, xAI, Mistral, NVIDIA NIM, etc.
|
||
│ ↓ budget limit
|
||
├─→ [Tier 3: CHEAP] GLM ($0.6/1M), MiniMax ($0.2/1M)
|
||
│ ↓ budget limit
|
||
└─→ [Tier 4: FREE] iFlow, Qwen, Kiro (unlimited)
|
||
|
||
Result: Never stop coding, minimal cost
|
||
```
|
||
|
||
---
|
||
|
||
## 🎯 สิ่งที่ OmniRoute แก้ปัญหาได้ — 30 คะแนนปัญหาและกรณีการใช้งานจริง
|
||
|
||
> **นักพัฒนาทุกคนที่ใช้เครื่องมือ AI ต้องเผชิญกับปัญหาเหล่านี้ทุกวัน** OmniRoute ถูกสร้างขึ้นเพื่อแก้ไขปัญหาทั้งหมด ตั้งแต่ค่าใช้จ่ายที่มากเกินไปไปจนถึงการบล็อกระดับภูมิภาค จากโฟลว์ OAuth ที่เสียหาย ไปจนถึงการทำงานของโปรโตคอลและความสามารถในการสังเกตระดับองค์กร
|
||
|
||
<details>
|
||
<summary><b>💸 1. "ฉันจ่ายค่าสมัครสมาชิกราคาแพงแต่ยังคงถูกขัดจังหวะด้วยขีดจำกัด"</b></summary>
|
||
|
||
นักพัฒนาจ่ายเงิน $20–200/เดือนสำหรับ Claude Pro, Codex Pro หรือ GitHub Copilot แม้จะจ่ายเงิน โควต้าก็มีเพดาน — การใช้งาน 5 ชม. ขีดจำกัดรายสัปดาห์ หรือขีดจำกัดอัตราต่อนาที เซสชันการเข้ารหัสกลาง ผู้ให้บริการหยุดการตอบสนอง และนักพัฒนาสูญเสียความลื่นไหลและประสิทธิภาพการทำงาน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **ทางเลือกสำรองอัจฉริยะ 4 ระดับ** — หากโควต้าการสมัครสมาชิกหมด จะเปลี่ยนเส้นทางไปยังคีย์ API → ราคาถูก → ฟรีโดยไม่มีการแทรกแซงด้วยตนเอง
|
||
- **การติดตามโควต้าแบบเรียลไทม์** — แสดงการใช้โทเค็นแบบเรียลไทม์พร้อมการนับถอยหลังการรีเซ็ต (5 ชม. รายวัน รายสัปดาห์)
|
||
- **การสนับสนุนหลายบัญชี** — หลายบัญชีต่อผู้ให้บริการพร้อมการหมุนเวียนอัตโนมัติ — เมื่อบัญชีหนึ่งหมด ให้สลับไปยังบัญชีถัดไป
|
||
- **คอมโบแบบกำหนดเอง** — ห่วงโซ่ทางเลือกที่ปรับแต่งได้พร้อมกลยุทธ์การปรับสมดุล 6 แบบ (เติมก่อน, ปัดเศษ, P2C, สุ่ม, ใช้น้อยที่สุด, ปรับต้นทุนให้เหมาะสม)
|
||
- **โควต้าธุรกิจ Codex** — การตรวจสอบโควต้าพื้นที่ทำงานของธุรกิจ/ทีมโดยตรงในแดชบอร์ด
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔌 2. "ฉันจำเป็นต้องใช้ผู้ให้บริการหลายราย แต่แต่ละรายมี API ที่แตกต่างกัน"</b></summary>
|
||
|
||
OpenAI ใช้รูปแบบหนึ่ง Claude (Anthropic) ใช้อีกรูปแบบหนึ่ง Gemini ยังใช้อีกรูปแบบหนึ่ง หากผู้พัฒนาต้องการทดสอบโมเดลจากผู้ให้บริการหลายรายหรือทางเลือกระหว่างผู้ให้บริการ พวกเขาจำเป็นต้องกำหนดค่า SDK ใหม่ เปลี่ยนตำแหน่งข้อมูล และจัดการกับรูปแบบที่เข้ากันไม่ได้ ผู้ให้บริการแบบกำหนดเอง (FriendLI, NIM) มีจุดสิ้นสุดโมเดลที่ไม่ได้มาตรฐาน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **Unified Endpoint** — `http://localhost:20128/v1` เดียวทำหน้าที่เป็นพร็อกซีสำหรับผู้ให้บริการมากกว่า 67 ราย
|
||
- **การแปลรูปแบบ** — อัตโนมัติและโปร่งใส: OpenAI ↔ Claude ↔ Gemini ↔ Responses API
|
||
- **การฆ่าเชื้อการตอบสนอง** — ตัดช่องที่ไม่ได้มาตรฐาน (`x_groq`, `usage_breakdown`, `service_tier`) ที่ทำลาย OpenAI SDK v1.83+
|
||
- **การปรับบทบาทให้เป็นมาตรฐาน** — แปลง `developer` → `system` สำหรับผู้ให้บริการที่ไม่ใช่ OpenAI `system` → `user` สำหรับ GLM/ERNIE
|
||
- **ลองแยกแท็ก** — แยกบล็อก `<think>` จากโมเดลอย่าง DeepSeek R1 ให้เป็น `reasoning_content` ที่ได้มาตรฐาน
|
||
- **เอาต์พุตที่มีโครงสร้างสำหรับราศีเมถุน** — `json_schema` → `responseMimeType`/`responseSchema` การแปลงอัตโนมัติ
|
||
- **`stream` มีค่าเริ่มต้นเป็น `false`** — สอดคล้องกับข้อกำหนด OpenAI หลีกเลี่ยง SSE ที่ไม่คาดคิดใน Python/Rust/Go SDK
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🌐 3. "ผู้ให้บริการ AI ของฉันบล็อกภูมิภาค/ประเทศของฉัน"</b></summary>
|
||
|
||
ผู้ให้บริการเช่น OpenAI/Codex บล็อกการเข้าถึงจากภูมิภาคทางภูมิศาสตร์บางแห่ง ผู้ใช้ได้รับข้อผิดพลาดเช่น `unsupported_country_region_territory` ในระหว่างการเชื่อมต่อ OAuth และ API สิ่งนี้น่าหงุดหงิดเป็นพิเศษสำหรับนักพัฒนาจากประเทศกำลังพัฒนา
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **การกำหนดค่าพร็อกซี 3 ระดับ** — พร็อกซีที่กำหนดค่าได้ 3 ระดับ: ทั่วโลก (การรับส่งข้อมูลทั้งหมด) ต่อผู้ให้บริการ (ผู้ให้บริการรายเดียวเท่านั้น) และต่อการเชื่อมต่อ/คีย์
|
||
- **ป้ายพร็อกซีที่ใช้รหัสสี** — ตัวบ่งชี้ภาพ: 🟢 พร็อกซีส่วนกลาง, 🟡 พร็อกซีผู้ให้บริการ, 🔵 พร็อกซีการเชื่อมต่อ แสดง IP เสมอ
|
||
- **การแลกเปลี่ยนโทเค็น OAuth ผ่านพร็อกซี** — โฟลว์ OAuth ยังผ่านพร็อกซีด้วย การแก้ไข `unsupported_country_region_territory`
|
||
- **การทดสอบการเชื่อมต่อผ่านพร็อกซี** — การทดสอบการเชื่อมต่อใช้พร็อกซีที่กำหนดค่าไว้ (ไม่มีการบายพาสโดยตรงอีกต่อไป)
|
||
- **รองรับ SOCKS5** — รองรับพร็อกซี SOCKS5 เต็มรูปแบบสำหรับการกำหนดเส้นทางขาออก
|
||
- **การปลอมแปลงลายนิ้วมือ TLS** — ลายนิ้วมือ TLS เหมือนเบราว์เซอร์ผ่าน `wreq-js` เพื่อเลี่ยงการตรวจจับบอท
|
||
- **🔏 การจับคู่ลายนิ้วมือ CLI** — เรียงลำดับส่วนหัวและฟิลด์เนื้อหาใหม่เพื่อให้ตรงกับลายเซ็นไบนารีของ CLI ดั้งเดิม ซึ่งช่วยลดความเสี่ยงในการติดธงสถานะบัญชีได้อย่างมาก IP พร็อกซีจะถูกเก็บรักษาไว้ — คุณจะได้รับทั้งการซ่อนตัว **และ** การปกปิด IP พร้อมกัน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🆓 4. "ฉันต้องการใช้ AI ในการเขียนโค้ด แต่ไม่มีเงิน"</b></summary>
|
||
|
||
ไม่ใช่ทุกคนที่สามารถจ่าย $20–200/เดือน สำหรับการสมัครสมาชิก AI นักศึกษา นักพัฒนาจากประเทศเกิดใหม่ ผู้ที่สมัครเล่น และฟรีแลนซ์ต้องการเข้าถึงโมเดลคุณภาพโดยไม่มีค่าใช้จ่าย
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **Free Tier Providers ในตัว** — รองรับเนทิฟสำหรับผู้ให้บริการฟรี 100%: iFlow (5 โมเดลไม่จำกัดผ่าน OAuth: kimi-k2-thinking, qwen3-coder-plus, deepseek-r1, minimax-m2, kimi-k2), Qwen (4 โมเดลไม่จำกัด: qwen3-coder-plus, qwen3-coder-flash, qwen3-coder-next, vision-model) Kiro (Claude + AWS Builder ID ฟรี), Gemini CLI (ฟรี 180,000 โทเค็น/เดือน)
|
||
- **Ollama Cloud** — โมเดล Ollama ที่โฮสต์บนคลาวด์ที่ `api.ollama.com` พร้อมระดับ "การใช้งานระดับเบา" ฟรี ใช้คำนำหน้า `ollamacloud/<model>`
|
||
- **คอมโบฟรีเท่านั้น** — Chain `gc/gemini-3-flash → if/kimi-k2-thinking → qw/qwen3-coder-plus` = $0/เดือน โดยไม่มีการหยุดทำงาน
|
||
- **NVIDIA NIM Free Access** — ~40 RPM dev-เข้าถึงฟรีตลอดกาลสำหรับโมเดลกว่า 70 รุ่นที่ build.nvidia.com (เปลี่ยนจากเครดิตเป็นการจำกัดอัตราที่แท้จริง)
|
||
- **กลยุทธ์การปรับต้นทุนให้เหมาะสม** — กลยุทธ์การกำหนดเส้นทางที่จะเลือกผู้ให้บริการที่ถูกที่สุดที่มีอยู่โดยอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔒 5. "ฉันต้องปกป้องเกตเวย์ AI ของฉันจากการเข้าถึงที่ไม่ได้รับอนุญาต"</b></summary>
|
||
|
||
เมื่อเปิดเผยเกตเวย์ AI ไปยังเครือข่าย (LAN, VPS, Docker) ใครก็ตามที่มีที่อยู่จะสามารถใช้โทเค็น/โควต้าของนักพัฒนาได้ หากไม่มีการป้องกัน API ก็เสี่ยงต่อการถูกนำไปใช้ในทางที่ผิด การแทรกทันที และการละเมิด
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **การจัดการคีย์ API** — การสร้าง การหมุนเวียน และการกำหนดขอบเขตต่อผู้ให้บริการด้วยเพจ `/dashboard/api-manager` เฉพาะ
|
||
- **การอนุญาตระดับโมเดล** — จำกัดคีย์ API ให้กับโมเดลเฉพาะ (`openai/*` รูปแบบไวด์การ์ด) พร้อมสลับอนุญาตทั้งหมด/จำกัด
|
||
- **การป้องกันปลายทาง API** — ต้องใช้รหัสสำหรับ `/v1/models` และบล็อกผู้ให้บริการบางรายจากรายการ
|
||
- **Auth Guard + การป้องกัน CSRF** — เส้นทางแดชบอร์ดทั้งหมดที่ได้รับการป้องกันด้วยมิดเดิลแวร์ `withAuth` + โทเค็น CSRF
|
||
- **ตัวจำกัดอัตรา** — การจำกัดอัตราต่อ IP ด้วยหน้าต่างที่กำหนดค่าได้
|
||
- **การกรอง IP** — รายการที่อนุญาต/รายการบล็อกสำหรับการควบคุมการเข้าถึง
|
||
- **Prompt Injection Guard** — การฆ่าเชื้อจากรูปแบบการแจ้งเตือนที่เป็นอันตราย
|
||
- **การเข้ารหัส AES-256-GCM** — ข้อมูลประจำตัวได้รับการเข้ารหัสเมื่อไม่ได้ใช้งาน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🛑 6. "ผู้ให้บริการของฉันหยุดทำงานและฉันสูญเสียขั้นตอนการเขียนโค้ด"</b></summary>
|
||
|
||
ผู้ให้บริการ AI อาจไม่เสถียร ส่งกลับข้อผิดพลาด 5xx หรือถึงขีดจำกัดอัตราชั่วคราว หากผู้พัฒนาขึ้นอยู่กับผู้ให้บริการรายเดียว ผู้ให้บริการเหล่านั้นจะถูกขัดจังหวะ หากไม่มีเซอร์กิตเบรกเกอร์ การลองซ้ำหลายครั้งอาจทำให้แอปพลิเคชันเสียหายได้
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **เซอร์กิตเบรกเกอร์ต่อรุ่น** — เปิด/ปิดอัตโนมัติด้วยเกณฑ์และคูลดาวน์ที่กำหนดค่าได้ (ปิด/เปิด/เปิดครึ่ง) กำหนดขอบเขตต่อรุ่นเพื่อหลีกเลี่ยงการบล็อกแบบเรียงซ้อน
|
||
- **Exponential Backoff** — ความล่าช้าในการลองใหม่อย่างต่อเนื่อง
|
||
- **Anti-Thundering Herd** — Mutex + การป้องกันเซมาฟอร์จากพายุที่ลองใหม่พร้อมกัน
|
||
- **Combo Fallback Chains** — หากผู้ให้บริการหลักล้มเหลว จะตกผ่านห่วงโซ่โดยอัตโนมัติโดยไม่มีการแทรกแซง
|
||
- **Combo Circuit Breaker** — ปิดการใช้งานผู้ให้บริการที่ล้มเหลวภายในคอมโบเชนโดยอัตโนมัติ
|
||
- **แดชบอร์ดสุขภาพ** — การตรวจสอบสถานะการออนไลน์ สถานะของเซอร์กิตเบรกเกอร์ การล็อก สถิติแคช เวลาแฝง p50/p95/p99
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>ดำเนินการ 7. "การกำหนดค่าเครื่องมือ AI แต่ละรายการนั้นน่าเบื่อและซ้ำซาก"</b></summary>
|
||
|
||
นักพัฒนาใช้ Cursor, Claude Code, Codex CLI, OpenClaw, Gemini CLI, Kilo Code... เครื่องมือแต่ละอันจำเป็นต้องมีการกำหนดค่าที่แตกต่างกัน (จุดสิ้นสุด API, คีย์, โมเดล) การกำหนดค่าใหม่เมื่อเปลี่ยนผู้ให้บริการหรือรุ่นเป็นการเสียเวลา
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **แดชบอร์ดเครื่องมือ CLI** — หน้าเฉพาะพร้อมการตั้งค่าเพียงคลิกเดียวสำหรับ Claude Code, Codex CLI, OpenClaw, Kilo Code, Antigravity, Cline
|
||
- **GitHub Copilot Config Generator** — สร้าง `chatLanguageModels.json` สำหรับ VS Code พร้อมการเลือกรุ่นจำนวนมาก
|
||
- **ตัวช่วยสร้างการเริ่มต้นใช้งาน** — คำแนะนำการตั้งค่า 4 ขั้นตอนสำหรับผู้ใช้ครั้งแรก
|
||
- **จุดสิ้นสุดเดียว ทุกรุ่น** — กำหนดค่า `http://localhost:20128/v1` หนึ่งครั้ง เข้าถึงผู้ให้บริการมากกว่า 67 ราย
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔑 8. "การจัดการโทเค็น OAuth จากผู้ให้บริการหลายรายนั้นช่างเลวร้าย"</b></summary>
|
||
|
||
Claude Code, Codex, Gemini CLI, Copilot — ทั้งหมดใช้ OAuth 2.0 โดยมีโทเค็นที่กำลังจะหมดอายุ นักพัฒนาจำเป็นต้องตรวจสอบสิทธิ์ซ้ำอย่างต่อเนื่อง จัดการกับ `client_secret is missing`, `redirect_uri_mismatch` และความล้มเหลวบนเซิร์ฟเวอร์ระยะไกล OAuth บน LAN/VPS เป็นปัญหาอย่างยิ่ง
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **รีเฟรชโทเค็นอัตโนมัติ** — โทเค็น OAuth รีเฟรชในพื้นหลังก่อนหมดอายุ
|
||
- **OAuth 2.0 (PKCE) ในตัว** — โฟลว์อัตโนมัติสำหรับ Claude Code, Codex, Gemini CLI, Copilot, Kiro, Qwen, iFlow
|
||
- **OAuth หลายบัญชี** — หลายบัญชีต่อผู้ให้บริการผ่านการดึงโทเค็น JWT/ID
|
||
- **OAuth LAN/Remote Fix** — การตรวจจับ IP ส่วนตัวสำหรับ `redirect_uri` + โหมด URL แบบกำหนดเองสำหรับเซิร์ฟเวอร์ระยะไกล
|
||
- **OAuth หลัง Nginx** — ใช้ `window.location.origin` สำหรับความเข้ากันได้ของพร็อกซีย้อนกลับ
|
||
- **คู่มือ OAuth ระยะไกล** — คำแนะนำทีละขั้นตอนสำหรับข้อมูลรับรอง Google Cloud บน VPS/Docker
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>📊 9. "ฉันไม่รู้ว่าตัวเองใช้เงินไปเท่าไหร่หรือที่ไหน"</b></summary>
|
||
|
||
นักพัฒนาซอฟต์แวร์ใช้ผู้ให้บริการแบบชำระเงินหลายราย แต่ไม่มีมุมมองการใช้จ่ายแบบรวมศูนย์ ผู้ให้บริการแต่ละรายมีแดชบอร์ดการเรียกเก็บเงินของตัวเอง แต่ไม่มีข้อมูลรวม ค่าใช้จ่ายที่ไม่คาดคิดอาจกองพะเนิน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **แดชบอร์ดการวิเคราะห์ต้นทุน** — การติดตามต้นทุนต่อโทเค็นและการจัดการงบประมาณต่อผู้ให้บริการ
|
||
- **ขีดจำกัดงบประมาณต่อระดับ** — เพดานการใช้จ่ายต่อระดับที่ทำให้เกิดทางเลือกสำรองอัตโนมัติ
|
||
- **การกำหนดค่าราคาต่อรุ่น** — ราคาที่กำหนดค่าได้ต่อรุ่น
|
||
- **สถิติการใช้งานต่อคีย์ API** — จำนวนคำขอและการประทับเวลาที่ใช้ล่าสุดต่อคีย์
|
||
- **แดชบอร์ดการวิเคราะห์** — การ์ดสถิติ แผนภูมิการใช้งานโมเดล ตารางผู้ให้บริการพร้อมอัตราความสำเร็จและเวลาแฝง
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🐛 10. "ฉันไม่สามารถวินิจฉัยข้อผิดพลาดและปัญหาในการเรียก AI ได้"</b></summary>
|
||
|
||
เมื่อการโทรล้มเหลว ผู้พัฒนาจะไม่ทราบว่าเป็นการจำกัดอัตรา โทเค็นหมดอายุ รูปแบบไม่ถูกต้อง หรือข้อผิดพลาดของผู้ให้บริการ บันทึกที่แยกส่วนในเทอร์มินัลต่างๆ หากไม่สามารถสังเกตได้ การดีบักถือเป็นการลองผิดลองถูก
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **Unified Logs Dashboard** — 4 แท็บ: บันทึกคำขอ, บันทึกพร็อกซี, บันทึกการตรวจสอบ, คอนโซล
|
||
- **โปรแกรมดูบันทึกคอนโซล** — โปรแกรมดูสไตล์เทอร์มินัลแบบเรียลไทม์พร้อมระดับรหัสสี เลื่อนอัตโนมัติ ค้นหา ตัวกรอง
|
||
- **SQLite Proxy Logs** — บันทึกถาวรที่รอดจากการรีสตาร์ทเซิร์ฟเวอร์
|
||
- **Translator Playground** — โหมดแก้ไขข้อบกพร่อง 4 โหมด: Playground (การแปลรูปแบบ), Chat Tester (ไป-กลับ), ม้านั่งทดสอบ (เป็นกลุ่ม), Live Monitor (เรียลไทม์)
|
||
- **ร้องขอการตรวจวัดทางไกล** — p50/p95/p99 latency + การติดตาม X-Request-Id
|
||
- **การบันทึกตามไฟล์พร้อมการหมุน** — ตัวสกัดกั้นคอนโซลจะบันทึกทุกอย่างไปยังบันทึก JSON ด้วยการหมุนตามขนาด
|
||
- **รายงานข้อมูลระบบ** — `npm run system-info` สร้าง `system-info.txt` ด้วยสภาพแวดล้อมแบบเต็มของคุณ (เวอร์ชันโหนด, เวอร์ชัน OmniRoute, OS, เครื่องมือ CLI, สถานะ Docker/PM2) แนบมาเมื่อรายงานปัญหาเพื่อการคัดแยกทันที
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🏗️ 11. "การปรับใช้และการบำรุงรักษาเกตเวย์นั้นซับซ้อน"</b></summary>
|
||
|
||
การติดตั้ง การกำหนดค่า และการบำรุงรักษาพร็อกซี AI ในสภาพแวดล้อมที่แตกต่างกัน (ภายในเครื่อง, VPS, Docker, คลาวด์) ต้องใช้แรงงานมาก ปัญหาเช่นเส้นทางฮาร์ดโค้ด `EACCES` บนไดเร็กทอรี ข้อขัดแย้งของพอร์ต และการสร้างข้ามแพลตฟอร์มเพิ่มแรงเสียดทาน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **การติดตั้งทั่วโลก npm** — `npm install -g omniroute && omniroute` — เสร็จแล้ว
|
||
- **นักเทียบท่าหลายแพลตฟอร์ม** — AMD64 + ARM64 ดั้งเดิม (Apple Silicon, AWS Graviton, Raspberry Pi)
|
||
- **โปรไฟล์นักเทียบท่าเขียน** — `base` (ไม่มีเครื่องมือ CLI) และ `cli` (พร้อม Claude Code, Codex, OpenClaw)
|
||
- **แอป Electron Desktop** — แอปเนทีฟสำหรับ Windows/macOS/Linux พร้อมถาดระบบ เริ่มอัตโนมัติ โหมดออฟไลน์
|
||
- **โหมดแยกพอร์ต** — API และแดชบอร์ดบนพอร์ตแยกกันสำหรับสถานการณ์ขั้นสูง (พร็อกซีย้อนกลับ เครือข่ายคอนเทนเนอร์)
|
||
- **Cloud Sync** — กำหนดค่าการซิงโครไนซ์ระหว่างอุปกรณ์ผ่าน Cloudflare Workers
|
||
- **การสำรองข้อมูล DB** — การสำรองข้อมูล กู้คืน ส่งออก และนำเข้าการตั้งค่าทั้งหมดโดยอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🌍 12. "อินเทอร์เฟซเป็นภาษาอังกฤษเท่านั้น และทีมของฉันไม่พูดภาษาอังกฤษ"</b></summary>
|
||
|
||
ทีมในประเทศที่ไม่ได้ใช้ภาษาอังกฤษ โดยเฉพาะในละตินอเมริกา เอเชีย และยุโรป ประสบปัญหากับอินเทอร์เฟซที่ใช้ภาษาอังกฤษเท่านั้น อุปสรรคทางภาษาลดการนำไปใช้และเพิ่มข้อผิดพลาดในการกำหนดค่า
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **แดชบอร์ด i18n — 30 ภาษา** — ทั้งหมด 500+ คีย์ที่แปล รวมถึงอารบิก บัลแกเรีย เดนมาร์ก เยอรมัน สเปน ฟินแลนด์ ฝรั่งเศส ฮิบรู ฮินดี ฮังการี อินโดนีเซีย อิตาลี ญี่ปุ่น เกาหลี มาเลย์ ดัตช์ นอร์เวย์ โปแลนด์ โปรตุเกส (PT/BR) โรมาเนีย รัสเซีย สโลวาเกีย สวีเดน ไทย ยูเครน เวียดนาม จีน ฟิลิปปินส์ อังกฤษ
|
||
- **รองรับ RTL** — รองรับภาษาอาหรับและฮีบรูจากขวาไปซ้าย
|
||
- **README หลายภาษา** — การแปลเอกสารฉบับสมบูรณ์ 30 รายการ
|
||
- **ตัวเลือกภาษา** — ไอคอนลูกโลกในส่วนหัวสำหรับการสลับแบบเรียลไทม์
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔄 13. "ฉันต้องการมากกว่าการแชท — ฉันต้องการการฝัง รูปภาพ เสียง"</b></summary>
|
||
|
||
AI ไม่ใช่แค่การแชทให้เสร็จสิ้นเท่านั้น นักพัฒนาจำเป็นต้องสร้างภาพ ถอดเสียง สร้างการฝังสำหรับ RAG จัดอันดับเอกสารใหม่ และกลั่นกรองเนื้อหา API แต่ละรายการมีจุดสิ้นสุดและรูปแบบที่แตกต่างกัน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **การฝัง** — `/v1/embeddings` พร้อมผู้ให้บริการ 6 รายและโมเดลมากกว่า 9 รายการ
|
||
- **การสร้างภาพ** — `/v1/images/generations` พร้อมผู้ให้บริการ 10 รายและโมเดลมากกว่า 20 รุ่น (OpenAI, xAI, Together, ดอกไม้ไฟ, Nebius, ไฮเปอร์โบลิก, NanoBanana, ต้านแรงโน้มถ่วง, SD WebUI, ComfyUI)
|
||
- **ข้อความเป็นวิดีโอ** — `/v1/videos/generations` — ComfyUI (AnimateDiff, SVD) และ SD WebUI
|
||
- **ข้อความเป็นเพลง** — `/v1/music/generations` — ComfyUI (เปิดเสียงที่เสถียร, MusicGen)
|
||
- **การถอดเสียง** — `/v1/audio/transcriptions` — Whisper + Nvidia NIM, HuggingFace, Qwen3
|
||
- **การอ่านออกเสียงข้อความ** — `/v1/audio/speech` — ElevenLabs, Nvidia NIM, HuggingFace, Coqui, Tortoise, Qwen3, **Inworld**, **Cartesia**, **PlayHT**, + ผู้ให้บริการที่มีอยู่
|
||
- **การกลั่นกรอง** — `/v1/moderations` — การตรวจสอบความปลอดภัยของเนื้อหา
|
||
- **การจัดอันดับใหม่** — `/v1/rerank` — การจัดอันดับความเกี่ยวข้องของเอกสารใหม่
|
||
- **Responses API** — รองรับ `/v1/responses` เต็มรูปแบบสำหรับ Codex
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🧪 14. "ฉันไม่มีวิธีทดสอบและเปรียบเทียบคุณภาพระหว่างรุ่นต่างๆ"</b></summary>
|
||
|
||
นักพัฒนาต้องการทราบว่าโมเดลใดดีที่สุดสำหรับกรณีการใช้งานของพวกเขา เช่น โค้ด การแปล การใช้เหตุผล แต่การเปรียบเทียบด้วยตนเองนั้นช้า ไม่มีเครื่องมือประเมินแบบรวมอยู่
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **การประเมิน LLM** — การทดสอบชุดทองพร้อมเคสที่โหลดไว้ล่วงหน้า 10 เคส ซึ่งครอบคลุมการทักทาย คณิตศาสตร์ ภูมิศาสตร์ การสร้างโค้ด การปฏิบัติตาม JSON การแปล การมาร์กดาวน์ การปฏิเสธด้านความปลอดภัย
|
||
- **4 กลยุทธ์การจับคู่** — `exact`, `contains`, `regex`, `custom` (ฟังก์ชัน JS)
|
||
- **ม้านั่งทดสอบสนามเด็กเล่นสำหรับนักแปล** — การทดสอบเป็นกลุ่มที่มีอินพุตหลายอินพุตและเอาต์พุตที่คาดหวัง การเปรียบเทียบข้ามผู้ให้บริการ
|
||
- **เครื่องมือทดสอบการแชท** — ไป-กลับเต็มรูปแบบพร้อมการเรนเดอร์การตอบสนองด้วยภาพ
|
||
- **Live Monitor** — สตรีมคำขอทั้งหมดที่ไหลผ่านพร็อกซีแบบเรียลไทม์
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>📈 15. "ฉันต้องปรับขนาดโดยไม่สูญเสียประสิทธิภาพ"</b></summary>
|
||
|
||
เมื่อปริมาณคำขอเพิ่มขึ้น หากไม่มีการแคช คำถามเดียวกันจะทำให้เกิดต้นทุนซ้ำซ้อน หากไม่มีการระบุตัวตน คำขอซ้ำจะสูญเปล่าในการประมวลผล ต้องเคารพขีดจำกัดอัตราต่อผู้ให้บริการ
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **Semantic Cache** — แคชสองชั้น (ลายเซ็น + ความหมาย) ช่วยลดต้นทุนและเวลาแฝง
|
||
- **คำขอ Idempotency** — หน้าต่างการขจัดข้อมูลซ้ำซ้อน 5 วินาทีสำหรับคำขอที่เหมือนกัน
|
||
- **การตรวจจับขีดจำกัดอัตรา** — RPM ต่อผู้ให้บริการ ช่องว่างขั้นต่ำ และการติดตามพร้อมกันสูงสุด
|
||
- **ขีดจำกัดอัตราที่แก้ไขได้** — ค่าเริ่มต้นที่กำหนดค่าได้ในการตั้งค่า → ความยืดหยุ่นด้วยความคงอยู่
|
||
- **แคชการตรวจสอบคีย์ API** — แคช 3 ระดับสำหรับประสิทธิภาพการผลิต
|
||
- **แดชบอร์ดสุขภาพพร้อมการวัดและส่งข้อมูลทางไกล** — เวลาแฝง p50/p95/p99 สถิติแคช เวลาทำงาน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🤖 16. "ฉันต้องการควบคุมพฤติกรรมของโมเดลทั่วโลก"</b></summary>
|
||
|
||
นักพัฒนาที่ต้องการคำตอบทั้งหมดในภาษาใดภาษาหนึ่ง มีน้ำเสียงเฉพาะ หรือต้องการจำกัดโทเค็นการให้เหตุผล การกำหนดค่านี้ในทุกเครื่องมือ/คำขอไม่สามารถทำได้
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- **การแจ้งพร้อมท์ของระบบ** — พร้อมท์ทั่วโลกนำไปใช้กับคำขอทั้งหมด
|
||
- **การตรวจสอบงบประมาณการคิด** — การควบคุมการจัดสรรโทเค็นการให้เหตุผลต่อคำขอ (การส่งผ่าน, อัตโนมัติ, กำหนดเอง, การปรับตัว)
|
||
- **6 กลยุทธ์การกำหนดเส้นทาง** — กลยุทธ์ระดับโลกที่กำหนดวิธีกระจายคำขอ
|
||
- **Wildcard Router** — รูปแบบ `provider/*` กำหนดเส้นทางแบบไดนามิกไปยังผู้ให้บริการใดๆ
|
||
- **Combo Enable/Disable Toggle** — สลับคอมโบได้โดยตรงจากแดชบอร์ด
|
||
- **สลับผู้ให้บริการ** — เปิด/ปิดการเชื่อมต่อทั้งหมดสำหรับผู้ให้บริการได้ด้วยคลิกเดียว
|
||
- **ผู้ให้บริการที่ถูกบล็อก** — ไม่รวมผู้ให้บริการเฉพาะจากรายการ `/v1/models`
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🧰 17. "ฉันต้องการเครื่องมือ MCP เนื่องจากความสามารถของผลิตภัณฑ์ระดับเฟิร์สคลาส"</b></summary>
|
||
|
||
เกตเวย์ AI จำนวนมากเปิดเผย MCP เป็นเพียงรายละเอียดการใช้งานที่ซ่อนอยู่เท่านั้น ทีมจำเป็นต้องมีชั้นการปฏิบัติงานที่มองเห็นได้และจัดการได้
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- MCP ปรากฏในการนำทางแดชบอร์ดและแท็บโปรโตคอลปลายทาง
|
||
- หน้าการจัดการ MCP เฉพาะพร้อมกระบวนการ เครื่องมือ ขอบเขต และการตรวจสอบ
|
||
- การเริ่มต้นอย่างรวดเร็วในตัวสำหรับ `omniroute --mcp` และการเริ่มต้นใช้งานไคลเอ็นต์
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🧠 18. "ฉันต้องการการประสาน A2A พร้อมเส้นทางงานซิงค์ + สตรีม"</b></summary>
|
||
|
||
เวิร์กโฟลว์ของตัวแทนต้องการทั้งการตอบกลับโดยตรงและการดำเนินการสตรีมที่ใช้เวลานานพร้อมการควบคุมวงจรชีวิต
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- จุดสิ้นสุด A2A JSON-RPC (`POST /a2a`) พร้อมด้วย `message/send` และ `message/stream`
|
||
- การสตรีม SSE พร้อมการเผยแพร่สถานะเทอร์มินัล
|
||
- API วงจรชีวิตของงานสำหรับ `tasks/get` และ `tasks/cancel`
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🛰️ 19. "ฉันต้องการความสมบูรณ์ของกระบวนการ MCP ที่แท้จริง ไม่ใช่สถานะที่เดาได้"</b></summary>
|
||
|
||
ทีมปฏิบัติการจำเป็นต้องทราบว่า MCP ยังคงอยู่จริงหรือไม่ ไม่ใช่แค่ว่า API สามารถเข้าถึงได้หรือไม่
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- ไฟล์ฮาร์ทบีทรันไทม์พร้อม PID, การประทับเวลา, การขนส่ง, จำนวนเครื่องมือ และโหมดขอบเขต
|
||
- API สถานะ MCP รวมการเต้นของหัวใจ + กิจกรรมล่าสุด
|
||
- การ์ดสถานะ UI สำหรับความสดใหม่ของกระบวนการ/สถานะการออนไลน์/การเต้นของหัวใจ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>📋 20. "ฉันต้องการการทำงานของเครื่องมือ MCP ที่ตรวจสอบได้"</b></summary>
|
||
|
||
เมื่อเครื่องมือเปลี่ยนแปลงการกำหนดค่าหรือทริกเกอร์การดำเนินการ ทีมจำเป็นต้องมีการตรวจสอบย้อนกลับทางนิติวิทยาศาสตร์
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- การบันทึกการตรวจสอบที่ได้รับการสนับสนุนจาก SQLite สำหรับการเรียกใช้เครื่องมือ MCP
|
||
- กรองตามเครื่องมือ ความสำเร็จ/ความล้มเหลว คีย์ API และการแบ่งหน้า
|
||
- ตารางการตรวจสอบแดชบอร์ด + จุดสิ้นสุดสถิติสำหรับระบบอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔐 21. "ฉันต้องการสิทธิ์ MCP ที่มีการกำหนดขอบเขตต่อการบูรณาการ"</b></summary>
|
||
|
||
ไคลเอนต์ที่แตกต่างกันควรมีสิทธิ์เข้าถึงหมวดหมู่เครื่องมือน้อยที่สุด
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- ขอบเขต MCP แบบละเอียด 9 แบบสำหรับการเข้าถึงเครื่องมือที่ควบคุม
|
||
- การบังคับใช้ขอบเขตและการมองเห็นใน UI การจัดการ MCP
|
||
- ท่าทางเริ่มต้นที่ปลอดภัยสำหรับเครื่องมือในการปฏิบัติงาน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>⚙️ 22. "ฉันต้องการการควบคุมการปฏิบัติงานโดยไม่ต้องปรับใช้ใหม่"</b></summary>
|
||
|
||
ทีมต้องการการเปลี่ยนแปลงรันไทม์อย่างรวดเร็วระหว่างเหตุการณ์หรือเหตุการณ์ต้นทุน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- สลับการเปิดใช้งานคอมโบโดยตรงจากแดชบอร์ด MCP
|
||
- ใช้โปรไฟล์ความยืดหยุ่นจากชุดนโยบายที่กำหนดไว้ล่วงหน้า
|
||
- รีเซ็ตสถานะเซอร์กิตเบรกเกอร์จากแผงการทำงานเดียวกัน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔄 23. "ฉันต้องการการมองเห็นและการยกเลิกวงจรการใช้งาน A2A แบบสด"</b></summary>
|
||
|
||
หากไม่มีการมองเห็นวงจรการใช้งาน เหตุการณ์ของงานจะยากต่อการคัดแยก
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- รายการงาน/การกรองตามสถานะ/ทักษะพร้อมการแบ่งหน้า
|
||
- เจาะลึกข้อมูลเมตาของงาน เหตุการณ์ และสิ่งประดิษฐ์
|
||
- จุดสิ้นสุดการยกเลิกงานและการดำเนินการ UI พร้อมการยืนยัน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🌊 24. "ฉันต้องการเมตริกสตรีมที่ใช้งานอยู่สำหรับโหลด A2A"</b></summary>
|
||
|
||
เวิร์กโฟลว์การสตรีมจำเป็นต้องมีข้อมูลเชิงลึกในการดำเนินงานเกี่ยวกับการทำงานพร้อมกันและการเชื่อมต่อแบบสด
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- ตัวนับสตรีมที่ใช้งานรวมอยู่ในสถานะ A2A
|
||
- การประทับเวลางานล่าสุดและการนับต่อรัฐ
|
||
- การ์ดแดชบอร์ด A2A สำหรับการตรวจสอบการปฏิบัติงานแบบเรียลไทม์
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🪪 25. "ฉันต้องการการค้นพบเอเจนต์มาตรฐานสำหรับลูกค้า"</b></summary>
|
||
|
||
ไคลเอนต์และผู้ควบคุมภายนอกต้องการเมตาดาต้าที่เครื่องอ่านได้เพื่อการเริ่มต้นใช้งาน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- บัตรตัวแทนเปิดเผยที่ `/.well-known/agent.json`
|
||
- ความสามารถและทักษะที่แสดงใน UI การจัดการ
|
||
- API สถานะ A2A รวมถึงข้อมูลเมตาการค้นพบสำหรับระบบอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🧭 26. "ฉันต้องการการค้นพบโปรโตคอลใน UX ผลิตภัณฑ์"</b></summary>
|
||
|
||
หากผู้ใช้ไม่พบพื้นผิวของโปรโตคอล การนำไปใช้และคุณภาพการสนับสนุนจะลดลง
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- หน้า **ปลายทาง** รวมพร้อมแท็บสำหรับตำแหน่งข้อมูลพร็อกซี, MCP, A2A และ API
|
||
- สลับสถานะบริการอินไลน์ (ออนไลน์/ออฟไลน์) สำหรับ MCP และ A2A
|
||
- ลิงก์จากภาพรวมไปยังแท็บการจัดการเฉพาะ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🧪 27. "ฉันต้องการการตรวจสอบโปรโตคอลแบบ end-to-end กับไคลเอนต์จริง"</b></summary>
|
||
|
||
การทดสอบจำลองไม่เพียงพอที่จะตรวจสอบความเข้ากันได้ของโปรโตคอลก่อนเผยแพร่
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- ชุด E2E ที่บูทแอปและใช้การขนส่งไคลเอนต์ MCP SDK จริง
|
||
- ไคลเอนต์ A2A ทดสอบการค้นหา ส่ง สตรีม รับ และยกเลิกโฟลว์
|
||
- ยืนยันการตรวจสอบข้ามกับการตรวจสอบ MCP และ API งาน A2A
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>📡 28. "ฉันต้องการความสามารถในการสังเกตแบบรวมศูนย์ในทุกอินเทอร์เฟซ"</b></summary>
|
||
|
||
การแยกความสามารถในการสังเกตตามโปรโตคอลทำให้เกิดจุดบอดและ MTTR ที่ยาวขึ้น
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- แดชบอร์ด/บันทึก/การวิเคราะห์แบบรวมในผลิตภัณฑ์เดียว
|
||
- สุขภาพ + การตรวจสอบ + ขอการตรวจวัดทางไกลผ่านเลเยอร์ OpenAI, MCP และ A2A
|
||
- API การดำเนินงานสำหรับสถานะและระบบอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>💼 29. "ฉันต้องการรันไทม์หนึ่งรายการสำหรับพร็อกซี + เครื่องมือ + การจัดการเอเจนต์"</b></summary>
|
||
|
||
การใช้บริการแยกกันจำนวนมากจะเพิ่มต้นทุนการดำเนินงานและโหมดความล้มเหลว
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- พร็อกซีที่เข้ากันได้กับ OpenAI, เซิร์ฟเวอร์ MCP และเซิร์ฟเวอร์ A2A ในสแต็กเดียว
|
||
- การรับรองความถูกต้องที่ใช้ร่วมกัน ความยืดหยุ่น การจัดเก็บข้อมูล และความสามารถในการสังเกต
|
||
- รูปแบบนโยบายที่สอดคล้องกันในทุกรูปแบบการโต้ตอบ
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🚀 30. "ฉันต้องจัดส่งเวิร์กโฟลว์เอเจนต์โดยไม่ต้องใช้การแผ่ขยายโค้ดกาว"</b></summary>
|
||
|
||
ทีมจะสูญเสียความเร็วเมื่อรวมบริการและสคริปต์เฉพาะกิจหลายรายการเข้าด้วยกัน
|
||
|
||
**OmniRoute แก้ปัญหาอย่างไร:**
|
||
|
||
- กลยุทธ์อุปกรณ์ปลายทางแบบครบวงจรสำหรับลูกค้าและตัวแทน
|
||
- UIs การจัดการโปรโตคอลในตัวและเส้นทางการตรวจสอบควัน
|
||
- รากฐานที่พร้อมสำหรับการผลิต (ความปลอดภัย การบันทึก ความยืดหยุ่น การสำรองข้อมูล)
|
||
|
||
</details>
|
||
|
||
### Playbook ตัวอย่าง (กรณีการใช้งานแบบรวม)
|
||
|
||
**Playbook A: เพิ่มการสมัครสมาชิกแบบชำระเงินให้สูงสุด + การสำรองข้อมูลราคาถูก**
|
||
|
||
```txt
|
||
Combo: "maximize-claude"
|
||
1. cc/claude-opus-4-6
|
||
2. glm/glm-4.7
|
||
3. if/kimi-k2-thinking
|
||
|
||
Monthly cost: $20 + small backup spend
|
||
Outcome: higher quality, near-zero interruption
|
||
```
|
||
|
||
**Playbook B: สแต็คการเขียนโค้ดแบบไม่มีค่าใช้จ่าย**
|
||
|
||
```txt
|
||
Combo: "free-forever"
|
||
1. gc/gemini-3-flash
|
||
2. if/kimi-k2-thinking
|
||
3. qw/qwen3-coder-plus
|
||
|
||
Monthly cost: $0
|
||
Outcome: stable free coding workflow
|
||
```
|
||
|
||
**Playbook C: ห่วงโซ่ทางเลือกที่เปิดตลอด 24 ชั่วโมงทุกวัน**
|
||
|
||
```txt
|
||
Combo: "always-on"
|
||
1. cc/claude-opus-4-6
|
||
2. cx/gpt-5.2-codex
|
||
3. glm/glm-4.7
|
||
4. minimax/MiniMax-M2.1
|
||
5. if/kimi-k2-thinking
|
||
|
||
Outcome: deep fallback depth for deadline-critical workloads
|
||
```
|
||
|
||
**Playbook D: ตัวแทนดำเนินการด้วย MCP + A2A**
|
||
|
||
```txt
|
||
1) Start MCP transport (`omniroute --mcp`) for tool-driven operations
|
||
2) Run A2A tasks via `message/send` and `message/stream`
|
||
3) Observe via /dashboard/endpoint (MCP and A2A tabs)
|
||
4) Toggle services via inline status controls
|
||
```
|
||
|
||
---
|
||
|
||
## 🆓 เริ่มฟรี — ต้นทุนการกำหนดค่าเป็นศูนย์
|
||
|
||
> ตั้งค่าการเข้ารหัส AI ในไม่กี่นาทีที่ **$0/เดือน** เชื่อมต่อบัญชีฟรีเหล่านี้และใช้คอมโบ **Free Stack** ในตัว
|
||
|
||
| ขั้นตอน | การกระทำ | ผู้ให้บริการปลดล็อคแล้ว |
|
||
| ------- | ----------------------------------------------- | ------------------------------------------------------------ |
|
||
| 1 | เชื่อมต่อ **Kiro** (AWS Builder ID OAuth) | Claude Sonnet 4.5, Haiku 4.5 — **ไม่จำกัด** |
|
||
| 2 | เชื่อมต่อ **iFlow** (Google OAuth) | kimi-k2-คิด, qwen3-coder-plus, deepseek-r1... — **ไม่จำกัด** |
|
||
| 3 | เชื่อมต่อ **Qwen** (รหัสอุปกรณ์) | qwen3-coder-plus, qwen3-coder-flash... — **ไม่จำกัด** |
|
||
| 4 | เชื่อมต่อ **Gemini CLI** (Google OAuth) | gemini-3-flash, gemini-2.5-pro — **ฟรี 180K/เดือน** |
|
||
| 5 | `/dashboard/combos` → **สแต็คฟรี ($0)** เทมเพลต | Round-robin ผู้ให้บริการฟรีทั้งหมดโดยอัตโนมัติ |
|
||
|
||
**ชี้ IDE/CLI ใดๆ ไปที่:** `http://localhost:20128/v1` · คีย์ API: `any-string` · เสร็จสิ้น
|
||
|
||
> **ความคุ้มครองเพิ่มเติมเพิ่มเติม (ฟรี):** คีย์ Groq API (ฟรี 30 RPM), NVIDIA NIM (ฟรี 40 RPM, รุ่น 70+), Cerebras (1M tok/วัน), คีย์ LongCat API (โทเค็น 50M/วัน!), Cloudflare Workers AI (10K Neurons/วัน, รุ่น 50+)
|
||
|
||
## ⚡ เริ่มต้นอย่างรวดเร็ว
|
||
|
||
### 1) ติดตั้งและรัน
|
||
|
||
```bash
|
||
npm install -g omniroute
|
||
omniroute
|
||
```
|
||
|
||
> **ผู้ใช้ pnpm:** รัน `pnpm approve-builds -g` หลังการติดตั้งเพื่อเปิดใช้งานสคริปต์เนทิฟบิลด์ที่ `better-sqlite3` และ `@swc/core` ต้องการ:
|
||
>
|
||
> ```bash
|
||
> pnpm install -g omniroute
|
||
> pnpm approve-builds -g # Select all packages → approve
|
||
> omniroute
|
||
> ```
|
||
|
||
แดชบอร์ดเปิดที่ `http://localhost:20128` และ URL ฐาน API คือ `http://localhost:20128/v1`
|
||
|
||
| คำสั่ง | คำอธิบาย |
|
||
| ----------------------- | ------------------------------------------------------------------ |
|
||
| `omniroute` | เริ่มต้นเซิร์ฟเวอร์ (`PORT=20128`, API และแดชบอร์ดบนพอร์ตเดียวกัน) |
|
||
| `omniroute --port 3000` | ตั้งค่าพอร์ต Canonical/API เป็น 3000 |
|
||
| `omniroute --mcp` | เริ่มเซิร์ฟเวอร์ MCP (การขนส่ง stdio) |
|
||
| `omniroute --no-open` | อย่าเปิดเบราว์เซอร์อัตโนมัติ |
|
||
| `omniroute --help` | แสดงความช่วยเหลือ |
|
||
|
||
โหมดแยกพอร์ตเสริม:
|
||
|
||
```bash
|
||
PORT=20128 DASHBOARD_PORT=20129 omniroute
|
||
# API: http://localhost:20128/v1
|
||
# Dashboard: http://localhost:20129
|
||
```
|
||
|
||
### 2) เชื่อมต่อผู้ให้บริการและสร้างคีย์ API ของคุณ
|
||
|
||
1. เปิดแดชบอร์ด → `Providers` และเชื่อมต่อผู้ให้บริการอย่างน้อยหนึ่งราย (คีย์ OAuth หรือ API)
|
||
2. เปิดแดชบอร์ด → `Endpoints` และสร้างคีย์ API
|
||
3. (ทางเลือก) เปิดแดชบอร์ด → `Combos` และตั้งค่าห่วงโซ่ทางเลือกของคุณ
|
||
|
||
### 3) ชี้เครื่องมือเขียนโค้ดของคุณไปที่ OmniRoute
|
||
|
||
```txt
|
||
Base URL: http://localhost:20128/v1
|
||
API Key: [copy from Endpoint page]
|
||
Model: if/kimi-k2-thinking (or any provider/model prefix)
|
||
```
|
||
|
||
ทำงานร่วมกับ Claude Code, Codex CLI, Gemini CLI, Cursor, Cline, OpenClaw, OpenCode และ SDK ที่เข้ากันได้กับ OpenAI
|
||
|
||
### 4) เปิดใช้งานและตรวจสอบโปรโตคอล (v2.0)
|
||
|
||
**MCP (สำหรับการดำเนินการที่ขับเคลื่อนด้วยเครื่องมือ):**
|
||
|
||
```bash
|
||
omniroute --mcp
|
||
```
|
||
|
||
จากนั้นเชื่อมต่อไคลเอนต์ MCP ของคุณผ่าน `stdio` และเครื่องมือทดสอบเช่น:
|
||
|
||
- `omniroute_get_health`
|
||
- `omniroute_list_combos`
|
||
|
||
**A2A (สำหรับเวิร์กโฟลว์ตัวแทนถึงตัวแทน):**
|
||
|
||
```bash
|
||
curl http://localhost:20128/.well-known/agent.json
|
||
```
|
||
|
||
```bash
|
||
curl -X POST http://localhost:20128/a2a \
|
||
-H 'content-type: application/json' \
|
||
-d '{"jsonrpc":"2.0","id":"quickstart","method":"message/send","params":{"skill":"quota-management","messages":[{"role":"user","content":"Give me a short quota summary."}]}}'
|
||
```
|
||
|
||
### 5) ตรวจสอบทุกอย่างตั้งแต่ต้นจนจบ (แนะนำ)
|
||
|
||
```bash
|
||
npm run test:protocols:e2e
|
||
```
|
||
|
||
ชุดนี้ตรวจสอบโฟลว์ MCP และไคลเอ็นต์ A2A จริงกับแอปที่รันอยู่
|
||
|
||
### ทางเลือก: เรียกใช้จากแหล่งที่มา
|
||
|
||
```bash
|
||
cp .env.example .env
|
||
npm install
|
||
PORT=20128 DASHBOARD_PORT=20129 NEXT_PUBLIC_BASE_URL=http://localhost:20129 npm run dev
|
||
```
|
||
|
||
---
|
||
|
||
## 🐳 ด็อคเกอร์
|
||
|
||
OmniRoute มีให้เป็นอิมเมจ Docker สาธารณะบน [Docker Hub](https://hub.docker.com/r/diegosouzapw/omniroute)
|
||
|
||
**วิ่งด่วน:**
|
||
|
||
```bash
|
||
docker run -d \
|
||
--name omniroute \
|
||
--restart unless-stopped \
|
||
-p 20128:20128 \
|
||
-v omniroute-data:/app/data \
|
||
diegosouzapw/omniroute:latest
|
||
```
|
||
|
||
**พร้อมไฟล์สภาพแวดล้อม:**
|
||
|
||
```bash
|
||
# Copy and edit .env first
|
||
cp .env.example .env
|
||
|
||
docker run -d \
|
||
--name omniroute \
|
||
--restart unless-stopped \
|
||
--env-file .env \
|
||
-p 20128:20128 \
|
||
-v omniroute-data:/app/data \
|
||
diegosouzapw/omniroute:latest
|
||
```
|
||
|
||
**การใช้นักเทียบท่าเขียน:**
|
||
|
||
```bash
|
||
# Base profile (no CLI tools)
|
||
docker compose --profile base up -d
|
||
|
||
# CLI profile (Claude Code, Codex, OpenClaw built-in)
|
||
docker compose --profile cli up -d
|
||
```
|
||
|
||
| รูปภาพ | แท็ก | ขนาด | คำอธิบาย |
|
||
| ------------------------ | -------- | ------ | ---------------- |
|
||
| `diegosouzapw/omniroute` | `latest` | ~250MB | รุ่นเสถียรล่าสุด |
|
||
| `diegosouzapw/omniroute` | `1.0.3` | ~250MB | เวอร์ชันปัจจุบัน |
|
||
|
||
---
|
||
|
||
## 🖥️ แอปเดสก์ท็อป — ออฟไลน์และเปิดตลอดเวลา
|
||
|
||
> 🆕 **ใหม่!** OmniRoute พร้อมใช้งานแล้วในรูปแบบ **แอปพลิเคชันเดสก์ท็อปดั้งเดิม** สำหรับ Windows, macOS และ Linux
|
||
|
||
เรียกใช้ OmniRoute เป็นแอปเดสก์ท็อปแบบสแตนด์อโลน ไม่ต้องใช้เทอร์มินัล ไม่ต้องใช้เบราว์เซอร์ ไม่ต้องใช้อินเทอร์เน็ตสำหรับรุ่นท้องถิ่น แอพที่ใช้อิเล็กตรอนประกอบด้วย:
|
||
|
||
- 🖥️ **หน้าต่างดั้งเดิม** — หน้าต่างแอปเฉพาะพร้อมการรวมถาดระบบ
|
||
- 🔄 **เริ่มอัตโนมัติ** — เปิด OmniRoute เมื่อเข้าสู่ระบบ
|
||
- 🔔 **การแจ้งเตือนแบบเนทีฟ** — รับการแจ้งเตือนเกี่ยวกับโควต้าหมดหรือปัญหาของผู้ให้บริการ
|
||
- ⚡ **ติดตั้งเพียงคลิกเดียว** — NSIS (Windows), DMG (macOS), AppImage (Linux)
|
||
- 🌐 **โหมดออฟไลน์** — ทำงานแบบออฟไลน์โดยสมบูรณ์กับเซิร์ฟเวอร์รวม
|
||
|
||
### เริ่มต้นอย่างรวดเร็ว
|
||
|
||
```bash
|
||
# Development mode
|
||
npm run electron:dev
|
||
|
||
# Build for your platform
|
||
npm run electron:build # Current platform
|
||
npm run electron:build:win # Windows (.exe)
|
||
npm run electron:build:mac # macOS (.dmg) — x64 & arm64
|
||
npm run electron:build:linux # Linux (.AppImage)
|
||
```
|
||
|
||
### ถาดระบบ
|
||
|
||
เมื่อย่อเล็กสุด OmniRoute จะอยู่ในถาดระบบของคุณด้วยการดำเนินการด่วน:
|
||
|
||
- เปิดแดชบอร์ด
|
||
- เปลี่ยนพอร์ตเซิร์ฟเวอร์
|
||
- ออกจากแอปพลิเคชัน
|
||
|
||
📖 เอกสารฉบับเต็ม: [**OMNI_TOKEN_153**](electron/README.md)
|
||
|
||
---
|
||
|
||
## 💰 ราคาโดยสรุป
|
||
|
||
| ชั้น | ผู้ให้บริการ | ราคา | รีเซ็ตโควต้า | ดีที่สุดสำหรับ |
|
||
| ------------------ | --------------------------------- | ------------------------------- | ------------------------------- | --------------------------------------- |
|
||
| **💳 สมัครสมาชิก** | รหัสคลอดด์ (Pro) | $20/เดือน | 5 ชม. + รายสัปดาห์ | สมัครสมาชิกแล้ว |
|
||
| | Codex (พลัส/โปร) | $20-200/เดือน | 5 ชม. + รายสัปดาห์ | ผู้ใช้ OpenAI |
|
||
| | ราศีเมถุน CLI | **ฟรี** | 180K/เดือน + 1K/วัน | ทุกคน! |
|
||
| | นักบิน GitHub | $10-19/เดือน | รายเดือน | ผู้ใช้ GitHub |
|
||
| **🔑 คีย์ API** | NVIDIA NIM | **ฟรี** (พัฒนาตลอดไป) | ~40 รอบต่อนาที | รุ่นเปิดมากกว่า 70 รุ่น |
|
||
| | สมอง | **ฟรี** (1M ต๊อก/วัน) | 60,000 ทีพีเอ็ม / 30 รอบต่อนาที | เร็วที่สุดในโลก |
|
||
| | กรอค | **ฟรี** (30 รอบต่อนาที) | 14.4K RPD | ลามะ/เจมม่าที่เร็วเป็นพิเศษ |
|
||
| | DeepSeek V3.2 | $0.27/$1.10 ต่อ 1M | ไม่มี | เหตุผลด้านราคา/คุณภาพที่ดีที่สุด |
|
||
| | xAI Grok-4 เร็ว | **$0.20/$0.50 ต่อ 1M** 🆕 | ไม่มี | เร็วที่สุด + การเรียกเครื่องมือ, ต่ำมาก |
|
||
| | xAI Grok-4 (มาตรฐาน) | $0.20/$1.50 ต่อ 1M 🆕 | ไม่มี | การใช้เหตุผลเป็นเรือธงจาก xAI |
|
||
| | มิสทรัล | ทดลองใช้ฟรี + จ่ายเงิน | อัตราจำกัด | AI ยุโรป |
|
||
| | OpenRouter | จ่ายตามการใช้งาน | ไม่มี | มีโมเดลมากกว่า 100 แบบ |
|
||
| **💰 ราคาถูก** | GLM-5 (ผ่าน Z.AI) 🆕 | $0.5/1M | ทุกวัน 10.00 น. | เอาต์พุต 128K เรือธงใหม่ล่าสุด |
|
||
| | GLM-4.7 | $0.6/1M | ทุกวัน 10.00 น. | สำรองงบประมาณ |
|
||
| | MiniMax M2.5 🆕 | $0.3/1M อินพุต | กลิ้ง 5 ชั่วโมง | การใช้เหตุผล + งานตัวแทน |
|
||
| | MiniMax M2.1 | $0.2/1M | กลิ้ง 5 ชั่วโมง | ตัวเลือกที่ถูกที่สุด |
|
||
| | Kimi K2.5 (Moonshot API) 🆕 | จ่ายตามการใช้งาน | ไม่มี | การเข้าถึง Moonshot API โดยตรง |
|
||
| | คิมิ K2 | $9/เดือน คงที่ | 10M โทเค็น/เดือน | ต้นทุนที่คาดการณ์ได้ |
|
||
| **🆓 ฟรี** | ไอโฟลว์ | **$0** | ไม่จำกัด | 5 รุ่นไม่จำกัด |
|
||
| | ควีน | **$0** | ไม่จำกัด | 4 รุ่นไม่จำกัด |
|
||
| | คิโระ | **$0** | ไม่จำกัด | Claude Sonnet/ไฮกุ (AWS Builder) |
|
||
| | LongCat Flash-Lite 🆕 | **$0** (50M ต็อก/วัน 🔥) | 1 รอบต่อนาที | โควต้าฟรีที่ใหญ่ที่สุดในโลก |
|
||
| | AI การผสมเกสร 🆕 | **$0** (ไม่ต้องใช้กุญแจ) | 1 คำขอ/15 วินาที | GPT-5, Claude, DeepSeek, ลามะ 4 |
|
||
| | AI ของผู้ปฏิบัติงาน Cloudflare 🆕 | **$0** (10,000 เซลล์ประสาท/วัน) | ~150 ครั้ง/วัน | โมเดลมากกว่า 50 แบบ ขอบระดับโลก |
|
||
| | สเกลเวย์ AI 🆕 | **$0** (รวมโทเค็น 1M) | อัตราจำกัด | EU/GDPR, Qwen3 235B, ลามะ 70B |
|
||
|
||
> 🆕 **เพิ่มโมเดลใหม่ (มี.ค. 2026):** Grok-4 Fast family ที่ $0.20/$0.50/M (เปรียบเทียบที่ 1143ms — เร็วกว่า Gemini 2.5 Flash 30%), GLM-5 ผ่าน Z.AI พร้อมเอาต์พุต 128K, การใช้เหตุผล MiniMax M2.5, ราคาที่อัปเดต DeepSeek V3.2, Kimi K2.5 ผ่าน Moonshot direct API
|
||
|
||
**💡 $0 Combo Stack — การตั้งค่าที่สมบูรณ์ฟรี:**
|
||
|
||
```
|
||
# 🆓 Ultimate Free Stack 2026 — 11 Providers, $0 Forever
|
||
Kiro (kr/) → Claude Sonnet/Haiku UNLIMITED
|
||
iFlow (if/) → kimi-k2-thinking, qwen3-coder-plus, deepseek-r1 UNLIMITED
|
||
LongCat Lite (lc/) → LongCat-Flash-Lite — 50M tokens/day 🔥
|
||
Pollinations (pol/) → GPT-5, Claude, DeepSeek, Llama 4 — no key needed
|
||
Qwen (qw/) → qwen3-coder-plus, qwen3-coder-flash, qwen3-coder-next UNLIMITED
|
||
Gemini (gemini/) → Gemini 2.5 Flash — 1,500 req/day free API key
|
||
Cloudflare AI (cf/) → Llama 70B, Gemma 3, Mistral — 10K Neurons/day
|
||
Scaleway (scw/) → Qwen3 235B, Llama 70B — 1M free tokens (EU)
|
||
Groq (groq/) → Llama/Gemma ultra-fast — 14.4K req/day
|
||
NVIDIA NIM (nvidia/) → 70+ open models — 40 RPM forever
|
||
Cerebras (cerebras/) → Llama/Qwen world-fastest — 1M tok/day
|
||
```
|
||
|
||
**ไม่มีค่าใช้จ่าย ไม่หยุดเขียนโค้ด** กำหนดค่านี้เป็น OmniRoute เดียวและทางเลือกทั้งหมดจะเกิดขึ้นโดยอัตโนมัติ ไม่มีการสลับด้วยตนเองเลย
|
||
|
||
---
|
||
|
||
---
|
||
|
||
## 🆓 โมเดลฟรี — สิ่งที่คุณได้รับจริง
|
||
|
||
> ทุกรุ่นด้านล่าง **ฟรี 100% โดยไม่ต้องใช้บัตรเครดิต** OmniRoute จะกำหนดเส้นทางอัตโนมัติระหว่างกันเมื่อโควต้าหนึ่งหมด — รวมเข้าด้วยกันเพื่อคอมโบ $0 ที่ไม่อาจแตกหักได้
|
||
|
||
### 🔵 โมเดล CLAUDE (ผ่าน Kiro — AWS Builder ID)
|
||
|
||
| รุ่น | คำนำหน้า | ขีดจำกัด | ขีดจำกัดอัตรา |
|
||
| ------------------- | -------- | ------------ | ------------------------- |
|
||
| `claude-sonnet-4.5` | `kr/` | **ไม่จำกัด** | ไม่มีรายงานสูงสุดรายวัน |
|
||
| `claude-haiku-4.5` | `kr/` | **ไม่จำกัด** | ไม่มีรายงานสูงสุดรายวัน |
|
||
| `claude-opus-4.6` | `kr/` | **ไม่จำกัด** | บทประพันธ์ล่าสุดผ่าน Kiro |
|
||
|
||
### 🟢 IFLOW MODELS (OAuth ฟรี — ไม่มีบัตรเครดิต)
|
||
|
||
| รุ่น | คำนำหน้า | ขีดจำกัด | ขีดจำกัดอัตรา |
|
||
| ------------------ | -------- | ------------ | --------------- |
|
||
| `kimi-k2-thinking` | `if/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `qwen3-coder-plus` | `if/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `deepseek-r1` | `if/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `minimax-m2.1` | `if/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `kimi-k2` | `if/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
|
||
### 🟡 รุ่น QWEN (การตรวจสอบรหัสอุปกรณ์)
|
||
|
||
| รุ่น | คำนำหน้า | ขีดจำกัด | ขีดจำกัดอัตรา |
|
||
| ------------------- | -------- | ------------ | ------------------------- |
|
||
| `qwen3-coder-plus` | `qw/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `qwen3-coder-flash` | `qw/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `qwen3-coder-next` | `qw/` | **ไม่จำกัด** | ไม่มีรายงานหมวก |
|
||
| `vision-model` | `qw/` | **ไม่จำกัด** | ต่อเนื่องหลายรูปแบบ (ภาพ) |
|
||
|
||
### 🟣 GEMINI CLI (Google OAuth)
|
||
|
||
| รุ่น | คำนำหน้า | ขีดจำกัด | ขีดจำกัดอัตรา |
|
||
| ------------------------ | -------- | --------------------------- | -------------- |
|
||
| `gemini-3-flash-preview` | `gc/` | **180K tok/เดือน** + 1K/วัน | รีเซ็ตรายเดือน |
|
||
| `gemini-2.5-pro` | `gc/` | 180K/เดือน (พูลรวม) | คุณภาพสูง |
|
||
|
||
### ⚫ NVIDIA NIM (คีย์ API ฟรี — build.nvidia.com)
|
||
|
||
| ชั้น | ขีดจำกัดรายวัน | ขีดจำกัดอัตรา | หมายเหตุ |
|
||
| ----------- | ---------------- | ------------------ | --------------------------------------------------------------------- |
|
||
| ฟรี (พัฒนา) | ไม่มีฝาปิดโทเค็น | **~40 รอบต่อนาที** | มากกว่า 70 รุ่น; การเปลี่ยนไปใช้ขีดจำกัดอัตราเดียวในช่วงกลางปี 2025 |
|
||
|
||
รุ่นฟรียอดนิยม: `moonshotai/kimi-k2.5` (Kimi K2.5), `z-ai/glm4.7` (GLM 4.7), `deepseek-ai/deepseek-v3.2` (DeepSeek V3.2), `nvidia/llama-3.3-70b-instruct`, `deepseek/deepseek-r1`
|
||
|
||
### ⚪ CEREBRAS (คีย์ API ฟรี — inference.cerebras.ai)
|
||
|
||
| ชั้น | ขีดจำกัดรายวัน | ขีดจำกัดอัตรา | หมายเหตุ |
|
||
| ---- | ----------------- | ------------------------------- | --------------------------------------------- |
|
||
| ฟรี | **1M โทเค็น/วัน** | 60,000 ทีพีเอ็ม / 30 รอบต่อนาที | การอนุมาน LLM ที่เร็วที่สุดในโลก รีเซ็ตทุกวัน |
|
||
|
||
ใช้งานได้ฟรี: `llama-3.3-70b`, `llama-3.1-8b`, `deepseek-r1-distill-llama-70b`
|
||
|
||
### 🔴 GROQ (คีย์ API ฟรี — console.groq.com)
|
||
|
||
| ชั้น | ขีดจำกัดรายวัน | ขีดจำกัดอัตรา | หมายเหตุ |
|
||
| ---- | -------------- | -------------- | ---------------------------------------- |
|
||
| ฟรี | **14.4K RPD** | 30 RPM ต่อรุ่น | ไม่มีบัตรเครดิต 429 ตามวงเงิน ไม่คิดเงิน |
|
||
|
||
ใช้งานได้ฟรี: `llama-3.3-70b-versatile`, `gemma2-9b-it`, `mixtral-8x7b`, `whisper-large-v3`
|
||
|
||
### 🔴 LONGCAT AI (คีย์ API ฟรี — longcat.chat) 🆕
|
||
|
||
| รุ่น | คำนำหน้า | โควต้าฟรีรายวัน | หมายเหตุ |
|
||
| ----------------------------- | -------- | ----------------- | ------------------------------------ |
|
||
| `LongCat-Flash-Lite` | `lc/` | **โทเค็น 50M** 💥 | โควต้าฟรีที่ใหญ่ที่สุดเท่าที่เคยมีมา |
|
||
| `LongCat-Flash-Chat` | `lc/` | โทเค็น 500K | แชทหลายรอบ |
|
||
| `LongCat-Flash-Thinking` | `lc/` | โทเค็น 500K | การใช้เหตุผล / CoT |
|
||
| `LongCat-Flash-Thinking-2601` | `lc/` | โทเค็น 500K | เวอร์ชันม.ค. 2569 |
|
||
| `LongCat-Flash-Omni-2603` | `lc/` | โทเค็น 500K | ต่อเนื่องหลายรูปแบบ |
|
||
|
||
> ฟรี 100% ขณะอยู่ในช่วงเบต้าสาธารณะ ลงทะเบียนที่ [longcat.chat](https://longcat.chat) ด้วยอีเมลหรือโทรศัพท์ รีเซ็ตทุกวัน 00:00 UTC
|
||
|
||
### 🟢 POLLINATIONS AI (ไม่ต้องใช้คีย์ API) 🆕
|
||
|
||
| รุ่น | คำนำหน้า | ขีดจำกัดอัตรา | ผู้ให้บริการเบื้องหลัง |
|
||
| ---------- | -------- | ---------------- | ---------------------- |
|
||
| `openai` | `pol/` | 1 คำขอ/15 วินาที | GPT-5 |
|
||
| `claude` | `pol/` | 1 คำขอ/15 วินาที | มานุษยวิทยาคลอด |
|
||
| `gemini` | `pol/` | 1 คำขอ/15 วินาที | Google ราศีเมถุน |
|
||
| `deepseek` | `pol/` | 1 คำขอ/15 วินาที | DeepSeek V3 |
|
||
| `llama` | `pol/` | 1 คำขอ/15 วินาที | Meta Llama 4 ลูกเสือ |
|
||
| `mistral` | `pol/` | 1 คำขอ/15 วินาที | มิสทรัล AI |
|
||
|
||
> ✨ **แรงเสียดทานเป็นศูนย์:** ไม่ต้องสมัคร ไม่มีคีย์ API เพิ่มผู้ให้บริการ Pollinations ด้วยฟิลด์คีย์ว่างและใช้งานได้ทันที
|
||
|
||
### 🟠 AI คนงานบนคลาวด์ (คีย์ API ฟรี — cloudflare.com) 🆕
|
||
|
||
| ชั้น | เซลล์ประสาทรายวัน | การใช้งานที่เทียบเท่า | หมายเหตุ |
|
||
| ---- | ----------------- | --------------------------------------- | --------------- |
|
||
| ฟรี | **10,000** | ~150 LLM resp / เสียง 500s / การฝัง 15K | ขอบโลก รุ่น 50+ |
|
||
|
||
รุ่นฟรียอดนิยม: `@cf/meta/llama-3.3-70b-instruct`, `@cf/google/gemma-3-12b-it`, `@cf/openai/whisper-large-v3-turbo` (เสียงฟรี!), `@cf/qwen/qwen2.5-coder-15b-instruct`
|
||
|
||
> ต้องใช้โทเค็น API + รหัสบัญชีจาก [dash.cloudflare.com](https://dash.cloudflare.com) รหัสบัญชีร้านค้าในการตั้งค่าผู้ให้บริการ
|
||
|
||
### 🟣 SCALEWAY AI (โทเค็นฟรี 1 ล้านโทเค็น — scaleway.com) 🆕
|
||
|
||
| ชั้น | โควต้าฟรี | ที่ตั้ง | หมายเหตุ |
|
||
| ---- | ----------------- | ------------------- | ------------------------------- |
|
||
| ฟรี | **โทเค็น 1 ล้าน** | 🇫🇷 ปารีส สหภาพยุโรป | ไม่ต้องใช้บัตรเครดิตภายในวงเงิน |
|
||
|
||
มีให้บริการฟรี: `qwen3-235b-a22b-instruct-2507` (Qwen3 235B!), `llama-3.1-70b-instruct`, `mistral-small-3.2-24b-instruct-2506`, `deepseek-v3-0324`
|
||
|
||
> สอดคล้องกับสหภาพยุโรป/GDPR รับคีย์ API ที่ [console.scaleway.com](https://console.scaleway.com)
|
||
|
||
> **💡 สุดยอดสแต็คฟรี (ผู้ให้บริการ 11 ราย, $0 ตลอดไป):**
|
||
>
|
||
> ```
|
||
> Kiro (kr/) → Claude Sonnet/Haiku UNLIMITED
|
||
> iFlow (if/) → kimi-k2-thinking, qwen3-coder-plus, deepseek-r1 UNLIMITED
|
||
> LongCat Lite (lc/) → LongCat-Flash-Lite — 50M tokens/day 🔥
|
||
> Pollinations (pol/) → GPT-5, Claude, DeepSeek, Llama 4 — no key needed
|
||
> Qwen (qw/) → qwen3-coder models UNLIMITED
|
||
> Gemini (gemini/) → Gemini 2.5 Flash — 1,500 req/day free
|
||
> Cloudflare AI (cf/) → 50+ models — 10K Neurons/day
|
||
> Scaleway (scw/) → Qwen3 235B, Llama 70B — 1M free tokens (EU)
|
||
> Groq (groq/) → Llama/Gemma — 14.4K req/day ultra-fast
|
||
> NVIDIA NIM (nvidia/) → 70+ open models — 40 RPM forever
|
||
> Cerebras (cerebras/) → Llama/Qwen world-fastest — 1M tok/day
|
||
> ```
|
||
|
||
## 🎙️ คอมโบถอดความฟรี
|
||
|
||
> ถอดเสียง/วิดีโอใดๆ ในราคา **$0** — Deepgram Leads พร้อมฟรี $200, AssemblyAI สำรอง $50, Groq Whisper เป็นการสำรองข้อมูลฉุกเฉินไม่จำกัด
|
||
|
||
| ผู้ให้บริการ | เครดิตฟรี | โมเดลที่ดีที่สุด | ขีดจำกัดอัตรา |
|
||
| ----------------- | -------------------------- | --------------------------------------- | --------------------------------- |
|
||
| 🟢 **ดีปแกรม** | **ฟรี $200** (สมัครสมาชิก) | `nova-3` — แม่นยำที่สุด มากกว่า 30 ภาษา | ไม่มีการจำกัด RPM สำหรับเครดิตฟรี |
|
||
| 🔵 **AssemblyAI** | **ฟรี $50** (สมัครสมาชิก) | `universal-3-pro` — บท ความรู้สึก PII | ไม่มีการจำกัด RPM สำหรับเครดิตฟรี |
|
||
| 🔴 **โกรก** | **ฟรีตลอดไป** | `whisper-large-v3` — OpenAI กระซิบ | 30 RPM (อัตราจำกัด) |
|
||
|
||
**คอมโบที่แนะนำใน `/dashboard/combos`:**
|
||
|
||
```
|
||
Name: free-transcription
|
||
Strategy: Priority
|
||
Nodes:
|
||
[1] deepgram/nova-3 → uses $200 free first
|
||
[2] assemblyai/universal-3-pro → fallback when Deepgram credits run out
|
||
[3] groq/whisper-large-v3 → free forever, emergency fallback
|
||
```
|
||
|
||
จากนั้นใน `/dashboard/media` → แท็บ **การถอดเสียง**: อัปโหลดไฟล์เสียงหรือวิดีโอ → เลือกจุดสิ้นสุดคอมโบของคุณ → รับการถอดเสียงในรูปแบบที่รองรับ
|
||
|
||
## 💡 คุณสมบัติที่สำคัญ
|
||
|
||
OmniRoute v2.0 ถูกสร้างขึ้นเพื่อเป็นแพลตฟอร์มการดำเนินงาน ไม่ใช่แค่รีเลย์พร็อกซี
|
||
|
||
### 🆕 ใหม่ — การปรับปรุงที่ได้แรงบันดาลใจจาก ClawRouter (มี.ค. 2026)
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ------------------------------------------------- | ------------------------------------------------------------------------------------------------------- |
|
||
| ⚡ **Grok-4 ฟาสต์แฟมิลี่** | รุ่น xAI ที่ $0.20/$0.50/M — เทียบมาตรฐาน 1143ms (เร็วกว่า Gemini 2.5 Flash 30%) |
|
||
| 🧠 **GLM-5 ผ่าน Z.AI** | บริบทเอาต์พุต 128K, $0.5/1M — รุ่นเรือธงใหม่ล่าสุดจากตระกูล GLM |
|
||
| 🔮 **MiniMax M2.5** | การใช้เหตุผล + งานเอเจนต์ที่ 0.30 ดอลลาร์/1 ล้าน — อัปเกรดอย่างมีนัยสำคัญจาก M2.1 |
|
||
| 🎯 **toolCalling Flag ต่อรุ่น** | ต่อรุ่น `toolCalling: true/false` ในรีจิสทรี — AutoCombo ข้ามรุ่นที่ไม่ใช้เครื่องมือ |
|
||
| 🌍 **การตรวจจับเจตนาหลายภาษา** | คีย์เวิร์ด PT/ZH/ES/AR ในการให้คะแนน AutoCombo — การเลือกโมเดลที่ดีกว่าสำหรับเนื้อหาที่ไม่ใช่ภาษาอังกฤษ |
|
||
| 📊 **ทางเลือกสำรองที่ขับเคลื่อนด้วยเกณฑ์มาตรฐาน** | เวลาแฝง p95 จริงจากคำขอสดฟีดการให้คะแนนคอมโบ — AutoCombo เรียนรู้จากข้อมูลจริง |
|
||
| 🔁 **ขอการขจัดข้อมูลซ้ำซ้อน** | หน้าต่าง dedup ตามแฮชเนื้อหา — ปลอดภัยสำหรับหลายเอเจนต์ ป้องกันการเรียกเก็บเงินซ้ำ |
|
||
| 🔌 **กลยุทธ์เราเตอร์แบบเสียบได้** | อินเทอร์เฟซ `RouterStrategy` ที่ขยายได้ — เพิ่มตรรกะการกำหนดเส้นทางที่กำหนดเองเป็นปลั๊กอิน |
|
||
|
||
### 🚀 ก่อนหน้า v2.0.9+ — Playground, ลายนิ้วมือ CLI และ ACP
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ----------------------------------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
|
||
| 🎮 **โมเดลสนามเด็กเล่น** | หน้าแดชบอร์ดเพื่อทดสอบโมเดลใดๆ โดยตรง — ตัวเลือกผู้ให้บริการ/โมเดล/ปลายทาง, Monaco Editor, การสตรีม, ยกเลิก, การกำหนดเวลา |
|
||
| 🔏 **การจับคู่ลายนิ้วมือ CLI** | การจัดลำดับส่วนหัว/เนื้อหาต่อผู้ให้บริการเพื่อให้ตรงกับลายเซ็น CLI ดั้งเดิม — สลับตามผู้ให้บริการในการตั้งค่า > ความปลอดภัย ** IP พร็อกซีของคุณยังคงอยู่** |
|
||
| 🤝 **รองรับ ACP (โปรโตคอลไคลเอ็นต์ตัวแทน)** | การค้นพบเอเจนต์ CLI (Codex, Claude, Goose, Gemini CLI, OpenClaw + อีก 9 รายการ), กระบวนการวางไข่, `/api/acp/agents` จุดสิ้นสุด |
|
||
| 🤖 **แดชบอร์ดตัวแทน ACP** | ดีบัก › หน้าตัวแทน — ตารางตัวแทน 14 รายพร้อมสถานะการติดตั้ง เวอร์ชัน แบบฟอร์มตัวแทนแบบกำหนดเองสำหรับเครื่องมือ CLI ผู้ใช้ **OpenCode** จะได้รับปุ่ม "ดาวน์โหลด opencode.json" ที่สร้างการกำหนดค่าที่พร้อมใช้งานโดยอัตโนมัติสำหรับโมเดลที่มีอยู่ทั้งหมด |
|
||
| ???? **โมเดลที่กำหนดเอง `apiFormat` การกำหนดเส้นทาง** | โมเดลที่กำหนดเองด้วย `apiFormat: "responses"` กำหนดเส้นทางไปยังตัวแปล Responses API ได้อย่างถูกต้องแล้ว |
|
||
| 🏢 **การแยกพื้นที่ทำงาน Codex** | พื้นที่ทำงาน Codex หลายรายการต่ออีเมล — OAuth แยกการเชื่อมต่ออย่างถูกต้องด้วยรหัสพื้นที่ทำงาน |
|
||
| 🔄 **อัปเดตอิเล็กตรอนอัตโนมัติ** | แอปเดสก์ท็อปตรวจสอบการอัปเดต + ติดตั้งอัตโนมัติเมื่อรีสตาร์ท |
|
||
|
||
### 🤖 การดำเนินการตัวแทนและโปรโตคอล (v2.0)
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| --------------------------------------- | -------------------------------------------------------------------------------------------------------- |
|
||
| 🏽 **เซิร์ฟเวอร์ MCP (16 เครื่องมือ)** | เครื่องมือ IDE/เอเจนต์ผ่าน 3 การขนส่ง: stdio, SSE (`/api/mcp/sse`), HTTP แบบสตรีมได้ (`/api/mcp/stream`) |
|
||
| 🤝 **เซิร์ฟเวอร์ A2A (JSON-RPC + SSE)** | การดำเนินการงานระหว่างเอเจนต์กับเอเจนต์ด้วยการซิงค์และการสตรีมโฟลว์ |
|
||
| 🧭 **หน้าปลายทางรวม** | หน้าการจัดการแบบแท็บพร้อมแท็บ Endpoint Proxy, MCP, A2A และ API Endpoints |
|
||
| 🎚️ **บริการเปิด/ปิดการสลับ** | สวิตช์เปิด/ปิดสำหรับ MCP และ A2A พร้อมการตั้งค่าคงอยู่ (ค่าเริ่มต้น: ปิด) |
|
||
| 🛰️ **MCP รันไทม์ฮาร์ทบีท** | สถานะกระบวนการจริง (pid, สถานะการออนไลน์, อายุฮาร์ทบีท, การขนส่ง, โหมดขอบเขต) |
|
||
| 📋 **เส้นทางการตรวจสอบ MCP** | บันทึกการตรวจสอบที่กรองได้พร้อมความสำเร็จ/ล้มเหลวและการระบุแหล่งที่มาที่สำคัญ |
|
||
| 🔐 **การบังคับใช้ขอบเขต MCP** | สิทธิ์ขอบเขตโดยละเอียด 9 รายการสำหรับการเข้าถึงเครื่องมือที่ควบคุม |
|
||
| 📡 **การจัดการวงจรงาน A2A** | แสดงรายการ/กรองงาน ตรวจสอบเหตุการณ์/สิ่งประดิษฐ์ ยกเลิกงานที่กำลังทำงานอยู่ |
|
||
| 📋 **การค้นพบบัตรตัวแทน** | `/.well-known/agent.json` สำหรับการค้นพบอัตโนมัติของไคลเอ็นต์ |
|
||
| 🧪 **ชุดทดสอบโปรโตคอล E2E** | ไคลเอนต์ MCP SDK + A2A จริงไหลใน `test:protocols:e2e` |
|
||
| ⚙️ **การควบคุมการปฏิบัติงาน** | สลับคอมโบ ใช้โปรไฟล์ความยืดหยุ่น รีเซ็ตเบรกเกอร์จากพื้นผิวควบคุมเดียว |
|
||
|
||
### 🧠 การกำหนดเส้นทางและความฉลาด
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ------------------------------------------ | --------------------------------------------------------------------------------- |
|
||
| 🎯 **ทางเลือกสำรองอัจฉริยะ 4 ระดับ** | เส้นทางอัตโนมัติ: การสมัครสมาชิก → คีย์ API → ถูก → ฟรี |
|
||
| 📊 **การติดตามโควต้าแบบเรียลไทม์** | จำนวนโทเค็นสด + รีเซ็ตการนับถอยหลังต่อผู้ให้บริการ |
|
||
| 🔄 **แปลรูปแบบ** | OpenAI ↔ Claude ↔ Gemini ↔ การตอบกลับด้วยการแปลงสคีมาที่ปลอดภัย |
|
||
| 👥 **รองรับหลายบัญชี** | หลายบัญชีต่อผู้ให้บริการพร้อมตัวเลือกที่ชาญฉลาด |
|
||
| 🔄 **รีเฟรชโทเค็นอัตโนมัติ** | โทเค็น OAuth รีเฟรชอัตโนมัติพร้อมลองอีกครั้ง |
|
||
| 🎨 **คอมโบแบบกำหนดเอง** | 6 กลยุทธ์การปรับสมดุล + การควบคุมลูกโซ่สำรอง |
|
||
| 🌐 **เราเตอร์ตัวแทน** | `provider/*` การกำหนดเส้นทางแบบไดนามิก |
|
||
| 🧠 **คิดควบคุมงบประมาณ** | ขีดจำกัดการให้เหตุผลแบบส่งผ่าน อัตโนมัติ แบบกำหนดเอง และแบบปรับเปลี่ยนได้ |
|
||
| 🔀 **นามแฝงโมเดล** | นามแฝงโมเดลในตัว + แบบกำหนดเองและความปลอดภัยในการย้ายข้อมูล |
|
||
| ⚡ **การเสื่อมสภาพของพื้นหลัง** | กำหนดเส้นทางงานพื้นหลังที่มีลำดับความสำคัญต่ำไปยังโมเดลที่ถูกกว่า |
|
||
| 🧪 **การกำหนดเส้นทางอัจฉริยะที่รับรู้งาน** | เลือกโมเดลอัตโนมัติตามประเภทเนื้อหา (การเข้ารหัส/การมองเห็น/การวิเคราะห์/การสรุป) |
|
||
| 💌 **ระบบพร้อมฉีด** | มีการใช้การควบคุมพฤติกรรมทั่วโลกอย่างสม่ำเสมอ |
|
||
| 📄 **ความเข้ากันได้ของ API การตอบกลับ** | รองรับ `/v1/responses` เต็มรูปแบบสำหรับ Codex และเวิร์กโฟลว์ตัวแทนขั้นสูง |
|
||
|
||
### 🎵 Multi-Modal API
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ----------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
||
| 🖼️ **การสร้างภาพ** | `/v1/images/generations` พร้อมระบบคลาวด์และแบ็กเอนด์ในเครื่อง |
|
||
| 📐 **การฝัง** | `/v1/embeddings` สำหรับการค้นหาและไปป์ไลน์ RAG |
|
||
| 🎶 **การถอดเสียง** | `/v1/audio/transcriptions` — ผู้ให้บริการ 7 ราย (Deepgram Nova 3, AssemblyAI, Groq Whisper, HuggingFace, ElevenLabs, OpenAI, Azure), การตรวจจับภาษาอัตโนมัติ, รองรับ MP4/MP3/WAV |
|
||
| 🔊 **ข้อความเป็นคำพูด** | `/v1/audio/speech` — ผู้ให้บริการ 10 ราย (ElevenLabs, OpenAI, Deepgram, Cartesia, PlayHT, HuggingFace, Nvidia NIM, Inworld, Coqui, Tortoise) พร้อมข้อความแสดงข้อผิดพลาดที่ถูกต้อง |
|
||
| 🎬 **การสร้างวิดีโอ** | `/v1/videos/generations` (เวิร์กโฟลว์ ComfyUI + SD WebUI) |
|
||
| 🎵 **การสร้างดนตรี** | `/v1/music/generations` (เวิร์กโฟลว์ ComfyUI) |
|
||
| 🛡️ **การกลั่นกรอง** | `/v1/moderations` การตรวจสอบความปลอดภัย |
|
||
| 🔀 **จัดอันดับ** | `/v1/rerank` สำหรับการให้คะแนนความเกี่ยวข้อง |
|
||
| 🔍 **ค้นหาเว็บ** 🆕 | `/v1/search` — ผู้ให้บริการ 5 ราย (Serper, Brave, Perplexity, Exa, Tavily), ฟรี 6,500+ รายการ/เดือน, เฟลโอเวอร์อัตโนมัติ, แคช |
|
||
|
||
### 🛡️ ความยืดหยุ่น ความปลอดภัย และการกำกับดูแล
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ----------------------------------------- | --------------------------------------------------------------------------------- |
|
||
| 🔌 **เซอร์กิตเบรกเกอร์** | การเดินทางต่อรุ่น/การกู้คืนด้วยการควบคุมเกณฑ์ |
|
||
| 🎯 **โมเดล Endpoint-Aware** | โมเดลที่กำหนดเองประกาศจุดสิ้นสุดที่รองรับ + รูปแบบ API |
|
||
| 🛡️ **ฝูงต่อต้านฟ้าร้อง** | การป้องกัน Mutex + เซมาฟอร์ในการลองใหม่/ให้คะแนนเหตุการณ์ |
|
||
| 🧠 **แคชความหมาย + ลายเซ็น** | การลดต้นทุน/เวลาแฝงด้วยแคชสองชั้น |
|
||
| ⚡ **ขอ Idempotency** | หน้าต่างการป้องกันซ้ำ |
|
||
| 🔒 **การปลอมแปลงลายนิ้วมือ TLS** | ลายนิ้วมือ TLS เหมือนเบราว์เซอร์ — **ลดการตรวจจับบอทและการตั้งค่าสถานะบัญชี** |
|
||
| 🔏 **การจับคู่ลายนิ้วมือ CLI** | จับคู่ลายเซ็นคำขอ CLI ดั้งเดิม — **ลดความเสี่ยงในการแบนในขณะที่รักษา IP พร็อกซี** |
|
||
| 🌐 **การกรอง IP** | การควบคุมรายการที่อนุญาต/รายการบล็อกสำหรับการปรับใช้แบบเปิดเผย |
|
||
| 📊 **ขีดจำกัดอัตราที่แก้ไขได้** | ขีดจำกัดระดับโลก/ระดับผู้ให้บริการที่กำหนดค่าได้ด้วยความคงอยู่ |
|
||
| 🔑 **การจัดการคีย์ API + การกำหนดขอบเขต** | รักษาความปลอดภัยการออก/การหมุนเวียนคีย์ และการควบคุมโมเดล/ผู้ให้บริการ |
|
||
| 🛡️ **ป้องกัน `/models`** | ตัวเลือกการตรวจสอบสิทธิ์และการซ่อนผู้ให้บริการสำหรับแค็ตตาล็อกโมเดล |
|
||
|
||
### 📊 ความสามารถในการสังเกตและการวิเคราะห์
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ------------------------------ | -------------------------------------------------------- |
|
||
| 📝 **คำขอ + การบันทึกพร็อกซี** | คำขอ/ตอบกลับแบบเต็มและการบันทึกพร็อกซี |
|
||
| 📋 **แดชบอร์ดบันทึกแบบรวม** | มุมมองคำขอ พร็อกซี การตรวจสอบ และคอนโซลในหน้าเดียว |
|
||
| 🔍 **ขอโทรมาตร** | เวลาแฝง p50/p95/p99 และคำขอการติดตาม |
|
||
| 🏥 **แดชบอร์ดสุขภาพ** | เวลาทำงาน สถานะของเบรกเกอร์ การล็อก สถิติแคช |
|
||
| 💰 **ติดตามต้นทุน** | การควบคุมงบประมาณและการเปิดเผยราคาต่อรุ่น |
|
||
| 📈 **การแสดงภาพการวิเคราะห์** | ข้อมูลเชิงลึกการใช้งานโมเดล/ผู้ให้บริการและมุมมองแนวโน้ม |
|
||
| 🧪 **กรอบการประเมินผล** | การทดสอบชุดทองพร้อมกลยุทธ์การจับคู่ที่กำหนดค่าได้ |
|
||
|
||
### ☁️ การปรับใช้และแพลตฟอร์ม
|
||
|
||
| คุณสมบัติ | มันทำอะไร |
|
||
| ------------------------------------ | ----------------------------------------------------------------- |
|
||
| 🌐 **ปรับใช้ได้ทุกที่** | Localhost, VPS, Docker, สภาพแวดล้อมคลาวด์ |
|
||
| 💾 **คลาวด์ซิงค์** | การซิงค์การกำหนดค่าผ่านระบบคลาวด์ |
|
||
| 🔄 **สำรอง/กู้คืน** | ขั้นตอนการส่งออก/นำเข้าและการกู้คืนความเสียหาย |
|
||
| 🧙 **ตัวช่วยสร้างการเริ่มต้นใช้งาน** | การตั้งค่าที่แนะนำการใช้งานครั้งแรก |
|
||
| ???? **แดชบอร์ดเครื่องมือ CLI** | ตั้งค่าเพียงคลิกเดียวสำหรับเครื่องมือเข้ารหัสยอดนิยม |
|
||
| 🎮 **โมเดลสนามเด็กเล่น** | ทดสอบผู้ให้บริการ/รุ่น/ปลายทางจากแดชบอร์ด |
|
||
| 🔏 **สลับลายนิ้วมือ CLI** | การจับคู่ลายนิ้วมือของแต่ละผู้ให้บริการในการตั้งค่า > ความปลอดภัย |
|
||
| 🌐 **i18n (30 ภาษา)** | รองรับภาษาแดชบอร์ด + เอกสารแบบเต็มพร้อมการครอบคลุม RTL |
|
||
| 🧹 **ล้างทุกรุ่น** | การล้างรายการโมเดลในคลิกเดียวในรายละเอียดผู้ให้บริการ |
|
||
| 📋 **เทมเพลตปัญหา** | เทมเพลต GitHub มาตรฐานสำหรับข้อบกพร่องและฟีเจอร์ |
|
||
| 📂 **ไดเรกทอรีข้อมูลที่กำหนดเอง** | `DATA_DIR` แทนที่ตำแหน่งที่เก็บข้อมูล |
|
||
|
||
### เจาะลึกคุณสมบัติ
|
||
|
||
#### ทางเลือกอัจฉริยะพร้อมการควบคุมต้นทุนที่ใช้งานได้จริง
|
||
|
||
```txt
|
||
Combo: "my-coding-stack"
|
||
1. cc/claude-opus-4-6
|
||
2. nvidia/llama-3.3-70b
|
||
3. glm/glm-4.7
|
||
4. if/kimi-k2-thinking
|
||
```
|
||
|
||
เมื่อโควต้า อัตรา หรือสุขภาพล้มเหลว OmniRoute จะย้ายไปยังผู้สมัครรายถัดไปโดยอัตโนมัติโดยไม่ต้องสลับด้วยตนเอง
|
||
|
||
#### การจัดการโปรโตคอลที่มองเห็นและใช้งานได้
|
||
|
||
- MCP + A2A สามารถค้นพบได้ใน UI และเอกสาร (ไม่ได้ซ่อนไว้)
|
||
- API สถานะโปรโตคอลเปิดเผยข้อมูลการดำเนินงานสด (`/api/mcp/*`, `/api/a2a/*`)
|
||
- แดชบอร์ดรวมการดำเนินการสำหรับปฏิบัติการวันที่ 2 (การสลับคำสั่งผสม การรีเซ็ตเบรกเกอร์ การยกเลิกงาน)
|
||
|
||
#### นักแปล + ขั้นตอนการตรวจสอบความถูกต้อง
|
||
|
||
พื้นที่นักแปลประกอบด้วย:
|
||
|
||
- **สนามเด็กเล่น**: ขอตรวจสอบการเปลี่ยนแปลง
|
||
- **ผู้ทดสอบแชท**: คำขอ/ตอบกลับแบบเต็มไปกลับ
|
||
- **ม้านั่งทดสอบ**: มีหลายกรณีในการวิ่งครั้งเดียว
|
||
- **Live Monitor**: มุมมองการจราจรแบบเรียลไทม์
|
||
|
||
พร้อมการตรวจสอบความถูกต้องของโปรโตคอลกับไคลเอนต์จริงผ่าน `npm run test:protocols:e2e`
|
||
|
||
> 📖 **[MCP Server README](open-sse/mcp-server/README.md)** — การอ้างอิงเครื่องมือ การกำหนดค่า IDE และตัวอย่างไคลเอนต์
|
||
>
|
||
> 📖 **[A2A Server README](src/lib/a2a/README.md)** — ทักษะ, วิธี JSON-RPC, การสตรีม และวงจรชีวิตของงาน
|
||
|
||
## 🧪 การประเมินผล (Evals)
|
||
|
||
OmniRoute มีกรอบการประเมินในตัวเพื่อทดสอบคุณภาพการตอบสนองของ LLM เทียบกับชุดทอง เข้าถึงได้ผ่านทาง **Analytics → Evals** ในแดชบอร์ด
|
||
|
||
### ชุดทองในตัว
|
||
|
||
"OmniRoute Golden Set" ที่โหลดไว้ล่วงหน้ามีกรณีทดสอบสำหรับ:
|
||
|
||
- คำทักทาย คณิตศาสตร์ ภูมิศาสตร์ การสร้างโค้ด
|
||
- การปฏิบัติตามรูปแบบ JSON, การแปล, การสร้างมาร์กดาวน์
|
||
- การปฏิเสธอย่างปลอดภัย (เนื้อหาที่เป็นอันตราย) การนับ ตรรกะบูลีน
|
||
|
||
### กลยุทธ์การประเมินผล
|
||
|
||
| กลยุทธ์ | คำอธิบาย | ตัวอย่าง |
|
||
| ---------- | ------------------------------------------------------------------ | -------------------------------- |
|
||
| `exact` | ผลลัพธ์จะต้องตรงกันทุกประการ | `"4"` |
|
||
| `contains` | เอาต์พุตจะต้องมีสตริงย่อย (ไม่คำนึงถึงตัวพิมพ์เล็กและตัวพิมพ์ใหญ่) | `"Paris"` |
|
||
| `regex` | เอาต์พุตต้องตรงกับรูปแบบ regex | `"1.*2.*3"` |
|
||
| `custom` | ฟังก์ชัน JS แบบกำหนดเองส่งคืนค่า true/false | `(output) => output.length > 10` |
|
||
|
||
---
|
||
|
||
## 📖 คู่มือการตั้งค่า
|
||
|
||
### การตั้งค่าโปรโตคอล (MCP + A2A)
|
||
|
||
<details>
|
||
<summary><b>🧩 การตั้งค่า MCP (โปรโตคอลบริบทโมเดล)</b></summary>
|
||
|
||
เริ่มการขนส่ง MCP ในโหมด stdio:
|
||
|
||
```bash
|
||
omniroute --mcp
|
||
```
|
||
|
||
ขั้นตอนการตรวจสอบที่แนะนำ:
|
||
|
||
1. เชื่อมต่อไคลเอนต์ MCP ของคุณผ่าน stdio
|
||
2. เรียกใช้ `omniroute_get_health`
|
||
3. เรียกใช้ `omniroute_list_combos`
|
||
4. เปิด `/dashboard/mcp` เพื่อยืนยันการเต้นของหัวใจ กิจกรรม และการตรวจสอบ
|
||
|
||
API ที่มีประโยชน์สำหรับระบบอัตโนมัติ:
|
||
|
||
- `GET /api/mcp/status`
|
||
- `GET /api/mcp/tools`
|
||
- `GET /api/mcp/audit`
|
||
- `GET /api/mcp/audit/stats`
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🤝 การตั้งค่า A2A (Agent2Agent)</b>OMNI_TOKEN_658__
|
||
|
||
ค้นหาตัวแทน:
|
||
|
||
```bash
|
||
curl http://localhost:20128/.well-known/agent.json
|
||
```
|
||
|
||
ส่งงาน:
|
||
|
||
```bash
|
||
curl -X POST http://localhost:20128/a2a \
|
||
-H 'content-type: application/json' \
|
||
-d '{"jsonrpc":"2.0","id":"setup-a2a","method":"message/send","params":{"skill":"quota-management","messages":[{"role":"user","content":"Summarize quota status."}]}}'
|
||
```
|
||
|
||
จัดการวงจรชีวิต:
|
||
|
||
- `GET /api/a2a/status`
|
||
- `GET /api/a2a/tasks`
|
||
- `GET /api/a2a/tasks/:id`
|
||
- `POST /api/a2a/tasks/:id/cancel`
|
||
|
||
UI การดำเนินงาน:
|
||
|
||
- `/dashboard/a2a` สำหรับการสังเกตงาน/สถานะ/สตรีมและการดำเนินการควัน
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🧪 การตรวจสอบความถูกต้องของโปรโตคอลจากต้นทางถึงปลายทาง</b></summary>
|
||
|
||
ตรวจสอบทั้งสองโปรโตคอลกับไคลเอนต์จริง:
|
||
|
||
```bash
|
||
npm run test:protocols:e2e
|
||
```
|
||
|
||
สิ่งนี้จะยืนยัน:
|
||
|
||
- เชื่อมต่อ/รายการ/โทรไคลเอ็นต์ MCP SDK
|
||
- การค้นพบ A2A/ส่ง/สตรีม/รับ/ยกเลิก
|
||
- ตรวจสอบข้อมูลในการตรวจสอบ MCP และ API การจัดการงาน A2A
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>💳 ผู้ให้บริการสมัครสมาชิก</b>OMNI_TOKEN_670__
|
||
|
||
### รหัสคลอด (Pro/Max)
|
||
|
||
```bash
|
||
Dashboard → Providers → Connect Claude Code
|
||
→ OAuth login → Auto token refresh
|
||
→ 5-hour + weekly quota tracking
|
||
|
||
Models:
|
||
cc/claude-opus-4-6
|
||
cc/claude-sonnet-4-5-20250929
|
||
cc/claude-haiku-4-5-20251001
|
||
```
|
||
|
||
**เคล็ดลับสำหรับมือโปร:** ใช้ Opus สำหรับงานที่ซับซ้อน และใช้ Sonnet เพื่อความรวดเร็ว โควต้าการติดตาม OmniRoute ต่อรุ่น!
|
||
|
||
### OpenAI Codex (พลัส/โปร)
|
||
|
||
```bash
|
||
Dashboard → Providers → Connect Codex
|
||
→ OAuth login (port 1455)
|
||
→ 5-hour + weekly reset
|
||
|
||
Models:
|
||
cx/gpt-5.2-codex
|
||
cx/gpt-5.1-codex-max
|
||
```
|
||
|
||
#### การจัดการขีดจำกัดบัญชี Codex (5 ชม. + รายสัปดาห์)
|
||
|
||
ขณะนี้บัญชี Codex แต่ละบัญชีมีการสลับนโยบายใน `Dashboard -> Providers`:
|
||
|
||
- `5h` (เปิด/ปิด): บังคับใช้นโยบายเกณฑ์กรอบเวลา 5 ชั่วโมง
|
||
- `Weekly` (เปิด/ปิด): บังคับใช้นโยบายขีดจำกัดหน้าต่างรายสัปดาห์
|
||
- ลักษณะการทำงานตามเกณฑ์: เมื่อหน้าต่างที่เปิดใช้งานถึงการใช้งาน >=90% บัญชีนั้นจะถูกข้ามไป
|
||
- พฤติกรรมการหมุน: OmniRoute กำหนดเส้นทางไปยังบัญชี Codex ที่มีสิทธิ์ถัดไปโดยอัตโนมัติ
|
||
- รีเซ็ตพฤติกรรม: เมื่อเวลาของผู้ให้บริการ `resetAt` ผ่านไป บัญชีจะมีสิทธิ์อีกครั้งโดยอัตโนมัติ
|
||
|
||
สถานการณ์:
|
||
|
||
- `5h ON` + `Weekly ON`: บัญชีจะถูกข้ามเมื่อหน้าต่างใดหน้าต่างหนึ่งถึงเกณฑ์
|
||
- `5h OFF` + `Weekly ON`: การใช้งานรายสัปดาห์เท่านั้นที่สามารถบล็อกบัญชีได้
|
||
- `5h ON` + `Weekly OFF`: การใช้งานเพียง 5 ชั่วโมงเท่านั้นที่สามารถบล็อกบัญชีได้
|
||
- `resetAt` ผ่าน: บัญชีเข้าสู่การหมุนเวียนอีกครั้งโดยอัตโนมัติ (ไม่มีการเปิดใช้อีกครั้งด้วยตนเอง)
|
||
|
||
### Gemini CLI (ฟรี 180K/เดือน!)
|
||
|
||
```bash
|
||
Dashboard → Providers → Connect Gemini CLI
|
||
→ Google OAuth
|
||
→ 180K completions/month + 1K/day
|
||
|
||
Models:
|
||
gc/gemini-3-flash-preview
|
||
gc/gemini-2.5-pro
|
||
```
|
||
|
||
**คุ้มค่าที่สุด:** ระดับฟรีมหาศาล! ใช้สิ่งนี้ก่อนระดับที่ชำระเงิน
|
||
|
||
### นักบิน GitHub
|
||
|
||
```bash
|
||
Dashboard → Providers → Connect GitHub
|
||
→ OAuth via GitHub
|
||
→ Monthly reset (1st of month)
|
||
|
||
Models:
|
||
gh/gpt-5
|
||
gh/claude-4.5-sonnet
|
||
gh/gemini-3-pro
|
||
```
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🔑 ผู้ให้บริการคีย์ API</b></summary>
|
||
|
||
### NVIDIA NIM (เข้าถึงนักพัฒนาฟรี — มากกว่า 70 รุ่น)
|
||
|
||
1. ลงทะเบียน: [build.nvidia.com](https://build.nvidia.com)
|
||
2. รับคีย์ API ฟรี (รวมเครดิตการอนุมาน 1,000 รายการ)
|
||
3. แดชบอร์ด → เพิ่มผู้ให้บริการ → NVIDIA NIM:
|
||
- คีย์ API: `nvapi-your-key`
|
||
|
||
**รุ่น:** `nvidia/llama-3.3-70b-instruct`, `nvidia/mistral-7b-instruct` และอีก 50+ รายการ
|
||
|
||
**เคล็ดลับสำหรับมือโปร:** API ที่เข้ากันได้กับ OpenAI — ทำงานได้อย่างราบรื่นกับการแปลรูปแบบของ OmniRoute!
|
||
|
||
### ดีปซีค
|
||
|
||
1. ลงทะเบียน: [platform.deepseek.com](https://platform.deepseek.com)
|
||
2. รับรหัส API
|
||
3. แดชบอร์ด → เพิ่มผู้ให้บริการ → DeepSeek
|
||
|
||
**รุ่น:** `deepseek/deepseek-chat`, `deepseek/deepseek-coder`
|
||
|
||
### Groq (มีระดับฟรี!)
|
||
|
||
1. ลงทะเบียน: [console.groq.com](https://console.groq.com)
|
||
2. รับคีย์ API (รวมเทียร์ฟรี)
|
||
3. แดชบอร์ด → เพิ่มผู้ให้บริการ → Groq
|
||
|
||
**รุ่น:** `groq/llama-3.3-70b`, `groq/mixtral-8x7b`
|
||
|
||
**เคล็ดลับสำหรับมือโปร:** การอนุมานที่รวดเร็วเป็นพิเศษ — ดีที่สุดสำหรับการเขียนโค้ดแบบเรียลไทม์!
|
||
|
||
### OpenRouter (มากกว่า 100 รุ่น)
|
||
|
||
1. ลงทะเบียน: [openrouter.ai](https://openrouter.ai)
|
||
2. รับรหัส API
|
||
3. แดชบอร์ด → เพิ่มผู้ให้บริการ → OpenRouter
|
||
|
||
**รุ่น:** เข้าถึงโมเดลมากกว่า 100 โมเดลจากผู้ให้บริการรายใหญ่ทั้งหมดผ่านคีย์ API เดียว
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>💰 ผู้ให้บริการราคาถูก (สำรอง)</b></summary>
|
||
|
||
### GLM-4.7 (รีเซ็ตรายวัน, $0.6/1M)
|
||
|
||
1. ลงทะเบียน: [Zhipu AI](https://open.bigmodel.cn/)
|
||
2. รับคีย์ API จาก Coding Plan
|
||
3. แดชบอร์ด → เพิ่มคีย์ API:
|
||
- ผู้ให้บริการ: `glm`
|
||
- คีย์ API: `your-key`
|
||
|
||
**ใช้:** `glm/glm-4.7`
|
||
|
||
**เคล็ดลับสำหรับมือโปร:** แผนการเขียนโค้ดเสนอโควต้า 3 เท่าในราคา 1/7! รีเซ็ตทุกวัน 10.00 น.
|
||
|
||
### MiniMax M2.1 (รีเซ็ต 5 ชม., $0.20/1M)
|
||
|
||
1. ลงทะเบียน: [MiniMax](https://www.minimax.io/)
|
||
2. รับรหัส API
|
||
3. แดชบอร์ด → เพิ่มคีย์ API
|
||
|
||
**ใช้:** `minimax/MiniMax-M2.1`
|
||
|
||
**เคล็ดลับสำหรับมือโปร:** ตัวเลือกที่ถูกที่สุดสำหรับบริบทที่ยาว (โทเค็น 1M)!
|
||
|
||
### Kimi K2 ($9/เดือน)
|
||
|
||
1. สมัครสมาชิก: [Moonshot AI](https://platform.moonshot.ai/)
|
||
2. รับรหัส API
|
||
3. แดชบอร์ด → เพิ่มคีย์ API
|
||
|
||
**ใช้:** `kimi/kimi-latest`
|
||
|
||
**เคล็ดลับสำหรับมือโปร:** แก้ไข $9/เดือนสำหรับโทเค็น 10M = $0.90/ต้นทุนที่แท้จริง 1M!
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary><b>🆓 ผู้ให้บริการฟรี (การสำรองข้อมูลฉุกเฉิน)</b>OMNI_TOKEN_688__
|
||
|
||
### iFlow (5 รุ่นฟรีผ่าน OAuth)
|
||
|
||
```bash
|
||
Dashboard → Connect iFlow
|
||
→ iFlow OAuth login
|
||
→ Unlimited usage
|
||
|
||
Models:
|
||
if/kimi-k2-thinking
|
||
if/qwen3-coder-plus
|
||
if/glm-4.7
|
||
if/minimax-m2
|
||
if/deepseek-r1
|
||
```
|
||
|
||
### Qwen (ฟรี 4 รุ่นผ่านรหัสอุปกรณ์)
|
||
|
||
```bash
|
||
Dashboard → Connect Qwen
|
||
→ Device code authorization
|
||
→ Unlimited usage
|
||
|
||
Models:
|
||
qw/qwen3-coder-plus
|
||
qw/qwen3-coder-flash
|
||
```
|
||
|
||
### คิโระ (คลอดด์ฟรี)
|
||
|
||
```bash
|
||
Dashboard → Connect Kiro
|
||
→ AWS Builder ID or Google/GitHub
|
||
→ Unlimited usage
|
||
|
||
Models:
|
||
kr/claude-sonnet-4.5
|
||
kr/claude-haiku-4.5
|
||
```
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary>OMNI_TOKEN_692____ วาดภาพคอมโบ</b>OMNI_TOKEN_694__
|
||
|
||
### ตัวอย่างที่ 1: เพิ่มการสมัครสมาชิกให้สูงสุด → การสำรองข้อมูลราคาถูก
|
||
|
||
```
|
||
Dashboard → Combos → Create New
|
||
|
||
Name: premium-coding
|
||
Models:
|
||
1. cc/claude-opus-4-6 (Subscription primary)
|
||
2. glm/glm-4.7 (Cheap backup, $0.6/1M)
|
||
3. minimax/MiniMax-M2.1 (Cheapest fallback, $0.20/1M)
|
||
|
||
Use in CLI: premium-coding
|
||
```
|
||
|
||
### ตัวอย่างที่ 2: ฟรีเท่านั้น (ไม่มีค่าใช้จ่าย)
|
||
|
||
```
|
||
Name: free-combo
|
||
Models:
|
||
1. gc/gemini-3-flash-preview (180K free/month)
|
||
2. if/kimi-k2-thinking (unlimited)
|
||
3. qw/qwen3-coder-plus (unlimited)
|
||
|
||
Cost: $0 forever!
|
||
```
|
||
|
||
</details>
|
||
|
||
<details>
|
||
<summary>OMNI_TOKEN_698__ดำเนินการบูรณาการ CLI</b>OMNI_TOKEN_700__
|
||
|
||
### เคอร์เซอร์ IDE
|
||
|
||
```
|
||
Settings → Models → Advanced:
|
||
OpenAI API Base URL: http://localhost:20128/v1
|
||
OpenAI API Key: [from OmniRoute dashboard]
|
||
Model: cc/claude-opus-4-6
|
||
```
|
||
|
||
### รหัสคลอด
|
||
|
||
ใช้หน้า **เครื่องมือ CLI** ในแดชบอร์ดสำหรับการกำหนดค่าด้วยคลิกเดียว หรือแก้ไข `~/.claude/settings.json` ด้วยตนเอง
|
||
|
||
### Codex CLI
|
||
|
||
```bash
|
||
export OPENAI_BASE_URL="http://localhost:20128"
|
||
export OPENAI_API_KEY="your-omniroute-api-key"
|
||
|
||
codex "your prompt"
|
||
```
|
||
|
||
### โอเพ่นคลอว์
|
||
|
||
**ตัวเลือก 1 — แดชบอร์ด (แนะนำ):**
|
||
|
||
```
|
||
Dashboard → CLI Tools → OpenClaw → Select Model → Apply
|
||
```
|
||
|
||
**ตัวเลือก 2 — กำหนดเอง:** แก้ไข `~/.openclaw/openclaw.json`:
|
||
|
||
```json
|
||
{
|
||
"models": {
|
||
"providers": {
|
||
"omniroute": {
|
||
"baseUrl": "http://127.0.0.1:20128/v1",
|
||
"apiKey": "sk_omniroute",
|
||
"api": "openai-completions"
|
||
}
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
> **หมายเหตุ:** OpenClaw ใช้งานได้กับ OmniRoute ในพื้นที่เท่านั้น ใช้ `127.0.0.1` แทน `localhost` เพื่อหลีกเลี่ยงปัญหาความละเอียดของ IPv6
|
||
|
||
### ไคลน์ / ดำเนินการต่อ / RooCode
|
||
|
||
```
|
||
Settings → API Configuration:
|
||
Provider: OpenAI Compatible
|
||
Base URL: http://localhost:20128/v1
|
||
API Key: [from OmniRoute dashboard]
|
||
Model: if/kimi-k2-thinking
|
||
```
|
||
|
||
### โอเพ่นโค้ด
|
||
|
||
**ขั้นตอนที่ 1:** เพิ่ม OmniRoute เป็นผู้ให้บริการแบบกำหนดเอง:
|
||
|
||
```bash
|
||
opencode
|
||
/connect
|
||
# Select "Other" → Enter ID: "omniroute" → Enter your OmniRoute API key
|
||
```
|
||
|
||
**ขั้นตอนที่ 2:** สร้าง/แก้ไข `opencode.json` ในรูทโปรเจ็กต์ของคุณ:
|
||
|
||
```json
|
||
{
|
||
"$schema": "https://opencode.ai/config.json",
|
||
"provider": {
|
||
"omniroute": {
|
||
"npm": "@ai-sdk/openai-compatible",
|
||
"name": "OmniRoute",
|
||
"options": {
|
||
"baseURL": "http://localhost:20128/v1"
|
||
},
|
||
"models": {
|
||
"cc/claude-sonnet-4-20250514": { "name": "Claude Sonnet 4" },
|
||
"gg/gemini-2.5-pro": { "name": "Gemini 2.5 Pro" },
|
||
"if/kimi-k2-thinking": { "name": "Kimi K2 (Free)" }
|
||
}
|
||
}
|
||
}
|
||
}
|
||
```
|
||
|
||
**ขั้นตอนที่ 3:** เลือกโมเดลใน OpenCode:
|
||
|
||
```bash
|
||
/models
|
||
# Select any OmniRoute model from the list
|
||
```
|
||
|
||
> **เคล็ดลับ:** เพิ่มโมเดลใดๆ ที่มีอยู่ในปลายทาง OmniRoute `/v1/models` ของคุณไปยังส่วน `models` ใช้รูปแบบ `provider/model-id` จากแดชบอร์ด OmniRoute ของคุณ
|
||
|
||
</details>
|
||
|
||
---
|
||
|
||
## 🐛 การแก้ไขปัญหา
|
||
|
||
<details>
|
||
<summary><b>คลิกเพื่อขยายคำแนะนำการแก้ไขปัญหา</b>OMNI_TOKEN_706__
|
||
|
||
**"โมเดลภาษาไม่ได้ระบุข้อความ"**
|
||
|
||
- โควต้าผู้ให้บริการหมด → ตรวจสอบตัวติดตามโควต้าแดชบอร์ด
|
||
- วิธีแก้ไข: ใช้ทางเลือกแบบคอมโบหรือเปลี่ยนไปใช้ระดับที่ถูกกว่า
|
||
|
||
**จำกัดอัตรา**
|
||
|
||
- โควต้าการสมัครสมาชิกหมด → สำรองไปที่ GLM/MiniMax
|
||
- เพิ่มคอมโบ: `cc/claude-opus-4-6 → glm/glm-4.7 → if/kimi-k2-thinking`
|
||
|
||
**โทเค็น OAuth หมดอายุแล้ว**
|
||
|
||
- รีเฟรชอัตโนมัติโดย OmniRoute
|
||
- หากปัญหายังคงอยู่: แดชบอร์ด → ผู้ให้บริการ → เชื่อมต่อใหม่
|
||
|
||
**ค่าใช้จ่ายสูง**
|
||
|
||
- ตรวจสอบสถิติการใช้งานในแดชบอร์ด → ต้นทุน
|
||
- เปลี่ยนโมเดลหลักเป็น GLM/MiniMax
|
||
- ใช้ระดับฟรี (Gemini CLI, iFlow) สำหรับงานที่ไม่สำคัญ
|
||
|
||
**พอร์ตแดชบอร์ด/API ไม่ถูกต้อง**
|
||
|
||
- `PORT` เป็นพอร์ตฐานมาตรฐาน (และพอร์ต API ตามค่าเริ่มต้น)
|
||
- `API_PORT` แทนที่เฉพาะ Listener API ที่เข้ากันได้กับ OpenAI
|
||
- `DASHBOARD_PORT` แทนที่เฉพาะตัวฟังแดชบอร์ด/Next.js
|
||
- ตั้งค่า `NEXT_PUBLIC_BASE_URL` เป็นแดชบอร์ด/URL สาธารณะของคุณ (สำหรับการเรียกกลับ OAuth)
|
||
|
||
**ข้อผิดพลาดในการซิงค์คลาวด์**
|
||
|
||
- ตรวจสอบ `BASE_URL` ชี้ไปยังอินสแตนซ์ที่ทำงานอยู่ของคุณ
|
||
- ตรวจสอบ `CLOUD_URL` ชี้ไปยังจุดปลายทางคลาวด์ที่คุณคาดหวัง
|
||
- เก็บค่า `NEXT_PUBLIC_*` ให้สอดคล้องกับค่าฝั่งเซิร์ฟเวอร์
|
||
|
||
**เข้าสู่ระบบครั้งแรกใช้งานไม่ได้**
|
||
|
||
- ตรวจสอบ `INITIAL_PASSWORD` ใน `.env`
|
||
- หากไม่ได้ตั้งค่า รหัสผ่านสำรองจะเป็น `123456`
|
||
|
||
** ไม่มีบันทึกคำขอ **
|
||
|
||
- ตั้งค่า `ENABLE_REQUEST_LOGS=true` ใน `.env`
|
||
|
||
**การทดสอบการเชื่อมต่อแสดงว่า "ไม่ถูกต้อง" สำหรับผู้ให้บริการที่รองรับ OpenAI**
|
||
|
||
- ผู้ให้บริการหลายรายไม่เปิดเผยปลายทาง `/models`
|
||
- OmniRoute v1.0.6+ มีการตรวจสอบทางเลือกผ่านการแชทให้เสร็จสิ้น
|
||
- ตรวจสอบให้แน่ใจว่า URL ฐานมีคำต่อท้าย `/v1`
|
||
|
||
### 🔐 OAuth บนเซิร์ฟเวอร์ระยะไกล
|
||
|
||
<a name="oauth-on-a-remote-server"></a>
|
||
<a name="oauth-em-servidor-remoto"></a>
|
||
|
||
> **⚠️ สำคัญสำหรับผู้ใช้ที่ใช้งาน OmniRoute บน VPS, Docker หรือเซิร์ฟเวอร์ระยะไกลใดๆ**
|
||
|
||
#### เหตุใด Antigravity / Gemini CLI OAuth จึงล้มเหลวบนเซิร์ฟเวอร์ระยะไกล
|
||
|
||
ผู้ให้บริการ **Antigravity** และ **Gemini CLI** ใช้ **Google OAuth 2.0** Google กำหนดให้ `redirect_uri` ในขั้นตอน OAuth ตรงกับหนึ่งใน URI ที่ลงทะเบียนล่วงหน้าใน Google Cloud Console ของแอป
|
||
|
||
ข้อมูลรับรอง OAuth ที่รวมอยู่ใน OmniRoute ได้รับการลงทะเบียน **สำหรับ `localhost` เท่านั้น** เมื่อคุณเข้าถึง OmniRoute บนเซิร์ฟเวอร์ระยะไกล (เช่น `https://omniroute.myserver.com`) Google จะปฏิเสธการตรวจสอบสิทธิ์ด้วย:
|
||
|
||
```
|
||
Error 400: redirect_uri_mismatch
|
||
```
|
||
|
||
#### วิธีแก้ไข: กำหนดค่าข้อมูลรับรอง OAuth ของคุณเอง
|
||
|
||
คุณต้องสร้าง **OAuth 2.0 Client ID** ใน Google Cloud Console ด้วย URI ของเซิร์ฟเวอร์ของคุณ
|
||
|
||
#### ทีละขั้นตอน
|
||
|
||
**1. เปิดคอนโซล Google Cloud**
|
||
|
||
ไปที่: [https://console.cloud.google.com/apis/credentials](https://console.cloud.google.com/apis/credentials)
|
||
|
||
**2. สร้างรหัสไคลเอ็นต์ OAuth 2.0 ใหม่**
|
||
|
||
- คลิก **"+ สร้างข้อมูลรับรอง"** → **"รหัสไคลเอ็นต์ OAuth"**
|
||
- ประเภทแอปพลิเคชัน: **"แอปพลิเคชันเว็บ"**
|
||
- ชื่อ: อะไรก็ได้ที่คุณชอบ (เช่น `OmniRoute Remote`)
|
||
|
||
**3. เพิ่ม URI การเปลี่ยนเส้นทางที่ได้รับอนุญาต**
|
||
|
||
ในช่อง **"URI การเปลี่ยนเส้นทางที่ได้รับอนุญาต"** ให้เพิ่ม:
|
||
|
||
```
|
||
https://your-server.com/callback
|
||
```
|
||
|
||
> แทนที่ `your-server.com` ด้วยโดเมนหรือ IP ของเซิร์ฟเวอร์ของคุณ (รวมพอร์ตหากจำเป็น เช่น `http://45.33.32.156:20128/callback`)
|
||
|
||
**4. บันทึกและคัดลอกข้อมูลรับรอง**
|
||
|
||
หลังจากสร้างแล้ว Google จะแสดง **รหัสไคลเอ็นต์** และ **รหัสลับไคลเอ็นต์**
|
||
|
||
**5. ตั้งค่าตัวแปรสภาพแวดล้อม**
|
||
|
||
ใน `.env` ของคุณ (หรือตัวแปรสภาพแวดล้อม Docker):
|
||
|
||
```bash
|
||
# For Antigravity:
|
||
ANTIGRAVITY_OAUTH_CLIENT_ID=your-client-id.apps.googleusercontent.com
|
||
ANTIGRAVITY_OAUTH_CLIENT_SECRET=GOCSPX-your-secret
|
||
|
||
# For Gemini CLI:
|
||
GEMINI_OAUTH_CLIENT_ID=your-client-id.apps.googleusercontent.com
|
||
GEMINI_OAUTH_CLIENT_SECRET=GOCSPX-your-secret
|
||
GEMINI_CLI_OAUTH_CLIENT_SECRET=GOCSPX-your-secret
|
||
```
|
||
|
||
**6. รีสตาร์ท OmniRoute**
|
||
|
||
```bash
|
||
# npm:
|
||
npm run dev
|
||
|
||
# Docker:
|
||
docker restart omniroute
|
||
```
|
||
|
||
**7. ลองเชื่อมต่ออีกครั้ง**
|
||
|
||
แดชบอร์ด → ผู้ให้บริการ → Antigravity (หรือ Gemini CLI) → OAuth
|
||
|
||
ขณะนี้ Google จะเปลี่ยนเส้นทางไปยัง `https://your-server.com/callback` อย่างถูกต้อง
|
||
|
||
---
|
||
|
||
#### วิธีแก้ปัญหาชั่วคราว (ไม่มีข้อมูลประจำตัวที่กำหนดเอง)
|
||
|
||
หากคุณไม่ต้องการตั้งค่าข้อมูลรับรองของคุณเองในขณะนี้ คุณยังคงใช้ **ขั้นตอน URL ด้วยตนเอง** ได้:
|
||
|
||
1. OmniRoute เปิด URL การอนุญาตของ Google
|
||
2. หลังจากการอนุญาต Google จะพยายามเปลี่ยนเส้นทางไปที่ `localhost` (ซึ่งล้มเหลวบนเซิร์ฟเวอร์ระยะไกล)
|
||
3. **คัดลอก URL แบบเต็ม** จากแถบที่อยู่ของเบราว์เซอร์ของคุณ (แม้ว่าหน้าเว็บจะไม่โหลดก็ตาม)
|
||
4. วาง URL นั้นลงในฟิลด์ที่แสดงในโมดอลการเชื่อมต่อ OmniRoute
|
||
5. คลิก **"เชื่อมต่อ"**
|
||
|
||
> ใช้งานได้เนื่องจากรหัสการให้สิทธิ์ใน URL นั้นถูกต้อง ไม่ว่าหน้าการเปลี่ยนเส้นทางจะโหลดแล้วก็ตาม
|
||
|
||
---
|
||
|
||
<details>
|
||
<summary><b>🇧🇷 เวอร์ชั่นโปรตุเกส</b>OMNI_TOKEN_715__
|
||
|
||
#### คุณใช้ OAuth ในเรื่อง Antigravity / Gemini CLI หรือไม่?
|
||
|
||
ระบบปฏิบัติการ **Antigravity** และ **Gemini CLI** ใช้ **Google OAuth 2.0** สำหรับการรับรองความถูกต้อง O Google ต้องการ `redirect_uri` usada no fluxo OAuth seja **exatamente** uma das URIs pré-cadastradas no Google Cloud Console do aplicativo.
|
||
|
||
ตามที่รับรอง OAuth embutidas no OmniRoute estão cadastradas **apenas para `localhost`**. ต้องการใช้ OmniRoute ในเซิร์ฟเวอร์ remoto (เช่น `https://omniroute.meuservidor.com`) หรือ Google ตรวจสอบ com autenticação:
|
||
|
||
```
|
||
Error 400: redirect_uri_mismatch
|
||
```
|
||
|
||
#### วิธีแก้ปัญหา: กำหนดค่า suas próprias credenciais OAuth
|
||
|
||
อยู่ในนั้นโดยตรง **OAuth 2.0 Client ID** ไม่มี Google Cloud Console พร้อม URI สำหรับเซิร์ฟเวอร์
|
||
|
||
#### เยี่ยมเลย
|
||
|
||
**1. เข้าถึง Google Cloud Console**
|
||
|
||
อับรา: [https://console.cloud.google.com/apis/credentials](https://console.cloud.google.com/apis/credentials)
|
||
|
||
**2. ฉันเพิ่งค้นพบ OAuth 2.0 Client ID**
|
||
|
||
- คลิก em **"+ สร้างข้อมูลรับรอง"** → **"รหัสไคลเอ็นต์ OAuth"**
|
||
- เคล็ดลับการใช้งาน: **"แอปพลิเคชันเว็บ"**
|
||
- ชื่อ: ชื่อ escolha qualquer (เช่น: `OmniRoute Remote`)
|
||
|
||
**3. Adicione เป็น URI การเปลี่ยนเส้นทางที่ได้รับอนุญาต**
|
||
|
||
ไม่มีค่าย **"URI การเปลี่ยนเส้นทางที่ได้รับอนุญาต"** ผู้สนับสนุน:
|
||
|
||
```
|
||
https://seu-servidor.com/callback
|
||
```
|
||
|
||
> Substitua `seu-servidor.com` pelo domínio ou IP do seu servidor (รวม porta se necessário เช่น `http://45.33.32.156:20128/callback`)
|
||
|
||
**4. Salve e copy as credenciais**
|
||
|
||
อ้างอิงถึง Google มากที่สุด o **Client ID** e o **Client Secret**
|
||
|
||
**5. กำหนดค่าเป็น variáveis de Ambiente**
|
||
|
||
ไม่มี `.env` (คุณ นาส วาเรียเว เดอ แอมเบียนท์ โด นักเทียบท่า):
|
||
|
||
```bash
|
||
# Para Antigravity:
|
||
ANTIGRAVITY_OAUTH_CLIENT_ID=seu-client-id.apps.googleusercontent.com
|
||
ANTIGRAVITY_OAUTH_CLIENT_SECRET=GOCSPX-seu-secret
|
||
|
||
# Para Gemini CLI:
|
||
GEMINI_OAUTH_CLIENT_ID=seu-client-id.apps.googleusercontent.com
|
||
GEMINI_OAUTH_CLIENT_SECRET=GOCSPX-seu-secret
|
||
GEMINI_CLI_OAUTH_CLIENT_SECRET=GOCSPX-seu-secret
|
||
```
|
||
|
||
**6. ย้อนกลับไปสู่ OmniRoute**
|
||
|
||
```bash
|
||
# Se usando npm:
|
||
npm run dev
|
||
|
||
# Se usando Docker:
|
||
docker restart omniroute
|
||
```
|
||
|
||
**7. เต็นท์ คอนเนกตาร์ โนวาเมนเต**
|
||
|
||
แดชบอร์ด → ผู้ให้บริการ → Antigravity (หรือ Gemini CLI) → OAuth
|
||
|
||
ภาพรวมของ Google การแก้ไขสำหรับ `https://seu-servidor.com/callback` และการรับรองความถูกต้อง
|
||
|
||
---
|
||
|
||
#### วิธีแก้ปัญหาชั่วคราว (sem configurar credenciais próprias)
|
||
|
||
Se não quiser criar credenciais próprias agora, ainda é possível usar o fluxo **manual de URL**:
|
||
|
||
1. O OmniRoute ย่อ URL อัตโนมัติของ Google
|
||
2. Após você autorizar, o Google tentará redirecionar para `localhost` (que falha no servidor remoto)
|
||
3. **คัดลอก URL ที่สมบูรณ์** da barra de endereço do seu browser (mesmo que a página não carregue)
|
||
4. Cole essa URL no campo que aparece no modal de conexão do OmniRoute
|
||
5. คลิกที่นี่ **"เชื่อมต่อ"**
|
||
|
||
> วิธีแก้ปัญหาเบื้องต้นคือทำการเปลี่ยนเส้นทางโดยอัตโนมัติและทำการเปลี่ยนเส้นทางโดยอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
---
|
||
|
||
</details>
|
||
|
||
## 🛠️ เทคสแต็ค
|
||
|
||
<details>
|
||
<summary>OMNI_TOKEN_720__คลิกเพื่อขยายรายละเอียดกลุ่มเทคโนโลยี</b></summary>
|
||
|
||
- **รันไทม์**: Node.js 18–22 LTS (⚠️ Node.js 24+ ไม่ได้รับการสนับสนุน\*\* — `better-sqlite3` ไบนารีดั้งเดิมเข้ากันไม่ได้)
|
||
- **ภาษา**: TypeScript 5.9 — **TypeScript 100%** ทั่วทั้ง `src/` และ `open-sse/` (ศูนย์ `any` ในโมดูลหลักตั้งแต่เวอร์ชัน 2.0)
|
||
- **เฟรมเวิร์ก**: Next.js 16 + React 19 + Tailwind CSS 4
|
||
- **ฐานข้อมูล**: LowDB (JSON) + SQLite (สถานะโดเมน + บันทึกพร็อกซี + การตรวจสอบ MCP + การตัดสินใจกำหนดเส้นทาง)
|
||
- **Schemas**: Zod (การตรวจสอบ I/O ของเครื่องมือ MCP, สัญญา API)
|
||
- **โปรโตคอล**: MCP (stdio/HTTP) + A2A v0.3 (JSON-RPC 2.0 + SSE)
|
||
- **การสตรีม**: เหตุการณ์ที่เซิร์ฟเวอร์ส่ง (SSE)
|
||
- **การตรวจสอบสิทธิ์**: OAuth 2.0 (PKCE) + JWT + คีย์ API + การอนุญาตขอบเขต MCP
|
||
- **การทดสอบ**: ตัวรันการทดสอบ Node.js + Vitest (การทดสอบมากกว่า 900 รายการ รวมถึงหน่วย, การรวม, E2E)
|
||
- **CI/CD**: การดำเนินการ GitHub (เผยแพร่ npm อัตโนมัติ + Docker Hub เมื่อวางจำหน่าย)
|
||
- **เว็บไซต์**: [omniroute.online](https://omniroute.online)
|
||
- **แพ็คเกจ**: [npmjs.com/package/omniroute](https://www.npmjs.com/package/omniroute)
|
||
- **นักเทียบท่า**: [hub.docker.com/r/diegosouzapw/omniroute](https://hub.docker.com/r/diegosouzapw/omniroute)
|
||
- **ความยืดหยุ่น**: เซอร์กิตเบรกเกอร์, การถอยกลับแบบเอ็กซ์โปเนนเชียล, การป้องกันฝูงฟ้าผ่า, การปลอมแปลง TLS, การรักษาตัวเองแบบคอมโบอัตโนมัติ
|
||
|
||
</details>
|
||
|
||
---
|
||
|
||
## 📖 เอกสารประกอบ
|
||
|
||
| เอกสาร | คำอธิบาย |
|
||
| ---------------------------------------------- | ---------------------------------------------------------------- |
|
||
| [User Guide](docs/USER_GUIDE.md) | ผู้ให้บริการ, คอมโบ, การรวม CLI, การปรับใช้ |
|
||
| [API Reference](docs/API_REFERENCE.md) | จุดสิ้นสุดทั้งหมดพร้อมตัวอย่าง |
|
||
| [MCP Server](open-sse/mcp-server/README.md) | เครื่องมือ MCP 16 รายการ, การกำหนดค่า IDE, ไคลเอนต์ Python/TS/Go |
|
||
| [A2A Server](src/lib/a2a/README.md) | โปรโตคอล JSON-RPC 2.0, ทักษะ, การสตรีม, การจัดการงาน |
|
||
| [Auto-Combo Engine](docs/auto-combo.md) | การให้คะแนน 6 ปัจจัย แพ็กโหมด การรักษาตัวเอง |
|
||
| [Troubleshooting](docs/TROUBLESHOOTING.md) | ปัญหาและแนวทางแก้ไขทั่วไป |
|
||
| [Architecture](docs/ARCHITECTURE.md) | สถาปัตยกรรมระบบและภายใน |
|
||
| [Contributing](CONTRIBUTING.md) | การตั้งค่าและแนวทางการพัฒนา |
|
||
| [OpenAPI Spec](docs/openapi.yaml) | ข้อมูลจำเพาะของ OpenAPI 3.0 |
|
||
| [Security Policy](SECURITY.md) | การรายงานช่องโหว่และแนวปฏิบัติด้านความปลอดภัย |
|
||
| [VM Deployment](docs/VM_DEPLOYMENT_GUIDE.md) | คู่มือฉบับสมบูรณ์: VM + nginx + การตั้งค่า Cloudflare |
|
||
| [Features Gallery](docs/FEATURES.md) | ทัวร์ชมแดชบอร์ดภาพพร้อมภาพหน้าจอ |
|
||
| [Release Checklist](docs/RELEASE_CHECKLIST.md) | ขั้นตอนการตรวจสอบก่อนเผยแพร่ |
|
||
|
||
---
|
||
|
||
## 🗺️ โรดแมป
|
||
|
||
OmniRoute มี **ฟีเจอร์มากกว่า 210 รายการที่วางแผน** ไว้ในขั้นตอนการพัฒนาหลายขั้นตอน นี่คือประเด็นสำคัญ:
|
||
|
||
| หมวดหมู่ | คุณสมบัติที่วางแผนไว้ | ไฮไลท์ |
|
||
| ------------------------------------------ | --------------------- | ------------------------------------------------------------------------------------------------------------- |
|
||
| 🧠 **การกำหนดเส้นทางและความฉลาด** | 25+ | การกำหนดเส้นทางที่มีความหน่วงต่ำที่สุด, การกำหนดเส้นทางตามแท็ก, โควต้า preflight, การเลือกบัญชี P2C |
|
||
| 🔒 **ความปลอดภัยและการปฏิบัติตามข้อกำหนด** | 20+ | การเสริมความแข็งแกร่งของ SSRF, การปิดบังข้อมูลรับรอง, ขีดจำกัดอัตราต่อจุดสิ้นสุด, การกำหนดขอบเขตคีย์การจัดการ |
|
||
| 📊 **ความสามารถในการสังเกต** | 15+ | การรวม OpenTelemetry การตรวจสอบโควต้าแบบเรียลไทม์ การติดตามต้นทุนต่อรุ่น |
|
||
| 🔄 **การบูรณาการของผู้ให้บริการ** | 20+ | การลงทะเบียนโมเดลแบบไดนามิก, คูลดาวน์ของผู้ให้บริการ, Codex หลายบัญชี, การแยกวิเคราะห์โควต้า Copilot |
|
||
| ⚡ **ประสิทธิภาพ** | 15+ | เลเยอร์แคชคู่, แคชพร้อมท์, แคชการตอบสนอง, การสตรีมแบบ Keepalive, ชุด API |
|
||
| 🌐 **ระบบนิเวศ** | 10+ | WebSocket API, กำหนดค่า hot-reload, การจัดเก็บ config แบบกระจาย, โหมดเชิงพาณิชย์ |
|
||
|
||
### 🔜 เร็วๆ นี้
|
||
|
||
- 🔗 **การรวม OpenCode** — รองรับผู้ให้บริการเนทีฟสำหรับ IDE การเข้ารหัส OpenCode AI
|
||
- 🔗 **การบูรณาการ TRAE** — รองรับกรอบการพัฒนา TRAE AI อย่างเต็มที่
|
||
- 📦 **Batch API** — การประมวลผลแบบแบตช์แบบอะซิงโครนัสสำหรับคำขอจำนวนมาก
|
||
- 🎯 **การกำหนดเส้นทางตามแท็ก** — คำขอกำหนดเส้นทางตามแท็กที่กำหนดเองและข้อมูลเมตา
|
||
- 💰 **กลยุทธ์ต้นทุนต่ำสุด** — เลือกผู้ให้บริการที่ถูกที่สุดโดยอัตโนมัติ
|
||
|
||
> dict ข้อมูลจำเพาะคุณสมบัติแบบเต็มมีอยู่ใน [**OMNI_TOKEN_342**](docs/new-features/) (ข้อมูลจำเพาะโดยละเอียด 217 รายการ)
|
||
|
||
---
|
||
|
||
## 👥 ผู้มีส่วนร่วม
|
||
|
||
[](https://github.com/diegosouzapw/OmniRoute/graphs/contributors)
|
||
|
||
### วิธีการมีส่วนร่วม
|
||
|
||
1. แยกพื้นที่เก็บข้อมูล
|
||
2. สร้างสาขาคุณลักษณะของคุณ (`git checkout -b feature/amazing-feature`)
|
||
3. ยอมรับการเปลี่ยนแปลงของคุณ (`git commit -m 'Add amazing feature'`)
|
||
4. กดไปที่สาขา (`git push origin feature/amazing-feature`)
|
||
5. เปิดคำขอดึง
|
||
|
||
ดู [CONTRIBUTING.md](CONTRIBUTING.md) สำหรับคำแนะนำโดยละเอียด
|
||
|
||
### เปิดตัวเวอร์ชันใหม่
|
||
|
||
```bash
|
||
# Create a release — npm publish happens automatically
|
||
gh release create v2.0.0 --title "v2.0.0" --generate-notes
|
||
```
|
||
|
||
---
|
||
|
||
## 📊 ประวัติดารา
|
||
|
||
## Stargazers เมื่อเวลาผ่านไป
|
||
|
||
## [](https://starchart.cc/diegosouzapw/OmniRoute)
|
||
|
||
## 🙏ขอบพระคุณ
|
||
|
||
ขอขอบคุณเป็นพิเศษกับ **[9router](https://github.com/decolua/9router)** โดย **[decolua](https://github.com/decolua)** — โปรเจ็กต์ดั้งเดิมที่เป็นแรงบันดาลใจให้กับ Fork นี้ OmniRoute สร้างบนรากฐานอันน่าทึ่งดังกล่าวด้วยคุณสมบัติเพิ่มเติม API หลายรูปแบบ และการเขียน TypeScript ใหม่ทั้งหมด
|
||
|
||
ขอขอบคุณเป็นพิเศษสำหรับ **[CLIProxyAPI](https://github.com/router-for-me/CLIProxyAPI)** — การใช้งาน Go ดั้งเดิมที่เป็นแรงบันดาลใจให้กับพอร์ต JavaScript นี้
|
||
|
||
---
|
||
|
||
## 📄 ใบอนุญาต
|
||
|
||
ใบอนุญาต MIT - ดู [LICENSE](LICENSE) สำหรับรายละเอียด
|
||
|
||
---
|
||
|
||
<div align="center">
|
||
<sub>สร้างด้วย ❤️ สำหรับนักพัฒนาที่เขียนโค้ด 24/7</sub>
|
||
<br/>
|
||
<sub><a href="https://omniroute.online">omniroute.online</a>OMNI_TOKEN_731__
|
||
</div>
|
||
<!-- เปิดใช้งานการสนทนา GitHub สำหรับชุมชนถาม & ตอบ -->
|