FROM node:10-buster ARG UID ENV UID=${UID:-9999} ARG GID ENV GID=${GID:-9999} # Perform all OS package installation and cleanup in one single command to reduce the # size of the created layer. RUN apt-get update && \ apt-get install -y --no-install-recommends \ build-essential \ curl \ gnupg2 \ dos2unix \ tini \ && apt-get autoclean \ && apt-get clean \ && apt-get autoremove \ && rm -rf /var/lib/apt/lists/* # The node image already creates a non-root user to run as, update its ids so they # match the provided UID and GID we wish to build and run this image with. # If GID or UID already exist that's OK no need to stop the build. RUN groupmod -g ${GID} node || exit 0 RUN usermod -u ${UID} -g ${GID} node || exit 0 USER $UID:$GID # Create and install the dependencies in separate COPY commands COPY --chown=$UID:$GID ./web-frontend/package.json ./web-frontend/yarn.lock /baserow/web-frontend/ WORKDIR /baserow/web-frontend # We still need dev-dependencies as we will be running a nuxt build below RUN yarn install COPY --chown=$UID:$GID ./web-frontend /baserow/web-frontend/ COPY --chown=$UID:$GID ./premium/web-frontend /baserow/web-frontend/plugins/premium RUN yarn run build-local RUN dos2unix /baserow/web-frontend/docker/docker-entrypoint.sh && \ chmod a+x /baserow/web-frontend/docker/docker-entrypoint.sh # tini installed above protects us from zombie processes and ensures the default signal # handlers work, see https://github.com/krallin/tini. ENTRYPOINT ["/usr/bin/tini", "--", "/bin/bash", "/baserow/web-frontend/docker/docker-entrypoint.sh"] CMD ["local"]