X-Git-Url: https://git.madduck.net/etc/ssh.git/blobdiff_plain/c61b78f6631ca529dc36a7df58830b2dec94bb95..361eacfe215343d432812e29bd6369783679b210:/.zsh/zshrc/parts.d/50-ssh diff --git a/.zsh/zshrc/parts.d/50-ssh b/.zsh/zshrc/parts.d/50-ssh index 53d189c..166fa12 100644 --- a/.zsh/zshrc/parts.d/50-ssh +++ b/.zsh/zshrc/parts.d/50-ssh @@ -20,20 +20,48 @@ _ssh_proxy() { local cmd sshopts cmdopts cmd="$1"; shift sshopts="${*%%--*}"; sshopts="${sshopts%% }" + [[ -n "$sshopts" ]] || { ssh; return $? } cmdopts="${*#$sshopts}"; cmdopts="${cmdopts#*-- }" eval ssh $sshopts -t $cmd $cmdopts } # need functions instead of aliases for completion -rrsh() { _ssh_proxy "su -" "$@" } +rrsh() { _ssh_proxy "sudo -i" "$@" } compdef rrsh=ssh ttsh() { _ssh_proxy "tmux last" "$@" } compdef ttsh=ssh -rtsh() { _ssh_proxy "tmux new su -" "$@" } +rtsh() { _ssh_proxy "tmux new sudo -i" "$@" } compdef rtsh=ssh -alias kssh='rm -vf -- $VARDIR/ssh/ssh_control_*(=as-60Y1omN)' +declare _SSH_SOCKDIR="${VARDIR}/ssh" +kssh() { + if [[ -z "$1" ]]; then + rm -vf -- ${_SSH_SOCKDIR}/*(=as-60Y1omN) + else + rm "$@" + fi +} +compdef -e "compset -P ${_SSH_SOCKDIR}/ || PREFIX=${_SSH_SOCKDIR}/; _files -W ${_SSH_SOCKDIR}" kssh + +sshcd() { + local args host dir arg + + for arg in "$@"; do + case "$arg" in + (*:*) host=${arg%%:*}; dir="${arg#*:}";; + (*) args="${args:+$args }$arg";; + esac + done + + if [[ -z $dir ]]; then + ssh "$@" + + else + + ssh -t $args $host "cd '${dir:gs/\'/\'\\\'\'}' && exec \$SHELL --login" + fi +} # vim:ft=zsh