MikroTik Cursor MCP
Allows managing Docker containers, images, and container networking on RouterOS v7.x.
Provides a natural language interface to manage MikroTik RouterOS devices, including firewall, system, interfaces, routing, wireless, VPN, containers, and more.
Allows managing OpenVPN server and client connections, certificates, and configurations on MikroTik routers.
Allows managing WireGuard VPN tunnels, interfaces, and peers on MikroTik routers.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@MikroTik Cursor MCPShow me my router's system information"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MikroTik Cursor MCP
A Model Context Protocol (MCP) server for managing MikroTik routers using natural language in Cursor IDE.
Based on mikrotik-mcp by @jeff-nasseri
Overview
This MCP server provides a natural language interface to MikroTik RouterOS devices through Cursor IDE. It translates natural language requests into RouterOS commands via the MikroTik API with SSH fallback.
Architecture
API-First Design: Uses MikroTik API for fast, structured communication
SSH Fallback: Automatically falls back to SSH when API is unavailable
Category-Based Tools: Organizes 440+ actions into 19 logical categories
Dual Transport: API and SSH support with automatic selection
Quick Start
Installation
cd mikrotik-mcp
python -m venv .venv
.venv\Scripts\activate # Windows
# or: source .venv/bin/activate # Linux/Mac
pip install -r requirements.txtConfigure Cursor MCP
Update your Cursor MCP configuration file:
Windows: %APPDATA%\Cursor\User\globalStorage\cursor.mcp\mcp.json
macOS: ~/Library/Application Support/Cursor/User/globalStorage/cursor.mcp/mcp.json
Linux: ~/.config/Cursor/User/globalStorage/cursor.mcp/mcp.json
{
"mcpServers": {
"mikrotik-cursor-mcp": {
"command": "C:\\path\\to\\mikrotik-mcp\\.venv\\Scripts\\python.exe",
"args": ["C:\\path\\to\\mikrotik-mcp\\src\\mcp_mikrotik\\server.py"],
"env": {
"MIKROTIK_HOST": "192.168.88.1",
"MIKROTIK_USERNAME": "your_username",
"MIKROTIK_PASSWORD": "your_password"
}
}
}
}Test Connection
Restart Cursor and ask: "Show me my router's system information"
For detailed setup instructions, see: SETUP_COMPLETE_GUIDE.md
What Is This?
A production-ready MCP server that enables natural language management of MikroTik routers through Cursor IDE. Instead of memorizing RouterOS commands, describe your intent in plain language.
Example:
"Create a WireGuard VPN tunnel to my AWS EC2 instance at 52.1.2.3"
The server translates this into the necessary RouterOS API calls or SSH commands to generate keys, configure interfaces, set up routes, and create firewall rules.
Features
Available Categories
Category | Actions | Coverage |
Firewall | 54 | Filter, NAT, Mangle, RAW, Layer 7, Chains, Address Lists, Connections |
System | 42 | Resources, Identity, Packages, Scheduler, Watchdog, Safe Mode |
IPv6 | 43 | Addresses, Routes, Firewall, DHCPv6, Neighbor Discovery |
Interfaces | 53 | Physical, Virtual, Bridge, PPPoE, Tunnels, Bonding, VRRP, VLAN |
Wireless | 39 | Interfaces, CAPsMAN, Security Profiles, Access Lists |
Routes | 33 | Static, BGP, OSPF, Routing Filters |
Queues | 20 | Simple, Queue Trees, Traffic Shaping |
Container | 18 | Docker Containers, Images, Networking, Environment |
Certificates | 11 | PKI, CA, SSL/TLS |
WireGuard | 11 | Interfaces, Peers, Keys |
Hotspot | 10 | Servers, Users, Captive Portal |
DNS | 15 | Settings, Static Entries, Cache |
OpenVPN | 9 | Client, Server, Certificates |
IP Management | 18 | Addresses, Pools, Services |
DHCP | 7 | Servers, Pools, Leases |
Users | 18 | Management, Groups, Permissions |
Backup | 10 | Create, Restore, Export |
Logs | 10 | View, Search, Clear |
Diagnostics | 9 | Ping, Traceroute, DNS Lookup, ARP, Neighbors |
Total: 440+ actions across 19 categories
Core Capabilities
Dual-Stack Networking: Full IPv4 and IPv6 support
VPN Suite: WireGuard, OpenVPN, certificate management
Dynamic Routing: BGP, OSPF with authentication, route filters
Container Support: Docker containers on RouterOS v7.x
Advanced Wireless: CAPsMAN centralized management
Layer 7 Inspection: Application-aware firewall rules
QoS: Queue trees, traffic shaping
High Availability: VRRP redundancy
Automation: Script scheduler, watchdog monitoring
Installation
Prerequisites
Python 3.8+
Cursor IDE
MikroTik RouterOS device with SSH or API enabled
Network access to the router
Setup Steps
# 1. Clone the repository
git clone https://github.com/kevinpez/mikrotik-cursor-mcp.git
cd mikrotik-cursor-mcp
# 2. Create virtual environment
python -m venv .venv
# On Windows:
.venv\Scripts\activate
# On Linux/Mac:
source .venv/bin/activate
# 3. Install dependencies
pip install -r requirements.txt
# 4. Install the package
pip install -e .Configure Cursor IDE
Add this to your Cursor MCP configuration file (%USERPROFILE%\.cursor\mcp.json on Windows or ~/.cursor/mcp.json on Linux/Mac):
{
"mcpServers": {
"mikrotik-cursor-mcp": {
"command": "python",
"args": [
"-m",
"mcp_mikrotik.server"
],
"cwd": "C:\\Users\\YourUsername\\mikrotik-cursor-mcp",
"env": {
"MIKROTIK_HOST": "192.168.88.1",
"MIKROTIK_USERNAME": "admin",
"MIKROTIK_PASSWORD": "your-password",
"MIKROTIK_PORT": "22",
"MIKROTIK_SSH_KEY": "C:\\Users\\YourUsername\\.ssh\\mikrotik_rsa",
"MIKROTIK_STRICT_HOST_KEY_CHECKING": "false",
"MIKROTIK_KNOWN_HOSTS": "C:\\Users\\YourUsername\\.ssh\\known_hosts",
"MIKROTIK_CONNECT_TIMEOUT": "10",
"MIKROTIK_CMD_TIMEOUT": "30"
}
}
}
}Important: Replace the paths and credentials with your actual values.
Verify Installation
Restart Cursor IDE completely
Open a new Cursor chat
Ask: "List all backups on my MikroTik router"
Usage Examples
Natural Language Commands
Basic Management
"Show me the system resources and uptime"
"List all network interfaces and their status"
"What's in my ARP table?"
"Create a backup called 'before-vpn-setup'"Firewall & Security
"Create a firewall rule to allow SSH from 10.0.0.0/8"
"Block all traffic from 192.168.99.0/24"
"Show me active connections"
"Create a port forward: external 8080 to internal 192.168.1.100:80"VPN Setup
"Set up a WireGuard VPN to my AWS server at 52.1.2.3"
"Create an OpenVPN client connection to my office"
"List all WireGuard interfaces and their status"IPv6 Networking
"Add IPv6 address 2001:db8::1/64 to bridge"
"Enable IPv6 forwarding"
"List IPv6 neighbors"
"Create a DHCPv6 server on bridge interface"Wireless Management
"List all wireless interfaces"
"Scan for nearby WiFi networks"
"Show connected wireless clients"
"Enable CAPsMAN controller"Container Management (RouterOS v7.x)
"List all containers"
"Create a container from nginx:latest"
"Show container configuration"
"Create a veth interface for containers"Dynamic Routing
"List BGP peers"
"Show OSPF neighbors"
"Create a route filter"Architecture
Category-Based Organization
The MCP uses category-based tools to organize functionality:
Traditional Approach: This MCP:
├─ mikrotik_list_firewall ├─ mikrotik_firewall
├─ mikrotik_create_firewall ├─ list_filter_rules
├─ mikrotik_update_firewall ├─ create_filter_rule
├─ mikrotik_list_nat ├─ list_nat_rules
├─ mikrotik_create_nat └─ ... (54 actions)
├─ mikrotik_port_forward
... (100+ separate tools) └─ mikrotik_ipv6 (43 actions)Technology Stack
Python 3.8+ - Core language
MCP SDK - Model Context Protocol implementation
RouterOS API - Primary communication method
Paramiko - SSH fallback connectivity
RouterOS CLI - Command execution via SSH
Communication Flow
┌───────────────┐ ┌────────────────────┐ ┌───────────────┐
│ Cursor IDE │ │ MikroTik MCP │ │ RouterOS │
│ + AI │──────▶│ Server │──API▶ │ Device │
└───────────────┘ └────────────────────┘ └───────────────┘
│ │ │
│ Natural language request │ │
│─────────────────────────▶ │
│ │ Parse & translate │
│ │ Execute via API/SSH │
│ ├─────────────────────────▶
│ │ Verify results │
│ │◀─────────────────────────│
│ Structured response │ │
◀─────────────────────────────────│ │Testing
Hardware Validation Suite
The project includes a comprehensive hardware validation suite that tests all handlers against live MikroTik hardware.
# Test all handlers
python tests/hardware_validation.py
# Test specific category with verbose output
python tests/hardware_validation.py --category System -v
# Save test results to JSON
python tests/hardware_validation.py --report results.json
# List available categories
python tests/hardware_validation.py --list-categoriesTest Configuration
Create a .env.test file in the project root:
MIKROTIK_HOST=192.168.88.1
MIKROTIK_USERNAME=admin
MIKROTIK_PASSWORD=your_password
MIKROTIK_PORT=22
MIKROTIK_LOG_LEVEL=INFOTest Categories
The test suite covers all 19 categories:
System, Backup, Certificates, Containers
DHCP, DNS, Diagnostics
Firewall (Filter, NAT, Mangle, RAW)
Hotspot, IP Services, IPv6
Interfaces, Logs, OpenVPN
Queues, Routes, Routing Filters
Users, Wireless, WireGuard, CAPsMAN
See TESTING.md for complete testing documentation.
Security Considerations
Credentials
Never commit credentials to version control
Use environment variables for sensitive data
Consider SSH keys instead of passwords
Network Access
Ensure secure SSH/API access to router
Use firewall rules to restrict management access
Enable two-factor authentication if available
Backup Strategy
Create backups before major changes
Use built-in backup commands
Store backups in multiple locations
Testing
Test on non-production routers first
Use isolated VLANs for experiments
Maintain out-of-band access
Troubleshooting
MCP Not Loading
Symptoms: Cursor doesn't recognize MikroTik commands
Solutions:
Verify
mcp.jsonpath and formatCheck Python path in configuration
Ensure virtual environment is activated
Restart Cursor completely
Connection Issues
Symptoms: "Failed to connect" errors
Solutions:
Verify
MIKROTIK_HOSTis correctCheck SSH/API is enabled:
/ip service printTest manual SSH:
ssh admin@192.168.88.1Verify firewall rules allow SSH/API
Command Failures
Symptoms: Commands return errors
Solutions:
Check RouterOS version compatibility
Verify required packages are installed
Check user permissions
Review router logs:
/log print
Performance Issues
Symptoms: Slow responses
Solutions:
Check network latency to router
Reduce concurrent operations
Verify router has sufficient resources
Update to latest RouterOS version
Contributing
Contributions are welcome.
Reporting Issues
Use GitHub Issues
Include RouterOS version
Provide command examples
Share error messages
Feature Requests
Check existing requests
Describe use case
Explain RouterOS capability
Pull Requests
Fork the repository
Create feature branch
Test on live router
Update documentation
Submit PR with clear description
License
MIT License - see LICENSE file
Acknowledgments
@jeff-nasseri - Original mikrotik-mcp project
@kevinpez - Extended implementation
MikroTik - RouterOS platform
Anthropic - Claude and MCP protocol
Cursor Team - AI-powered IDE
Support
GitHub Issues: Report bugs or request features
GitHub Discussions: Ask questions or share use cases
Documentation: See documentation section below
Documentation
Getting Started
Quick Start - Installation and configuration
Setup Guide - Complete installation and configuration
Testing Guide - Comprehensive testing procedures
User Guides
Security Guide - Security best practices and hardening
User Guides - IP Services and Safe Mode operations
Development
Contributing - Contribution guidelines
Changelog - Version history
Roadmap - Future development plans
License - MIT License
MikroTik RouterOS automation through natural language
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/kevinpez/mikrotik-cursor-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server