A Model Context Protocol (MCP) server for the POX SDN controller
- • Core MCP protocol features implemented (25/40)
- • Room for improvement in GitHub community
- • Optimal dependency management (20/20)
- • Room for improvement in deployment maturity
- • Documentation (8/8)
- • Archestra MCP Trust score badge is missing
{
"pox": {
"command": "uv",
"args": [
"--directory",
"parent_of_servers_repo/servers/src/mcp_server_pox",
"run",
"server.py"
],
"env": {
"POX_SERVER_URL": "http://localhost:8000"
}
}
}POX MCP Server
Overview
A Model Context Protocol (MCP) server implementation that provides network control and management capabilities through the POX SDN controller. This server enables Python-based network programming, OpenFlow device management, and automated network analysis through POX's modular architecture. Perfect for educational environments, network prototyping, and SDN research.
Components
Resources
The server exposes two dynamic resources:
pox://network-config: A comprehensive POX controller configuration memo- Tracks active POX components and their configurations
- Records network topology and flow rules
- Maintains discovered network insights
pox://topology: Real-time network topology view- Shows active OpenFlow datapaths (switches)
- Maps host locations and connections
- Displays link status and port mappings
Prompts
The server provides three specialized prompts:
-
pox-network-manager: Interactive prompt for POX controller management- Required argument:
topic- The network control aspect to focus on - Helps configure POX components and modules
- Guides through network policy implementation
- Integrates with network configuration memo
- Required argument:
-
simple-hub: Basic L2 hub implementation using POX- Required argument:
dpid- The datapath identifier - Demonstrates POX's event-driven programming
- Shows basic packet handling and flooding
- Explains POX's core mechanisms
- Required argument:
-
learning-switch: L2 learning switch implementation- Required argument:
dpid- The datapath identifier - Showcases POX's table management
- Implements MAC learning and forwarding
- Demonstrates POX's packet handling capabilities
- Required argument:
Tools
The server offers five core tools:
Datapath Management Tools
-
get_switches- List all connected OpenFlow datapaths
- No input required
- Returns: Array of active POX-controlled switches
- Includes connection status and capabilities
-
get_switch_desc- Get detailed datapath information
- Input:
dpid(string): Datapath identifier
- Returns: POX-managed switch details and features
Flow Management Tools
-
get_flow_stats- Retrieve POX flow statistics
- Input:
dpid(string): Datapath identifiermatch(object, optional): POX match structuretable_id(string, optional): OpenFlow table IDout_port(string, optional): Output port filter
- Returns: POX flow statistics including packet counts
-
set_table- Configure POX flow tables
- Input:
dpid(string): Datapath identifierflows(array): POX flow specifications
- Returns: Flow table update confirmation
Analysis Tools
append_insight- Add network insights to POX configuration memo
- Input:
insight(string): Network observation or analysis
- Returns: Insight addition confirmation
- Updates pox://network-config resource
Usage with Claude Desktop
uv
{
"mcpServers": {
"pox": {
"command": "uv",
"args": [
"--directory",
"parent_of_servers_repo/servers/src/mcp_server_pox",
"run",
"server.py"
],
"env": {
"POX_SERVER_URL": "http://localhost:8000"
}
}
}
}
License
This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.
Contributing
Contributions are welcome! Please feel free to submit pull requests, report bugs, or suggest new features.
[](https://archestra.ai/mcp-catalog/davidlin2k__pox-mcp-server)POX MCP Server
Overview
A Model Context Protocol (MCP) server implementation that provides network control and management capabilities through the POX SDN controller. This server enables Python-based network programming, OpenFlow device management, and automated network analysis through POX's modular architecture. Perfect for educational environments, network prototyping, and SDN research.
Components
Resources
The server exposes two dynamic resources:
pox://network-config: A comprehensive POX controller configuration memo- Tracks active POX components and their configurations
- Records network topology and flow rules
- Maintains discovered network insights
pox://topology: Real-time network topology view- Shows active OpenFlow datapaths (switches)
- Maps host locations and connections
- Displays link status and port mappings
Prompts
The server provides three specialized prompts:
-
pox-network-manager: Interactive prompt for POX controller management- Required argument:
topic- The network control aspect to focus on - Helps configure POX components and modules
- Guides through network policy implementation
- Integrates with network configuration memo
- Required argument:
-
simple-hub: Basic L2 hub implementation using POX- Required argument:
dpid- The datapath identifier - Demonstrates POX's event-driven programming
- Shows basic packet handling and flooding
- Explains POX's core mechanisms
- Required argument:
-
learning-switch: L2 learning switch implementation- Required argument:
dpid- The datapath identifier - Showcases POX's table management
- Implements MAC learning and forwarding
- Demonstrates POX's packet handling capabilities
- Required argument:
Tools
The server offers five core tools:
Datapath Management Tools
-
get_switches- List all connected OpenFlow datapaths
- No input required
- Returns: Array of active POX-controlled switches
- Includes connection status and capabilities
-
get_switch_desc- Get detailed datapath information
- Input:
dpid(string): Datapath identifier
- Returns: POX-managed switch details and features
Flow Management Tools
-
get_flow_stats- Retrieve POX flow statistics
- Input:
dpid(string): Datapath identifiermatch(object, optional): POX match structuretable_id(string, optional): OpenFlow table IDout_port(string, optional): Output port filter
- Returns: POX flow statistics including packet counts
-
set_table- Configure POX flow tables
- Input:
dpid(string): Datapath identifierflows(array): POX flow specifications
- Returns: Flow table update confirmation
Analysis Tools
append_insight- Add network insights to POX configuration memo
- Input:
insight(string): Network observation or analysis
- Returns: Insight addition confirmation
- Updates pox://network-config resource
Usage with Claude Desktop
uv
{
"mcpServers": {
"pox": {
"command": "uv",
"args": [
"--directory",
"parent_of_servers_repo/servers/src/mcp_server_pox",
"run",
"server.py"
],
"env": {
"POX_SERVER_URL": "http://localhost:8000"
}
}
}
}
License
This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.
Contributing
Contributions are welcome! Please feel free to submit pull requests, report bugs, or suggest new features.
Related MCP Servers
Agent-MCP
89/100Agent-MCP is a framework for creating multi-agent systems that enables coordinated, efficient AI collaboration through the Model Context Protocol (MCP). The system is designed for developers building AI applications that benefit from multiple specialized agents working in parallel on different aspects of a project.
serena
85/100A powerful coding agent toolkit providing semantic retrieval and editing capabilities (MCP server & other integrations)
JFrog MCP Server
85/100Official JFrog MCP server that enables AI assistants to interact with the JFrog Platform. Supports repository management, build tracking, runtime monitoring, artifact searching, package intelligence, and Xray security scanning.
context7
82/100Context7 MCP Server -- Up-to-date code documentation for LLMs and AI code editors
gk-cli
81/100GitKraken CLI Releases and Documentation
Excalidraw
80/100Remote MCP server for Excalidraw - streams hand-drawn diagrams with smooth viewport camera control and interactive fullscreen editing
