Presupuestador_web/Dockerfile.server
2024-09-13 13:58:41 +02:00

68 lines
2.2 KiB
Docker

# syntax=docker/dockerfile:1.4
# BUILD STAGE
FROM node:lts-iron AS builder
# Configure default locale (important for chrome-headless-shell).
ENV LANG es_ES.UTF-8
# We don't need the standalone Chromium
ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD true
# Install Google Chrome Stable and fonts
# Note: this installs the necessary libs to make the browser work with Puppeteer.
RUN apt-get update && apt-get install gnupg wget -y && \
wget --quiet --output-document=- https://dl-ssl.google.com/linux/linux_signing_key.pub | gpg --dearmor > /etc/apt/trusted.gpg.d/google-archive.gpg && \
sh -c 'echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" >> /etc/apt/sources.list.d/google.list' && \
apt-get update && \
apt-get install google-chrome-stable -y --no-install-recommends && \
rm -rf /var/lib/apt/lists/*
# Establecer el directorio de trabajo
WORKDIR /api
# Copiar los archivos de dependencias
COPY package.json .
COPY tsconfig*.json .
RUN yarn install
RUN mkdir -p ./shared
RUN mkdir -p ./server
COPY shared ./shared
COPY server ./server
#CMD pwd && ls -la
RUN cd ./shared && yarn install
RUN cd ./server && yarn install
# Ejecutar el build
# Si hay un error, mostrarlo en detalle.
RUN cd ./server && yarn run build || { echo 'Error during build'; exit 1; }
# Copiar plantillas
RUN mkdir -p /api/dist/server/src/contexts/sales/infrastructure/express/controllers/quotes/reportQuote/reporter/templates/quote/
COPY server/src/contexts/sales/infrastructure/express/controllers/quotes/reportQuote/reporter/templates/quote/* /api/dist/server/src/contexts/sales/infrastructure/express/controllers/quotes/reportQuote/reporter/templates/quote
# FINAL STAGE (Producción)
FROM node:lts-iron AS prod
WORKDIR /api
# Copiar los archivos del build desde la fase anterior
COPY --from=builder /api/dist .
COPY --from=builder /api/server/package.json .
COPY --from=builder /api/server/tsconfig.production.json ./tsconfig.json
# Instalar sólo las dependencias de producción en el servidor
RUN yarn install --production
# Exponer el puerto que la API usa
EXPOSE 3001
#CMD pwd && ls -la
#CMD cat package.json
# Comando para correr la aplicación
CMD node -r ts-node/register/transpile-only -r tsconfig-paths/register ./server/src/index.js