59 lines
1.4 KiB
Docker
59 lines
1.4 KiB
Docker
# --- 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"]
|