mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-18 14:17:03 +01:00
scd: Fix readkey --info in case a readkey command is available.
* scd/command.c (do_readkey): Make --info also work if a readkey command is available. * scd/app-p15.c (cdf_object_from_certid): Fix a but introduced with the previous commit.
This commit is contained in:
parent
488eaedc9a
commit
2490f4e8e1
@ -768,8 +768,8 @@ cdf_object_from_certid (app_t app, const char *certid, cdf_object_t *r_cdf)
|
|||||||
|
|
||||||
err = cdf_object_from_objid (app, objidlen, objid, &cdf);
|
err = cdf_object_from_objid (app, objidlen, objid, &cdf);
|
||||||
xfree (objid);
|
xfree (objid);
|
||||||
if (!cdf)
|
if (err)
|
||||||
return gpg_error (GPG_ERR_NOT_FOUND);
|
return err;
|
||||||
*r_cdf = cdf;
|
*r_cdf = cdf;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -620,62 +620,56 @@ do_readkey (card_t card, ctrl_t ctrl, const char *line,
|
|||||||
opt_info? APP_READKEY_FLAG_INFO : 0,
|
opt_info? APP_READKEY_FLAG_INFO : 0,
|
||||||
opt_nokey? NULL : pk_p, pklen_p);
|
opt_nokey? NULL : pk_p, pklen_p);
|
||||||
if (!rc)
|
if (!rc)
|
||||||
/* Okay, got that key. */
|
; /* Got the key. */
|
||||||
return 0;
|
else if (gpg_err_code (rc) == GPG_ERR_UNSUPPORTED_OPERATION
|
||||||
|
|| gpg_err_code (rc) == GPG_ERR_NOT_FOUND)
|
||||||
if (gpg_err_code (rc) == GPG_ERR_UNSUPPORTED_OPERATION
|
|
||||||
|| gpg_err_code (rc) == GPG_ERR_NOT_FOUND)
|
|
||||||
{
|
{
|
||||||
|
/* Fall back to certificate reading. */
|
||||||
unsigned char *cert = NULL;
|
unsigned char *cert = NULL;
|
||||||
size_t ncert;
|
size_t ncert;
|
||||||
|
|
||||||
/* Fall back to certificate reading. */
|
|
||||||
rc = app_readcert (card, ctrl, line, &cert, &ncert);
|
rc = app_readcert (card, ctrl, line, &cert, &ncert);
|
||||||
if (rc)
|
if (rc)
|
||||||
|
log_error ("app_readcert failed: %s\n", gpg_strerror (rc));
|
||||||
|
else
|
||||||
{
|
{
|
||||||
log_error ("app_readcert failed: %s\n", gpg_strerror (rc));
|
rc = app_help_pubkey_from_cert (cert, ncert, pk_p, pklen_p);
|
||||||
return rc;
|
xfree (cert);
|
||||||
}
|
|
||||||
|
|
||||||
rc = app_help_pubkey_from_cert (cert, ncert, pk_p, pklen_p);
|
|
||||||
xfree (cert);
|
|
||||||
if (rc)
|
|
||||||
{
|
|
||||||
log_error ("failed to parse the certificate: %s\n",
|
|
||||||
gpg_strerror (rc));
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (opt_info)
|
|
||||||
{
|
|
||||||
char keygripstr[KEYGRIP_LEN*2+1];
|
|
||||||
char *algostr;
|
|
||||||
|
|
||||||
rc = app_help_get_keygrip_string_pk (*pk_p, *pklen_p,
|
|
||||||
keygripstr, NULL, NULL,
|
|
||||||
&algostr);
|
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
log_error ("failed to parse the certificate: %s\n",
|
||||||
log_error ("app_help_get_keygrip_string failed: %s\n",
|
gpg_strerror (rc));
|
||||||
gpg_strerror (rc));
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* FIXME: Using LINE is not correct because it might be an
|
|
||||||
* OID and has not been canonicalized (i.e. uppercased). */
|
|
||||||
send_status_info (ctrl, "KEYPAIRINFO",
|
|
||||||
keygripstr, strlen (keygripstr),
|
|
||||||
line, strlen (line),
|
|
||||||
"-", (size_t)1,
|
|
||||||
"-", (size_t)1,
|
|
||||||
algostr, strlen (algostr),
|
|
||||||
NULL, (size_t)0);
|
|
||||||
xfree (algostr);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
log_error ("app_readkey failed: %s\n", gpg_strerror (rc));
|
log_error ("app_readkey failed: %s\n", gpg_strerror (rc));
|
||||||
|
|
||||||
|
if (!rc && opt_info)
|
||||||
|
{
|
||||||
|
char keygripstr[KEYGRIP_LEN*2+1];
|
||||||
|
char *algostr;
|
||||||
|
|
||||||
|
rc = app_help_get_keygrip_string_pk (*pk_p, *pklen_p,
|
||||||
|
keygripstr, NULL, NULL,
|
||||||
|
&algostr);
|
||||||
|
if (rc)
|
||||||
|
{
|
||||||
|
log_error ("app_help_get_keygrip_string failed: %s\n",
|
||||||
|
gpg_strerror (rc));
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* FIXME: Using LINE is not correct because it might be an
|
||||||
|
* OID and has not been canonicalized (i.e. uppercased). */
|
||||||
|
send_status_info (ctrl, "KEYPAIRINFO",
|
||||||
|
keygripstr, strlen (keygripstr),
|
||||||
|
line, strlen (line),
|
||||||
|
"-", (size_t)1,
|
||||||
|
"-", (size_t)1,
|
||||||
|
algostr, strlen (algostr),
|
||||||
|
NULL, (size_t)0);
|
||||||
|
xfree (algostr);
|
||||||
|
}
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user