commit ac2f4ada2b12f5d0a3db4547803ada318e981994
parent 1b7ee2a7788ff569f720187443144bb8bcfd8677
Author: Klemens Nanni <kl3@posteo.org>
Date: Thu, 23 Mar 2017 02:00:44 +0100
Small fixes, drop gpg filename extension
File extensions aren't needed at all, in fact they're complicating
internal handling of filenames since users must be able to provide
regular expressions containing the $ pattern.
In order to rename your files and fix symbolic links, you can use the
following commands:
$ cd "${PASSWORD_STORE_DIR:-~/.spm}"
$ find . \( -type f -o -type l \) -name \*.gpg -exec sh -c '
# remove filename extension
mv "${0}" "${0%.gpg}"
' {} \;
$ find . -type l -exec sh -c '
# fix link destinations
dst="$(readlink "${0}")
ln -fs "${dst%.gpg}" "${0}"
' {} \;
Diffstat:
M | spm.sh | | | 18 | +++++++++--------- |
1 file changed, 9 insertions(+), 9 deletions(-)
diff --git a/spm.sh b/spm.sh
@@ -55,17 +55,17 @@ readpw() {
}
find() {
- command find "${STORE_DIR}" \( -type f -o -type l \) -name \*.gpg |
- sed -e s/\.gpg$// | grep -Gie "${1}"
+ command find "${STORE_DIR}" \( -type f -o -type l \) |
+ grep -Gie "${1}"
}
view() {
- sed -e s/.gpg//g | less -EiKRX
+ less -EiKRX
}
## Commands
add() {
- [ -e "${STORE_DIR}"/"${1}".gpg ] && usage 'entry already exists'
+ [ -e "${STORE_DIR}"/"${1}" ] && usage 'entry already exists'
password=
readpw "Password for '${1}': " password
@@ -76,13 +76,13 @@ add() {
mkdir -p "${STORE_DIR}"/"${group}" &&
printf '%s\n' "${password}" |
- gpg --encrypt --output "${STORE_DIR}"/"${1}".gpg
+ gpg --encrypt --output "${STORE_DIR}"/"${1}"
}
list() {
[ -d "${STORE_DIR}"/"${1:-}" ] || usage 'no such group'
- tree ${gflag:+-d} -F -- "${STORE_DIR}"/"${1:-}" | view
+ tree ${gflag:+-d} -Fx -- "${STORE_DIR}"/"${1:-}" | view
}
del() {
@@ -95,7 +95,7 @@ search() {
}
show() {
- entry="$(find "${1}" | head -n2)".gpg
+ entry=$(find "${1}" | head -n2)
check; gpg --decrypt "${entry}"
}
@@ -110,12 +110,12 @@ case "${1}" in
${1} "${2}"
;;
list)
- if [ "${2}" = -g ] && [ ${#} -le 3 ]; then
+ if [ "${2:-}" = -g ] && [ ${#} -le 3 ]; then
gflag=1; shift 1
elif [ ${#} -gt 2 ]; then
usage 'too many arguments'
fi
- list "${2}"
+ list "${2:-}"
;;
help)
usage