mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
sm: Add a couple of debug calls to the keydb module.
* sm/gpgsm.h (DBG_CLOCK_VALUE, DBG_CLOCK): New. (DBG_LOOKUP_VALUE, DBG_LOOKUP): New. * sm/gpgsm.c: new debug flags "lookup" and "clock" * sm/keydb.c: Add log_clock calls to most functions. (keydb_search_desc_dump): New. (keydb_search) [DBG_LOOKUP]: Print descrh decription. * sm/keylist.c (list_cert_std): Flush FP in debug mode to better syncronize the output with the debug output -- Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
62c29af632
commit
6e041b7b35
@ -430,6 +430,8 @@ static struct debug_flags_s debug_flags [] =
|
|||||||
{ DBG_MEMSTAT_VALUE, "memstat" },
|
{ DBG_MEMSTAT_VALUE, "memstat" },
|
||||||
{ DBG_HASHING_VALUE, "hashing" },
|
{ DBG_HASHING_VALUE, "hashing" },
|
||||||
{ DBG_IPC_VALUE , "ipc" },
|
{ DBG_IPC_VALUE , "ipc" },
|
||||||
|
{ DBG_CLOCK_VALUE , "clock" },
|
||||||
|
{ DBG_LOOKUP_VALUE , "lookup" },
|
||||||
{ 0, NULL }
|
{ 0, NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -175,6 +175,8 @@ struct
|
|||||||
#define DBG_MEMSTAT_VALUE 128 /* show memory statistics */
|
#define DBG_MEMSTAT_VALUE 128 /* show memory statistics */
|
||||||
#define DBG_HASHING_VALUE 512 /* debug hashing operations */
|
#define DBG_HASHING_VALUE 512 /* debug hashing operations */
|
||||||
#define DBG_IPC_VALUE 1024 /* debug assuan communication */
|
#define DBG_IPC_VALUE 1024 /* debug assuan communication */
|
||||||
|
#define DBG_CLOCK_VALUE 4096
|
||||||
|
#define DBG_LOOKUP_VALUE 8192 /* debug the key lookup */
|
||||||
|
|
||||||
#define DBG_X509 (opt.debug & DBG_X509_VALUE)
|
#define DBG_X509 (opt.debug & DBG_X509_VALUE)
|
||||||
#define DBG_CRYPTO (opt.debug & DBG_CRYPTO_VALUE)
|
#define DBG_CRYPTO (opt.debug & DBG_CRYPTO_VALUE)
|
||||||
@ -182,6 +184,8 @@ struct
|
|||||||
#define DBG_CACHE (opt.debug & DBG_CACHE_VALUE)
|
#define DBG_CACHE (opt.debug & DBG_CACHE_VALUE)
|
||||||
#define DBG_HASHING (opt.debug & DBG_HASHING_VALUE)
|
#define DBG_HASHING (opt.debug & DBG_HASHING_VALUE)
|
||||||
#define DBG_IPC (opt.debug & DBG_IPC_VALUE)
|
#define DBG_IPC (opt.debug & DBG_IPC_VALUE)
|
||||||
|
#define DBG_CLOCK (opt.debug & DBG_CLOCK_VALUE)
|
||||||
|
#define DBG_LOOKUP (opt.debug & DBG_LOOKUP_VALUE)
|
||||||
|
|
||||||
/* Forward declaration for an object defined in server.c */
|
/* Forward declaration for an object defined in server.c */
|
||||||
struct server_local_s;
|
struct server_local_s;
|
||||||
|
260
sm/keydb.c
260
sm/keydb.c
@ -23,7 +23,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <assert.h>
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
@ -401,11 +400,14 @@ keydb_new (void)
|
|||||||
KEYDB_HANDLE hd;
|
KEYDB_HANDLE hd;
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter\n", __func__);
|
||||||
|
|
||||||
hd = xcalloc (1, sizeof *hd);
|
hd = xcalloc (1, sizeof *hd);
|
||||||
hd->found = -1;
|
hd->found = -1;
|
||||||
hd->saved_found = -1;
|
hd->saved_found = -1;
|
||||||
|
|
||||||
assert (used_resources <= MAX_KEYDB_RESOURCES);
|
log_assert (used_resources <= MAX_KEYDB_RESOURCES);
|
||||||
for (i=j=0; i < used_resources; i++)
|
for (i=j=0; i < used_resources; i++)
|
||||||
{
|
{
|
||||||
switch (all_resources[i].type)
|
switch (all_resources[i].type)
|
||||||
@ -428,6 +430,8 @@ keydb_new (void)
|
|||||||
hd->used = j;
|
hd->used = j;
|
||||||
|
|
||||||
active_handles++;
|
active_handles++;
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (hd=%p)\n", __func__, hd);
|
||||||
return hd;
|
return hd;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -438,7 +442,11 @@ keydb_release (KEYDB_HANDLE hd)
|
|||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return;
|
return;
|
||||||
assert (active_handles > 0);
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
|
log_assert (active_handles > 0);
|
||||||
active_handles--;
|
active_handles--;
|
||||||
|
|
||||||
hd->keep_lock = 0;
|
hd->keep_lock = 0;
|
||||||
@ -455,7 +463,9 @@ keydb_release (KEYDB_HANDLE hd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
xfree (hd);
|
xfree (hd);
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave\n", __func__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -537,10 +547,14 @@ keydb_lock (KEYDB_HANDLE hd)
|
|||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_HANDLE);
|
return gpg_error (GPG_ERR_INV_HANDLE);
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
err = lock_all (hd);
|
err = lock_all (hd);
|
||||||
if (!err)
|
if (!err)
|
||||||
hd->keep_lock = 1;
|
hd->keep_lock = 1;
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -637,6 +651,8 @@ keydb_push_found_state (KEYDB_HANDLE hd)
|
|||||||
|
|
||||||
hd->saved_found = hd->found;
|
hd->saved_found = hd->found;
|
||||||
hd->found = -1;
|
hd->found = -1;
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: done (hd=%p)\n", __func__, hd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -660,6 +676,8 @@ keydb_pop_found_state (KEYDB_HANDLE hd)
|
|||||||
keybox_pop_found_state (hd->active[hd->found].u.kr);
|
keybox_pop_found_state (hd->active[hd->found].u.kr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: done (hd=%p)\n", __func__, hd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -677,9 +695,16 @@ keydb_get_cert (KEYDB_HANDLE hd, ksba_cert_t *r_cert)
|
|||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
|
|
||||||
if ( hd->found < 0 || hd->found >= hd->used)
|
if (DBG_CLOCK)
|
||||||
return -1; /* nothing found */
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
|
if ( hd->found < 0 || hd->found >= hd->used)
|
||||||
|
{
|
||||||
|
rc = -1; /* nothing found */
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = GPG_ERR_BUG;
|
||||||
switch (hd->active[hd->found].type)
|
switch (hd->active[hd->found].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
@ -690,9 +715,13 @@ keydb_get_cert (KEYDB_HANDLE hd, ksba_cert_t *r_cert)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
leave:
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (rc=%d)\n", __func__, rc);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Return a flag of the last found object. WHICH is the flag requested;
|
/* Return a flag of the last found object. WHICH is the flag requested;
|
||||||
it should be one of the KEYBOX_FLAG_ values. If the operation is
|
it should be one of the KEYBOX_FLAG_ values. If the operation is
|
||||||
successful, the flag value will be stored at the address given by
|
successful, the flag value will be stored at the address given by
|
||||||
@ -700,14 +729,21 @@ keydb_get_cert (KEYDB_HANDLE hd, ksba_cert_t *r_cert)
|
|||||||
gpg_error_t
|
gpg_error_t
|
||||||
keydb_get_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int *value)
|
keydb_get_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int *value)
|
||||||
{
|
{
|
||||||
int err = 0;
|
gpg_error_t err;
|
||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
|
|
||||||
if ( hd->found < 0 || hd->found >= hd->used)
|
if (DBG_CLOCK)
|
||||||
return gpg_error (GPG_ERR_NOTHING_FOUND);
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
|
if ( hd->found < 0 || hd->found >= hd->used)
|
||||||
|
{
|
||||||
|
err = gpg_error (GPG_ERR_NOTHING_FOUND);
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = gpg_error (GPG_ERR_BUG);
|
||||||
switch (hd->active[hd->found].type)
|
switch (hd->active[hd->found].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
@ -718,9 +754,13 @@ keydb_get_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int *value)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
leave:
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Set a flag of the last found object. WHICH is the flag to be set; it
|
/* Set a flag of the last found object. WHICH is the flag to be set; it
|
||||||
should be one of the KEYBOX_FLAG_ values. If the operation is
|
should be one of the KEYBOX_FLAG_ values. If the operation is
|
||||||
successful, the flag value will be stored in the keybox. Note,
|
successful, the flag value will be stored in the keybox. Note,
|
||||||
@ -730,16 +770,25 @@ keydb_get_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int *value)
|
|||||||
gpg_error_t
|
gpg_error_t
|
||||||
keydb_set_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int value)
|
keydb_set_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int value)
|
||||||
{
|
{
|
||||||
int err = 0;
|
gpg_error_t err = 0;
|
||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
if ( hd->found < 0 || hd->found >= hd->used)
|
if ( hd->found < 0 || hd->found >= hd->used)
|
||||||
return gpg_error (GPG_ERR_NOTHING_FOUND);
|
{
|
||||||
|
err = gpg_error (GPG_ERR_NOTHING_FOUND);
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
if (!hd->locked)
|
if (!hd->locked)
|
||||||
return gpg_error (GPG_ERR_NOT_LOCKED);
|
{
|
||||||
|
err = gpg_error (GPG_ERR_NOT_LOCKED);
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
switch (hd->active[hd->found].type)
|
switch (hd->active[hd->found].type)
|
||||||
{
|
{
|
||||||
@ -751,16 +800,19 @@ keydb_set_flags (KEYDB_HANDLE hd, int which, int idx, unsigned int value)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
leave:
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Insert a new Certificate into one of the resources.
|
* Insert a new Certificate into one of the resources.
|
||||||
*/
|
*/
|
||||||
int
|
gpg_error_t
|
||||||
keydb_insert_cert (KEYDB_HANDLE hd, ksba_cert_t cert)
|
keydb_insert_cert (KEYDB_HANDLE hd, ksba_cert_t cert)
|
||||||
{
|
{
|
||||||
int rc = -1;
|
gpg_error_t err;
|
||||||
int idx;
|
int idx;
|
||||||
unsigned char digest[20];
|
unsigned char digest[20];
|
||||||
|
|
||||||
@ -770,103 +822,136 @@ keydb_insert_cert (KEYDB_HANDLE hd, ksba_cert_t cert)
|
|||||||
if (opt.dry_run)
|
if (opt.dry_run)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
if ( hd->found >= 0 && hd->found < hd->used)
|
if ( hd->found >= 0 && hd->found < hd->used)
|
||||||
idx = hd->found;
|
idx = hd->found;
|
||||||
else if ( hd->current >= 0 && hd->current < hd->used)
|
else if ( hd->current >= 0 && hd->current < hd->used)
|
||||||
idx = hd->current;
|
idx = hd->current;
|
||||||
else
|
else
|
||||||
return gpg_error (GPG_ERR_GENERAL);
|
{
|
||||||
|
err = gpg_error (GPG_ERR_GENERAL);
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
if (!hd->locked)
|
if (!hd->locked)
|
||||||
return gpg_error (GPG_ERR_NOT_LOCKED);
|
{
|
||||||
|
err = gpg_error (GPG_ERR_NOT_LOCKED);
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
gpgsm_get_fingerprint (cert, GCRY_MD_SHA1, digest, NULL); /* kludge*/
|
gpgsm_get_fingerprint (cert, GCRY_MD_SHA1, digest, NULL); /* kludge*/
|
||||||
|
|
||||||
|
err = gpg_error (GPG_ERR_BUG);
|
||||||
switch (hd->active[idx].type)
|
switch (hd->active[idx].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
rc = gpg_error (GPG_ERR_GENERAL);
|
err = gpg_error (GPG_ERR_GENERAL);
|
||||||
break;
|
break;
|
||||||
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
||||||
rc = keybox_insert_cert (hd->active[idx].u.kr, cert, digest);
|
err = keybox_insert_cert (hd->active[idx].u.kr, cert, digest);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock_all (hd);
|
unlock_all (hd);
|
||||||
return rc;
|
|
||||||
|
leave:
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* Update the current keyblock with KB. */
|
/* Update the current keyblock with KB. */
|
||||||
int
|
/* Note: This function is currently not called. */
|
||||||
|
gpg_error_t
|
||||||
keydb_update_cert (KEYDB_HANDLE hd, ksba_cert_t cert)
|
keydb_update_cert (KEYDB_HANDLE hd, ksba_cert_t cert)
|
||||||
{
|
{
|
||||||
int rc = 0;
|
gpg_error_t err;
|
||||||
unsigned char digest[20];
|
unsigned char digest[20];
|
||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
|
|
||||||
if ( hd->found < 0 || hd->found >= hd->used)
|
if ( hd->found < 0 || hd->found >= hd->used)
|
||||||
return -1; /* nothing found */
|
return gpg_error (GPG_ERR_NOT_FOUND);
|
||||||
|
|
||||||
if (opt.dry_run)
|
if (opt.dry_run)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
rc = lock_all (hd);
|
if (DBG_CLOCK)
|
||||||
if (rc)
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
return rc;
|
|
||||||
|
err = lock_all (hd);
|
||||||
|
if (err)
|
||||||
|
goto leave;
|
||||||
|
|
||||||
gpgsm_get_fingerprint (cert, GCRY_MD_SHA1, digest, NULL); /* kludge*/
|
gpgsm_get_fingerprint (cert, GCRY_MD_SHA1, digest, NULL); /* kludge*/
|
||||||
|
|
||||||
|
err = gpg_error (GPG_ERR_BUG);
|
||||||
switch (hd->active[hd->found].type)
|
switch (hd->active[hd->found].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
rc = gpg_error (GPG_ERR_GENERAL); /* oops */
|
err = gpg_error (GPG_ERR_GENERAL); /* oops */
|
||||||
break;
|
break;
|
||||||
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
||||||
rc = keybox_update_cert (hd->active[hd->found].u.kr, cert, digest);
|
err = keybox_update_cert (hd->active[hd->found].u.kr, cert, digest);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock_all (hd);
|
unlock_all (hd);
|
||||||
return rc;
|
leave:
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The current keyblock or cert will be deleted.
|
* The current keyblock or cert will be deleted.
|
||||||
*/
|
*/
|
||||||
int
|
gpg_error_t
|
||||||
keydb_delete (KEYDB_HANDLE hd)
|
keydb_delete (KEYDB_HANDLE hd)
|
||||||
{
|
{
|
||||||
int rc = -1;
|
gpg_error_t err;
|
||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
|
|
||||||
if ( hd->found < 0 || hd->found >= hd->used)
|
if ( hd->found < 0 || hd->found >= hd->used)
|
||||||
return -1; /* nothing found */
|
return gpg_error (GPG_ERR_NOT_FOUND);
|
||||||
|
|
||||||
if( opt.dry_run )
|
if (opt.dry_run)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (!hd->locked)
|
if (DBG_CLOCK)
|
||||||
return gpg_error (GPG_ERR_NOT_LOCKED);
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
|
if (!hd->locked)
|
||||||
|
{
|
||||||
|
err = gpg_error (GPG_ERR_NOT_LOCKED);
|
||||||
|
goto leave;
|
||||||
|
}
|
||||||
|
|
||||||
|
err = gpg_error (GPG_ERR_BUG);
|
||||||
switch (hd->active[hd->found].type)
|
switch (hd->active[hd->found].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
rc = gpg_error (GPG_ERR_GENERAL);
|
err = gpg_error (GPG_ERR_GENERAL);
|
||||||
break;
|
break;
|
||||||
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
||||||
rc = keybox_delete (hd->active[hd->found].u.kr);
|
err = keybox_delete (hd->active[hd->found].u.kr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
unlock_all (hd);
|
unlock_all (hd);
|
||||||
return rc;
|
|
||||||
|
leave:
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -939,29 +1024,92 @@ keydb_rebuild_caches (void)
|
|||||||
gpg_error_t
|
gpg_error_t
|
||||||
keydb_search_reset (KEYDB_HANDLE hd)
|
keydb_search_reset (KEYDB_HANDLE hd)
|
||||||
{
|
{
|
||||||
|
gpg_error_t err = 0;
|
||||||
int i;
|
int i;
|
||||||
gpg_error_t rc = 0;
|
|
||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
hd->current = 0;
|
hd->current = 0;
|
||||||
hd->found = -1;
|
hd->found = -1;
|
||||||
/* and reset all resources */
|
/* and reset all resources */
|
||||||
for (i=0; !rc && i < hd->used; i++)
|
for (i=0; !err && i < hd->used; i++)
|
||||||
{
|
{
|
||||||
switch (hd->active[i].type)
|
switch (hd->active[i].type)
|
||||||
{
|
{
|
||||||
case KEYDB_RESOURCE_TYPE_NONE:
|
case KEYDB_RESOURCE_TYPE_NONE:
|
||||||
break;
|
break;
|
||||||
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
case KEYDB_RESOURCE_TYPE_KEYBOX:
|
||||||
rc = keybox_search_reset (hd->active[i].u.kr);
|
err = keybox_search_reset (hd->active[i].u.kr);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return rc;
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (err=%s)\n", __func__, gpg_strerror (err));
|
||||||
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
char *
|
||||||
|
keydb_search_desc_dump (struct keydb_search_desc *desc)
|
||||||
|
{
|
||||||
|
char *fpr;
|
||||||
|
char *result;
|
||||||
|
|
||||||
|
switch (desc->mode)
|
||||||
|
{
|
||||||
|
case KEYDB_SEARCH_MODE_EXACT:
|
||||||
|
return xasprintf ("EXACT: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_SUBSTR:
|
||||||
|
return xasprintf ("SUBSTR: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_MAIL:
|
||||||
|
return xasprintf ("MAIL: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_MAILSUB:
|
||||||
|
return xasprintf ("MAILSUB: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_MAILEND:
|
||||||
|
return xasprintf ("MAILEND: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_WORDS:
|
||||||
|
return xasprintf ("WORDS: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_SHORT_KID:
|
||||||
|
return xasprintf ("SHORT_KID: '%08lX'", (ulong)desc->u.kid[1]);
|
||||||
|
case KEYDB_SEARCH_MODE_LONG_KID:
|
||||||
|
return xasprintf ("LONG_KID: '%08lX%08lX'",
|
||||||
|
(ulong)desc->u.kid[0], (ulong)desc->u.kid[1]);
|
||||||
|
case KEYDB_SEARCH_MODE_FPR:
|
||||||
|
fpr = bin2hexcolon (desc->u.fpr, desc->fprlen, NULL);
|
||||||
|
result = xasprintf ("FPR%02d: '%s'", desc->fprlen, fpr);
|
||||||
|
xfree (fpr);
|
||||||
|
return result;
|
||||||
|
case KEYDB_SEARCH_MODE_ISSUER:
|
||||||
|
return xasprintf ("ISSUER: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_ISSUER_SN:
|
||||||
|
return xasprintf ("ISSUER_SN: '%*s'",
|
||||||
|
(int) (desc->snlen == -1
|
||||||
|
? strlen (desc->sn) : desc->snlen),
|
||||||
|
desc->sn);
|
||||||
|
case KEYDB_SEARCH_MODE_SN:
|
||||||
|
return xasprintf ("SN: '%*s'",
|
||||||
|
(int) (desc->snlen == -1
|
||||||
|
? strlen (desc->sn) : desc->snlen),
|
||||||
|
desc->sn);
|
||||||
|
case KEYDB_SEARCH_MODE_SUBJECT:
|
||||||
|
return xasprintf ("SUBJECT: '%s'", desc->u.name);
|
||||||
|
case KEYDB_SEARCH_MODE_KEYGRIP:
|
||||||
|
return xasprintf ("KEYGRIP: %s", desc->u.grip);
|
||||||
|
case KEYDB_SEARCH_MODE_FIRST:
|
||||||
|
return xasprintf ("FIRST");
|
||||||
|
case KEYDB_SEARCH_MODE_NEXT:
|
||||||
|
return xasprintf ("NEXT");
|
||||||
|
default:
|
||||||
|
return xasprintf ("Bad search mode (%d)", desc->mode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Search through all keydb resources, starting at the current position,
|
* Search through all keydb resources, starting at the current position,
|
||||||
* for a keyblock which contains one of the keys described in the DESC array.
|
* for a keyblock which contains one of the keys described in the DESC array.
|
||||||
@ -972,6 +1120,7 @@ keydb_search (ctrl_t ctrl, KEYDB_HANDLE hd,
|
|||||||
{
|
{
|
||||||
int rc = -1;
|
int rc = -1;
|
||||||
unsigned long skipped;
|
unsigned long skipped;
|
||||||
|
int i;
|
||||||
|
|
||||||
if (!hd)
|
if (!hd)
|
||||||
return gpg_error (GPG_ERR_INV_VALUE);
|
return gpg_error (GPG_ERR_INV_VALUE);
|
||||||
@ -983,7 +1132,22 @@ keydb_search (ctrl_t ctrl, KEYDB_HANDLE hd,
|
|||||||
return gpg_error (GPG_ERR_NOT_FOUND);
|
return gpg_error (GPG_ERR_NOT_FOUND);
|
||||||
}
|
}
|
||||||
|
|
||||||
while (rc == -1 && hd->current >= 0 && hd->current < hd->used)
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: enter (hd=%p)\n", __func__, hd);
|
||||||
|
|
||||||
|
if (DBG_LOOKUP)
|
||||||
|
{
|
||||||
|
log_debug ("%s: %zd search description(s):\n", __func__, ndesc);
|
||||||
|
for (i = 0; i < ndesc; i ++)
|
||||||
|
{
|
||||||
|
char *t = keydb_search_desc_dump (&desc[i]);
|
||||||
|
log_debug ("%s: %d: %s\n", __func__, i, t);
|
||||||
|
xfree (t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
while ((rc == -1 || gpg_err_code (rc) == GPG_ERR_EOF)
|
||||||
|
&& hd->current >= 0 && hd->current < hd->used)
|
||||||
{
|
{
|
||||||
switch (hd->active[hd->current].type)
|
switch (hd->active[hd->current].type)
|
||||||
{
|
{
|
||||||
@ -996,6 +1160,15 @@ keydb_search (ctrl_t ctrl, KEYDB_HANDLE hd,
|
|||||||
NULL, &skipped);
|
NULL, &skipped);
|
||||||
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_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 */
|
||||||
hd->current++;
|
hd->current++;
|
||||||
@ -1004,6 +1177,9 @@ keydb_search (ctrl_t ctrl, KEYDB_HANDLE hd,
|
|||||||
hd->found = hd->current;
|
hd->found = hd->current;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
if (DBG_CLOCK)
|
||||||
|
log_clock ("%s: leave (rc=%d)\n", __func__, rc);
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,10 +46,10 @@ gpg_error_t keydb_set_flags (KEYDB_HANDLE hd, int which, int idx,
|
|||||||
void keydb_push_found_state (KEYDB_HANDLE hd);
|
void keydb_push_found_state (KEYDB_HANDLE hd);
|
||||||
void keydb_pop_found_state (KEYDB_HANDLE hd);
|
void keydb_pop_found_state (KEYDB_HANDLE hd);
|
||||||
int keydb_get_cert (KEYDB_HANDLE hd, ksba_cert_t *r_cert);
|
int keydb_get_cert (KEYDB_HANDLE hd, ksba_cert_t *r_cert);
|
||||||
int keydb_insert_cert (KEYDB_HANDLE hd, ksba_cert_t cert);
|
gpg_error_t keydb_insert_cert (KEYDB_HANDLE hd, ksba_cert_t cert);
|
||||||
int keydb_update_cert (KEYDB_HANDLE hd, ksba_cert_t cert);
|
gpg_error_t keydb_update_cert (KEYDB_HANDLE hd, ksba_cert_t cert);
|
||||||
|
|
||||||
int keydb_delete (KEYDB_HANDLE hd);
|
gpg_error_t keydb_delete (KEYDB_HANDLE hd);
|
||||||
|
|
||||||
int keydb_locate_writable (KEYDB_HANDLE hd, const char *reserved);
|
int keydb_locate_writable (KEYDB_HANDLE hd, const char *reserved);
|
||||||
void keydb_rebuild_caches (void);
|
void keydb_rebuild_caches (void);
|
||||||
|
@ -1373,6 +1373,8 @@ list_cert_std (ctrl_t ctrl, ksba_cert_t cert, estream_t fp, int have_secret,
|
|||||||
else
|
else
|
||||||
es_fprintf (fp, " [certificate is bad: %s]\n", gpg_strerror (err));
|
es_fprintf (fp, " [certificate is bad: %s]\n", gpg_strerror (err));
|
||||||
}
|
}
|
||||||
|
if (opt.debug)
|
||||||
|
es_fflush (fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user