summaryrefslogtreecommitdiff
path: root/Dockerfile
diff options
context:
space:
mode:
authorlain <lain@soykaf.club>2019-08-08 16:04:20 +0200
committerlain <lain@soykaf.club>2019-08-08 16:04:20 +0200
commita2b98f6d58218c5806247743aa0a2a600c9959ab (patch)
tree49914ac1e30561e1180651ad6b0fef5d96ecfb5c /Dockerfile
parente4a01d253ef7ab09d028198e5e39b9aba357486c (diff)
parentb18234e04c76daa564e0d8157dcd09566485da24 (diff)
downloadpleroma-a2b98f6d58218c5806247743aa0a2a600c9959ab.tar.gz
pleroma-a2b98f6d58218c5806247743aa0a2a600c9959ab.zip
Merge remote-tracking branch 'origin/develop' into pleroma-conversations
Diffstat (limited to 'Dockerfile')
-rw-r--r--Dockerfile39
1 files changed, 39 insertions, 0 deletions
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 000000000..268ec61dc
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,39 @@
+FROM rinpatch/elixir:1.9.0-rc.0-alpine as build
+
+COPY . .
+
+ENV MIX_ENV=prod
+
+RUN apk add git gcc g++ musl-dev make &&\
+ echo "import Mix.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:latest
+
+ARG HOME=/opt/pleroma
+ARG DATA=/var/lib/pleroma
+
+RUN echo "http://nl.alpinelinux.org/alpine/latest-stable/community" >> /etc/apk/repositories &&\
+ apk update &&\
+ apk add 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"]