# Stage 1: Build backend
FROM node:20-alpine AS backend-builder
WORKDIR /app/backend
COPY backend/package*.json ./
# Use inline NODE_ENV=development so devDeps (nest CLI) are installed
# but the global NODE_ENV stays production for the actual build
RUN NODE_ENV=development npm ci --legacy-peer-deps --include=dev
COPY backend/ .
RUN ./node_modules/.bin/nest build

# Stage 2: Build frontend
FROM node:20-alpine AS frontend-builder
WORKDIR /app/frontend
COPY frontend/package*.json ./
RUN NODE_ENV=development npm ci --legacy-peer-deps --include=dev
COPY frontend/ .
ENV NEXT_PUBLIC_API_URL=/api-backend
ENV NEXT_TELEMETRY_DISABLED=1
ENV NODE_ENV=production
RUN npm run build

# Stage 3: Runtime
FROM node:20-bookworm-slim AS runner
WORKDIR /app

# Install nginx and MongoDB
RUN apt-get update && apt-get install -y --no-install-recommends \
    nginx \
    gnupg \
    curl \
    && curl -fsSL https://www.mongodb.org/static/pgp/server-7.0.asc | gpg -o /usr/share/keyrings/mongodb-server-7.0.gpg --dearmor \
    && echo "deb [ signed-by=/usr/share/keyrings/mongodb-server-7.0.gpg ] https://repo.mongodb.org/apt/debian bookworm/mongodb-org/7.0 main" > /etc/apt/sources.list.d/mongodb-org-7.0.list \
    && apt-get update && apt-get install -y --no-install-recommends mongodb-org \
    && rm -rf /var/lib/apt/lists/* \
    && mkdir -p /data/db /run/nginx

# Copy backend build
COPY --from=backend-builder /app/backend/dist ./backend/dist
COPY --from=backend-builder /app/backend/node_modules ./backend/node_modules
COPY --from=backend-builder /app/backend/package.json ./backend/

# Copy frontend build (standalone mode)
COPY --from=frontend-builder /app/frontend/.next/standalone ./frontend/
COPY --from=frontend-builder /app/frontend/.next/static ./frontend/.next/static
# public dir may be empty — copy if exists
COPY --from=frontend-builder /app/frontend/public/ ./frontend/public/

# Nginx config
COPY nginx.conf /etc/nginx/nginx.conf

# Start script
COPY start.sh .
RUN chmod +x start.sh

EXPOSE 80
CMD ["./start.sh"]
