FROM node:20-alpine

WORKDIR /app

# Install OpenSSL for certificate generation
RUN apk add --no-cache openssl

COPY package*.json ./
RUN npm install --production

COPY *.js ./
COPY routes/ ./routes/
COPY openapi.yaml ./

ARG DASHCADDY_COMMIT=unknown
RUN echo "${DASHCADDY_COMMIT}" > VERSION

# Note: Running as root because container needs Docker socket access
# (which is root-equivalent anyway). Socket access required for container management.

EXPOSE 3001

STOPSIGNAL SIGTERM

HEALTHCHECK --interval=30s --timeout=5s --start-period=10s --retries=3 \
  CMD node -e "require('http').get('http://localhost:3001/health', (r) => { process.exit(r.statusCode === 200 ? 0 : 1); }).on('error', () => process.exit(1))"

CMD ["node", "server.js"]
