Introduce the mobilizon_ctl wrapper to easily call tasks inside releases
Signed-off-by: Thomas Citharel <tcit@tcit.fr>
This commit is contained in:
parent
d1dece23a8
commit
6da7d1c922
@ -5,7 +5,7 @@ RUN apk add --no-cache python build-base
|
|||||||
|
|
||||||
COPY js .
|
COPY js .
|
||||||
RUN yarn install \
|
RUN yarn install \
|
||||||
&& yarn run build
|
&& yarn run build
|
||||||
|
|
||||||
# Then, build the application binary
|
# Then, build the application binary
|
||||||
FROM elixir:alpine AS builder
|
FROM elixir:alpine AS builder
|
||||||
@ -15,8 +15,8 @@ RUN apk add --no-cache build-base git cmake
|
|||||||
COPY mix.exs mix.lock ./
|
COPY mix.exs mix.lock ./
|
||||||
ENV MIX_ENV=prod
|
ENV MIX_ENV=prod
|
||||||
RUN mix local.hex --force \
|
RUN mix local.hex --force \
|
||||||
&& mix local.rebar --force \
|
&& mix local.rebar --force \
|
||||||
&& mix deps.get
|
&& mix deps.get
|
||||||
|
|
||||||
COPY lib ./lib
|
COPY lib ./lib
|
||||||
COPY priv ./priv
|
COPY priv ./priv
|
||||||
@ -25,7 +25,7 @@ COPY docker/production/releases.exs ./config/
|
|||||||
COPY --from=assets ./priv/static ./priv/static
|
COPY --from=assets ./priv/static ./priv/static
|
||||||
|
|
||||||
RUN mix phx.digest \
|
RUN mix phx.digest \
|
||||||
&& mix release
|
&& mix release
|
||||||
|
|
||||||
# Finally setup the app
|
# Finally setup the app
|
||||||
FROM alpine
|
FROM alpine
|
||||||
@ -36,6 +36,6 @@ USER nobody
|
|||||||
EXPOSE 4000
|
EXPOSE 4000
|
||||||
|
|
||||||
COPY --from=builder --chown=nobody:nobody _build/prod/rel/mobilizon ./
|
COPY --from=builder --chown=nobody:nobody _build/prod/rel/mobilizon ./
|
||||||
|
COPY docker/production/docker-entrypoint.sh ./
|
||||||
|
|
||||||
ENTRYPOINT ["/bin/mobilizon"]
|
ENTRYPOINT ["./docker-entrypoint.sh"]
|
||||||
CMD ["start"]
|
|
||||||
|
@ -25,7 +25,7 @@ services:
|
|||||||
volumes:
|
volumes:
|
||||||
- ./public/uploads:/app/uploads
|
- ./public/uploads:/app/uploads
|
||||||
ports:
|
ports:
|
||||||
- "4000:4000"
|
- "4000:4000"
|
||||||
|
|
||||||
db:
|
db:
|
||||||
image: postgis/postgis
|
image: postgis/postgis
|
||||||
|
9
docker/production/docker-entrypoint.sh
Executable file
9
docker/production/docker-entrypoint.sh
Executable file
@ -0,0 +1,9 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
echo "-- Running migrations..."
|
||||||
|
/bin/mobilizon_ctl migrate
|
||||||
|
|
||||||
|
echo "-- Starting!"
|
||||||
|
exec /bin/mobilizon start
|
41
rel/overlays/bin/mobilizon_ctl
Executable file
41
rel/overlays/bin/mobilizon_ctl
Executable file
@ -0,0 +1,41 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Portions of this file are derived from Pleroma:
|
||||||
|
# Pleroma: A lightweight social networking server
|
||||||
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
||||||
|
# SPDX-License-Identifier: AGPL-3.0-only
|
||||||
|
|
||||||
|
if [ -z "$1" ] || [ "$1" = "help" ]; then
|
||||||
|
echo "Usage: $(basename "$0") COMMAND [ARGS]
|
||||||
|
|
||||||
|
The known commands are:
|
||||||
|
|
||||||
|
migrate
|
||||||
|
Execute database migrations (needs to be done after updates)
|
||||||
|
|
||||||
|
rollback [VERSION]
|
||||||
|
Rollback database migrations (needs to be done before downgrading)
|
||||||
|
|
||||||
|
and any mix tasks under Mobilizon namespace, for example \`mix mobilizon.user.show COMMAND\` is
|
||||||
|
equivalent to \`$(basename "$0") user.show COMMAND\`
|
||||||
|
|
||||||
|
By default mobilizon_ctl will try calling into a running instance to execute non migration-related commands,
|
||||||
|
if for some reason this is undesired, set MOBILIZON_CTL_RPC_DISABLED environment variable.
|
||||||
|
|
||||||
|
"
|
||||||
|
else
|
||||||
|
SCRIPT=$(readlink -f "$0")
|
||||||
|
SCRIPTPATH=$(dirname "$SCRIPT")
|
||||||
|
|
||||||
|
FULL_ARGS="$*"
|
||||||
|
|
||||||
|
ACTION="$1"
|
||||||
|
if [ $# -gt 0 ]; then
|
||||||
|
shift
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$ACTION" = "migrate" ] || [ "$ACTION" = "rollback" ] || [ "$ACTION" = "create" ] || [ "$MOBILIZON_CTL_RPC_DISABLED" = true ]; then
|
||||||
|
"$SCRIPTPATH"/mobilizon eval 'Mobilizon.CLI.run("'"$FULL_ARGS"'")'
|
||||||
|
else
|
||||||
|
"$SCRIPTPATH"/mobilizon rpc 'Mobilizon.CLI.run("'"$FULL_ARGS"'")'
|
||||||
|
fi
|
||||||
|
fi
|
Loading…
Reference in New Issue
Block a user