Skip to main content

Runs agentic coding assistants in docker containers

Project description

aicage

Run your favorite AI coding agents comfortably in Docker.

Why use aicage?

Agents need deep access (read code, run shells, install deps). Their built-in safety checks are naturally limited.

Running agents in containers gives a hard boundary - while the experience stays the same. See Why cage agents? for the full rationale.

Quickstart

  • Prerequisites:

    • Docker
    • Python 3.10+ and pipx
  • Install:

    pipx install aicage
    
  • Navigate to your project directory.

  • Use one of these commands:

    aicage claude
    aicage cline
    aicage codex
    aicage droid
    

Base images

The first run asks which base image to use; pick Ubuntu or whatever matches your Linux distro.

Base Distro Notes
ubuntu Ubuntu Good default for most users
debian Debian For Debian users
fedora Fedora For RedHat/Fedora users
alpine Alpine Minimal footprint; experimental
node Ubuntu Official Node image (all base images have Node)
act Ubuntu Default runner image from act (act runs GitHub Actions locally)

All base images have the same stack of tools installed.

Agents

CLI Agent Homepage
claude Claude Code https://claude.com/product/claude-code
cline Cline CLI https://docs.cline.bot/cline-cli
codex Codex CLI https://developers.openai.com/codex/cli
droid Factory CLI https://factory.ai/product/cli

Your existing CLI config for each tool is mounted inside the container so you can keep using your preferences and credentials.

aicage options

  • --dry-run prints the composed docker run command without executing it.

Why cage agents?

AI coding agents read your code, run shells, install packages, and edit files. That power is useful, but granting it directly on the host expands your risk surface.

Where built-in safety is limited:

  • Allow/deny lists only cover known patterns; unexpected commands or attack paths can slip through.
  • Some tools work fully only after relaxing their own safety modes, broadening what they can touch.
  • “Read-only project” features are software rules. Other projects and files still sit alongside them on the same host.

How aicage mitigates this:

  • Containers create a hard boundary: the agent can access only what you explicitly mount. Day-to-day use stays familiar—just with the host kept out of reach.

Development info

More details are in DEVELOPMENT.md.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aicage-0.0.9.tar.gz (29.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aicage-0.0.9-py3-none-any.whl (23.8 kB view details)

Uploaded Python 3

File details

Details for the file aicage-0.0.9.tar.gz.

File metadata

  • Download URL: aicage-0.0.9.tar.gz
  • Upload date:
  • Size: 29.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aicage-0.0.9.tar.gz
Algorithm Hash digest
SHA256 36d46ef4e3d18cfbcf219b8dc3a33a1f700d306c8867a57e12e9ed131dbdcf54
MD5 d63b0b35a8d013e3131c8559e174a263
BLAKE2b-256 0672803687954b5ea38d624a638364189f13973fef4682d8e220bbad788c92df

See more details on using hashes here.

Provenance

The following attestation bundles were made for aicage-0.0.9.tar.gz:

Publisher: publish.yml on Wuodan/aicage

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file aicage-0.0.9-py3-none-any.whl.

File metadata

  • Download URL: aicage-0.0.9-py3-none-any.whl
  • Upload date:
  • Size: 23.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aicage-0.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 a9d45823efdbb1030894707182adf097f571428f4b1f2dba572343c90acba1ba
MD5 5cbf9581ed4e8547dc8a240476f91ef1
BLAKE2b-256 3438d5f4d9b4dacb4e4e367758179c3973c38e4e01bce2bd127802698f6e6ac5

See more details on using hashes here.

Provenance

The following attestation bundles were made for aicage-0.0.9-py3-none-any.whl:

Publisher: publish.yml on Wuodan/aicage

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page