diff options
Diffstat (limited to 'plugins/ssh-agent')
| -rw-r--r-- | plugins/ssh-agent/ssh-agent.plugin.zsh | 47 | 
1 files changed, 40 insertions, 7 deletions
| diff --git a/plugins/ssh-agent/ssh-agent.plugin.zsh b/plugins/ssh-agent/ssh-agent.plugin.zsh index fe4946c6d..a7a4ee33a 100644 --- a/plugins/ssh-agent/ssh-agent.plugin.zsh +++ b/plugins/ssh-agent/ssh-agent.plugin.zsh @@ -2,20 +2,51 @@ typeset _agent_forwarding _ssh_env_cache  function _start_agent() {  	local lifetime -	local -a identities - -	# start ssh-agent and setup environment  	zstyle -s :omz:plugins:ssh-agent lifetime lifetime +	# start ssh-agent and setup environment +	echo starting ssh-agent...  	ssh-agent -s ${lifetime:+-t} ${lifetime} | sed 's/^echo/#echo/' >! $_ssh_env_cache  	chmod 600 $_ssh_env_cache  	. $_ssh_env_cache > /dev/null +} -	# load identies +function _add_identities() { +	local id line sig +	local -a identities loaded_sigs loaded_ids not_loaded  	zstyle -a :omz:plugins:ssh-agent identities identities -	echo starting ssh-agent... -	ssh-add $HOME/.ssh/${^identities} +	# check for .ssh folder presence +	if [[ ! -d $HOME/.ssh ]]; then +		return +	fi + +	# add default keys if no identities were set up via zstyle +	# this is to mimic the call to ssh-add with no identities +	if [[ ${#identities} -eq 0 ]]; then +		# key list found on `ssh-add` man page's DESCRIPTION section +		for id in id_rsa id_dsa id_ecdsa id_ed25519 identity; do +			# check if file exists +			[[ -f "$HOME/.ssh/$id" ]] && identities+=$id +		done +	fi + +	# get list of loaded identities' signatures and filenames +	for line in ${(f)"$(ssh-add -l)"}; do +		loaded_sigs+=${${(z)line}[2]} +		loaded_ids+=${${(z)line}[3]} +	done + +	# add identities if not already loaded +	for id in $identities; do +		# check for filename match, otherwise try for signature match +		if [[ ${loaded_ids[(I)$HOME/.ssh/$id]} -le 0 ]]; then +			sig="$(ssh-keygen -lf "$HOME/.ssh/$id" | awk '{print $2}')" +			[[ ${loaded_sigs[(I)$sig]} -le 0 ]] && not_loaded+="$HOME/.ssh/$id" +		fi +	done + +	[[ -n "$not_loaded" ]] && ssh-add ${^not_loaded}  }  # Get the filename to store/lookup the environment from @@ -42,6 +73,8 @@ else  	_start_agent  fi +_add_identities +  # tidy up after ourselves  unset _agent_forwarding _ssh_env_cache -unfunction _start_agent +unfunction _start_agent _add_identities | 
