# syntax=docker/dockerfile:1.7

# ─── Stage 1 — install deps ─────────────────────────────────────────────────
FROM node:22-alpine AS deps
WORKDIR /app
RUN apk add --no-cache git python3 make g++
RUN corepack enable && corepack prepare pnpm@9.15.0 --activate
COPY package.json pnpm-lock.yaml* ./
RUN pnpm install --frozen-lockfile || pnpm install

# ─── Stage 2 — build client + server ─────────────────────────────────────────
FROM node:22-alpine AS builder
WORKDIR /app
RUN apk add --no-cache git
RUN corepack enable && corepack prepare pnpm@9.15.0 --activate
COPY --from=deps /app/node_modules ./node_modules
COPY . .
RUN pnpm build

# ─── Stage 3 — runtime ──────────────────────────────────────────────────────
FROM node:22-alpine AS runner
WORKDIR /app
ENV NODE_ENV=production \
    PORT=5000

RUN corepack enable && corepack prepare pnpm@9.15.0 --activate

# Copy production deps + built assets
COPY --from=deps /app/node_modules ./node_modules
COPY --from=builder /app/dist ./dist
COPY package.json tsconfig.json drizzle.config.ts ./
COPY server ./server
COPY shared ./shared

# Persistent app data directory (WhatsApp sessions, DB backups, …).
# In production this should be backed by a Docker named volume.
RUN mkdir -p /app/data/whatsapp-sessions /app/data/backups

# Bundle the operational scripts (DB backup, etc.)
COPY scripts ./scripts
RUN chmod +x ./scripts/*.sh || true

# Tools used by the backup script
RUN apk add --no-cache mysql-client

RUN addgroup -S app && adduser -S app -G app && chown -R app:app /app
USER app

EXPOSE 5000

HEALTHCHECK --interval=30s --timeout=5s --start-period=15s --retries=3 \
  CMD wget -qO- http://127.0.0.1:5000/api/health || exit 1

CMD ["pnpm", "start"]
