Commit 711e96b1 authored by Olaf Conradi's avatar Olaf Conradi
Browse files

Prevent starting multiple gpg-agents

Don't just overwrite the environment. First check for a running agent (an
x-session might have one running). If no agent is found, source the
environment and check again using those settings. If again no agent is
found, start a new instance.
parent 78dba754
...@@ -14,16 +14,24 @@ function start_agent_withssh { ...@@ -14,16 +14,24 @@ function start_agent_withssh {
export SSH_AGENT_PID export SSH_AGENT_PID
} }
# source settings of old agent, if applicable # check if another agent is running
if [ -f "${GPG_ENV}" ]; then 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 . ${GPG_ENV} > /dev/null
fi fi
# check for existing ssh-agent # check again if another agent is running using the newly sources settings
if ssh-add -l > /dev/null 2> /dev/null; then 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; start_agent_nossh;
else else
# otherwise start gpg-agent with ssh support
start_agent_withssh; start_agent_withssh;
fi
fi
fi fi
GPG_TTY=$(tty) GPG_TTY=$(tty)
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment