diff options
author | 2025-02-13 14:13:49 +0530 | |
---|---|---|
committer | 2025-02-13 14:13:49 +0530 | |
commit | 8a2e1006b3b272126332aa064f3ad95387129544 (patch) | |
tree | 944c80ac612a65980d94a54ba11b6c7102037ecf /.config/zsh/oh-my-zsh/plugins/gpg-agent/gpg-agent.plugin.zsh | |
parent | dcbb16d8b08ff5956abef5e6478b59df2e93ad35 (diff) | |
download | dotfiles-master.tar.gz dotfiles-master.tar.bz2 dotfiles-master.zip |
Diffstat (limited to '.config/zsh/oh-my-zsh/plugins/gpg-agent/gpg-agent.plugin.zsh')
-rw-r--r-- | .config/zsh/oh-my-zsh/plugins/gpg-agent/gpg-agent.plugin.zsh | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/.config/zsh/oh-my-zsh/plugins/gpg-agent/gpg-agent.plugin.zsh b/.config/zsh/oh-my-zsh/plugins/gpg-agent/gpg-agent.plugin.zsh new file mode 100644 index 0000000..1f4be20 --- /dev/null +++ b/.config/zsh/oh-my-zsh/plugins/gpg-agent/gpg-agent.plugin.zsh @@ -0,0 +1,17 @@ +export GPG_TTY=$TTY + +# 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 2>/dev/null | 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 |