1
0
Fork 0
mirror of git://git.gnupg.org/gnupg.git synced 2025-07-14 21:47:19 +02:00

* packet.h, parse_packet (parse_key): Add is_primary flag for public keys

(it already exists for secret keys).

* keylist.c (print_capabilities): Only primary signing keys can certify
other keys.
This commit is contained in:
David Shaw 2002-10-03 17:40:10 +00:00
parent 27d526298b
commit 3f2d94179f
4 changed files with 23 additions and 3 deletions

View file

@ -301,13 +301,15 @@ static void
print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
{
unsigned int use = pk? pk->pubkey_usage : sk->pubkey_usage;
int primary = pk? pk->is_primary : sk->is_primary;
if ( use & PUBKEY_USAGE_ENC ) {
putchar ('e');
}
if ( use & PUBKEY_USAGE_SIG ) {
putchar ('s');
putchar ('c');
if(primary)
putchar ('c');
}
if ( keyblock ) { /* figure our the usable capabilities */
KBNODE k;
@ -321,7 +323,11 @@ print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
if ( pk->pubkey_usage & PUBKEY_USAGE_ENC )
enc = 1;
if ( pk->pubkey_usage & PUBKEY_USAGE_SIG )
sign = cert = 1;
{
sign = 1;
if(primary)
cert = 1;
}
}
}
else if ( k->pkt->pkttype == PKT_SECRET_KEY
@ -331,7 +337,11 @@ print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
if ( sk->pubkey_usage & PUBKEY_USAGE_ENC )
enc = 1;
if ( sk->pubkey_usage & PUBKEY_USAGE_SIG )
sign = cert = 1;
{
sign = 1;
if(primary)
cert = 1;
}
}
}
}