1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-10 13:04:23 +01:00

* getkey.c (fixup_uidnode, merge_selfsigs_main): Handle both expired

and revoked uids in fixup_uidnode().  No need to special case in
merge_selfsigs_main().  This also means that an expired uid will have
its selfsig tagged with chosen_selfsig.
This commit is contained in:
David Shaw 2005-06-08 13:12:57 +00:00
parent 2c9948c00a
commit 1b07e3723e
2 changed files with 16 additions and 12 deletions

View File

@ -1,3 +1,10 @@
2005-06-08 David Shaw <dshaw@jabberwocky.com>
* getkey.c (fixup_uidnode, merge_selfsigs_main): Handle both
expired and revoked uids in fixup_uidnode(). No need to special
case in merge_selfsigs_main(). This also means that an expired
uid will have its selfsig tagged with chosen_selfsig.
2005-06-07 David Shaw <dshaw@jabberwocky.com> 2005-06-07 David Shaw <dshaw@jabberwocky.com>
* options.h, g10.c (main), export.c (parse_export_options, * options.h, g10.c (main), export.c (parse_export_options,

View File

@ -1347,11 +1347,18 @@ fixup_uidnode ( KBNODE uidnode, KBNODE signode, u32 keycreated )
return; /* has been revoked */ return; /* has been revoked */
} }
uid->expiredate = sig->expiredate;
if(sig->flags.expired)
{
uid->is_expired = 1;
return; /* has expired */
}
uid->created = sig->timestamp; /* this one is okay */ uid->created = sig->timestamp; /* this one is okay */
uid->selfsigversion = sig->version; uid->selfsigversion = sig->version;
/* If we got this far, it's not expired :) */ /* If we got this far, it's not expired :) */
uid->is_expired = 0; uid->is_expired = 0;
uid->expiredate = sig->expiredate;
/* store the key flags in the helper variable for later processing */ /* store the key flags in the helper variable for later processing */
uid->help_key_usage=parse_key_usage(sig); uid->help_key_usage=parse_key_usage(sig);
@ -1652,19 +1659,9 @@ merge_selfsigs_main(KBNODE keyblock, int *r_revoked, struct revoke_info *rinfo)
* the same email address may become valid again (hired, * the same email address may become valid again (hired,
* fired, hired again). * fired, hired again).
*/ */
if(sig->flags.expired)
{
uidnode->pkt->pkt.user_id->is_expired=1;
signode = NULL;
}
else
{
uidnode->pkt->pkt.user_id->is_expired=0;
signode = k;
}
sigdate = sig->timestamp; sigdate = sig->timestamp;
uidnode->pkt->pkt.user_id->expiredate=sig->expiredate; signode = k;
if( sig->version > sigversion ) if( sig->version > sigversion )
sigversion = sig->version; sigversion = sig->version;
} }