1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-02 12:01:32 +01:00

Fix bug#998.

This commit is contained in:
Werner Koch 2009-02-09 11:09:57 +00:00
parent d1c2e66fbc
commit 02890eedd8
4 changed files with 35 additions and 3 deletions

View File

@ -1,3 +1,9 @@
2009-02-09 Werner Koch <wk@g10code.com>
* keylist.c (print_capabilities): Take care of cert-only keys.
Fixes bug#998.
* keyedit.c (show_key_with_all_names_colon): Print the capabilities.
2009-01-26 Werner Koch <wk@g10code.com> 2009-01-26 Werner Koch <wk@g10code.com>
* card-util.c (card_status): Detect a Geldkarte. * card-util.c (card_status): Detect a Geldkarte.

View File

@ -2522,6 +2522,17 @@ show_key_with_all_names_colon (KBNODE keyblock)
&& !(opt.fast_list_mode || opt.no_expensive_trust_checks )) && !(opt.fast_list_mode || opt.no_expensive_trust_checks ))
putchar(get_ownertrust_info (pk)); putchar(get_ownertrust_info (pk));
putchar(':'); putchar(':');
putchar (':');
putchar (':');
/* Print capabilities. */
if ( (pk->pubkey_usage & PUBKEY_USAGE_ENC) )
putchar ('e');
if ( (pk->pubkey_usage & PUBKEY_USAGE_SIG) )
putchar ('s');
if ( (pk->pubkey_usage & PUBKEY_USAGE_CERT) )
putchar ('c');
if ( (pk->pubkey_usage & PUBKEY_USAGE_AUTH) )
putchar ('a');
putchar('\n'); putchar('\n');
print_fingerprint (pk, NULL, 0); print_fingerprint (pk, NULL, 0);

View File

@ -594,6 +594,7 @@ print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
if(pk || (sk && sk->protect.s2k.mode!=1001)) if(pk || (sk && sk->protect.s2k.mode!=1001))
{ {
unsigned int use = pk? pk->pubkey_usage : sk->pubkey_usage; unsigned int use = pk? pk->pubkey_usage : sk->pubkey_usage;
int c_printed = 0;
if ( use & PUBKEY_USAGE_ENC ) if ( use & PUBKEY_USAGE_ENC )
putchar ('e'); putchar ('e');
@ -602,9 +603,19 @@ print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
{ {
putchar ('s'); putchar ('s');
if( pk? pk->is_primary : sk->is_primary ) if( pk? pk->is_primary : sk->is_primary )
putchar ('c'); {
putchar ('c');
/* The PUBKEY_USAGE_CERT flag was introduced later and
we used to always print 'c' for a primary key. To
avoid any regression here we better track whether we
printed 'c' already. */
c_printed = 1;
}
} }
if ( (use & PUBKEY_USAGE_CERT) && !c_printed )
putchar ('c');
if ( (use & PUBKEY_USAGE_AUTH) ) if ( (use & PUBKEY_USAGE_AUTH) )
putchar ('a'); putchar ('a');
} }
@ -630,6 +641,8 @@ print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
if(pk->is_primary) if(pk->is_primary)
cert = 1; cert = 1;
} }
if ( pk->pubkey_usage & PUBKEY_USAGE_CERT )
cert = 1;
if ( (pk->pubkey_usage & PUBKEY_USAGE_AUTH) ) if ( (pk->pubkey_usage & PUBKEY_USAGE_AUTH) )
auth = 1; auth = 1;
} }
@ -647,6 +660,8 @@ print_capabilities (PKT_public_key *pk, PKT_secret_key *sk, KBNODE keyblock)
if(sk->is_primary) if(sk->is_primary)
cert = 1; cert = 1;
} }
if ( (sk->pubkey_usage & PUBKEY_USAGE_CERT) )
cert = 1;
if ( (sk->pubkey_usage & PUBKEY_USAGE_AUTH) ) if ( (sk->pubkey_usage & PUBKEY_USAGE_AUTH) )
auth = 1; auth = 1;
} }

View File

@ -893,7 +893,7 @@ main ( int argc, char **argv)
/* Note: If you change this default cipher algorithm , please /* Note: If you change this default cipher algorithm , please
remember to update the Gpgconflist entry as well. */ remember to update the Gpgconflist entry as well. */
opt.def_cipher_algoid = "AES"; /*des-EDE3-CBC*/ opt.def_cipher_algoid = "3DES"; /*des-EDE3-CBC*/
opt.homedir = default_homedir (); opt.homedir = default_homedir ();
@ -1607,7 +1607,7 @@ main ( int argc, char **argv)
#ifndef HAVE_W32_SYSTEM #ifndef HAVE_W32_SYSTEM
printf ("prefer-system-dirmngr:%lu:\n", GC_OPT_FLAG_NONE); printf ("prefer-system-dirmngr:%lu:\n", GC_OPT_FLAG_NONE);
#endif #endif
printf ("cipher-algo:%lu:\"AES:\n", GC_OPT_FLAG_DEFAULT); printf ("cipher-algo:%lu:\"3DES:\n", GC_OPT_FLAG_DEFAULT);
printf ("p12-charset:%lu:\n", GC_OPT_FLAG_DEFAULT); printf ("p12-charset:%lu:\n", GC_OPT_FLAG_DEFAULT);
printf ("default-key:%lu:\n", GC_OPT_FLAG_DEFAULT); printf ("default-key:%lu:\n", GC_OPT_FLAG_DEFAULT);
printf ("encrypt-to:%lu:\n", GC_OPT_FLAG_DEFAULT); printf ("encrypt-to:%lu:\n", GC_OPT_FLAG_DEFAULT);