All checks were successful
Build & Deploy / build-and-deploy (push) Successful in 9s
The Style Studio's curator-prompt + chat features read reference docs
from disk at runtime. Two issues from the initial production run:
1. Dockerfile + .dockerignore excluded .claude/, docs/, and most of
skills/. Now COPY the four specific files the new endpoints need:
- .claude/agents/hermes-curator.md
- skills/decision/SKILL.md
- docs/legal-decision-lessons.md
- docs/corpus-analysis.md
.dockerignore opens whitelists for just those files.
2. Coolify's custom_docker_run_options=--add-host=host.docker.internal:host-gateway
is not honored on dockerimage build_pack apps (ExtraHosts stayed []).
Switch chat_proxy.py default to http://10.0.1.1:8770 — the docker0
bridge gateway, same pattern Paperclip uses for 3100. Bind the host
pm2 service to 0.0.0.0:8770 so the container can reach it via the
bridge IP. Oracle Cloud's security list keeps the port unreachable
from the public internet.
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
86 lines
3.5 KiB
Docker
86 lines
3.5 KiB
Docker
# ══════════════════════════════════════════════════════════════
|
|
# Dockerfile — Next.js frontend + FastAPI backend (single container)
|
|
#
|
|
# The container runs both:
|
|
# - FastAPI (uvicorn) on :8000 — the API backend
|
|
# - Next.js (node) on :3000 — the frontend (proxies /api/* to :8000)
|
|
#
|
|
# start.sh launches both processes.
|
|
# ══════════════════════════════════════════════════════════════
|
|
|
|
# ── Stage 1: Node deps ────────────────────────────────────────
|
|
FROM node:20-alpine AS deps
|
|
WORKDIR /app
|
|
COPY web-ui/package.json web-ui/package-lock.json ./
|
|
RUN npm ci --no-audit --no-fund
|
|
|
|
# ── Stage 2: Build Next.js ────────────────────────────────────
|
|
FROM node:20-alpine AS builder
|
|
WORKDIR /app
|
|
COPY --from=deps /app/node_modules ./node_modules
|
|
COPY web-ui/ ./
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
RUN npm run build
|
|
|
|
# ── Stage 3: Install Python deps (use slim for pre-built wheels) ──
|
|
FROM python:3.12-slim AS pydeps
|
|
WORKDIR /opt/api
|
|
COPY mcp-server/ ./mcp-server/
|
|
RUN pip install --no-cache-dir ./mcp-server
|
|
|
|
# ── Stage 4: Runner ───────────────────────────────────────────
|
|
FROM python:3.12-slim AS runner
|
|
WORKDIR /app
|
|
|
|
# Install Node.js 20.x
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
curl ca-certificates git \
|
|
&& curl -fsSL https://deb.nodesource.com/setup_20.x | bash - \
|
|
&& apt-get install -y --no-install-recommends nodejs \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
ENV NODE_ENV=production
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
ENV PORT=3000
|
|
ENV HOSTNAME=0.0.0.0
|
|
|
|
# Copy Python packages from pydeps stage
|
|
COPY --from=pydeps /usr/local/lib/python3.12/site-packages /usr/local/lib/python3.12/site-packages
|
|
COPY --from=pydeps /usr/local/bin/uvicorn /usr/local/bin/uvicorn
|
|
|
|
# Copy Next.js standalone build
|
|
COPY --from=builder /app/public ./public
|
|
COPY --from=builder /app/.next/standalone ./
|
|
COPY --from=builder /app/.next/static ./.next/static
|
|
|
|
# Copy FastAPI backend code
|
|
COPY web/ ./web/
|
|
COPY mcp-server/src/ ./mcp-server/src/
|
|
|
|
# DOCX template used by analysis_docx_exporter — loaded at runtime by path
|
|
# (Path(__file__).resolve().parents[4] / "skills/docx/decision_template.docx")
|
|
COPY skills/docx/decision_template.docx ./skills/docx/decision_template.docx
|
|
|
|
# Reference content the /training tab reads at runtime:
|
|
# - .claude/agents/hermes-curator.md → GET /api/training/curator/prompt
|
|
# - skills/decision/SKILL.md → system prompt for the chat
|
|
# - docs/legal-decision-lessons.md → system prompt for the chat
|
|
# - docs/corpus-analysis.md → system prompt for the chat
|
|
#
|
|
# These are read-only at runtime; chair edits go through git, not the container.
|
|
COPY .claude/agents/hermes-curator.md ./.claude/agents/hermes-curator.md
|
|
COPY skills/decision/SKILL.md ./skills/decision/SKILL.md
|
|
COPY docs/legal-decision-lessons.md ./docs/legal-decision-lessons.md
|
|
COPY docs/corpus-analysis.md ./docs/corpus-analysis.md
|
|
|
|
# Make mcp-server source available to web/app.py (it does sys.path.insert for legal_mcp)
|
|
ENV PYTHONPATH=/app/mcp-server/src
|
|
|
|
# Copy startup script
|
|
COPY start.sh ./start.sh
|
|
RUN chmod +x ./start.sh
|
|
|
|
EXPOSE 3000
|
|
|
|
CMD ["./start.sh"]
|