FROM node:18-alpine AS builder WORKDIR /app # Copy workspace files COPY package.json pnpm-lock.yaml pnpm-workspace.yaml ./ COPY apps/api/package.json ./apps/api/ # Install pnpm RUN npm install -g pnpm # Install dependencies RUN pnpm install --frozen-lockfile # Copy source COPY apps/api ./apps/api # Production image FROM node:18-alpine WORKDIR /app # Install pnpm and ts-node RUN npm install -g pnpm ts-node typescript # Copy package files COPY package.json pnpm-lock.yaml pnpm-workspace.yaml ./ COPY apps/api/package.json ./apps/api/ # Install production dependencies RUN pnpm install --frozen-lockfile # Copy app from builder COPY --from=builder /app/apps/api ./apps/api WORKDIR /app/apps/api # Create data directory RUN mkdir -p /app/data EXPOSE 3001 # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=40s --retries=3 \ CMD node -e "require('http').get('http://localhost:3001/health', (r) => {process.exit(r.statusCode === 200 ? 0 : 1)})" CMD ["pnpm", "run", "dev"]