123456789101112131415161718192021222324252627282930 |
- 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
- }
- # source settings of old agent, if applicable
- if [ -f "${GPG_ENV}" ]; then
- . ${GPG_ENV} > /dev/null
- fi
- # check for existing ssh-agent
- if ssh-add -l > /dev/null 2> /dev/null; then
- start_agent_nossh;
- else
- start_agent_withssh;
- fi
- GPG_TTY=$(tty)
- export GPG_TTY
|