# Build stage FROM node:20-alpine AS builder WORKDIR /app # Copy package files first for layer caching COPY package*.json ./ COPY prisma ./prisma/ # Copy the encryptid-sdk (symlinked or copied into build context) COPY encryptid-sdk/ /encryptid-sdk/ # Install dependencies RUN npm ci || npm install # Ensure SDK is properly linked in node_modules RUN rm -rf node_modules/@encryptid/sdk && \ mkdir -p node_modules/@encryptid && \ cp -r /encryptid-sdk node_modules/@encryptid/sdk # Copy source files COPY src ./src COPY public ./public COPY next.config.ts tsconfig.json postcss.config.mjs components.json ./ # Generate Prisma client RUN npx prisma generate # Build the application RUN npm run build # Production stage FROM node:20-alpine AS runner WORKDIR /app ENV NODE_ENV=production # Create non-root user RUN addgroup --system --gid 1001 nodejs RUN adduser --system --uid 1001 nextjs # Copy necessary files from 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/prisma ./prisma COPY --from=builder /app/node_modules/.prisma ./node_modules/.prisma COPY --from=builder /app/node_modules/prisma ./node_modules/prisma COPY --from=builder /app/node_modules/@prisma ./node_modules/@prisma # Infisical entrypoint for secret injection COPY --chown=nextjs:nodejs entrypoint.sh /entrypoint.sh RUN chmod +x /entrypoint.sh # Set ownership RUN chown -R nextjs:nodejs /app USER nextjs EXPOSE 3000 ENV PORT=3000 ENV HOSTNAME="0.0.0.0" ENTRYPOINT ["/entrypoint.sh"] CMD ["node", "server.js"]