openenv / Dockerfile
sentinel-space-publisher
space: publish latest Sentinel app snapshot
c452421
# Single-stage build - avoids pulling the same base image twice (prevents
# manifest-digest cache errors on the validator's Docker daemon).
FROM python:3.12-slim
ENV PYTHONDONTWRITEBYTECODE=1 \
PYTHONUNBUFFERED=1 \
PIP_NO_CACHE_DIR=1 \
PORT=7860 \
ENABLE_WEB_INTERFACE=true \
HOME=/tmp \
XDG_CACHE_HOME=/tmp/.cache
WORKDIR /app
# Install dependencies first (layer cache friendly)
COPY requirements.txt .
RUN python -m pip install --no-cache-dir -r requirements.txt
# Copy application source as a numeric non-root owner. This avoids a fragile
# useradd/chown build layer on Hugging Face Spaces while still avoiding root.
COPY --chown=1000:1000 . .
USER 1000
# HF Spaces requires port 7860
EXPOSE 7860
HEALTHCHECK --interval=30s --timeout=10s --start-period=10s --retries=3 \
CMD python -c "import os, urllib.request; port=os.environ.get('PORT','7860'); urllib.request.urlopen(f'http://localhost:{port}/health').read()"
# Single worker - session state is in-process. server.app reads $PORT.
CMD ["python", "-m", "server.app"]