All checks were successful
Trigger Cloudarix Deploy / call-webhook (push) Successful in 1s
34 lines
1.3 KiB
Docker
34 lines
1.3 KiB
Docker
### Multi-stage build: compile TypeScript in a builder image, produce a smaller runtime image
|
|
### IMPORTANT: Dokploy must set dockerContextPath="." (repo root) in database
|
|
### This allows the build to access package.json and other files from repo root
|
|
### Dockerfile path should be "worker/Dockerfile"
|
|
|
|
FROM node:20 AS builder
|
|
WORKDIR /usr/src/app
|
|
|
|
# Copy package manifests and install all deps (including dev) for build
|
|
COPY package.json package-lock.json ./
|
|
RUN npm ci --silent
|
|
|
|
# Copy entire project and compile TypeScript
|
|
COPY . .
|
|
# Try to compile the project; if there is no TS config for worker, keep files as-is
|
|
RUN npx tsc -p tsconfig.json --outDir dist || echo "tsc exit code ignored"
|
|
|
|
FROM node:20-alpine AS runner
|
|
WORKDIR /usr/src/app
|
|
|
|
# Install only production dependencies
|
|
COPY package.json package-lock.json ./
|
|
RUN npm ci --production --silent
|
|
|
|
# Copy compiled output from builder (if present) and essential runtime files
|
|
COPY --from=builder /usr/src/app/dist ./dist
|
|
COPY --from=builder /usr/src/app/worker ./worker
|
|
COPY --from=builder /usr/src/app/lib ./lib
|
|
|
|
ENV NODE_ENV=production
|
|
|
|
# If compiled JS exists, run compiled entrypoint; otherwise fallback to tsx runtime
|
|
CMD ["sh", "-c", "if [ -f ./dist/worker/index.js ]; then node ./dist/worker/index.js; else npx tsx ./worker/index.ts; fi"]
|