1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-04 12:21:31 +01:00

Add new option --with-keygrip

This commit is contained in:
Werner Koch 2010-10-08 11:11:08 +00:00
parent 002b30e75c
commit a78335c9ce
10 changed files with 75 additions and 5 deletions

View File

@ -1945,6 +1945,11 @@ obsolete; it does not harm to use it though.
Same as the command @option{--fingerprint} but changes only the format Same as the command @option{--fingerprint} but changes only the format
of the output and may be used together with another command. of the output and may be used together with another command.
@ifset gpgtwoone
@item --with-keygrip
@opindex with-keygrip
Include the keygrip in the key listings.
@end ifset
@end table @end table

View File

@ -554,6 +554,10 @@ This option is therefore useful to simply verify a certificate.
For standard key listings, also print the MD5 fingerprint of the For standard key listings, also print the MD5 fingerprint of the
certificate. certificate.
@item --with-keygrip
Include the keygrip in standard key listings. Note that the keygrip is
always listed in --with-colons mode.
@end table @end table
@c ******************************************* @c *******************************************

View File

@ -1,3 +1,10 @@
2010-10-08 Werner Koch <wk@g10code.com>
* gpg.c: Add option --with-keygrip.
* options.h (struct opt): Add WITH_KEYGRIP.
* keylist.c (list_keyblock_print, list_keyblock_colon): Implement
new option.
2010-10-06 Werner Koch <wk@g10code.com> 2010-10-06 Werner Koch <wk@g10code.com>
* import.c (transfer_secret_keys): Ignore missing key parameters. * import.c (transfer_secret_keys): Ignore missing key parameters.

View File

@ -166,6 +166,7 @@ enum cmd_and_opt_values
oNoAskCertLevel, oNoAskCertLevel,
oFingerprint, oFingerprint,
oWithFingerprint, oWithFingerprint,
oWithKeygrip,
oAnswerYes, oAnswerYes,
oAnswerNo, oAnswerNo,
oKeyring, oKeyring,
@ -669,6 +670,7 @@ static ARGPARSE_OPTS opts[] = {
ARGPARSE_s_n (oUtf8Strings, "utf8-strings", "@"), ARGPARSE_s_n (oUtf8Strings, "utf8-strings", "@"),
ARGPARSE_s_n (oNoUtf8Strings, "no-utf8-strings", "@"), ARGPARSE_s_n (oNoUtf8Strings, "no-utf8-strings", "@"),
ARGPARSE_s_n (oWithFingerprint, "with-fingerprint", "@"), ARGPARSE_s_n (oWithFingerprint, "with-fingerprint", "@"),
ARGPARSE_s_n (oWithKeygrip, "with-keygrip", "@"),
ARGPARSE_s_s (oDisableCipherAlgo, "disable-cipher-algo", "@"), ARGPARSE_s_s (oDisableCipherAlgo, "disable-cipher-algo", "@"),
ARGPARSE_s_s (oDisablePubkeyAlgo, "disable-pubkey-algo", "@"), ARGPARSE_s_s (oDisablePubkeyAlgo, "disable-pubkey-algo", "@"),
ARGPARSE_s_n (oAllowNonSelfsignedUID, "allow-non-selfsigned-uid", "@"), ARGPARSE_s_n (oAllowNonSelfsignedUID, "allow-non-selfsigned-uid", "@"),
@ -2279,6 +2281,10 @@ main (int argc, char **argv)
fpr_maybe_cmd = 1; fpr_maybe_cmd = 1;
break; break;
case oWithKeygrip:
opt.with_keygrip = 1;
break;
case oSecretKeyring: case oSecretKeyring:
/* Ignore this old option. */ /* Ignore this old option. */
break; break;

View File

@ -822,6 +822,17 @@ list_keyblock_print (KBNODE keyblock, int secret, int fpr, void *opaque)
if (fpr) if (fpr)
print_fingerprint (pk, 0); print_fingerprint (pk, 0);
if (opt.with_keygrip)
{
char *p;
if (!hexkeygrip_from_pk (pk, &p))
{
es_fprintf (es_stdout, " Keygrip = %s\n", p);
xfree (p);
}
}
/* FIXME: Change this function to take a PK and ask the agent: */ /* FIXME: Change this function to take a PK and ask the agent: */
/* if (secret) print_card_serialno (sk); */ /* if (secret) print_card_serialno (sk); */
@ -919,6 +930,16 @@ list_keyblock_print (KBNODE keyblock, int secret, int fpr, void *opaque)
/* if (secret) */ /* if (secret) */
/* print_card_serialno (sk2); */ /* print_card_serialno (sk2); */
} }
if (opt.with_keygrip)
{
char *p;
if (!hexkeygrip_from_pk (pk2, &p))
{
es_fprintf (es_stdout, " Keygrip = %s\n", p);
xfree (p);
}
}
if (opt.with_key_data) if (opt.with_key_data)
print_key_data (pk2); print_key_data (pk2);
} }
@ -1131,13 +1152,14 @@ list_keyblock_colon (KBNODE keyblock, int secret, int fpr)
print_revokers (pk); print_revokers (pk);
if (fpr) if (fpr)
print_fingerprint (pk, 0); print_fingerprint (pk, 0);
if (opt.with_key_data) if (opt.with_key_data || opt.with_keygrip)
{ {
if (!hexkeygrip_from_pk (pk, &p)) if (!hexkeygrip_from_pk (pk, &p))
{ {
es_fprintf (es_stdout, "grp:::::::::%s:\n", p); es_fprintf (es_stdout, "grp:::::::::%s:\n", p);
xfree (p); xfree (p);
} }
if (opt.with_key_data)
print_key_data (pk); print_key_data (pk);
} }
@ -1236,13 +1258,14 @@ list_keyblock_colon (KBNODE keyblock, int secret, int fpr)
es_putc ('\n', es_stdout); es_putc ('\n', es_stdout);
if (fpr > 1) if (fpr > 1)
print_fingerprint (pk2, 0); print_fingerprint (pk2, 0);
if (opt.with_key_data) if (opt.with_key_data || opt.with_keygrip)
{ {
if (!hexkeygrip_from_pk (pk2, &p)) if (!hexkeygrip_from_pk (pk2, &p))
{ {
es_fprintf (es_stdout, "grp:::::::::%s:\n", p); es_fprintf (es_stdout, "grp:::::::::%s:\n", p);
xfree (p); xfree (p);
} }
if (opt.with_key_data)
print_key_data (pk2); print_key_data (pk2);
} }
} }

