Skip to main content

Portable, offline-first container sandboxes for LLM agents and dev workflows

Project description

pocketdock

CI PyPI Coverage: 100% Docs License: BSD-2-Clause

Portable, offline-first container sandboxes for LLM agents and dev workflows.

One Container class. Podman-first, Docker-compatible. Python SDK + CLI. Zero cloud. Zero API keys.

Why pocketdock?

Managed sandbox platforms require API keys, cloud accounts, and an internet connection. Rolling your own container glue means rewriting hundreds of lines of boilerplate every time. pocketdock sits in between: a clean Python SDK that talks directly to your container engine over its Unix socket, works entirely offline, and has zero external dependencies for the core SDK.

Features

  • Three execution modes — blocking, streaming, and detached (background) with ring buffer
  • File operations — read, write, list, push, and pull files between host and container
  • Persistent sessions — long-lived shell sessions with state (cwd, env vars, history)
  • Resource limits — memory caps, CPU throttling, per-container isolation
  • Port mapping — expose container ports on the host (e.g., ports={8080: 80})
  • Container persistence — stop/resume, snapshot to image, volume mounts
  • Project management.pocketdock/ project directories with config, logging, and health checks
  • Image profiles — six pre-baked Dockerfiles: minimal-python, minimal-node, minimal-bun, dev, agent, embedded
  • Full CLI — 22 commands for container lifecycle, file ops, and project management
  • Async-first — sync facade over async core; use either API style
  • Callbacks — register handlers for stdout, stderr, and exit events

Quick Example

from pocketdock import create_new_container

with create_new_container() as c:
    result = c.run("echo hello")
    print(result.stdout)  # "hello\n"
    print(result.ok)      # True

Install

pip install pocketdock          # SDK only (zero dependencies)
pip install pocketdock[cli]     # SDK + CLI (click, rich)
pip install pocketdock[agent]   # SDK + CLI + LLM agent (litellm)

Single-file downloads (no pip required) are available from GitHub Releases.

Requires Podman (recommended) or Docker.

# Build the minimal-python image (~25MB, <500ms startup)
pocketdock build minimal-python

Documentation

Full documentation is available at deftio.github.io/pocketdock.

Architecture

User Code / LLM Agent / CLI
        |
        v
  pocketdock SDK
  +--------------------------------------+
  | Container (sync)  -> AsyncContainer  |  facade pattern
  |   +- _socket_client (raw HTTP/Unix)  |
  +- ProjectManager (.pocketdock/)      |
  +- Persistence (resume, snapshot)      |
  +- Sessions (persistent shells)        |
  +--------------------------------------+
        |  raw HTTP over Unix socket
        |  (one connection per operation)
        v
  Podman (rootless) / Docker Engine

Design principles:

  • Connection-per-operation — each API call opens its own Unix socket. No pooling.
  • Async core, sync facadeAsyncContainer does all real work. Container is a sync wrapper.
  • No cached state — always polls live from the engine.
  • Minimal dependencies — stdlib-only for the core SDK.

Development

uv sync --dev                    # Install dependencies
uv run pytest                    # Run tests (100% coverage enforced)
uv run ruff check .              # Lint (zero warnings)
uv run mypy --strict python/     # Type checking (strict mode)
uv run mkdocs serve              # Local docs site

License

BSD-2-Clause. Copyright (c) deftio llc.

Project details


Download files

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

Source Distribution

pocketdock-1.2.2.tar.gz (169.1 kB view details)

Uploaded Source

Built Distribution

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

pocketdock-1.2.2-py3-none-any.whl (54.9 kB view details)

Uploaded Python 3

File details

Details for the file pocketdock-1.2.2.tar.gz.

File metadata

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

File hashes

Hashes for pocketdock-1.2.2.tar.gz
Algorithm Hash digest
SHA256 bfef42eab0d463d4a32c6f093ac3692d87ec5960b65e09436ca14e85aeb47963
MD5 1df2f2ba9d63d3b0303c9fced5762af6
BLAKE2b-256 cde54cc9b3c09149132799a11ce020b810c39004811f449cdb599201c2ae3713

See more details on using hashes here.

Provenance

The following attestation bundles were made for pocketdock-1.2.2.tar.gz:

Publisher: publish.yml on deftio/pocketdock

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

File details

Details for the file pocketdock-1.2.2-py3-none-any.whl.

File metadata

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

File hashes

Hashes for pocketdock-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 edd68f701747e0176d384eec9ff99645aec9120431bc60b04e293ffa6dc41bbd
MD5 0de182d1253b659b792dd38ec77d5a56
BLAKE2b-256 a426dc9c2f6ca86bfc04d03b345391af2ca6371210fcf8be8ad0922d4ab06c77

See more details on using hashes here.

Provenance

The following attestation bundles were made for pocketdock-1.2.2-py3-none-any.whl:

Publisher: publish.yml on deftio/pocketdock

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