1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-03 12:11:33 +01:00

gpg: Use just the addrspec from the Signer's UID.

* g10/parse-packet.c (parse_signature): Take only the addrspec from a
Signer's UID subpacket.
--

This is to address a problem in the currentr OpenKeychain which put
the entire UID into the subpacket.  For example our Tofu code can only
use the addrspec and not the entire UID.

Reported-by: Wiktor Kwapisiewicz <wiktor@metacode.biz>
Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2019-05-03 10:53:34 +02:00
parent caa61fb7da
commit 05204b7249
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B

View File

@ -35,6 +35,7 @@
#include "main.h" #include "main.h"
#include "../common/i18n.h" #include "../common/i18n.h"
#include "../common/host2net.h" #include "../common/host2net.h"
#include "../common/mbox-util.h"
/* Maximum length of packets to avoid excessive memory allocation. */ /* Maximum length of packets to avoid excessive memory allocation. */
@ -2064,12 +2065,20 @@ parse_signature (IOBUF inp, int pkttype, unsigned long pktlen,
p = parse_sig_subpkt (sig->hashed, SIGSUBPKT_SIGNERS_UID, &len); p = parse_sig_subpkt (sig->hashed, SIGSUBPKT_SIGNERS_UID, &len);
if (p && len) if (p && len)
{ {
char *mbox;
sig->signers_uid = try_make_printable_string (p, len, 0); sig->signers_uid = try_make_printable_string (p, len, 0);
if (!sig->signers_uid) if (!sig->signers_uid)
{ {
rc = gpg_error_from_syserror (); rc = gpg_error_from_syserror ();
goto leave; goto leave;
} }
mbox = mailbox_from_userid (sig->signers_uid);
if (mbox)
{
xfree (sig->signers_uid);
sig->signers_uid = mbox;
}
} }
p = parse_sig_subpkt (sig->hashed, SIGSUBPKT_NOTATION, NULL); p = parse_sig_subpkt (sig->hashed, SIGSUBPKT_NOTATION, NULL);