Skip to main content
Glama

Electron Terminal MCP Server

Electron Terminal MCP-Server

Idealerweise würden Anbieter eine eigene MCP-Integration für das Terminal bereitstellen. Dieses Projekt bietet jedoch einen Model Context Protocol (MCP)-Server, der Clients die Interaktion mit einem Systemterminal ermöglicht, das innerhalb einer Electron-Anwendung läuft. Es ermöglicht die Ausführung von Befehlen, die Verwaltung von Terminalsitzungen und das programmgesteuerte Abrufen von Ausgaben.

Das System besteht aus zwei Hauptteilen:

  • MCP-Server ( index.js ): Ein Node.js-Skript, das über die Standard-Ein-/Ausgabe (stdio) auf MCP-Anfragen wartet. Es verwendet @modelcontextprotocol/sdk und fungiert als Brücke zum Electron-Backend. Es startet das Electron-Backend automatisch, falls es nicht bereits läuft. In mcp-package.json muss "type": "module" angegeben werden.
  • Electron-Backend ( main.js ): Der Hauptprozess der Electron-Anwendung. Er betreibt einen Express-HTTP-Server (standardmäßig Port 3000), mit dem der MCP-Server ( index.js ) für Integritätsprüfungen und API-Aufrufe kommuniziert. Dieses Backend verwaltet die eigentlichen Terminalprozesse mithilfe von node-pty in versteckten BrowserWindow Instanzen, terminal.html laden.

2. Screenshots

So sieht die Terminalinteraktion innerhalb eines Clients wie Claude Desktop aus:

Claude-Desktopfenster mit Terminalausgabe:Claude-Desktopfenster mit Terminalausgabe

Fenster für einzelne Elektronenanschlüsse:Elektronenterminalfenster

3. Installation

  1. Voraussetzungen: Stellen Sie sicher, dass Sie Node.js und npm installiert haben.
  2. Klonen: Klonen Sie das Repository, falls Sie dies noch nicht getan haben.
    git clone <your-repository-url> cd command-terminal-electron # Or your repository directory name
  3. Abhängigkeiten installieren: Installieren Sie Node-Module sowohl für den MCP-Server als auch für die Electron-App.
    npm install
  4. Native Module neu erstellen: Native Module (wie node-pty ) für Electron neu erstellen.
    node rebuild.js
    (Weitere Einzelheiten finden Sie in rebuild.js .)

3. Nutzung

  1. Starten Sie den MCP-Server: Führen Sie das Skript index.js mit Node.js aus. Dadurch wird auf stdio auf MCP-Befehle gewartet und automatisch versucht, den Electron-Backend-Prozess ( main.js ) zu starten, falls dieser nicht bereits läuft und auf dem erwarteten HTTP-Port lauscht.
    node index.js
    Hinweis: Der Electron-Prozess läuft verborgen im Hintergrund und wird bei Bedarf automatisch (neu) gestartet und nach Möglichkeit immer wiederverwendet.
  2. Interaktion über MCP: Clients verbinden sich über stdio mit dem node index.js -Prozess und verwenden den Befehl use_mcp_tool . Der Servername ist in index.js als „Electron Terminal“ definiert.Verfügbare Tools:
    • terminal_start : Erstellt eine neue Terminalsitzung und führt einen ersten Befehl aus.
      • Eingabe: { "command": "string" }
      • Ausgabe: { "content": [...], "sessionId": "string" } GXP5
    • terminal_execute : Führt einen Befehl in einer bestehenden Sitzung aus.
      • Eingabe: { "command": "string", "sessionId": "string" }
      • Ausgabe: { "content": [...] } (Sitzungs-ID ist im Textinhalt enthalten) GXP6
    • terminal_get_output : Ruft die kumulierte Ausgabe für eine Sitzung ab.
      • Eingabe: { "sessionId": "string" }
      • Ausgabe: { "content": [...] } GXP7
    • terminal_stop : Beendet einen bestimmten Terminalsitzungsprozess.
      • Eingabe: { "sessionId": "string" }
      • Ausgabe: { "content": [...] } GXP8
    • terminal_get_sessions : Listet alle derzeit aktiven Sitzungen auf, die vom Electron-Backend verwaltet werden.
      • Eingabe: {}
      • Ausgabe: { "content": [...] } (Inhalt enthält eine JSON-Zeichenfolge aktiver Sitzungen) GXP9

5. Synergie mit dem Filesystem MCP Server

