diff options
author | Werner Koch <[email protected]> | 2025-03-17 16:37:08 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2025-03-17 16:37:08 +0000 |
commit | f463586a9617392f68305a1059045ece1243475b (patch) | |
tree | b53d5936f09ebddd1b769149424b3b7e1b19bdc7 /sm | |
parent | gpgconf: Fix reload and kill of keyboxd. (diff) | |
download | gnupg-f463586a9617392f68305a1059045ece1243475b.tar.gz gnupg-f463586a9617392f68305a1059045ece1243475b.zip |
gpgsm: Extend --learn-card by an optional s/n argument.
* agent/command.c (cmd_learn): Allow for s/n argument.
* agent/learncard.c (agent_handle_learn): Ditto.
* agent/call-scd.c (agent_card_learn): Ditto. Pass it on to scd.
* scd/command.c (cmd_switchcard): Factor most code out to ...
(switchcard_core): new.
(cmd_learn): Add option --demand to specify a s/n.
* sm/gpgsm.c (main): Allow a s/n argument for --learn-card.
--
This help Kleopatra to get a stable certificate listing.
GnuPG-bug-id: 7379
Diffstat (limited to 'sm')
-rw-r--r-- | sm/call-agent.c | 12 | ||||
-rw-r--r-- | sm/gpgsm.c | 4 | ||||
-rw-r--r-- | sm/gpgsm.h | 2 |
3 files changed, 12 insertions, 6 deletions
diff --git a/sm/call-agent.c b/sm/call-agent.c index abce0387d..f2b7b6fba 100644 --- a/sm/call-agent.c +++ b/sm/call-agent.c @@ -1275,14 +1275,17 @@ learn_cb (void *opaque, const void *buffer, size_t length) return 0; } -/* Call the agent to learn about a smartcard */ + +/* Call the agent to learn about a smartcard. If SERIALNO is not NULL + * switch to the card with that s/n first. */ int -gpgsm_agent_learn (ctrl_t ctrl) +gpgsm_agent_learn (ctrl_t ctrl, const char *serialno) { int rc; struct learn_parm_s learn_parm; membuf_t data; size_t len; + char line[ASSUAN_LINELENGTH]; rc = start_agent (ctrl); if (rc) @@ -1297,7 +1300,10 @@ gpgsm_agent_learn (ctrl_t ctrl) learn_parm.ctrl = ctrl; learn_parm.ctx = agent_ctx; learn_parm.data = &data; - rc = assuan_transact (agent_ctx, "LEARN --send", + snprintf (line, sizeof line, "LEARN --send%s%s", + serialno? " -- ":"", + serialno? serialno:""); + rc = assuan_transact (agent_ctx, line, learn_cb, &learn_parm, NULL, NULL, learn_status_cb, &learn_parm); diff --git a/sm/gpgsm.c b/sm/gpgsm.c index b60f0bb46..4614938c2 100644 --- a/sm/gpgsm.c +++ b/sm/gpgsm.c @@ -2269,11 +2269,11 @@ main ( int argc, char **argv) case aLearnCard: - if (argc) + if (argc > 1) wrong_args ("--learn-card"); else { - int rc = gpgsm_agent_learn (&ctrl); + int rc = gpgsm_agent_learn (&ctrl, argc? *argv : NULL); if (rc) log_error ("error learning card: %s\n", gpg_strerror (rc)); } diff --git a/sm/gpgsm.h b/sm/gpgsm.h index 78efe2379..4a4bd5ac4 100644 --- a/sm/gpgsm.h +++ b/sm/gpgsm.h @@ -539,7 +539,7 @@ int gpgsm_agent_istrusted (ctrl_t ctrl, ksba_cert_t cert, const char *hexfpr, struct rootca_flags_s *rootca_flags); int gpgsm_agent_havekey (ctrl_t ctrl, const char *hexkeygrip); int gpgsm_agent_marktrusted (ctrl_t ctrl, ksba_cert_t cert); -int gpgsm_agent_learn (ctrl_t ctrl); +int gpgsm_agent_learn (ctrl_t ctrl, const char *serialno); int gpgsm_agent_passwd (ctrl_t ctrl, const char *hexkeygrip, const char *desc); gpg_error_t gpgsm_agent_get_confirmation (ctrl_t ctrl, const char *desc); gpg_error_t gpgsm_agent_send_nop (ctrl_t ctrl); |