diff options
| author | Adam Pike <adam.pike@1password.com> | 2022-03-26 15:11:04 +0100 | 
|---|---|---|
| committer | Marc Cornellà <hello@mcornella.com> | 2022-03-26 15:16:19 +0100 | 
| commit | dbadfa0810c0be346b98c02cc802c33fa43bee11 (patch) | |
| tree | c02594da735f7b9e3c13f7273d98ec0f557fdf62 /plugins/1password/opswd | |
| parent | a64d9403775f45036daf3b66693c35df7bab3c53 (diff) | |
| download | zsh-dbadfa0810c0be346b98c02cc802c33fa43bee11.tar.gz zsh-dbadfa0810c0be346b98c02cc802c33fa43bee11.tar.bz2 zsh-dbadfa0810c0be346b98c02cc802c33fa43bee11.zip | |
refactor(1password): support CLI 2 and soft-deprecate CLI 1 (#10787)
This change still supports CLI 1, but shows a deprecation warning
on the first run of `opswd`. Support for CLI 1 shall be removed
in the near future.
Closes #10787
Co-authored-by: Marc Cornellà <hello@mcornella.com>
Diffstat (limited to 'plugins/1password/opswd')
| -rw-r--r-- | plugins/1password/opswd | 49 | 
1 files changed, 45 insertions, 4 deletions
| diff --git a/plugins/1password/opswd b/plugins/1password/opswd index 6849d42b3..57672807e 100644 --- a/plugins/1password/opswd +++ b/plugins/1password/opswd @@ -12,11 +12,11 @@ function opswd() {    local service=$1    # If not logged in, print error and return -  op list users > /dev/null || return +  op user list > /dev/null || return    local password    # Copy the password to the clipboard -  if ! password=$(op get item "$service" --fields password 2>/dev/null); then +  if ! password=$(op item get "$service" --fields password 2>/dev/null); then      echo "error: could not obtain password for $service"      return 1    fi @@ -24,9 +24,9 @@ function opswd() {    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 +  # If there's a one time password, copy it to the clipboard after 10 seconds    local totp -  if totp=$(op get totp "$service" 2>/dev/null) && [[ -n "$totp" ]]; then +  if totp=$(op item get --otp "$service" 2>/dev/null) && [[ -n "$totp" ]]; then      sleep 10 && echo -n "$totp" | clipcopy      echo "✔ TOTP for $service copied to clipboard"    fi @@ -34,4 +34,45 @@ function opswd() {    (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 "$@" | 
