mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-10 13:04:23 +01:00
gpg: Allow overridden key import when stub exists.
* g10/import.c (do_transfer): Force importing when it's card reference. -- Cherry-picked from 2.4 branch: 2c1297055041b4657ea1a927acac978c2b09a483 GnuPG-bug-id: 3456 Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
4817825511
commit
383d524239
12
g10/import.c
12
g10/import.c
@ -2836,9 +2836,19 @@ do_transfer (ctrl_t ctrl, kbnode_t keyblock, PKT_public_key *pk,
|
|||||||
{
|
{
|
||||||
gpg_error_t err;
|
gpg_error_t err;
|
||||||
struct import_stats_s subkey_stats = {0};
|
struct import_stats_s subkey_stats = {0};
|
||||||
|
int force = 0;
|
||||||
|
int already_exist = agent_probe_secret_key (ctrl, pk);
|
||||||
|
|
||||||
|
if (already_exist == 2)
|
||||||
|
{
|
||||||
|
if (!opt.quiet)
|
||||||
|
log_info (_("key %s: card reference is overridden by key material\n"),
|
||||||
|
keystr_from_pk (pk));
|
||||||
|
force = 1;
|
||||||
|
}
|
||||||
|
|
||||||
err = transfer_secret_keys (ctrl, &subkey_stats, keyblock,
|
err = transfer_secret_keys (ctrl, &subkey_stats, keyblock,
|
||||||
batch, 0, only_marked);
|
batch, force, only_marked);
|
||||||
if (gpg_err_code (err) == GPG_ERR_NOT_PROCESSED)
|
if (gpg_err_code (err) == GPG_ERR_NOT_PROCESSED)
|
||||||
{
|
{
|
||||||
/* TRANSLATORS: For a smartcard, each private key on host has a
|
/* TRANSLATORS: For a smartcard, each private key on host has a
|
||||||
|
Loading…
x
Reference in New Issue
Block a user