mirror of
https://github.com/d0zingcat/BroadcastChannel.git
synced 2026-05-13 15:09:12 +00:00
Improves Sentry integration in Docker builds by: - Moving Sentry environment variables to build args - Adding .env to dockerignore for security - Properly passing Sentry configuration during build process This change ensures better security practices and more reliable Sentry configuration in containerized environments.
35 lines
739 B
Docker
35 lines
739 B
Docker
FROM node:lts-alpine AS base
|
|
|
|
ENV PNPM_HOME="/pnpm"
|
|
ENV PATH="$PNPM_HOME:$PATH"
|
|
RUN corepack enable
|
|
|
|
WORKDIR /app
|
|
COPY package.json pnpm-lock.yaml ./
|
|
|
|
# FROM base AS prod-deps
|
|
# RUN --mount=type=cache,id=pnpm,target=/pnpm/store pnpm install --prod --frozen-lockfile
|
|
|
|
FROM base AS build-deps
|
|
RUN --mount=type=cache,id=pnpm,target=/pnpm/store pnpm install --frozen-lockfile
|
|
|
|
FROM build-deps AS build
|
|
COPY . .
|
|
|
|
ARG SENTRY_DSN
|
|
ARG SENTRY_AUTH_TOKEN
|
|
ARG SENTRY_PROJECT
|
|
|
|
RUN export $(cat .env.example) && \
|
|
export DOCKER=true && \
|
|
pnpm run build
|
|
|
|
FROM base AS runtime
|
|
# COPY --from=prod-deps /app/node_modules ./node_modules
|
|
COPY --from=build /app/dist ./dist
|
|
|
|
ENV HOST=0.0.0.0
|
|
ENV PORT=4321
|
|
EXPOSE 4321
|
|
CMD node ./dist/server/entry.mjs
|