Spaces:
Running
Running
| # Build the React frontend | |
| FROM node:18 AS frontend-builder | |
| WORKDIR /app/frontend | |
| COPY frontend/package*.json ./ | |
| RUN npm install | |
| COPY frontend/ . | |
| RUN npm run build | |
| # Build the FastAPI backend | |
| FROM python:3.11-slim | |
| # Hugging Face runs as user 1000 | |
| RUN useradd -m -u 1000 user | |
| WORKDIR /home/user/app | |
| # Install system dependencies | |
| RUN apt-get update && apt-get install -y \ | |
| build-essential \ | |
| cmake \ | |
| git \ | |
| g++ \ | |
| && rm -rf /var/lib/apt/lists/* | |
| # Install Python requirements | |
| COPY requirements.txt . | |
| RUN pip install --no-cache-dir -r requirements.txt | |
| # Pre-download the embedding model while we have internet access | |
| # This caches it so runtime doesn't need to download | |
| RUN python -c "from sentence_transformers import SentenceTransformer; SentenceTransformer('all-MiniLM-L6-v2')" 2>/dev/null || echo "Model download skipped (expected in some environments)" | |
| # Copy the backend code | |
| COPY --chown=user . . | |
| # Copy the built React app from the frontend-builder stage | |
| COPY --from=frontend-builder --chown=user /app/frontend/dist /home/user/app/frontend/dist | |
| # Create data directories for persistent storage | |
| # /data is the HF Spaces persistent volume mount point | |
| RUN mkdir -p /data && chown -R user:user /data | |
| RUN mkdir -p /home/user/app/data && chown -R user:user /home/user/app/data | |
| USER user | |
| ENV PORT=7860 | |
| ENV HOME=/home/user | |
| ENV PATH=/home/user/.local/bin:$PATH | |
| ENV TORCH_HOME=/data/.cache/torch | |
| ENV HF_HOME=/data/.cache/huggingface | |
| ENV XDG_CACHE_HOME=/data/.cache | |
| ENV CHROMA_DB_PATH=/data/chroma_db | |
| ENV SQLITE_DB_PATH=/data/soma_sessions.db | |
| EXPOSE 8080 | |
| # PORT env var is overridden by each platform (HF sets 7860, Fly.io sets 8080) | |
| CMD uvicorn app.main:app --host 0.0.0.0 --port ${PORT} | |