Skip to main content

Bridge for stdio-only MCP tools that exposes their stdio protocol via streamable-http

Project description

MCP Network Bridge

Enable network access to STDIO-based MCP servers through HTTP streamable protocol.

The Problem

Many open-source MCP servers only support the local-only stdio protocol. For one reason or another their developers never bothered to implement one of the two network-enabled modes: SSE or StreamableHTTP. In most cases that's fine - Claude Code or Cursor or any other modern IDE supports MCP over stdio. But when your AI application is not a stock-standard IDE that needs access to some MCP server over the network you've got a problem.

One option is to add Streaming HTTP support to the MCP servers that you want to use. It's usually not very difficult but also it's not very scalable.

A better option is to Bridge the STDIO local-only protocol to StreamableHTTP network-enabled protocol. And that's what this project is for.

Learn more about STDIO and StreamableHTTP MCP Protocols

Quick Start

The typical MCP server will provide a sample config to use. It could be something like:

{
  "server": {
    "command": "npx",
    "args": [
      "-y",
      "@modelcontextprotocol/server-everything"
    ]
  }
}

We can use the same config.json with mcp-network-bridge:

Run with Docker:

docker run --rm -it -p 8000:8000 -v $(pwd)/config.json:/app/config.json ghcr.io/mludvig/mcp-http-bridge

Or use docker-compose:

docker-compose up

Your MCP server is now available at http://localhost:8000/mcp/. Test it out with MCP Inspector.

MCP server network access

With the bridge running the MCP server can now be accessed over the network:

{
  "server": {
    "type": "http",
    "url": "http://127.0.0.1:8000/mcp/",
  }
}

Security

This bridge doesn't implement any security or access control. You'll have to configure something like nginx in front of it for TLS or Authentication support. That's beyond the scope of this project since better and more appropriate tools already exist.

Development

Local Development

This project uses uv for dependency management:

# Install dependencies
uv sync --extra dev

# Run tests
uv run pytest

# Run linting
uv run ruff check src/ tests/

# Format code
uv run ruff format src/ tests/

# Run the CLI
uv run mcp-http-bridge --help

CI/CD

This project uses GitHub Actions for:

  • Continuous Integration: Runs tests, linting, and formatting checks on every push and PR
  • Build and Release: Automatically builds and publishes to PyPI and GHCR when tags are pushed
  • Dependency Updates: Dependabot keeps dependencies up to date

To publish a new release:

  1. Update the version in pyproject.toml
  2. Create a git tag: git tag v0.1.1
  3. Push the tag: git push origin v0.1.1
  4. GitHub Actions will automatically build and publish to PyPI and GHCR

Publishing to PyPI

The workflow uses Trusted Publishing to securely publish to PyPI without storing API tokens. Make sure to configure the PyPI trusted publisher for this repository.

Author

Michael Ludvig

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_http_bridge-1.2.0.tar.gz (74.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_http_bridge-1.2.0-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file mcp_http_bridge-1.2.0.tar.gz.

File metadata

  • Download URL: mcp_http_bridge-1.2.0.tar.gz
  • Upload date:
  • Size: 74.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for mcp_http_bridge-1.2.0.tar.gz
Algorithm Hash digest
SHA256 5669534efbd20d8fea486f03856a2a9d8a8522844e9a8624ecc46304996545b9
MD5 09b71fddff5fc839a30066e630dbc468
BLAKE2b-256 920d7f50be217ca5651287b4d5c71311dee2541457e16c80d482cb8b32078c9e

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_http_bridge-1.2.0.tar.gz:

Publisher: release.yml on mludvig/mcp-http-bridge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_http_bridge-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_http_bridge-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8ca750df1efdd1cbb8944b33b94d50853f7597255001b6fbf71863a6864a0a0c
MD5 cdb93d4b190ce90a3bd244e35961dad6
BLAKE2b-256 7a0bbf0214312ac62676f76019a2bffb26f6e60bd62de684c0d4d6384abf1e62

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_http_bridge-1.2.0-py3-none-any.whl:

Publisher: release.yml on mludvig/mcp-http-bridge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page