fix(gpg-agent): correctly overwrite `$SSH_AUTH_SOCK` and other improvements (#7059)
parent
49bc55f966
commit
e5b9b80008
2 changed files with 14 additions and 13 deletions
@ -1,16 +1,17 @@ |
||||
# Enable gpg-agent if it is not running- |
||||
# --use-standard-socket will work from version 2 upwards |
||||
|
||||
AGENT_SOCK=$(gpgconf --list-dirs | grep agent-socket | cut -d : -f 2) |
||||
|
||||
if [[ ! -S $AGENT_SOCK ]]; then |
||||
gpg-agent --daemon --use-standard-socket &>/dev/null |
||||
fi |
||||
export GPG_TTY=$TTY |
||||
|
||||
# Set SSH to use gpg-agent if it's enabled |
||||
GNUPGCONFIG="${GNUPGHOME:-"$HOME/.gnupg"}/gpg-agent.conf" |
||||
if [[ -r $GNUPGCONFIG ]] && command grep -q enable-ssh-support "$GNUPGCONFIG"; then |
||||
export SSH_AUTH_SOCK="$AGENT_SOCK.ssh" |
||||
# Fix for passphrase prompt on the correct tty |
||||
# See https://www.gnupg.org/documentation/manuals/gnupg/Agent-Options.html#option-_002d_002denable_002dssh_002dsupport |
||||
function _gpg-agent_update-tty_preexec { |
||||
gpg-connect-agent updatestartuptty /bye &>/dev/null |
||||
} |
||||
autoload -U add-zsh-hook |
||||
add-zsh-hook preexec _gpg-agent_update-tty_preexec |
||||
|
||||
# If enable-ssh-support is set, fix ssh agent integration |
||||
if [[ $(gpgconf --list-options gpg-agent | awk -F: '$1=="enable-ssh-support" {print $10}') = 1 ]]; then |
||||
unset SSH_AGENT_PID |
||||
if [[ "${gnupg_SSH_AUTH_SOCK_by:-0}" -ne $$ ]]; then |
||||
export SSH_AUTH_SOCK="$(gpgconf --list-dirs agent-ssh-socket)" |
||||
fi |
||||
fi |
||||
|
||||
Loading…
Reference in new issue