@tech4242

Aquaman — API Key Protection

Protect API keys and secrets for OpenClaw — credentials stay in your vault, never in the agent's memory

当前版本
v0.12.1
code-plugin社区source-linked

aquaman-plugin — API Key Protection for OpenClaw

The aquaman adapter for the OpenClaw Gateway. Your API keys and tokens stay in your vault. The agent never sees them. Even a compromised agent can't steal credentials — they live in a separate process.

This plugin spawns aquaman-proxy (exact-pinned, same author) on Gateway startup, routes channel traffic through a UDS to that proxy, and lets you reach the same vault and policy engine from inside OpenClaw.

Agent / OpenClaw Gateway              Aquaman Proxy
┌──────────────────────┐              ┌──────────────────────┐
│                      │              │                      │
│  ANTHROPIC_BASE_URL  │══ Unix ═════>│  Keychain / 1Pass /  │
│  = aquaman.local     │   Domain     │  Vault / Encrypted   │
│                      │<═ Socket ════│                      │
│  fetch() interceptor │══ (UDS) ════>│  + Policy enforced   │
│  redirects channel   │              │  + Auth injected:    │
│  API traffic         │              │    header / url-path │
│                      │              │    basic / oauth     │
│                      │              │                      │
│  No credentials.     │  ~/.aquaman/ │                      │
│  No open ports.      │  proxy.sock  │                      │
│  Nothing to steal.   │  (chmod 600) │                      │
└──────────────────────┘              └───┬──────────┬───────┘
                                         │          │
                                         │          ▼
                                         │  ~/.aquaman/audit/
                                         │  (hash-chained log)
                                         ▼
                               api.anthropic.com / api.mistral.ai /
                               api.telegram.org / slack.com/api  …

What it does

  1. Secrets stay in your vault — Keychain, 1Password, HashiCorp Vault, KeePassXC, systemd-creds, Bitwarden, or encrypted file.
  2. Agent gets a proxy URL — requests route through ~/.aquaman/proxy.sock (UDS, chmod 0o600); the proxy injects auth headers on the fly.
  3. Dangerous endpoints blocked — request policies deny admin APIs, prevent deletions, block sends — before credentials are even injected.
  4. Tamper-evident audit log — every credential use logged with SHA-256 hash chains.

Quick Start

openclaw plugins install aquaman-plugin           # 1. install plugin + proxy
openclaw aquaman setup                            # 2. store your API keys, wire up plugin
openclaw                                          # 3. done — proxy starts automatically

The aquaman-proxy binary is bundled as an exact-pinned npm dependency — no separate download or install needed.

Using npm directly? npm install -g aquaman-proxy && aquaman openclaw setup does the same thing — installs the proxy CLI, stores your keys, installs the plugin into ~/.openclaw/extensions/aquaman-plugin/, and writes the auth-profiles.json placeholder.

Troubleshooting: openclaw aquaman doctor (or aquaman openclaw doctor from a regular shell).

Security model

Aquaman keeps API credentials out of the agent process by running them in a separate proxy process. The agent never sees the secret — only a sentinel base URL that the proxy intercepts, authenticates, and forwards. See the architecture diagram in the main README.

Proxy process

  • The plugin spawns the aquaman binary from the aquaman-proxy npm package, declared as an exact-pinned dependency (no semver range) and published by the same author (tech4242). After spawn, the plugin checks the running proxy's reported version against its own and logs a warning if they disagree.
  • The spawn (aquaman openclaw plugin-mode) is what triggers the dangerous-exec finding in OpenClaw's static scanner — it's intentional and is the whole point of the plugin.

HTTP interceptor scope

  • Only services listed in the plugin's services config get their traffic redirected to the local proxy. As of v0.11.4, the interceptor filters its known-host map by your services list — channels you didn't opt into keep talking to the upstream directly.
  • The interceptor uses a Unix Domain Socket (no TCP, no network exposure). UDS file permissions are chmod 0o600, enforced explicitly at proxy startup (v0.12.0+).

