MCP SSH Proxy
A human-in-the-loop SSH bridge for AI agents that requires approval for every command before execution on configured servers.
README
MCP SSH Proxy
A human-in-the-loop SSH bridge for AI agents. It exposes an MCP server with two tools β ssh_list_hosts and ssh_exec β but every command an agent wants to run is held for your review in a desktop app before it touches a server. You see the exact command and the target host, then click Run, edit it, or Reject it.
Servers are configured only in the app's UI β nothing is hardcoded, and credentials are encrypted at rest with the OS keystore (Windows DPAPI via Electron safeStorage).
Sibling project to MCP SQL Proxy β same approval-loop architecture, applied to SSH instead of SQL.
Features
- π Human-in-the-loop approval β every agent command is shown for review (Run / edit / Reject) before it runs; the result is returned to the agent automatically.
- βοΈ Per-command confirm modes β a global confirm-each β· auto-run switch, overridable per server (
always confirm/auto). - π₯οΈ Built-in interactive terminals β full PuTTY-style xterm.js shells, multiple servers at once in tabs; type freely, see colors/vim/live output. Agent commands are echoed into the matching server's terminal as a labelled blue bar.
- ποΈ Multi-server aware β pending requests are scoped to the selected server with a
!badge on the others; idle target servers are auto-connected on demand. - π€ SFTP file transfer β
ssh_upload/ssh_downloadmove files to/from a server (inline content or a local path), each approved in the app. - π Any key format β OpenSSH, PEM/PKCS#8, and PuTTY
.ppk(v2 & v3) are detected and converted automatically; key, password, or ssh-agent auth. - π₯ PuTTY session import β pull saved sessions (host/port/user/key) straight from the Windows registry.
- π Persistent per-server history β every executed command is stored across sessions.
- π Danger mode β destructive commands (
rm,dd,shutdown,sudo,systemctl stop, redirects into/, β¦) flash the window red.
Why
Letting an agent run arbitrary shell commands on a production server is risky. This proxy keeps a person in the loop: the agent proposes, you approve. Destructive commands (rm, dd, shutdown, sudo, systemctl stop, redirects into /, β¦) light the whole window up in danger mode so a careless approval is hard.
Architecture
Claude / MCP client ββstdioβββΊ MCP server ββWebSocket(127.0.0.1:52346)βββΊ Electron app
(ssh_exec) (dist/mcp/server.js) (approval UI + ssh2)
- MCP server (
src/mcp/server.ts) β speaks MCP over stdio, forwards each request to the desktop app and waits for the result. Auto-launches the app if it isn't running. - Electron app (
src/electron/main.ts) β holds the server list, renders the approval queue, and runs approved commands viassh2. Single-instance: many MCP clients share one window. - Renderer (
src/renderer/index.html) β the UI: server list, per-server approval panel, tabbed interactive terminals (xterm.js), and all-server history.
Nothing binds to anything but 127.0.0.1.
Tools
| Tool | Approval? | Description |
|---|---|---|
ssh_list_hosts |
no | Returns the configured host names (+ address/user/auth). No secrets. Call this first. |
ssh_exec |
yes | Runs a command on a host (by name). You approve/edit/reject in the app. Returns stdout, stderr, exit code. |
ssh_upload |
yes | Uploads a file via SFTP β inline content (text/base64) or a local_path on the proxy machine β remote_path. |
ssh_download |
yes | Downloads a file via SFTP β returned inline (UTF-8 or base64, capped) or saved to a local_path. |
Install & build
npm install
npm run build
Run the desktop app standalone
npm start
Open Servers β + Add and configure a host:
- Name β the handle the agent uses (e.g.
web-01) - User / Host / Port
- Authentication β Private Key (with optional passphrase), Password, or SSH Agent
Hit Test Connection to verify. Secrets you type are encrypted before they are stored; the UI never reads them back in clear text (leave a secret field blank when editing to keep the stored value).
Register as an MCP server
Point your MCP client at the built server entry (dist/mcp/server.js). For Claude Code:
claude mcp add ssh-proxy -- node /absolute/path/to/McpSshProxy/dist/mcp/server.js
Or in a client config:
{
"mcpServers": {
"ssh-proxy": {
"command": "node",
"args": ["/absolute/path/to/McpSshProxy/dist/mcp/server.js"]
}
}
}
The first ssh_exec call auto-launches the approval window.
Security notes
- All traffic is loopback-only (
127.0.0.1:52346). - Passwords and key passphrases are encrypted with the OS keystore (
safeStorage). On platforms without an available keystore they fall back to obfuscated-but-not-encrypted local storage β prefer key/agent auth there. - The agent can only target servers you have configured by name. An
ssh_execfor an unknown host is refused. - This is an approval tool, not a sandbox: once you click Run, the command executes with the configured user's privileges. Review before approving.
License
MIT β see LICENSE.
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
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.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.