mirror of
git://git.gnupg.org/gnupg.git
synced 2024-12-31 11:41:32 +01:00
gpg: Add some debugging output.
-- Signed-off-by: Neal H. Walfield <neal@g10code.com>
This commit is contained in:
parent
11ec4785df
commit
8f6099ac51
12
g10/gpg.c
12
g10/gpg.c
@ -2124,6 +2124,12 @@ check_user_ids (strlist_t *sp,
|
|||||||
default: log_bug ("Unsupport option: %d\n", t->flags >> 2);
|
default: log_bug ("Unsupport option: %d\n", t->flags >> 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
{
|
||||||
|
log_debug ("\n");
|
||||||
|
log_debug ("%s: Checking %s=%s\n", __func__, option, t->d);
|
||||||
|
}
|
||||||
|
|
||||||
err = classify_user_id (t->d, &desc, 1);
|
err = classify_user_id (t->d, &desc, 1);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
@ -2153,6 +2159,9 @@ check_user_ids (strlist_t *sp,
|
|||||||
err = keydb_search (hd, &desc, 1, NULL);
|
err = keydb_search (hd, &desc, 1, NULL);
|
||||||
if (gpg_err_code (err) == GPG_ERR_NOT_FOUND)
|
if (gpg_err_code (err) == GPG_ERR_NOT_FOUND)
|
||||||
{
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: '%s' not found.\n", __func__, t->d);
|
||||||
|
|
||||||
if (error_if_not_found)
|
if (error_if_not_found)
|
||||||
{
|
{
|
||||||
if (! rc)
|
if (! rc)
|
||||||
@ -2195,6 +2204,9 @@ check_user_ids (strlist_t *sp,
|
|||||||
release_kbnode (kb);
|
release_kbnode (kb);
|
||||||
|
|
||||||
/* Continue the search. */
|
/* Continue the search. */
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: Check for duplicates for %s='%s'\n",
|
||||||
|
__func__, option, t->d);
|
||||||
err = keydb_search (hd, &desc, 1, NULL);
|
err = keydb_search (hd, &desc, 1, NULL);
|
||||||
if (! err)
|
if (! err)
|
||||||
/* Another result! */
|
/* Another result! */
|
||||||
|
22
g10/keydb.c
22
g10/keydb.c
@ -1692,7 +1692,16 @@ keydb_search (KEYDB_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
while ((rc == -1 || gpg_err_code (rc) == GPG_ERR_EOF)
|
while ((rc == -1 || gpg_err_code (rc) == GPG_ERR_EOF)
|
||||||
&& hd->current >= 0 && hd->current < hd->used)
|
&& hd->current >= 0 && hd->current < hd->used)
|
||||||
{
|
{
|
||||||
switch (hd->active[hd->current].type)
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: searching %s (resource %d of %d)\n",
|
||||||
|
__func__,
|
||||||
|
hd->active[hd->current].type == KEYDB_RESOURCE_TYPE_KEYRING
|
||||||
|
? "keyring"
|
||||||
|
: (hd->active[hd->current].type == KEYDB_RESOURCE_TYPE_KEYBOX
|
||||||
|
? "keybox" : "unknown type"),
|
||||||
|
hd->current, hd->used);
|
||||||
|
|
||||||
|
switch (hd->active[hd->current].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
BUG(); /* we should never see it here */
|
BUG(); /* we should never see it here */
|
||||||
@ -1707,6 +1716,17 @@ keydb_search (KEYDB_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
descindex, &hd->skipped_long_blobs);
|
descindex, &hd->skipped_long_blobs);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: searched %s (resource %d of %d) => %s\n",
|
||||||
|
__func__,
|
||||||
|
hd->active[hd->current].type == KEYDB_RESOURCE_TYPE_KEYRING
|
||||||
|
? "keyring"
|
||||||
|
: (hd->active[hd->current].type == KEYDB_RESOURCE_TYPE_KEYBOX
|
||||||
|
? "keybox" : "unknown type"),
|
||||||
|
hd->current, hd->used,
|
||||||
|
rc == -1 ? "EOF" : gpg_strerror (rc));
|
||||||
|
|
||||||
if (rc == -1 || gpg_err_code (rc) == GPG_ERR_EOF)
|
if (rc == -1 || gpg_err_code (rc) == GPG_ERR_EOF)
|
||||||
{
|
{
|
||||||
/* EOF -> switch to next resource */
|
/* EOF -> switch to next resource */
|
||||||
|
@ -699,29 +699,51 @@ prepare_search (KEYRING_HANDLE hd)
|
|||||||
/* If the last key was a legacy key, we simply ignore the error so that
|
/* If the last key was a legacy key, we simply ignore the error so that
|
||||||
we can easily use search_next. */
|
we can easily use search_next. */
|
||||||
if (gpg_err_code (hd->current.error) == GPG_ERR_LEGACY_KEY)
|
if (gpg_err_code (hd->current.error) == GPG_ERR_LEGACY_KEY)
|
||||||
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: last error was GPG_ERR_LEGACY_KEY, clearing\n",
|
||||||
|
__func__);
|
||||||
hd->current.error = 0;
|
hd->current.error = 0;
|
||||||
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: returning last error: %s\n",
|
||||||
|
__func__, gpg_strerror (hd->current.error));
|
||||||
return hd->current.error; /* still in error state */
|
return hd->current.error; /* still in error state */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hd->current.kr && !hd->current.eof) {
|
if (hd->current.kr && !hd->current.eof) {
|
||||||
if ( !hd->current.iobuf )
|
if ( !hd->current.iobuf )
|
||||||
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: missing iobuf!\n", __func__);
|
||||||
return GPG_ERR_GENERAL; /* Position invalid after a modify. */
|
return GPG_ERR_GENERAL; /* Position invalid after a modify. */
|
||||||
|
}
|
||||||
return 0; /* okay */
|
return 0; /* okay */
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!hd->current.kr && hd->current.eof)
|
if (!hd->current.kr && hd->current.eof)
|
||||||
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: EOF!\n", __func__);
|
||||||
return -1; /* still EOF */
|
return -1; /* still EOF */
|
||||||
|
}
|
||||||
|
|
||||||
if (!hd->current.kr) { /* start search with first keyring */
|
if (!hd->current.kr) { /* start search with first keyring */
|
||||||
hd->current.kr = hd->resource;
|
hd->current.kr = hd->resource;
|
||||||
if (!hd->current.kr) {
|
if (!hd->current.kr) {
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: keyring not available!\n", __func__);
|
||||||
hd->current.eof = 1;
|
hd->current.eof = 1;
|
||||||
return -1; /* keyring not available */
|
return -1; /* keyring not available */
|
||||||
}
|
}
|
||||||
assert (!hd->current.iobuf);
|
assert (!hd->current.iobuf);
|
||||||
}
|
}
|
||||||
else { /* EOF */
|
else { /* EOF */
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: EOF\n", __func__);
|
||||||
iobuf_close (hd->current.iobuf);
|
iobuf_close (hd->current.iobuf);
|
||||||
hd->current.iobuf = NULL;
|
hd->current.iobuf = NULL;
|
||||||
hd->current.kr = NULL;
|
hd->current.kr = NULL;
|
||||||
@ -988,22 +1010,44 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: need_uid = %d; need_words = %d; need_keyid = %d; need_fpr = %d; any_skip = %d\n",
|
||||||
|
__func__, need_uid, need_words, need_keyid, need_fpr, any_skip);
|
||||||
|
|
||||||
rc = prepare_search (hd);
|
rc = prepare_search (hd);
|
||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: prepare_search failed: %s (%d)\n",
|
||||||
|
__func__, gpg_strerror (rc), gpg_err_code (rc));
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
use_offtbl = !!kr_offtbl;
|
use_offtbl = !!kr_offtbl;
|
||||||
if (!use_offtbl)
|
if (!use_offtbl)
|
||||||
;
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: no offset table.\n", __func__);
|
||||||
|
}
|
||||||
else if (!kr_offtbl_ready)
|
else if (!kr_offtbl_ready)
|
||||||
need_keyid = 1;
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: initializing offset table. (need_keyid: %d => 1)\n",
|
||||||
|
__func__, need_keyid);
|
||||||
|
need_keyid = 1;
|
||||||
|
}
|
||||||
else if (ndesc == 1 && desc[0].mode == KEYDB_SEARCH_MODE_LONG_KID)
|
else if (ndesc == 1 && desc[0].mode == KEYDB_SEARCH_MODE_LONG_KID)
|
||||||
{
|
{
|
||||||
struct off_item *oi;
|
struct off_item *oi;
|
||||||
|
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: look up by long key id, checking cache\n", __func__);
|
||||||
|
|
||||||
oi = lookup_offset_hash_table (kr_offtbl, desc[0].u.kid);
|
oi = lookup_offset_hash_table (kr_offtbl, desc[0].u.kid);
|
||||||
if (!oi)
|
if (!oi)
|
||||||
{ /* We know that we don't have this key */
|
{ /* We know that we don't have this key */
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: cache says not present\n", __func__);
|
||||||
hd->found.kr = NULL;
|
hd->found.kr = NULL;
|
||||||
hd->current.eof = 1;
|
hd->current.eof = 1;
|
||||||
return -1;
|
return -1;
|
||||||
@ -1047,6 +1091,9 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
pk_no = uid_no = 0;
|
pk_no = uid_no = 0;
|
||||||
initial_skip = 1; /* skip until we see the start of a keyblock */
|
initial_skip = 1; /* skip until we see the start of a keyblock */
|
||||||
scanned_from_start = iobuf_tell (hd->current.iobuf) == 0;
|
scanned_from_start = iobuf_tell (hd->current.iobuf) == 0;
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: %ssearching from start of resource.\n",
|
||||||
|
__func__, scanned_from_start ? "" : "not ");
|
||||||
while (!(rc=search_packet (hd->current.iobuf, &pkt, &offset, need_uid)))
|
while (!(rc=search_packet (hd->current.iobuf, &pkt, &offset, need_uid)))
|
||||||
{
|
{
|
||||||
byte afp[MAX_FINGERPRINT_LEN];
|
byte afp[MAX_FINGERPRINT_LEN];
|
||||||
@ -1143,6 +1190,10 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
free_packet (&pkt);
|
free_packet (&pkt);
|
||||||
continue;
|
continue;
|
||||||
found:
|
found:
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: packet starting at offset %zx matched descriptor %zd\n",
|
||||||
|
__func__, offset, n);
|
||||||
|
|
||||||
/* Record which desc we matched on. Note this value is only
|
/* Record which desc we matched on. Note this value is only
|
||||||
meaningful if this function returns with no errors. */
|
meaningful if this function returns with no errors. */
|
||||||
if(descindex)
|
if(descindex)
|
||||||
@ -1151,7 +1202,12 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
{
|
{
|
||||||
if (desc[n].skipfnc
|
if (desc[n].skipfnc
|
||||||
&& desc[n].skipfnc (desc[n].skipfncvalue, aki, uid_no))
|
&& desc[n].skipfnc (desc[n].skipfncvalue, aki, uid_no))
|
||||||
break;
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: skipping match: desc %zd's skip function returned TRUE\n",
|
||||||
|
__func__, n);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (n == ndesc)
|
if (n == ndesc)
|
||||||
goto real_found;
|
goto real_found;
|
||||||
@ -1160,6 +1216,8 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
real_found:
|
real_found:
|
||||||
if (!rc)
|
if (!rc)
|
||||||
{
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: returing success\n", __func__);
|
||||||
hd->found.offset = main_offset;
|
hd->found.offset = main_offset;
|
||||||
hd->found.kr = hd->current.kr;
|
hd->found.kr = hd->current.kr;
|
||||||
hd->found.pk_no = pk? pk_no : 0;
|
hd->found.pk_no = pk? pk_no : 0;
|
||||||
@ -1167,6 +1225,9 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
}
|
}
|
||||||
else if (rc == -1)
|
else if (rc == -1)
|
||||||
{
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: no matches (EOF)\n", __func__);
|
||||||
|
|
||||||
hd->current.eof = 1;
|
hd->current.eof = 1;
|
||||||
/* if we scanned all keyrings, we are sure that
|
/* if we scanned all keyrings, we are sure that
|
||||||
* all known key IDs are in our offtbl, mark that. */
|
* all known key IDs are in our offtbl, mark that. */
|
||||||
@ -1195,7 +1256,12 @@ keyring_search (KEYRING_HANDLE hd, KEYDB_SEARCH_DESC *desc,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
hd->current.error = rc;
|
{
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
log_debug ("%s: error encountered during search: %s (%d)\n",
|
||||||
|
__func__, gpg_strerror (rc), rc);
|
||||||
|
hd->current.error = rc;
|
||||||
|
}
|
||||||
|
|
||||||
free_packet(&pkt);
|
free_packet(&pkt);
|
||||||
set_packet_list_mode(save_mode);
|
set_packet_list_mode(save_mode);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user