MCP-Kali-Server

TriV3/MCP-Kali-Server

3.4

If you are the rightful owner of MCP-Kali-Server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to henry@mcphub.com.

The MCP Kali Server is a comprehensive Model Context Protocol server designed for penetration testing and cybersecurity operations, providing seamless integration between Kali Linux tools and MCP-compatible clients.

Tools
5
Resources
0
Prompts
0

MCP Kali Server

License: MIT Version: v0.2.1

A comprehensive Model Context Protocol (MCP) server for penetration testing and cybersecurity operations, providing seamless integration between Kali Linux tools and MCP-compatible clients.

๐ŸŽฅ Demo Video

Automating Kali Linux with an MCP (Model Context Protocol) โ€” HTB Demo

In this video, I showcase how my MCP automates a Kali Linux workflow inside WSL2 and assists with solving a Hack The Box challenge โ€” from enumeration to exploitation to auto-generated documentation.

Watch the demo on YouTube


๐Ÿš€ Overview

This project provides a powerful MCP server that enables secure, programmatic access to Kali Linux penetration testing tools through a standardized interface. It includes advanced features like reverse shell management, SSH session handling, and comprehensive file operations with integrity verification.

๐Ÿ—๏ธ Architecture

This project is designed to work across different environments:

1. Kali Server (kali-server/)

Runs on Kali Linux only - The core server application that provides the actual penetration testing capabilities.

kali-server/
โ”œโ”€โ”€ api/           # REST API routes and endpoints
โ”œโ”€โ”€ core/          # Core functionality (SSH, reverse shells, config, Docker)
โ”œโ”€โ”€ tools/         # Penetration testing tools integration
โ””โ”€โ”€ utils/         # Utility functions and file operations

Features:

  • Docker test mode (--test option) - automatically manages test containers
  • All penetration testing tools (nmap, gobuster, etc.)
  • SSH and reverse shell session management
  • File operations with integrity verification

2. MCP Server (mcp-server/)

Can run on any system - The Model Context Protocol server that provides a standardized interface for MCP clients.

mcp-server/
โ””โ”€โ”€ mcp_server.py  # MCP protocol implementation

Note: The MCP server communicates with the Kali server via HTTP, so they can be on different systems.

Deployment Architecture

โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    HTTP     โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”    HTTP     โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”
โ”‚   MCP Client    โ”‚ โ—„โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ–บ โ”‚   MCP Server     โ”‚ โ—„โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ–บ โ”‚   Kali Server    โ”‚
โ”‚  (Any system)   โ”‚             โ”‚  (Any system)    โ”‚             โ”‚  (Kali Linux)    โ”‚
โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜             โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜             โ”‚                  โ”‚
                                                                  โ”‚ โ”Œโ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ” โ”‚
                                                                  โ”‚ โ”‚   Docker     โ”‚ โ”‚
                                                                  โ”‚ โ”‚ (test mode)  โ”‚ โ”‚
                                                                  โ”‚ โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜ โ”‚
                                                                  โ””โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”€โ”˜

โœจ Key Features

๐Ÿ”ง Penetration Testing Tools

  • Nmap: Network discovery and security auditing
  • Gobuster: Directory/file enumeration
  • Dirb: Web content scanner
  • Nikto: Web server scanner
  • Hydra: Network logon cracker
  • SQLmap: SQL injection testing
  • WPScan: WordPress security scanner
  • John the Ripper: Password cracking
  • Enum4linux: SMB enumeration
  • Metasploit: Exploitation framework

