FROM python:3.12-slim-bookworm COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/ WORKDIR /app ENV PYTHONUNBUFFERED=1 \ UV_COMPILE_BYTECODE=1 RUN apt-get update && apt-get install -y --no-install-recommends \ build-essential \ libpq-dev \ gcc \ libgomp1 \ && rm -rf /var/lib/apt/lists/* RUN addgroup --system app && \ adduser --system --group --home /home/app app COPY pyproject.toml uv.lock ./ RUN uv sync --frozen --no-dev # Download spaCy model required by presidio-analyzer RUN uv pip install https://github.com/explosion/spacy-models/releases/download/en_core_web_lg-3.8.0/en_core_web_lg-3.8.0-py3-none-any.whl COPY . . RUN chown -R app:app /app USER app EXPOSE 7860 CMD ["uv", "run", "--no-sync", "uvicorn", "main:app", "--host", "0.0.0.0", "--port", "7860"]