mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-08 12:44:23 +01:00
gpg: Fix two other cases in get_best_pubkey_byname.
* g10/getkey.c (pubkey_cmp): Handle a primary key with PUBKEY_USAGE_ENC, and make sure new key is for encryption. (get_best_pubkey_byname): Add comment for ranking. GnuPG-bug-id: 4713 Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
627a990f8e
commit
286d4c6075
13
g10/getkey.c
13
g10/getkey.c
@ -1288,7 +1288,11 @@ pubkey_cmp (ctrl_t ctrl, const char *name, struct pubkey_cmp_cookie *old,
|
||||
{
|
||||
kbnode_t n;
|
||||
|
||||
if ((new->key.pubkey_usage & PUBKEY_USAGE_ENC) == 0)
|
||||
new->creation_time = 0;
|
||||
else
|
||||
new->creation_time = new->key.timestamp;
|
||||
|
||||
for (n = find_next_kbnode (new_keyblock, PKT_PUBLIC_SUBKEY);
|
||||
n; n = find_next_kbnode (n, PKT_PUBLIC_SUBKEY))
|
||||
{
|
||||
@ -1304,6 +1308,10 @@ pubkey_cmp (ctrl_t ctrl, const char *name, struct pubkey_cmp_cookie *old,
|
||||
new->creation_time = sub->timestamp;
|
||||
}
|
||||
|
||||
/* When new key has no encryption key, use OLD key. */
|
||||
if (new->creation_time == 0)
|
||||
return 1;
|
||||
|
||||
for (n = find_next_kbnode (new_keyblock, PKT_USER_ID);
|
||||
n; n = find_next_kbnode (n, PKT_USER_ID))
|
||||
{
|
||||
@ -1416,7 +1424,7 @@ get_best_pubkey_byname (ctrl_t ctrl, enum get_pubkey_modes mode,
|
||||
|
||||
if (is_mbox && ctx)
|
||||
{
|
||||
/* Rank results and return only the most relevant key. */
|
||||
/* Rank results and return only the most relevant key for encryption. */
|
||||
struct pubkey_cmp_cookie best = { 0 };
|
||||
struct pubkey_cmp_cookie new = { 0 };
|
||||
kbnode_t new_keyblock;
|
||||
@ -1463,8 +1471,6 @@ get_best_pubkey_byname (ctrl_t ctrl, enum get_pubkey_modes mode,
|
||||
best.uid = NULL;
|
||||
|
||||
if (best.valid)
|
||||
{
|
||||
if (1)
|
||||
{
|
||||
ctx = xtrycalloc (1, sizeof **retctx);
|
||||
if (! ctx)
|
||||
@ -1495,7 +1501,6 @@ get_best_pubkey_byname (ctrl_t ctrl, enum get_pubkey_modes mode,
|
||||
err = getkey_next (ctrl, ctx, NULL, ret_keyblock);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (pk)
|
||||
*pk = best.key;
|
||||
|
Loading…
x
Reference in New Issue
Block a user