๐Ÿš Advanced Session Management

  • SSH Session Manager: Complete SSH session lifecycle management
    • start_ssh_session: Establish secure SSH connections
    • execute_ssh_command: Run commands in SSH sessions
    • get_ssh_status: Monitor SSH session status
    • stop_ssh_session: Cleanly terminate SSH sessions
    • list_ssh_sessions: View all active SSH sessions
  • Reverse Shell Manager: Multi-session reverse shell handling
    • start_reverse_shell_listener: Start listening for reverse shells
    • execute_shell_command: Execute commands in reverse shells
    • trigger_reverse_shell_action: Non-blocking trigger execution for payloads
    • get_shell_status: Monitor reverse shell session status
    • stop_reverse_shell: Terminate reverse shell sessions
    • list_reverse_shell_sessions: View all active reverse shell sessions

๐Ÿ“ Comprehensive File Operations

  • Kali Server File Management:
    • upload_to_kali: Upload files directly to Kali server
    • download_from_kali: Download files from Kali server
  • SSH File Transfer (optimized for large files):
    • ssh_upload_content: Upload content via SSH with auto-optimization
    • ssh_download_content: Download content via SSH with chunking
    • ssh_estimate_transfer_time: Estimate transfer times and get recommendations
  • Reverse Shell File Transfer:
    • reverse_shell_upload_file: Upload files via reverse shell
    • reverse_shell_upload_content: Upload content via reverse shell
    • reverse_shell_download_file: Download files via reverse shell
    • reverse_shell_download_content: Download content via reverse shell

๐Ÿ› ๏ธ System Integration

  • Command Execution: Direct command execution on Kali server
  • Health Monitoring: Server health checks and status monitoring
  • Session Persistence: Maintain multiple concurrent sessions

๐Ÿ”’ Security Features

  • Data Integrity: SHA256 checksum verification for all file transfers
  • Secure Communications: Encrypted SSH connections
  • Session Isolation: Independent session management
  • Error Handling: Comprehensive error detection and reporting

๐Ÿ“Š Performance Optimization

  • Chunked Transfers: Optimized for large file operations
  • Automatic Method Selection: Smart selection based on file size
  • Background Processing: Non-blocking operations for long-running tasks
  • Resource Management: Efficient memory and CPU usage

๐Ÿ› ๏ธ Installation

See for detailed installation instructions.

Dependency Split

This project now separates Python dependencies for the two runtime components:

  • requirements.kali.txt โ€“ Only what the Kali API server Python code needs (Flask, etc.)
  • requirements.mcp.txt โ€“ Dependencies for the MCP server client interface (requests, FastMCP, test libs)
  • requirements.txt โ€“ Informational file describing the split; contains no direct packages now.

Install on each machine as appropriate:

pip install -r requirements.kali.txt   # On Kali host running kali-server/
pip install -r requirements.mcp.txt    # On host running mcp-server/

โš ๏ธ Security Warning

IMPORTANT: Be extremely cautious when running the Kali server with sudo privileges:

# โš ๏ธ DANGEROUS - Avoid if possible
sudo python kali_server.py

Why this is risky:

  • The entire server runs with root privileges
  • All API endpoints and commands execute with full system access
  • Any compromise of the server grants complete root access to the system
  • No privilege separation or access control

Safer alternatives:

  • Run the server as a regular user (many tools work without root)
  • Use specific sudo permissions only for commands that require them
  • Consider containerization or virtualization for isolation
  • Implement privilege escalation only when absolutely necessary

For production environments: Please see TODO.md for planned security enhancements including granular privilege management and access controls.

๐Ÿ“– Usage

See for detailed usage instructions and examples.

๐Ÿงช Testing

The project includes comprehensive test suites using Docker containers for isolated testing environments.

Run All Tests

cd tests
./run_all.bat  # Windows
# or
chmod +x run_all.sh && ./run_all.sh  # Linux

Docker Testing Environment

cd tests/docker
docker-compose up -d --build
python test_config_docker.py

SSH Manager Tests

cd tests/kali
python -m pytest test_ssh_manager.py -v

Test Configuration

Tests use Docker containers for consistent and isolated testing environments. The configuration is automatically set up in:

  • tests/kali/test_config.py - Main test configuration (Docker-based)
  • tests/docker/test_config_docker.py - Docker-specific test configuration

