Clear master password after use

This commit is contained in:
Bob Mottram 2016-12-04 10:12:36 +00:00
parent 4f752ec349
commit daafbef7a1
1 changed files with 15 additions and 12 deletions

View File

@ -277,18 +277,6 @@ if [ ! -d /home/$CURR_USERNAME ]; then
fi fi
fi fi
if [[ "$CURR_USERNAME" == "root" ]]; then
if [ ! -d /root/.passwords/root ]; then
mkdir -p /root/.passwords/root
fi
if [ ! -f /root/.passwords/root/master ]; then
MASTER_PASSWORD=$(openssl rand -base64 32 | cut -c1-30)
echo "$MASTER_PASSWORD" > /root/.passwords/root/master
chmod 700 /root/.passwords/root/master
fi
MASTER_PASSWORD=$(cat /root/.passwords/root/master)
fi
if [ ${REMOVE_APP} ]; then if [ ${REMOVE_APP} ]; then
if [ -d ~/.passwords/${CURR_USERNAME}/${REMOVE_APP} ]; then if [ -d ~/.passwords/${CURR_USERNAME}/${REMOVE_APP} ]; then
shred -zu ~/.passwords/${CURR_USERNAME}/${REMOVE_APP} shred -zu ~/.passwords/${CURR_USERNAME}/${REMOVE_APP}
@ -301,9 +289,21 @@ if [ ! $CURR_APP ]; then
exit 3 exit 3
fi fi
if [[ "$CURR_USERNAME" == "root" ]]; then
if [ ! -d /root/.passwords/root ]; then
mkdir -p /root/.passwords/root
fi
if [ ! -f /root/.passwords/root/master ]; then
echo "$(openssl rand -base64 32 | cut -c1-30)" > /root/.passwords/root/master
chmod 700 /root/.passwords/root/master
fi
MASTER_PASSWORD=$(cat /root/.passwords/root/master)
fi
if [ ${#CURR_PASSWORD} -eq 0 ]; then if [ ${#CURR_PASSWORD} -eq 0 ]; then
# retrieve password # retrieve password
if [ ! -f ~/.passwords/$CURR_USERNAME/$CURR_APP ]; then if [ ! -f ~/.passwords/$CURR_USERNAME/$CURR_APP ]; then
MASTER_PASSWORD=
echo "" echo ""
exit 4 exit 4
else else
@ -314,6 +314,7 @@ else
# store password # store password
if [ -f $NO_PASSWORD_STORE_FILE ]; then if [ -f $NO_PASSWORD_STORE_FILE ]; then
if [[ "$CURR_USERNAME" != 'root' ]]; then if [[ "$CURR_USERNAME" != 'root' ]]; then
MASTER_PASSWORD=
exit 0 exit 0
fi fi
fi fi
@ -323,8 +324,10 @@ else
# padding helps to ensure than nothing can be learned from the length of the cyphertext # padding helps to ensure than nothing can be learned from the length of the cyphertext
pad_string "${CURR_PASSWORD}" | gpg -ca --cipher-algo AES256 --passphrase "$MASTER_PASSWORD" > ~/.passwords/$CURR_USERNAME/$CURR_APP pad_string "${CURR_PASSWORD}" | gpg -ca --cipher-algo AES256 --passphrase "$MASTER_PASSWORD" > ~/.passwords/$CURR_USERNAME/$CURR_APP
if [ ! -f ~/.passwords/$CURR_USERNAME/$CURR_APP ]; then if [ ! -f ~/.passwords/$CURR_USERNAME/$CURR_APP ]; then
MASTER_PASSWORD=
exit 5 exit 5
fi fi
fi fi
MASTER_PASSWORD=
exit 0 exit 0