Dieser Electron Terminal MCP-Server arbeitet sehr effektiv mit dem Filesystem MCP-Server zusammen. Sie können den Filesystem-Server verwenden, um Verzeichnisse zu durchsuchen, Dateien zu lesen/schreiben und anschließend mit diesem Terminalserver Befehle innerhalb dieser Verzeichnisse oder in Bezug auf diese Dateien auszuführen. Dies bietet eine umfassende Remote-Entwicklungs- und Interaktionserfahrung, die nahtlos mit beispielsweise der in Claude Desktop integrierten Internet-Suchfunktion zusammenarbeitet.

6. Voraussetzungen

  • Node.js (v20 oder höher empfohlen, ich verwende Node 22)
  • npm
  • Mit Electron kompatibles Betriebssystem (Windows, macOS, Linux)

7. Konfiguration

Claude Desktop MCP-Serverkonfiguration

Standort

Die Datei claude_desktop_config.json sollte im AppData-Verzeichnis Ihres Benutzers abgelegt werden:

  • Windows: C:\Users\<username>\AppData\Roaming\Claude\claude_desktop_config.json

Diese Datei wird von Claude Desktop verwendet, um externe MCP-Server zu erkennen und zu konfigurieren.

Zweck und Struktur

Die Konfigurationsdatei definiert MCP-Server, die Claude Desktop starten und mit denen es sich verbinden kann. Jeder Servereintrag gibt an, wie der Serverprozess gestartet werden soll.

  • mcpServers : Ein Objekt, bei dem jeder Schlüssel ein Servername und der Wert seine Startkonfiguration ist.
  • Beispiel für eine Serverkonfiguration ( command-terminal ) :
    • command : Die auszuführende ausführbare Datei (z. B. node für Node.js-Server).
    • args : Ein Array von Argumenten, die an den Befehl übergeben werden (z. B. der Pfad zu Ihrem MCP-Serverskript).
Beispiel
{ "mcpServers": { "command-terminal": { "command": "node", "args": [ "C:\\Path\\to\\index.js" ] } } }
Felderklärungen
  • mcpServers : Objekt der obersten Ebene, das Servernamen ihren Konfigurationen zuordnet.
  • command-terminal : Beispiel-Servername. Sie können in diesem Objekt mehrere Server definieren.
  • command : Die ausführbare Datei zum Starten des MCP-Servers.
  • args : An den Befehl übergebene Argumente, z. B. der Pfad zu Ihrem Serverskript.

8. Lizenz

Dieses Projekt ist unter der MIT-Lizenz lizenziert. Weitere Informationen finden Sie in der Datei LICENSE.

Install Server
A
security – no known vulnerabilities
A
license - permissive license
A
quality - confirmed to work

local-only server

The server can only run on the client's local machine because it depends on local resources.

Ein Model Context Protocol-Server, der Clients die Interaktion mit einem Systemterminal ermöglicht, das in einer Electron-Anwendung ausgeführt wird. Dadurch ist die Ausführung von Befehlen, die Verwaltung von Terminalsitzungen und das programmgesteuerte Abrufen von Ausgaben möglich.

  1. Screenshots
    1. Installation
      1. Nutzung
        1. Synergie mit dem Filesystem MCP Server
          1. Voraussetzungen
            1. Konfiguration
              1. Claude Desktop MCP-Serverkonfiguration
            2. Lizenz

              Related MCP Servers

              • -
                security
                F
                license
                -
                quality
                This server enables running a Model Context Protocol in a web browser with functionalities including arithmetic operations and session-based key-value storage.
                Last updated -
                2
                TypeScript
              • -
                security
                F
                license
                -
                quality
                A Model Context Protocol server that allows LLMs to execute shell commands and receive their output in a controlled manner.
                Last updated -
                Python
              • A
                security
                A
                license
                A
                quality
                A secure terminal execution server that enables controlled command execution with security features and resource limits via the Model Context Protocol (MCP).
                Last updated -
                1
                12
                1
                JavaScript
                MIT License
                • Apple
              • -
                security
                A
                license
                -
                quality
                A Model Context Protocol server that enables seamless execution of commands, Python code, web content fetching, and reusable task management with secure credentials handling.
                Last updated -
                2
                Python
                MIT License
                • Apple

              View all related MCP servers

              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/nexon33/console-terminal-mcp-server'

              If you have feedback or need assistance with the MCP directory API, please join our Discord server