# ── Stage 1: Build Vue SPA ────────────────────────────────────────────────────
FROM node:22-alpine AS web-builder
WORKDIR /web
COPY web/package.json web/package-lock.json ./
RUN npm ci
COPY web/ ./
RUN npm run build

# ── Stage 2: Python runtime ───────────────────────────────────────────────────
FROM python:3.12-slim
WORKDIR /app

RUN apt-get update && apt-get install -y --no-install-recommends \
    curl \
    && rm -rf /var/lib/apt/lists/*

COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt

# sqlite-vec: optional vector search extension for context embedding (Paid tier)
RUN set -e; \
    SVEC_VER=0.1.6; \
    ARCH=$(uname -m); \
    case "$ARCH" in \
      x86_64)  SVEC_ARCH="x86_64-linux-gnu" ;; \
      aarch64) SVEC_ARCH="aarch64-linux-gnu" ;; \
      *)        echo "sqlite-vec: unsupported arch $ARCH — skipping" && exit 0 ;; \
    esac; \
    curl -fsSL -o /tmp/sqlite_vec.tar.gz \
      "https://github.com/asg017/sqlite-vec/releases/download/v${SVEC_VER}/sqlite-vec-${SVEC_VER}-loadable-linux-${SVEC_ARCH}.tar.gz" \
    && tar -xz -C /usr/lib/python3/ -f /tmp/sqlite_vec.tar.gz --wildcards '*.so' \
    && rm /tmp/sqlite_vec.tar.gz \
    || echo "sqlite-vec optional extension unavailable — vector search disabled"

COPY app/ ./app/
COPY patterns/ ./patterns/
COPY scripts/ ./scripts/
COPY --from=web-builder /web/dist ./web/dist

# Volume mount points — override at runtime:
#   /data/     → TURNSTONE_DB=/data/turnstone.db  (read-write)
#   /patterns/ → custom pattern YAML files        (read-write)
#   /logs/     → host log directories             (read-only)
ENV TURNSTONE_DB=/data/turnstone.db

EXPOSE 8534

HEALTHCHECK --interval=30s --timeout=10s --start-period=20s --retries=3 \
    CMD curl -f http://localhost:8534/turnstone/health || exit 1

CMD ["uvicorn", "app.rest:app", "--host", "0.0.0.0", "--port", "8534"]
