summaryrefslogtreecommitdiffstats
path: root/agent/findkey.c
diff options
context:
space:
mode:
authorNIIBE Yutaka <gniibe@fsij.org>2022-05-27 02:59:54 +0200
committerNIIBE Yutaka <gniibe@fsij.org>2022-05-27 02:59:54 +0200
commit9f1dcfc7a7b47ab8221e75eaa1872bbf2a72980c (patch)
tree376cfbd93346230425f09ddaa3faa29c30f5ba99 /agent/findkey.c
parentagent,ssh: Support "Use-for-ssh" flag in private key. (diff)
downloadgnupg2-9f1dcfc7a7b47ab8221e75eaa1872bbf2a72980c.tar.xz
gnupg2-9f1dcfc7a7b47ab8221e75eaa1872bbf2a72980c.zip
agent: New field "Prompt" to prevent asking card key insertion.
* agent/findkey.c (prompt_for_card): Add "Prompt" field handling. -- GnuPG-bug-id: 5987 Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
Diffstat (limited to 'agent/findkey.c')
-rw-r--r--agent/findkey.c25
1 files changed, 21 insertions, 4 deletions
diff --git a/agent/findkey.c b/agent/findkey.c
index dd6233ad1..83d984fb6 100644
--- a/agent/findkey.c
+++ b/agent/findkey.c
@@ -976,14 +976,25 @@ prompt_for_card (ctrl_t ctrl, const unsigned char *grip,
char hexgrip[41];
char *comment_buffer = NULL;
const char *comment = NULL;
+ int refuse_prompt = 0;
bin2hex (grip, 20, hexgrip);
- if (keymeta && (comment = nvc_get_string (keymeta, "Label:")))
+ if (keymeta)
{
- if (strchr (comment, '\n')
- && (comment_buffer = linefeed_to_percent0A (comment)))
- comment = comment_buffer;
+ const char *p;
+
+ if ((p = nvc_get_string (keymeta, "Prompt:")) && !strcmp (p, "no"))
+ refuse_prompt = 1;
+
+ if ((p = nvc_get_string (keymeta, "Label:")))
+ {
+ if (strchr (p, '\n')
+ && (comment_buffer = linefeed_to_percent0A (p)))
+ comment = comment_buffer;
+ else
+ comment = p;
+ }
}
err = parse_shadow_info (shadow_info, &want_sn, NULL, NULL);
@@ -1042,6 +1053,12 @@ prompt_for_card (ctrl_t ctrl, const unsigned char *grip,
}
/* Card is not available. Prompt the insertion. */
+ if (refuse_prompt)
+ {
+ err = gpg_error (GPG_ERR_UNUSABLE_SECKEY);
+ break;
+ }
+
if (asprintf (&desc,
"%s:%%0A%%0A"
" %s%%0A"