mirror of
https://github.com/DictXiong/dotfiles.git
synced 2024-11-24 14:47:02 +08:00
Compare commits
2 Commits
37abe68d1f
...
4e5dfce9fb
Author | SHA1 | Date | |
---|---|---|---|
|
4e5dfce9fb | ||
|
c5841e4aaa |
22
scripts/riot
22
scripts/riot
|
@ -91,8 +91,9 @@ get_server_meta() {
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
parse_remote() {
|
||||||
# remote setting, including jump servers
|
# remote setting, including jump servers
|
||||||
# will be called only once
|
# called for every remote
|
||||||
# provides:
|
# provides:
|
||||||
SERVER=""
|
SERVER=""
|
||||||
TRUST_SERVER=1
|
TRUST_SERVER=1
|
||||||
|
@ -102,13 +103,13 @@ SSH_OPTIONS="" # optional
|
||||||
if [[ "$RIOT_TRUST_CLIENT" == "1" ]]; then
|
if [[ "$RIOT_TRUST_CLIENT" == "1" ]]; then
|
||||||
SSH_OPTIONS='-o ControlMaster=auto -o ControlPath=/tmp/sshcm-%C -o PermitLocalCommand=yes'
|
SSH_OPTIONS='-o ControlMaster=auto -o ControlPath=/tmp/sshcm-%C -o PermitLocalCommand=yes'
|
||||||
fi
|
fi
|
||||||
parse_remote() {
|
# handle input
|
||||||
local remote="$1"
|
local remote="$1"
|
||||||
local jump_servers=""
|
local jump_servers=""
|
||||||
# loop for jump servers
|
# loop for jump servers
|
||||||
while [[ -n $remote ]]; do
|
while [[ -n $remote ]]; do
|
||||||
local server=${remote%%,*}
|
local server=${remote%%/*}
|
||||||
remote=${remote#*,}
|
remote=${remote#*/}
|
||||||
get_server_meta "$server"
|
get_server_meta "$server"
|
||||||
if [[ -n "$RET_JUMP_SERVER" ]]; then
|
if [[ -n "$RET_JUMP_SERVER" ]]; then
|
||||||
jump_servers="$jump_servers${jump_servers:+,}$RET_JUMP_SERVER"
|
jump_servers="$jump_servers${jump_servers:+,}$RET_JUMP_SERVER"
|
||||||
|
@ -212,12 +213,14 @@ router() {
|
||||||
print_help
|
print_help
|
||||||
exit
|
exit
|
||||||
fi
|
fi
|
||||||
parse_remote "$1"
|
|
||||||
|
IFS=',' read -ra remotes <<< "$1"
|
||||||
|
for remote in "${remotes[@]}"; do
|
||||||
|
if [[ -z "$remote" ]]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
parse_remote "$remote"
|
||||||
case $2 in
|
case $2 in
|
||||||
-h|--help)
|
|
||||||
print_help
|
|
||||||
exit
|
|
||||||
;;
|
|
||||||
ssh|"" )
|
ssh|"" )
|
||||||
run_ssh ssh "${@:3}"
|
run_ssh ssh "${@:3}"
|
||||||
;;
|
;;
|
||||||
|
@ -241,6 +244,7 @@ router() {
|
||||||
fmt_fatal "unknown command: $2"
|
fmt_fatal "unknown command: $2"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
router "${GOT_OPTS[@]}"
|
router "${GOT_OPTS[@]}"
|
||||||
|
|
Loading…
Reference in New Issue
Block a user