# ── Timmy Agent — Multi-stage Optimized Build ────────────────────────────────
#
# Lightweight agent container for running Timmy or swarm workers.
# Build: docker build -f docker/Dockerfile.agent -t timmy-agent:latest .
# Run: docker run -e COORDINATOR_URL=http://dashboard:8000 timmy-agent:latest
# ── Stage 1: Builder ──────────────────────────────────────────────────────────
FROM python:3.12-slim AS builder
WORKDIR /build
# Install build dependencies
RUN apt-get update && apt-get install -y --no-install-recommends \
gcc curl \
&& rm -rf /var/lib/apt/lists/*
# Install Poetry + export plugin for dependency export
RUN pip install --no-cache-dir poetry poetry-plugin-export
# Copy only dependency files for layer caching
COPY pyproject.toml poetry.lock ./
# Export pinned requirements and install with pip
RUN poetry export --extras swarm --without-hashes \
-f requirements.txt -o requirements.txt
RUN --mount=type=cache,target=/root/.cache/pip \
pip install --no-cache-dir --user -r requirements.txt
# ── Stage 2: Runtime ─────────────────────────────────────────────────────────
FROM python:3.12-slim AS runtime
WORKDIR /app
# Install only runtime dependencies
curl \
# Copy Python packages from builder
COPY --from=builder /root/.local /root/.local
# Copy application source
COPY src/ ./src/
# Create data directory
RUN mkdir -p /app/data
# Create non-root user
RUN groupadd -r timmy && useradd -r -g timmy -d /app -s /sbin/nologin timmy && \
chown -R timmy:timmy /app
# Set environment
ENV PATH=/root/.local/bin:$PATH
ENV PYTHONPATH=/app/src
ENV PYTHONUNBUFFERED=1
ENV PYTHONDONTWRITEBYTECODE=1
# Switch to non-root user
USER timmy
# Default: run Timmy agent (can be overridden)
CMD ["python", "-m", "timmy.docker_agent"]