# node-livereload server supporting SSL/TLS # allow dynamic building by specifying base image elements as build-args ARG NODE_VERSION=16 ARG ALPINE_VERSION=3.15 FROM node:${NODE_VERSION}-alpine${ALPINE_VERSION} as builder ARG NODE_VERSION ARG ALPINE_VERSION # install node dependences WORKDIR /build COPY [ "package.json", "package-lock.json", "./" ] RUN npm ci --production # final container FROM alpine:${ALPINE_VERSION} as final ARG NODE_VERSION ARG ALPINE_VERSION # create new node user with set UID and GID from build-args and create volume directories ARG NODE_UID=9999 ARG NODE_GID=9999 RUN addgroup -g ${NODE_GID} -S node \ && adduser -G node -S -u ${NODE_UID} node \ && mkdir /watch /watch2 /watch3 /watch4 /watch5 /certs \ && chown root:node /certs \ && chmod 770 /certs # create default volumes in case user forgets, expose default port VOLUME [ "/watch", "/certs" ] EXPOSE 35729 # add tini, timezone support, nodejs and create certificate directories RUN apk --update --no-cache add \ tini \ tzdata \ openssl \ nodejs~${NODE_VERSION} \ && apk --update --no-cache upgrade # labels MAINTAINER Asif Bacchus LABEL maintainer="Asif Bacchus " LABEL dev.asifbacchus.docker.internalName="ab-livereload" LABEL org.opencontainers.image.authors="Asif Bacchus " LABEL org.opencontainers.image.description="Dockerized node-livereload supporting TLS and running under limited user account. Environment variables allow specifying files to watch/exclude and notification delay." LABEL org.opencontainers.image.documentation="https://git.asifbacchus.dev/ab-docker/ab-livereload/raw/branch/main/README.md" LABEL org.opencontainers.image.source="https://git.asifbacchus.dev/ab-docker/ab-livereload.git" LABEL org.opencontainers.image.title="ab-livereload" LABEL org.opencontainers.image.url="https://git.asifbacchus.dev/ab-docker/ab-livereload" LABEL org.opencontainers.image.vendor="Asif Bacchus " # default environment variables ENV NODE_ENV=production ENV TZ="Etc/UTC" ENV LR_PORT=35729 ENV LR_EXTS="html,xml,css,js,jsx,ts,tsx,php,py" ENV LR_EXCLUDE=".vscode/,.idea/,.tmp$,.swp$" ENV LR_DELAY=500 ENV LR_DEBUG=true ENV LR_HTTPS=true ENV CERT_HOSTNAME="" # set-up application and copy dependencies from builder WORKDIR /home/node COPY [ "selfsigned.cnf", "/etc/selfsigned.cnf" ] COPY [ "entrypoint.sh", "/usr/local/bin/entrypoint.sh" ] COPY --chown=node:node [ "ab-livereload.js", "/home/node/"] COPY --from=builder [ "/build/node_modules", "/home/node/node_modules" ] RUN chown -R node:node /home/node/* \ && chmod 644 /home/node/ab-livereload.js \ && chmod 755 /usr/local/bin/entrypoint.sh \ && chmod 644 /etc/selfsigned.cnf HEALTHCHECK \ --interval=10s \ --timeout=5s \ --start-period=60s \ --retries=3 \ CMD wget --spider -T 3 -q localhost:3000/api/v1/health || exit 1 # switch to node user, run entrypoint script by default USER node WORKDIR /home/node ENTRYPOINT [ "/sbin/tini", "-e", "143", "--", "/usr/local/bin/entrypoint.sh" ] # set build timestamp and version labels ARG INTERNAL_VERSION ARG GIT_COMMIT ARG BUILD_DATE LABEL org.opencontainers.image.version="NODE=${NODE_VERSION}, node-livereload=0.9.3" LABEL dev.asifbacchus.docker.internalVersion=${INTERNAL_VERSION} LABEL org.opencontainers.image.revision=${GIT_COMMIT} LABEL org.opencontainers.image.created=${BUILD_DATE} #EOF