diff options
author | lassulus <lassulus@lassul.us> | 2018-11-28 18:55:08 +0100 |
---|---|---|
committer | lassulus <lassulus@lassul.us> | 2018-11-28 18:55:08 +0100 |
commit | a69175a719b34222c8fb734478f04190a50d70e8 (patch) | |
tree | 765b2521aab1ab789ff56ce1550c7dcce881b3ac /tv/5pkgs/simple/fzmenu/bin/otpmenu | |
parent | f69a078f90d3cddfd5d3146ce39fbd294a14fb57 (diff) | |
parent | d1f81ace7241cf751f8a02c102b02bc1c8ad6c07 (diff) |
Merge remote-tracking branch 'ni/master' into ci
Diffstat (limited to 'tv/5pkgs/simple/fzmenu/bin/otpmenu')
-rwxr-xr-x | tv/5pkgs/simple/fzmenu/bin/otpmenu | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/tv/5pkgs/simple/fzmenu/bin/otpmenu b/tv/5pkgs/simple/fzmenu/bin/otpmenu new file mode 100755 index 000000000..ad8a0fda9 --- /dev/null +++ b/tv/5pkgs/simple/fzmenu/bin/otpmenu @@ -0,0 +1,41 @@ +#! /bin/sh +set -efu + +#PATH= + +case ${FZMENU_PHASE-0} in + 0) + export FZMENU_PHASE=1 + exec setsid -f urxvt -name fzmenu-urxvt -e dash "$0" + ;; + 1) + if result=$( + FZF_DEFAULT_OPTS=${FZMENU_FZF_DEFAULT_OPTS-} + if test -n "$FZF_DEFAULT_OPTS"; then + export FZF_DEFAULT_OPTS + fi + pass git ls-files '*/otp.gpg' | \ + sed ' + + s/\/otp\.gpg$// + ' | + exec fzf \ + --history=/dev/null \ + --no-sort \ + --prompt='OTP: ' \ + ) + then + export FZMENU_PHASE=2 + export FZMENU_RESULT="$result" + setsid -f "$0" + fi + ;; + 2) + pass=$(pass otp code "$FZMENU_RESULT/otp") + printf %s "$pass" | + xdotool type -f - + ;; + *) + echo "$0: error: bad phase: $FZMENU_PHASE" >&2 + exit -1 +esac |