2026-02-06 20:02:48 +00:00
|
|
|
# syntax=docker/dockerfile:1
|
|
|
|
|
|
|
|
|
|
FROM python:3.12-slim AS base
|
|
|
|
|
|
|
|
|
|
ENV PYTHONDONTWRITEBYTECODE=1 \
|
|
|
|
|
PYTHONUNBUFFERED=1
|
|
|
|
|
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
|
|
# System deps (keep minimal)
|
|
|
|
|
RUN apt-get update \
|
2026-03-02 19:41:25 +00:00
|
|
|
&& apt-get install -y --no-install-recommends curl ca-certificates git \
|
2026-02-06 20:02:48 +00:00
|
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
|
|
|
|
|
|
# Install uv (https://github.com/astral-sh/uv)
|
|
|
|
|
RUN curl -LsSf https://astral.sh/uv/install.sh | sh
|
|
|
|
|
ENV PATH="/root/.local/bin:${PATH}"
|
|
|
|
|
|
|
|
|
|
# --- deps layer ---
|
|
|
|
|
FROM base AS deps
|
|
|
|
|
|
|
|
|
|
# Copy only dependency metadata first for better build caching
|
2026-02-07 15:57:25 +00:00
|
|
|
# NOTE: compose builds backend with repo-root context, so files live under /backend.
|
|
|
|
|
COPY backend/pyproject.toml backend/uv.lock ./
|
2026-02-06 20:02:48 +00:00
|
|
|
|
|
|
|
|
# Create venv and sync deps (including runtime)
|
|
|
|
|
RUN uv sync --frozen --no-dev
|
|
|
|
|
|
|
|
|
|
# --- runtime ---
|
|
|
|
|
FROM base AS runtime
|
|
|
|
|
|
|
|
|
|
# Copy virtual environment from deps stage
|
|
|
|
|
COPY --from=deps /app/.venv /app/.venv
|
|
|
|
|
ENV PATH="/app/.venv/bin:${PATH}"
|
|
|
|
|
|
|
|
|
|
# Copy app source
|
2026-02-09 00:51:26 +05:30
|
|
|
COPY backend/migrations ./migrations
|
2026-02-07 11:29:06 +00:00
|
|
|
COPY backend/alembic.ini ./alembic.ini
|
|
|
|
|
COPY backend/app ./app
|
|
|
|
|
|
2026-02-10 20:01:08 +05:30
|
|
|
# Copy provisioning templates.
|
|
|
|
|
# In-repo these live at `backend/templates/`; runtime path is `/app/templates`.
|
|
|
|
|
COPY backend/templates ./templates
|
2026-02-06 20:02:48 +00:00
|
|
|
|
2026-03-02 14:57:00 +00:00
|
|
|
# Copy worker scripts.
|
|
|
|
|
# In-repo these live at `scripts/`; runtime path is `/app/scripts`.
|
|
|
|
|
COPY scripts ./scripts
|
|
|
|
|
|
2026-03-03 13:39:32 -07:00
|
|
|
# Run as non-root user
|
|
|
|
|
RUN groupadd --system appgroup && useradd --system --gid appgroup appuser \
|
|
|
|
|
&& chown -R appuser:appgroup /app
|
|
|
|
|
USER appuser
|
|
|
|
|
|
2026-02-06 20:02:48 +00:00
|
|
|
# Default API port
|
|
|
|
|
EXPOSE 8000
|
|
|
|
|
|
|
|
|
|
# Run the API
|
|
|
|
|
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]
|