by GreyhavenHQ
Container-free, deny-by-default sandbox for AI coding agents. Kernel-enforced filesystem, network, and syscall isolation for Linux and macOS
# Add to your Claude Code skills
git clone https://github.com/GreyhavenHQ/greywallLast scanned: 5/30/2026
{
"issues": [],
"status": "PASSED",
"scannedAt": "2026-05-30T15:43:48.980Z",
"npmAuditRan": true,
"pipAuditRan": true
}greywall is an open-source ai agents skill for AI coding assistants such as Claude Code, Codex CLI, and ChatGPT, built by GreyhavenHQ. Container-free, deny-by-default sandbox for AI coding agents. Kernel-enforced filesystem, network, and syscall isolation for Linux and macOS. It has 244 GitHub stars.
Yes. greywall passed SkillsLLM's automated security scan — a dependency vulnerability audit plus prompt-injection heuristics — with no high-severity issues. You can read the full report in the Security Report section on this page.
Clone the repository with "git clone https://github.com/GreyhavenHQ/greywall" and add it to your Claude Code skills directory (see the Installation section above).
greywall is primarily written in Go. It is open-source under GreyhavenHQ on GitHub, so you can review or fork the full source.
Yes. SkillsLLM lists many other AI Agents skills you can browse and compare side by side. Open the AI Agents category from the badge at the top of this page, or use the Related Skills and comparison links further down to weigh greywall against similar tools.
No comments yet. Be the first to share your thoughts!
Greywall is a container-free sandbox for AI coding agents on Linux and macOS, with two complementary modes:
greywall — deny-by-default sandbox. Restricts filesystem access, network connections, and system calls to only what you explicitly allow, so tools like Claude Code, Cursor, Codex, and other AI agents can't reach your SSH keys, secrets, or anything outside the working directory.greywatch — allow-by-default observability layer (equivalent to greywall --watch). Skips profile loading, registers a */* allow rule with greyproxy so every network request is accepted but logged on the dashboard, and runs with a permissive filesystem. Use it to see what a tool actually does before deciding what to lock down.Both modes route every network connection through greyproxy — a transparent proxy with a live allow/deny dashboard — so traffic stays visible whether you're enforcing or observing. Use --learning to trace what a command needs and auto-generate a least-privilege config profile.
Supports Linux and macOS. See platform support for details.
https://github.com/user-attachments/assets/7d62d45d-a201-4f24-9138-b460e4c157a8
rm -rf / and git push --force are deniedgreywatch (or greywall --watch) runs commands with no profile and all network allowed, so the greyproxy dashboard shows exactly what an agent does without anything being denied# Sandbox a command (network + filesystem denied by default)
greywall -- curl https://example.com
# Sandbox an AI coding agent with a built-in profile
greywall -- claude
# Observe what an agent does without blocking anything (allow-by-default)
greywatch -- claude
# Learn what filesystem access a command needs, then auto-generate a profile
greywall --learning -- opencode
# Block dangerous commands
greywall -c "rm -rf /" # → blocked by command deny rules
Homebrew (macOS):
brew tap greyhavenhq/tap
brew install greywall
This also installs greyproxy as a dependency.
Linux / Mac:
curl -fsSL https://raw.githubusercontent.com/GreyhavenHQ/greywall/main/install.sh | sh
Both greywall and the greywatch alias (observability mode) are installed by Homebrew, install.sh, and make build. greywatch is a symlink to the same binary — argv[0] dispatch enables --watch automatically.
Go install:
go install github.com/GreyhavenHQ/greywall/cmd/greywall@latest
# Create the greywatch alias yourself (Go install ships a single binary):
ln -s "$(go env GOPATH)/bin/greywall" "$(go env GOPATH)/bin/greywatch"
mise:
mise use -g github:GreyhavenHQ/greywall
mise use -g github:GreyhavenHQ/greyproxy
Manual tarball: GitHub release tarballs contain only the greywall binary. After extracting, create the alias yourself:
ln -s greywall greywatch
Build from source:
git clone https://github.com/GreyhavenHQ/greywall
cd greywall
make setup && make build # creates ./greywall and ./greywatch symlink
Linux dependencies:
bubblewrap - container-free sandboxing (required)socat - network bridging (required)xdg-dbus-proxy - filtered D-Bus proxy for notify-send support (optional)libsecret-tools - keyring credential injection for gh/glab (optional)Check dependency status with greywall check.
# Run with all network blocked (default)
greywall -- curl https://example.com
# Run with shell expansion
greywall -c "echo hello && ls"
# Route through a SOCKS5 proxy
greywall --proxy socks5://localhost:1080 -- npm install
# Expose a port for inbound connections (e.g., dev servers)
greywall -p 3000 -c "npm run dev"
# Grant an extra directory/file for this run (read+write, or read-only)
greywall --allow-path /tmp/work -- mytool
greywall --allow-read-path /data/refs -- mytool
# Enable debug logging
greywall -d -- curl https://example.com
# Monitor sandbox violations
greywall -m -- npm install
# Show available Linux security features
greywall --linux-features
# Show version
greywall --version
# Check dependencies, security features, and greyproxy status
greywall check
# Install and start greyproxy
greywall setup
Greywall ships with built-in sandbox profiles for popular AI coding agents (Claude Code, Codex, Cursor, Aider, Goose, Gemini CLI, OpenCode, Amp, Cline, Copilot, Kilo, Auggie, Droid) and toolchains (Node, Python, Go, Rust, Java, Ruby, Docker).
On first run, greywall shows what the profile allows and lets you apply, edit, or skip:
$ greywall -- claude
[greywall] Running claude in a sandbox.
A built-in profile is available. Without it, only the current directory is accessible.
Allow read: ~/.claude ~/.claude.json ~/.config/claude ~/.local/share/claude ~/.gitconfig ... + working dir
Allow write: ~/.claude ~/.claude.json ~/.cache/claude ~/.config/claude ... + working dir
Deny read: ~/.ssh/id_* ~/.gnupg/** .env .env.*
Deny write: ~/.bashrc ~/.zshrc ~/.ssh ~/.gnupg
[Y] Use profile (recommended) [e] Edit first [s] Skip (restrictive) [n] Don't ask again
>
Combine agent and toolchain profiles with --profile:
# Agent + Python toolchain (allows access to ~/.cache/uv, ~/.local/pipx, etc.)
greywall --profile claude,python -- claude
# Agent + multiple toolchains
greywall --profile opencode,node,go -- opencode
# List all available and saved profiles
greywall profiles list
Greywall can trace a command's filesystem access and generate a config profile automatically:
# Run in learning mode - traces file access via strace
greywall --learning -- opencode
# List generated profiles
greywall profiles list
# Show a profile's content
greywall profiles show opencode
# Next run auto-loads the learned profile
greywall -- opencode
Watch mode flips the policy: no profile is loaded, every network request is accepted but logged on the greyproxy dashboard, and the local filesystem is permissive. Use it to see what a tool does before deciding what to restrict — the inverse of deny-by-default.
# Same thing, two entry points
greywatch -- claude
greywall --watch -- claude
# Inspect what claude touches in the greyproxy dashboard:
# http://localhost:43080
What stays the same:
--unshare-net + tun2socks force it; on macOS, the Seatbelt profile blocks direct egress to anything except the proxy. The dashboard sees every request.~/.ssh/authorized_keys, git hooks, etc.) still apply even with the permissive filesystem.--no-credential-protection).What changes vs. normal mode:
*/* allow rule is registered with greyproxy for the session, so nothing is denied.-m (violation monitor) stays orthogonal — combine --watch -m if you want both.
Greywall reads from ~/.config/greywall/greywall.json by default (or ~/Library/Application Support/greywall/greywall.json on macOS).
{
// Route traffic through an external SOCKS5 proxy
"network": {
"proxyUrl": "socks5://localhost:1080",
"dnsAddr": "localhost:5353"
},
// Control filesystem access
"filesystem": {
"defaultDenyRead": true,
"allowRead": ["~/.config/myapp"],
"allowWrite": ["."],
"denyWrite": ["~/.ssh/**"],
"denyRead": ["~/.ssh/id_*", ".env"]
},
// Block dangerous commands
"command": {
"deny": ["git push", "npm publish"]
}
}
Use greywall --settings ./custom.json to specify a different config file.
By default, traffic routes through the GreyProxy SOCKS5 proxy at localhost:43052 with DNS via localhost:43053.
| Feature | Linux | macOS |
|---|---|---|
| Sandbox engine | bubblewrap | sandbox-exec (Seatbelt) |
| Filesystem deny-by-default (read/write) | ✅ | ✅ |
| Syscall filtering | ✅ (seccomp) | ✅ (Seatbelt) |
| Filesystem access control | ✅ (Landlock + bubblewrap) | ✅ (Seatbelt) |
| Violation monitoring | ✅ (eBPF) | ✅ (Seatbe |