feat(docker): add Dockerfile, Docker Compose, and deployment entrypoint

Multi-stage Dockerfile produces a lean image with the compiled SvelteKit
app (adapter-node) and the MCP server TypeScript source. A single image
supports two run modes selected via CMD: web (default) and mcp.

- docker-entrypoint.sh handles CA certificate install (PEM/DER auto-detected
  via openssl), SSH key permission fix for Windows-mounted keys, per-host
  HTTPS credential helpers for Bitbucket and GitLab, DB migrations, then
  starts the requested service
- docker-compose.yml runs web on :3000 and the MCP HTTP server on :3001,
  with the MCP container pointed at the web service via internal DNS
- .dockerignore excludes node_modules, build output, .env files, and *.db*

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Giancarmine Salucci
2026-03-25 14:30:12 +01:00
parent a63de39473
commit 69743862a7
4 changed files with 104 additions and 0 deletions

45
Dockerfile Normal file
View File

@@ -0,0 +1,45 @@
# ---- build stage ----
FROM node:20-alpine AS builder
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build
# ---- production stage ----
FROM node:20-alpine
WORKDIR /app
# Install all deps (includes tsx for the MCP server and drizzle-kit for migrations)
COPY package*.json ./
RUN npm ci
# Built SvelteKit app (adapter-node output)
COPY --from=builder /app/build ./build
# MCP server source
COPY --from=builder /app/src/mcp ./src/mcp
# Drizzle migrations
COPY --from=builder /app/drizzle.config.ts ./drizzle.config.ts
COPY --from=builder /app/src/lib/server/db/migrations ./src/lib/server/db/migrations
COPY --from=builder /app/tsconfig.json ./tsconfig.json
# Persistent volume for the SQLite database
RUN mkdir -p /data
VOLUME ["/data"]
ENV DATABASE_URL=/data/trueref.db
ENV HOST=0.0.0.0
ENV PORT=3000
ENV TRUEREF_API_URL=http://localhost:3000
EXPOSE 3000 3001
COPY docker-entrypoint.sh /docker-entrypoint.sh
RUN chmod +x /docker-entrypoint.sh
ENTRYPOINT ["/docker-entrypoint.sh"]
CMD ["web"]