← 返回
未分类 Key 中文

SSH Vault

Execute SSH commands on remote hosts via SSH Vault MCP. Use when: user asks to run commands on vault-managed hosts, or when in a Discord channel mapped to a...
通过 SSH Vault MCP 在远程主机上执行 SSH 命令。使用场景:用户请求在 vault 托管主机上运行命令时,或在映射到相关Discord 频道时。
qsobad
未分类 clawhub v1.0.2 1 版本 99523.8 Key: 需要
★ 0
Stars
📥 209
下载
💾 0
安装
1
版本
#latest

概述

SSH Vault

Execute SSH commands on remote hosts through a self-hosted SSH Vault instance.

User has deployed SSH Vault via Docker. Ask for their vault URL if not known.

Required env vars:

  • SSH_VAULT_URL — vault URL
  • SSH_VAULT_AGENT_PRIVATE_KEY — agent Ed25519 private key (base64)
  • SSH_VAULT_AGENT_PUBLIC_KEY — agent Ed25519 public key (base64)

Fingerprint is auto-derived from public key.

Docker Setup (user-managed)

docker run -d -p 3001:3001 \
  -v vault-data:/app/data \
  -v vault-config:/app/config \
  qsobad/ssh-vault-mcp:latest
  • /app/config/config.yml — auto-created with localhost defaults if missing
  • /app/data — encrypted vault storage
  • Set `SSH_VAULT_ORIGIN env var for custom origin (e.g. https://ssh.example.com))

Execution

node scripts/vault.mjs exec <host> <command> [timeout]

Happy path (has session): returns { stdout, stderr, exitCode } immediately.

No session: returns needsApproval:

{ "needsApproval": true, "approvalUrl": "...", "listenUrl": "...", "execRequestId": "..." }

Approval Flow

  1. Show approvalUrl to user — opens /approve-exec page showing host + command
  2. User authenticates with Master Password + Passkey → vault unlocks, command executes
  3. Listen on listenUrl (SSE) for result:

```

data: {"status":"pending"}

data: {"status":"approved"}

data: {"status":"executing"}

data: {"status":"completed","stdout":"...","stderr":"...","exitCode":0,"sessionId":"..."}

```

  1. Save sessionId to /tmp/ssh-vault-session.json — subsequent commands skip approval

Shell metacharacters (&&, ;, |, $(), backticks) are all allowed in commands.

Other Commands

node scripts/vault.mjs status              # Vault lock status
node scripts/vault.mjs session             # Cached session info
node scripts/vault.mjs register            # Register agent
node scripts/vault.mjs check-unlock <id>   # Check unlock & get session
node scripts/vault.mjs hosts               # List hosts (needs session)

Adding Hosts

Hosts can be added by agent via API — user provides credential (password/key) during approval:

node scripts/vault.mjs request-host <name> <ip> <user> [port] [authType]

Error Handling

  • needsApproval → show approvalUrl, listen SSE
  • Host not found → check with hosts
  • Agent not registered → run register

版本历史

共 1 个版本

  • v1.0.2 当前
    2026-05-12 06:11 安全 安全

安全检测

腾讯云安全 (Keen)

安全,无风险
查看报告

腾讯云安全 (Sanbu)

安全,无风险
查看报告

🔗 相关推荐

developer-tools

Github

steipete
使用 `gh` CLI 与 GitHub 交互,通过 `gh issue`、`gh pr`、`gh run` 和 `gh api` 管理议题、PR、CI 运行及高级查询。
★ 672 📥 324,922
security-compliance

Skill Vetter

spclaudehome
AI智能体技能安全预审工具。安装ClawdHub、GitHub等来源技能前,检查风险信号、权限范围及可疑模式。
★ 1,223 📥 267,290
ai-intelligence

self-improving agent

pskoett
捕获经验教训、错误及修正内容,以实现持续改进。适用于以下场景:(1)命令或操作意外失败;(2)用户纠正Claude(如“不,那不对……”“实际上……”);(3)用户请求的功能不存在;(4)外部API或工具出现故障;(5)Claude发现自身
★ 4,071 📥 804,569