diff options
| author | pleroma <pleroma@plato.logografos.com> | 2023-09-02 23:39:40 -0700 |
|---|---|---|
| committer | pleroma <pleroma@plato.logografos.com> | 2023-09-02 23:39:40 -0700 |
| commit | 240237fa3b91176b6798b5348411bcbebc6f4f10 (patch) | |
| tree | 676d35290b3f7460e99d6e84076c73d3d602e519 /Dockerfile | |
| parent | f448602f012f0151aeaa46aa4aeaec891123528d (diff) | |
| download | anni-240237fa3b91176b6798b5348411bcbebc6f4f10.tar.gz anni-240237fa3b91176b6798b5348411bcbebc6f4f10.tar.bz2 anni-240237fa3b91176b6798b5348411bcbebc6f4f10.zip | |
rebaseded
Diffstat (limited to 'Dockerfile')
| -rw-r--r-- | Dockerfile | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..8c3ff3a --- /dev/null +++ b/Dockerfile @@ -0,0 +1,56 @@ +ARG ELIXIR_VER=1.11.4 +ARG ERLANG_VER=24.2.1 +ARG ALPINE_VER=3.17.0 + +FROM hexpm/elixir:${ELIXIR_VER}-erlang-${ERLANG_VER}-alpine-${ALPINE_VER} as build + +COPY . . + +ENV MIX_ENV=prod + +RUN apk add git gcc g++ musl-dev make cmake file-dev &&\ + echo "import Config" > config/prod.secret.exs &&\ + mix local.hex --force &&\ + mix local.rebar --force &&\ + mix deps.get --only prod &&\ + mkdir release &&\ + mix release --path release + +FROM alpine:${ALPINE_VER} + +ARG BUILD_DATE +ARG VCS_REF + +LABEL maintainer="ops@pleroma.social" \ + org.opencontainers.image.title="pleroma" \ + org.opencontainers.image.description="Pleroma for Docker" \ + org.opencontainers.image.authors="ops@pleroma.social" \ + org.opencontainers.image.vendor="pleroma.social" \ + org.opencontainers.image.documentation="https://git.pleroma.social/pleroma/pleroma" \ + org.opencontainers.image.licenses="AGPL-3.0" \ + org.opencontainers.image.url="https://pleroma.social" \ + org.opencontainers.image.revision=$VCS_REF \ + org.opencontainers.image.created=$BUILD_DATE + +ARG HOME=/opt/pleroma +ARG DATA=/var/lib/pleroma + +RUN apk update &&\ + apk add exiftool ffmpeg imagemagick libmagic ncurses postgresql-client &&\ + adduser --system --shell /bin/false --home ${HOME} pleroma &&\ + mkdir -p ${DATA}/uploads &&\ + mkdir -p ${DATA}/static &&\ + chown -R pleroma ${DATA} &&\ + mkdir -p /etc/pleroma &&\ + chown -R pleroma /etc/pleroma + +USER pleroma + +COPY --from=build --chown=pleroma:0 /release ${HOME} + +COPY ./config/docker.exs /etc/pleroma/config.exs +COPY ./docker-entrypoint.sh ${HOME} + +EXPOSE 4000 + +ENTRYPOINT ["/opt/pleroma/docker-entrypoint.sh"] |
