# Copyright (c) Meta Platforms, Inc. and affiliates. # All rights reserved. # # This source code is licensed under the BSD-style license found in the # LICENSE file in the root directory of this source tree. ARG BASE_IMAGE=ghcr.io/meta-pytorch/openenv-base:latest FROM ${BASE_IMAGE} AS builder WORKDIR /app RUN apt-get update && \ apt-get install -y --no-install-recommends git && \ rm -rf /var/lib/apt/lists/* COPY . /app/env WORKDIR /app/env RUN if ! command -v uv >/dev/null 2>&1; then \ curl -LsSf https://astral.sh/uv/install.sh | sh && \ mv /root/.local/bin/uv /usr/local/bin/uv && \ mv /root/.local/bin/uvx /usr/local/bin/uvx; \ fi RUN --mount=type=cache,target=/root/.cache/uv \ uv sync --no-install-project --no-editable RUN --mount=type=cache,target=/root/.cache/uv \ uv sync --no-editable FROM ${BASE_IMAGE} WORKDIR /app COPY --from=builder /app/env/.venv /app/.venv COPY --from=builder /app/env /app/env # Ported from RL_ENV Dockerfile hardening: # run the HF Space as uid 1000 rather than root. RUN useradd -m -u 1000 appuser && \ chown -R appuser:appuser /app ENV PATH="/app/.venv/bin:$PATH" ENV PYTHONPATH="/app/env:$PYTHONPATH" HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \ CMD curl -f http://localhost:7860/health || exit 1 EXPOSE 7860 WORKDIR /app/env USER appuser CMD ["uvicorn", "server.app:app", "--host", "0.0.0.0", "--port", "7860"]