From fdf0c89532a8c3dd9aef0a14bc98b83b78f48ff3 Mon Sep 17 00:00:00 2001 From: Jose Diaz-Gonzalez Date: Sun, 15 May 2016 22:47:15 -0400 Subject: [PATCH] Move all commands into subcommand structure --- commands | 216 ++++++++++--------------------------------- subcommands/clone | 19 ++++ subcommands/connect | 17 ++++ subcommands/create | 30 ++++++ subcommands/destroy | 47 ++++++++++ subcommands/export | 21 +++++ subcommands/expose | 13 +++ subcommands/import | 21 +++++ subcommands/info | 13 +++ subcommands/link | 15 +++ subcommands/list | 11 +++ subcommands/logs | 13 +++ subcommands/promote | 15 +++ subcommands/restart | 15 +++ subcommands/start | 13 +++ subcommands/stop | 13 +++ subcommands/unexpose | 13 +++ subcommands/unlink | 15 +++ 18 files changed, 354 insertions(+), 166 deletions(-) create mode 100755 subcommands/clone create mode 100755 subcommands/connect create mode 100755 subcommands/create create mode 100755 subcommands/destroy create mode 100755 subcommands/export create mode 100755 subcommands/expose create mode 100755 subcommands/import create mode 100755 subcommands/info create mode 100755 subcommands/link create mode 100755 subcommands/list create mode 100755 subcommands/logs create mode 100755 subcommands/promote create mode 100755 subcommands/restart create mode 100755 subcommands/start create mode 100755 subcommands/stop create mode 100755 subcommands/unexpose create mode 100755 subcommands/unlink diff --git a/commands b/commands index c25673a..7b04ab7 100755 --- a/commands +++ b/commands @@ -15,191 +15,75 @@ if [[ -d "$PLUGIN_DATA_ROOT/*" ]]; then fi case "$1" in - $PLUGIN_COMMAND_PREFIX:create) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - [[ ! -d "$PLUGIN_DATA_ROOT/$2" ]] || dokku_log_fail "$PLUGIN_SERVICE service $2 already exists" - SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"; LINKS_FILE="$SERVICE_ROOT/LINKS" - - if ! docker images | grep -e "^$PLUGIN_IMAGE " | grep -q " $PLUGIN_IMAGE_VERSION " ; then - docker pull "$PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION" || dokku_log_fail "$PLUGIN_SERVICE image $PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION pull failed" - fi - - mkdir -p "$SERVICE_ROOT" || dokku_log_fail "Unable to create service directory" - mkdir -p "$SERVICE_ROOT/data" || dokku_log_fail "Unable to create service data directory" - mkdir -p "$SERVICE_ROOT/config" || dokku_log_fail "Unable to create service config directory" - curl "https://raw.githubusercontent.com/antirez/redis/${REDIS_IMAGE_VERSION:0:3}/redis.conf" > "$SERVICE_ROOT/config/redis.conf" || dokku_log_fail "Unable to download the default redis.conf to the config directory" - touch "$LINKS_FILE" - - if [[ -n $REDIS_CUSTOM_ENV ]]; then - echo "$REDIS_CUSTOM_ENV" | tr ';' "\n" > "$SERVICE_ROOT/ENV" - else - echo "" > "$SERVICE_ROOT/ENV" - fi - service_create_container "$SERVICE" - ;; - - $PLUGIN_COMMAND_PREFIX:destroy) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"; LINKS_FILE="$SERVICE_ROOT/LINKS" - SERVICE_NAME="$(get_service_name "$SERVICE")" - - [[ -s "$LINKS_FILE" ]] && dokku_log_fail "Cannot delete linked service" - - [[ "$3" == "force" ]] && DOKKU_APPS_FORCE_DELETE=1 - if [[ -z "$DOKKU_APPS_FORCE_DELETE" ]]; then - dokku_log_warn "WARNING: Potentially Destructive Action" - dokku_log_warn "This command will destroy $SERVICE $PLUGIN_SERVICE service." - dokku_log_warn "To proceed, type \"$SERVICE\"" - echo "" - - read -rp "> " service_name - if [[ "$service_name" != "$SERVICE" ]]; then - dokku_log_warn "Confirmation did not match $SERVICE. Aborted." - exit 1 - fi - fi - - dokku_log_info1 "Deleting $SERVICE" - if [[ -n $(docker ps -aq -f name="$SERVICE_NAME") ]]; then - service_stop "$SERVICE" - - dokku_log_verbose_quiet "Removing container" - docker rm -v "$SERVICE_NAME" > /dev/null - sleep 1 - else - dokku_log_verbose_quiet "No container exists for $SERVICE" - fi - - dokku_log_verbose_quiet "Removing data" - docker run --rm -v "$SERVICE_ROOT/data:/data" "$PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION" chmod 777 -R /data - rm -rf "$SERVICE_ROOT" - - dokku_log_info2 "$PLUGIN_SERVICE container deleted: $SERVICE" - ;; - - $PLUGIN_COMMAND_PREFIX:link) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - [[ -z $3 ]] && dokku_log_fail "Please specify an app to run the command on" - verify_app_name "$3" - verify_service_name "$2" - service_link "$2" "$3" - ;; - - $PLUGIN_COMMAND_PREFIX:unlink) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - [[ -z $3 ]] && dokku_log_fail "Please specify an app to run the command on" - verify_app_name "$3" - verify_service_name "$2" - service_unlink "$2" "$3" - ;; - - $PLUGIN_COMMAND_PREFIX:export) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE" - SERVICE_NAME="$(get_service_name "$SERVICE")" - - [[ -n $SSH_TTY ]] && stty -opost - docker exec "$SERVICE_NAME" bash -c "echo SAVE | redis-cli" > /dev/null 2>&1 - docker exec "$SERVICE_NAME" cat /data/dump.rdb - status=$? - [[ -n $SSH_TTY ]] && stty opost - exit $status - ;; - - $PLUGIN_COMMAND_PREFIX:import) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE" - SERVICE_NAME="$(get_service_name "$SERVICE")" - - if [[ -t 0 ]]; then - dokku_log_fail "No data provided on stdin." - fi - dokku "$PLUGIN_COMMAND_PREFIX:stop" "$SERVICE" > /dev/null 2>&1 - docker run --rm -i -v "$SERVICE_ROOT/data:/data" "$PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION" bash -c "cat > /data/dump.rdb && chown redis: /data/dump.rdb" - dokku "$PLUGIN_COMMAND_PREFIX:start" "$SERVICE" > /dev/null 2>&1 - ;; - - $PLUGIN_COMMAND_PREFIX:logs) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_logs "$2" "$3" - ;; - - $PLUGIN_COMMAND_PREFIX:start) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_start "$2" - ;; - - $PLUGIN_COMMAND_PREFIX:stop) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_stop "$2" - ;; - - $PLUGIN_COMMAND_PREFIX:restart) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_stop "$2" - service_start "$2" - dokku_log_info1 "Please call dokku ps:restart on all linked apps" + $PLUGIN_COMMAND_PREFIX:clone) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/clone" "$@" ;; $PLUGIN_COMMAND_PREFIX:connect) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE" - SERVICE_NAME="$(get_service_name "$SERVICE")" - has_tty && SERVICE_TTY_OPTS="-t" - - docker exec -i $SERVICE_TTY_OPTS "$SERVICE_NAME" redis-cli + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/connect" "$@" ;; - $PLUGIN_COMMAND_PREFIX:info) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_info "$2" + $PLUGIN_COMMAND_PREFIX:create) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/create" "$@" ;; - $PLUGIN_COMMAND_PREFIX:list) - service_list + $PLUGIN_COMMAND_PREFIX:destroy) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/destroy" "$@" ;; - $PLUGIN_COMMAND_PREFIX:clone) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - [[ -z $3 ]] && dokku_log_fail "Please specify a name for the new service" - verify_service_name "$2" - SERVICE="$2" - NEW_SERVICE="$3" - dokku "$PLUGIN_COMMAND_PREFIX:create" "$NEW_SERVICE" - dokku_log_info1 "Copying data from $SERVICE to $NEW_SERVICE" - dokku "$PLUGIN_COMMAND_PREFIX:export" "$SERVICE" | dokku "$PLUGIN_COMMAND_PREFIX:import" "$NEW_SERVICE" > /dev/null 2>&1 || true - dokku_log_info1 "Done" + $PLUGIN_COMMAND_PREFIX:export) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/export" "$@" ;; $PLUGIN_COMMAND_PREFIX:expose) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_port_expose "$2" "${@:3}" + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/expose" "$@" ;; - $PLUGIN_COMMAND_PREFIX:unexpose) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - verify_service_name "$2" - service_port_unexpose "$2" + $PLUGIN_COMMAND_PREFIX:import) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/import" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:info) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/info" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:link) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/link" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:list) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/list" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:logs) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/logs" "$@" ;; $PLUGIN_COMMAND_PREFIX:promote) - [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" - [[ -z $3 ]] && dokku_log_fail "Please specify an app to run the command on" - verify_service_name "$2" - verify_app_name "$3" - promote "$2" "$3" + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/promote" "$@" ;; + $PLUGIN_COMMAND_PREFIX:restart) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/restart" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:start) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/start" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:stop) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/stop" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:unexpose) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/unexpose" "$@" + ;; + + $PLUGIN_COMMAND_PREFIX:unlink) + "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)/subcommands/unlink" "$@" + ;; + + help | $PLUGIN_COMMAND_PREFIX:help) help_content_func() { # shellcheck disable=SC2034 diff --git a/subcommands/clone b/subcommands/clone new file mode 100755 index 0000000..202b306 --- /dev/null +++ b/subcommands/clone @@ -0,0 +1,19 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-clone-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + [[ -z $3 ]] && dokku_log_fail "Please specify a name for the new service" + verify_service_name "$2" + SERVICE="$2" + NEW_SERVICE="$3" + dokku "$PLUGIN_COMMAND_PREFIX:create" "$NEW_SERVICE" + dokku_log_info1 "Copying data from $SERVICE to $NEW_SERVICE" + dokku "$PLUGIN_COMMAND_PREFIX:export" "$SERVICE" | dokku "$PLUGIN_COMMAND_PREFIX:import" "$NEW_SERVICE" > /dev/null 2>&1 || true + dokku_log_info1 "Done" +} + +redis-clone-cmd "$@" diff --git a/subcommands/connect b/subcommands/connect new file mode 100755 index 0000000..871c468 --- /dev/null +++ b/subcommands/connect @@ -0,0 +1,17 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-connect-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE" + SERVICE_NAME="$(get_service_name "$SERVICE")" + has_tty && SERVICE_TTY_OPTS="-t" + + docker exec -i $SERVICE_TTY_OPTS "$SERVICE_NAME" redis-cli +} + +redis-connect-cmd "$@" diff --git a/subcommands/create b/subcommands/create new file mode 100755 index 0000000..7843c3e --- /dev/null +++ b/subcommands/create @@ -0,0 +1,30 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-create-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + [[ ! -d "$PLUGIN_DATA_ROOT/$2" ]] || dokku_log_fail "$PLUGIN_SERVICE service $2 already exists" + SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"; LINKS_FILE="$SERVICE_ROOT/LINKS" + + if ! docker images | grep -e "^$PLUGIN_IMAGE " | grep -q " $PLUGIN_IMAGE_VERSION " ; then + docker pull "$PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION" || dokku_log_fail "$PLUGIN_SERVICE image $PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION pull failed" + fi + + mkdir -p "$SERVICE_ROOT" || dokku_log_fail "Unable to create service directory" + mkdir -p "$SERVICE_ROOT/data" || dokku_log_fail "Unable to create service data directory" + mkdir -p "$SERVICE_ROOT/config" || dokku_log_fail "Unable to create service config directory" + curl "https://raw.githubusercontent.com/antirez/redis/${REDIS_IMAGE_VERSION:0:3}/redis.conf" > "$SERVICE_ROOT/config/redis.conf" || dokku_log_fail "Unable to download the default redis.conf to the config directory" + touch "$LINKS_FILE" + + if [[ -n $REDIS_CUSTOM_ENV ]]; then + echo "$REDIS_CUSTOM_ENV" | tr ';' "\n" > "$SERVICE_ROOT/ENV" + else + echo "" > "$SERVICE_ROOT/ENV" + fi + service_create_container "$SERVICE" +} + +redis-create-cmd "$@" diff --git a/subcommands/destroy b/subcommands/destroy new file mode 100755 index 0000000..0478a48 --- /dev/null +++ b/subcommands/destroy @@ -0,0 +1,47 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-destroy-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE"; LINKS_FILE="$SERVICE_ROOT/LINKS" + SERVICE_NAME="$(get_service_name "$SERVICE")" + + [[ -s "$LINKS_FILE" ]] && dokku_log_fail "Cannot delete linked service" + + [[ "$3" == "force" ]] && DOKKU_APPS_FORCE_DELETE=1 + if [[ -z "$DOKKU_APPS_FORCE_DELETE" ]]; then + dokku_log_warn "WARNING: Potentially Destructive Action" + dokku_log_warn "This command will destroy $SERVICE $PLUGIN_SERVICE service." + dokku_log_warn "To proceed, type \"$SERVICE\"" + echo "" + + read -rp "> " service_name + if [[ "$service_name" != "$SERVICE" ]]; then + dokku_log_warn "Confirmation did not match $SERVICE. Aborted." + exit 1 + fi + fi + + dokku_log_info1 "Deleting $SERVICE" + if [[ -n $(docker ps -aq -f name="$SERVICE_NAME") ]]; then + service_stop "$SERVICE" + + dokku_log_verbose_quiet "Removing container" + docker rm -v "$SERVICE_NAME" > /dev/null + sleep 1 + else + dokku_log_verbose_quiet "No container exists for $SERVICE" + fi + + dokku_log_verbose_quiet "Removing data" + docker run --rm -v "$SERVICE_ROOT/data:/data" "$PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION" chmod 777 -R /data + rm -rf "$SERVICE_ROOT" + + dokku_log_info2 "$PLUGIN_SERVICE container deleted: $SERVICE" +} + +redis-destroy-cmd "$@" diff --git a/subcommands/export b/subcommands/export new file mode 100755 index 0000000..62419de --- /dev/null +++ b/subcommands/export @@ -0,0 +1,21 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-export-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE" + SERVICE_NAME="$(get_service_name "$SERVICE")" + + [[ -n $SSH_TTY ]] && stty -opost + docker exec "$SERVICE_NAME" bash -c "echo SAVE | redis-cli" > /dev/null 2>&1 + docker exec "$SERVICE_NAME" cat /data/dump.rdb + status=$? + [[ -n $SSH_TTY ]] && stty opost + exit $status +} + +redis-export-cmd "$@" diff --git a/subcommands/expose b/subcommands/expose new file mode 100755 index 0000000..51779f4 --- /dev/null +++ b/subcommands/expose @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-expose-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_port_expose "$2" "${@:3}" +} + +redis-expose-cmd "$@" diff --git a/subcommands/import b/subcommands/import new file mode 100755 index 0000000..5c9c940 --- /dev/null +++ b/subcommands/import @@ -0,0 +1,21 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-import-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + SERVICE="$2"; SERVICE_ROOT="$PLUGIN_DATA_ROOT/$SERVICE" + SERVICE_NAME="$(get_service_name "$SERVICE")" + + if [[ -t 0 ]]; then + dokku_log_fail "No data provided on stdin." + fi + dokku "$PLUGIN_COMMAND_PREFIX:stop" "$SERVICE" > /dev/null 2>&1 + docker run --rm -i -v "$SERVICE_ROOT/data:/data" "$PLUGIN_IMAGE:$PLUGIN_IMAGE_VERSION" bash -c "cat > /data/dump.rdb && chown redis: /data/dump.rdb" + dokku "$PLUGIN_COMMAND_PREFIX:start" "$SERVICE" > /dev/null 2>&1 +} + +redis-import-cmd "$@" diff --git a/subcommands/info b/subcommands/info new file mode 100755 index 0000000..e5809ff --- /dev/null +++ b/subcommands/info @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-info-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_info "$2" +} + +redis-info-cmd "$@" diff --git a/subcommands/link b/subcommands/link new file mode 100755 index 0000000..e0c2ba8 --- /dev/null +++ b/subcommands/link @@ -0,0 +1,15 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-link-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + [[ -z $3 ]] && dokku_log_fail "Please specify an app to run the command on" + verify_app_name "$3" + verify_service_name "$2" + service_link "$2" "$3" +} + +redis-link-cmd "$@" diff --git a/subcommands/list b/subcommands/list new file mode 100755 index 0000000..66369cd --- /dev/null +++ b/subcommands/list @@ -0,0 +1,11 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-list-cmd() { + service_list +} + +redis-list-cmd "$@" diff --git a/subcommands/logs b/subcommands/logs new file mode 100755 index 0000000..be8911d --- /dev/null +++ b/subcommands/logs @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-logs-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_logs "$2" "$3" +} + +redis-logs-cmd "$@" diff --git a/subcommands/promote b/subcommands/promote new file mode 100755 index 0000000..d4cae71 --- /dev/null +++ b/subcommands/promote @@ -0,0 +1,15 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-promote-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + [[ -z $3 ]] && dokku_log_fail "Please specify an app to run the command on" + verify_service_name "$2" + verify_app_name "$3" + promote "$2" "$3" +} + +redis-promote-cmd "$@" diff --git a/subcommands/restart b/subcommands/restart new file mode 100755 index 0000000..db69baa --- /dev/null +++ b/subcommands/restart @@ -0,0 +1,15 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-restart-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_stop "$2" + service_start "$2" + dokku_log_info1 "Please call dokku ps:restart on all linked apps" +} + +redis-restart-cmd "$@" diff --git a/subcommands/start b/subcommands/start new file mode 100755 index 0000000..803472b --- /dev/null +++ b/subcommands/start @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-start-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_start "$2" +} + +redis-start-cmd "$@" diff --git a/subcommands/stop b/subcommands/stop new file mode 100755 index 0000000..9261754 --- /dev/null +++ b/subcommands/stop @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-stop-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_stop "$2" +} + +redis-stop-cmd "$@" diff --git a/subcommands/unexpose b/subcommands/unexpose new file mode 100755 index 0000000..91a5c4e --- /dev/null +++ b/subcommands/unexpose @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-unexpose-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + verify_service_name "$2" + service_port_unexpose "$2" +} + +redis-unexpose-cmd "$@" diff --git a/subcommands/unlink b/subcommands/unlink new file mode 100755 index 0000000..fa46e98 --- /dev/null +++ b/subcommands/unlink @@ -0,0 +1,15 @@ +#!/usr/bin/env bash +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/config" +set -eo pipefail; [[ $DOKKU_TRACE ]] && set -x +source "$PLUGIN_BASE_PATH/common/functions" +source "$(dirname "$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)")/functions" + +redis-unlink-cmd() { + [[ -z $2 ]] && dokku_log_fail "Please specify a name for the service" + [[ -z $3 ]] && dokku_log_fail "Please specify an app to run the command on" + verify_app_name "$3" + verify_service_name "$2" + service_unlink "$2" "$3" +} + +redis-unlink-cmd "$@"