diff options
author | Werner Koch <[email protected]> | 2020-07-13 12:30:14 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2020-07-14 09:04:23 +0000 |
commit | 0a6af6dc12998ef7b19673ad05d11e82f826de9d (patch) | |
tree | eee597b842f038dfa127f1dc3c32f8c48cb423b3 | |
parent | gpg: Reword warning about decryption w/o using a non-encrypt key. (diff) | |
download | gnupg-0a6af6dc12998ef7b19673ad05d11e82f826de9d.tar.gz gnupg-0a6af6dc12998ef7b19673ad05d11e82f826de9d.zip |
agent: Fix regression with --newsymkey in loopback mode.
* agent/command.c (cmd_get_passphrase): Never repeat in loopback mode;
same as with !OPT_NEWSYMKEY.
--
In loopback mode there shall not be any repeat because the caller is
expected to do any confirmation before passing a new passphrase to
gpg.
Fixes-commit: eace4bbe1ded8b01f9ad52ebc1871f2fd13c3a08
GnuPG-bug-id: 4991
Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to '')
-rw-r--r-- | agent/command.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/agent/command.c b/agent/command.c index f54762b44..2980ae2da 100644 --- a/agent/command.c +++ b/agent/command.c @@ -1738,11 +1738,14 @@ cmd_get_passphrase (assuan_context_t ctx, char *line) pi2->failed_tries = 0; continue; } - if (*pi->pin && !pi->repeat_okay) + if (*pi->pin && !pi->repeat_okay + && ctrl->pinentry_mode != PINENTRY_MODE_LOOPBACK) { /* The passphrase is empty and the pinentry did not * already run the repetition check, do it here. This - * is only called when using an old and simple pinentry. */ + * is only called when using an old and simple pinentry. + * It is neither called in loopback mode because the + * caller does any passphrase repetition by herself. */ xfree (response); response = NULL; rc = agent_get_passphrase (ctrl, &response, |