1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-08 12:44:23 +01:00

gpg: Add support for Subkey-Expire-Date.

* g10/keygen.c (enum para_name): Add pSUBKEYEXPIREDATE.
(proc_parameter_file): Add support for pSUBKEYEXPIREDATE.
(read_parameter_file): Add "Subkey-Expire-Date".

--

Cherry-pick from master commit of:
	23bcb78d279ebc81ec9340356401d19cf89985f1

Signed-off-by: NIIBE Yutaka <gniibe@fsij.org>
This commit is contained in:
NIIBE Yutaka 2023-07-12 14:04:28 +09:00
parent 2258bcded6
commit 96b69c1866
No known key found for this signature in database
GPG Key ID: 640114AF89DE6054

View File

@ -87,6 +87,7 @@ enum para_name {
pEXPIREDATE, pEXPIREDATE,
pKEYEXPIRE, /* in n seconds */ pKEYEXPIRE, /* in n seconds */
pSUBKEYCREATIONDATE, pSUBKEYCREATIONDATE,
pSUBKEYEXPIREDATE,
pSUBKEYEXPIRE, /* in n seconds */ pSUBKEYEXPIRE, /* in n seconds */
pAUTHKEYCREATIONDATE, /* Not yet used. */ pAUTHKEYCREATIONDATE, /* Not yet used. */
pPASSPHRASE, pPASSPHRASE,
@ -4331,12 +4332,29 @@ proc_parameter_file (ctrl_t ctrl, struct para_data_s *para, const char *fname,
return -1; return -1;
} }
r->u.expire = seconds; r->u.expire = seconds;
r->key = pKEYEXPIRE; /* change hat entry */ r->key = pKEYEXPIRE; /* change that entry */
/* also set it for the subkey */
r = xmalloc_clear( sizeof *r + 20 ); /* Make SUBKEYEXPIRE from Subkey-Expire-Date, if any. */
r->key = pSUBKEYEXPIRE; r = get_parameter( para, pSUBKEYEXPIREDATE );
r->u.expire = seconds; if( r && *r->u.value )
append_to_parameter (para, r); {
seconds = parse_expire_string_with_ct (r->u.value, creation_time);
if( seconds == (u32)-1 )
{
log_error("%s:%d: invalid subkey expire date\n", fname, r->lnr );
return -1;
}
r->key = pSUBKEYEXPIRE; /* change that entry */
r->u.expire = seconds;
}
else
{
/* Or else, set Expire-Date for the subkey */
r = xmalloc_clear( sizeof *r + 20 );
r->key = pSUBKEYEXPIRE;
r->u.expire = seconds;
append_to_parameter (para, r);
}
} }
do_generate_keypair (ctrl, para, outctrl, card ); do_generate_keypair (ctrl, para, outctrl, card );
@ -4367,6 +4385,7 @@ read_parameter_file (ctrl_t ctrl, const char *fname )
{ "Name-Email", pNAMEEMAIL }, { "Name-Email", pNAMEEMAIL },
{ "Name-Comment", pNAMECOMMENT }, { "Name-Comment", pNAMECOMMENT },
{ "Expire-Date", pEXPIREDATE }, { "Expire-Date", pEXPIREDATE },
{ "Subkey-Expire-Date", pSUBKEYEXPIREDATE },
{ "Creation-Date", pCREATIONDATE }, { "Creation-Date", pCREATIONDATE },
{ "Passphrase", pPASSPHRASE }, { "Passphrase", pPASSPHRASE },
{ "Preferences", pPREFERENCES }, { "Preferences", pPREFERENCES },