add support for user-supplied copy/type commands
This commit is contained in:
parent
42699fdbcb
commit
15269b633a
@ -2,9 +2,12 @@
|
|||||||
```
|
```
|
||||||
Usage: wofi-pass [options]
|
Usage: wofi-pass [options]
|
||||||
-a, --autotype autotype whatever entry is chosen
|
-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
|
-h, --help show this help message
|
||||||
-s, --squash don't show field choice if password file only contains password
|
-s, --squash don't show field choice if password file only contains password
|
||||||
-t, --type type the selection instead of copying to clipboard
|
-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
|
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
|
The `-t | --type` flag tells `wofi-pass` to type the choice instead of copying
|
||||||
to clipboard. This also enables the autotype choice which types
|
to clipboard. This also enables the autotype choice which types
|
||||||
`username :tab password`.
|
`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.
|
|
||||||
|
53
wofi-pass
53
wofi-pass
@ -3,11 +3,14 @@
|
|||||||
set -eu
|
set -eu
|
||||||
|
|
||||||
autotype=0
|
autotype=0
|
||||||
|
copyisset=0
|
||||||
fileisuser=0
|
fileisuser=0
|
||||||
help=0
|
help=0
|
||||||
squash=0
|
squash=0
|
||||||
|
typeisset=0
|
||||||
|
|
||||||
TYPE_CMD="wl-copy"
|
COPY_CMD="wl-copy"
|
||||||
|
TYPE_CMD="wtype -"
|
||||||
|
|
||||||
_trim() {
|
_trim() {
|
||||||
var="$*"
|
var="$*"
|
||||||
@ -46,7 +49,7 @@ _parse_fields() {
|
|||||||
"
|
"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
if [ "$TYPE_CMD" = "wtype -" ] && [ "$has_username" -eq 1 ]; then
|
if [ "$typeisset" -eq 1 ] && [ "$has_username" -eq 1 ]; then
|
||||||
printf "autotype
|
printf "autotype
|
||||||
"
|
"
|
||||||
fi
|
fi
|
||||||
@ -72,23 +75,40 @@ _pass_get() {
|
|||||||
_usage() {
|
_usage() {
|
||||||
printf "Usage: wofi-pass [options]\n"
|
printf "Usage: wofi-pass [options]\n"
|
||||||
printf " -a, --autotype autotype whatever entry is chosen\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 " -f, --fileisuser use the name of the password file as username\n"
|
||||||
printf " -h, --help show this help message\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 " -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"
|
eval set -- "$OPTS"
|
||||||
while true; do
|
while true; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-a | --autotype ) autotype=1; shift ;;
|
-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;;
|
-f | --fileisuser ) fileisuser=1; shift;;
|
||||||
-h | --help ) help=1; shift ;;
|
-h | --help ) help=1; shift ;;
|
||||||
-s | --squash ) squash=1; shift ;;
|
-s | --squash ) squash=1; shift ;;
|
||||||
-t | --type ) TYPE_CMD="wtype -"; shift;;
|
-t | --type )
|
||||||
-- ) shift; break ;;
|
typeisset=1
|
||||||
* ) break ;;
|
if [ -z "$2" ]; then
|
||||||
|
type_cmd="$TYPE_CMD"
|
||||||
|
else
|
||||||
|
type_cmd="$2"
|
||||||
|
fi
|
||||||
|
shift 2;;
|
||||||
|
-- ) shift; break;;
|
||||||
|
* ) break;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
@ -97,6 +117,13 @@ if [ "$help" -eq 1 ]; then
|
|||||||
exit 0
|
exit 0
|
||||||
fi
|
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}"
|
cd "${PASSWORD_STORE_DIR:-$HOME/.password-store}"
|
||||||
password_files="$(find . -name "*.gpg" | sed "s/^\.\/\(.*\)\.gpg$/\1/")"
|
password_files="$(find . -name "*.gpg" | sed "s/^\.\/\(.*\)\.gpg$/\1/")"
|
||||||
|
|
||||||
@ -122,7 +149,15 @@ if [ "$field" = "autotype" ] || [ "$autotype" -eq 1 ]; then
|
|||||||
username=$(_pass_get "username")
|
username=$(_pass_get "username")
|
||||||
fi
|
fi
|
||||||
password=$(_pass_get "password")
|
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
|
else
|
||||||
_pass_get "$field" | $TYPE_CMD
|
if [ "$typeisset" -eq 1 ]; then
|
||||||
|
_pass_get "$field" | $type_cmd
|
||||||
|
else
|
||||||
|
_pass_get "$field" | $copy_cmd
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
Reference in New Issue
Block a user