summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorAlejandro Colomar <alx@kernel.org>2024-02-09 12:51:28 +0100
committerAlejandro Colomar <alx@kernel.org>2024-02-20 16:04:24 +0100
commitd6ed000316b4226ad73333ba294ac63096665a02 (patch)
tree30998992454a0b48331dd394956519b71ef5a68a
parentcca2c46e4995497c091073d51d7148eac5cf140a (diff)
downloadunit-d6ed000316b4226ad73333ba294ac63096665a02.tar.gz
unit-d6ed000316b4226ad73333ba294ac63096665a02.tar.bz2
Tools: setup-unit: De-duplicate code
Centralize handling of the ssh(1) tunnel in the ctl command. This is possible now that we do the cleanup with trap(1). Reviewed-by: Andrew Clayton <a.clayton@nginx.com> Signed-off-by: Alejandro Colomar <alx@kernel.org>
Diffstat (limited to '')
-rwxr-xr-xtools/setup-unit100
1 files changed, 22 insertions, 78 deletions
diff --git a/tools/setup-unit b/tools/setup-unit
index 5b5b3ccc..8466e882 100755
--- a/tools/setup-unit
+++ b/tools/setup-unit
@@ -315,25 +315,44 @@ unit_ctl()
if echo $sock | grep '^ssh://' >/dev/null; then
local remote="$(echo $sock | sed 's,\(ssh://[^/]*\).*,\1,')";
local sock="$(echo $sock | sed 's,ssh://[^/]*\(.*\),unix:\1,')";
+
+ local remote_sock="$(echo "$sock" | unit_sock_filter -s)";
+ local local_sock="$(mktemp -u -p /var/run/unit/)";
+ local ssh_ctrl="$(mktemp -u -p /var/run/unit/)";
+
+ mkdir -p /var/run/unit/;
+
+ ssh -fMNnT -S "$ssh_ctrl" \
+ -o 'ExitOnForwardFailure yes' \
+ -L "$local_sock:$remote_sock" "$remote";
+
+ trap "ssh -S '$ssh_ctrl' -O exit '$remote' 2>/dev/null;
+ unlink '$local_sock';" EXIT;
+
+ sock="unix:$local_sock";
fi;
case $1 in
edit)
shift;
- unit_ctl_edit ${remote:+ ---r $remote} ---s "$sock" $@;
+ unit_ctl_edit ---s "$sock" $@;
;;
http)
shift;
- unit_ctl_http ${remote:+ ---r $remote} ---s "$sock" $@;
+ unit_ctl_http ---s "$sock" $@;
;;
insert)
shift;
- unit_ctl_insert ${remote:+ ---r $remote} ---s "$sock" $@;
+ unit_ctl_insert ---s "$sock" $@;
;;
*)
err "ctl: $1: Unknown argument.";
;;
esac;
+
+ if test -v remote; then
+ run_trap EXIT;
+ fi;
}
@@ -378,10 +397,6 @@ unit_ctl_edit()
help_unit_ctl_edit;
exit 0;
;;
- ---r | ----remote)
- local remote="$2";
- shift;
- ;;
---s | ----sock)
local sock="$2";
shift;
@@ -401,23 +416,6 @@ unit_ctl_edit()
fi;
local req_path="$1";
- if test -v remote; then
- local remote_sock="$(echo "$sock" | unit_sock_filter -s)";
- local local_sock="$(mktemp -u -p /var/run/unit/)";
- local ssh_ctrl="$(mktemp -u -p /var/run/unit/)";
-
- mkdir -p /var/run/unit/;
-
- ssh -fMNnT -S "$ssh_ctrl" \
- -o 'ExitOnForwardFailure yes' \
- -L "$local_sock:$remote_sock" "$remote";
-
- trap "ssh -S '$ssh_ctrl' -O exit '$remote' 2>/dev/null;
- unlink '$local_sock'" EXIT;
-
- sock="unix:$local_sock";
- fi;
-
local tmp="$(mktemp)";
unit_ctl_http ---s "$sock" -c --no-progress-meter GET "$req_path" \
@@ -433,10 +431,6 @@ unit_ctl_edit()
) "$tmp";
unit_ctl_http ---s "$sock" PUT "$req_path" <"$tmp";
-
- if test -v remote; then
- run_trap EXIT;
- fi;
}
@@ -492,10 +486,6 @@ unit_ctl_http()
help_unit_ctl_http;
exit 0;
;;
- ---r | ----remote)
- local remote="$2";
- shift;
- ;;
---s | ----sock)
local sock="$2";
shift;
@@ -520,29 +510,8 @@ unit_ctl_http()
fi;
local req_path="$2";
- if test -v remote; then
- local remote_sock="$(echo "$sock" | unit_sock_filter -s)";
- local local_sock="$(mktemp -u -p /var/run/unit/)";
- local ssh_ctrl="$(mktemp -u -p /var/run/unit/)";
-
- mkdir -p /var/run/unit/;
-
- ssh -fMNnT -S "$ssh_ctrl" \
- -o 'ExitOnForwardFailure yes' \
- -L "$local_sock:$remote_sock" "$remote";
-
- trap "ssh -S '$ssh_ctrl' -O exit '$remote' 2>/dev/null;
- unlink '$local_sock'" EXIT;
-
- sock="unix:$local_sock";
- fi;
-
curl $curl_options -X $method -d@- \
$(echo "$sock" | unit_sock_filter -c)${req_path};
-
- if test -v remote; then
- run_trap EXIT;
- fi;
}
@@ -577,10 +546,6 @@ unit_ctl_insert()
help_unit_ctl_insert;
exit 0;
;;
- ---r | ----remote)
- local remote="$2";
- shift;
- ;;
---s | ----sock)
local sock="$2";
shift;
@@ -605,23 +570,6 @@ unit_ctl_insert()
fi;
local idx="$2";
- if test -v remote; then
- local remote_sock="$(echo "$sock" | unit_sock_filter -s)";
- local local_sock="$(mktemp -u -p /var/run/unit/)";
- local ssh_ctrl="$(mktemp -u -p /var/run/unit/)";
-
- mkdir -p /var/run/unit/;
-
- ssh -fMNnT -S "$ssh_ctrl" \
- -o 'ExitOnForwardFailure yes' \
- -L "$local_sock:$remote_sock" "$remote";
-
- trap "ssh -S '$ssh_ctrl' -O exit '$remote' 2>/dev/null;
- unlink '$local_sock'" EXIT;
-
- sock="unix:$local_sock";
- fi;
-
local old="$(mktemp)";
unit_ctl_http ---s "$sock" -c --no-progress-meter GET "$req_path" \
@@ -629,10 +577,6 @@ unit_ctl_insert()
unit_json_ins "$old" "$idx" \
| unit_ctl_http ---s "$sock" PUT "$req_path";
-
- if test -v remote; then
- run_trap EXIT;
- fi;
}