# Etherpad Lite Dockerfile # # https://github.com/ether/etherpad-lite # # Author: muxator FROM node:14-buster-slim LABEL maintainer="Etherpad team, https://github.com/ether/etherpad-lite" # plugins to install while building the container. By default no plugins are # installed. # If given a value, it has to be a space-separated, quoted list of plugin names. # # EXAMPLE: # ETHERPAD_PLUGINS="ep_codepad ep_author_neat" ARG ETHERPAD_PLUGINS= # Control whether abiword will be installed, enabling exports to DOC/PDF/ODT formats. # By default, it is not installed. # If given any value, abiword will be installed. # # EXAMPLE: # INSTALL_ABIWORD=true ARG INSTALL_ABIWORD= # Control whether libreoffice will be installed, enabling exports to DOC/PDF/ODT formats. # By default, it is not installed. # If given any value, libreoffice will be installed. # # EXAMPLE: # INSTALL_LIBREOFFICE=true ARG INSTALL_SOFFICE= # By default, Etherpad container is built and run in "production" mode. This is # leaner (development dependencies are not installed) and runs faster (among # other things, assets are minified & compressed). ENV NODE_ENV=production # Follow the principle of least privilege: run as unprivileged user. # # Running as non-root enables running this image in platforms like OpenShift # that do not allow images running as root. # # If any of the following args are set to the empty string, default # values will be chosen. ARG EP_HOME= ARG EP_UID=5001 ARG EP_GID=0 ARG EP_SHELL= RUN groupadd --system ${EP_GID:+--gid "${EP_GID}" --non-unique} etherpad && \ useradd --system ${EP_UID:+--uid "${EP_UID}" --non-unique} --gid etherpad \ ${EP_HOME:+--home-dir "${EP_HOME}"} --create-home \ ${EP_SHELL:+--shell "${EP_SHELL}"} etherpad ARG EP_DIR=/opt/etherpad-lite RUN mkdir -p "${EP_DIR}" && chown etherpad:etherpad "${EP_DIR}" # install abiword for DOC/PDF/ODT export RUN [ -z "${INSTALL_ABIWORD}" ] || (apt update && apt -y install abiword && apt clean && rm -rf /var/lib/apt/lists/*) # install libreoffice for DOC/PDF/ODT export # the mkdir is needed for configuration of openjdk-11-jre-headless, see https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=863199 RUN [ -z "${INSTALL_SOFFICE}" ] || (apt update && mkdir -p /usr/share/man/man1 && apt -y install libreoffice && apt clean && rm -rf /var/lib/apt/lists/*) USER etherpad WORKDIR "${EP_DIR}" COPY --chown=etherpad:etherpad ./ ./ # Plugins must be installed before installing Etherpad's dependencies, otherwise # npm will try to hoist common dependencies by removing them from # src/node_modules and installing them in the top-level node_modules. As of # v6.14.10, npm's hoist logic appears to be buggy, because it sometimes removes # dependencies from src/node_modules but fails to add them to the top-level # node_modules. Even if npm correctly hoists the dependencies, the hoisting # seems to confuse tools such as `npm outdated`, `npm update`, and some ESLint # rules. RUN { [ -z "${ETHERPAD_PLUGINS}" ] || \ npm install --no-save ${ETHERPAD_PLUGINS}; } && \ src/bin/installDeps.sh && \ rm -rf ~/.npm # Copy the configuration file. COPY --chown=etherpad:etherpad ./settings.json.docker "${EP_DIR}"/settings.json # Fix group permissions RUN chmod -R g=u . EXPOSE 9001 CMD ["node", "src/node/server.js"]