97 lines
2.6 KiB
Docker
97 lines
2.6 KiB
Docker
FROM alpine:3.12
|
|
|
|
ARG __VIA_SCRIPT
|
|
RUN \
|
|
if [ -z "$__VIA_SCRIPT" ]; then \
|
|
echo -e "\n\nERROR\nYou must build pleroma via build.sh\n\n"; \
|
|
exit 1; \
|
|
fi
|
|
|
|
# Set up environment
|
|
ENV LC_ALL=C.UTF-8
|
|
ENV LANG=C.UTF-8
|
|
ARG MIX_ENV
|
|
ENV MIX_ENV=$MIX_ENV
|
|
|
|
# Prepare mounts
|
|
VOLUME /custom.d /uploads
|
|
|
|
# Expose HTTP, Gopher, and SSH ports, respectively
|
|
EXPOSE 4000 9999 2222
|
|
|
|
# Get dependencies
|
|
RUN \
|
|
apk add --no-cache --virtual .tools \
|
|
git curl rsync postgresql-client \
|
|
&& \
|
|
apk add --no-cache --virtual .sdk \
|
|
build-base cmake file-dev \
|
|
&& \
|
|
apk add --no-cache --virtual .runtime \
|
|
imagemagick \
|
|
elixir erlang erlang-dev
|
|
|
|
# Add entrypoint
|
|
COPY ./entrypoint.sh /
|
|
RUN chmod a+x /entrypoint.sh
|
|
ENTRYPOINT ["/entrypoint.sh"]
|
|
|
|
# Limit permissions
|
|
ARG DOCKER_UID
|
|
ARG DOCKER_GID
|
|
RUN \
|
|
echo "#> Pleroma user will be ${DOCKER_UID}:${DOCKER_GID}" 1>&2 && \
|
|
addgroup -g ${DOCKER_GID} pleroma && \
|
|
adduser -S -s /bin/ash -G pleroma -u ${DOCKER_UID} pleroma && \
|
|
mkdir -p /custom.d /uploads && \
|
|
chown -R pleroma:pleroma /custom.d /uploads
|
|
|
|
USER pleroma
|
|
WORKDIR /home/pleroma
|
|
|
|
# Get pleroma sources
|
|
#
|
|
# Also make sure that instance/static/emoji exists.
|
|
# Pleroma does not ship with an `instance` folder by default, causing docker to create `instance/static` for us at launch.
|
|
# In itself that wouldn't be much of an issue, but said folder(s) are created as root:pleroma with 2755.
|
|
# This breaks the custom.d step in entrypoint.sh which relies on writing there (See #10).
|
|
#
|
|
ARG PLEROMA_GIT_REPO
|
|
RUN \
|
|
echo "#> Getting pleroma sources from $PLEROMA_GIT_REPO..." 1>&2 && \
|
|
git clone --progress $PLEROMA_GIT_REPO ./pleroma && \
|
|
mkdir -p ./pleroma/instance/static/emoji
|
|
|
|
WORKDIR /home/pleroma/pleroma
|
|
|
|
# Bust the build cache (if needed)
|
|
# This works by setting an environment variable with the last
|
|
# used version/branch/tag/commit/... which originates in the script.
|
|
ARG __CACHE_TAG
|
|
ENV __CACHE_TAG $__CACHE_TAG
|
|
|
|
# Fetch changes, checkout
|
|
# Only pull if the version-string happens to be a branch
|
|
ARG PLEROMA_VERSION
|
|
RUN \
|
|
git fetch --all && \
|
|
git checkout $PLEROMA_VERSION && \
|
|
if git show-ref --quiet "refs/heads/$PLEROMA_VERSION"; then \
|
|
git pull --rebase --autostash; \
|
|
fi
|
|
|
|
# Precompile
|
|
RUN \
|
|
cp ./config/dev.exs ./config/prod.secret.exs && \
|
|
BUILDTIME=1 /entrypoint.sh && \
|
|
rm ./config/prod.secret.exs
|
|
|
|
# Register healthcheck
|
|
# You might need to change these values on slow or busy servers.
|
|
HEALTHCHECK \
|
|
--interval=10s \
|
|
--start-period=50s \
|
|
--timeout=4s \
|
|
--retries=3 \
|
|
CMD curl -sSLf http://localhost:4000/api/pleroma/healthcheck || exit 1
|