mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-06 12:33:23 +01:00
* keygen.c (proc_parameter_file): Default key and subkey usage flags to
algo capabilities if parameter file doesn't specify them. Noted by Timo Schulz.
This commit is contained in:
parent
4a58bbbb8a
commit
b9f1815947
@ -1,3 +1,9 @@
|
|||||||
|
2005-10-26 David Shaw <dshaw@jabberwocky.com>
|
||||||
|
|
||||||
|
* keygen.c (proc_parameter_file): Default key and subkey usage
|
||||||
|
flags to algo capabilities if parameter file doesn't specify them.
|
||||||
|
Noted by Timo Schulz.
|
||||||
|
|
||||||
2005-10-18 Werner Koch <wk@g10code.com>
|
2005-10-18 Werner Koch <wk@g10code.com>
|
||||||
|
|
||||||
* cardglue.c (pin_cb): Fixed prompt for repeated PIN. Return
|
* cardglue.c (pin_cb): Fixed prompt for repeated PIN. Return
|
||||||
|
36
g10/keygen.c
36
g10/keygen.c
@ -1955,7 +1955,7 @@ parse_parameter_usage (const char *fname,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
r->u.usage = use;
|
r->u.usage = use;
|
||||||
return 0;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -2062,14 +2062,14 @@ proc_parameter_file( struct para_data_s *para, const char *fname,
|
|||||||
const char *s1, *s2, *s3;
|
const char *s1, *s2, *s3;
|
||||||
size_t n;
|
size_t n;
|
||||||
char *p;
|
char *p;
|
||||||
int have_user_id=0;
|
int have_user_id=0,err,algo;
|
||||||
|
|
||||||
/* Check that we have all required parameters. */
|
/* Check that we have all required parameters. */
|
||||||
r = get_parameter( para, pKEYTYPE );
|
r = get_parameter( para, pKEYTYPE );
|
||||||
if(r)
|
if(r)
|
||||||
{
|
{
|
||||||
if(check_pubkey_algo2(get_parameter_algo(para,pKEYTYPE),
|
algo=get_parameter_algo(para,pKEYTYPE);
|
||||||
PUBKEY_USAGE_SIG))
|
if(check_pubkey_algo2(algo,PUBKEY_USAGE_SIG))
|
||||||
{
|
{
|
||||||
log_error("%s:%d: invalid algorithm\n", fname, r->lnr );
|
log_error("%s:%d: invalid algorithm\n", fname, r->lnr );
|
||||||
return -1;
|
return -1;
|
||||||
@ -2081,19 +2081,41 @@ proc_parameter_file( struct para_data_s *para, const char *fname,
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (parse_parameter_usage (fname, para, pKEYUSAGE))
|
err=parse_parameter_usage (fname, para, pKEYUSAGE);
|
||||||
|
if(err==0)
|
||||||
|
{
|
||||||
|
/* Default to algo capabilities if key-usage is not provided */
|
||||||
|
r=xmalloc_clear(sizeof(*r));
|
||||||
|
r->key=pKEYUSAGE;
|
||||||
|
r->u.usage=openpgp_pk_algo_usage(algo);
|
||||||
|
r->next=para;
|
||||||
|
para=r;
|
||||||
|
}
|
||||||
|
else if(err==-1)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
r = get_parameter( para, pSUBKEYTYPE );
|
r = get_parameter( para, pSUBKEYTYPE );
|
||||||
if(r)
|
if(r)
|
||||||
{
|
{
|
||||||
if(check_pubkey_algo( get_parameter_algo( para, pSUBKEYTYPE)))
|
algo=get_parameter_algo( para, pSUBKEYTYPE);
|
||||||
|
if(check_pubkey_algo(algo))
|
||||||
{
|
{
|
||||||
log_error("%s:%d: invalid algorithm\n", fname, r->lnr );
|
log_error("%s:%d: invalid algorithm\n", fname, r->lnr );
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(parse_parameter_usage (fname, para, pSUBKEYUSAGE))
|
err=parse_parameter_usage (fname, para, pSUBKEYUSAGE);
|
||||||
|
if(err==0)
|
||||||
|
{
|
||||||
|
/* Default to algo capabilities if subkey-usage is not
|
||||||
|
provided */
|
||||||
|
r=xmalloc_clear(sizeof(*r));
|
||||||
|
r->key=pSUBKEYUSAGE;
|
||||||
|
r->u.usage=openpgp_pk_algo_usage(algo);
|
||||||
|
r->next=para;
|
||||||
|
para=r;
|
||||||
|
}
|
||||||
|
else if(err==-1)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user