mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-18 14:17:03 +01:00
gpgsm: Remove restriction of key generation (only RSA).
* sm/certreqgen.c (proc_parameters): Remove checking GCRY_PK_RSA. -- This is an initial change to support ECC key generation. GnuPG-bug-id: 4888 Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
parent
c1844ca752
commit
238707db8b
@ -433,6 +433,7 @@ proc_parameters (ctrl_t ctrl, struct para_data_s *para,
|
|||||||
struct para_data_s *r;
|
struct para_data_s *r;
|
||||||
const char *s, *string;
|
const char *s, *string;
|
||||||
int i;
|
int i;
|
||||||
|
int algo;
|
||||||
unsigned int nbits;
|
unsigned int nbits;
|
||||||
char numbuf[20];
|
char numbuf[20];
|
||||||
unsigned char keyparms[100];
|
unsigned char keyparms[100];
|
||||||
@ -446,22 +447,22 @@ proc_parameters (ctrl_t ctrl, struct para_data_s *para,
|
|||||||
/* Check that we have all required parameters; */
|
/* Check that we have all required parameters; */
|
||||||
assert (get_parameter (para, pKEYTYPE, 0));
|
assert (get_parameter (para, pKEYTYPE, 0));
|
||||||
|
|
||||||
/* We can only use RSA for now. There is a problem with pkcs-10 on
|
/* There is a problem with pkcs-10 on how to use ElGamal because it
|
||||||
how to use ElGamal because it is expected that a PK algorithm can
|
is expected that a PK algorithm can always be used for
|
||||||
always be used for signing. Another problem is that on-card
|
signing. Another problem is that on-card generated encryption
|
||||||
generated encryption keys may not be used for signing. */
|
keys may not be used for signing. */
|
||||||
i = get_parameter_algo (para, pKEYTYPE);
|
algo = get_parameter_algo (para, pKEYTYPE);
|
||||||
if (!i && (s = get_parameter_value (para, pKEYTYPE, 0)) && *s)
|
if (!algo && (s = get_parameter_value (para, pKEYTYPE, 0)) && *s)
|
||||||
{
|
{
|
||||||
/* Hack to allow creation of certificates directly from a smart
|
/* Hack to allow creation of certificates directly from a smart
|
||||||
card. For example: "Key-Type: card:OPENPGP.3". */
|
card. For example: "Key-Type: card:OPENPGP.3". */
|
||||||
if (!strncmp (s, "card:", 5) && s[5])
|
if (!strncmp (s, "card:", 5) && s[5])
|
||||||
cardkeyid = xtrystrdup (s+5);
|
cardkeyid = xtrystrdup (s+5);
|
||||||
}
|
}
|
||||||
if ( (i < 1 || i != GCRY_PK_RSA) && !cardkeyid )
|
if (algo < 1 && !cardkeyid)
|
||||||
{
|
{
|
||||||
r = get_parameter (para, pKEYTYPE, 0);
|
r = get_parameter (para, pKEYTYPE, 0);
|
||||||
log_error (_("line %d: invalid algorithm\n"), r->lnr);
|
log_error (_("line %d: invalid algorithm\n"), r ? r->lnr: -1);
|
||||||
return gpg_error (GPG_ERR_INV_PARAMETER);
|
return gpg_error (GPG_ERR_INV_PARAMETER);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user