DrayTek Vigor MCP Server
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@DrayTek Vigor MCP ServerCheck the DSL status"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
DrayTek Vigor 167 MCP Server
MCP-Server für DSL-Diagnose und CLI-Zugriff am DrayTek Vigor 167 (Firmware 5.2.8) über interaktive SSH-Shell.
Befehle werden nicht geraten: Discovery läuft live gegen das Gerät (? / help) und wird unter cache/command_tree.json gecacht. Convenience-Tools und Parser basieren auf verifiziertem CLI-Output.
Status
Komponente | Status |
Python venv ( |
|
Cursor MCP ( | Noch nicht eingetragen — siehe Abschnitt Cursor einbinden |
| Lokal vorhanden, nicht im Git |
Related MCP server: MikroTik MCP Server
Voraussetzungen
Python 3.11+
Netzwerkzugang zum Modem (Standard:
192.168.167.1:22)Cursor oder anderer MCP-Client
DrayTek Vigor 167 mit eingeschränkter Bridge-CLI (kein voller DrayOS-Befehlssatz)
Schnellstart
cd ~/Workspaces/draytek-vigor-mcp
python -m venv .venv
source .venv/bin/activate
pip install "mcp[cli]" paramiko.env anlegen (Format siehe unten), dann Discovery testen:
.venv/bin/python discover.py 2 --refresh
.venv/bin/python -c "from vigor_ssh import run_command; print(run_command('exec dslinfo'))"Server manuell starten (stdio-MCP):
.venv/bin/python server.pyCredentials (.env)
Nicht committen (steht in .gitignore). Kein Standard-dotenv — Parsing: erstes : trennt Schlüssel und Wert, umschließende " am Wert werden entfernt.
mcp:"geheim"
VIGOR_HOST:"192.168.167.1"
VIGOR_PORT:"22"Optional:
VIGOR_PROMPT:"vigor>\\s*$"
VIGOR_IDLE_SEC:"0.8"Die erste Zeile ohne reservierten Schlüssel (VIGOR_*) ist der CLI-Benutzername; der Wert ist das CLI-Passwort.
SSH- und CLI-Ablauf (Vigor 167)
Am 167 unterscheidet sich der Ablauf von klassischen DrayTek-Routern:
SSH-Transport:
auth_none(kein SSH-Passwort/Key nötig)Interaktive Shell:
invoke_shell+ PTY —exec_commandliefert oft leere AusgabeCLI-Login: Gerät fragt
Username:/Password:(Credentials aus.env)Prompt:
vigor>Neue Session pro Aufruf: Das Modem beendet idle SSH-Sessions
enable ist in der CLI vorhanden, aber am Vigor 167 ohne konfigurierbares Passwort nutzlos (Access denied). DSL-Diagnose funktioniert ohne privilegierten Modus.
Cursor einbinden
Eintrag in ~/.cursor/mcp.json unter mcpServers ergänzen:
{
"mcpServers": {
"draytek-vigor": {
"command": "/home/ladwein/Workspaces/draytek-vigor-mcp/.venv/bin/python",
"args": ["/home/ladwein/Workspaces/draytek-vigor-mcp/server.py"],
"cwd": "/home/ladwein/Workspaces/draytek-vigor-mcp"
}
}
}Danach Cursor neu laden oder MCP-Server in den Einstellungen aktivieren.
MCP-Tools
Tool | CLI-Befehl | Beschreibung |
|
| Befehlsbaum vom Gerät (gecacht) |
| beliebig | Einzelbefehl ausführen |
| beliebig | Mehrere Befehle in einer SSH-Session |
|
| Sync-Status, Profil, Raten, SNR |
|
| Modell, Firmware, Build-Infos |
|
| Gerätezeit |
|
| Offene Dienste/Ports |
|
| Config-Profil-Status |
| — | Gecachter Discovery-Baum |
run_command / run_commands decken per Definition alle vom Gerät akzeptierten Befehle ab. Ungültige Befehle liefern die Geräte-Fehlermeldung im Ergebnis, keine Exception nach außen.
Beispiel get_dsl_info (FW 5.2.8, verifiziert)
Status : Showtime
Mode : VDSL2
Profile : 17a
Annex : ANNEX B
DSL Version : 5.12.31.0_B_A60901
Line Uptime : …
Downstream Line Rate : … kbps
Upstream Line Rate : … kbps
SNR Downstream : … dB
SNR Upstream : … dBNicht verfügbar in exec dslinfo auf 5.2.8: Attenuation, CRC/FEC/ES/SES — dafür gibt es bewusst kein Convenience-Tool.
Verifizierter Befehlsbaum (Kurzüberblick)
Top-Level (?)
help, quit, logout, history, enable, exit, config, exec
Exec (exec ?)
date, ping, reboot_system, operation_mode, lan_mtu, wan_mtu, dot3ah_oam, y1731, dsl_dbg, dsl_35b_enhance, dsl_35b_target, process_dbg, tr069, coredump, sysinfo, telnet, cfg, services, dslinfo, nat_prio
Config (help, Auszug)
config Configuration Physical_Interface
config Configuration WAN WAN_Connections
config Monitoring DSL_Status Monitoring_DSL_General
config Monitoring DSL_Status Monitoring_DSL_Tone
config System_Maintenance Device_Settings Time
config System_Maintenance Management Access_Control
…Config-Zweige nutzen Web-Form-CLI (show / edit); ohne enable kaum schreibbar.
Vollständiger Baum: cache/command_tree.json oder discover.py 2 --refresh.
Discovery manuell
.venv/bin/python discover.py 2 --refreshParameter: Tiefe (Standard 2), --refresh erzwingt Neuerkennung.
Projektstruktur
server.py MCP-Server (FastMCP)
vigor_ssh.py SSH auth_none, CLI-Login, Prompt-Handling
discover.py Befehls-Discovery via ?
parsers.py Regex-Parser für verifizierte Ausgaben
pyproject.toml Abhängigkeiten
cache/ command_tree.json (generiert, nicht committen)
.env Credentials (lokal, nicht committen)Hinweise und Grenzen
Bridge-Modem: Absichtlich eingeschränkte CLI — kein voip/qos/etc. wie bei großen DrayOS-Routern.
Kein
enable: Privilegierte Config-Befehle über CLI nicht erreichbar.Timing:
VIGOR_IDLE_SECerhöhen (z. B.1.0), falls Ausgaben abgeschnitten werden.Credentials: Niemals in Code, Logs oder Commits — nur in
.env.Parser: Nur für tatsächlich gelieferte Felder; bei Firmware-Änderungen Discovery und Parser neu verifizieren.
Fehlerbehebung
Symptom | Ursache / Lösung |
Leere SSH-Ausgabe | Kein PTY / |
| Erwartet; am 167 kein Enable-Passwort |
| Am 167 |
Abgeschnittene CLI-Ausgabe |
|
MCP-Tools fehlen in Cursor | Eintrag in |
Lizenz / Gerät
Getestet gegen DrayTek Vigor 167, Firmware 5.2.8, Host 192.168.167.1.
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
- Why MCP Servers Need Execution Sandboxing (And Why Your Current Stack Isn't Enough)By Om-Shree-0709 on .Agentic AiPrompt InjectionWebAssembly
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/dtrywets/draytek-vigor-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server