2018-08-01 02:00:32 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
source "$PLUGIN_CORE_AVAILABLE_PATH/common/functions"
|
|
|
|
|
source "$PLUGIN_CORE_AVAILABLE_PATH/common/property-functions"
|
2018-12-04 16:13:47 -05:00
|
|
|
source "$PLUGIN_AVAILABLE_PATH/config/functions"
|
2019-01-07 01:04:17 -05:00
|
|
|
set -eo pipefail
|
|
|
|
|
[[ $DOKKU_TRACE ]] && set -x
|
2018-08-01 02:00:32 -04:00
|
|
|
|
|
|
|
|
cmd-scheduler-docker-local-report() {
|
|
|
|
|
declare desc="displays a scheduler-docker-local report for one or more apps"
|
|
|
|
|
local cmd="scheduler-docker-local:report"
|
|
|
|
|
local INSTALLED_APPS=$(dokku_apps)
|
|
|
|
|
local APP="$2" INFO_FLAG="$3"
|
|
|
|
|
|
|
|
|
|
if [[ -n "$APP" ]] && [[ "$APP" == --* ]]; then
|
|
|
|
|
INFO_FLAG="$APP"
|
|
|
|
|
APP=""
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [[ -z "$APP" ]] && [[ -z "$INFO_FLAG" ]]; then
|
|
|
|
|
INFO_FLAG="true"
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [[ -z "$APP" ]]; then
|
|
|
|
|
for app in $INSTALLED_APPS; do
|
|
|
|
|
cmd-scheduler-docker-local-report-single "$app" "$INFO_FLAG" | tee || true
|
|
|
|
|
done
|
|
|
|
|
else
|
|
|
|
|
cmd-scheduler-docker-local-report-single "$APP" "$INFO_FLAG"
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cmd-scheduler-docker-local-report-single() {
|
|
|
|
|
declare APP="$1" INFO_FLAG="$2"
|
|
|
|
|
if [[ "$INFO_FLAG" == "true" ]]; then
|
|
|
|
|
INFO_FLAG=""
|
|
|
|
|
fi
|
|
|
|
|
verify_app_name "$APP"
|
|
|
|
|
local flag_map=(
|
|
|
|
|
"--scheduler-docker-local-disable-chown: $(fn-plugin-property-get "scheduler-docker-local" "$APP" "disable-chown" "")"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
if [[ -z "$INFO_FLAG" ]]; then
|
|
|
|
|
dokku_log_info2_quiet "${APP} scheduler-docker-local information"
|
|
|
|
|
for flag in "${flag_map[@]}"; do
|
|
|
|
|
key="$(echo "${flag#--}" | cut -f1 -d' ' | tr - ' ')"
|
|
|
|
|
dokku_log_verbose "$(printf "%-30s %-25s" "${key^}" "${flag#*: }")"
|
|
|
|
|
done
|
|
|
|
|
else
|
2019-01-07 01:04:17 -05:00
|
|
|
local match=false
|
|
|
|
|
local value_exists=false
|
2018-08-01 02:00:32 -04:00
|
|
|
for flag in "${flag_map[@]}"; do
|
|
|
|
|
valid_flags="${valid_flags} $(echo "$flag" | cut -d':' -f1)"
|
|
|
|
|
if [[ "$flag" == "${INFO_FLAG}:"* ]]; then
|
|
|
|
|
value=${flag#*: }
|
|
|
|
|
size="${#value}"
|
|
|
|
|
if [[ "$size" -ne 0 ]]; then
|
|
|
|
|
echo "$value" && match=true && value_exists=true
|
|
|
|
|
else
|
|
|
|
|
match=true
|
|
|
|
|
fi
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
[[ "$match" == "true" ]] || dokku_log_fail "Invalid flag passed, valid flags:${valid_flags}"
|
|
|
|
|
[[ "$value_exists" == "true" ]] || dokku_log_fail "not deployed"
|
|
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
scheduler_docker_local_help_content_func() {
|
|
|
|
|
declare desc="return scheduler-docker-local plugin help content"
|
2019-01-07 01:04:17 -05:00
|
|
|
cat <<help_content
|
2018-08-01 02:00:32 -04:00
|
|
|
scheduler-docker-local:report [<app>] [<flag>], Displays a scheduler-docker-local report for one or more apps
|
|
|
|
|
scheduler-docker-local:set <app> <property> (<value>), Set or clear a scheduler-docker-local property for an app
|
|
|
|
|
help_content
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cmd-scheduler-docker-local-help() {
|
2019-01-07 01:04:17 -05:00
|
|
|
if [[ $1 == "scheduler-docker-local:help" ]]; then
|
2018-08-01 02:00:32 -04:00
|
|
|
echo -e 'Usage: dokku scheduler-docker-local[:COMMAND]'
|
|
|
|
|
echo ''
|
|
|
|
|
echo 'Manages the scheduler-docker-local integration for an app.'
|
|
|
|
|
echo ''
|
|
|
|
|
echo 'Additional commands:'
|
|
|
|
|
scheduler_docker_local_help_content_func | sort | column -c2 -t -s,
|
|
|
|
|
echo ''
|
|
|
|
|
elif [[ $(ps -o command= $PPID) == *"--all"* ]]; then
|
|
|
|
|
scheduler_docker_local_help_content_func
|
|
|
|
|
else
|
2019-01-07 01:04:17 -05:00
|
|
|
cat <<help_desc
|
2018-08-01 02:00:32 -04:00
|
|
|
scheduler-docker-local, Manages the scheduler-docker-local integration for an app
|
|
|
|
|
help_desc
|
|
|
|
|
fi
|
|
|
|
|
}
|
2018-07-20 10:37:58 -04:00
|
|
|
|
|
|
|
|
fn-scheduler-docker-local-retire-container() {
|
|
|
|
|
declare APP="$1" CID="$2" DEAD_TIME="$3"
|
2019-01-11 11:08:59 -05:00
|
|
|
local STATE
|
2018-07-20 10:37:58 -04:00
|
|
|
|
2019-05-29 00:08:02 -04:00
|
|
|
STATE="$("$DOCKER_BIN" inspect -f "{{ .State.Status }}" "$CID" 2>/dev/null || true)"
|
2019-01-11 11:08:59 -05:00
|
|
|
if [[ -z "$STATE" ]]; then
|
2018-07-20 10:37:58 -04:00
|
|
|
return
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
DOKKU_DOCKER_STOP_TIMEOUT="$(config_get "$APP" DOKKU_DOCKER_STOP_TIMEOUT || true)"
|
|
|
|
|
[[ $DOKKU_DOCKER_STOP_TIMEOUT ]] && DOCKER_STOP_TIME_ARG="--time=${DOKKU_DOCKER_STOP_TIMEOUT}"
|
|
|
|
|
|
2019-01-11 11:08:59 -05:00
|
|
|
if [[ "$STATE" == "restarting" ]]; then
|
2019-05-29 00:08:02 -04:00
|
|
|
"$DOCKER_BIN" update --restart=no "$CID" >/dev/null 2>&1
|
2019-01-11 11:08:59 -05:00
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [[ "$STATE" != "dead" ]] && [[ "$STATE" != "exited" ]]; then
|
|
|
|
|
# Attempt to stop, if that fails, then force a kill as docker seems
|
|
|
|
|
# to not send SIGKILL as the docs would indicate. If that fails, move
|
|
|
|
|
# on to the next.
|
|
|
|
|
# shellcheck disable=SC2086
|
2019-05-29 00:08:02 -04:00
|
|
|
"$DOCKER_BIN" stop $DOCKER_STOP_TIME_ARG "$CID" \
|
|
|
|
|
|| "$DOCKER_BIN" kill "$CID" \
|
2019-01-11 11:08:59 -05:00
|
|
|
|| dokku_log_warn "Unable to kill container ${CID}"
|
|
|
|
|
fi
|
|
|
|
|
|
2019-05-29 00:08:02 -04:00
|
|
|
STATE="$("$DOCKER_BIN" inspect -f "{{ .State.Status }}" "$CID" 2>/dev/null || true)"
|
2019-01-11 11:08:59 -05:00
|
|
|
if [[ -z "$STATE" ]]; then
|
|
|
|
|
return
|
|
|
|
|
fi
|
2018-07-20 10:37:58 -04:00
|
|
|
|
2019-01-11 11:08:59 -05:00
|
|
|
if [[ "$STATE" != "dead" ]] && [[ "$STATE" != "exited" ]]; then
|
2019-05-29 00:08:02 -04:00
|
|
|
if ! "$DOCKER_BIN" kill "$CID"; then
|
2019-01-11 11:08:59 -05:00
|
|
|
dokku_log_warn "Unable to kill container ${CID}"
|
|
|
|
|
fi
|
2018-07-20 10:37:58 -04:00
|
|
|
fi
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn-scheduler-docker-local-register-retired-container() {
|
|
|
|
|
declare APP="$1" CID="$2" WAIT="$3"
|
2018-07-20 14:29:00 -04:00
|
|
|
local DEAD_CONTAINER_FILE="${DOKKU_LIB_ROOT}/data/scheduler-docker-local/dead-containers"
|
2018-07-20 10:37:58 -04:00
|
|
|
local CURRENT_TIME DEAD_TIME
|
|
|
|
|
|
|
|
|
|
CURRENT_TIME="$(date +%s)"
|
2018-07-20 13:08:15 -04:00
|
|
|
DEAD_TIME=$((CURRENT_TIME + WAIT))
|
2019-01-07 01:04:17 -05:00
|
|
|
echo "${APP} ${CID} ${DEAD_TIME}" >>"${DEAD_CONTAINER_FILE}"
|
2018-07-20 10:37:58 -04:00
|
|
|
}
|