12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 |
- #autoload
- # opswd puts the password of the named service into the clipboard. If there's a
- # one time password, it will be copied into the clipboard after 10 seconds. The
- # clipboard is cleared after another 20 seconds.
- function opswd() {
- if [[ $# -lt 1 ]]; then
- echo "Usage: opswd <service>"
- return 1
- fi
- local service=$1
- # If not logged in, print error and return
- op user list > /dev/null || return
- local username
- # Copy the username to the clipboard
- if ! username=$(op item get "$service" --fields username 2>/dev/null); then
- echo "error: could not obtain username for $service"
- return 1
- fi
- echo -n "$username" | clipcopy
- echo "✔ username for service $service copied to the clipboard. Press Enter to continue"
- read
- local password
- # Copy the password to the clipboard
- if ! password=$(op item get "$service" --fields password 2>/dev/null); then
- echo "error: could not obtain password for $service"
- return 1
- fi
- echo -n "$password" | clipcopy
- echo "✔ password for $service copied to clipboard. Press Enter to continue"
- read
- # If there's a one time password, copy it to the clipboard
- local totp
- if totp=$(op item get --otp "$service" 2>/dev/null) && [[ -n "$totp" ]]; then
- echo -n "$totp" | clipcopy
- echo "✔ TOTP for $service copied to clipboard"
- fi
- (sleep 20 && clipcopy </dev/null 2>/dev/null) &!
- }
- # TODO: 2022-03-26: Remove support for op CLI 1
- autoload -Uz is-at-least
- is-at-least 2.0.0 $(op --version) || {
- print -ru2 ${(%):-"%F{yellow}opswd: usage with op version $(op --version) is deprecated. Upgrade to CLI 2 and reload zsh.
- For instructions, see https://developer.1password.com/docs/cli/upgrade.%f"}
- # opswd puts the password of the named service into the clipboard. If there's a
- # one time password, it will be copied into the clipboard after 10 seconds. The
- # clipboard is cleared after another 20 seconds.
- function opswd() {
- if [[ $# -lt 1 ]]; then
- echo "Usage: opswd <service>"
- return 1
- fi
- local service=$1
- # If not logged in, print error and return
- op list users > /dev/null || return
- local password
- # Copy the password to the clipboard
- if ! password=$(op get item "$service" --fields password 2>/dev/null); then
- echo "error: could not obtain password for $service"
- return 1
- fi
- echo -n "$password" | clipcopy
- echo "✔ password for $service copied to clipboard"
- # If there's a one time password, copy it to the clipboard after 5 seconds
- local totp
- if totp=$(op get totp "$service" 2>/dev/null) && [[ -n "$totp" ]]; then
- sleep 10 && echo -n "$totp" | clipcopy
- echo "✔ TOTP for $service copied to clipboard"
- fi
- (sleep 20 && clipcopy </dev/null 2>/dev/null) &!
- }
- }
- opswd "$@"
|