mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2024-11-12 21:39:48 +01:00
feat(ssh): add plugin (#12186)
Closes #2707 Co-authored-by: Frank Wittig <frank.wittig@here.com> Co-authored-by: Frank Wittig <frank@e5k.com>
This commit is contained in:
parent
80c114cb3a
commit
8b2ce98578
1 changed files with 46 additions and 0 deletions
46
plugins/ssh/ssh.plugin.zsh
Normal file
46
plugins/ssh/ssh.plugin.zsh
Normal file
|
@ -0,0 +1,46 @@
|
|||
############################################################
|
||||
# Take all host sections in .ssh/config and offer them for
|
||||
# completion as hosts (e.g. for ssh, rsync, scp and the like)
|
||||
# Filter out wildcard host sections.
|
||||
_ssh_configfile="$HOME/.ssh/config"
|
||||
if [[ -f "$_ssh_configfile" ]]; then
|
||||
_hosts=($(egrep '^Host.*' "$_ssh_configfile" | awk '{print $2}' | grep -v '^*' | sed -e 's/\.*\*$//'))
|
||||
zstyle ':completion:*:hosts' hosts $_hosts
|
||||
unset _hosts
|
||||
fi
|
||||
unset _ssh_configfile
|
||||
|
||||
############################################################
|
||||
# Remove host key from known hosts based on a host section
|
||||
# name from .ssh/config
|
||||
function ssh_rmhkey {
|
||||
local ssh_configfile="$HOME/.ssh/config"
|
||||
local ssh_host="$1"
|
||||
if [[ -z "$ssh_host" ]]; then return; fi
|
||||
ssh-keygen -R $(grep -A10 "$ssh_host" "$ssh_configfile" | grep -i HostName | head -n 1 | awk '{print $2}')
|
||||
}
|
||||
compctl -k hosts ssh_rmhkey
|
||||
|
||||
############################################################
|
||||
# Load SSH key into agent
|
||||
function ssh_load_key() {
|
||||
local key="$1"
|
||||
if [[ -z "$key" ]]; then return; fi
|
||||
local keyfile="$HOME/.ssh/$key"
|
||||
local keysig=$(ssh-keygen -l -f "$keyfile")
|
||||
if ( ! ssh-add -l | grep -q "$keysig" ); then
|
||||
ssh-add "$keyfile"
|
||||
fi
|
||||
}
|
||||
|
||||
############################################################
|
||||
# Remove SSH key from agent
|
||||
function ssh_unload_key {
|
||||
local key="$1"
|
||||
if [[ -z "$key" ]]; then return; fi
|
||||
local keyfile="$HOME/.ssh/$key"
|
||||
local keysig=$(ssh-keygen -l -f "$keyfile")
|
||||
if ( ssh-add -l | grep -q "$keysig" ); then
|
||||
ssh-add -d "$keyfile"
|
||||
fi
|
||||
}
|
Loading…
Reference in a new issue