pentest-mcp-server
Enables authorized penetration testing and security assessments with CVE monitoring, vulnerability scanning, and reporting features.
README
Penetration Testing MCP Server v2.0
A comprehensive MCP (Model Context Protocol) server for authorized penetration testing and security assessments, now with CVE Monitoring and Nuclei Integration.
ā ļø IMPORTANT LEGAL NOTICE
This tool is designed EXCLUSIVELY for authorized security testing.
Users MUST:
- Have explicit written permission from the system owner
- Comply with all applicable laws and regulations
- Use only for defensive security purposes
- Not use for malicious purposes or unauthorized access
Unauthorized use may violate computer crime laws and result in severe penalties.
š Version 2.0 Features
CVE Monitoring
- Real-time CVE Fetching - Get latest CVEs from NVD database
- CVE Search - Search CVEs by keyword
- Detailed CVE Information - CVSS scores, affected products, descriptions
- Local Vulnerability Database - Store and search CVEs locally
Nuclei Integration
- Automated Vulnerability Scanning - Use nuclei templates for scanning
- Template Management - Update and search nuclei templates
- Severity-based Filtering - Scan by severity level
- Template Discovery - Find templates for specific CVEs
Features
Phase 1: Reconnaissance (Passive)
whois_lookup- Domain WHOIS informationdns_enum- DNS record enumerationsubdomain_enum- Subdomain discoveryosint_search- Open Source Intelligence gathering
Phase 2: Scanning (Active)
port_scan- TCP/UDP port scanningservice_detection- Service version detectionvuln_scan- Vulnerability scanning
Phase 3: Enumeration
web_enum- Web directory/file enumerationsmb_enum- SMB share enumerationldap_enum- LDAP directory enumeration
Phase 4: Vulnerability Analysis
ssl_analyze- SSL/TLS configuration analysisweb_vuln_check- OWASP Top 10 checkscve_lookup- CVE database lookup- NEW
fetch_recent_cves- Fetch recent CVEs from NVD - NEW
search_cve- Search CVEs by keyword - NEW
get_cve_exploit_info- Get detailed exploit info
Phase 5: Exploitation (Safe/Limited)
password_audit- Password strength auditinggenerate_payload- Test payload generation
Phase 6: Post-Exploitation (Safe/Limited)
privilege_check- Privilege escalation vectorspersistence_check- Persistence mechanisms
Phase 7: Reporting
generate_report- Penetration test report generationrisk_score- Risk score calculation
NEW: Nuclei Integration
nuclei_scan- Run nuclei vulnerability scanupdate_nuclei_templates- Update nuclei templatessearch_nuclei_templates- Search nuclei templateslist_nuclei_templates- List templates by severitycheck_nuclei_status- Check nuclei installation
NEW: Vulnerability Database
add_cve_to_db- Add CVE to local databasesearch_local_vuln_db- Search local database
Utility Tools
set_scope- Define authorized testing scopeverify_authorization- Verify target authorization
Installation
Prerequisites
# macOS
brew install nmap whois samba dnsutils python3 go
# Install nuclei
go install -v github.com/projectdiscovery/nuclei/v3/cmd/nuclei@latest
# Download nuclei templates
nuclei -update-templates
# Ubuntu/Debian
sudo apt install nmap whois smbclient dnsutils python3 python3-pip golang-go
# Arch Linux
sudo pacman -S nmap whois samba dnsutils python3 go
Install the MCP Server
cd pentest-mcp-server
pip install -e .
Configure with Claude Desktop
Add to your claude_desktop_config.json:
{
"mcpServers": {
"pentest": {
"command": "python",
"args": ["-m", "pentest_mcp.server"]
}
}
}
Usage
1. Set Authorized Scope First
Use set_scope to define your authorized targets:
- targets: ["example.com", "192.168.1.0/24"]
- engagement_id: "PENTEST-2024-001"
- tester_name: "Your Name"
2. Verify Authorization
Before testing any target, verify it's in scope:
verify_authorization(target="example.com")
3. CVE Monitoring Workflow
# Fetch recent critical CVEs
fetch_recent_cves(days=7, severity="critical")
# Search for specific CVEs
search_cve(keyword="log4j")
# Get detailed exploit information
get_cve_exploit_info(cve_id="CVE-2021-44228")
# Add CVE to local database
add_cve_to_db(cve_id="CVE-2021-44228")
4. Nuclei Scanning Workflow
# Check nuclei installation
check_nuclei_status()
# Update templates
update_nuclei_templates()
# Run vulnerability scan
nuclei_scan(target="https://example.com", severity="high")
# Search for templates
search_nuclei_templates(query="cve-2021")
# List critical templates
list_nuclei_templates(severity="critical")
5. Full Penetration Testing Workflow
# Reconnaissance
whois_lookup(domain="example.com")
dns_enum(domain="example.com")
subdomain_enum(domain="example.com")
# Scanning
port_scan(target="example.com", ports="1-1000")
service_detection(target="example.com")
# Enumeration
web_enum(url="https://example.com")
# Vulnerability Analysis
ssl_analyze(target="example.com:443")
nuclei_scan(target="https://example.com", severity="all")
# Reporting
generate_report(format="markdown", include_remediation=true)
CVE Monitoring Details
NVD API Integration
The server integrates with the National Vulnerability Database (NVD) API to:
- Fetch recent CVEs (last 7 days by default)
- Search CVEs by keyword
- Get detailed CVE information including:
- CVSS v3.1 scores
- Affected products (CPEs)
- Severity ratings
- Publication dates
Local Vulnerability Database
Store frequently referenced CVEs locally for:
- Quick offline access
- Custom annotations
- Searchable repository
Nuclei Integration Details
Template Management
Nuclei templates are stored in ~/nuclei-templates/ and include:
- CVE templates
- Vulnerability classifications
- Severity ratings
- Technical details
Scanning Capabilities
- HTTP-based vulnerability scanning
- DNS scanning
- SSL/TLS checks
- Headless browser scanning
- Custom template support
Template Categories
cves/- CVE-specific templatesvulnerabilities/- Generic vulnerability templatesexposures/- Information disclosure templatesmisconfiguration/- Security misconfiguration templates
Security Features
Authorization Enforcement
- All active tools require target authorization
- Scope must be defined before testing
- Clear error messages for unauthorized targets
Safe Defaults
- Limited exploitation capabilities
- No destructive operations
- Audit logging of all actions
Legal Compliance
- Clear warnings about legal requirements
- Engagement tracking
- Documentation support
Example Output
CVE Monitoring
š Recent CVEs (Last 7 days)
Severity: critical
==================================================
š Found 15 CVEs:
š“ CVE-2024-12345
Score: 9.8 | Severity: CRITICAL
Remote code execution in Apache HTTP Server...
š“ CVE-2024-12346
Score: 9.1 | Severity: CRITICAL
SQL injection in popular CMS...
Nuclei Scan
š Nuclei Vulnerability Scan
Target: https://example.com
==================================================
š Running nuclei scan...
š“ Found 3 vulnerabilities:
š CVE-2021-41773
Template: cves/2021/CVE-2021-41773.yaml
Severity: high
Matched: https://example.com/cgi-bin/
Troubleshooting
Nuclei Not Found
# Install Go
brew install go # macOS
sudo apt install golang-go # Ubuntu
# Install nuclei
go install -v github.com/projectdiscovery/nuclei/v3/cmd/nuclei@latest
# Add to PATH
export PATH=$PATH:$(go env GOPATH)/bin
# Download templates
nuclei -update-templates
CVE API Errors
- Check internet connection
- NVD API has rate limits (wait and retry)
- For heavy usage, consider NVD API key
Contributing
Contributions are welcome! Please ensure:
- All code follows security best practices
- No malicious capabilities are added
- Documentation is updated
- Tests are included
License
MIT License - For authorized security testing only.
Disclaimer
This tool is provided for educational and authorized security testing purposes only. The authors and contributors are not responsible for any misuse or illegal activities conducted with this software. Always obtain proper authorization before testing any systems.
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.