Dockerfile 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. # syntax=docker.io/docker/dockerfile:1.3@sha256:42399d4635eddd7a9b8a24be879d2f9a930d0ed040a61324cfdf59ef1357b3b2
  2. FROM node:lts-alpine@sha256:2ae9624a39ce437e7f58931a5747fdc60224c6e40f8980db90728de58e22af7c
  3. # npm wants to clone random Git repositories - lovely.
  4. RUN apk add git python make build-base
  5. # Run as user, otherwise, npx explodes.
  6. USER 1000
  7. RUN mkdir -p /home/node/app
  8. RUN mkdir -p /home/node/.npm
  9. WORKDIR /home/node/app
  10. # Fix git ssh error
  11. RUN git config --global url."https://".insteadOf ssh://
  12. # Support additional root CAs
  13. COPY README.md cert.pem* /certs/
  14. # Node
  15. ENV NODE_EXTRA_CA_CERTS=/certs/cert.pem
  16. ENV NODE_OPTIONS=--use-openssl-ca
  17. # npm
  18. RUN if [ -e /certs/cert.pem ]; then npm config set cafile /certs/cert.pem; fi
  19. # git
  20. RUN if [ -e /certs/cert.pem ]; then git config --global http.sslCAInfo /certs/cert.pem; fi
  21. # Only invalidate the npm install step if package.json changed
  22. COPY --chown=node:node package.json .
  23. COPY --chown=node:node package-lock.json .
  24. COPY --chown=node:node .env.test .env
  25. # We want to cache node_modules *and* incorporate it into the final image.
  26. RUN --mount=type=cache,uid=1000,gid=1000,target=/home/node/.npm \
  27. --mount=type=cache,uid=1000,gid=1000,target=node_modules \
  28. npm ci && \
  29. cp -r node_modules node_modules_cache
  30. # Amusingly, Debian's coreutils version has a bug where mv believes that
  31. # the target is on a different fs and does a full recursive copy for what
  32. # could be a renameat syscall. Alpine does not have this bug.
  33. RUN rm -rf node_modules && mv node_modules_cache node_modules
  34. COPY --chown=node:node . .