stormbliss/SDWAN-MCP-SERVER
If you are the rightful owner of SDWAN-MCP-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 dayong@mcphub.com.
A comprehensive Model Context Protocol (MCP) server for monitoring and managing SD-WAN devices through REST API endpoints.
SD-WAN MCP Server
A comprehensive Model Context Protocol (MCP) server for monitoring and managing SD-WAN devices through REST API endpoints. This server exposes SD-WAN device monitoring and management functionality that can be integrated with Cursor and other MCP-compatible tools.
🚀 Features
- 🔧 Device Management: List and monitor SD-WAN fabric devices
- 📊 Statistics Collection: Interface statistics, device counters, tunnel statistics
- 🔍 BFD Monitoring: Bidirectional Forwarding Detection state and sessions
- ⚙️ Configuration Access: Device configuration retrieval
- 📈 Advanced Analytics: Health summaries, traffic analysis, and alerting
- 🔐 Session Management: Automatic authentication and session handling
- ⚡ Async Support: Full async/await support for non-blocking operations
- 🎯 Cursor Integration: Seamless integration with Cursor IDE
📋 Available Tools
Basic Monitoring Tools
- get_fabric_devices - Get list of all SD-WAN fabric devices
- get_device_monitor - Get SD-WAN device monitoring information
- get_device_counters - Get SD-WAN device counters and statistics
- get_interface_statistics - Get interface statistics for all SD-WAN devices
- get_device_config - Get SD-WAN device configuration (requires device_id)
- get_bfd_state - Get BFD state for an SD-WAN device (requires device_id)
- get_bfd_sessions - Get BFD sessions for an SD-WAN device (requires device_id)
- get_tunnel_statistics - Get tunnel statistics for an SD-WAN device (requires device_id)
Authentication Tools
- authenticate - Authenticate with the SD-WAN management server
- get_session_status - Check current authentication session status
Advanced Analytics Tools
- get_device_health_summary - Comprehensive health summary across all SD-WAN devices
- filter_devices_by_status - Filter SD-WAN devices by operational status
- get_top_interfaces_by_traffic - Get top interfaces ranked by traffic utilization
- check_bfd_session_health - Monitor BFD session health across all SD-WAN devices
- generate_network_report - Generate comprehensive SD-WAN network status report
- get_device_alerts - Get alerts and warnings for SD-WAN devices by severity
- monitor_interface_utilization - Monitor interface utilization with configurable thresholds
- get_network_topology - Get SD-WAN network topology information
🛠️ Quick Start
Prerequisites
- Python 3.8 or higher
- Access to SD-WAN management server
- Cursor IDE (for integration)
Installation
-
Clone the repository
git clone https://github.com/yourusername/sdwan-mcp-server.git cd sdwan-mcp-server -
Install dependencies
pip install -r requirements.txt -
Configure environment variables
# Copy the example environment file cp .env.example .env # Edit .env with your settings nano .env -
Update configuration
⚠️ IMPORTANT: You must update the IP address in your configuration!
Edit your
.envfile:# REQUIRED: Change this to your SD-WAN management server IP SDWAN_BASE_URL="https://YOUR_SDWAN_SERVER_IP:8443" # Update credentials SDWAN_USERNAME="your_username" SDWAN_PASSWORD="your_password" # Optional settings VERIFY_SSL="false" LOG_LEVEL="INFO" -
Test the server
python test_client.py -
Run the server
python main.py
⚙️ Configuration
Environment Variables
| Variable | Description | Default | Required |
|---|---|---|---|
SDWAN_BASE_URL | SD-WAN server base URL | https://192.168.10.130:8443 | ✅ YES |
SDWAN_USERNAME | Authentication username | admin | ✅ YES |
SDWAN_PASSWORD | Authentication password | 1 | ✅ YES |
VERIFY_SSL | Enable SSL certificate verification | false | No |
LOG_LEVEL | Logging level (DEBUG, INFO, WARNING, ERROR) | INFO | No |
SESSION_TIMEOUT | Session timeout in seconds | 3600 | No |
AUTO_RECONNECT | Auto-reconnect on session expiry | true | No |
Configuration Methods
Method 1: Environment Variables (Recommended)
export SDWAN_BASE_URL="https://your-sdwan-server:8443"
export SDWAN_USERNAME="admin"
export SDWAN_PASSWORD="your_password"
python main.py
Method 2: .env File
# Create .env file
echo "SDWAN_BASE_URL=https://your-sdwan-server:8443" > .env
echo "SDWAN_USERNAME=admin" >> .env
echo "SDWAN_PASSWORD=your_password" >> .env
python main.py
Method 3: Direct Configuration
Edit config.py to change default values (not recommended for production).
🔧 Cursor Integration
Option 1: MCP Configuration File
-
Create or update your MCP configuration file:
{ "mcpServers": { "sdwan-mcp-server": { "command": "python", "args": ["/full/path/to/your/project/main.py"], "env": { "SDWAN_BASE_URL": "https://your-sdwan-server:8443", "SDWAN_USERNAME": "admin", "SDWAN_PASSWORD": "your_password" } } } } -
Update the path to point to your
main.pyfile -
Restart Cursor
Option 2: Cursor Settings
Add to your Cursor settings:
{
"mcp": {
"servers": {
"sdwan-mcp-server": {
"command": "python",
"args": ["/full/path/to/main.py"]
}
}
}
}
💡 Usage Examples
Once integrated with Cursor, you can use natural language queries:
Basic Queries
- "Show me all SD-WAN fabric devices"
- "Get the SD-WAN interface statistics"
- "Check BFD state for SD-WAN device 200.0.1.1"
- "Get tunnel statistics for SD-WAN device 200.0.2.2"
Advanced Analytics
- "Give me a comprehensive health summary of the SD-WAN network"
- "Show me all SD-WAN devices that are currently down"
- "What are the top 10 interfaces by traffic volume?"
- "Generate a full SD-WAN network report"
- "Which interfaces are using more than 80% bandwidth?"
Troubleshooting
- "Check if I'm authenticated to the SD-WAN server"
- "Show me all critical alerts in the SD-WAN network"
- "What SD-WAN devices need immediate attention?"
🏗️ Project Structure
sdwan-mcp-server/
├── main.py # Main MCP server implementation
├── config.py # Configuration management
├── test_client.py # Test client for validation
├── requirements.txt # Python dependencies
├── setup.py # Package setup
├── mcp_config.json # MCP configuration template
├── .env.example # Environment variables template
├── .gitignore # Git ignore file
├── LICENSE # MIT license
└── README.md # This file
🔍 API Endpoints
The server connects to these SD-WAN management API endpoints:
/dataservice/device- Fabric devices/dataservice/device/monitor- Device monitoring/dataservice/device/counters- Device counters/dataservice/statistics/interface- Interface statistics/dataservice/device/config- Device configuration/dataservice/device/bfd/state/device- BFD state/dataservice/device/bfd/sessions- BFD sessions/dataservice/device/tunnel/statistics- Tunnel statistics
🐛 Troubleshooting
Common Issues
-
Connection Errors
# Check if your SD-WAN server is accessible curl -k https://YOUR_SDWAN_SERVER_IP:8443 -
Authentication Errors
# Verify credentials export SDWAN_USERNAME="correct_username" export SDWAN_PASSWORD="correct_password" -
SSL Certificate Issues
# Disable SSL verification for self-signed certificates export VERIFY_SSL="false" -
Import Errors
# Install missing dependencies pip install -r requirements.txt
Debug Mode
Enable detailed logging:
export LOG_LEVEL="DEBUG"
python main.py
Testing Connection
# Test authentication
python -c "
import asyncio
from main import SDWANMCPServer
async def test():
server = SDWANMCPServer()
result = await server._authenticate()
print(result)
asyncio.run(test())
"
🤝 Contributing
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
📝 License
This project is licensed under the MIT License - see the file for details.
🆘 Support
- Issues: GitHub Issues
- Discussions: GitHub Discussions
🙏 Acknowledgments
- Built with Model Context Protocol (MCP)
- Designed for Cursor IDE and [CLAUDE DESKTOP]
- SD-WAN management capabilities
⚠️ Remember: Always update the SDWAN_BASE_URL to match your SD-WAN management server's IP address!