Auth profiles

  • On load the plugin writes ~/.openclaw/agents/<id>/agent/auth-profiles.json with placeholder API-key entries for anthropic and openai so OpenClaw doesn't reject requests before they reach the proxy. The proxy strips the placeholder and injects the real credential.
  • The plugin never overwrites an existing auth-profiles.json. To suppress generation entirely, set autoGenerateAuthProfiles: false in the plugin config (v0.11.4+).
  • OpenClaw ≥ 2026.6.5: provider auth profiles moved into each agent's openclaw-agent.sqlite and the runtime read path for auth-profiles.json was removed (openclaw/openclaw#89102). The placeholder must be imported into SQLite once with openclaw doctor --fix (OpenClaw then archives the JSON file). Run aquaman openclaw doctor — it detects this and prints the exact remediation.

Audit log

  • Every credential use is recorded in ~/.aquaman/audit/current.jsonl with a SHA-256 hash chain so tampering is detectable. The log stays local — no telemetry.
  • aquaman openclaw doctor surfaces audit log issues; aquaman audit tail shows recent entries.
  • Operators can constrain which upstream endpoints get proxied (and therefore credentialed) via the policy config in ~/.aquaman/config.yaml. Denied requests return 403 before any credential is injected.

Scanner findings

openclaw security audit --deep reports two expected findings:

  • dangerous-exec on the proxy-manager module — the plugin spawns the proxy as a separate process. This is how credential isolation works.
  • tools_reachable_permissive_policy — advisory about your tool policy, not an aquaman vulnerability. Set "tools": { "profile": "coding" } in openclaw.json if your agents handle untrusted input.

ClawHub's ClawScan additionally produces a higher-level review of plugin behavior. The current scan acknowledges credential isolation, proxy spawn, the host map, the auth-profiles generation, and the audit log — see the publisher note on the package page for context on each item.

aquaman openclaw setup adds the plugin to plugins.allow automatically so OpenClaw knows you trust it.

Available commands

All commands work via OpenClaw CLI or your terminal:

OpenClaw CLITerminalDescription
openclaw aquaman setupaquaman openclaw setupOpenClaw bundle — vault wizard + plugin install + auth-profiles
openclaw aquaman doctoraquaman openclaw doctorDeep diagnostic for the OpenClaw integration
openclaw aquaman credentials listaquaman credentials listList stored credentials
openclaw aquaman credentials addaquaman credentials addAdd a credential (interactive)
openclaw aquaman policy-listaquaman policy listShow request policy rules
openclaw aquaman audit-tailaquaman audit tailRecent audit entries
openclaw aquaman services-listaquaman services listList configured services
openclaw aquaman statusaquaman openclaw statusPlugin lifecycle + sentinel env vars

Slash commands in chat: /aquaman-status, /aquaman list, /aquaman doctor.

Config options

aquaman openclaw setup writes these to ~/.openclaw/openclaw.json automatically:

KeyTypeDefaultDescription
backend"keychain" | "1password" | "vault" | "encrypted-file" | "keepassxc" | "systemd-creds" | "bitwarden""keychain"Credential store
servicesstring[]["anthropic", "openai"]Services to proxy (also gates which hostnames the interceptor redirects, v0.11.4+)
autoGenerateAuthProfilesbooleantrueAuto-generate auth-profiles.json with placeholder anthropic/openai entries when the file is absent. Set false to manage your own (v0.11.4+)

Advanced settings (audit, vault, request policies) go in ~/.aquaman/config.yaml. See the request policy docs.

Documentation

  • Root README — value prop, three-path Quick Start, security model
  • aquaman-proxy — core CLI and daemon
  • aquaman-coder — coding-agent adapter (Claude Code, Codex/OpenCode/Cursor planned)

License

MIT

源码与版本

源码仓库

tech4242/aquaman

打开仓库

源码提交

1626eec93788f394a1a92c8d88f7b9f6d9bdfc67

查看提交

安装命令

openclaw plugins install clawhub:aquaman-plugin

元数据

  • 包名: aquaman-plugin
  • 创建时间: 2026/04/13
  • 更新时间: 2026/06/16
  • 执行代码:
  • 源码标签: main

兼容性

  • 构建于 OpenClaw: 2026.6.6
  • 插件 API 范围: >=2026.5.7
  • 标签: latest
  • 文件数: 24