1
0
mirror of https://github.com/octoleo/Purse.git synced 2025-01-01 05:31:47 +00:00

Add delete option

This commit is contained in:
drduh 2015-07-01 22:31:38 -04:00
parent e5c1bbb492
commit 454994f5aa
2 changed files with 36 additions and 9 deletions

View File

@ -18,5 +18,7 @@ Type `w` to create a password. Will update existing password with same Username/
Type `r` to print stored passwords. Can be piped to `grep` and `pbcopy` or `xsel`, for example. Type `r` to print stored passwords. Can be piped to `grep` and `pbcopy` or `xsel`, for example.
Type `d` to delete a password by Username/ID.
To reset/erase keys and passwords, `rm pwd.sh.*`. To reset/erase keys and passwords, `rm pwd.sh.*`.

43
pwd.sh
View File

@ -4,8 +4,6 @@
# #
# An interface to gpg for managing passwords. # An interface to gpg for managing passwords.
#set -o errexit
#set -o xtrace
set -o pipefail set -o pipefail
set -o nounset set -o nounset
@ -75,10 +73,11 @@ read_pass () {
} }
write_pass () { create_id () {
# Writes a password. # Creates a new Username/ID.
read -p "Username/ID: " id read -p "Username/ID: " id
read -p "Create random password? (y/n default: y) " rand_pass read -p "Create random password? (y/n default: y) " rand_pass
if [ "${rand_pass}" == "n" ]; then if [ "${rand_pass}" == "n" ]; then
echo "Choose a password for '${id}'." echo "Choose a password for '${id}'."
@ -87,19 +86,40 @@ write_pass () {
else else
user_pass=$(gen_pass) user_pass=$(gen_pass)
fi fi
}
write_pass () {
# Writes a password to safe.
echo "Enter password to unlock ${safe}." echo "Enter password to unlock ${safe}."
get_pass ; echo get_pass ; echo
# Create a temporary file to decrypt passwords to.
# TODO(any): can this be done without writing to disk?
tmp_secret=$(mktemp -q /tmp/pwd.sh.XXXXXX) tmp_secret=$(mktemp -q /tmp/pwd.sh.XXXXXX)
# Decrypt safe, exclude specified ID in case of update/removal.
if [ -s ${safe} ] ; then if [ -s ${safe} ] ; then
decrypt ${password} ${safe} | grep -v " ${id}" > ${tmp_secret} decrypt ${password} ${safe} | grep -v " ${id}" > ${tmp_secret}
fi fi
echo "${user_pass} ${id}" >> ${tmp_secret}
# Append new password for ID, if one was provided.
if [ ! -z ${user_pass+x} ] ; then
echo "${user_pass} ${id}" >> ${tmp_secret}
fi
# Encrypt plaintext to safe.
encrypt ${password} ${safe} ${tmp_secret} encrypt ${password} ${safe} ${tmp_secret}
# Remove temporary plaintext.
${del} ${del_opts} ${tmp_secret} ${del} ${del_opts} ${tmp_secret}
echo "Wrote password for '${id}' to ${safe}." echo "Updated password for '${id}' in ${safe}."
unset id
unset password
unset user_pass
} }
@ -124,7 +144,6 @@ create_keys () {
echo "Choose a strong master password." echo "Choose a strong master password."
get_pass ; echo get_pass ; echo
key_pass=$password
${gpg} ${gpg_opts} \ ${gpg} ${gpg_opts} \
--gen-key --batch <( --gen-key --batch <(
@ -133,12 +152,14 @@ Key-Type: RSA
Key-Length: 4096 Key-Length: 4096
Expire-Date: 0 Expire-Date: 0
Name-Real: ${name} Name-Real: ${name}
Passphrase: ${key_pass} Passphrase: ${password}
%commit %commit
EOF EOF
) 2>/dev/null ) 2>/dev/null
echo "Created keys: ${public} and ${secret}." echo "Created keys: ${public} and ${secret}."
unset password
} }
@ -184,8 +205,12 @@ main () {
sanity_check sanity_check
read -p "Read or write a password? (r/w default: r) " action read -p "Read, write, or delete a password? (r/w/d default: r) " action
if [ "${action}" == "w" ] ; then if [ "${action}" == "w" ] ; then
create_id
write_pass
elif [ "${action}" == "d" ] ; then
read -p "Which Username/ID to delete? " id
write_pass write_pass
else else
read_pass read_pass