🌐 Languages: 🇺🇸 English | 🇧🇷 Português (Brasil) | 🇪🇸 Español | 🇫🇷 Français | 🇮🇹 Italiano | 🇷🇺 Русский | 🇨🇳 中文 (简体) | 🇩🇪 Deutsch | 🇮🇳 हिन्दी | 🇹🇭 ไทย | 🇺🇦 Українська | 🇸🇦 العربية | 🇯🇵 日本語 | 🇻🇳 Tiếng Việt | 🇧🇬 Български | 🇩🇰 Dansk | 🇫🇮 Suomi | 🇮🇱 עברית | 🇭🇺 Magyar | 🇮🇩 Bahasa Indonesia | 🇰🇷 한국어 | 🇲🇾 Bahasa Melayu | 🇳🇱 Nederlands | 🇳🇴 Norsk | 🇵🇹 Português (Portugal) | 🇷🇴 Română | 🇵🇱 Polski | 🇸🇰 Slovenčina | 🇸🇪 Svenska | 🇵🇭 Filipino
#omniroute — コードベースのドキュメント
omniroute マルチプロバイダー AI プロキシ ルーターに関する初心者向けの包括的なガイド。
オムニルートは、AI クライアント (Claude CLI、Codex、Cursor IDE など) と AI プロバイダー (Anthropic、Google、OpenAI、AWS、GitHub など) の間に位置する プロキシ ルーター です。これにより、1 つの大きな問題が解決されます。
異なる AI クライアントは異なる「言語」(API 形式) を話し、異なる AI プロバイダーも異なる「言語」を期待します。 オムニルートはそれらの間で自動的に翻訳します。
これを国連の万能翻訳者のようなものだと考えてください。どの代表者もあらゆる言語を話すことができ、翻訳者は他の代表者のためにそれを変換します。
graph LR
subgraph Clients
A[Claude CLI]
B[Codex]
C[Cursor IDE]
D[OpenAI-compatible]
end
subgraph omniroute
E[Handler Layer]
F[Translator Layer]
G[Executor Layer]
H[Services Layer]
end
subgraph Providers
I[Anthropic Claude]
J[Google Gemini]
K[OpenAI / Codex]
L[GitHub Copilot]
M[AWS Kiro]
N[Antigravity]
O[Cursor API]
end
A --> E
B --> E
C --> E
D --> E
E --> F
F --> G
G --> I
G --> J
G --> K
G --> L
G --> M
G --> N
G --> O
H -.-> E
H -.-> G
すべての形式変換は、OpenAI 形式をハブとして 通過します。
Client Format → [OpenAI Hub] → Provider Format (request)
Provider Format → [OpenAI Hub] → Client Format (response)
これは、N² (ペアごと) ではなく、N トランスレーター (フォーマットごとに 1 人) だけが必要であることを意味します。
omniroute/
├── open-sse/ ← Core proxy library (portable, framework-agnostic)
│ ├── index.js ← Main entry point, exports everything
│ ├── config/ ← Configuration & constants
│ ├── executors/ ← Provider-specific request execution
│ ├── handlers/ ← Request handling orchestration
│ ├── services/ ← Business logic (auth, models, fallback, usage)
│ ├── translator/ ← Format translation engine
│ │ ├── request/ ← Request translators (8 files)
│ │ ├── response/ ← Response translators (7 files)
│ │ └── helpers/ ← Shared translation utilities (6 files)
│ └── utils/ ← Utility functions
├── src/ ← Application layer (Express/Worker runtime)
│ ├── app/ ← Web UI, API routes, middleware
│ ├── lib/ ← Database, auth, and shared library code
│ ├── mitm/ ← Man-in-the-middle proxy utilities
│ ├── models/ ← Database models
│ ├── shared/ ← Shared utilities (wrappers around open-sse)
│ ├── sse/ ← SSE endpoint handlers
│ └── store/ ← State management
├── data/ ← Runtime data (credentials, logs)
│ └── provider-credentials.json (external credentials override, gitignored)
└── tester/ ← Test utilities
すべてのプロバイダー構成に関する 唯一の信頼できる情報源。
| ファイル | 目的 |
|---|---|
constants.ts |
PROVIDERS オブジェクトには、ベース URL、OAuth 資格情報 (デフォルト)、ヘッダー、および各プロバイダーのデフォルトのシステム プロンプトが含まれます。 HTTP_STATUS、ERROR_TYPES、COOLDOWN_MS、BACKOFF_CONFIG、および SKIP_PATTERNS も定義します。 |
credentialLoader.ts |
data/provider-credentials.json から外部資格情報をロードし、PROVIDERS のハードコードされたデフォルトにそれらをマージします。下位互換性を維持しながら、秘密をソース管理から除外します。 |
providerModels.ts |
中央モデル レジストリ: プロバイダーのエイリアス → モデル ID をマップします。 getModels()、getProviderByAlias() のような関数。 |
codexInstructions.ts |
Codex リクエストに挿入されるシステム命令 (編集制約、サンドボックス ルール、承認ポリシー)。 |
defaultThinkingSignature.ts |
Claude モデルと Gemini モデルのデフォルトの「思考」シグネチャ。 |
ollamaModels.ts |
ローカル Ollama モデルのスキーマ定義 (名前、サイズ、ファミリー、量子化)。 |
flowchart TD
A["App starts"] --> B["constants.ts defines PROVIDERS\nwith hardcoded defaults"]
B --> C{"data/provider-credentials.json\nexists?"}
C -->|Yes| D["credentialLoader reads JSON"]
C -->|No| E["Use hardcoded defaults"]
D --> F{"For each provider in JSON"}
F --> G{"Provider exists\nin PROVIDERS?"}
G -->|No| H["Log warning, skip"]
G -->|Yes| I{"Value is object?"}
I -->|No| J["Log warning, skip"]
I -->|Yes| K["Merge clientId, clientSecret,\ntokenUrl, authUrl, refreshUrl"]
K --> F
H --> F
J --> F
F -->|Done| L["PROVIDERS ready with\nmerged credentials"]
E --> L
エグゼキュータは、戦略パターンを使用してプロバイダ固有のロジックをカプセル化します。各エグゼキュータは、必要に応じて基本メソッドをオーバーライドします。
classDiagram
class BaseExecutor {
+buildUrl(model, stream, options)
+buildHeaders(credentials, stream, body)
+transformRequest(body, model, stream, credentials)
+execute(url, options)
+shouldRetry(status, error)
+refreshCredentials(credentials, log)
}
class DefaultExecutor {
+refreshCredentials()
}
class AntigravityExecutor {
+buildUrl()
+buildHeaders()
+transformRequest()
+shouldRetry()
+refreshCredentials()
}
class CursorExecutor {
+buildUrl()
+buildHeaders()
+transformRequest()
+parseResponse()
+generateChecksum()
}
class KiroExecutor {
+buildUrl()
+buildHeaders()
+transformRequest()
+parseEventStream()
+refreshCredentials()
}
BaseExecutor <|-- DefaultExecutor
BaseExecutor <|-- AntigravityExecutor
BaseExecutor <|-- CursorExecutor
BaseExecutor <|-- KiroExecutor
BaseExecutor <|-- CodexExecutor
BaseExecutor <|-- GeminiCLIExecutor
BaseExecutor <|-- GithubExecutor
| 執行者 | プロバイダー | 主な専門分野 |
|---|---|---|
base.ts |
— | 抽象ベース: URL 構築、ヘッダー、再試行ロジック、資格情報の更新 |
default.ts |
クロード、ジェミニ、OpenAI、GLM、キミ、MiniMax | 標準プロバイダーの汎用 OAuth トークンの更新 |
antigravity.ts |
Googleクラウドコード | プロジェクト/セッション ID の生成、マルチ URL フォールバック、エラー メッセージからのカスタム再試行解析 (「2 時間 7 分 23 秒後にリセット」) |
cursor.ts |
カーソルIDE | 最も複雑: SHA-256 チェックサム認証、Protobuf リクエスト エンコード、バイナリ EventStream → SSE レスポンス解析 |
codex.ts |
OpenAI コーデックス | システム命令の挿入、思考レベルの管理、サポートされていないパラメータの削除 |
gemini-cli.ts |
Google Gemini CLI | カスタム URL の構築 (streamGenerateContent)、Google OAuth トークンの更新 |
github.ts |
GitHub コパイロット | デュアル トークン システム (GitHub OAuth + Copilot トークン)、VSCode ヘッダーの模倣 |
kiro.ts |
AWS CodeWhisperer | AWS EventStream バイナリ解析、AMZN イベント フレーム、トークン推定 |
index.ts |
— | ファクトリ: デフォルトのフォールバックを使用して、プロバイダー名 → エグゼキューター クラスをマップします。 |
オーケストレーション レイヤー — 変換、実行、ストリーミング、エラー処理を調整します。
| ファイル | 目的 |
|---|---|
chatCore.ts |
中央オーケストレーター (約 600 行)。リクエストのライフサイクル全体を処理します: フォーマット検出→変換→エグゼキュータディスパッチ→ストリーミング/非ストリーミング応答→トークン更新→エラー処理→使用状況ログ。 |
responsesHandler.ts |
OpenAI の応答 API 用アダプター: 応答形式を変換 → チャット完了 → chatCore に送信 → SSE を応答形式に変換します。 |
embeddings.ts |
埋め込み生成ハンドラー: 埋め込みモデル→プロバイダーを解決し、プロバイダー API にディスパッチし、OpenAI 互換の埋め込み応答を返します。 6 つ以上のプロバイダーをサポートします。 |
imageGeneration.ts |
イメージ生成ハンドラー: イメージ モデル → プロバイダーを解決し、OpenAI 互換、Gemini イメージ (Antigravity)、およびフォールバック (Nebius) モードをサポートします。 Base64 または URL イメージを返します。 |
sequenceDiagram
participant Client
participant chatCore
participant Translator
participant Executor
participant Provider
Client->>chatCore: Request (any format)
chatCore->>chatCore: Detect source format
chatCore->>chatCore: Check bypass patterns
chatCore->>chatCore: Resolve model & provider
chatCore->>Translator: Translate request (source → OpenAI → target)
chatCore->>Executor: Get executor for provider
Executor->>Executor: Build URL, headers, transform request
Executor->>Executor: Refresh credentials if needed
Executor->>Provider: HTTP fetch (streaming or non-streaming)
alt Streaming
Provider-->>chatCore: SSE stream
chatCore->>chatCore: Pipe through SSE transform stream
Note over chatCore: Transform stream translates<br/>each chunk: target → OpenAI → source
chatCore-->>Client: Translated SSE stream
else Non-streaming
Provider-->>chatCore: JSON response
chatCore->>Translator: Translate response
chatCore-->>Client: Translated JSON
end
alt Error (401, 429, 500...)
chatCore->>Executor: Retry with credential refresh
chatCore->>chatCore: Account fallback logic
end
ハンドラーとエグゼキューターをサポートするビジネス ロジック。
| ファイル | 目的 |
|---|---|
provider.ts |
形式検出 (detectFormat): リクエスト本文の構造を分析して、Claude/OpenAI/Gemini/Antigravity/Responses 形式を識別します (Claude の max_tokens ヒューリスティックを含む)。また、URL の構築、ヘッダーの構築、思考構成の正規化も行います。 openai-compatible-* および anthropic-compatible-* 動的プロバイダーをサポートします。 |
model.ts |
モデル文字列解析 (claude/model-name → {provider: "claude", model: "model-name"})、衝突検出によるエイリアス解決、入力サニタイズ (パス トラバーサル/制御文字の拒否)、および非同期エイリアス ゲッター サポートによるモデル情報解決。 |
accountFallback.ts |
レート制限の処理: 指数関数的バックオフ (1 秒 → 2 秒 → 4 秒 → 最大 2 分)、アカウントのクールダウン管理、エラー分類 (どのエラーがフォールバックをトリガーするのか、トリガーしないのか)。 |
tokenRefresh.ts |
すべてのプロバイダの OAuth トークン更新: Google (Gemini、Antigravity)、Claude、Codex、Qwen、iFlow、GitHub (OAuth + Copilot デュアル トークン)、Kiro (AWS SSO OIDC + Social Auth)。実行中の Promise 重複排除キャッシュと指数バックオフによる再試行が含まれます。 |
combo.ts |
コンボ モデル: フォールバック モデルのチェーン。モデル A がフォールバック対象エラーで失敗した場合は、モデル B、次にモデル C などを試します。実際のアップストリーム ステータス コードを返します。 |
usage.ts |
プロバイダー API からクォータ/使用量データを取得します (GitHub Copilot クォータ、反重力モデル クォータ、Codex レート制限、Kiro 使用量の内訳、Claude 設定)。 |
accountSelector.ts |
スコアリング アルゴリズムを使用したスマートなアカウント選択: 優先度、健全性ステータス、ラウンドロビン ポジション、クールダウン状態を考慮して、各リクエストに最適なアカウントを選択します。 |
contextManager.ts |
リクエスト コンテキストのライフサイクル管理: デバッグとロギングのために、メタデータ (リクエスト ID、タイムスタンプ、プロバイダー情報) を含むリクエストごとのコンテキスト オブジェクトを作成および追跡します。 |
ipFilter.ts |
IP ベースのアクセス制御: ホワイトリスト モードとブロックリスト モードをサポートします。 API リクエストを処理する前に、設定されたルールに照らしてクライアント IP を検証します。 |
sessionManager.ts |
クライアント フィンガープリントによるセッション追跡: ハッシュされたクライアント ID を使用してアクティブなセッションを追跡し、リクエスト数を監視し、セッション メトリックを提供します。 |
signatureCache.ts |
リクエスト署名ベースの重複排除キャッシュ: 最近のリクエスト署名をキャッシュし、時間枠内の同一リクエストに対してキャッシュされた応答を返すことで、リクエストの重複を防ぎます。 |
systemPrompt.ts |
グローバル システム プロンプト インジェクション: プロバイダーごとの互換性処理を使用して、構成可能なシステム プロンプトをすべてのリクエストの先頭または末尾に追加します。 |
thinkingBudget.ts |
推論トークンの予算管理: 思考/推論トークンを制御するためのパススルー、自動 (ストリップ思考構成)、カスタム (固定予算)、および適応型 (複雑さスケール) モードをサポートします。 |
wildcardRouter.ts |
ワイルドカード モデル パターン ルーティング: 可用性と優先度に基づいて、ワイルドカード パターン (*/claude-* など) を具体的なプロバイダー/モデルのペアに解決します。 |
sequenceDiagram
participant R1 as Request 1
participant R2 as Request 2
participant Cache as refreshPromiseCache
participant OAuth as OAuth Provider
R1->>Cache: getAccessToken("gemini", token)
Cache->>Cache: No in-flight promise
Cache->>OAuth: Start refresh
R2->>Cache: getAccessToken("gemini", token)
Cache->>Cache: Found in-flight promise
Cache-->>R2: Return existing promise
OAuth-->>Cache: New access token
Cache-->>R1: New access token
Cache-->>R2: Same access token (shared)
Cache->>Cache: Delete cache entry
stateDiagram-v2
[*] --> Active
Active --> Error: Request fails (401/429/500)
Error --> Cooldown: Apply backoff
Cooldown --> Active: Cooldown expires
Active --> Active: Request succeeds (reset backoff)
state Error {
[*] --> ClassifyError
ClassifyError --> ShouldFallback: Rate limit / Auth / Transient
ClassifyError --> NoFallback: 400 Bad Request
}
state Cooldown {
[*] --> ExponentialBackoff
ExponentialBackoff: Level 0 = 1s
ExponentialBackoff: Level 1 = 2s
ExponentialBackoff: Level 2 = 4s
ExponentialBackoff: Max = 2min
}
flowchart LR
A["Request with\ncombo model"] --> B["Model A"]
B -->|"2xx Success"| C["Return response"]
B -->|"429/401/500"| D{"Fallback\neligible?"}
D -->|Yes| E["Model B"]
D -->|No| F["Return error"]
E -->|"2xx Success"| C
E -->|"429/401/500"| G{"Fallback\neligible?"}
G -->|Yes| H["Model C"]
G -->|No| F
H -->|"2xx Success"| C
H -->|"Fail"| I["All failed →\nReturn last status"]
自己登録プラグイン システムを使用した フォーマット変換エンジン。
graph TD
subgraph "Request Translation"
A["Claude → OpenAI"]
B["Gemini → OpenAI"]
C["Antigravity → OpenAI"]
D["OpenAI Responses → OpenAI"]
E["OpenAI → Claude"]
F["OpenAI → Gemini"]
G["OpenAI → Kiro"]
H["OpenAI → Cursor"]
end
subgraph "Response Translation"
I["Claude → OpenAI"]
J["Gemini → OpenAI"]
K["Kiro → OpenAI"]
L["Cursor → OpenAI"]
M["OpenAI → Claude"]
N["OpenAI → Antigravity"]
O["OpenAI → Responses"]
end
| ディレクトリ | ファイル | 説明 |
|---|---|---|
request/ |
翻訳者8名 | リクエストボディをフォーマット間で変換します。各ファイルは、インポート時に register(from, to, fn) を介して自己登録されます。 |
response/ |
翻訳者 7 名 | ストリーミング応答チャンクをフォーマット間で変換します。 SSE イベント タイプ、思考ブロック、ツール呼び出しを処理します。 |
helpers/ |
6人のヘルパー | 共有ユーティリティ: claudeHelper (システム プロンプト抽出、シンキング構成)、geminiHelper (パーツ/コンテンツ マッピング)、openaiHelper (フォーマット フィルタリング)、toolCallHelper (ID 生成、欠落応答挿入)、maxTokensHelper、responsesApiHelper。 |
index.ts |
— | 変換エンジン: translateRequest()、translateResponse()、状態管理、レジストリ。 |
formats.ts |
— | フォーマット定数: OPENAI、CLAUDE、GEMINI、ANTIGRAVITY、KIRO、CURSOR、OPENAI_RESPONSES。 |
// Each translator file calls register() on import:
import { register } from "../index.js";
register("claude", "openai", translateClaudeToOpenAI);
// The index.js imports all translator files, triggering registration:
import "./request/claude-to-openai.js"; // ← self-registers| ファイル | 目的 |
|---|---|
error.ts |
エラー応答の構築 (OpenAI 互換形式)、アップストリーム エラー解析、エラー メッセージからの反重力再試行時間の抽出、SSE エラー ストリーミング。 |
stream.ts |
SSE Transform Stream — コア ストリーミング パイプライン。 2 つのモード: TRANSLATE (完全な形式の変換) と PASSTHROUGH (正規化 + 使用法の抽出)。チャンクのバッファリング、使用量の推定、コンテンツの長さの追跡を処理します。ストリームごとのエンコーダ/デコーダ インスタンスは共有状態を回避します。 |
streamHelpers.ts |
低レベル SSE ユーティリティ: parseSSELine (ホワイトスペース耐性)、hasValuableContent (OpenAI/Claude/Gemini の空のチャンクをフィルタリング)、fixInvalidId、formatSSE (perf_metrics クリーンアップによる形式認識 SSE シリアル化)。 |
usageTracking.ts |
任意の形式 (Claude/OpenAI/Gemini/Responses) からのトークン使用量の抽出、別個のツール/メッセージの文字数とトークンの比率による推定、バッファーの追加 (2000 トークンの安全マージン)、形式固有のフィールド フィルタリング、ANSI カラーでのコンソール ロギング。 |
requestLogger.ts |
ファイルベースのリクエストログ (ENABLE_REQUEST_LOGS=true によるオプトイン)。番号付きファイルを含むセッション フォルダーを作成します: 1_req_client.json → 7_res_client.txt。すべての I/O は非同期 (ファイア アンド フォーゲット) です。機密ヘッダーをマスクします。 |
bypassHandler.ts |
Claude CLI からの特定のパターン (タイトル抽出、ウォームアップ、カウント) を傍受し、プロバイダーを呼び出さずに偽の応答を返します。ストリーミングと非ストリーミングの両方をサポートします。意図的に Claude CLI スコープに限定されています。 |
networkProxy.ts |
指定されたプロバイダーの送信プロキシ URL を優先順位で解決します: プロバイダー固有の構成 → グローバル構成 → 環境変数 (HTTPS_PROXY/HTTP_PROXY/ALL_PROXY)。 NO_PROXY の除外をサポートします。設定を 30 秒間キャッシュします。 |
flowchart TD
A["Provider SSE stream"] --> B["TextDecoder\n(per-stream instance)"]
B --> C["Buffer lines\n(split on newline)"]
C --> D["parseSSELine()\n(trim whitespace, parse JSON)"]
D --> E{"Mode?"}
E -->|TRANSLATE| F["translateResponse()\ntarget → OpenAI → source"]
E -->|PASSTHROUGH| G["fixInvalidId()\nnormalize chunk"]
F --> H["hasValuableContent()\nfilter empty chunks"]
G --> H
H -->|"Has content"| I["extractUsage()\ntrack token counts"]
H -->|"Empty"| J["Skip chunk"]
I --> K["formatSSE()\nserialize + clean perf_metrics"]
K --> L["TextEncoder\n(per-stream instance)"]
L --> M["Enqueue to\nclient stream"]
style A fill:#f9f,stroke:#333
style M fill:#9f9,stroke:#333
logs/
└── claude_gemini_claude-sonnet_20260208_143045/
├── 1_req_client.json ← Raw client request
├── 2_req_source.json ← After initial conversion
├── 3_req_openai.json ← OpenAI intermediate format
├── 4_req_target.json ← Final target format
├── 5_res_provider.txt ← Provider SSE chunks (streaming)
├── 5_res_provider.json ← Provider response (non-streaming)
├── 6_res_openai.txt ← OpenAI intermediate chunks
├── 7_res_client.txt ← Client-facing SSE chunks
└── 6_error.json ← Error details (if any)
| ディレクトリ | 目的 |
|---|---|
src/app/ |
Web UI、API ルート、Express ミドルウェア、OAuth コールバック ハンドラー |
src/lib/ |
データベース アクセス (localDb.ts、usageDb.ts)、認証、共有 |
src/mitm/ |
プロバイダーのトラフィックを傍受する中間者プロキシ ユーティリティ |
src/models/ |
データベースモデルの定義 |
src/shared/ |
open-sse 関数 (プロバイダー、ストリーム、エラーなど) のラッパー |
src/sse/ |
open-sse ライブラリを Express ルートに接続する SSE エンドポイント ハンドラー |
src/store/ |
アプリケーション状態管理 |
| ルート | メソッド | 目的 |
|---|---|---|
/api/provider-models |
取得/投稿/削除 | プロバイダーごとのカスタム モデルの CRUD |
/api/models/catalog |
入手 | プロバイダーごとにグループ化されたすべてのモデル (チャット、埋め込み、イメージ、カスタム) の集約カタログ |
/api/settings/proxy |
取得/挿入/削除 | 階層型送信プロキシ構成 (global/providers/combos/keys) |
/api/settings/proxy/test |
投稿 | プロキシ接続を検証し、パブリック IP/遅延を返します。 |
/v1/providers/[provider]/chat/completions |
投稿 | モデル検証を備えたプロバイダーごとの専用チャット補完 |
/v1/providers/[provider]/embeddings |
投稿 | モデル検証を備えたプロバイダーごとの専用埋め込み |
/v1/providers/[provider]/images/generations |
投稿 | モデル検証を備えたプロバイダーごとの専用イメージ生成 |
/api/settings/ip-filter |
GET/PUT | IP ホワイトリスト/ブロックリスト管理 |
/api/settings/thinking-budget |
GET/PUT | 推論トークンの予算構成 (パススルー/自動/カスタム/アダプティブ) |
/api/settings/system-prompt |
GET/PUT | すべてのリクエストに対するグローバル システム プロンプト インジェクション |
/api/sessions |
入手 | アクティブなセッションの追跡とメトリクス |
/api/rate-limits |
入手 | アカウントごとのレート制限ステータス |
すべての形式は OpenAI 形式をハブとして変換します。新しいプロバイダーを追加するには、N ペアではなく、1 ペア のトランスレーター (OpenAI との間) を作成するだけで済みます。
各プロバイダーには、BaseExecutor を継承する専用の実行クラスがあります。 executors/index.ts のファクトリは、実行時に正しいものを選択します。
トランスレータ モジュールは、インポート時に register() を介して自身を登録します。新しいトランスレータを追加するには、ファイルを作成してインポートするだけです。
プロバイダーが 429/401/500 を返すと、システムは次のアカウントに切り替えて、指数関数的なクールダウン (1 秒 → 2 秒 → 4 秒 → 最大 2 分) を適用できます。
「コンボ」は、複数の provider/model 文字列をグループ化します。最初の処理が失敗した場合は、自動的に次の処理にフォールバックします。
応答の変換は、initState() メカニズムを介して、SSE チャンク全体 (思考ブロックの追跡、ツール呼び出しの蓄積、コンテンツ ブロックのインデックス作成) の状態を維持します。
システム プロンプトや形式変換によるオーバーヘッドによってクライアントがコンテキスト ウィンドウの制限に達するのを防ぐために、報告された使用量に 2000 トークンのバッファーが追加されます。
| フォーマット | 方向 | 識別子 |
|---|---|---|
| OpenAI チャットの完了 | ソース + ターゲット | openai |
| OpenAI レスポンス API | ソース + ターゲット | openai-responses |
| 人間のクロード | ソース + ターゲット | claude |
| Google ジェミニ | ソース + ターゲット | gemini |
| Google Gemini CLI | ターゲットのみ | gemini-cli |
| 反重力 | ソース + ターゲット | antigravity |
| AWS キロ | ターゲットのみ | kiro |
| カーソル | ターゲットのみ | cursor |
| プロバイダー | 認証方法 | 執行者 | 重要なメモ |
|---|---|---|---|
| 人間のクロード | API キーまたは OAuth | デフォルト | x-api-key ヘッダーを使用します。 |
| Google ジェミニ | API キーまたは OAuth | デフォルト | x-goog-api-key ヘッダーを使用します。 |
| Google Gemini CLI | OAuth | ジェミニCLI | streamGenerateContent エンドポイントを使用します。 |
| 反重力 | OAuth | 反重力 | マルチ URL フォールバック、カスタム再試行解析 |
| オープンAI | APIキー | デフォルト | 標準ベアラー認証 |
| コーデックス | OAuth | コーデックス | システム命令を注入し、思考を管理します |
| GitHub コパイロット | OAuth + コパイロット トークン | ギットハブ | デュアル トークン、VSCode ヘッダーの模倣 |
| キロ (AWS) | AWS SSO OIDC またはソーシャル | キロ | バイナリ EventStream 解析 |
| カーソルIDE | チェックサム認証 | カーソル | Protobuf エンコーディング、SHA-256 チェックサム |
| クウェン | OAuth | デフォルト | 標準認証 |
| iFlow | OAuth (ベーシック + ベアラー) | デフォルト | デュアル認証ヘッダー |
| オープンルーター | APIキー | デフォルト | 標準ベアラー認証 |
| GLM、キミ、ミニマックス | APIキー | デフォルト | Claude と互換性があるため、x-api-key を使用してください。 |
openai-compatible-* |
APIキー | デフォルト | 動的: 任意の OpenAI 互換エンドポイント |
anthropic-compatible-* |
APIキー | デフォルト | 動的: クロードと互換性のある任意のエンドポイント |
flowchart LR
A["Client"] --> B["detectFormat()"]
B --> C["translateRequest()\nsource → OpenAI → target"]
C --> D["Executor\nbuildUrl + buildHeaders"]
D --> E["fetch(providerURL)"]
E --> F["createSSEStream()\nTRANSLATE mode"]
F --> G["parseSSELine()"]
G --> H["translateResponse()\ntarget → OpenAI → source"]
H --> I["extractUsage()\n+ addBuffer"]
I --> J["formatSSE()"]
J --> K["Client receives\ntranslated SSE"]
K --> L["logUsage()\nsaveRequestUsage()"]
flowchart LR
A["Client"] --> B["detectFormat()"]
B --> C["translateRequest()\nsource → OpenAI → target"]
C --> D["Executor.execute()"]
D --> E["translateResponse()\ntarget → OpenAI → source"]
E --> F["Return JSON\nresponse"]
flowchart LR
A["Claude CLI request"] --> B{"Match bypass\npattern?"}
B -->|"Title/Warmup/Count"| C["Generate fake\nOpenAI response"]
B -->|"No match"| D["Normal flow"]
C --> E["Translate to\nsource format"]
E --> F["Return without\ncalling provider"]