@ -1,41 +1,14 @@
local GPG_ENV = $HOME /.gnupg/gpg-agent.env
function start_agent_nossh {
eval $( /usr/bin/env gpg-agent --quiet --daemon --write-env-file ${ GPG_ENV } 2> /dev/null)
chmod 600 ${ GPG_ENV }
export GPG_AGENT_INFO
}
function start_agent_withssh {
eval $( /usr/bin/env gpg-agent --quiet --daemon --enable-ssh-support --write-env-file ${ GPG_ENV } 2> /dev/null)
chmod 600 ${ GPG_ENV }
export GPG_AGENT_INFO
export SSH_AUTH_SOCK
export SSH_AGENT_PID
}
# check if another agent is running
if ! gpg-connect-agent --quiet /bye > /dev/null 2> /dev/null; then
# source settings of old agent, if applicable
if [ -f " ${ GPG_ENV } " ] ; then
. ${ GPG_ENV } > /dev/null
export GPG_AGENT_INFO
export SSH_AUTH_SOCK
export SSH_AGENT_PID
fi
# Enable gpg-agent if it is not running
GPG_AGENT_SOCKET = " ${ XDG_RUNTIME_DIR } /gnupg/S.gpg-agent.ssh "
if [ ! -S $GPG_AGENT_SOCKET ] ; then
gpg-agent --daemon >/dev/null 2>& 1
export GPG_TTY = $( tty)
fi
# check again if another agent is running using the newly sourced settings
if ! gpg-connect-agent --quiet /bye > /dev/null 2> /dev/null; then
# check for existing ssh-agent
if ssh-add -l > /dev/null 2> /dev/null; then
# ssh-agent running, start gpg-agent without ssh support
start_agent_nossh;
else
# otherwise start gpg-agent with ssh support
start_agent_withssh;
fi
fi
# Set SSH to use gpg-agent if it is configured to do so
GNUPGCONFIG = ${ GNUPGHOME :- " $HOME /.gnupg/gpg-agent.conf " }
if [ -r " $GNUPGCONFIG " ] && grep -q enable-ssh-support " $GNUPGCONFIG " ; then
unset SSH_AGENT_PID
export SSH_AUTH_SOCK = $GPG_AGENT_SOCKET
fi
GPG_TTY = $( tty)
export GPG_TTY