NetMCP
A professional-grade network analysis MCP server that integrates Wireshark/TShark, Nmap, and threat intelligence to enable packet capture, network scanning, threat detection, and credential extraction through natural language.
README
<div align="center">
๐ NetMCP
Professional-grade network analysis MCP server โ Wireshark/TShark + Nmap + Threat Intelligence
NetMCP bridges the gap between raw network data and AI comprehension. It gives Claude, Cursor, and any MCP-compliant client the ability to capture packets, scan networks, detect threats, and extract credentials โ all through natural language.
Quick Start โข Features โข Configuration โข API Reference โข Architecture
</div>
๐ Quick Start
# Install system dependencies
sudo apt-get install -y tshark nmap # Ubuntu/Debian
# brew install wireshark nmap # macOS
# Install NetMCP
pip install netmcp
# Run
netmcp
That's it. The server starts on stdio transport by default, ready for any MCP client.
โจ Features
- ๐ก Packet Capture โ Live capture, BPF filtering, targeted traffic, quick capture mode
- ๐ฌ Deep Analysis โ PCAP parsing, protocol statistics, HTTP traffic analysis, DNS analysis, expert info, GeoIP enrichment
- ๐ Stream Reconstruction โ Follow TCP/UDP conversations, enumerate streams
- ๐ค Flexible Export โ JSON, CSV, pcap/pcapng format conversion
- ๐ Nmap Integration โ Port scan, service detection, OS fingerprinting, vulnerability scan
- ๐ก๏ธ Threat Intelligence โ URLhaus + AbuseIPDB IP reputation checks, PCAP-wide threat scan
- ๐ Credential Extraction โ HTTP Basic, FTP, Telnet, Kerberos (hashcat-ready)
- ๐ GeoIP Mapping โ MaxMind GeoLite2 IP geolocation for traffic analysis
- ๐ 5-Layer Security โ Input validation, shell=False, rate limiting, path traversal protection, audit logging
- ๐ฌ Guided Workflows โ Security audit, incident response, troubleshooting, traffic analysis, network baseline prompts
Advanced Features
- ๐ PCAP Diff/Merge/Slice โ Compare captures, combine files via mergecap, extract packet ranges via editcap
- ๐ Flow Visualization โ ASCII art and Mermaid sequence diagrams of network conversations
- ๐ TLS Decryption โ Decrypt HTTPS traffic using SSLKEYLOGFILE (NSS Key Log Format)
- ๐จ Wireshark Profiles โ List profiles, apply profile settings, parse color filters, capture with profile
- ๐งฌ DNS Tunneling Detection โ Analyze DNS traffic and flag suspiciously long subdomain names
- ๐ฆ Packet Decode โ Detailed single-packet analysis with full protocol layer dissection
- ๐ฅ Expert Information โ Extract Wireshark's expert warnings, errors, and protocol violation notes
๐ Tool Categories
NetMCP provides 48 tools across 9 categories, plus 3 resources and 5 prompts:
| Category | Tools | Description |
|---|---|---|
| ๐ก Capture & Analysis | 5 | get_network_interfaces ยท capture_live_packets ยท quick_capture ยท save_capture_to_file ยท analyze_large_pcap |
| ๐ฌ Protocol Analysis | 10 | analyze_pcap_file ยท get_protocol_statistics ยท get_capture_file_info ยท capture_targeted_traffic ยท analyze_http_traffic ยท detect_network_protocols ยท analyze_http_headers ยท geoip_lookup ยท analyze_dns_traffic ยท get_expert_info |
| ๐ Network Flows | 2 | visualize_network_flows (ASCII + Mermaid) ยท decrypt_tls_traffic |
| ๐ง PCAP Tools | 4 | diff_pcap_files ยท merge_pcap_files ยท slice_pcap ยท decode_packet |
| ๐ Streams | 3 | follow_tcp_stream ยท follow_udp_stream ยท list_tcp_streams |
| ๐ค Export | 3 | export_packets_json ยท export_packets_csv ยท convert_pcap_format |
| ๐ Nmap | 6 | nmap_port_scan ยท nmap_service_detection ยท nmap_os_detection ยท nmap_vulnerability_scan ยท nmap_quick_scan ยท nmap_comprehensive_scan |
| ๐ก๏ธ Security | 3 | extract_credentials ยท check_ip_threat_intel ยท scan_capture_for_threats |
| ๐จ Wireshark Profiles | 4 | list_wireshark_profiles ยท apply_profile_capture ยท get_color_filters ยท capture_with_profile |
๐ Full API reference with parameters and examples: docs/API.md
๐ Transport Options
NetMCP supports all MCP transport protocols:
| Transport | Command | Use Case |
|---|---|---|
| stdio (default) | netmcp |
Claude Desktop, Cursor, local clients |
| SSE | netmcp --transport sse |
Web-based clients, remote access |
| Streamable HTTP | netmcp --transport streamable-http |
Modern HTTP clients |
โ๏ธ Configuration
Claude Desktop
Edit your config file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json - Linux:
~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"netmcp": {
"command": "netmcp",
"env": {
"ABUSEIPDB_API_KEY": "your_api_key_here"
}
}
}
}
Cursor
Edit .cursor/mcp.json in your project root:
{
"mcpServers": {
"netmcp": {
"command": "netmcp"
}
}
}
Windsurf / VS Code
Edit .vscode/mcp.json:
{
"servers": {
"netmcp": {
"command": "netmcp",
"env": {
"ABUSEIPDB_API_KEY": "your_api_key_here"
}
}
}
}
Environment Variables
| Variable | Required | Default | Description |
|---|---|---|---|
ABUSEIPDB_API_KEY |
No | โ | AbuseIPDB API key for threat intelligence. Get free key |
NETMCP_TSHARK_PATH |
No | Auto-detect | Custom path to tshark binary |
NETMCP_MAX_PACKETS |
No | 10000 |
Maximum packets per capture operation |
NETMCP_MAX_FILE_SIZE |
No | 104857600 |
Maximum PCAP file size in bytes (100 MB) |
๐ Requirements
| Dependency | Required | Install |
|---|---|---|
| Python | 3.11+ | sudo apt install python3.11 |
| TShark | Yes | sudo apt install tshark |
| Nmap | Optional | sudo apt install nmap |
macOS
brew install wireshark nmap
Linux Permissions
# Option 1: Set capabilities (recommended)
sudo setcap cap_net_raw,cap_net_admin=eip /usr/bin/dumpcap
# Option 2: Add user to wireshark group
sudo usermod -aG wireshark $USER && newgrp wireshark
๐ก๏ธ Security Model
NetMCP implements 5 layers of defense in depth:
| Layer | Mechanism | Prevents |
|---|---|---|
| 1. Input Validation | Regex, ipaddress module, Pydantic |
Malformed input, injection payloads |
| 2. Command Construction | List args, shell=False everywhere |
Command injection, shell expansion |
| 3. Subprocess Execution | Timeouts, captured output only | Runaway processes, resource exhaustion |
| 4. File System | Path.resolve(), extension allowlist, size limits |
Path traversal, symlink attacks |
| 5. Rate Limiting | Sliding window, per-operation tracking | Abuse, DoS attacks |
Additional protections:
- ๐ Never auto-escalates privileges
- ๐ All operations audit-logged with timestamps
- ๐ซ Dangerous nmap flags rejected (
--script-args,--interactive, etc.) - โ ๏ธ Clear error messages for permission issues
๐ฏ Usage Examples
Live Packet Capture
You: Capture 100 packets from eth0 and analyze the protocols.
Claude: [capture_live_packets(interface="eth0", packet_count=100)]
[get_protocol_statistics(filepath="capture.pcap")]
Found 8 protocols: TCP (62%), UDP (24%), DNS (8%), HTTP (4%)...
Security Audit
You: Perform a security audit on suspicious.pcap
Claude: 1. [get_protocol_statistics] โ traffic breakdown
2. [extract_credentials] โ found HTTP Basic Auth credentials
3. [scan_capture_for_threats] โ 2 malicious IPs detected
4. Generated full security report with IOCs
Nmap Vulnerability Scan
You: Scan 192.168.1.100 for vulnerabilities
Claude: [nmap_quick_scan("192.168.1.100")] โ ports 22, 80, 443 open
[nmap_service_detection("192.168.1.100")] โ nginx 1.18.0, OpenSSH 8.2
[nmap_vulnerability_scan("192.168.1.100")] โ no critical CVEs found
๐ง MCP Resources & Prompts
Resources
| URI | Description |
|---|---|
netmcp://interfaces |
Dynamic list of available network interfaces |
netmcp://captures |
Available PCAP files in common directories |
netmcp://system/info |
System capabilities: tool versions, features |
Prompts (Guided Workflows)
| Prompt | Description |
|---|---|
security_audit |
Comprehensive PCAP security analysis with IOC extraction |
network_troubleshooting |
Step-by-step network diagnostics |
incident_response |
Security incident investigation workflow |
traffic_analysis |
Deep traffic analysis with GeoIP mapping |
network_baseline |
Establish normal traffic patterns |
๐งช Development
# Clone and setup
git clone https://github.com/cortexc0de/netmcp.git
cd netmcp
python -m venv .venv
source .venv/bin/activate
# Install with dev dependencies
pip install -e ".[dev]"
# Run tests
pytest tests/ -v
# Run with coverage
pytest tests/ --cov=netmcp --cov-report=html
# Linting
ruff check src/netmcp/ tests/
ruff format --check src/netmcp/
mypy src/netmcp/
Project Structure
src/netmcp/
โโโ server.py # FastMCP server entry point
โโโ core/
โ โโโ security.py # 5-layer input validation + rate limiting
โ โโโ formatter.py # MCP response formatting
โโโ interfaces/
โ โโโ tshark.py # TShark async CLI wrapper
โ โโโ nmap.py # python-nmap wrapper
โ โโโ threat_intel.py # URLhaus + AbuseIPDB clients
โโโ tools/ # 48 MCP tools across 11 modules
โโโ resources/ # 3 MCP resources
โโโ prompts/ # 5 MCP prompts
๐ค Contributing
Contributions are welcome! See CONTRIBUTING.md for guidelines.
- Fork the repository
- Create a feature branch (
git checkout -b feat/amazing-feature) - Run tests (
pytest tests/ -v) - Submit a Pull Request
๐ License
MIT License โ see LICENSE for details.
๐ Acknowledgments
- Wireshark/TShark โ packet analysis toolkit
- Nmap โ network scanner
- URLhaus & AbuseIPDB โ threat intelligence
- Model Context Protocol โ AI tool framework
<div align="center">
Transform your network analysis with AI-powered packet capture, scanning, and threat intelligence.
</div>
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.