mirror of
https://github.com/octoleo/Purse.git
synced 2025-01-01 13:41:46 +00:00
Add delete option
This commit is contained in:
parent
e5c1bbb492
commit
454994f5aa
@ -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.*`.
|
||||||
|
|
||||||
|
41
pwd.sh
41
pwd.sh
@ -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
|
||||||
|
|
||||||
|
# Append new password for ID, if one was provided.
|
||||||
|
if [ ! -z ${user_pass+x} ] ; then
|
||||||
echo "${user_pass} ${id}" >> ${tmp_secret}
|
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
|
||||||
|
Loading…
Reference in New Issue
Block a user