2013-08-12 12:32:21 +00:00
|
|
|
#!/bin/sh
|
|
|
|
# Copyright (C) 2013 g10 Code GmbH
|
|
|
|
#
|
|
|
|
# This file is free software; as a special exception the author gives
|
|
|
|
# unlimited permission to copy and/or distribute it, with or without
|
|
|
|
# modifications, as long as this notice is preserved. This file is
|
|
|
|
# distributed in the hope that it will be useful, but WITHOUT ANY
|
|
|
|
# WARRANTY, to the extent permitted by law; without even the implied
|
|
|
|
# warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
|
|
|
|
if [ -z "$(command -v gpg-connect-agent)" ]; then
|
|
|
|
echo "gpg-agent not installed and thus not started" >&2
|
|
|
|
exit 0;
|
|
|
|
fi
|
|
|
|
|
|
|
|
GPG_AGENT_INFO=
|
|
|
|
export GPG_AGENT_INFO
|
2017-01-25 13:10:18 +00:00
|
|
|
GPG_AGENT=$(which gpg-agent)
|
2013-08-12 12:32:21 +00:00
|
|
|
|
|
|
|
token=$(echo "gpgme-$(pwd)" | tr ' ' '_')
|
|
|
|
|
|
|
|
if [ "$1" = "--stop" ]; then
|
2017-01-25 13:10:18 +00:00
|
|
|
if [ "$(gpg-connect-agent --no-autostart getval\ $token /bye 2>/dev/null | head -1)" \
|
2013-08-12 12:32:21 +00:00
|
|
|
!= "D set" ]; then
|
|
|
|
echo "gpg-agent not running" >&2
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
echo "stopping gpg-agent " >&2
|
|
|
|
gpg-connect-agent KILLAGENT /bye >/dev/null 2>&1
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2017-07-13 13:41:11 +00:00
|
|
|
# Update 'agent-program' in the configuration files to make sure we
|
|
|
|
# will always start exactly this agent again if we ever need to.
|
|
|
|
for F in gpg.conf gpgsm.conf
|
|
|
|
do
|
|
|
|
if test -f "$GNUPGHOME/$F"
|
|
|
|
then
|
|
|
|
mv "$GNUPGHOME/$F" "$GNUPGHOME/$F~"
|
|
|
|
sed -e "s#^agent-program.*#agent-program ${GPG_AGENT}|--debug-quick-random#" \
|
|
|
|
>"$GNUPGHOME/$F" <"$GNUPGHOME/$F~"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2017-01-25 13:10:18 +00:00
|
|
|
if [ "$(gpg-connect-agent --no-autostart getval\ $token /bye 2>/dev/null | head -1)" \
|
2013-08-12 12:32:21 +00:00
|
|
|
= "D set" ]; then
|
|
|
|
echo "gpg-agent already running" >&2
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2017-01-25 13:10:18 +00:00
|
|
|
echo "starting gpg-agent.." >&2
|
|
|
|
|
2017-03-20 15:36:27 +00:00
|
|
|
# GnuPG prior to 2.1.12 needs --allow-loopback-pinentry for the
|
|
|
|
# loopback entry to work. Old versions do not understand this though,
|
|
|
|
# so we need to be careful.
|
|
|
|
if "$GPG_AGENT" --gpgconf-test --allow-loopback-pinentry &&
|
2017-03-20 16:07:31 +00:00
|
|
|
test -f "$GNUPGHOME/gpg-agent.conf" &&
|
|
|
|
! grep -q allow-loopback-pinentry "$GNUPGHOME/gpg-agent.conf"; then
|
2017-03-20 15:36:27 +00:00
|
|
|
echo allow-loopback-pinentry >> "$GNUPGHOME/gpg-agent.conf"
|
|
|
|
fi
|
|
|
|
|
2017-01-25 13:10:18 +00:00
|
|
|
gpg-connect-agent --agent-program="${GPG_AGENT}|--debug-quick-random" putval\ $token\ set /bye
|
|
|
|
if [ $? -ne 0 -o "$(gpg-connect-agent getval\ $token /bye 2>/dev/null | head -1)" \
|
2013-08-12 12:32:21 +00:00
|
|
|
!= "D set" ]; then
|
|
|
|
echo "error starting gpg-agent" >&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
exit 0
|