389 lines
11 KiB
Plaintext
Raw Normal View History

# ssh(1) completion -*- shell-script -*-
2009-12-24 15:52:05 +02:00
_ssh_ciphers()
{
COMPREPLY+=( $( compgen -W '3des-cbc aes128-cbc \
2009-12-24 15:52:05 +02:00
aes192-cbc aes256-cbc aes128-ctr aes192-ctr aes256-ctr arcfour128 \
arcfour256 arcfour blowfish-cbc cast128-cbc' -- "$cur" ) )
2009-12-24 15:52:05 +02:00
}
_ssh_macs()
{
COMPREPLY+=( $( compgen -W 'hmac-md5 hmac-sha1 \
umac-64@openssh.com hmac-ripemd160 hmac-sha1-96 hmac-md5-96' \
-- "$cur" ) )
2009-12-24 15:52:05 +02:00
}
_ssh_options()
{
compopt -o nospace
COMPREPLY=( $( compgen -S = -W 'AddressFamily BatchMode BindAddress \
2009-10-19 21:24:25 +03:00
ChallengeResponseAuthentication CheckHostIP Cipher Ciphers \
ClearAllForwardings Compression CompressionLevel ConnectionAttempts \
ConnectTimeout ControlMaster ControlPath DynamicForward EscapeChar \
ExitOnForwardFailure ForwardAgent ForwardX11 ForwardX11Trusted \
GatewayPorts GlobalKnownHostsFile GSSAPIAuthentication \
GSSAPIDelegateCredentials HashKnownHosts Host HostbasedAuthentication \
HostKeyAlgorithms HostKeyAlias HostName IdentityFile IdentitiesOnly \
KbdInteractiveDevices LocalCommand LocalForward LogLevel MACs \
2009-10-19 21:24:25 +03:00
NoHostAuthenticationForLocalhost NumberOfPasswordPrompts \
PasswordAuthentication PermitLocalCommand Port \
PreferredAuthentications Protocol ProxyCommand PubkeyAuthentication \
RekeyLimit RemoteForward RhostsRSAAuthentication RSAAuthentication \
SendEnv ServerAliveInterval ServerAliveCountMax SmartcardDevice \
2009-10-19 21:24:25 +03:00
StrictHostKeyChecking TCPKeepAlive Tunnel TunnelDevice \
UsePrivilegedPort User UserKnownHostsFile VerifyHostKeyDNS \
VisualHostKey XAuthLocation' -- "$cur" ) )
2009-05-02 17:34:00 +02:00
}
# Complete a ssh suboption (like ForwardAgent=y<tab>)
# Only one parameter: the string to complete including the equal sign.
# Not all suboptions are completed.
# Doesn't handle comma-separated lists.
_ssh_suboption()
{
# Split into subopt and subval
local prev=${1%%=*} cur=${1#*=}
case $prev in
BatchMode|ChallengeResponseAuthentication|CheckHostIP|\
ClearAllForwardings|Compression|ExitOnForwardFailure|ForwardAgent|\
ForwardX11|ForwardX11Trusted|GatewayPorts|GSSAPIAuthentication|\
GSSAPIKeyExchange|GSSAPIDelegateCredentials|GSSAPITrustDns|\
HashKnownHosts|HostbasedAuthentication|IdentitiesOnly|\
KbdInteractiveAuthentication|KbdInteractiveDevices|\
NoHostAuthenticationForLocalhost|PasswordAuthentication|\
PubkeyAuthentication|RhostsRSAAuthentication|RSAAuthentication|\
StrictHostKeyChecking|TCPKeepAlive|UsePrivilegedPort|\
VerifyHostKeyDNS|VisualHostKey)
COMPREPLY=( $( compgen -W 'yes no' -- "$cur") )
;;
AddressFamily)
COMPREPLY=( $( compgen -W 'any inet inet6' -- "$cur" ) )
;;
BindAddress)
_ip_addresses
;;
Cipher)
COMPREPLY=( $( compgen -W 'blowfish des 3des' -- "$cur" ) )
;;
Protocol)
COMPREPLY=( $( compgen -W '1 2 1,2 2,1' -- "$cur" ) )
;;
Tunnel)
COMPREPLY=( $( compgen -W 'yes no point-to-point ethernet' \
-- "$cur" ) )
;;
PreferredAuthentications)
COMPREPLY=( $( compgen -W 'gssapi-with-mic host-based \
publickey keyboard-interactive password' -- "$cur" ) )
;;
MACs)
_ssh_macs
;;
Ciphers)
_ssh_ciphers
;;
esac
return 0
}
# Try to complete -o SubOptions=
#
# Returns 0 if the completion was handled or non-zero otherwise.
_ssh_suboption_check()
{
# Get prev and cur words without splitting on =
local cureq=`_get_cword :=` preveq=`_get_pword :=`
if [[ $cureq == *=* && $preveq == -o ]]; then
_ssh_suboption $cureq
return $?
fi
return 1
}
2008-09-27 12:58:42 +02:00
_ssh()
{
local cur prev words cword
_init_completion -n : || return
2008-09-27 12:58:42 +02:00
local configfile
local -a config
2008-09-27 12:58:42 +02:00
_ssh_suboption_check && return 0
case $prev in
-F|-i|-S)
2009-10-19 21:24:25 +03:00
_filedir
return 0
;;
-c)
_ssh_ciphers
2009-10-19 21:24:25 +03:00
return 0
;;
2009-11-28 12:47:11 +02:00
-m)
_ssh_macs
2009-10-19 21:24:25 +03:00
return 0
;;
-l)
COMPREPLY=( $( compgen -u -- "$cur" ) )
return 0
;;
-o)
_ssh_options
return 0
;;
-w)
_available_interfaces
return 0
;;
-b)
_ip_addresses
2009-10-19 21:24:25 +03:00
return 0
;;
-D|-e|-I|-L|-O|-p|-R|-W)
return 0
;;
2009-10-19 21:24:25 +03:00
esac
2008-09-27 12:58:42 +02:00
2009-10-19 21:24:25 +03:00
if [[ "$cur" == -F* ]]; then
cur=${cur#-F}
_filedir
# Prefix completions with '-F'
COMPREPLY=( "${COMPREPLY[@]/#/-F}" )
cur=-F$cur # Restore cur
elif [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '$( _parse_usage "$1" )' -- "$cur" ) )
2009-10-19 21:24:25 +03:00
else
# Search COMP_WORDS for '-F configfile' or '-Fconfigfile' argument
set -- "${words[@]}"
2011-11-09 23:28:11 +02:00
while [[ $# -gt 0 ]]; do
if [[ $1 == -F* ]]; then
2011-11-09 23:28:11 +02:00
if [[ ${#1} -gt 2 ]]; then
2009-10-19 21:24:25 +03:00
configfile="$(dequote "${1:2}")"
else
shift
2011-11-09 23:28:11 +02:00
[[ $1 ]] && configfile="$(dequote "$1")"
2009-10-19 21:24:25 +03:00
fi
break
fi
shift
done
_known_hosts_real -a -F "$configfile" "$cur"
2011-11-09 23:28:11 +02:00
if [[ $cword -ne 1 ]]; then
compopt -o filenames
COMPREPLY+=( $( compgen -c -- "$cur" ) )
2009-10-19 21:24:25 +03:00
fi
fi
2009-10-19 21:24:25 +03:00
return 0
2011-04-04 22:14:39 +03:00
} &&
2009-05-02 17:34:00 +02:00
shopt -u hostcomplete && complete -F _ssh ssh slogin autossh
# sftp(1) completion
#
_sftp()
{
local cur prev words cword
_init_completion || return
2009-05-02 17:34:00 +02:00
local configfile
2009-05-02 17:34:00 +02:00
_ssh_suboption_check && return 0
case $prev in
-b|-F|-i)
2009-10-19 21:24:25 +03:00
_filedir
return 0
;;
-o)
_ssh_options
return 0
;;
-c)
_ssh_ciphers
return 0
;;
-B|-D|-P|-R|-S|-s)
return 0
;;
2009-10-19 21:24:25 +03:00
esac
2009-05-02 17:34:00 +02:00
2009-10-19 21:24:25 +03:00
if [[ "$cur" == -F* ]]; then
cur=${cur#-F}
_filedir
# Prefix completions with '-F'
COMPREPLY=( "${COMPREPLY[@]/#/-F}" )
cur=-F$cur # Restore cur
elif [[ "$cur" == -* ]]; then
COMPREPLY=( $( compgen -W '$( _parse_usage "$1" )' -- "$cur" ) )
2009-10-19 21:24:25 +03:00
else
# Search COMP_WORDS for '-F configfile' argument
set -- "${words[@]}"
2011-11-09 23:28:11 +02:00
while [[ $# -gt 0 ]]; do
if [[ $1 == -F* ]]; then
2011-11-09 23:28:11 +02:00
if [[ ${#1} -gt 2 ]]; then
2009-10-19 21:24:25 +03:00
configfile="$(dequote "${1:2}")"
else
shift
2011-11-09 23:28:11 +02:00
[[ $1 ]] && configfile="$(dequote "$1")"
2009-10-19 21:24:25 +03:00
fi
break
fi
shift
done
_known_hosts_real -a -F "$configfile" "$cur"
fi
2009-05-02 17:34:00 +02:00
2009-10-19 21:24:25 +03:00
return 0
2011-04-04 22:14:39 +03:00
} &&
2009-05-02 17:34:00 +02:00
shopt -u hostcomplete && complete -F _sftp sftp
# things we want to backslash escape in scp paths
_scp_path_esc='[][(){}<>",:;^&!$=?`|\\'"'"'[:space:]]'
# Complete remote files with ssh. If the first arg is -d, complete on dirs
# only. Returns paths escaped with three backslashes.
_scp_remote_files()
{
local IFS=$'\n'
# remove backslash escape from the first colon
cur=${cur/\\:/:}
local userhost=${cur%%?(\\):*}
local path=${cur#*:}
# unescape (3 backslashes to 1 for chars we escaped)
path=$( sed -e 's/\\\\\\\('$_scp_path_esc'\)/\\\1/g' <<<"$path" )
# default to home dir of specified user on remote host
2011-11-09 23:28:11 +02:00
if [[ -z $path ]]; then
path=$(ssh -o 'Batchmode yes' $userhost pwd 2>/dev/null)
fi
local files
2011-11-09 23:28:11 +02:00
if [[ $1 == -d ]]; then
# escape problematic characters; remove non-dirs
files=$( ssh -o 'Batchmode yes' $userhost \
command ls -aF1dL "$path*" 2>/dev/null | \
sed -e 's/'$_scp_path_esc'/\\\\\\&/g' -e '/[^\/]$/d' )
else
# escape problematic characters; remove executables, aliases, pipes
# and sockets; add space at end of file names
files=$( ssh -o 'Batchmode yes' $userhost \
command ls -aF1dL "$path*" 2>/dev/null | \
sed -e 's/'$_scp_path_esc'/\\\\\\&/g' -e 's/[*@|=]$//g' \
-e 's/[^\/]$/& /g' )
fi
COMPREPLY+=( $files )
}
# This approach is used instead of _filedir to get a space appended
# after local file/dir completions, and -o nospace retained for others.
# If first arg is -d, complete on directory names only. The next arg is
# an optional prefix to add to returned completions.
_scp_local_files()
{
local IFS=$'\n'
local dirsonly=false
2011-11-09 23:28:11 +02:00
if [[ $1 == -d ]]; then
dirsonly=true
shift
fi
if $dirsonly ; then
COMPREPLY+=( $( command ls -aF1dL $cur* 2>/dev/null | \
sed -e "s/$_scp_path_esc/\\\\&/g" -e '/[^\/]$/d' -e "s/^/$1/") )
else
COMPREPLY+=( $( command ls -aF1dL $cur* 2>/dev/null | \
sed -e "s/$_scp_path_esc/\\\\&/g" -e 's/[*@|=]$//g' \
-e 's/[^\/]$/& /g' -e "s/^/$1/") )
fi
}
2008-09-27 12:58:42 +02:00
# scp(1) completion
#
_scp()
{
local cur prev words cword
_init_completion -n : || return
2008-09-27 12:58:42 +02:00
local configfile prefix
2009-12-25 11:57:33 +02:00
_ssh_suboption_check && {
COMPREPLY=( "${COMPREPLY[@]/%/ }" )
return 0
}
case $prev in
2009-12-25 11:57:33 +02:00
-l|-P)
return 0
;;
-F|-i|-S)
_filedir
compopt +o nospace
2009-12-25 11:57:33 +02:00
return 0
;;
-c)
_ssh_ciphers
COMPREPLY=( "${COMPREPLY[@]/%/ }" )
return 0
;;
-o)
_ssh_options
return 0
;;
esac
2008-09-27 12:58:42 +02:00
2009-10-19 21:24:25 +03:00
_expand || return 0
2008-09-27 12:58:42 +02:00
2009-10-19 21:24:25 +03:00
if [[ "$cur" == *:* ]]; then
_scp_remote_files
return 0
2009-10-19 21:24:25 +03:00
fi
if [[ "$cur" == -F* ]]; then
2009-10-19 21:24:25 +03:00
cur=${cur#-F}
prefix=-F
else
# Search COMP_WORDS for '-F configfile' or '-Fconfigfile' argument
set -- "${words[@]}"
2011-11-09 23:28:11 +02:00
while [[ $# -gt 0 ]]; do
if [[ $1 == -F* ]]; then
2011-11-09 23:28:11 +02:00
if [[ ${#1} -gt 2 ]]; then
2009-10-19 21:24:25 +03:00
configfile="$(dequote "${1:2}")"
else
shift
2011-11-09 23:28:11 +02:00
[[ $1 ]] && configfile="$(dequote "$1")"
2009-10-19 21:24:25 +03:00
fi
break
fi
shift
done
case $cur in
2009-12-25 11:57:33 +02:00
-*)
COMPREPLY=( $( compgen -W '$( _parse_usage "${words[0]}" )' \
-- "$cur" ) )
2009-12-25 11:57:33 +02:00
COMPREPLY=( "${COMPREPLY[@]/%/ }" )
return 0
;;
*/*|[.~]*)
# not a known host, pass through
2009-12-25 11:57:33 +02:00
;;
*)
_known_hosts_real -c -a -F "$configfile" "$cur"
;;
esac
2009-10-19 21:24:25 +03:00
fi
_scp_local_files "$prefix"
2009-10-19 21:24:25 +03:00
return 0
2011-04-04 22:14:39 +03:00
} &&
complete -F _scp -o nospace scp
2008-09-27 12:58:42 +02:00
2009-10-04 19:42:50 +02:00
# ex: ts=4 sw=4 et filetype=sh