@nimbletools/mcp-http-bridge
v1.0.5
Published
Bridge MCP stdio protocol to HTTP-based MCP services
Readme
NimbleTools - MCP HTTP Bridge
Bridge the Model Context Protocol (MCP) stdio interface to HTTP-based MCP services. This allows MCP clients like Claude Code to seamlessly connect to remote MCP servers running over HTTP.
For more information about MCP and related tools, visit www.nimbletools.ai.
Requirements
- Node.js 20.0.0 or higher
- npm 9.0.0 or higher
Installation
npm install -g @nimbletools/mcp-http-bridgeOr use directly with npx:
npx @nimbletools/mcp-http-bridge --endpoint "https://..." --token "..."Updating
To update to the latest version:
npm install -g @nimbletools/mcp-http-bridge@latestUsage
Command Line
mcp-http-bridge \
--endpoint "https://api.example.com/mcp" \
--token "your-bearer-token" \
--timeout 15000 \
--retries 2With Claude Code
Add to your Claude Code configuration:
{
"mcpServers": {
"my-remote-server": {
"command": "npx",
"args": [
"@nimbletools/mcp-http-bridge",
"--endpoint",
"https://api.example.com/mcp",
"--token",
"your-bearer-token"
]
}
}
}With Environment Variables
For better security, use environment variables:
{
"mcpServers": {
"my-remote-server": {
"command": "mcp-http-bridge",
"args": ["--endpoint", "https://api.example.com/mcp"],
"env": {
"MCP_BEARER_TOKEN": "your-bearer-token"
}
}
}
}Options
| Option | Alias | Default | Description |
| ------------ | ----- | ---------- | --------------------------------- |
| --endpoint | -e | required | HTTP endpoint for the MCP service |
| --token | -t | required | Bearer token for authentication |
| --timeout | | 30000 | Request timeout in milliseconds |
| --retries | | 3 | Number of retry attempts |
| --verbose | -v | false | Enable verbose logging |
How It Works
The bridge acts as a protocol translator:
- Input: Accepts MCP JSON-RPC messages via stdin
- Translation: Forwards them as HTTP POST requests to your endpoint
- Session Management: Automatically captures and manages
mcp-session-idheaders - Output: Returns responses via stdout in MCP format
Claude Code ↔ stdio/JSON-RPC ↔ MCP HTTP Bridge ↔ HTTP/JSON ↔ Your MCP ServiceFeatures
- ✅ Session ID Management: Automatically captures and includes
mcp-session-idheaders - ✅ Server-Sent Events: Supports both JSON and SSE response formats
- ✅ Content Type Negotiation: Accepts
application/jsonandtext/event-stream - ✅ Error Handling: Robust retry logic with exponential backoff
- ✅ Authentication: Bearer token support
Authentication
The bridge adds Bearer token authentication to all HTTP requests:
POST /mcp HTTP/1.1
Authorization: Bearer your-token-here
Content-Type: application/json
{
"jsonrpc": "2.0",
"method": "tools/list",
"id": 1
}Error Handling
- 4xx Client Errors: Returned immediately (no retries)
- 5xx Server Errors: Retried with exponential backoff
- Network Errors: Retried with exponential backoff
- Timeouts: Configurable per request
Examples
Basic Usage
mcp-http-bridge \
--endpoint "https://mcp.example.com/api" \
--token "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."With Custom Timeout
mcp-http-bridge \
--endpoint "https://slow-service.com/mcp" \
--token "abc123" \
--timeout 60000 \
--retries 5Testing Connectivity
echo '{"jsonrpc":"2.0","method":"tools/list","id":1}' | \
mcp-http-bridge --endpoint "https://api.com/mcp" --token "token"Development
# Clone the repository
git clone https://github.com/nimbletools/mcp-http-bridge.git
cd mcp-http-bridge
# Install dependencies
npm install
# Build TypeScript
npm run build
# Run locally
npm run dev -- --endpoint "https://..." --token "..."Local Development with Claude Code
For testing during development, you can configure Claude Code to use either your local build or the published package:
Using local build:
{
"mcpServers": {
"national-parks": {
"command": "node",
"args": [
"/path/to/your/mcp-http-bridge/dist/cli.js",
"--endpoint",
"https://mcp.nimbletools.dev/v1/workspaces/your-workspace-id/servers/nationalparks-mcp/mcp",
"--token",
"your-auth-token-here",
"--insecure"
],
"auth": null,
"oauth": false
}
}
}Using published package with npx:
{
"mcpServers": {
"national-parks": {
"command": "npx",
"args": [
"@nimbletools/mcp-http-bridge",
"--endpoint",
"https://mcp.nimbletools.dev/v1/workspaces/your-workspace-id/servers/nationalparks-mcp/mcp",
"--token",
"your-auth-token-here",
"--insecure"
],
"auth": null,
"oauth": false
}
}
}Replace the workspace ID and token with your actual credentials. The --insecure flag is useful for development against local or test endpoints.
Contributing
We welcome contributions! If you're interested in contributing, please read our Contributing Guide for details on our development process, how to propose bugfixes and improvements, and how to build and test your changes.
License
MIT License - see LICENSE file for details.