๐Ÿ“‹ Available MCP Tools

The MCP server provides the following tools:

ToolDescription
mcp_kali_mcp_nmap_scanNetwork scanning and enumeration
mcp_kali_mcp_gobuster_scanDirectory and file enumeration
mcp_kali_mcp_hydra_attackPassword brute forcing
mcp_kali_mcp_start_ssh_sessionSSH session management
mcp_kali_mcp_execute_ssh_commandSSH command execution
mcp_kali_mcp_ssh_upload_contentFile upload via SSH
mcp_kali_mcp_ssh_download_contentFile download via SSH
mcp_kali_mcp_start_reverse_shell_listenerReverse shell management
mcp_kali_mcp_generate_reverse_shell_payloadPayload generation

๐Ÿ” File Operations

Upload with Integrity Verification

# The system automatically verifies file integrity using SHA256 checksums
upload_result = {
    "success": True,
    "source_checksum": "abc123...",
    "remote_checksum": "abc123...",
    "checksum_verified": True,
    "integrity_check": "PASSED"
}

Download with Integrity Verification

# All downloads include automatic integrity verification
download_result = {
    "success": True,
    "remote_checksum": "def456...",
    "local_checksum": "def456...",
    "checksum_verified": True,
    "integrity_check": "PASSED"
}

๐Ÿšจ Security Considerations

  • Testing Environment: All tests use isolated Docker containers for security
  • Network Security: Ensure proper firewall configuration
  • Authentication: Use strong passwords and key-based authentication
  • Session Management: Regularly clean up unused sessions
  • File Permissions: Set appropriate file permissions on uploaded files
  • Logging: Monitor all activities through comprehensive logging

๐Ÿ› Troubleshooting

Common Issues

  1. Connection Refused

    # Check if server is running
    curl http://localhost:5000/health
    
  2. SSH Connection Failed

    # Verify SSH connectivity
    ssh user@target-host
    
  3. Tool Not Found

    # Install missing tools
    sudo apt update && sudo apt install nmap gobuster
    
  4. Docker Test Mode Issues

    If you encounter Docker-related errors when using --test mode on Kali Linux:

    Common Docker fixes on Kali Linux:

    # Install Docker
    sudo apt update && sudo apt install docker.io
    
    # Start Docker service
    sudo systemctl start docker
    sudo systemctl enable docker
    
    # Add user to docker group (then logout/login)
    sudo usermod -aG docker $USER
    
    # Test Docker access
    docker --version
    docker ps
    

    If Docker commands work manually but fail in test mode:

    • The issue might be PATH-related in the Python environment
    • Try running with sudo: sudo python kali_server.py --test
    • Check Docker socket permissions: ls -la /var/run/docker.sock
    • Ensure you're running this on Kali Linux, not Windows

Debug Mode

Enable debug logging:

# For the server
python kali_server.py --test --debug

# For Python logging
import logging
logging.basicConfig(level=logging.DEBUG)

๐Ÿค Contributing

  1. Fork the repository
  2. Create a feature branch
  3. Follow the coding standards (English comments, proper naming)
  4. Add comprehensive tests
  5. Update documentation
  6. Submit a pull request

Coding Standards

  • All code, variables, and functions must be in English
  • All comments and documentation must be in clear English
  • Follow standard naming conventions
  • Add tests for new features or bug fixes
  • Update README and documentation

๐Ÿ“„ License

This project is licensed under the MIT License - see the file for details.

๐Ÿ™ Acknowledgments

  • Original Project: This project is initially a fork of MCP-Kali-Server but has been completely rewritten and restructured
  • Kali Linux for the comprehensive penetration testing platform
  • Model Context Protocol for the standardized interface
  • The cybersecurity community for continuous tool development

๐Ÿ“ž Support


โš ๏ธ Disclaimer: This tool is designed for authorized penetration testing and security research only. Users are responsible for complying with applicable laws and regulations.