nwtools-mcp
Provides accurate IPv4 subnet and address tools for LLMs using Python's ipaddress library. Includes CIDR parsing, overlap detection, IP classification, and more.
README
nwtools-mcp
An MCP server that gives LLMs accurate IPv4 subnet and address tools. LLMs are unreliable at network math — this server provides deterministic, correct results via Python's ipaddress standard library.
PyPI: https://pypi.org/project/nwtools-mcp/
Tools
| Tool | Description |
|---|---|
parse_cidr |
Network address, broadcast, netmask, wildcard mask, host count |
ip_in_subnet |
Check whether an IP falls within a subnet |
subnets_overlap |
Detect overlap between two subnets and return the intersection |
cidr_to_range |
Convert a CIDR to its first and last IP address |
range_to_cidrs |
Convert an IP range to the minimal list of covering CIDRs |
subtract_subnet |
Carve a subnet out of a larger block, returning remaining CIDRs |
find_gaps |
Find unallocated space within a container block |
check_coverage |
Check whether a set of CIDRs fully covers a target block |
summarize_cidrs |
Collapse a list of CIDRs into the minimal set of supernets |
classify_ip |
Classify an IP as RFC 1918, loopback, link-local, multicast, or public |
ip_convert |
Convert an IP between dotted-decimal, hex, binary, and integer |
Environment variables
| Variable | Default | Description |
|---|---|---|
MCP_TRANSPORT |
stdio |
stdio, streamable-http, or sse |
HOST |
0.0.0.0 |
Bind address (HTTP transports only) |
PORT |
8000 |
Listen port (HTTP transports only) |
API_KEY |
(none) | When set, requires X-API-Key: <value> on all HTTP requests |
LOG_LEVEL |
INFO |
Python log level for process and request logging |
Local use (stdio)
The stdio transport is used when Claude Desktop spawns the server as a subprocess. No network port is opened.
Run from PyPI with uvx
The simplest way to run the server locally is:
uvx nwtools-mcp
That runs the nwtools-mcp console command from an isolated ephemeral environment. For a persistent install:
uv tool install nwtools-mcp
nwtools-mcp
Install and run directly:
pip install -e .
python main.py
Or use the console script:
nwtools-mcp
Or install from PyPI with pip:
pip install nwtools-mcp
nwtools-mcp
Or via Docker:
docker run --rm -i nwtools-mcp
Claude Desktop config
Add to ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"nwtools": {
"command": "python",
"args": ["/path/to/nwtools-mcp/main.py"]
}
}
}
Or run it directly from PyPI with uvx:
{
"mcpServers": {
"nwtools": {
"command": "uvx",
"args": ["nwtools-mcp"]
}
}
}
If you prefer a persistent uv-managed install, use:
{
"mcpServers": {
"nwtools": {
"command": "nwtools-mcp"
}
}
}
Remote deployment (HTTP)
The server supports streamable-http (recommended) and sse transports for remote access. Set MCP_TRANSPORT to switch modes.
Running the HTTP server
# Local test
MCP_TRANSPORT=streamable-http python main.py
# With auth
API_KEY=your-secret MCP_TRANSPORT=streamable-http python main.py
With Docker:
docker build -t nwtools-mcp .
docker run --rm -p 8000:8000 \
-e MCP_TRANSPORT=streamable-http \
-e API_KEY=your-secret \
nwtools-mcp
Operational endpoints
When running in HTTP mode, the container exposes two unauthenticated probe endpoints:
| Endpoint | Description |
|---|---|
/healthz |
Basic liveness probe |
/readyz |
Readiness probe |
HTTP requests are also logged as structured JSON lines, including method, path, status, duration, client IP, and request ID.
TLS and auth
The server does not terminate TLS. In production, place it behind a reverse proxy. Example Caddy config:
nwtools.example.com {
reverse_proxy localhost:8000
}
The built-in API_KEY check adds a layer of defense at the application level, but it does not replace TLS — never expose the server without it.
Connecting Claude to a remote server
In Claude Desktop (claude_desktop_config.json):
{
"mcpServers": {
"nwtools": {
"url": "https://nwtools.example.com/mcp",
"headers": {
"X-API-Key": "your-secret"
}
}
}
}
On claude.ai, add the server under Settings → Integrations using the same URL.
Development
Install with the test extra and run the suite:
pip install -e ".[test]"
pytest
To build distribution artifacts locally:
uv build
Or with the standard Python build frontend:
pip install build
python -m build
Release
The project is now structured to publish cleanly to PyPI and run via uvx.
Build locally:
uv build
Publish manually:
uv publish
Automated publishing uses publish.yml with PyPI Trusted Publishing.
Release checklist:
- Update
versionin pyproject.toml and__version__in src/nwtools_mcp/init.py. - Run
pytest. - Run
uv build. - Commit and push to
main. - Push a version tag such as
v0.2.0.
Trusted Publisher settings:
- Create a
pypienvironment in the GitHub repository settings. - Add a Trusted Publisher for this project on PyPI that matches:
Repository owner:crims0nRepository name:nwtools-mcpWorkflow filename:publish.ymlEnvironment name:pypi
The publish workflow builds the wheel and sdist, smoke-tests both artifacts, and then runs uv publish.
Requirements
- Python 3.11+
mcpuvicorn
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.