aboutsummaryrefslogtreecommitdiffstats
path: root/g10/call-agent.c
diff options
context:
space:
mode:
authorWerner Koch <[email protected]>2014-12-12 11:35:45 +0000
committerWerner Koch <[email protected]>2014-12-12 11:47:28 +0000
commitf3f9f9b2844c35f7942ee904d5222523615cdad4 (patch)
treedcf872de1625703b30a8fbf0758291553fb2767b /g10/call-agent.c
parentgpg: Fix possible read of unallocated memory (diff)
downloadgnupg-f3f9f9b2844c35f7942ee904d5222523615cdad4.tar.gz
gnupg-f3f9f9b2844c35f7942ee904d5222523615cdad4.zip
gpg: Let --card--status create a shadow key (card key stub).
* agent/command.c (cmd_learn): Add option --sendinfo. * agent/learncard.c (agent_handle_learn): Add arg "send" andsend certifciate only if that is set. * g10/call-agent.c (agent_scd_learn): Use --sendinfo. Make INFO optional. (agent_learn): Remove. * g10/keygen.c (gen_card_key): Replace agent_learn by agent_scd_learn. -- The requirement of using --card-status on the first use of card on a new box is a bit annoying but the alternative of always checking whether a card is available before a decryption starts does not sound promising either. Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'g10/call-agent.c')
-rw-r--r--g10/call-agent.c32
1 files changed, 8 insertions, 24 deletions
diff --git a/g10/call-agent.c b/g10/call-agent.c
index f5c943d70..43a5c4e12 100644
--- a/g10/call-agent.c
+++ b/g10/call-agent.c
@@ -655,6 +655,7 @@ agent_scd_learn (struct agent_card_info_s *info)
{
int rc;
struct default_inq_parm_s parm;
+ struct agent_card_info_s dummyinfo;
memset (&parm, 0, sizeof parm);
@@ -674,39 +675,22 @@ agent_scd_learn (struct agent_card_info_s *info)
if (rc)
return rc;
+ if (!info)
+ info = &dummyinfo;
+
parm.ctx = agent_ctx;
memset (info, 0, sizeof *info);
- rc = assuan_transact (agent_ctx, "SCD LEARN --force",
+ rc = assuan_transact (agent_ctx, "LEARN --sendinfo",
dummy_data_cb, NULL, default_inq_cb, &parm,
learn_status_cb, info);
/* Also try to get the key attributes. */
if (!rc)
agent_scd_getattr ("KEY-ATTR", info);
- return rc;
-}
-
-
-/* Call the agent to learn about the current smartcard. This is
- currently only used to have the agent create the shadow key. */
-gpg_error_t
-agent_learn (void)
-{
- gpg_error_t err;
- struct default_inq_parm_s parm;
-
- memset (&parm, 0, sizeof parm);
-
- err = start_agent (NULL, 1);
- if (err)
- return err;
-
- parm.ctx = agent_ctx;
- err = assuan_transact (agent_ctx, "LEARN",
- dummy_data_cb, NULL, default_inq_cb, &parm,
- NULL, NULL);
+ if (info == &dummyinfo)
+ agent_release_card_info (info);
- return err;
+ return rc;
}