View File

@ -59,7 +59,8 @@ struct
int check_sigs; /* check key signatures */ int check_sigs; /* check key signatures */
int with_colons; int with_colons;
int with_key_data; int with_key_data;
int with_fingerprint; /* opt --with-fingerprint active */ int with_fingerprint; /* Option --with-fingerprint active. */
int with_keygrip; /* Option --with-keygrip active. */
int fingerprint; /* list fingerprints */ int fingerprint; /* list fingerprints */
int list_sigs; /* list signatures */ int list_sigs; /* list signatures */
int no_armor; int no_armor;

View File

@ -1,3 +1,9 @@
2010-10-08 Werner Koch <wk@g10code.com>
* gpgsm.c: Add option --with-keygrip.
* gpgsm.h (struct opt): Add WITH_KEYGRIP.
* keylist.c (list_cert_std): Implement option.
2010-09-16 Werner Koch <wk@g10code.com> 2010-09-16 Werner Koch <wk@g10code.com>
* certchain.c (gpgsm_walk_cert_chain): Use GPG_ERR_MISSING_ISSUER_CERT. * certchain.c (gpgsm_walk_cert_chain): Use GPG_ERR_MISSING_ISSUER_CERT.

View File

@ -143,6 +143,7 @@ enum cmd_and_opt_values {
oWithFingerprint, oWithFingerprint,
oWithMD5Fingerprint, oWithMD5Fingerprint,
oWithKeygrip,
oAnswerYes, oAnswerYes,
oAnswerNo, oAnswerNo,
oKeyring, oKeyring,
@ -371,6 +372,7 @@ static ARGPARSE_OPTS opts[] = {
ARGPARSE_s_n (oWithEphemeralKeys, "with-ephemeral-keys", "@"), ARGPARSE_s_n (oWithEphemeralKeys, "with-ephemeral-keys", "@"),
ARGPARSE_s_n (oSkipVerify, "skip-verify", "@"), ARGPARSE_s_n (oSkipVerify, "skip-verify", "@"),
ARGPARSE_s_n (oWithFingerprint, "with-fingerprint", "@"), ARGPARSE_s_n (oWithFingerprint, "with-fingerprint", "@"),
ARGPARSE_s_n (oWithKeygrip, "with-keygrip", "@"),
ARGPARSE_s_s (oDisableCipherAlgo, "disable-cipher-algo", "@"), ARGPARSE_s_s (oDisableCipherAlgo, "disable-cipher-algo", "@"),
ARGPARSE_s_s (oDisablePubkeyAlgo, "disable-pubkey-algo", "@"), ARGPARSE_s_s (oDisablePubkeyAlgo, "disable-pubkey-algo", "@"),
ARGPARSE_s_n (oIgnoreTimeConflict, "ignore-time-conflict", "@"), ARGPARSE_s_n (oIgnoreTimeConflict, "ignore-time-conflict", "@"),
@ -1244,6 +1246,10 @@ main ( int argc, char **argv)
opt.fingerprint++; opt.fingerprint++;
break; break;
case oWithKeygrip:
opt.with_keygrip = 1;
break;
case oOptions: case oOptions:
/* config files may not be nested (silently ignore them) */ /* config files may not be nested (silently ignore them) */
if (!configfp) if (!configfp)

View File

@ -80,6 +80,8 @@ struct
int with_md5_fingerprint; /* Also print an MD5 fingerprint for int with_md5_fingerprint; /* Also print an MD5 fingerprint for
standard key listings. */ standard key listings. */
int with_keygrip; /* Option --with-keygrip active. */
int armor; /* force base64 armoring (see also ctrl.with_base64) */ int armor; /* force base64 armoring (see also ctrl.with_base64) */
int no_armor; /* don't try to figure out whether data is base64 armored*/ int no_armor; /* don't try to figure out whether data is base64 armored*/

View File

@ -1216,6 +1216,16 @@ list_cert_std (ctrl_t ctrl, ksba_cert_t cert, estream_t fp, int have_secret,
es_fprintf (fp, " fingerprint: %s\n", dn?dn:"error"); es_fprintf (fp, " fingerprint: %s\n", dn?dn:"error");
xfree (dn); xfree (dn);
if (opt.with_keygrip)
{
dn = gpgsm_get_keygrip_hexstring (cert);
if (dn)
{
es_fprintf (fp, " keygrip: %s\n", dn);
xfree (dn);
}
}
if (have_secret) if (have_secret)
{ {
char *cardsn; char *cardsn;