An MCP server that exposes a single tool, read_web_url
, which fetches absolute URLs with curl -sL
after prepending a configurable CUSTOM_PREFIX
on the server side. This server uses the MCP TypeScript/JavaScript SDK and serves a Streamable HTTP endpoint at /mcp
for compatibility across many AI applications. Perfect for routing AI web requests through proxies, caching layers, or custom gateways.
- 🌐 Simple web URL reading via curl
- 🔧 Configurable URL prefix for proxying/routing
- 🐳 Tiny Docker image based on Node.js
- 🚀 Easy deployment with Docker Compose
- 🛠️ Compatible with any MCP-enabled AI application
The AI thinks it's reading a normal URL:
curl -sL https://www.example.com
But the server actually executes:
curl -sL CUSTOM_PREFIX/https://www.example.com
This allows you to:
- Route requests through a caching proxy
- Add authentication layers
- Use custom gateways
- Bypass rate limits with your own infrastructure
- Monitor/log AI web access
See docker-compose.yml
for a working example service mapping 8080:8080
and injecting both environment variables.
The MCP server will be available at http://localhost:8080
Variable | Description | Default |
---|---|---|
CUSTOM_PREFIX |
URL prefix to prepend to all requests | "" (empty) |
INTERNAL_PORT |
Internal server port | 80800 |
environment:
- CUSTOM_PREFIX=
- PORT=3000
environment:
- CUSTOM_PREFIX=https://proxy.myserver.com
- INTERNAL_PORT=8080
environment:
- CUSTOM_PREFIX=http://cache-server:8000/fetch
- INTERNAL_PORT=8080
The server exposes tools over Streamable HTTP: initialize a session with a POST to /mcp
, reuse Mcp-Session-Id
from the response, then call tools/call
with { name: "read_web_url", arguments: { url: "https://example.com" } }
. The server will run curl -sL CUSTOM_PREFIX/https://example.com
and return text content. Ensure the Mcp-Session-Id
header is included in subsequent requests and allowed via CORS.
Add to your claude_desktop_config.json
:
{
"mcpServers": {
"web-url-reader": {
"url": "http://localhost:8080/mcp"
}
}
}
Use the MCP Server node and point it to http://localhost:8080/mcp
Connect to the MCP endpoint at http://localhost:8080/mcp
The server exposes one tool:
read_web_url
- Description: Read and return the contents of a web page
- Parameter:
url
(string, required) - The complete URL to fetch - Returns: Text content of the web page
Example tool call:
{
"name": "read_web_url",
"arguments": {
"url": "https://www.example.com"
}
}
Route all AI web requests through your caching server to reduce external calls:
CUSTOM_PREFIX=http://cache-server/proxy
Add authentication to web requests:
CUSTOM_PREFIX=http://auth-gateway/fetch
Route through your own infrastructure to manage rate limits:
CUSTOM_PREFIX=https://ratelimit-proxy.myserver.com
Log and monitor all AI web access:
CUSTOM_PREFIX=http://monitoring-gateway/fetch
- Open
http://localhost:8080/
for a basic health probe and connect your MCP client tohttp://localhost:8080/mcp
. - The MCP endpoint is on
http://localhost:8080/mcp
with Streamable HTTP semantics for POST/GET/DELETE and CORS exposure forMcp-Session-Id
.
- Check that port 8080 is not in use
- Verify environment variables are set correctly
- Check Docker logs:
docker-compose logs -f
- Verify CUSTOM_PREFIX is accessible from container
- Test curl manually:
docker exec -it mcp-web-reader curl -sL YOUR_URL
- Check timeout settings (default 30s)
- Ensure workflow permissions are enabled
- Check that GITHUB_TOKEN has package write access
- Verify Dockerfile syntax
MIT License - Feel free to use and modify as needed.
Pull requests welcome! Please ensure:
- Docker image builds successfully
- README is updated for new features
- GitHub Actions workflow passes