2010-10-15 22:50:39 +08:00
|
|
|
local GPG_ENV=$HOME/.gnupg/gpg-agent.env
|
|
|
|
|
2013-02-21 09:46:20 +08:00
|
|
|
function start_agent_nossh {
|
|
|
|
eval $(/usr/bin/env gpg-agent --daemon --write-env-file ${GPG_ENV}) > /dev/null
|
|
|
|
export GPG_AGENT_INFO
|
|
|
|
}
|
|
|
|
|
|
|
|
function start_agent_withssh {
|
|
|
|
eval $(/usr/bin/env gpg-agent --daemon --enable-ssh-support --write-env-file ${GPG_ENV}) > /dev/null
|
|
|
|
export GPG_AGENT_INFO
|
|
|
|
export SSH_AUTH_SOCK
|
|
|
|
export SSH_AGENT_PID
|
2010-10-15 22:50:39 +08:00
|
|
|
}
|
|
|
|
|
2013-02-21 09:46:20 +08:00
|
|
|
# make sure all created files are u=rw only
|
|
|
|
umask 177
|
|
|
|
|
|
|
|
# source settings of old agent, if applicable
|
2010-10-15 22:50:39 +08:00
|
|
|
if [ -f "${GPG_ENV}" ]; then
|
|
|
|
. ${GPG_ENV} > /dev/null
|
|
|
|
fi
|
|
|
|
|
2013-02-21 09:46:20 +08:00
|
|
|
# check for existing ssh-agent
|
|
|
|
if ssh-add -l > /dev/null 2> /dev/null; then
|
|
|
|
start_agent_nossh;
|
|
|
|
else
|
|
|
|
start_agent_withssh;
|
|
|
|
fi
|
2010-10-15 22:50:39 +08:00
|
|
|
|
|
|
|
GPG_TTY=$(tty)
|
|
|
|
export GPG_TTY
|