# Read the doc: https://huggingface.co/docs/hub/spaces-sdks-docker | |
# Dockerfile for Cyber-LLM Research Platform on Hugging Face Spaces | |
FROM python:3.9-slim | |
# Create user for security | |
RUN useradd -m -u 1000 user | |
USER user | |
# Set environment variables | |
ENV PATH="/home/user/.local/bin:$PATH" | |
ENV PYTHONPATH="/app" | |
# Set working directory | |
WORKDIR /app | |
# Copy requirements file | |
COPY --chown=user ./requirements-hf-space.txt requirements.txt | |
# Install Python dependencies | |
RUN pip install --no-cache-dir --upgrade -r requirements.txt | |
# Copy application files | |
COPY --chown=user . /app | |
# Expose port 7860 (Hugging Face Spaces standard) | |
EXPOSE 7860 | |
# Health check | |
HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \ | |
CMD curl -f http://localhost:7860/health || exit 1 | |
# Start the FastAPI application | |
CMD ["uvicorn", "app:app", "--host", "0.0.0.0", "--port", "7860", "--workers", "1"] | |