Claude-skill-registry gemini-sandbox-configuration

Central authority for Gemini CLI sandboxing and isolation. Covers Docker, Podman, macOS Seatbelt profiles, and security boundaries. Use when enabling sandboxing, choosing sandbox methods, configuring Seatbelt profiles, or troubleshooting sandbox issues. Delegates 100% to gemini-cli-docs for official documentation.

install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/gemini-sandbox-configuration" ~/.claude/skills/majiayu000-claude-skill-registry-gemini-sandbox-configuration && rm -rf "$T"
manifest: skills/data/gemini-sandbox-configuration/SKILL.md
source content

Gemini Sandbox Configuration

MANDATORY: Invoke gemini-cli-docs First

STOP - Before providing ANY response about Gemini sandboxing:

  1. INVOKE
    gemini-cli-docs
    skill
  2. QUERY for the specific sandbox topic
  3. BASE responses EXCLUSIVELY on official documentation loaded

Overview

Meta-skill for configuring Gemini CLI's sandbox isolation. Sandboxing isolates potentially dangerous operations from your host system.

When to Use This Skill

Keywords: sandbox, docker, podman, seatbelt, isolation, container, safe execution, -s flag, GEMINI_SANDBOX

Use this skill when:

  • Enabling sandboxing for the first time
  • Choosing between sandbox methods
  • Configuring Seatbelt profiles (macOS)
  • Troubleshooting sandbox issues
  • Understanding security boundaries

Sandbox Methods

MethodPlatformIsolation
DockerAllFull container
PodmanAllRootless container
SeatbeltmacOSProcess sandbox

Configuration

Enable via Command Flag

gemini -s -p "command"

Enable via Environment

export GEMINI_SANDBOX=true
gemini "command"

# Or specify method
export GEMINI_SANDBOX=docker
export GEMINI_SANDBOX=podman
export GEMINI_SANDBOX=sandbox-exec

Enable via Settings

Add to

settings.json
:

{
  "tools": {
    "sandbox": true
  }
}

Or specify method:

{
  "tools": {
    "sandbox": "docker"
  }
}

Seatbelt Profiles (macOS)

Set via

SEATBELT_PROFILE
environment variable:

ProfileWritesNetwork
permissive-open
(default)
RestrictedAllowed
permissive-closed
RestrictedBlocked
permissive-proxied
RestrictedVia proxy
restrictive-open
StrictAllowed
restrictive-closed
StrictBlocked

Custom Sandbox Flags

For container-based sandboxing, inject custom flags:

export SANDBOX_FLAGS="--security-opt label=disable"

Keyword Registry (Delegates to gemini-cli-docs)

TopicQuery Keywords
Enable
enable sandbox
,
-s flag
,
GEMINI_SANDBOX
Docker
docker sandbox
,
container isolation
Podman
podman sandbox
,
rootless container
Seatbelt
seatbelt profiles
,
sandbox-exec macos
Custom flags
SANDBOX_FLAGS
,
custom docker flags
Troubleshooting
sandbox troubleshooting
,
operation not permitted

Quick Decision Tree

What do you want to do?

  1. Enable sandbox quickly -> Use
    -s
    flag
  2. Make it persistent -> Add to settings.json
  3. Use Docker -> Set
    GEMINI_SANDBOX=docker
  4. Use stricter macOS -> Set
    SEATBELT_PROFILE=restrictive-closed
  5. Debug issues -> Use
    DEBUG=1 gemini -s

Troubleshooting

ErrorCauseSolution
"Operation not permitted"Sandbox restrictionExpected behavior
"Docker not found"Docker not runningStart Docker daemon
Network blockedRestrictive profileUse
permissive-open
Missing commandsNot in sandbox imageAdd to custom Dockerfile

Security Notes

  • Sandboxing reduces but doesn't eliminate all risks
  • Use most restrictive profile that allows your work
  • GUI applications may not work in sandbox
  • Container overhead is minimal after first build

Verification Checkpoint

  • Did I invoke gemini-cli-docs skill?
  • Did official documentation load?
  • Is my response based EXCLUSIVELY on official docs?

Test Scenarios

Scenario 1: Enable Sandbox

Query: "How do I enable sandboxing in Gemini CLI?" Expected Behavior:

  • Skill activates on "sandbox" keyword
  • Delegates to gemini-cli-docs for configuration options Success Criteria: User receives -s flag and settings.json configuration

Scenario 2: macOS Seatbelt

Query: "How do I configure Seatbelt profiles for Gemini CLI?" Expected Behavior:

  • Skill activates on "seatbelt" or "macos sandbox"
  • Provides SEATBELT_PROFILE environment variable options Success Criteria: User receives profile comparison table

Scenario 3: Troubleshoot Sandbox

Query: "Getting 'operation not permitted' in Gemini sandbox" Expected Behavior:

  • Skill activates on "sandbox troubleshooting" or "operation not permitted"
  • Explains expected sandbox restrictions Success Criteria: User understands behavior is expected and gets workarounds

References

Query

gemini-cli-docs
for official documentation on:

  • "sandbox"
  • "seatbelt profiles"
  • "docker sandbox"

Version History

  • v1.1.0 (2025-12-01): Added Test Scenarios section
  • v1.0.0 (2025-11-25): Initial release