mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
g10: Fix default-key selection for signing, possibly by card.
* g10/call-agent.c (warn_version_mismatch): Revert. (start_agent): Suppress version mismatch if relevant. * g10/getkey.c (get_seckey_default_or_card): New. * g10/skclist.c (build_sk_list): Use get_seckey_default_or_card. -- The change of97a2394
, which prefers available card than default key specified is too strong. Fixes-commit:97a2394eca
Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
3713f67026
commit
fbb2259d22
4 changed files with 62 additions and 16 deletions
52
g10/getkey.c
52
g10/getkey.c
|
@ -3960,6 +3960,58 @@ enum_secret_keys (ctrl_t ctrl, void **context, PKT_public_key *sk)
|
|||
}
|
||||
}
|
||||
|
||||
gpg_error_t
|
||||
get_seckey_default_or_card (ctrl_t ctrl, PKT_public_key *pk,
|
||||
const byte *fpr_card, size_t fpr_len)
|
||||
{
|
||||
gpg_error_t err;
|
||||
strlist_t namelist = NULL;
|
||||
|
||||
const char *def_secret_key = parse_def_secret_key (ctrl);
|
||||
|
||||
if (def_secret_key)
|
||||
add_to_strlist (&namelist, def_secret_key);
|
||||
else if (fpr_card)
|
||||
return get_pubkey_byfprint (ctrl, pk, NULL, fpr_card, fpr_len);
|
||||
|
||||
if (!fpr_card
|
||||
|| (def_secret_key && def_secret_key[strlen (def_secret_key)-1] == '!'))
|
||||
err = key_byname (ctrl, NULL, namelist, pk, 1, 0, NULL, NULL);
|
||||
else
|
||||
{ /* Default key is specified and card key is also available. */
|
||||
kbnode_t k, keyblock = NULL;
|
||||
|
||||
err = key_byname (ctrl, NULL, namelist, pk, 1, 0, &keyblock, NULL);
|
||||
if (!err)
|
||||
for (k = keyblock; k; k = k->next)
|
||||
{
|
||||
PKT_public_key *pk_candidate;
|
||||
char fpr[MAX_FINGERPRINT_LEN];
|
||||
|
||||
if (k->pkt->pkttype != PKT_PUBLIC_KEY
|
||||
&&k->pkt->pkttype != PKT_PUBLIC_SUBKEY)
|
||||
continue;
|
||||
|
||||
pk_candidate = k->pkt->pkt.public_key;
|
||||
if (!pk_candidate->flags.valid)
|
||||
continue;
|
||||
if (!((pk_candidate->pubkey_usage & USAGE_MASK) & pk->req_usage))
|
||||
continue;
|
||||
fingerprint_from_pk (pk_candidate, fpr, NULL);
|
||||
if (!memcmp (fpr_card, fpr, fpr_len))
|
||||
{
|
||||
release_public_key_parts (pk);
|
||||
copy_public_key (pk, pk_candidate);
|
||||
break;
|
||||
}
|
||||
}
|
||||
release_kbnode (keyblock);
|
||||
}
|
||||
|
||||
free_strlist (namelist);
|
||||
|
||||
return err;
|
||||
}
|
||||
|
||||
/*********************************************
|
||||
*********** User ID printing helpers *******
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue