mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-05 12:31:50 +01:00
gpg: Introduce magic value 25519 to switch a card to ECC.
* g10/card-util.c (show_keysize_warning): Slightly change the text. (ask_card_keyattr): Handle special value 25519. (do_change_keyattr): Allow changing to cv25519/ed25519. (generate_card_keys): Ditto. (card_generate_subkey): Ditto. -- This is kludge to make it easier for gnuk to be switched into ECC mode. Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
parent
1651310203
commit
ea09b6cded
@ -1317,12 +1317,11 @@ show_keysize_warning (void)
|
|||||||
return;
|
return;
|
||||||
shown = 1;
|
shown = 1;
|
||||||
tty_printf
|
tty_printf
|
||||||
(_("Note: There is no guarantee that the card "
|
(_("Note: There is no guarantee that the card supports the requested\n"
|
||||||
"supports the requested size.\n"
|
" key type or size. If the key generation does not succeed,\n"
|
||||||
" If the key generation does not succeed, "
|
" please check the documentation of your card to see which\n"
|
||||||
"please check the\n"
|
" key types and sizes are supported.\n")
|
||||||
" documentation of your card to see what "
|
);
|
||||||
"sizes are allowed.\n"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -1353,40 +1352,61 @@ ask_card_keyattr (int keyno, unsigned int nbits)
|
|||||||
xfree (prompt);
|
xfree (prompt);
|
||||||
xfree (answer);
|
xfree (answer);
|
||||||
|
|
||||||
if (req_nbits != nbits && (req_nbits % 32) )
|
if (req_nbits == 25519)
|
||||||
{
|
{
|
||||||
req_nbits = ((req_nbits + 31) / 32) * 32;
|
if (req_nbits == nbits)
|
||||||
tty_printf (_("rounded up to %u bits\n"), req_nbits);
|
return 0; /* Use default. */
|
||||||
}
|
|
||||||
|
|
||||||
if (req_nbits == nbits)
|
tty_printf (_("The card will now be re-configured"
|
||||||
return 0; /* Use default. */
|
" to generate a key of type: %s\n"),
|
||||||
|
keyno==1? "cv25519":"ed25519");
|
||||||
if (req_nbits < min_nbits || req_nbits > max_nbits)
|
show_keysize_warning ();
|
||||||
{
|
return req_nbits;
|
||||||
tty_printf (_("%s keysizes must be in the range %u-%u\n"),
|
|
||||||
"RSA", min_nbits, max_nbits);
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
tty_printf (_("The card will now be re-configured "
|
if (req_nbits != nbits && (req_nbits % 32) )
|
||||||
"to generate a key of %u bits\n"), req_nbits);
|
{
|
||||||
show_keysize_warning ();
|
req_nbits = ((req_nbits + 31) / 32) * 32;
|
||||||
return req_nbits;
|
tty_printf (_("rounded up to %u bits\n"), req_nbits);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (req_nbits == nbits)
|
||||||
|
return 0; /* Use default. */
|
||||||
|
|
||||||
|
if (req_nbits < min_nbits || req_nbits > max_nbits)
|
||||||
|
{
|
||||||
|
tty_printf (_("%s keysizes must be in the range %u-%u\n"),
|
||||||
|
"RSA", min_nbits, max_nbits);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
tty_printf (_("The card will now be re-configured"
|
||||||
|
" to generate a key of %u bits\n"), req_nbits);
|
||||||
|
show_keysize_warning ();
|
||||||
|
return req_nbits;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Change the size of key KEYNO (0..2) to NBITS and show an error
|
/* Change the size of key KEYNO (0..2) to NBITS and show an error
|
||||||
message if that fails. */
|
* message if that fails. Using the magic value 25519 for NBITS
|
||||||
|
* switches to ed25519 or cv25519 depending on the KEYNO. */
|
||||||
static gpg_error_t
|
static gpg_error_t
|
||||||
do_change_keyattr (int keyno, unsigned int nbits)
|
do_change_keyattr (int keyno, unsigned int nbits)
|
||||||
{
|
{
|
||||||
gpg_error_t err;
|
gpg_error_t err;
|
||||||
char args[100];
|
char args[100];
|
||||||
|
|
||||||
snprintf (args, sizeof args, "--force %d 1 rsa%u", keyno+1, nbits);
|
if (nbits == 25519)
|
||||||
|
snprintf (args, sizeof args, "--force %d %d %s",
|
||||||
|
keyno+1,
|
||||||
|
keyno == 1? PUBKEY_ALGO_ECDH : PUBKEY_ALGO_EDDSA,
|
||||||
|
keyno == 1? "cv25519" : "ed25519");
|
||||||
|
else
|
||||||
|
snprintf (args, sizeof args, "--force %d 1 rsa%u", keyno+1, nbits);
|
||||||
err = agent_scd_setattr ("KEY-ATTR", args, strlen (args), NULL);
|
err = agent_scd_setattr ("KEY-ATTR", args, strlen (args), NULL);
|
||||||
if (err)
|
if (err)
|
||||||
log_error (_("error changing size of key %d to %u bits: %s\n"),
|
log_error (_("error changing size of key %d to %u bits: %s\n"),
|
||||||
@ -1460,9 +1480,15 @@ generate_card_keys (ctrl_t ctrl)
|
|||||||
|
|
||||||
for (keyno = 0; keyno < DIM (info.key_attr); keyno++)
|
for (keyno = 0; keyno < DIM (info.key_attr); keyno++)
|
||||||
{
|
{
|
||||||
if (info.key_attr[keyno].algo == PUBKEY_ALGO_RSA)
|
if (info.key_attr[keyno].algo == PUBKEY_ALGO_RSA
|
||||||
|
|| info.key_attr[keyno].algo == PUBKEY_ALGO_ECDH
|
||||||
|
|| info.key_attr[keyno].algo == PUBKEY_ALGO_EDDSA)
|
||||||
{
|
{
|
||||||
nbits = ask_card_keyattr (keyno, info.key_attr[keyno].nbits);
|
if (info.key_attr[keyno].algo == PUBKEY_ALGO_RSA)
|
||||||
|
nbits = ask_card_keyattr (keyno, info.key_attr[keyno].nbits);
|
||||||
|
else
|
||||||
|
nbits = ask_card_keyattr (keyno, 25519 /* magic */);
|
||||||
|
|
||||||
if (nbits && do_change_keyattr (keyno, nbits))
|
if (nbits && do_change_keyattr (keyno, nbits))
|
||||||
{
|
{
|
||||||
/* Error: Better read the default key size again. */
|
/* Error: Better read the default key size again. */
|
||||||
@ -1540,12 +1566,18 @@ card_generate_subkey (ctrl_t ctrl, kbnode_t pub_keyblock)
|
|||||||
key size. */
|
key size. */
|
||||||
if (info.is_v2 && info.extcap.aac)
|
if (info.is_v2 && info.extcap.aac)
|
||||||
{
|
{
|
||||||
if (info.key_attr[keyno-1].algo == PUBKEY_ALGO_RSA)
|
if (info.key_attr[keyno-1].algo == PUBKEY_ALGO_RSA
|
||||||
|
|| info.key_attr[keyno].algo == PUBKEY_ALGO_ECDH
|
||||||
|
|| info.key_attr[keyno].algo == PUBKEY_ALGO_EDDSA)
|
||||||
{
|
{
|
||||||
unsigned int nbits;
|
unsigned int nbits;
|
||||||
|
|
||||||
ask_again:
|
ask_again:
|
||||||
nbits = ask_card_keyattr (keyno-1, info.key_attr[keyno-1].nbits);
|
if (info.key_attr[keyno].algo == PUBKEY_ALGO_RSA)
|
||||||
|
nbits = ask_card_keyattr (keyno-1, info.key_attr[keyno-1].nbits);
|
||||||
|
else
|
||||||
|
nbits = ask_card_keyattr (keyno-1, 25519);
|
||||||
|
|
||||||
if (nbits && do_change_keyattr (keyno-1, nbits))
|
if (nbits && do_change_keyattr (keyno-1, nbits))
|
||||||
{
|
{
|
||||||
/* Error: Better read the default key size again. */
|
/* Error: Better read the default key size again. */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user