FROM node:18-alpine AS installer RUN corepack enable && corepack prepare pnpm@latest --activate WORKDIR /app COPY . . # Copy .env file because Docker don't follow symlinks COPY .env.docker /app/apps/web/.env RUN pnpm install # Build the project RUN pnpm post-install --filter=web... RUN pnpm turbo run build --filter=web... FROM node:18-alpine AS runner RUN corepack enable && corepack prepare pnpm@latest --activate # Don't run production as root RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs USER nextjs WORKDIR /home/nextjs COPY --from=installer /app/apps/web/next.config.mjs . COPY --from=installer /app/apps/web/package.json . # Automatically leverage output traces to reduce image size # https://nextjs.org/docs/advanced-features/output-file-tracing COPY --from=installer --chown=nextjs:nodejs /app/apps/web/.next/standalone ./ COPY --from=installer --chown=nextjs:nodejs /app/apps/web/.next/static ./apps/web/.next/static COPY --from=installer --chown=nextjs:nodejs /app/apps/web/public ./apps/web/public COPY --from=installer --chown=nextjs:nodejs /app/packages/database/schema.prisma ./packages/database/schema.prisma COPY --from=installer --chown=nextjs:nodejs /app/packages/database/migrations ./packages/database/migrations ENV NEXTAUTH_SECRET=$NEXTAUTH_SECRET EXPOSE 3000 CMD if [ "$NEXTAUTH_SECRET" != "RANDOM_STRING" ]; then \ pnpm dlx prisma migrate deploy && node apps/web/server.js; \ else \ echo "ERROR: Please set a value for NEXTAUTH_SECRET in .env.docker!"; \ exit 1; \ fi