1
0
mirror of git://git.gnupg.org/gnupg.git synced 2024-12-31 11:41:32 +01:00

g10: Unattended key generation "Key-Grip" and "Subkey-Grip".

* g10/keygen.c (pSUBKEYGRIP): New.
(read_parameter_file): Add "Key-Grip" and "Subkey-Grip".
(do_generate_keypair): Support pSUBKEYGRIP.

--

In the manual, it says "Key-Grip".  gpgsm also supports "Key-Grip".
Adding "Subkey-Grip" now, adding "Key-Grip" makes sense.

GnuPG-bug-id: 3478
Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
NIIBE Yutaka 2017-11-01 10:19:35 +09:00
parent d63b7966cd
commit 6c63a04569

View File

@ -89,7 +89,8 @@ enum para_name {
pCARDBACKUPKEY, pCARDBACKUPKEY,
pHANDLE, pHANDLE,
pKEYSERVER, pKEYSERVER,
pKEYGRIP pKEYGRIP,
pSUBKEYGRIP,
}; };
struct para_data_s { struct para_data_s {
@ -3648,6 +3649,8 @@ read_parameter_file (ctrl_t ctrl, const char *fname )
{ "Handle", pHANDLE }, { "Handle", pHANDLE },
{ "Keyserver", pKEYSERVER }, { "Keyserver", pKEYSERVER },
{ "Keygrip", pKEYGRIP }, { "Keygrip", pKEYGRIP },
{ "Key-Grip", pKEYGRIP },
{ "Subkey-grip", pSUBKEYGRIP },
{ NULL, 0 } { NULL, 0 }
}; };
IOBUF fp; IOBUF fp;
@ -4696,8 +4699,7 @@ do_generate_keypair (ctrl_t ctrl, struct para_data_s *para,
if (!err && card && get_parameter (para, pAUTHKEYTYPE)) if (!err && card && get_parameter (para, pAUTHKEYTYPE))
{ {
err = gen_card_key (3, get_parameter_algo( para, pAUTHKEYTYPE, NULL ), err = gen_card_key (3, get_parameter_algo( para, pAUTHKEYTYPE, NULL ),
0, pub_root, &timestamp, 0, pub_root, &timestamp, expire);
get_parameter_u32 (para, pKEYEXPIRE));
if (!err) if (!err)
err = write_keybinding (ctrl, pub_root, pri_psk, NULL, err = write_keybinding (ctrl, pub_root, pri_psk, NULL,
PUBKEY_USAGE_AUTH, timestamp, cache_nonce); PUBKEY_USAGE_AUTH, timestamp, cache_nonce);
@ -4705,11 +4707,18 @@ do_generate_keypair (ctrl_t ctrl, struct para_data_s *para,
if (!err && get_parameter (para, pSUBKEYTYPE)) if (!err && get_parameter (para, pSUBKEYTYPE))
{ {
sub_psk = NULL; int subkey_algo = get_parameter_algo (para, pSUBKEYTYPE, NULL);
s = NULL; s = NULL;
if (!card || (s = get_parameter_value (para, pCARDBACKUPKEY))) key_from_hexgrip = get_parameter_value (para, pSUBKEYGRIP);
if (key_from_hexgrip)
err = do_create_from_keygrip (ctrl, subkey_algo, key_from_hexgrip,
pub_root, timestamp,
get_parameter_u32 (para, pSUBKEYEXPIRE),
1);
else if (!card || (s = get_parameter_value (para, pCARDBACKUPKEY)))
{ {
err = do_create (get_parameter_algo (para, pSUBKEYTYPE, NULL), err = do_create (subkey_algo,
get_parameter_uint (para, pSUBKEYLENGTH), get_parameter_uint (para, pSUBKEYLENGTH),
get_parameter_value (para, pSUBKEYCURVE), get_parameter_value (para, pSUBKEYCURVE),
pub_root, pub_root,
@ -4735,9 +4744,7 @@ do_generate_keypair (ctrl_t ctrl, struct para_data_s *para,
} }
else else
{ {
err = gen_card_key (2, get_parameter_algo (para, pSUBKEYTYPE, NULL), err = gen_card_key (2, subkey_algo, 0, pub_root, &timestamp, expire);
0, pub_root, &timestamp,
get_parameter_u32 (para, pKEYEXPIRE));
} }
if (!err) if (!err)