Optional password file when splitting gpg key

This commit is contained in:
Bob Mottram 2017-06-03 15:42:57 +01:00
parent 75b0eb4291
commit 45c3c6be3e
2 changed files with 31 additions and 4 deletions

View File

@ -716,6 +716,14 @@ function create_private_mailing_list {
function split_gpg_key_into_fragments { function split_gpg_key_into_fragments {
# split the gpg key into fragments if social key management is enabled # split the gpg key into fragments if social key management is enabled
if [[ $ENABLE_SOCIAL_KEY_MANAGEMENT == "yes" ]]; then if [[ $ENABLE_SOCIAL_KEY_MANAGEMENT == "yes" ]]; then
if [ $IMAGE_PASSWORD_FILE ]; then
if [ -f $IMAGE_PASSWORD_FILE ]; then
${PROJECT_NAME}-splitkey -u $MY_USERNAME -e $MY_EMAIL_ADDRESS --fullname "$MY_NAME" --passwordfile $IMAGE_PASSWORD_FILE
return
fi
fi
echo 'Splitting GPG key. You may need to enter your passphrase.' echo 'Splitting GPG key. You may need to enter your passphrase.'
${PROJECT_NAME}-splitkey -u $MY_USERNAME -e $MY_EMAIL_ADDRESS --fullname "$MY_NAME" ${PROJECT_NAME}-splitkey -u $MY_USERNAME -e $MY_EMAIL_ADDRESS --fullname "$MY_NAME"
if [ ! -d /home/$MY_USERNAME/.gnupg_fragments ]; then if [ ! -d /home/$MY_USERNAME/.gnupg_fragments ]; then

View File

@ -46,6 +46,7 @@ KEY_FRAGMENTS=3
MY_USERNAME= MY_USERNAME=
MY_EMAIL_ADDRESS= MY_EMAIL_ADDRESS=
MY_NAME= MY_NAME=
PASSWORD_FILE=
function show_help { function show_help {
echo '' echo ''
@ -78,6 +79,10 @@ case $key in
shift shift
MY_NAME=$1 MY_NAME=$1
;; ;;
--passwordfile)
shift
PASSWORD_FILE=$1
;;
*) *)
# unknown option # unknown option
;; ;;
@ -98,6 +103,13 @@ if [ ! -d /home/$MY_USERNAME/.gnupg ]; then
exit 5393 exit 5393
fi fi
if [ $PASSWORD_FILE ]; then
if [ ! -f $PASSWORD_FILE ]; then
echo $'Password file not found'
exit 62952
fi
fi
FRAGMENTS_DIR=/home/$MY_USERNAME/.gnupg_fragments FRAGMENTS_DIR=/home/$MY_USERNAME/.gnupg_fragments
if [ -d $FRAGMENTS_DIR ]; then if [ -d $FRAGMENTS_DIR ]; then
exit 0 exit 0
@ -128,8 +140,15 @@ if [ ! "$?" = "0" ]; then
echo $"Unable to extract public key for $KEYID" echo $"Unable to extract public key for $KEYID"
exit 7835 exit 7835
fi fi
if [ ! $PASSWORD_FILE ]; then
gpg --output $FRAGMENTS_DIR/privkey.txt \ gpg --output $FRAGMENTS_DIR/privkey.txt \
--armor --export-secret-key $KEYID --armor --export-secret-key $KEYID
else
echo "$(printf `cat $PASSWORD_FILE`)" | \
gpg --batch --passphrase-fd 0 \
--output $FRAGMENTS_DIR/privkey.txt \
--armor --export-secret-key $KEYID
fi
if [ ! "$?" = "0" ]; then if [ ! "$?" = "0" ]; then
echo $"Unable to extract private key for $KEYID" echo $"Unable to extract private key for $KEYID"
exit 7823 exit 7823