50 lines
2 KiB
Docker
50 lines
2 KiB
Docker
# ── 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 -eux; \
|
|
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' || true; \
|
|
rm /tmp/sqlite_vec.tar.gz
|
|
|
|
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"]
|