add support for user-supplied copy/type commands

This commit is contained in:
Joel Beckmeyer 2022-08-19 13:36:10 -04:00
parent 42699fdbcb
commit 15269b633a
2 changed files with 51 additions and 17 deletions

View File

@ -1,10 +1,13 @@
# wofi-pass
```
Usage: wofi-pass [options]
-a, --autotype autotype whatever entry is chosen
-h, --help show this help message
-s, --squash don't show field choice if password file only contains password
-t, --type type the selection instead of copying to clipboard
-a, --autotype autotype whatever entry is chosen
-c, --copy [cmd] copy to clipboard. Defaults to wl-copy if no cmd is given.
-f, --fileisuser use the name of the password file as username
-h, --help show this help message
-s, --squash don't show field choice if password file only contains password
-t, --type [cmd] type the selection instead of copying to clipboard.
Defaults to wtype if no cmd is given.
```
Since `wofi` isn't a drop-in replacement for `rofi`, I couldn't use
@ -37,7 +40,3 @@ the field choice dialogue when there is only a password in the file.
The `-t | --type` flag tells `wofi-pass` to type the choice instead of copying
to clipboard. This also enables the autotype choice which types
`username :tab password`.
## Disclaimer???
I know this script needs some work; it was mostly hacked together in an
afternoon to get the minimum functionality I needed.

View File

@ -3,11 +3,14 @@
set -eu
autotype=0
copyisset=0
fileisuser=0
help=0
squash=0
typeisset=0
TYPE_CMD="wl-copy"
COPY_CMD="wl-copy"
TYPE_CMD="wtype -"
_trim() {
var="$*"
@ -46,7 +49,7 @@ _parse_fields() {
"
fi
done
if [ "$TYPE_CMD" = "wtype -" ] && [ "$has_username" -eq 1 ]; then
if [ "$typeisset" -eq 1 ] && [ "$has_username" -eq 1 ]; then
printf "autotype
"
fi
@ -72,23 +75,40 @@ _pass_get() {
_usage() {
printf "Usage: wofi-pass [options]\n"
printf " -a, --autotype autotype whatever entry is chosen\n"
printf " -c, --copy [cmd] copy to clipboard. Defaults to wl-copy if no cmd is given.\n"
printf " -f, --fileisuser use the name of the password file as username\n"
printf " -h, --help show this help message\n"
printf " -s, --squash don't show field choice if password file only contains password\n"
printf " -t, --type type the selection instead of copying to clipboard\n"
printf " -t, --type [cmd] type the selection instead of copying to clipboard.\n"
printf " Defaults to wtype if no cmd is given.\n"
}
OPTS="$(getopt --options afhst --longoptions autotype,fileisuser,help,squash,type -n 'wofi-pass' -- "$@")"
OPTS="$(getopt --options ac::fhst:: --longoptions autotype,copy::,fileisuser,help,squash,type:: -n 'wofi-pass' -- "$@")"
eval set -- "$OPTS"
while true; do
case "$1" in
-a | --autotype ) autotype=1; shift ;;
-c | --copy )
copyisset=1
if [ -z "$2" ]; then
copy_cmd="$COPY_CMD"
else
copy_cmd="$2"
fi
shift 2;;
-f | --fileisuser ) fileisuser=1; shift;;
-h | --help ) help=1; shift ;;
-s | --squash ) squash=1; shift ;;
-t | --type ) TYPE_CMD="wtype -"; shift;;
-- ) shift; break ;;
* ) break ;;
-t | --type )
typeisset=1
if [ -z "$2" ]; then
type_cmd="$TYPE_CMD"
else
type_cmd="$2"
fi
shift 2;;
-- ) shift; break;;
* ) break;;
esac
done
@ -97,6 +117,13 @@ if [ "$help" -eq 1 ]; then
exit 0
fi
if [ "$typeisset" -eq 1 ] && [ "$copyisset" -eq 1 ]; then
printf "copy and type cannot be used at same time. Please pass only one.\n"
exit 1
elif [ "$typeisset" -eq 0 ] && [ "$copyisset" -eq 0 ]; then
printf "neither -c/--copy or -t/--type passed. Defaulting to copying with wl-copy."
fi
cd "${PASSWORD_STORE_DIR:-$HOME/.password-store}"
password_files="$(find . -name "*.gpg" | sed "s/^\.\/\(.*\)\.gpg$/\1/")"
@ -122,7 +149,15 @@ if [ "$field" = "autotype" ] || [ "$autotype" -eq 1 ]; then
username=$(_pass_get "username")
fi
password=$(_pass_get "password")
printf '%s\t%s\n' "$username" "$password" | $TYPE_CMD
if [ "$typeisset" -eq 1 ]; then
printf '%s\t%s\n' "$username" "$password" | $type_cmd
else
printf '%s\t%s\n' "$username" "$password" | $copy_cmd
fi
else
_pass_get "$field" | $TYPE_CMD
if [ "$typeisset" -eq 1 ]; then
_pass_get "$field" | $type_cmd
else
_pass_get "$field" | $copy_cmd
fi
fi