You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
96 lines
2.6 KiB
96 lines
2.6 KiB
FROM alpine:3.16 |
|
|
|
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 ffmpeg exiftool \ |
|
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
|
|
|