114 lines
4.3 KiB
Docker
114 lines
4.3 KiB
Docker
# syntax=docker/dockerfile:1.8
|
|
|
|
# Please see https://docs.docker.com/engine/reference/builder for information about
|
|
# the extended buildx capabilities used in this file.
|
|
# Make sure multiarch TARGETPLATFORM is available for interpolation
|
|
# See: https://docs.docker.com/build/building/multi-platform/
|
|
ARG TARGETPLATFORM=${TARGETPLATFORM}
|
|
ARG BUILDPLATFORM=${BUILDPLATFORM}
|
|
|
|
# Node version to use in base image, change with [--build-arg NODE_MAJOR_VERSION="20"]
|
|
# renovate: datasource=node-version depName=node
|
|
ARG NODE_MAJOR_VERSION="20"
|
|
# Debian image to use for base image, change with [--build-arg DEBIAN_VERSION="bookworm"]
|
|
ARG DEBIAN_VERSION="bookworm"
|
|
# Node image to use for base image based on combined variables (ex: 20-bookworm-slim)
|
|
FROM docker.io/node:${NODE_MAJOR_VERSION}-${DEBIAN_VERSION}-slim AS streaming
|
|
|
|
# Resulting version string is vX.X.X-MASTODON_VERSION_PRERELEASE+MASTODON_VERSION_METADATA
|
|
# Example: v4.3.0-nightly.2023.11.09+pr-123456
|
|
# Overwrite existence of 'alpha.X' in version.rb [--build-arg MASTODON_VERSION_PRERELEASE="nightly.2023.11.09"]
|
|
ARG MASTODON_VERSION_PRERELEASE=""
|
|
# Append build metadata or fork information to version.rb [--build-arg MASTODON_VERSION_METADATA="pr-123456"]
|
|
ARG MASTODON_VERSION_METADATA=""
|
|
|
|
# Timezone used by the Docker container and runtime, change with [--build-arg TZ=Europe/Berlin]
|
|
ARG TZ="Etc/UTC"
|
|
# Linux UID (user id) for the mastodon user, change with [--build-arg UID=1234]
|
|
ARG UID="991"
|
|
# Linux GID (group id) for the mastodon user, change with [--build-arg GID=1234]
|
|
ARG GID="991"
|
|
|
|
# Apply Mastodon build options based on options above
|
|
ENV \
|
|
# Apply Mastodon version information
|
|
MASTODON_VERSION_PRERELEASE="${MASTODON_VERSION_PRERELEASE}" \
|
|
MASTODON_VERSION_METADATA="${MASTODON_VERSION_METADATA}" \
|
|
# Apply timezone
|
|
TZ=${TZ}
|
|
|
|
ENV \
|
|
# Configure the IP to bind Mastodon to when serving traffic
|
|
BIND="0.0.0.0" \
|
|
# Explicitly set PORT to match the exposed port
|
|
PORT=4000 \
|
|
# Use production settings for Yarn, Node and related nodejs based tools
|
|
NODE_ENV="production" \
|
|
# Add Ruby and Mastodon installation to the PATH
|
|
DEBIAN_FRONTEND="noninteractive"
|
|
|
|
# Set default shell used for running commands
|
|
SHELL ["/bin/bash", "-o", "pipefail", "-o", "errexit", "-c"]
|
|
|
|
ARG TARGETPLATFORM
|
|
|
|
RUN echo "Target platform is ${TARGETPLATFORM}"
|
|
|
|
RUN \
|
|
# Remove automatic apt cache Docker cleanup scripts
|
|
rm -f /etc/apt/apt.conf.d/docker-clean; \
|
|
# Sets timezone
|
|
echo "${TZ}" > /etc/localtime; \
|
|
# Creates mastodon user/group and sets home directory
|
|
groupadd -g "${GID}" mastodon; \
|
|
useradd -l -u "${UID}" -g "${GID}" -m -d /opt/mastodon mastodon; \
|
|
# Creates symlink for /mastodon folder
|
|
ln -s /opt/mastodon /mastodon;
|
|
|
|
# hadolint ignore=DL3008,DL3005
|
|
RUN \
|
|
# Mount Apt cache and lib directories from Docker buildx caches
|
|
--mount=type=cache,id=apt-cache-${TARGETPLATFORM},target=/var/cache/apt,sharing=locked \
|
|
--mount=type=cache,id=apt-lib-${TARGETPLATFORM},target=/var/lib/apt,sharing=locked \
|
|
# Upgrade to check for security updates to Debian image
|
|
apt-get update; \
|
|
apt-get dist-upgrade -yq; \
|
|
apt-get install -y --no-install-recommends \
|
|
ca-certificates \
|
|
curl \
|
|
tzdata \
|
|
wget \
|
|
;
|
|
|
|
# Set /opt/mastodon as working directory
|
|
WORKDIR /opt/mastodon
|
|
|
|
# Copy Node package configuration files from build system to container
|
|
COPY package.json yarn.lock .yarnrc.yml /opt/mastodon/
|
|
COPY .yarn /opt/mastodon/.yarn
|
|
# Copy Streaming source code from build system to container
|
|
COPY ./streaming /opt/mastodon/streaming
|
|
|
|
RUN \
|
|
# Mount local Corepack and Yarn caches from Docker buildx caches
|
|
--mount=type=cache,id=corepack-cache-${TARGETPLATFORM},target=/usr/local/share/.cache/corepack,sharing=locked \
|
|
--mount=type=cache,id=yarn-cache-${TARGETPLATFORM},target=/usr/local/share/.cache/yarn,sharing=locked \
|
|
# Configure Corepack
|
|
rm /usr/local/bin/yarn*; \
|
|
corepack enable; \
|
|
corepack prepare --activate;
|
|
|
|
RUN \
|
|
# Mount Corepack and Yarn caches from Docker buildx caches
|
|
--mount=type=cache,id=corepack-cache-${TARGETPLATFORM},target=/usr/local/share/.cache/corepack,sharing=locked \
|
|
--mount=type=cache,id=yarn-cache-${TARGETPLATFORM},target=/usr/local/share/.cache/yarn,sharing=locked \
|
|
# Install Node packages
|
|
yarn workspaces focus --production @mastodon/streaming;
|
|
|
|
# Set the running user for resulting container
|
|
USER mastodon
|
|
# Expose default Streaming ports
|
|
EXPOSE 4000
|
|
# Run streaming when started
|
|
CMD [ "node", "./streaming/index.js" ]
|