Move info and list commands into shared functions
Also add better output formatting for both commands
This commit is contained in:
16
commands
16
commands
@@ -192,23 +192,11 @@ case "$1" in
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
$PLUGIN_COMMAND_PREFIX:info)
|
$PLUGIN_COMMAND_PREFIX:info)
|
||||||
[[ -z $2 ]] && dokku_log_fail "Please specify a name for the service"
|
service_info $2
|
||||||
verify_service_name "$2"
|
|
||||||
SERVICE="$2"; SERVICE_URL=$(service_url "$SERVICE")
|
|
||||||
|
|
||||||
echo " DSN: $SERVICE_URL"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
$PLUGIN_COMMAND_PREFIX:list)
|
$PLUGIN_COMMAND_PREFIX:list)
|
||||||
CONTAINERS=$(ls $PLUGIN_DATA_ROOT 2> /dev/null)
|
service_list
|
||||||
if [[ -z $CONTAINERS ]]; then
|
|
||||||
echo "There are no $PLUGIN_SERVICE services"
|
|
||||||
else
|
|
||||||
echo "$PLUGIN_SERVICE services:"
|
|
||||||
for CONTAINER in $CONTAINERS; do
|
|
||||||
echo " - $CONTAINER"
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
$PLUGIN_COMMAND_PREFIX:clone)
|
$PLUGIN_COMMAND_PREFIX:clone)
|
||||||
|
|||||||
47
functions
47
functions
@@ -40,6 +40,41 @@ service_alias() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
service_info() {
|
||||||
|
[[ -z $1 ]] && dokku_log_fail "Please specify a name for the service"
|
||||||
|
verify_service_name "$1"
|
||||||
|
|
||||||
|
local SERVICE="$1";
|
||||||
|
local SERVICE_URL=$(service_url "$SERVICE")
|
||||||
|
|
||||||
|
echo " DSN: $SERVICE_URL"
|
||||||
|
}
|
||||||
|
|
||||||
|
service_list() {
|
||||||
|
local SERVICES=$(ls $PLUGIN_DATA_ROOT 2> /dev/null)
|
||||||
|
if [[ -z $SERVICES ]]; then
|
||||||
|
dokku_log_warn "There are no $PLUGIN_SERVICE services"
|
||||||
|
else
|
||||||
|
dokku_log_info1_quiet "$PLUGIN_SERVICE services:"
|
||||||
|
for SERVICE in $SERVICES; do
|
||||||
|
dokku_log_verbose "$SERVICE $(service_status $SERVICE)"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
service_status() {
|
||||||
|
local SERVICE="$1";
|
||||||
|
local SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"
|
||||||
|
local ID="$(cat "$SERVICE_ROOT/ID")"
|
||||||
|
|
||||||
|
is_container_status "$ID" "Dead" && echo "(dead)" && return 0
|
||||||
|
is_container_status "$ID" "OOMKilled" && echo "(oomkilled)" && return 0
|
||||||
|
is_container_status "$ID" "Paused" && echo "(paused)" && return 0
|
||||||
|
is_container_status "$ID" "Restarting" && echo "(restarting)" && return 0
|
||||||
|
is_container_status "$ID" "Running" && echo "(running)" && return 0
|
||||||
|
echo "(stopped)" && return 0
|
||||||
|
}
|
||||||
|
|
||||||
service_url() {
|
service_url() {
|
||||||
local SERVICE="$1";
|
local SERVICE="$1";
|
||||||
local SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"
|
local SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"
|
||||||
@@ -49,3 +84,15 @@ service_url() {
|
|||||||
local PASSWORD="$(cat "$SERVICE_ROOT/PASSWORD")"
|
local PASSWORD="$(cat "$SERVICE_ROOT/PASSWORD")"
|
||||||
echo "$PLUGIN_SCHEME://mysql:$PASSWORD@$IP:$PLUGIN_DATASTORE_PORT/$SERVICE"
|
echo "$PLUGIN_SCHEME://mysql:$PASSWORD@$IP:$PLUGIN_DATASTORE_PORT/$SERVICE"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
is_container_status () {
|
||||||
|
local CID=$1
|
||||||
|
local TEMPLATE="{{.State.$2}}"
|
||||||
|
local CONTAINER_STATUS=$(docker inspect -f "$TEMPLATE" "$CID" || true)
|
||||||
|
|
||||||
|
if [[ "$CONTAINER_STATUS" == "true" ]]; then
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user