mirror of
git://git.gnupg.org/gnupg.git
synced 2025-07-02 22:46:30 +02:00
gpg: Take care of keydb_new returning NULL.
* g10/keydb.c (keydb_new): Print an error message if needed. Also use
xtrycalloc because we return an error anyway.
* g10/delkey.c (do_delete_key): Handle error retruned by keydb_new.
* g10/export.c (do_export_stream): Ditto.
* g10/getkey.c (get_pubkey): Ditto.
(get_pubkey_fast): Ditto.
(get_pubkeyblock): Ditto.
(get_seckey): Ditto.
(key_byname): Ditto.
(get_pubkey_byfprint): Ditto.
(get_pubkey_byfprint_fast): Ditto.
(parse_def_secret_key): Ditto.
(have_secret_key_with_kid): Ditto.
* g10/import.c (import_one): Ditto.
(import_revoke_cert): Ditto.
* g10/keyedit.c (keyedit_quick_adduid): Ditto.
* g10/keygen.c (quick_generate_keypair): Ditto.
(do_generate_keypair): Ditto.
* g10/trustdb.c (validate_keys): Ditto.
* g10/keyserver.c (keyidlist): Ditto.
* g10/revoke.c (gen_desig_revoke): Ditto.
(gen_revoke): Ditto.
* g10/gpg.c (check_user_ids): Ditto.
(main): Do not print an error message for keydb_new error.
* g10/keylist.c (list_all): Use actual error code returned by
keydb_new.
* g10/t-keydb-get-keyblock.c (do_test): Abort on keydb_new error.
* g10/t-keydb.c (do_test): Ditto.
* g10/keyring.c (keyring_new): Actually return an error so that the
existing keydb_new error checking makes sense for a keyring resource.
(keyring_rebuild_cache): Take care of keyring_new returning an error.
--
Commit 04a6b903
changed keydb_new to return an error. However the
error was not checked at most places which we fix with this patch. To
make things easier keydb_new prints an error message itself.
Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
9fcc047d92
commit
a28ac99efe
16 changed files with 155 additions and 37 deletions
19
g10/keygen.c
19
g10/keygen.c
|
@ -3533,6 +3533,9 @@ quick_generate_keypair (ctrl_t ctrl, const char *uid)
|
|||
desc.u.name = uid;
|
||||
|
||||
kdbhd = keydb_new ();
|
||||
if (!kdbhd)
|
||||
goto leave;
|
||||
|
||||
err = keydb_search (kdbhd, &desc, 1, NULL);
|
||||
keydb_release (kdbhd);
|
||||
if (gpg_err_code (err) != GPG_ERR_NOT_FOUND)
|
||||
|
@ -4148,12 +4151,18 @@ do_generate_keypair (ctrl_t ctrl, struct para_data_s *para,
|
|||
}
|
||||
else if (!err) /* Write to the standard keyrings. */
|
||||
{
|
||||
KEYDB_HANDLE pub_hd = keydb_new ();
|
||||
KEYDB_HANDLE pub_hd;
|
||||
|
||||
err = keydb_locate_writable (pub_hd);
|
||||
if (err)
|
||||
log_error (_("no writable public keyring found: %s\n"),
|
||||
gpg_strerror (err));
|
||||
pub_hd = keydb_new ();
|
||||
if (!pub_hd)
|
||||
err = gpg_error_from_syserror ();
|
||||
else
|
||||
{
|
||||
err = keydb_locate_writable (pub_hd);
|
||||
if (err)
|
||||
log_error (_("no writable public keyring found: %s\n"),
|
||||
gpg_strerror (err));
|
||||
}
|
||||
|
||||
if (!err && opt.verbose)
|
||||
{
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue