# --- STAGE 1: BUILDER --- FROM node:20-alpine AS builder WORKDIR /app # Install dependencies COPY package*.json ./ RUN npm install # Copy source code COPY . . # Build-time environment variables ARG NEXT_PUBLIC_API_URL ARG NEXT_PUBLIC_APP_URL ARG NEXTAUTH_URL ARG NEXTAUTH_SECRET ARG NEXT_PUBLIC_AUTH_REQUIRED ARG NEXT_PUBLIC_PADDLE_CLIENT_TOKEN ARG NEXT_PUBLIC_PADDLE_ENVIRONMENT ARG NEXT_PUBLIC_PADDLE_SELLER_ID ENV NEXT_PUBLIC_API_URL=$NEXT_PUBLIC_API_URL ENV NEXT_PUBLIC_APP_URL=$NEXT_PUBLIC_APP_URL ENV NEXTAUTH_URL=$NEXTAUTH_URL ENV NEXTAUTH_SECRET=$NEXTAUTH_SECRET ENV NEXT_PUBLIC_AUTH_REQUIRED=$NEXT_PUBLIC_AUTH_REQUIRED ENV NEXT_PUBLIC_PADDLE_CLIENT_TOKEN=$NEXT_PUBLIC_PADDLE_CLIENT_TOKEN ENV NEXT_PUBLIC_PADDLE_ENVIRONMENT=$NEXT_PUBLIC_PADDLE_ENVIRONMENT ENV NEXT_PUBLIC_PADDLE_SELLER_ID=$NEXT_PUBLIC_PADDLE_SELLER_ID # Build Next.js app RUN npm run build # --- STAGE 2: RUNNER --- FROM node:20-alpine AS runner WORKDIR /app ENV NODE_ENV=production # Don't run as root RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs # Copy standalone build COPY --from=builder /app/public ./public # Set permissions for standalone build 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" # Start standalone server CMD ["node", "server.js"]