diff options
author | Tharre <tharre3@gmail.com> | 2018-02-02 16:02:12 +0100 |
---|---|---|
committer | Tharre <tharre3@gmail.com> | 2018-02-02 16:55:02 +0100 |
commit | 23a777d5f9dfc5572edb75c21737aca44c01aefa (patch) | |
tree | 0e1c83ef0718d9c853ec6ed2f7323e55b57eb07e /.zshrc | |
parent | d453b2879431d32101c0761e97738845730f64fc (diff) | |
download | dotfiles-23a777d5f9dfc5572edb75c21737aca44c01aefa.tar.gz dotfiles-23a777d5f9dfc5572edb75c21737aca44c01aefa.tar.xz dotfiles-23a777d5f9dfc5572edb75c21737aca44c01aefa.zip |
gnupg: properly setup gpg-agent as ssh-agent
Diffstat (limited to '.zshrc')
-rw-r--r-- | .zshrc | 16 |
1 files changed, 13 insertions, 3 deletions
@@ -185,9 +185,19 @@ alias open="xdg-open" ## env export EDITOR=vim -# use gpg-agent as ssh-agent -gpg-connect-agent /bye > /dev/null 2>&1 -export SSH_AUTH_SOCK="$HOME/.gnupg/S.gpg-agent.ssh" +## gpg-agent +export GPG_TTY=$(tty) + +# Refresh gpg-agent tty in case user switches into an X session +gpg-connect-agent updatestartuptty /bye >/dev/null 2>&1 + +# if $SSH_AUTH_SOCK is not set or not pointing to a socket, use gpg-agent +if [ ! -S "$SSH_AUTH_SOCK" ] && type "gpgconf" > /dev/null; 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 ## zsh options |