Merge pull request #8 from Kenearos/claude/check-progress-McAlj

Add Docker support for Next.js frontend service
This commit is contained in:
Kenearos 2026-02-22 11:20:20 +01:00 committed by GitHub
commit 7d023af43b
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 65 additions and 1 deletions

View file

@ -49,6 +49,21 @@ services:
condition: service_healthy
command: uvicorn main:app --host 0.0.0.0 --port 8000 --reload
# ---------------------------------------------------------------------------
# CouncilOS Frontend — Next.js + React Flow UI
# ---------------------------------------------------------------------------
frontend:
build:
context: ./frontend
dockerfile: Dockerfile
restart: unless-stopped
ports:
- "3000:3000"
environment:
NEXT_PUBLIC_API_URL: http://api:8000
depends_on:
- api
volumes:
postgres_data:
chroma_data:

7
frontend/.dockerignore Normal file
View file

@ -0,0 +1,7 @@
node_modules
.next
.git
.gitignore
*.md
.env*
vitest.config.ts

42
frontend/Dockerfile Normal file
View file

@ -0,0 +1,42 @@
FROM node:22-alpine AS base
# --- Dependencies stage ---
FROM base AS deps
WORKDIR /app
COPY package.json package-lock.json* ./
RUN npm ci
# --- Build stage ---
FROM base AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
ENV NEXT_TELEMETRY_DISABLED=1
RUN npm run build
# --- Production stage ---
FROM base AS runner
WORKDIR /app
ENV NODE_ENV=production
ENV NEXT_TELEMETRY_DISABLED=1
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
COPY --from=builder /app/public ./public
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
USER nextjs
EXPOSE 3000
ENV PORT=3000
ENV HOSTNAME="0.0.0.0"
CMD ["node", "server.js"]

View file

@ -1,7 +1,7 @@
import type { NextConfig } from "next";
const nextConfig: NextConfig = {
/* config options here */
output: "standalone",
};
export default nextConfig;