本地 MCP 橋樑:把多個 API key + endpoint 收編為統一的模型能力池,給 Agent 透過 MCP 調用
Project description
ai-mcp-server
Languages: English | 繁體中文 | 简体中文
Local MCP bridge: register multiple (api_key, base_url) pairs once, and let your Agent automatically discover and route to any model with the right capability (chat, vision, reasoning, embedding, image_gen, tts, stt, rerank).
Three entry points:
ai-mcp— CLI (manage endpoints, query models, trigger probes, init wizard)ai-mcp-server— MCP stdio server, launched by Claude Desktop / Cursor / Cline / Traeai-mcp ui— local Web management dashboard (FastAPI + Jinja2, bound to 127.0.0.1)
Install
Option 1: uv (recommended)
uv tool install ai-mcp-server
Option 2: Homebrew
brew install brianMacao/tap/ai-mcp-server
Option 3: npm / npx
npx ai-mcp-server # auto-installs uv + Python package
Option 4: pip
pip install ai-mcp-server
Quickstart
# Interactive first-run wizard
ai-mcp init
# Or step by step:
ai-mcp endpoint add --name openrouter --base-url https://openrouter.ai/api/v1 --key sk-...
ai-mcp endpoint probe openrouter
ai-mcp model list --capability vision
# Start the Web UI
ai-mcp ui
# → http://127.0.0.1:8765/
# Start the MCP server (for Claude Desktop, Cursor, etc.)
ai-mcp-server
MCP Tools
ai-mcp-server exposes 6 MCP tools:
usage_guide— dynamic inventory, capability distribution, and routing guidance.list_models— filter models by capability, context length, endpoint, and probe state.invoke_model— pass through chat / embedding / image_gen / tts / stt / rerank calls; TTS audio is returned asaudio_base64inside the JSON body.model_performance— inspect recent per-model call counts, success rate, and latency.refresh_endpoint— refresh model lists and enqueue asynchronous capability probes.add_models— manually register models for endpoints without/v1/models, or let an Agent register user-confirmed model features.
Model Feature Registration
Capabilities use canonical names such as text_chat, vision, audio_tts,
audio_stt, embedding, and rerank. Common aliases including tts, stt,
and asr are accepted by manual registration flows and normalized internally.
Static recognition includes these known model ids:
seed-tts-2.0→audio_ttsvolc.seedasr.sauc.duration→audio_stt
Register model features from the CLI:
ai-mcp model add --endpoint volc seed-tts-2.0 --capability audio_tts
ai-mcp model add --endpoint volc volc.seedasr.sauc.duration --features asr=true
ai-mcp model add --endpoint volc custom-model --features text_chat=true,context_length=32000
ai-mcp model override volc custom-model --capability vision=false
Register features from the Web UI:
ai-mcp ui
# Open http://127.0.0.1:8765/
# Use Models -> manual add, or Overrides -> add/update feature override.
Register features from an MCP client / Agent:
- Call
usage_guide. - Use
add_modelswithcapabilitiesfor true capability flags. - Use
feature_overridesfor explicit boolean or context-length overrides.
Example MCP arguments:
{
"endpoint": "volc",
"model_ids": ["seed-tts-2.0"],
"feature_overrides": {
"audio_tts": true,
"context_length": 32000
}
}
Claude Desktop / Trae / Codex Configuration
ai-mcp init will auto-detect installed MCP clients and configure them.
Manual configuration
Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"ai-mcp": {
"command": "uv",
"args": ["run", "--from", "ai-mcp-server", "ai-mcp-server"]
}
}
}
Trae / Trae CN (project root .mcp.json):
{
"mcpServers": {
"ai-mcp": {
"command": "uv",
"args": ["run", "--from", "ai-mcp-server", "ai-mcp-server"],
"transport": "stdio"
}
}
}
Codex Desktop (~/.codex/config.toml):
[mcp_servers.ai-mcp]
command = "uv"
args = ["run", "--from", "ai-mcp-server", "ai-mcp-server"]
Environment Variables
| Variable | Purpose | Default |
|---|---|---|
AI_MCP_CONFIG_DIR |
Override data/config directory | ~/.ai-mcp-server |
AI_MCP_DB_PATH |
SQLite database path | $AI_MCP_CONFIG_DIR/db.sqlite3 |
AI_MCP_MASTER_KEY |
Fernet master key for api_key encryption | auto-generated → system keyring |
AI_MCP_UI_TOKEN |
Access token for Web UI when exposed (--expose) |
none |
Development
# Clone and set up
git clone https://github.com/brianMacao/ai-mcp-server
cd ai-mcp-server
uv sync
# Run tests
uv run pytest -q
# Verify against real endpoint
cp .keys.example .keys # edit with your keys
source .keys
export AI_MCP_CONFIG_DIR="$(pwd)/.data"
export AI_MCP_MASTER_KEY="$(cat .data/.master_key)" # first run generates this
uv run ai-mcp endpoint add --name test --base-url "$EXAMPLE_URL" --key "$EXAMPLE_API_KEY"
uv run ai-mcp endpoint probe test --capability text_chat -y
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ai_mcp_server-0.1.1.tar.gz.
File metadata
- Download URL: ai_mcp_server-0.1.1.tar.gz
- Upload date:
- Size: 94.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8e8e7614ecc98c205e3eb9a43b719ee2589a6f69f92f54f65798b62e9ae55301
|
|
| MD5 |
9241312bd1d59429faa405cf26dff57b
|
|
| BLAKE2b-256 |
50834392dee281aee38ce3e78588da2d6cabb0921a57e3905378d17eb6c458f2
|
Provenance
The following attestation bundles were made for ai_mcp_server-0.1.1.tar.gz:
Publisher:
publish.yml on brianMacao/ai-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ai_mcp_server-0.1.1.tar.gz -
Subject digest:
8e8e7614ecc98c205e3eb9a43b719ee2589a6f69f92f54f65798b62e9ae55301 - Sigstore transparency entry: 2006440061
- Sigstore integration time:
-
Permalink:
brianMacao/ai-mcp-server@35c0a1879356a3f37d245347f281504fe80d0d64 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/brianMacao
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@35c0a1879356a3f37d245347f281504fe80d0d64 -
Trigger Event:
push
-
Statement type:
File details
Details for the file ai_mcp_server-0.1.1-py3-none-any.whl.
File metadata
- Download URL: ai_mcp_server-0.1.1-py3-none-any.whl
- Upload date:
- Size: 80.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce5b2ba1a0005160a5291608ab19a9d12f96f7860b8371d523a2a140a48fd7f0
|
|
| MD5 |
ed8b2f3f6068a1e30f8db021e0eecb38
|
|
| BLAKE2b-256 |
fdd6fa5ec88f697f9ba26e33d6b84be0673efc21363b16524b74beadacc31ab5
|
Provenance
The following attestation bundles were made for ai_mcp_server-0.1.1-py3-none-any.whl:
Publisher:
publish.yml on brianMacao/ai-mcp-server
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ai_mcp_server-0.1.1-py3-none-any.whl -
Subject digest:
ce5b2ba1a0005160a5291608ab19a9d12f96f7860b8371d523a2a140a48fd7f0 - Sigstore transparency entry: 2006440165
- Sigstore integration time:
-
Permalink:
brianMacao/ai-mcp-server@35c0a1879356a3f37d245347f281504fe80d0d64 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/brianMacao
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@35c0a1879356a3f37d245347f281504fe80d0d64 -
Trigger Event:
push
-
Statement type: