MCP ExplorerExplorer

Pox Mcp Server

@davidlin2kon 10 months ago
1 MIT
FreeCommunity
AI Systems
A Model Context Protocol (MCP) server for the POX SDN controller

Overview

What is Pox Mcp Server

The pox-mcp-server is a Model Context Protocol (MCP) server implementation designed for the POX SDN controller, providing network control and management capabilities through Python-based programming and OpenFlow device management.

Use cases

Use cases for the pox-mcp-server include managing OpenFlow switches, developing network applications, conducting network topology analysis, and experimenting with SDN concepts in a controlled environment.

How to use

To use the pox-mcp-server, set up the POX SDN controller and access its dynamic resources via specified prompts. Utilize the interactive prompts for network management and implement basic network functionalities such as L2 hub and learning switch.

Key features

Key features include dynamic resource exposure for network configuration and topology, interactive management prompts, and core tools for datapath management, enabling efficient network programming and analysis.

Where to use

The pox-mcp-server is suitable for educational environments, network prototyping, and SDN research, providing a practical platform for learning and experimentation in software-defined networking.

Content

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
  • 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
  • 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

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 identifier
      • match (object, optional): POX match structure
      • table_id (string, optional): OpenFlow table ID
      • out_port (string, optional): Output port filter
    • Returns: POX flow statistics including packet counts
  • set_table

    • Configure POX flow tables
    • Input:
      • dpid (string): Datapath identifier
      • flows (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.

Tools

No tools

Comments

Recommend MCP Servers

View All MCP Servers