OpenWRT SSH MCP Server
Enables AI agents to manage OpenWRT routers remotely via SSH, supporting system monitoring, network management, OpenThread Border Router configuration, and package management through natural language commands.
README
OpenWRT SSH MCP Server ๐ณ
A containerized MCP (Model Context Protocol) server for managing OpenWRT routers via SSH. This server allows AI agents (like Claude) to execute commands and manage OpenWRT routers remotely and securely.
๐ STATUS: โ Fully functional and tested with physical router
โจ Features
- ๐ณ Docker Ready - Optimized image with multi-stage build (271MB)
- ๐ Robust Security - Command whitelist, read-only filesystem, audit logging
- ๐ ๏ธ 19 OpenWRT Tools - Complete router management (network, system, Thread, packages)
- ๐ Easy Integration - Compatible with Claude Desktop and VS Code
- ๐ Monitoring - Detailed logs of all operations
- ๐ MCP Toolkit - Fully compatible with Docker Desktop MCP
- ๐ฆ Package Management - Install/remove IPK packages with opkg
- ๐ OpenThread OTBR - Support for Thread Border Router
Architecture
โโโโโโโโโโโโโโโโโโโโโโโ
โ Claude / VS Code โ โ Your AI agent
โโโโโโโโโโโโฌโโโโโโโโโโโ
โ MCP Protocol (stdio)
โ
โโโโโโโโโโโโผโโโโโโโโโโโ
โ Docker Container โ โ MCP Server
โ โโโโโโโโโโโโโโโโ โ
โ โ MCP Server โ โ
โ โ (Python) โ โ
โ โโโโโโโโฌโโโโโโโโ โ
โโโโโโโโโโโผโโโโโโโโโโโโ
โ SSH
โ
โโโโโโโโโโโผโโโโโโโโโโโโ
โ OpenWRT Router โ โ Your physical router
โ (192.168.1.1) โ
โโโโโโโโโโโโโโโโโโโโโโโ
Features
- ๐ Secure SSH authentication (password or key-based)
- ๐ ๏ธ OpenWRT-specific tools (ubus, uci)
- โ Command validation with whitelist
- ๐ Audit logging
- ๐ณ Docker support (optional)
- ๐ Integration with Claude Desktop and VS Code
Requirements
- Python 3.10+
- OpenWRT router with SSH enabled
- SSH access to router (root user recommended)
Installation
1. Clone or create the project
cd "c:\Users\Luis Antonio\Documents\UNAL\MCPs-OpenWRT"
2. Create virtual environment and install dependencies
python -m venv venv
.\venv\Scripts\activate # Windows
pip install -e .
3. Configure SSH credentials
# Copy example file
copy .env.example .env
# Edit .env with your router credentials
4. Generate and copy SSH key (recommended)
# Generate dedicated key
ssh-keygen -t ed25519 -f ~/.ssh/openwrt_router -C "MCP Server"
# Copy to router
ssh-copy-id -i ~/.ssh/openwrt_router.pub root@192.168.1.1
# Update .env
OPENWRT_KEY_FILE=C:\Users\YOUR_USER\.ssh\openwrt_router
๐ง Configuration
Claude Desktop (Docker)
Includes optimized configuration in claude_desktop_config.json:
{
"mcpServers": {
"openwrt-router-docker": {
"command": "docker",
"args": [
"run", "--rm", "-i",
"--network", "host",
"--env-file", "C:\\Users\\Luis Antonio\\Documents\\UNAL\\MCPs-OpenWRT\\.env",
"--mount", "type=bind,src=C:\\Users\\Luis Antonio\\.ssh,dst=/root/.ssh,readonly",
"openwrt-ssh-mcp:latest"
]
}
}
}
VS Code with GitHub Copilot
The project includes complete VS Code configuration:
Option 1: Direct Python (Recommended)
# Open workspace
code mcp-openwrt.code-workspace
# In Copilot Chat (Ctrl+Shift+I):
"What OpenWRT tools do I have available?"
Option 2: With Tasks
Terminal > Run Task > "Start MCP Server (Python)"
Option 3: Startup Script
.\start-mcp-vscode.ps1
Script Helper
Use docker-mcp.ps1 for all operations:
.\docker-mcp.ps1 build # Build image
.\docker-mcp.ps1 run # Run server
.\docker-mcp.ps1 test # Test connection
.\docker-mcp.ps1 logs # View logs
.\docker-mcp.ps1 shell # Open shell
.\docker-mcp.ps1 clean # Clean all
๐ ๏ธ Available Tools
System & Network (8 tools)
openwrt_test_connection- Test SSH connectionopenwrt_execute_command- Execute raw command (validated)openwrt_get_system_info- System info (uptime, memory, CPU)openwrt_restart_interface- Restart network interfaceopenwrt_get_wifi_status- WiFi status and clientsopenwrt_list_dhcp_leases- List DHCP clientsopenwrt_get_firewall_rules- View firewall rulesopenwrt_read_config- Read UCI config file
OpenThread Border Router (5 tools)
openwrt_thread_get_state- Current Thread stateopenwrt_thread_create_network- Create new Thread networkopenwrt_thread_get_dataset- Get network credentialsopenwrt_thread_get_info- Complete Thread network infoopenwrt_thread_enable_commissioner- Allow new devices
Package Management (6 tools)
openwrt_opkg_update- Update package listsopenwrt_opkg_install- Install IPK packagesopenwrt_opkg_remove- Remove packagesopenwrt_opkg_list_installed- List installed packagesopenwrt_opkg_info- Detailed package infoopenwrt_opkg_list_available- List available packages
๐ฌ Usage Examples
Once configured, you can ask Claude:
System & Network
- "Show me the WiFi status on my router"
- "List connected devices"
- "Restart the wan interface"
- "What's the router's memory usage?"
Package Management
- "Update the package repositories"
- "Install the luci-app-openthread package"
- "Show me installed packages"
- "Give me information about the ot-br-posix package"
OpenThread
- "Create a Thread network called 'MyHome' on channel 15"
- "Show me the Thread network status"
- "Enable the commissioner to add new devices"
- "Give me the Thread network credentials"
Security
โ ๏ธ IMPORTANT: This server has root access to your router. Make sure to:
- Use SSH key authentication (not password)
- Keep
.envout of version control - Review commands before production execution
- Enable audit logging
- Limit SSH access from router to your PC
๐ Documentation
๐ Quick Start
- QUICKSTART_DOCKER.md - Quick start with Docker
- TEST_OPKG.md - Test IPK package management
๐ Detailed Guides
- DOCKER_GUIDE.md - Complete Docker guide
๐งช Testing
# Test with helper script
.\docker-mcp.ps1 test
# Test with MCP Inspector
npm install -g @modelcontextprotocol/inspector
npx @modelcontextprotocol/inspector docker run -i --rm openwrt-ssh-mcp:latest
# View logs
.\docker-mcp.ps1 logs
๐ Implemented Security
- โ Read-only filesystem - Immutable container
- โ No capabilities - No special permissions
- โ SSH keys read-only - Protected keys
- โ Command whitelist - Only safe commands
- โ Audit logging - Complete logging
- โ Volatile tmpfs - /tmp cleaned on restart
- โ No privilege escalation - No sudo
๐ฏ Use Cases
Advanced Workflows
- ๐ Automated backup of UCI configurations
- ๐ Network monitoring - Connected devices, resource usage
- ๐ง AI-guided troubleshooting
- ๐ Automatic documentation of changes
- ๐จ Network anomaly alerts
- ๐ฆ Package management - Install/update software
- ๐ Thread configuration - Create and manage Thread/Matter networks
- ๐ก๏ธ Security auditing - Review firewall rules
๐ณ Docker Hub (Optional)
# Publish your image
docker login
docker tag openwrt-ssh-mcp:latest yourusername/openwrt-ssh-mcp:latest
docker push yourusername/openwrt-ssh-mcp:latest
๐ ๏ธ Development
# Install development dependencies
pip install -e ".[dev]"
# Run tests
pytest
# Format code
black .
ruff check --fix .
# Rebuild after changes
.\docker-mcp.ps1 build
๐ค Contributing
Contributions are welcome! Please:
- Fork the project
- Create a branch for your feature
- Commit your changes
- Push to the branch
- Open a Pull Request
๐ Resources
๐ License
MIT
Made with โค๏ธ for the OpenWRT and MCP community
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.
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.
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.
E2B
Using MCP to run code via e2b.