Docker
Use Docker when you want a self-contained Paperclip instance without installing Node or pnpm on the host machine.
This page covers the quickstart image, the manual image build, and what persists between container restarts.
Compose Quickstart
The recommended path is the compose-based quickstart:
docker compose -f docker/docker-compose.quickstart.yml up --build
Open the app at:
http://localhost:3100
Defaults:
- host port
3100 - data directory
./data/docker-paperclip
Override them with environment variables:
PAPERCLIP_PORT=3200 PAPERCLIP_DATA_DIR=../data/pc \
docker compose -f docker/docker-compose.quickstart.yml up --build
Note:
PAPERCLIP_DATA_DIRis resolved relative to the compose file indocker/, so../data/pcmaps todata/pcin the repository root.
Manual Image Build
If you want a plain container run instead of compose, build and start the image manually:
docker build -t paperclip-local .
docker run --name paperclip \
-p 3100:3100 \
-e HOST=0.0.0.0 \
-e PAPERCLIP_HOME=/paperclip \
-v "$(pwd)/data/docker-paperclip:/paperclip" \
paperclip-local
Use this when you want tight control over the container lifecycle or are embedding Paperclip into a larger Docker workflow.
What Persists
All persistent data lives under the bind mount:
- embedded PostgreSQL data
- uploaded assets
- the local secrets key
- agent workspace data
If the bind mount is removed, the instance starts fresh on the next run.
LLM Adapter Support
The Docker image pre-installs the local CLI tools used by the built-in local adapters, so they work inside the container out of the box:
claudeforclaude_localcodexforcodex_localopencodeforopencode_localgeminiforgemini_local
The image sets GEMINI_SANDBOX=false so the Gemini CLI runs safely inside the container without its own sandbox layer.
If you want those adapters to run inside the container, pass the relevant API keys:
docker run --name paperclip \
-p 3100:3100 \
-e HOST=0.0.0.0 \
-e PAPERCLIP_HOME=/paperclip \
-e OPENAI_API_KEY=sk-... \
-e ANTHROPIC_API_KEY=sk-... \
-e GEMINI_API_KEY=... \
-v "$(pwd)/data/docker-paperclip:/paperclip" \
paperclip-local
Without those keys, the app still runs. The adapter environment test will simply report missing prerequisites for the relevant adapter.
Tip: If you are testing adapter behavior inside Docker, verify the bind mount first. Most surprising failures come from lost state, not the container image itself.