We upgraded ESLint to version 9 in the eslint-config-impress package. We rename it to eslint-plugin-docs.
63 lines
1.6 KiB
Docker
63 lines
1.6 KiB
Docker
FROM node:22-alpine AS base
|
|
|
|
# Upgrade system packages to install security updates
|
|
RUN apk update && \
|
|
apk upgrade && \
|
|
rm -rf /var/cache/apk/*
|
|
|
|
FROM base AS y-provider-deps
|
|
|
|
WORKDIR /home/frontend/
|
|
|
|
COPY ./src/frontend/package.json ./package.json
|
|
COPY ./src/frontend/yarn.lock ./yarn.lock
|
|
COPY ./src/frontend/servers/y-provider/package.json ./servers/y-provider/package.json
|
|
COPY ./src/frontend/packages/eslint-plugin-docs/package.json ./packages/eslint-plugin-docs/package.json
|
|
|
|
RUN yarn install
|
|
|
|
COPY ./src/frontend/packages/eslint-plugin-docs ./packages/eslint-plugin-docs
|
|
COPY ./src/frontend/servers/y-provider ./servers/y-provider
|
|
|
|
FROM y-provider-deps AS y-provider-development
|
|
|
|
WORKDIR /home/frontend/servers/y-provider
|
|
|
|
EXPOSE 4444
|
|
|
|
CMD [ "yarn", "dev"]
|
|
|
|
FROM y-provider-deps AS y-provider-builder
|
|
|
|
WORKDIR /home/frontend/servers/y-provider
|
|
RUN yarn build
|
|
|
|
FROM base AS y-provider
|
|
|
|
WORKDIR /home/frontend/
|
|
|
|
COPY ./src/frontend/package.json ./package.json
|
|
COPY ./src/frontend/yarn.lock ./yarn.lock
|
|
COPY ./src/frontend/servers/y-provider/package.json ./servers/y-provider/package.json
|
|
|
|
WORKDIR /home/frontend/servers/y-provider
|
|
|
|
COPY --from=y-provider-builder \
|
|
/home/frontend/servers/y-provider/dist \
|
|
./dist
|
|
|
|
RUN NODE_ENV=production yarn install --frozen-lockfile
|
|
|
|
# Remove npm, contains CVE related to cross-spawn and we don't use it.
|
|
RUN rm -rf /usr/local/bin/npm /usr/local/lib/node_modules/npm
|
|
|
|
# Un-privileged user running the application
|
|
ARG DOCKER_USER
|
|
USER ${DOCKER_USER}
|
|
|
|
# Copy entrypoint
|
|
COPY ./docker/files/usr/local/bin/entrypoint /usr/local/bin/entrypoint
|
|
ENTRYPOINT [ "/usr/local/bin/entrypoint" ]
|
|
|
|
CMD ["yarn", "start"]
|