packet-tracer-mcp
Enables control of Cisco Packet Tracer 9.0 via natural language, allowing creation of network topologies, device configuration, and simulation launches through an MCP interface.
README
packet-tracer-mcp
Servidor Model Context Protocol para controlar Cisco Packet Tracer 9.0 desde fuera. Una extensión propia se cuelga del editor de PT, abre un bridge HTTP local y desde ahí el servidor MCP llama a la API IPC nativa de PT para crear topologías, configurar routers, lanzar simulaciones, etc. Escrito en TypeScript sobre Bun.
[!WARNING] Proyecto experimental. Es la versión 0.1.0, hecha en mis ratos libres como experimento personal. Funciona contra PT 9.0.0.0810 en mi PC y pasa los smoke tests, pero no la consideres lista para producción. Espera bugs, cambios de API y cosas que se rompen al actualizar PT. Si te animas a probarla, abre issues con lo que veas.

<sub>Demo acelerada x15: el cliente MCP lanza una receta y el canvas de Packet Tracer 9 se va llenando solo (devices, cableado, configuración).</sub>
Autor: Juan Cordero Pascual · Licencia: MIT Idiomas: español (este archivo) · English
Tabla de contenidos
- Por qué otro MCP de Packet Tracer
- Filosofía: canvas-first
- Requisitos
- Arranque rápido
- Capacidades
- Recetas incluidas
- Configuración
- Documentación
- FAQ
- Estructura del proyecto
- Estado
Por qué otro MCP de Packet Tracer
Los proyectos para PT 6.x–8.x se apoyaban en librerías JS cargadas por
una extensión firmada de terceros. PT 9.0 cerró ese camino: los
App Meta Files (.pta) ahora tienen que ir firmados con ECDSA por
Cisco, así que ningún proyecto open-source puede entregar uno. La
alternativa que queda es hablar con la webview de PT desde fuera, y eso
es lo que hace este servidor:
- Hay una extensión
.ptspropia que se instala desde el menú Extensions de PT. Lo único que hace es arrancar un bucle de polling contra el bridge HTTP local. - Cuando el servidor MCP necesita escribir, llama a la API IPC nativa
de PT directamente: cosas como
ipc.appWindow().getActiveWorkspace().getLogicalWorkspace().addDevice(...)ogetDevice(...).getCommandLine().enterCommand(...). Sin librerías intermedias, sin JS opaco copiado de otros sitios. - Todo el JS que termina ejecutándose en el Script Engine de PT lo
genera este repo. Si quieres saber qué se está mandando, está en
src/ipc/.
Filosofía: canvas-first
Otras herramientas mantienen un objeto "plan" en memoria, lo validan y al final lo vuelcan al simulador. Aquí no funciona así:
- No hay ningún
TopologyPlanen memoria. Lo que hay en PT es lo que hay; el plan es el canvas. - Cada receta vuelve a leer un snapshot del canvas antes de actuar. Si la lanzas dos veces sobre un canvas a medio construir, la segunda vez termina lo que faltaba en lugar de duplicar dispositivos. Sale idempotente sin tener que pensarlo.
- La validación se hace contra el canvas vivo, no contra una estructura interna. Cuando algo falla (IPs duplicadas, peers en subredes distintas, un router apagado) lo ves directamente en PT, no en un grafo abstracto.
- La persistencia guarda snapshots, no planes. Volver atrás significa comparar el canvas actual con un dump anterior y ver qué ha cambiado. No hay rehidratación mágica.
Si quieres el detalle, está en docs/ARCHITECTURE.md.
Requisitos
- Cisco Packet Tracer 9.0 (macOS, Windows o Linux).
- Bun
>=1.2. Con Node solo no vale: el código es TypeScript y se ejecuta directamente con Bun, sin paso previo de compilación. - La extensión
mcp-bridge.ptsinstalada en PT. Viene en el repo enextension/dist/.
[!TIP] ¿Por qué Bun y no Node? Bun ejecuta
.tsnativamente, arranca en milisegundos y trae fetch, HTTP y test runner de serie sin instalar dependencias. Si solo tienes Node, puedes instalar Bun concurl -fsSL https://bun.sh/install | bash(obrew install bunen macOS). Convive con Node sin pisarse.
Arranque rápido
git clone https://github.com/jcorderop02/packet-tracer-mcp.git
cd packet-tracer-mcp
bun install
bun run start # streamable-HTTP en :39001 (default)
# o bien:
bun run src/index.ts --stdio # modo stdio para clientes MCP que lo prefieran
En Packet Tracer 9:
Extensions > Scripting > Configure PT Script Modules > Addy seleccionaextension/dist/mcp-bridge.pts.- Marca la extensión como activa.
- Abre la ventana desde
Extensions > MCP Bridgeuna vez por sesión.
El polling arranca solo en cuanto la ventana se carga. Para comprobar
que todo está bien, lanza pt_bridge_status: en menos de un segundo
debería responder connected: true.
El proceso completo de instalación está en
docs/BOOTSTRAP.md.
El endpoint MCP queda en:
http://127.0.0.1:39001/mcp
[!NOTE] Por qué
:39001. PT 9 ya tiene su propio IPC nativo (no documentado, con handshake firmado por Cisco) escuchando en:39000. Para no chocar y dejar claro que el servidor MCP es algo aparte, este escucha en:39001. Si te molesta, cámbialo con la variable de entornoPACKETTRACER_MCP_PORT.
Conectar un cliente MCP
<details> <summary><strong>Claude Code</strong> (CLI, recomendado)</summary>
Una sola línea, sin tocar JSON:
claude mcp add --transport http packet-tracer http://127.0.0.1:39001/mcp
Verifica con /mcp dentro de Claude Code: debe aparecer packet-tracer
con sus 57 tools.
</details>
<details> <summary><strong>Claude Desktop</strong></summary>
Edita ~/Library/Application Support/Claude/claude_desktop_config.json
(macOS) o el equivalente en tu SO y reinicia Claude Desktop:
{
"mcpServers": {
"packet-tracer": {
"url": "http://127.0.0.1:39001/mcp"
}
}
}
</details>
<details> <summary><strong>Cursor</strong></summary>
Settings → MCP → Add new MCP server → pega la URL
http://127.0.0.1:39001/mcp con transporte http.
</details>
<details> <summary><strong>VS Code</strong> (Continue / Cline)</summary>
En el config.json del cliente:
{
"mcpServers": {
"packet-tracer": {
"url": "http://127.0.0.1:39001/mcp"
}
}
}
</details>
<details> <summary><strong>Gemini CLI</strong></summary>
Edita ~/.gemini/settings.json:
{
"mcpServers": {
"packet-tracer": {
"httpUrl": "http://127.0.0.1:39001/mcp"
}
}
}
Verifica con /mcp list.
</details>
<details> <summary><strong>Codex CLI</strong></summary>
Edita ~/.codex/config.toml:
[mcp_servers.packet-tracer]
url = "http://127.0.0.1:39001/mcp"
</details>
<details> <summary><strong>Smoke con <code>curl</code></strong> (sin cliente)</summary>
Para confirmar que el server responde antes de configurar nada:
curl -sS -X POST http://127.0.0.1:39001/mcp \
-H "Content-Type: application/json" \
-H "Accept: application/json, text/event-stream" \
-d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"smoke","version":"1.0"}}}'
Debe devolver un result con serverInfo.name = "packet-tracer-mcp". Un
segundo POST con "method":"tools/list" devuelve las 57 tools con su
inputSchema.
</details>
Compilar a binario único
bun run build
./dist/packet-tracer-mcp
Tests
bun test
La suite unitaria cubre la aritmética de subnetting, la inspección del canvas, el parser de snapshots, los diffs, la validación de blueprints y los builders CLI de cada receta. No hace falta PT corriendo para ejecutarla.
Recorrido end-to-end
Con el bridge conectado (pt_bridge_status → connected: true), una
sesión completa más o menos se ve así:
1. pt_list_recipes # confirmar lo disponible
2. pt_forecast recipe='chain' params={routers:3, pcsPerLan:2}
# estimación dry-run, ningún cambio
3. pt_cook_topology recipe='chain'
params={routers:3, pcsPerLan:2, routing:'ospf'}
# construye el lab; idempotente
4. pt_inspect_canvas # findings: IPs duplicadas, etc.
5. pt_explain_canvas # narración legible
6. pt_save_snapshot name='chain-baseline' # captura T-0
7. pt_run_cli device='R1' command='show ip route'
# comprobación rápida desde el CLI
8. pt_diff_snapshots before='chain-baseline'
# qué ha cambiado desde T-0
9. pt_save_pkt path='/abs/path/lab.pkt' # guardar como .pkt nativo
Si algo se ha torcido por el camino, pt_mend_canvas aplica
reparaciones conservadoras (encender dispositivos que ya están
cableados pero apagados, ese tipo de cosas) y avisa de lo que no se
atreve a tocar.
Capacidades
packet-tracer-mcp expone 57 herramientas MCP agrupadas por dominio.
Bridge y diagnóstico
pt_bridge_status, pt_ping, pt_clear_canvas.
Catálogo y descubrimiento
pt_list_devices, pt_list_modules, pt_list_recipes,
pt_list_snapshots, pt_get_device_details.
Inspección del workspace en vivo (read-only)
pt_query_topology, pt_inspect_canvas, pt_explain_canvas,
pt_forecast (dry-run de receta), pt_generate_configs (genera el
IOS CLI offline de una receta sin tocar PT — útil para documentación,
aulas o reproducir el lab en hardware real), pt_inspect_ports
(estado per-puerto: link/up/proto, MAC, IP/máscara, wireless),
pt_read_vlans (base VLAN viva por switch), pt_read_acl (ACLs
configuradas leídas vía AclProcess), pt_show_bgp_routes (parsea
show ip bgp en filas estructuradas), pt_read_project_metadata
(descripción/versión/filename del .pkt actual).
Edición primitiva del canvas
pt_add_device, pt_add_module, pt_create_link, pt_delete_device,
pt_delete_link, pt_move_device, pt_auto_layout (recoloca todo el
canvas en una rejilla por capas, detecta routers de tránsito y los baja
a un segundo piso), pt_rename_device, pt_set_pc,
pt_set_device_power (toggle Device.setPower idempotente),
pt_add_canvas_annotation (notas/líneas/círculos),
pt_manage_clusters (lista/elimina/disuelve clusters lógicos),
pt_send_raw (vía de escape: ejecuta JS arbitrario en el Script
Engine).
Edición a nivel de receta (orquestación)
pt_cook_topology, pt_mend_canvas, pt_plan_review (revisión
pre-flight obligatoria para topologías de ≥3 routers), pt_apply_switching,
pt_apply_services, pt_configure_server_dhcp (DHCP server en Server-PT
vía API IPC nativa), pt_configure_subinterface (sub-interfaces 802.1Q
para router-on-a-stick), pt_apply_advanced_routing, pt_apply_ipv6,
pt_apply_voip, pt_apply_wireless.
Persistencia (snapshots)
pt_save_snapshot, pt_load_snapshot, pt_diff_snapshots. Los
snapshots se guardan en disco como un dump del canvas. Cargar uno no
sobreescribe nada: te enseña la diferencia contra lo que tienes ahora
mismo en PT y tú decides.
Persistencia .pkt nativa
pt_save_pkt, pt_open_pkt (cuando el servidor y PT comparten
filesystem), más pt_save_pkt_to_bytes y pt_open_pkt_from_bytes para
mover el .pkt por la red. El formato comprimido .pkz no funciona:
la API JS expone los métodos pero los bytes que devuelve no son válidos
en PT 9.0.0.0810.
CLI de routers y switches
pt_run_cli, pt_run_cli_bulk, pt_show_running (con | section
opcional).
Simulación y operaciones
pt_simulation_mode (toggle Realtime↔Simulation), pt_simulation_play
(play/back/forward/reset), pt_send_pdu (Simple PDU originado),
pt_traceroute, pt_screenshot (PNG/JPG del workspace).
Recetas incluidas
pt_list_recipes devuelve la lista al vuelo. Las que vienen de fábrica:
| Receta | Descripción |
|---|---|
chain |
N routers en serie, cada uno con su LAN de M PCs. |
star |
router hub con N spokes, cada spoke con su LAN. |
branch_office |
HQ con una o dos LANs y un router de sucursal con la suya. |
campus_vlan |
router-on-a-stick: un router + un switch con N VLANs y M PCs por VLAN. |
edge_nat |
router de borde con PAT, DHCP, ACL y router ISP upstream. |
dual_isp |
dos ISPs con BGP eBGP + HSRP en routers de borde. |
voip_lab |
router CME + switch + N IP Phones 7960; provisiona telephony-service, ephone-dn, voice VLAN y DHCP option-150. |
ipv6_lab |
dual-stack IPv4 + IPv6 con OSPFv3. |
wifi_lan |
router + AccessPoint + laptops. Limitada: la API JS pública de PT 9 no dispara la asociación radio (ver docs/COVERAGE.md). |
Las primeras tres admiten routing: 'static' | 'ospf' | 'eigrp' | 'rip' | 'none' y dhcp: true|false. campus_vlan acepta además startVlanId,
vlanStep y lanPool. wifi_lan acepta ssid, security, psk y
channel.
Configuración
Variables de entorno (todas opcionales):
| Variable | Por defecto | Significado |
|---|---|---|
PACKETTRACER_MCP_HOST |
127.0.0.1 |
Host del transporte HTTP MCP. Pon 0.0.0.0 para acceso LAN. |
PACKETTRACER_MCP_PORT |
39001 |
Puerto MCP (evita el :39000 del IPC nativo de PT). |
PACKETTRACER_BRIDGE_PORT |
54321 |
Puerto que sondea la webview de PT. |
PACKET_TRACER_SNAPSHOT_DIR |
./packet-tracer-snapshots |
Directorio para snapshots persistidos. |
Documentación
AGENTS.md— guía operativa para LLMs que usen este servidor: convenciones de cableado (LAN Gigabit vs WAN serial), LANs de usuario vs de tránsito, flujo recomendado de creación + auto layout, errores típicos a evitar.docs/ARCHITECTURE.md— capas (transporte MCP, tools, recetas, generadores IPC, bridge HTTP), por qué canvas-first, persistencia.pkt, qué queda fuera de alcance.docs/BOOTSTRAP.md— instalación de la extensión.pts, anatomía del polling, sección para desarrolladores que quieran reconstruir el.pts.docs/COVERAGE.md— qué está verificado contra PT 9 real, en qué estado (verified-pt9/contract-verified/partial/broken/dead-end), referencias a smoke runs y limitaciones conocidas del simulador que afectan al usuario.docs/TOOLS.md— referencia de las 57 tools MCP, con parámetros, comportamiento y notas.docs/RECIPES.md— catálogo de recipes (chain,star,branch_office,campus_vlan,edge_nat,wifi_lan,voip_lab,ipv6_lab,dual_isp) con parámetros, ejemplos y resultado esperado.docs/TROUBLESHOOTING.md— síntomas reales, causa probable y fix. La FAQ de aquí abajo es el resumen.CHANGELOG.md— qué entra en cada release, en formato Keep a Changelog.CONTRIBUTING.md— cómo abrir issues, setup local, convenciones de código y commits.CODE_OF_CONDUCT.md— Contributor Covenant 2.1.SECURITY.md— política de seguridad y reporte de vulnerabilidades.
Estructura del proyecto
src/
bridge/ Bridge HTTP que sondea la webview de PT
canvas/ Snapshot, inspección, diff y aritmética de subnetting
catalog/ Modelos PT (54), alias humanos, tipos de cable
ipc/ Generadores puros string-in/string-out para el IPC nativo
+ persistencia .pkt vía systemFileManager
recipes/ Blueprints, addressing, routing, switching, services,
ipv6, voip, wireless, topologías predefinidas
persistence/ Persistencia de snapshots
tools/ Un fichero por tool MCP; ALL_TOOLS los agrega
config.ts Configuración por entorno
server.ts Ciclo de vida (transporte MCP + bridge)
index.ts Entry-point CLI
extension/ Extensión .pts (módulo PT que arranca el polling)
docs/ Arquitectura, bootstrap y matriz de cobertura
scripts/ smoke.ts (suite de verificación contra PT real)
FAQ
<details> <summary><b>¿Para qué sirve esto exactamente?</b></summary>
Para que un LLM (Claude, ChatGPT, Gemini, lo que sea con cliente MCP) pueda crear, configurar y validar topologías en Packet Tracer 9 sin que tú toques el GUI. Útil para preparar laboratorios CCNA/CCNP, generar escenarios de prácticas, o automatizar tareas repetitivas.
</details>
<details> <summary><b>¿Funciona sin Packet Tracer corriendo?</b></summary>
Las llamadas read-only que no tocan el canvas (catálogo, listar
recetas, validar planes) funcionan sin PT. Cualquier cosa que toque la
topología (pt_add_device, pt_cook_topology, pt_run_cli, etc.)
necesita PT abierto y la extensión cargada.
</details>
<details> <summary><b>¿Qué versiones de Packet Tracer soporta?</b></summary>
Solo 9.0.0.0810. La API IPC nativa cambia entre minor versions de PT y este servidor está calibrado contra esa build. Versiones anteriores (8.x) no tienen el Script Engine moderno y no van a funcionar.
</details>
<details> <summary><b>¿Por qué Bun y no Node?</b></summary>
Por comodidad, sobre todo. Bun ejecuta TypeScript sin transpilación,
arranca en pocos milisegundos (importa cuando un cliente MCP relanza
el servidor varias veces al día) y bun build --compile saca un
binario standalone que puedes mover a otra máquina sin instalar nada.
Node funcionaría también; simplemente acabé prefiriendo el flujo de
Bun para esto.
</details>
<details> <summary><b>¿Tiene autenticación?</b></summary>
No. Asume entorno local de confianza (loopback). Si abres el puerto a
la LAN con PACKETTRACER_MCP_HOST=0.0.0.0, la responsabilidad de
proteger el puerto es tuya. Mira SECURITY.md.
</details>
<details> <summary><b>¿Qué hago si una receta se cuelga?</b></summary>
Llama a pt_clear_canvas, baja los parámetros (menos routers/VLANs) y
vuelve a probar. Si lo reproduces de forma fiable, abre un issue con
los parámetros exactos. Más detalle en
docs/TROUBLESHOOTING.md.
</details>
<details> <summary><b>¿Puedo añadir mis propias recetas?</b></summary>
Sí. Sigue el patrón de src/recipes/topologies/*.ts, exporta una
función que devuelva un Blueprint, y regístrala en
src/recipes/index.ts. Mira
CONTRIBUTING.md.
</details>
Errores frecuentes (respuesta corta)
| Síntoma | Fix rápido |
|---|---|
| Cliente MCP no conecta | lsof -i :39001 → si no hay nada, arranca bun run src/index.ts. |
pt_bridge_status → connected: false |
Pega el bootstrap del README en el editor de scripts de PT y pulsa Run. |
| Canvas no se mueve | El polling se paró: vuelve a pegar el bootstrap. |
pt_run_cli devuelve vacío |
Repite la llamada — terminal length 0 se aplica al primer enable. |
bun install falla |
bun --version ≥ 1.2 y rm -rf node_modules bun.lock && bun install. |
Lista completa en docs/TROUBLESHOOTING.md.
Estado
Probado contra Cisco Packet Tracer 9.0.0.0810:
- 54 / 54 modelos del catálogo etiquetados como
verified-pt9. - 57 tools MCP con sus tests unitarios.
- 8 de 9 recetas verificadas de principio a fin (
chain,star,branch_office,campus_vlan,edge_nat,dual_isp,voip_lab,ipv6_lab). La novena,wifi_lan, se queda a medias por una limitación de la API de PT (no del MCP). - Capas validadas end-to-end: switching L2, servicios L3 (NAT, ACL,
DHCP), routing dinámico (OSPF, BGP, HSRP, EIGRP), IPv6 con OSPFv3,
VoIP (CME + ephone-dn), simulación y operaciones, y persistencia
.pkt.
La evidencia detallada (smoke runs, capturas de pantalla y limitaciones
conocidas) está en docs/COVERAGE.md.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.