// MITM Tools — IDE tools intercepted via MITM proxy export const MITM_TOOLS = { antigravity: { id: "antigravity", name: "Antigravity", image: "/providers/antigravity.png", color: "#4285F4", description: "Google Antigravity IDE with MITM", configType: "mitm", mitmDomain: "daily-cloudcode-pa.googleapis.com", modelAliases: ["claude-opus-4-6-thinking", "claude-sonnet-4-6", "gemini-3-flash", "gpt-oss-120b-medium", "gemini-3-pro-high", "gemini-3-pro-low", "gemini-pro-agent"], defaultModels: [ { id: "gemini-pro-agent", name: "Gemini Pro Agent (AG v1.23+ Agent Mode)", alias: "gemini-pro-agent" }, { id: "gemini-3.1-pro-high", name: "Gemini 3.1 Pro High", alias: "gemini-3.1-pro-high" }, { id: "gemini-3.1-pro-low", name: "Gemini 3.1 Pro Low", alias: "gemini-3.1-pro-low" }, { id: "gemini-3-flash", name: "Gemini 3 Flash / Default", alias: "gemini-3-flash" }, { id: "claude-sonnet-4-6", name: "Claude Sonnet 4.6", alias: "claude-sonnet-4-6" }, { id: "claude-opus-4-6-thinking", name: "Claude Opus 4.6 Thinking", alias: "claude-opus-4-6-thinking" }, { id: "gpt-oss-120b-medium", name: "GPT OSS 120B Medium", alias: "gpt-oss-120b-medium" }, ], }, copilot: { id: "copilot", name: "GitHub Copilot", image: "/providers/copilot.png", color: "#1F6FEB", description: "GitHub Copilot IDE with MITM", configType: "mitm", mitmDomain: "api.individual.githubcopilot.com", modelAliases: ["gpt-4o-mini", "claude-haiku-4.5", "gpt-4o", "gpt-5-mini"], defaultModels: [ { id: "gpt-4o", name: "GPT-4o", alias: "gpt-4o" }, { id: "gpt-4.1", name: "GPT-4.1", alias: "gpt-4.1" }, { id: "claude-haiku-4.5", name: "Claude Haiku 4.5", alias: "claude-haiku-4.5" }, ], }, kiro: { id: "kiro", name: "Kiro", image: "/providers/kiro.png", color: "#FF6B00", description: "Kiro IDE with MITM", configType: "mitm", mitmDomain: "q.us-east-1.amazonaws.com", defaultModels: [ { id: "claude-sonnet-4.5", name: "Claude Sonnet 4.5", alias: "claude-sonnet-4.5" }, { id: "claude-sonnet-4", name: "Claude Sonnet 4", alias: "claude-sonnet-4" }, { id: "claude-haiku-4.5", name: "Claude Haiku 4.5", alias: "claude-haiku-4.5" }, { id: "deepseek-3.2", name: "DeepSeek 3.2", alias: "deepseek-3.2" }, { id: "minimax-m2.1", name: "MiniMax M2.1", alias: "minimax-m2.1" }, { id: "simple-task", name: "Qwen3 Coder Next", alias: "simple-task" }, ], }, // cursor: { // id: "cursor", // name: "Cursor", // image: "/providers/cursor.png", // color: "#000000", // description: "Cursor IDE with MITM", // configType: "mitm", // mitmDomain: "api2.cursor.sh", // defaultModels: [ // { id: "claude-sonnet-4-5", name: "Claude Sonnet 4.5", alias: "claude-sonnet-4-5" }, // { id: "claude-opus-4", name: "Claude Opus 4", alias: "claude-opus-4" }, // { id: "gpt-4o", name: "GPT-4o", alias: "gpt-4o" }, // ], // }, }; // CLI Tools configuration export const CLI_TOOLS = { claude: { id: "claude", name: "Claude Code", image: "/providers/claude.png", color: "#D97757", description: "Anthropic Claude Code CLI", configType: "env", envVars: { baseUrl: "ANTHROPIC_BASE_URL", model: "ANTHROPIC_MODEL", opusModel: "ANTHROPIC_DEFAULT_OPUS_MODEL", sonnetModel: "ANTHROPIC_DEFAULT_SONNET_MODEL", haikuModel: "ANTHROPIC_DEFAULT_HAIKU_MODEL", }, modelAliases: ["default", "sonnet", "opus", "haiku", "opusplan"], settingsFile: "~/.claude/settings.json", defaultModels: [ { id: "opus", name: "Claude Opus", alias: "opus", envKey: "ANTHROPIC_DEFAULT_OPUS_MODEL", defaultValue: "cc/claude-opus-4-6" }, { id: "sonnet", name: "Claude Sonnet", alias: "sonnet", envKey: "ANTHROPIC_DEFAULT_SONNET_MODEL", defaultValue: "cc/claude-sonnet-4-6" }, { id: "haiku", name: "Claude Haiku", alias: "haiku", envKey: "ANTHROPIC_DEFAULT_HAIKU_MODEL", defaultValue: "cc/claude-haiku-4-5-20251001" }, ], }, openclaw: { id: "openclaw", name: "Open Claw", image: "/providers/openclaw.png", color: "#FF6B35", description: "Open Claw AI Assistant", configType: "custom", }, codex: { id: "codex", name: "OpenAI Codex CLI / App", image: "/providers/codex.png", color: "#10A37F", description: "OpenAI Codex CLI", configType: "custom", }, opencode: { id: "opencode", name: "OpenCode", image: "/providers/opencode.png", color: "#E87040", description: "OpenCode AI Terminal Assistant", configType: "custom", }, cowork: { id: "cowork", name: "Claude Cowork", image: "/providers/claude.png", color: "#D97757", description: "Claude Desktop Cowork (third-party inference)", configType: "custom", }, hermes: { id: "hermes", name: "Hermes Agent", image: "/providers/hermes.png", color: "#8B5CF6", description: "Nous Research self-improving AI agent", configType: "custom", }, droid: { id: "droid", name: "Factory Droid", image: "/providers/droid.png", color: "#00D4FF", description: "Factory Droid AI Assistant", configType: "custom", }, cursor: { id: "cursor", name: "Cursor", image: "/providers/cursor.png", color: "#000000", description: "Cursor AI Code Editor", configType: "guide", requiresExternalUrl: true, notes: [ { type: "warning", text: "Requires Cursor Pro account to use this feature." }, { type: "cloudCheck", text: "Cursor routes requests through its own server, so local endpoint is not supported. Please enable Tunnel or Cloud Endpoint in Settings." }, ], guideSteps: [ { step: 1, title: "Open Settings", desc: "Go to Settings → Models" }, { step: 2, title: "Enable OpenAI API", desc: "Enable \"OpenAI API key\" option" }, { step: 3, title: "Base URL", value: "{{baseUrl}}", copyable: true }, { step: 4, title: "API Key", type: "apiKeySelector" }, { step: 5, title: "Add Custom Model", desc: "Click \"View All Model\" → \"Add Custom Model\"" }, { step: 6, title: "Select Model", type: "modelSelector" }, ], }, cline: { id: "cline", name: "Cline", image: "/providers/cline.png", color: "#00D1B2", description: "Cline AI Coding Assistant", configType: "custom", }, kilo: { id: "kilo", name: "Kilo Code", image: "/providers/kilocode.png", color: "#FF6B6B", description: "Kilo Code AI Assistant", configType: "custom", }, roo: { id: "roo", name: "Roo", image: "/providers/roo.png", color: "#FF6B6B", description: "Roo AI Assistant", configType: "guide", guideSteps: [ { step: 1, title: "Open Settings", desc: "Go to Roo Settings panel" }, { step: 2, title: "Select Provider", desc: "Choose API Provider → Ollama" }, { step: 3, title: "Base URL", value: "{{baseUrl}}", copyable: true }, { step: 4, title: "API Key", type: "apiKeySelector" }, { step: 5, title: "Select Model", type: "modelSelector" }, ], }, continue: { id: "continue", name: "Continue", image: "/providers/continue.png", color: "#7C3AED", description: "Continue AI Assistant", configType: "guide", guideSteps: [ { step: 1, title: "Open Config", desc: "Open Continue configuration file" }, { step: 2, title: "API Key", type: "apiKeySelector" }, { step: 3, title: "Select Model", type: "modelSelector" }, { step: 4, title: "Add Model Config", desc: "Add the following configuration to your models array:" }, ], codeBlock: { language: "json", code: `{ "apiBase": "{{baseUrl}}", "title": "{{model}}", "model": "{{model}}", "provider": "openai", "apiKey": "{{apiKey}}" }`, }, }, amp: { id: "amp", name: "Amp CLI", image: "/providers/amp.png", color: "#F97316", description: "Sourcegraph Amp coding assistant CLI", docsUrl: "/docs?section=cli-tools&tool=amp", configType: "guide", defaultCommand: "amp", modelAliases: ["g25p", "g25f", "cs45", "g54"], notes: [ { type: "info", text: "Use 9Router model aliases to keep Amp shorthand mappings stable across provider updates." }, { type: "warning", text: "Suggested shorthand examples: g25p → gemini/gemini-2.5-pro, g25f → gemini/gemini-2.5-flash, cs45 → cc/claude-sonnet-4-5-20250929." }, ], guideSteps: [ { step: 1, title: "Install Amp", desc: "Install the Amp CLI using the package manager supported by your environment." }, { step: 2, title: "API Key", type: "apiKeySelector" }, { step: 3, title: "Base URL", value: "{{baseUrl}}", copyable: true }, { step: 4, title: "Select Model", type: "modelSelector" }, { step: 5, title: "Add Shorthands", desc: "Map Amp shorthand names such as g25p or cs45 to 9Router aliases in your local config." }, ], codeBlock: { language: "bash", code: `export OPENAI_API_KEY="{{apiKey}}" export OPENAI_BASE_URL="{{baseUrl}}" amp --model "{{model}}" # Example shorthand aliases you can map locally: # g25p -> gemini/gemini-2.5-pro # cs45 -> cc/claude-sonnet-4-5-20250929`, }, }, qwen: { id: "qwen", name: "Qwen Code", image: "/providers/qwen.png", color: "#10B981", description: "Alibaba Qwen Code CLI — supports OpenAI, Anthropic & Gemini providers via 9Router", docsUrl: "https://qwenlm.github.io/qwen-code-docs/en/users/configuration/model-providers/", configType: "guide", defaultCommand: "qwen", notes: [ { type: "info", text: "Qwen Code supports multiple provider types (openai, anthropic, gemini) via modelProviders in settings.json. 9Router works as an OpenAI-compatible endpoint." }, { type: "info", text: "Any model available in 9Router can be used — not just Qwen models. Select from Qwen, Claude, Gemini, GPT, and more." }, { type: "warning", text: "Config path: Linux/macOS ~/.qwen/settings.json • Windows %USERPROFILE%\\.qwen\\settings.json" }, { type: "error", text: "Qwen OAuth free tier was discontinued on 2026-04-15. Use 9Router with alicode/openrouter/anthropic/gemini providers instead." }, ], modelAliases: ["coder-model", "qwen3-coder-plus", "qwen3-coder-flash", "vision-model", "claude-sonnet-4-6", "claude-opus-4-6-thinking", "gemini-3-flash", "gemini-3.1-pro-high"], defaultModels: [ { id: "coder-model", name: "Coder Model (Qwen 3.6 Plus)", alias: "coder-model", envKey: "OPENAI_MODEL", defaultValue: "coder-model", isTopLevel: true }, { id: "qwen3-coder-plus", name: "Qwen 3 Coder Plus", alias: "qwen3-coder-plus", envKey: "OPENAI_MODEL", defaultValue: "qwen3-coder-plus" }, { id: "qwen3-coder-flash", name: "Qwen 3 Coder Flash", alias: "qwen3-coder-flash", envKey: "OPENAI_MODEL", defaultValue: "qwen3-coder-flash" }, { id: "vision-model", name: "Vision Model (Multimodal)", alias: "vision-model", envKey: "OPENAI_MODEL", defaultValue: "vision-model" }, { id: "claude-sonnet-4-6", name: "Claude Sonnet 4.6", alias: "claude-sonnet-4-6", envKey: "OPENAI_MODEL", defaultValue: "claude-sonnet-4-6" }, { id: "claude-opus-4-6-thinking", name: "Claude Opus 4.6 Thinking", alias: "claude-opus-4-6-thinking", envKey: "OPENAI_MODEL", defaultValue: "claude-opus-4-6-thinking" }, { id: "gemini-3.1-pro-high", name: "Gemini 3.1 Pro High", alias: "gemini-3.1-pro-high", envKey: "OPENAI_MODEL", defaultValue: "gemini-3.1-pro-high" }, { id: "gemini-3-flash", name: "Gemini 3 Flash", alias: "gemini-3-flash", envKey: "OPENAI_MODEL", defaultValue: "gemini-3-flash" }, ], guideSteps: [ { step: 1, title: "Install Qwen Code", desc: "npm install -g @qwen-code/qwen-code" }, { step: 2, title: "API Key", type: "apiKeySelector" }, { step: 3, title: "Base URL", value: "{{baseUrl}}", copyable: true }, { step: 4, title: "Select Model", type: "modelSelector" }, { step: 5, title: "Save Config", desc: "Copy the JSON below to your ~/.qwen/settings.json file." }, ], codeBlock: { language: "json", code: `{ "security": { "auth": { "selectedType": "openai", "apiKey": "{{apiKey}}", "baseUrl": "{{baseUrl}}" } }, "model": { "name": "{{model}}" } }`, }, }, "deepseek-tui": { id: "deepseek-tui", name: "DeepSeek TUI", image: "/providers/deepseek-tui.png", color: "#4D6BFE", description: "DeepSeek Terminal Coding Agent (Rust TUI)", docsUrl: "https://github.com/DeepSeek-TUI/DeepSeek-TUI", configType: "custom", defaultCommand: "deepseek", modelAliases: ["deepseek-v4-pro", "deepseek-v4-flash", "deepseek-chat", "deepseek-reasoner"], defaultModels: [ { id: "deepseek-v4-pro", name: "DeepSeek V4 Pro", alias: "deepseek-v4-pro" }, { id: "deepseek-v4-flash", name: "DeepSeek V4 Flash", alias: "deepseek-v4-flash" }, { id: "deepseek-chat", name: "DeepSeek V3 Chat", alias: "deepseek-chat" }, ], notes: [ { type: "info", text: "DeepSeek TUI uses ~/.deepseek/config.toml for configuration. 9Router will update the provider to 'openai' mode with your base_url, api_key, and model." }, { type: "warning", text: "Config path: Linux/macOS ~/.deepseek/config.toml • Windows %USERPROFILE%\\.deepseek\\config.toml" }, ], }, jcode: { id: "jcode", name: "jcode", image: "/providers/jcode.png", color: "#FF6B35", description: "High-performance Rust-based coding agent harness", configType: "custom", docsUrl: "https://github.com/1jehuang/jcode", notes: [ { type: "info", text: "jcode is a Rust-based coding agent with semantic memory, multi-agent swarms, and extreme performance (27.8 MB RAM, 14ms boot)." }, { type: "info", text: "Configure 9router as an OpenAI-compatible provider to route all jcode requests through 9router's optimization layer." }, { type: "warning", text: "Requires jcode installed. Install via: curl -fsSL https://raw.githubusercontent.com/1jehuang/jcode/master/scripts/install.sh | bash" }, ], defaultModels: [ { id: "claude-opus-4-7", name: "Claude Opus 4.7", alias: "opus", defaultValue: "cc/claude-opus-4-7" }, { id: "claude-sonnet-4-6", name: "Claude Sonnet 4.6", alias: "sonnet", defaultValue: "cc/claude-sonnet-4-6" }, { id: "gpt-5.5", name: "GPT 5.5", alias: "gpt5", defaultValue: "cx/gpt-5.5" }, { id: "gemini-3.1-pro", name: "Gemini 3.1 Pro", alias: "gemini", defaultValue: "gemini/gemini-3.1-pro" }, ], }, // HIDDEN: gemini-cli // "gemini-cli": { // id: "gemini-cli", // name: "Gemini CLI", // icon: "terminal", // color: "#4285F4", // description: "Google Gemini CLI", // configType: "env", // envVars: { // baseUrl: "GEMINI_API_BASE_URL", // model: "GEMINI_MODEL", // }, // defaultModels: [ // { id: "gemini-2.5-pro", name: "Gemini 2.5 Pro", alias: "pro" }, // { id: "gemini-2.5-flash", name: "Gemini 2.5 Flash", alias: "flash" }, // ], // }, }; // Get all provider models for mapping dropdown export const getProviderModelsForMapping = (providers) => { const result = []; providers.forEach(conn => { if (conn.isActive && (conn.testStatus === "active" || conn.testStatus === "success")) { result.push({ connectionId: conn.id, provider: conn.provider, name: conn.name, models: conn.models || [], }); } }); return result; };