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:
parent
2258bcded6
commit
96b69c1866
31
g10/keygen.c
31
g10/keygen.c
@ -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 },
|
||||||
|
Loading…
x
Reference in New Issue
Block a user