mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-17 14:07:03 +01:00
gpg: Fix exporting of zero length user ID packets.
* g10/build-packet.c (do_user_id): Avoid indeterminate length header. -- We are able to import such user ids but when exporting them the exported data could not be imported again because the parser bails out on invalid keyrings. This is now fixed and should be backported. Note that in 1.4 and 2.0 this is only an issue for attribute packets. In 2.1 user IDs were also affected.a Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
23944d0249
commit
bb61191aad
@ -204,7 +204,12 @@ do_user_id( IOBUF out, int ctb, PKT_user_id *uid )
|
|||||||
{
|
{
|
||||||
if( uid->attrib_data )
|
if( uid->attrib_data )
|
||||||
{
|
{
|
||||||
write_header(out, ctb, uid->attrib_len);
|
/* We need to take special care of a user ID with a length of 0:
|
||||||
|
* Without forcing HDRLEN to 2 in this case an indeterminate length
|
||||||
|
* packet would be written which is not allowed. Note that we are
|
||||||
|
* always called with a CTB indicating an old packet header format,
|
||||||
|
* so that forcing a 2 octet header works. */
|
||||||
|
write_header2(out, ctb, uid->attrib_len, (uid->attrib_len? 0 : 2));
|
||||||
if( iobuf_write( out, uid->attrib_data, uid->attrib_len ) )
|
if( iobuf_write( out, uid->attrib_data, uid->attrib_len ) )
|
||||||
return G10ERR_WRITE_FILE;
|
return G10ERR_WRITE_FILE;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user