aboutsummaryrefslogtreecommitdiffstats
path: root/g10/keyid.c
diff options
context:
space:
mode:
authorDavid Shaw <[email protected]>2004-08-23 19:20:17 +0000
committerDavid Shaw <[email protected]>2004-08-23 19:20:17 +0000
commit10eb272a73c71d0803658d965ce70d9fdb0088f6 (patch)
tree12f307bb2ae091c6e14529721e4d52882b8398f5 /g10/keyid.c
parent* keydb.h, getkey.c (get_user_id_printable): Rename to get_user_id_native (diff)
downloadgnupg-10eb272a73c71d0803658d965ce70d9fdb0088f6.tar.gz
gnupg-10eb272a73c71d0803658d965ce70d9fdb0088f6.zip
* keyserver.c (keyserver_spawn): Show log line for what keyserver action
we are taking. * keyid.c (keystr): If printing a keyid that lacks the high 4 bytes, print the low 4 alone. (keystr_from_desc): Handle short keyids and warn on v3 fingerprints.
Diffstat (limited to '')
-rw-r--r--g10/keyid.c53
1 files changed, 34 insertions, 19 deletions
diff --git a/g10/keyid.c b/g10/keyid.c
index aa9ec0b5a..9d987179d 100644
--- a/g10/keyid.c
+++ b/g10/keyid.c
@@ -178,7 +178,10 @@ keystr(u32 *keyid)
break;
case KF_LONG:
- sprintf(keyid_str,"%08lX%08lX",(ulong)keyid[0],(ulong)keyid[1]);
+ if(keyid[0])
+ sprintf(keyid_str,"%08lX%08lX",(ulong)keyid[0],(ulong)keyid[1]);
+ else
+ sprintf(keyid_str,"%08lX",(ulong)keyid[1]);
break;
case KF_0xSHORT:
@@ -186,7 +189,10 @@ keystr(u32 *keyid)
break;
case KF_0xLONG:
- sprintf(keyid_str,"0x%08lX%08lX",(ulong)keyid[0],(ulong)keyid[1]);
+ if(keyid[0])
+ sprintf(keyid_str,"0x%08lX%08lX",(ulong)keyid[0],(ulong)keyid[1]);
+ else
+ sprintf(keyid_str,"0x%08lX",(ulong)keyid[1]);
break;
default:
@@ -215,25 +221,34 @@ keystr_from_sk(PKT_secret_key *sk)
const char *
keystr_from_desc(KEYDB_SEARCH_DESC *desc)
{
- if(desc->mode==KEYDB_SEARCH_MODE_LONG_KID)
- return keystr(desc->u.kid);
- else if(desc->mode==KEYDB_SEARCH_MODE_FPR20)
+ switch(desc->mode)
{
- u32 keyid[2];
-
- keyid[0] = (unsigned char)desc->u.fpr[12] << 24
- | (unsigned char)desc->u.fpr[13] << 16
- | (unsigned char)desc->u.fpr[14] << 8
- | (unsigned char)desc->u.fpr[15] ;
- keyid[1] = (unsigned char)desc->u.fpr[16] << 24
- | (unsigned char)desc->u.fpr[17] << 16
- | (unsigned char)desc->u.fpr[18] << 8
- | (unsigned char)desc->u.fpr[19] ;
-
- return keystr(keyid);
+ case KEYDB_SEARCH_MODE_LONG_KID:
+ case KEYDB_SEARCH_MODE_SHORT_KID:
+ return keystr(desc->u.kid);
+
+ case KEYDB_SEARCH_MODE_FPR20:
+ {
+ u32 keyid[2];
+
+ keyid[0] = (unsigned char)desc->u.fpr[12] << 24
+ | (unsigned char)desc->u.fpr[13] << 16
+ | (unsigned char)desc->u.fpr[14] << 8
+ | (unsigned char)desc->u.fpr[15] ;
+ keyid[1] = (unsigned char)desc->u.fpr[16] << 24
+ | (unsigned char)desc->u.fpr[17] << 16
+ | (unsigned char)desc->u.fpr[18] << 8
+ | (unsigned char)desc->u.fpr[19] ;
+
+ return keystr(keyid);
+ }
+
+ case KEYDB_SEARCH_MODE_FPR16:
+ return "?v3 fpr?";
+
+ default:
+ BUG();
}
- else
- BUG();
}
/****************