pyATS MCP Server
Model-driven STDIO server for safe, structured network automation with Cisco devices.
Key Features
Use Cases
README
pyATS MCP Server
This project implements a Model Context Protocol (MCP) Server that wraps Cisco pyATS and Genie functionality. It enables structured, model-driven interaction with network devices over STDIO using the JSON-RPC 2.0 protocol.
π¨ This server does not use HTTP or SSE. All communication is done via STDIN/STDOUT (standard input/output), making it ideal for secure, embedded, containerized, or LangGraph-based tool integrations.
π§ What It Does
Connects to Cisco IOS/NX-OS devices defined in a pyATS testbed
Supports safe execution of validated CLI commands (show, ping)
Allows controlled configuration changes
Returns structured (parsed) or raw output
Exposes a set of well-defined tools via tools/discover and tools/call
Operates entirely via STDIO for minimal surface area and maximum portability
π Usage
- Set your testbed path
export PYATS_TESTBED_PATH=/absolute/path/to/testbed.yaml
- Run the server
Continuous STDIO Mode (default)
python3 pyats_mcp_server.py
Launches a long-running process that reads JSON-RPC requests from stdin and writes responses to stdout.
One-Shot Mode
echo '{"jsonrpc": "2.0", "id": 1, "method": "tools/discover"}' | python3 pyats_mcp_server.py --oneshot
Processes a single JSON-RPC request and exits.
π¦ Docker Support
Build the container
docker build -t pyats-mcp-server .
Run the container (STDIO Mode)
docker run -i --rm \
-e PYATS_TESTBED_PATH=/app/testbed.yaml \
-v /your/testbed/folder:/app \
pyats-mcp-server
π§ Available MCP Tools
Tool Description
run_show_command Executes show commands safely with optional parsing
run_ping_command Executes ping tests and returns parsed or raw results
apply_configuration Applies safe configuration commands (multi-line supported)
learn_config Fetches running config (show run brief)
learn_logging Fetches system logs (show logging last 250)
All inputs are validated using Pydantic schemas for safety and consistency.
π€ LangGraph Integration
Add the MCP server as a tool node in your LangGraph pipeline like so:
("pyats-mcp", ["python3", "pyats_mcp_server.py", "--oneshot"], "tools/discover", "tools/call")
Name: pyats-mcp
Command: python3 pyats_mcp_server.py --oneshot
Discover Method: tools/discover
Call Method: tools/call
STDIO-based communication ensures tight integration with LangGraphβs tool invocation model without opening HTTP ports or exposing REST endpoints.
π Example Requests
Discover Tools
{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/discover"
}
Run Show Command
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "run_show_command",
"arguments": {
"device_name": "router1",
"command": "show ip interface brief"
}
}
}
π Security Features
Input validation using Pydantic
Blocks unsafe commands like erase, reload, write
Prevents pipe/redirect abuse (e.g., | include, >, copy, etc.)
Gracefully handles parsing fallbacks and errors
π Project Structure
.
βββ pyats_mcp_server.py # MCP server with JSON-RPC and pyATS integration
βββ Dockerfile # Docker container definition
βββ testbed.yaml # pyATS testbed (user-provided)
βββ README.md # This file
π₯ MCP Server Config Example (pyATS MCP via Docker)
To run the pyATS MCP Server as a container with STDIO integration, configure your mcpServers like this:
{
"mcpServers": {
"pyats": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"-e",
"PYATS_TESTBED_PATH",
"-v",
"/absolute/path/to/testbed/folder:/app",
"pyats-mcp-server"
],
"env": {
"PYATS_TESTBED_PATH": "/app/testbed.yaml"
}
}
}
}
{
"servers": {
"pyats": {
"type": "stdio",
"command": "python3",
"args": [
"-u",
"/Users/johncapobianco/pyATS_MCP/pyats_mcp_server.py"
],
"env": {
"PYATS_TESTBED_PATH": "/Users/johncapobianco/pyATS_MCP/testbed.yaml"
}
}
}
π§Ύ Explanation: command: Uses Docker to launch the containerized pyATS MCP server
args:
-i: Keeps STDIN open for communication
--rm: Automatically removes the container after execution
-e: Injects the environment variable PYATS_TESTBED_PATH
-v: Mounts your local testbed directory into the container
pyats-mcp-server: Name of the Docker image
env:
Sets the path to the testbed file inside the container (/app/testbed.yaml)
βοΈ Author
John Capobianco
Product Marketing Evangelist, Selector AI
Author, Automate Your Network
Let me know if youβd like to add:
A sample LangGraph graph config
Companion client script
CI/CD integration (e.g., GitHub Actions)
Happy to help!
The testbed.yaml file works with the Cisco DevNet Cisco Modeling Labs (CML) Sandbox!
Star History
Repository Owner
User
Repository Details
Programming Languages
Tags
Join Our Newsletter
Stay updated with the latest AI tools, news, and offers by subscribing to our weekly newsletter.
Related MCPs
Discover similar Model Context Protocol servers
MCP Shell Server
A secure, configurable shell command execution server implementing the Model Context Protocol.
MCP Shell Server provides secure remote execution of whitelisted shell commands via the Model Context Protocol (MCP). It supports standard input, command output retrieval, and enforces strict safety checks on command operations. The tool allows configuration of allowed commands and execution timeouts, and can be integrated with platforms such as Claude.app and Smithery. With robust security assessments and flexible deployment methods, it facilitates controlled shell access for AI agents.
- β 153
- MCP
- tumf/mcp-shell-server
POX MCP Server
Model Context Protocol server for SDN management via the POX controller.
Implements a Model Context Protocol (MCP) server for network control and management using the POX SDN controller. Provides dynamic resources for network configuration and topology, interactive management prompts, and a suite of tools for switch and flow administration. Supports Python-based SDN programming and automated analysis in educational and research settings.
- β 1
- MCP
- davidlin2k/pox-mcp-server
HarmonyOS MCP Server
Enables HarmonyOS device manipulation via the Model Context Protocol.
HarmonyOS MCP Server provides an MCP-compatible server that allows programmatic control of HarmonyOS devices. It integrates with tools and frameworks such as OpenAI's openai-agents SDK and LangGraph to facilitate LLM-powered automation workflows. The server supports execution through standard interfaces and can be used with agent platforms to process natural language instructions for device actions. Its design allows for seamless interaction with HarmonyOS systems using the Model Context Protocol.
- β 25
- MCP
- XixianLiang/HarmonyOS-mcp-server
CLI MCP Server
A secure MCP server for controlled command-line operations.
CLI MCP Server provides a secure implementation of the Model Context Protocol (MCP) for executing command-line operations with robust security features. It enables controlled CLI access by enforcing command and flag whitelisting, path validation, and shell operator restrictions, making it suitable for integration with large language model applications. Designed for configurable deployment, it supports detailed error reporting, execution timeouts, and strict working directory controls.
- β 155
- MCP
- MladenSU/cli-mcp-server
OPNsense MCP Server
AI-powered firewall and network management for OPNsense
OPNsense MCP Server provides a comprehensive Model Context Protocol server for automating and managing OPNsense firewall configurations. It enables AI assistants, such as Claude, to directly interact with and control networking features including firewall rules, NAT, VLANs, diagnostics, and advanced system operations via API and SSH. The tool supports batch operations, direct command execution, and advanced troubleshooting, enhancing network management automation. It also supports integration for infrastructure as code and toolchains supporting MCP environments.
- β 26
- MCP
- vespo92/OPNSenseMCP
Higress OPS MCP Server
Model Context Protocol server and client for fully managed Higress configuration.
Higress OPS MCP Server delivers a Model Context Protocol-compliant server and client for centralized configuration and management of Higress. It leverages a flexible tool-based architecture and offers seamless integration with LangGraph and LangChain MCP Adapters, streamlining agent-driven workflows for system operations. The package allows developers to define, extend, and register custom tools, supporting secure interaction with the Higress Console API. Sensitive actions can be flagged for human confirmation to enhance operational safety.
- β 22
- MCP
- higress-group/higress-ops-mcp-server
Didn't find tool you were looking for?