mirror of https://github.com/ohmyzsh/ohmyzsh.git
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.pull/1904/head
parent
78dba754d1
commit
711e96b1a2
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue