# Dockerfile optimisé pour la production Neah # Utilisé uniquement si vous déployez l'application complète avec Docker # Pour Vercel, ce fichier n'est pas nécessaire (Vercel build automatiquement) FROM node:22-alpine AS base # Installer les dépendances nécessaires pour Prisma RUN apk add --no-cache libc6-compat openssl WORKDIR /app # ============================================ # Étape 1: Dépendances # ============================================ FROM base AS deps COPY package.json package-lock.json* ./ RUN npm ci # ============================================ # Étape 2: Builder # ============================================ FROM base AS builder COPY --from=deps /app/node_modules ./node_modules COPY . . # Générer le client Prisma RUN npx prisma generate # Build Next.js (sans migrations - elles seront appliquées séparément) ENV NEXT_TELEMETRY_DISABLED=1 RUN npm run build # ============================================ # Étape 3: Runner (image finale) # ============================================ FROM base AS runner WORKDIR /app ENV NODE_ENV=production ENV NEXT_TELEMETRY_DISABLED=1 # Créer un utilisateur non-root pour la sécurité RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs # Copier les fichiers nécessaires depuis le builder COPY --from=builder /app/public ./public COPY --from=builder /app/.next/standalone ./ COPY --from=builder /app/.next/static ./.next/static COPY --from=builder /app/node_modules/.prisma ./node_modules/.prisma COPY --from=builder /app/node_modules/@prisma ./node_modules/@prisma # Changer les permissions RUN chown -R nextjs:nodejs /app USER nextjs EXPOSE 3000 ENV PORT=3000 ENV HOSTNAME="0.0.0.0" # Note: Les migrations Prisma doivent être appliquées séparément avant le démarrage # Utilisez: docker exec npx prisma migrate deploy CMD ["node", "server.js"]