Fix `run` subcommand

This commit is contained in:
3wc 2020-10-28 02:48:04 +02:00
parent 841e4fc61a
commit 6e38dc35e5
1 changed files with 30 additions and 19 deletions

49
abra
View File

@ -609,6 +609,7 @@ sub_app_secret_auto(){
###### .. app <domain> run <args>...
sub_app_run(){
load_instance
load_instance_env
if [ -n "$abra___user" ]; then
RUN_USER="-u $abra___user"
@ -618,7 +619,7 @@ sub_app_run(){
| grep "${STACK_NAME}_${abra__app_}" | head -n1 | cut -d',' -f1)
if [ -z "$CONTAINER" ]; then
error "Can't find a container for ${STACK_NAME}_${abra__app_}"
error "Can't find a container for ${STACK_NAME}_${abra__service_}"
exit
fi
@ -681,7 +682,8 @@ sub_app_logs (){
###### .. app <domain> cp <src> <dst>
sub_app_cp() {
require_stack
load_instance
load_instance_env
SOURCE="${abra__src_}"
DEST="${abra__dst_}"
@ -714,6 +716,19 @@ sub_app_cp() {
# abra server ..
#######################################
###### .. server ls
sub_server_ls() {
sub_server_list
}
sub_server_list() {
get_servers
printf "%s servers:\n\n" "${#SERVERS[@]}"
for SERVER in "${SERVERS[@]}"; do
echo " ${SERVER##*/}"
done
}
###### .. server init <host>
sub_server_init() {
export DOCKER_CONTEXT="${abra__host_}"
@ -724,6 +739,7 @@ sub_server_init() {
docker network create --driver=overlay proxy --scope swarm || true
}
###### .. server <add> <host> [<username>] [<password>]
sub_server_add() {
require_abra_dir
@ -746,43 +762,35 @@ sub_server_add() {
mkdir -p "$ABRA_DIR/servers/$HOST"
}
###### .. server <host> delete
sub_server_rm() {
sub_server_delete
}
sub_server_delete() {
docker context rm "$abra__host_"
}
###### .. server <host> use
sub_server_use() {
docker context use "$abra__host_"
}
sub_server_ls() {
sub_server_list
}
sub_server_list() {
get_servers
printf "%s server(s):\n\n" "${#SERVERS[@]}"
for SERVER in "${SERVERS[@]}"; do
echo " ${SERVER##*/}"
done
}
#######################################
# Misc commands
#######################################
###### Subcommand `upgrade`
###### .. upgrade
sub_upgrade() {
curl https://install.abra.autonomic.zone | bash
}
###### Docker alias subcommands
###### .. volume <args>...
sub_stack() {
# shellcheck disable=SC2068
docker stack $@
}
###### .. stack <args>...
sub_volume() {
# shellcheck disable=SC2068
docker volume $@
@ -803,8 +811,10 @@ abra() {
DOCOPT_PREFIX=abra_
eval "$(docopt "$@")"
# --stack <stack>
STACK_NAME=$abra___stack
# --env <env>
if [ -n "$abra___env" ]; then
# shellcheck disable=SC1090
source "$abra___env" || error "Unable to load env from '$abra___env'"
@ -817,6 +827,7 @@ abra() {
for SUBCOMMAND in $(declare -Ff | grep 'sub_' | cut -d' ' -f3 | sort -r); do
IFS='_' read -r -a PARTS <<< "$SUBCOMMAND"
for PART in "${PARTS[@]:1}"; do
# TODO 3wc: probably a better way to check if a function is defined..
VAR=$(eval "echo \$abra_$PART")
if [ ! "$VAR" == "true" ]; then
continue 2
@ -825,7 +836,7 @@ abra() {
abra__command_=$(IFS="_"; echo "${PARTS[*]:1}")
done
# Fallback for non-docopt-defined options
# Use abra__command_ in case `command` is provided (i.e. `volume` or `stack`)
CMD="sub_${abra__command_}"
if type "$CMD" > /dev/null 2>&1; then
# shellcheck disable=SC2086