loading…
Search for a command to run...
loading…
Provides accurate IPv4 subnet and address tools for LLMs using Python's ipaddress library. Includes CIDR parsing, overlap detection, IP classification, and more
Provides accurate IPv4 subnet and address tools for LLMs using Python's ipaddress library. Includes CIDR parsing, overlap detection, IP classification, and more.
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/
| 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 |
| 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 |
The stdio transport is used when Claude Desktop spawns the server as a subprocess. No network port is opened.
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
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"
}
}
}
The server supports streamable-http (recommended) and sse transports for remote access. Set MCP_TRANSPORT to switch modes.
# 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
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.
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.
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.
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
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:
version in pyproject.toml and __version__ in src/nwtools_mcp/init.py.pytest.uv build.main.v0.2.0.Trusted Publisher settings:
pypi environment in the GitHub repository settings.Repository owner: crims0n
Repository name: nwtools-mcp
Workflow filename: publish.yml
Environment name: pypiThe publish workflow builds the wheel and sdist, smoke-tests both artifacts, and then runs uv publish.
uvicornВыполни в терминале:
claude mcp add nwtools-mcp -- npx Безопасность
Низкий рискАвтоматическая эвристика по публичным данным — не гарантия безопасности.