mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-18 14:17:03 +01:00
test release
This commit is contained in:
parent
8ab0adb9f8
commit
8b10a87908
3
NEWS
3
NEWS
@ -9,6 +9,9 @@ Noteworthy changes in version 0.2.15
|
|||||||
|
|
||||||
* CAST5 works (using the PGP's special CFB mode).
|
* CAST5 works (using the PGP's special CFB mode).
|
||||||
|
|
||||||
|
* Now more PGP 5 compatible.
|
||||||
|
|
||||||
|
* Some new test cases
|
||||||
|
|
||||||
Noteworthy changes in version 0.2.14
|
Noteworthy changes in version 0.2.14
|
||||||
------------------------------------
|
------------------------------------
|
||||||
|
1
THANKS
1
THANKS
@ -20,6 +20,7 @@ Peter Gutmann pgut001@cs.auckland.ac.nz
|
|||||||
Ralph Gillen gillen@theochem.uni-duesseldorf.de
|
Ralph Gillen gillen@theochem.uni-duesseldorf.de
|
||||||
Thomas Roessler roessler@guug.de
|
Thomas Roessler roessler@guug.de
|
||||||
Tomas Fasth tomas.fasth@twinspot.net
|
Tomas Fasth tomas.fasth@twinspot.net
|
||||||
|
Ulf Möller 3umoelle@informatik.uni-hamburg.de
|
||||||
Walter Koch walterk@ddorf.rhein-ruhr.de
|
Walter Koch walterk@ddorf.rhein-ruhr.de
|
||||||
Werner Koch werner.koch@guug.de
|
Werner Koch werner.koch@guug.de
|
||||||
Wim Vandeputte bunbun@reptile.rug.ac.be
|
Wim Vandeputte bunbun@reptile.rug.ac.be
|
||||||
|
7
TODO
7
TODO
@ -49,12 +49,7 @@
|
|||||||
|
|
||||||
* fix the problems with "\v" in gettext
|
* fix the problems with "\v" in gettext
|
||||||
|
|
||||||
* calculation of cechksums for secret keys is wrong. We used a
|
* replace getkey.c#enum_secret_keys
|
||||||
the complete chunk length instead of the real number of bits.
|
|
||||||
The problme ist that it is how to stay compatible to old
|
|
||||||
keys? - Do wee need a kludge to calculate both versions of
|
|
||||||
checksums???? (keygen.c, seckey-cert.c)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
Wed Apr 8 14:57:11 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
|
* misc.c (check_pubkey_algo2): New.
|
||||||
|
|
||||||
Tue Apr 7 18:46:49 1998 Werner Koch (wk@isil.d.shuttle.de)
|
Tue Apr 7 18:46:49 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
* cipher.c: New
|
* cipher.c: New
|
||||||
|
@ -396,35 +396,17 @@ blowfish_encrypt_block( BLOWFISH_context *bc, byte *outbuf, byte *inbuf )
|
|||||||
{
|
{
|
||||||
u32 d1, d2;
|
u32 d1, d2;
|
||||||
|
|
||||||
#ifdef BIG_ENDIAN_HOST
|
d1 = inbuf[0] << 24 | inbuf[1] << 16 | inbuf[2] << 8 | inbuf[3];
|
||||||
d1 = ((u32*)inbuf)[0]; /* fixme: this may not be aligned */
|
d2 = inbuf[4] << 24 | inbuf[5] << 16 | inbuf[6] << 8 | inbuf[7];
|
||||||
d2 = ((u32*)inbuf)[1];
|
|
||||||
#else
|
|
||||||
((byte*)&d1)[3] = inbuf[0];
|
|
||||||
((byte*)&d1)[2] = inbuf[1];
|
|
||||||
((byte*)&d1)[1] = inbuf[2];
|
|
||||||
((byte*)&d1)[0] = inbuf[3];
|
|
||||||
((byte*)&d2)[3] = inbuf[4];
|
|
||||||
((byte*)&d2)[2] = inbuf[5];
|
|
||||||
((byte*)&d2)[1] = inbuf[6];
|
|
||||||
((byte*)&d2)[0] = inbuf[7];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
encrypt( bc, &d1, &d2 );
|
encrypt( bc, &d1, &d2 );
|
||||||
|
outbuf[0] = (d1 >> 24) & 0xff;
|
||||||
#ifdef BIG_ENDIAN_HOST
|
outbuf[1] = (d1 >> 16) & 0xff;
|
||||||
((u32*)outbuf)[0] = d1;
|
outbuf[2] = (d1 >> 8) & 0xff;
|
||||||
((u32*)outbuf)[1] = d2;
|
outbuf[3] = d1 & 0xff;
|
||||||
#else
|
outbuf[4] = (d2 >> 24) & 0xff;
|
||||||
outbuf[0] = ((byte*)&d1)[3];
|
outbuf[5] = (d2 >> 16) & 0xff;
|
||||||
outbuf[1] = ((byte*)&d1)[2];
|
outbuf[6] = (d2 >> 8) & 0xff;
|
||||||
outbuf[2] = ((byte*)&d1)[1];
|
outbuf[7] = d2 & 0xff;
|
||||||
outbuf[3] = ((byte*)&d1)[0];
|
|
||||||
outbuf[4] = ((byte*)&d2)[3];
|
|
||||||
outbuf[5] = ((byte*)&d2)[2];
|
|
||||||
outbuf[6] = ((byte*)&d2)[1];
|
|
||||||
outbuf[7] = ((byte*)&d2)[0];
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -433,35 +415,17 @@ blowfish_decrypt_block( BLOWFISH_context *bc, byte *outbuf, byte *inbuf )
|
|||||||
{
|
{
|
||||||
u32 d1, d2;
|
u32 d1, d2;
|
||||||
|
|
||||||
#ifdef BIG_ENDIAN_HOST
|
d1 = inbuf[0] << 24 | inbuf[1] << 16 | inbuf[2] << 8 | inbuf[3];
|
||||||
d1 = ((u32*)inbuf)[0]; /* fixme: this may not be aligned */
|
d2 = inbuf[4] << 24 | inbuf[5] << 16 | inbuf[6] << 8 | inbuf[7];
|
||||||
d2 = ((u32*)inbuf)[1];
|
|
||||||
#else
|
|
||||||
((byte*)&d1)[3] = inbuf[0];
|
|
||||||
((byte*)&d1)[2] = inbuf[1];
|
|
||||||
((byte*)&d1)[1] = inbuf[2];
|
|
||||||
((byte*)&d1)[0] = inbuf[3];
|
|
||||||
((byte*)&d2)[3] = inbuf[4];
|
|
||||||
((byte*)&d2)[2] = inbuf[5];
|
|
||||||
((byte*)&d2)[1] = inbuf[6];
|
|
||||||
((byte*)&d2)[0] = inbuf[7];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
decrypt( bc, &d1, &d2 );
|
decrypt( bc, &d1, &d2 );
|
||||||
|
outbuf[0] = (d1 >> 24) & 0xff;
|
||||||
#ifdef BIG_ENDIAN_HOST
|
outbuf[1] = (d1 >> 16) & 0xff;
|
||||||
((u32*)outbuf)[0] = d1;
|
outbuf[2] = (d1 >> 8) & 0xff;
|
||||||
((u32*)outbuf)[1] = d2;
|
outbuf[3] = d1 & 0xff;
|
||||||
#else
|
outbuf[4] = (d2 >> 24) & 0xff;
|
||||||
outbuf[0] = ((byte*)&d1)[3];
|
outbuf[5] = (d2 >> 16) & 0xff;
|
||||||
outbuf[1] = ((byte*)&d1)[2];
|
outbuf[6] = (d2 >> 8) & 0xff;
|
||||||
outbuf[2] = ((byte*)&d1)[1];
|
outbuf[7] = d2 & 0xff;
|
||||||
outbuf[3] = ((byte*)&d1)[0];
|
|
||||||
outbuf[4] = ((byte*)&d2)[3];
|
|
||||||
outbuf[5] = ((byte*)&d2)[2];
|
|
||||||
outbuf[6] = ((byte*)&d2)[1];
|
|
||||||
outbuf[7] = ((byte*)&d2)[0];
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -225,8 +225,7 @@ do_cfb_encrypt( CIPHER_HANDLE c, byte *outbuf, byte *inbuf, unsigned nbytes )
|
|||||||
if( nbytes <= c->unused ) {
|
if( nbytes <= c->unused ) {
|
||||||
/* short enough to be encoded by the remaining XOR mask */
|
/* short enough to be encoded by the remaining XOR mask */
|
||||||
/* XOR the input with the IV and store input into IV */
|
/* XOR the input with the IV and store input into IV */
|
||||||
c->unused -= nbytes;
|
for(ivp=c->iv+STD_BLOCKSIZE - c->unused; nbytes; nbytes--, c->unused-- )
|
||||||
for(ivp=c->iv+STD_BLOCKSIZE - c->unused; nbytes; nbytes-- )
|
|
||||||
*outbuf++ = (*ivp++ ^= *inbuf++);
|
*outbuf++ = (*ivp++ ^= *inbuf++);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -271,8 +270,7 @@ do_cfb_decrypt( CIPHER_HANDLE c, byte *outbuf, byte *inbuf, unsigned nbytes )
|
|||||||
if( nbytes <= c->unused ) {
|
if( nbytes <= c->unused ) {
|
||||||
/* short enough to be encoded by the remaining XOR mask */
|
/* short enough to be encoded by the remaining XOR mask */
|
||||||
/* XOR the input with the IV and store input into IV */
|
/* XOR the input with the IV and store input into IV */
|
||||||
c->unused -= nbytes;
|
for(ivp=c->iv+STD_BLOCKSIZE - c->unused; nbytes; nbytes--,c->unused--){
|
||||||
for(ivp=c->iv+STD_BLOCKSIZE - c->unused; nbytes; nbytes-- ) {
|
|
||||||
temp = *inbuf++;
|
temp = *inbuf++;
|
||||||
*outbuf++ = *ivp ^ temp;
|
*outbuf++ = *ivp ^ temp;
|
||||||
*ivp++ = temp;
|
*ivp++ = temp;
|
||||||
|
@ -114,18 +114,31 @@ digest_algo_to_string( int algo )
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int
|
int
|
||||||
check_pubkey_algo( int algo )
|
check_pubkey_algo( int algo )
|
||||||
|
{
|
||||||
|
return check_pubkey_algo2( algo, 0 );
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************
|
||||||
|
* a usage of 0 means: don't care
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
check_pubkey_algo2( int algo, unsigned usage )
|
||||||
{
|
{
|
||||||
switch( algo ) {
|
switch( algo ) {
|
||||||
case PUBKEY_ALGO_ELGAMAL:
|
|
||||||
case PUBKEY_ALGO_DSA:
|
case PUBKEY_ALGO_DSA:
|
||||||
|
if( usage & 2 )
|
||||||
|
return G10ERR_WR_PUBKEY_ALGO;
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
case PUBKEY_ALGO_ELGAMAL:
|
||||||
|
return 0;
|
||||||
|
|
||||||
#ifdef HAVE_RSA_CIPHER
|
#ifdef HAVE_RSA_CIPHER
|
||||||
case PUBKEY_ALGO_RSA:
|
case PUBKEY_ALGO_RSA:
|
||||||
#endif
|
|
||||||
return 0;
|
return 0;
|
||||||
|
#endif
|
||||||
default:
|
default:
|
||||||
return G10ERR_PUBKEY_ALGO;
|
return G10ERR_PUBKEY_ALGO;
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,23 @@
|
|||||||
|
Wed Apr 8 16:19:39 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
|
* packet.h: packet structs now uses structs from the pubkey,
|
||||||
|
removed all copy operations from packet to pubkey structs.
|
||||||
|
|
||||||
|
Wed Apr 8 13:40:33 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
|
* trustdb.c (verify_own_certs): Fixed "public key not found".
|
||||||
|
|
||||||
|
* getkey.c (key_byname): New, combines public and secret key search.
|
||||||
|
|
||||||
|
* pkclist.c (build_pkc_list): Add new arg usage, changed all callers.
|
||||||
|
* skclist.c (build_skc_list): Likewise.
|
||||||
|
|
||||||
|
* ringedit.c (find_keyblock, keyring_search2): Removed.
|
||||||
|
|
||||||
|
Wed Apr 8 09:47:21 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
|
* sig-check.c (do_check): Applied small fix from Ulf Möller.
|
||||||
|
|
||||||
Tue Apr 7 19:28:07 1998 Werner Koch (wk@isil.d.shuttle.de)
|
Tue Apr 7 19:28:07 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
* cipher.c, encr-data.c, seckey-cert.c: Now uses cipher_xxxx
|
* cipher.c, encr-data.c, seckey-cert.c: Now uses cipher_xxxx
|
||||||
|
@ -190,8 +190,8 @@ do_public_cert( IOBUF out, int ctb, PKT_public_cert *pkc )
|
|||||||
mpi_write(a, pkc->d.dsa.y );
|
mpi_write(a, pkc->d.dsa.y );
|
||||||
}
|
}
|
||||||
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
mpi_write(a, pkc->d.rsa.rsa_n );
|
mpi_write(a, pkc->d.rsa.n );
|
||||||
mpi_write(a, pkc->d.rsa.rsa_e );
|
mpi_write(a, pkc->d.rsa.e );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
rc = G10ERR_PUBKEY_ALGO;
|
rc = G10ERR_PUBKEY_ALGO;
|
||||||
@ -286,8 +286,8 @@ do_secret_cert( IOBUF out, int ctb, PKT_secret_cert *skc )
|
|||||||
write_16(a, skc->csum );
|
write_16(a, skc->csum );
|
||||||
}
|
}
|
||||||
else if( skc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( skc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
mpi_write(a, skc->d.rsa.rsa_n );
|
mpi_write(a, skc->d.rsa.n );
|
||||||
mpi_write(a, skc->d.rsa.rsa_e );
|
mpi_write(a, skc->d.rsa.e );
|
||||||
if( skc->is_protected ) {
|
if( skc->is_protected ) {
|
||||||
assert( skc->protect.algo == CIPHER_ALGO_BLOWFISH
|
assert( skc->protect.algo == CIPHER_ALGO_BLOWFISH
|
||||||
|| skc->protect.algo == CIPHER_ALGO_CAST );
|
|| skc->protect.algo == CIPHER_ALGO_CAST );
|
||||||
@ -296,10 +296,10 @@ do_secret_cert( IOBUF out, int ctb, PKT_secret_cert *skc )
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
iobuf_put(a, 0 );
|
iobuf_put(a, 0 );
|
||||||
mpi_write(a, skc->d.rsa.rsa_d );
|
mpi_write(a, skc->d.rsa.d );
|
||||||
mpi_write(a, skc->d.rsa.rsa_p );
|
mpi_write(a, skc->d.rsa.p );
|
||||||
mpi_write(a, skc->d.rsa.rsa_q );
|
mpi_write(a, skc->d.rsa.q );
|
||||||
mpi_write(a, skc->d.rsa.rsa_u );
|
mpi_write(a, skc->d.rsa.u );
|
||||||
write_16(a, skc->csum );
|
write_16(a, skc->csum );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
10
g10/dsa.c
10
g10/dsa.c
@ -39,7 +39,6 @@ void
|
|||||||
g10_dsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
g10_dsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
||||||
MD_HANDLE md, int digest_algo )
|
MD_HANDLE md, int digest_algo )
|
||||||
{
|
{
|
||||||
DSA_secret_key skey;
|
|
||||||
MPI frame;
|
MPI frame;
|
||||||
byte *dp;
|
byte *dp;
|
||||||
|
|
||||||
@ -58,12 +57,9 @@ g10_dsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
|||||||
/ BYTES_PER_MPI_LIMB );
|
/ BYTES_PER_MPI_LIMB );
|
||||||
mpi_set_buffer( frame, md_read(md, digest_algo),
|
mpi_set_buffer( frame, md_read(md, digest_algo),
|
||||||
md_digest_length(digest_algo), 0 );
|
md_digest_length(digest_algo), 0 );
|
||||||
skey.p = skc->d.elg.p;
|
if( DBG_CIPHER )
|
||||||
skey.g = skc->d.elg.g;
|
log_mpidump("used sig frame: ", frame);
|
||||||
skey.y = skc->d.elg.y;
|
dsa_sign( sig->d.dsa.r, sig->d.dsa.s, frame, &skc->d.dsa );
|
||||||
skey.x = skc->d.elg.x;
|
|
||||||
dsa_sign( sig->d.dsa.r, sig->d.dsa.s, frame, &skey);
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
mpi_free(frame);
|
mpi_free(frame);
|
||||||
if( opt.verbose ) {
|
if( opt.verbose ) {
|
||||||
char *ustr = get_user_id_string( sig->keyid );
|
char *ustr = get_user_id_string( sig->keyid );
|
||||||
|
14
g10/elg.c
14
g10/elg.c
@ -37,7 +37,6 @@
|
|||||||
void
|
void
|
||||||
g10_elg_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek )
|
g10_elg_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek )
|
||||||
{
|
{
|
||||||
ELG_public_key pkey;
|
|
||||||
MPI frame;
|
MPI frame;
|
||||||
|
|
||||||
assert( enc->pubkey_algo == PUBKEY_ALGO_ELGAMAL );
|
assert( enc->pubkey_algo == PUBKEY_ALGO_ELGAMAL );
|
||||||
@ -46,12 +45,9 @@ g10_elg_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek )
|
|||||||
enc->d.elg.b = mpi_alloc( mpi_get_nlimbs(pkc->d.elg.p) );
|
enc->d.elg.b = mpi_alloc( mpi_get_nlimbs(pkc->d.elg.p) );
|
||||||
keyid_from_pkc( pkc, enc->keyid );
|
keyid_from_pkc( pkc, enc->keyid );
|
||||||
frame = encode_session_key( dek, mpi_get_nbits(pkc->d.elg.p) );
|
frame = encode_session_key( dek, mpi_get_nbits(pkc->d.elg.p) );
|
||||||
pkey.p = pkc->d.elg.p;
|
|
||||||
pkey.g = pkc->d.elg.g;
|
|
||||||
pkey.y = pkc->d.elg.y;
|
|
||||||
if( DBG_CIPHER )
|
if( DBG_CIPHER )
|
||||||
log_mpidump("Plain DEK frame: ", frame);
|
log_mpidump("Plain DEK frame: ", frame);
|
||||||
elg_encrypt( enc->d.elg.a, enc->d.elg.b, frame, &pkey);
|
elg_encrypt( enc->d.elg.a, enc->d.elg.b, frame, &pkc->d.elg );
|
||||||
mpi_free( frame );
|
mpi_free( frame );
|
||||||
if( DBG_CIPHER ) {
|
if( DBG_CIPHER ) {
|
||||||
log_mpidump("Encry DEK a: ", enc->d.elg.a );
|
log_mpidump("Encry DEK a: ", enc->d.elg.a );
|
||||||
@ -69,7 +65,6 @@ void
|
|||||||
g10_elg_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
g10_elg_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
||||||
MD_HANDLE md, int digest_algo )
|
MD_HANDLE md, int digest_algo )
|
||||||
{
|
{
|
||||||
ELG_secret_key skey;
|
|
||||||
MPI frame;
|
MPI frame;
|
||||||
byte *dp;
|
byte *dp;
|
||||||
|
|
||||||
@ -85,12 +80,7 @@ g10_elg_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
|||||||
sig->d.elg.a = mpi_alloc( mpi_get_nlimbs(skc->d.elg.p) );
|
sig->d.elg.a = mpi_alloc( mpi_get_nlimbs(skc->d.elg.p) );
|
||||||
sig->d.elg.b = mpi_alloc( mpi_get_nlimbs(skc->d.elg.p) );
|
sig->d.elg.b = mpi_alloc( mpi_get_nlimbs(skc->d.elg.p) );
|
||||||
frame = encode_md_value( md, mpi_get_nbits(skc->d.elg.p));
|
frame = encode_md_value( md, mpi_get_nbits(skc->d.elg.p));
|
||||||
skey.p = skc->d.elg.p;
|
elg_sign( sig->d.elg.a, sig->d.elg.b, frame, &skc->d.elg );
|
||||||
skey.g = skc->d.elg.g;
|
|
||||||
skey.y = skc->d.elg.y;
|
|
||||||
skey.x = skc->d.elg.x;
|
|
||||||
elg_sign( sig->d.elg.a, sig->d.elg.b, frame, &skey);
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
mpi_free(frame);
|
mpi_free(frame);
|
||||||
if( opt.verbose ) {
|
if( opt.verbose ) {
|
||||||
char *ustr = get_user_id_string( sig->keyid );
|
char *ustr = get_user_id_string( sig->keyid );
|
||||||
|
@ -172,7 +172,7 @@ encode_crypt( const char *filename, STRLIST remusr )
|
|||||||
memset( &afx, 0, sizeof afx);
|
memset( &afx, 0, sizeof afx);
|
||||||
memset( &zfx, 0, sizeof zfx);
|
memset( &zfx, 0, sizeof zfx);
|
||||||
|
|
||||||
if( (rc=build_pkc_list( remusr, &pkc_list)) )
|
if( (rc=build_pkc_list( remusr, &pkc_list, 2)) )
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
/* prepare iobufs */
|
/* prepare iobufs */
|
||||||
|
@ -100,8 +100,8 @@ release_public_cert_parts( PKT_public_cert *cert )
|
|||||||
mpi_free( cert->d.dsa.y ); cert->d.dsa.y = NULL;
|
mpi_free( cert->d.dsa.y ); cert->d.dsa.y = NULL;
|
||||||
}
|
}
|
||||||
else if( cert->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( cert->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
mpi_free( cert->d.rsa.rsa_n ); cert->d.rsa.rsa_n = NULL;
|
mpi_free( cert->d.rsa.n ); cert->d.rsa.n = NULL;
|
||||||
mpi_free( cert->d.rsa.rsa_e ); cert->d.rsa.rsa_e = NULL;
|
mpi_free( cert->d.rsa.e ); cert->d.rsa.e = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -130,8 +130,8 @@ copy_public_cert( PKT_public_cert *d, PKT_public_cert *s )
|
|||||||
d->d.dsa.y = mpi_copy( s->d.dsa.y );
|
d->d.dsa.y = mpi_copy( s->d.dsa.y );
|
||||||
}
|
}
|
||||||
else if( s->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( s->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
d->d.rsa.rsa_n = mpi_copy( s->d.rsa.rsa_n );
|
d->d.rsa.n = mpi_copy( s->d.rsa.n );
|
||||||
d->d.rsa.rsa_e = mpi_copy( s->d.rsa.rsa_e );
|
d->d.rsa.e = mpi_copy( s->d.rsa.e );
|
||||||
}
|
}
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
@ -153,12 +153,12 @@ release_secret_cert_parts( PKT_secret_cert *cert )
|
|||||||
mpi_free( cert->d.dsa.x ); cert->d.dsa.x = NULL;
|
mpi_free( cert->d.dsa.x ); cert->d.dsa.x = NULL;
|
||||||
}
|
}
|
||||||
else if( cert->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( cert->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
mpi_free( cert->d.rsa.rsa_n ); cert->d.rsa.rsa_n = NULL;
|
mpi_free( cert->d.rsa.n ); cert->d.rsa.n = NULL;
|
||||||
mpi_free( cert->d.rsa.rsa_e ); cert->d.rsa.rsa_e = NULL;
|
mpi_free( cert->d.rsa.e ); cert->d.rsa.e = NULL;
|
||||||
mpi_free( cert->d.rsa.rsa_d ); cert->d.rsa.rsa_d = NULL;
|
mpi_free( cert->d.rsa.d ); cert->d.rsa.d = NULL;
|
||||||
mpi_free( cert->d.rsa.rsa_p ); cert->d.rsa.rsa_p = NULL;
|
mpi_free( cert->d.rsa.p ); cert->d.rsa.p = NULL;
|
||||||
mpi_free( cert->d.rsa.rsa_q ); cert->d.rsa.rsa_q = NULL;
|
mpi_free( cert->d.rsa.q ); cert->d.rsa.q = NULL;
|
||||||
mpi_free( cert->d.rsa.rsa_u ); cert->d.rsa.rsa_u = NULL;
|
mpi_free( cert->d.rsa.u ); cert->d.rsa.u = NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,12 +189,12 @@ copy_secret_cert( PKT_secret_cert *d, PKT_secret_cert *s )
|
|||||||
d->d.dsa.x = mpi_copy( s->d.dsa.x );
|
d->d.dsa.x = mpi_copy( s->d.dsa.x );
|
||||||
}
|
}
|
||||||
else if( s->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( s->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
d->d.rsa.rsa_n = mpi_copy( s->d.rsa.rsa_n );
|
d->d.rsa.n = mpi_copy( s->d.rsa.n );
|
||||||
d->d.rsa.rsa_e = mpi_copy( s->d.rsa.rsa_e );
|
d->d.rsa.e = mpi_copy( s->d.rsa.e );
|
||||||
d->d.rsa.rsa_d = mpi_copy( s->d.rsa.rsa_d );
|
d->d.rsa.d = mpi_copy( s->d.rsa.d );
|
||||||
d->d.rsa.rsa_p = mpi_copy( s->d.rsa.rsa_p );
|
d->d.rsa.p = mpi_copy( s->d.rsa.p );
|
||||||
d->d.rsa.rsa_q = mpi_copy( s->d.rsa.rsa_q );
|
d->d.rsa.q = mpi_copy( s->d.rsa.q );
|
||||||
d->d.rsa.rsa_u = mpi_copy( s->d.rsa.rsa_u );
|
d->d.rsa.u = mpi_copy( s->d.rsa.u );
|
||||||
}
|
}
|
||||||
return d;
|
return d;
|
||||||
}
|
}
|
||||||
@ -337,9 +337,9 @@ cmp_public_certs( PKT_public_cert *a, PKT_public_cert *b )
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
else if( a->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( a->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
if( mpi_cmp( a->d.rsa.rsa_n , b->d.rsa.rsa_n ) )
|
if( mpi_cmp( a->d.rsa.n , b->d.rsa.n ) )
|
||||||
return -1;
|
return -1;
|
||||||
if( mpi_cmp( a->d.rsa.rsa_e , b->d.rsa.rsa_e ) )
|
if( mpi_cmp( a->d.rsa.e , b->d.rsa.e ) )
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -378,9 +378,9 @@ cmp_public_secret_cert( PKT_public_cert *pkc, PKT_secret_cert *skc )
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
if( mpi_cmp( pkc->d.rsa.rsa_n , skc->d.rsa.rsa_n ) )
|
if( mpi_cmp( pkc->d.rsa.n , skc->d.rsa.n ) )
|
||||||
return -1;
|
return -1;
|
||||||
if( mpi_cmp( pkc->d.rsa.rsa_e , skc->d.rsa.rsa_e ) )
|
if( mpi_cmp( pkc->d.rsa.e , skc->d.rsa.e ) )
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
102
g10/getkey.c
102
g10/getkey.c
@ -69,7 +69,8 @@ static int pkc_cache_entries; /* number of entries in pkc cache */
|
|||||||
|
|
||||||
|
|
||||||
static int lookup( PKT_public_cert *pkc,
|
static int lookup( PKT_public_cert *pkc,
|
||||||
int mode, u32 *keyid, const char *name );
|
int mode, u32 *keyid, const char *name,
|
||||||
|
KBNODE *ret_keyblock );
|
||||||
static int lookup_skc( PKT_secret_cert *skc,
|
static int lookup_skc( PKT_secret_cert *skc,
|
||||||
int mode, u32 *keyid, const char *name );
|
int mode, u32 *keyid, const char *name );
|
||||||
|
|
||||||
@ -238,7 +239,6 @@ get_pubkey( PKT_public_cert *pkc, u32 *keyid )
|
|||||||
int rc = 0;
|
int rc = 0;
|
||||||
pkc_cache_entry_t ce;
|
pkc_cache_entry_t ce;
|
||||||
|
|
||||||
|
|
||||||
/* lets see wether we checked the keyid already */
|
/* lets see wether we checked the keyid already */
|
||||||
for( kl = unknown_keyids; kl; kl = kl->next )
|
for( kl = unknown_keyids; kl; kl = kl->next )
|
||||||
if( kl->keyid[0] == keyid[0] && kl->keyid[1] == keyid[1] )
|
if( kl->keyid[0] == keyid[0] && kl->keyid[1] == keyid[1] )
|
||||||
@ -259,7 +259,7 @@ get_pubkey( PKT_public_cert *pkc, u32 *keyid )
|
|||||||
|
|
||||||
|
|
||||||
/* do a lookup */
|
/* do a lookup */
|
||||||
rc = lookup( pkc, 11, keyid, NULL );
|
rc = lookup( pkc, 11, keyid, NULL, NULL );
|
||||||
if( !rc )
|
if( !rc )
|
||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
@ -329,8 +329,11 @@ hextobyte( const byte *s )
|
|||||||
* - If the userid starts with a '*' a case insensitive substring search is
|
* - If the userid starts with a '*' a case insensitive substring search is
|
||||||
* done (This is also the default).
|
* done (This is also the default).
|
||||||
*/
|
*/
|
||||||
int
|
|
||||||
get_pubkey_byname( PKT_public_cert *pkc, const char *name )
|
|
||||||
|
static int
|
||||||
|
key_byname( int secret,
|
||||||
|
PKT_public_cert *pkc, PKT_secret_cert *skc, const char *name )
|
||||||
{
|
{
|
||||||
int internal = 0;
|
int internal = 0;
|
||||||
int rc = 0;
|
int rc = 0;
|
||||||
@ -424,23 +427,60 @@ get_pubkey_byname( PKT_public_cert *pkc, const char *name )
|
|||||||
if( rc )
|
if( rc )
|
||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
if( !pkc ) {
|
if( secret ) {
|
||||||
pkc = m_alloc_clear( sizeof *pkc );
|
if( !skc ) {
|
||||||
internal++;
|
skc = m_alloc_clear( sizeof *skc );
|
||||||
|
internal++;
|
||||||
|
}
|
||||||
|
rc = mode < 16? lookup_skc( skc, mode, keyid, name )
|
||||||
|
: lookup_skc( skc, mode, keyid, fprint );
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if( !pkc ) {
|
||||||
|
pkc = m_alloc_clear( sizeof *pkc );
|
||||||
|
internal++;
|
||||||
|
}
|
||||||
|
rc = mode < 16? lookup( pkc, mode, keyid, name, NULL )
|
||||||
|
: lookup( pkc, mode, keyid, fprint, NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = mode < 16? lookup( pkc, mode, keyid, name )
|
|
||||||
: lookup( pkc, mode, keyid, fprint );
|
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
if( internal )
|
if( internal && secret )
|
||||||
m_free(pkc);
|
m_free( skc );
|
||||||
|
else if( internal )
|
||||||
|
m_free( pkc );
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
get_pubkey_byname( PKT_public_cert *pkc, const char *name )
|
||||||
|
{
|
||||||
|
return key_byname( 0, pkc, NULL, name );
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/****************
|
/****************
|
||||||
* Get a secret key and store it into skey
|
* Search for a key with the given fingerprint and return the
|
||||||
|
* complete keyblock which may have more than only this key.
|
||||||
|
* The fingerprint should always be 20 bytes, fill with zeroes
|
||||||
|
* for 16 byte fprints.
|
||||||
|
*/
|
||||||
|
int
|
||||||
|
get_keyblock_byfprint( KBNODE *ret_keyblock, const byte *fprint )
|
||||||
|
{
|
||||||
|
int rc;
|
||||||
|
PKT_public_cert *pkc = m_alloc_clear( sizeof *pkc );
|
||||||
|
|
||||||
|
rc = lookup( pkc, 20, NULL, fprint, ret_keyblock );
|
||||||
|
|
||||||
|
free_public_cert( pkc );
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
|
||||||
|
/****************
|
||||||
|
* Get a secret key and store it into skc
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
get_seckey( PKT_secret_cert *skc, u32 *keyid )
|
get_seckey( PKT_secret_cert *skc, u32 *keyid )
|
||||||
@ -486,8 +526,8 @@ get_seckey_byname( PKT_secret_cert *skc, const char *name, int unprotect )
|
|||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
/* fixme: add support for compare_name */
|
rc = name ? key_byname( 1, NULL, skc, name )
|
||||||
rc = lookup_skc( skc, name? 2:15, NULL, name );
|
: lookup_skc( skc, 15, NULL, NULL );
|
||||||
if( !rc && unprotect )
|
if( !rc && unprotect )
|
||||||
rc = check_secret_key( skc );
|
rc = check_secret_key( skc );
|
||||||
|
|
||||||
@ -547,9 +587,12 @@ compare_name( const char *uid, size_t uidlen, const char *name, int mode )
|
|||||||
* 20 = lookup by 20 byte fingerprint which is stored in NAME
|
* 20 = lookup by 20 byte fingerprint which is stored in NAME
|
||||||
* Caller must provide an empty PKC, if the pubkey_algo is filled in, only
|
* Caller must provide an empty PKC, if the pubkey_algo is filled in, only
|
||||||
* a key of this algo will be returned.
|
* a key of this algo will be returned.
|
||||||
|
* If ret_keyblock is not NULL, the complete keyblock is returned also
|
||||||
|
* and the caller must release it.
|
||||||
*/
|
*/
|
||||||
static int
|
static int
|
||||||
lookup( PKT_public_cert *pkc, int mode, u32 *keyid, const char *name )
|
lookup( PKT_public_cert *pkc, int mode, u32 *keyid,
|
||||||
|
const char *name, KBNODE *ret_keyblock )
|
||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
KBNODE keyblock = NULL;
|
KBNODE keyblock = NULL;
|
||||||
@ -593,12 +636,22 @@ lookup( PKT_public_cert *pkc, int mode, u32 *keyid, const char *name )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else { /* keyid or fingerprint lookup */
|
else { /* keyid or fingerprint lookup */
|
||||||
|
if( DBG_CACHE && (mode== 10 || mode==11) ) {
|
||||||
|
log_debug("lookup keyid=%08lx%08lx req_algo=%d mode=%d\n",
|
||||||
|
(ulong)keyid[0], (ulong)keyid[1],
|
||||||
|
pkc->pubkey_algo, mode );
|
||||||
|
}
|
||||||
for(k=keyblock; k; k = k->next ) {
|
for(k=keyblock; k; k = k->next ) {
|
||||||
if( k->pkt->pkttype == PKT_PUBLIC_CERT
|
if( k->pkt->pkttype == PKT_PUBLIC_CERT
|
||||||
|| k->pkt->pkttype == PKT_PUBKEY_SUBCERT ) {
|
|| k->pkt->pkttype == PKT_PUBKEY_SUBCERT ) {
|
||||||
if( mode == 10 || mode == 11 ) {
|
if( mode == 10 || mode == 11 ) {
|
||||||
u32 aki[2];
|
u32 aki[2];
|
||||||
keyid_from_pkc( k->pkt->pkt.public_cert, aki );
|
keyid_from_pkc( k->pkt->pkt.public_cert, aki );
|
||||||
|
if( DBG_CACHE ) {
|
||||||
|
log_debug(" aki=%08lx%08lx algo=%d\n",
|
||||||
|
(ulong)aki[0], (ulong)aki[1],
|
||||||
|
k->pkt->pkt.public_cert->pubkey_algo );
|
||||||
|
}
|
||||||
if( aki[1] == keyid[1]
|
if( aki[1] == keyid[1]
|
||||||
&& ( mode == 10 || aki[0] == keyid[0] )
|
&& ( mode == 10 || aki[0] == keyid[0] )
|
||||||
&& ( !pkc->pubkey_algo
|
&& ( !pkc->pubkey_algo
|
||||||
@ -643,6 +696,10 @@ lookup( PKT_public_cert *pkc, int mode, u32 *keyid, const char *name )
|
|||||||
assert( k->pkt->pkttype == PKT_PUBLIC_CERT
|
assert( k->pkt->pkttype == PKT_PUBLIC_CERT
|
||||||
|| k->pkt->pkttype == PKT_PUBKEY_SUBCERT );
|
|| k->pkt->pkttype == PKT_PUBKEY_SUBCERT );
|
||||||
copy_public_cert( pkc, k->pkt->pkt.public_cert );
|
copy_public_cert( pkc, k->pkt->pkt.public_cert );
|
||||||
|
if( ret_keyblock ) {
|
||||||
|
*ret_keyblock = keyblock;
|
||||||
|
keyblock = NULL;
|
||||||
|
}
|
||||||
break; /* enumeration */
|
break; /* enumeration */
|
||||||
}
|
}
|
||||||
release_kbnode( keyblock );
|
release_kbnode( keyblock );
|
||||||
@ -708,12 +765,22 @@ lookup_skc( PKT_secret_cert *skc, int mode, u32 *keyid, const char *name )
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else { /* keyid or fingerprint lookup */
|
else { /* keyid or fingerprint lookup */
|
||||||
|
if( DBG_CACHE && (mode== 10 || mode==11) ) {
|
||||||
|
log_debug("lookup_skc keyid=%08lx%08lx req_algo=%d mode=%d\n",
|
||||||
|
(ulong)keyid[0], (ulong)keyid[1],
|
||||||
|
skc->pubkey_algo, mode );
|
||||||
|
}
|
||||||
for(k=keyblock; k; k = k->next ) {
|
for(k=keyblock; k; k = k->next ) {
|
||||||
if( k->pkt->pkttype == PKT_SECRET_CERT
|
if( k->pkt->pkttype == PKT_SECRET_CERT
|
||||||
|| k->pkt->pkttype == PKT_SECKEY_SUBCERT ) {
|
|| k->pkt->pkttype == PKT_SECKEY_SUBCERT ) {
|
||||||
if( mode == 10 || mode == 11 ) {
|
if( mode == 10 || mode == 11 ) {
|
||||||
u32 aki[2];
|
u32 aki[2];
|
||||||
keyid_from_skc( k->pkt->pkt.secret_cert, aki );
|
keyid_from_skc( k->pkt->pkt.secret_cert, aki );
|
||||||
|
if( DBG_CACHE ) {
|
||||||
|
log_debug(" aki=%08lx%08lx algo=%d\n",
|
||||||
|
(ulong)aki[0], (ulong)aki[1],
|
||||||
|
k->pkt->pkt.secret_cert->pubkey_algo );
|
||||||
|
}
|
||||||
if( aki[1] == keyid[1]
|
if( aki[1] == keyid[1]
|
||||||
&& ( mode == 10 || aki[0] == keyid[0] )
|
&& ( mode == 10 || aki[0] == keyid[0] )
|
||||||
&& ( !skc->pubkey_algo
|
&& ( !skc->pubkey_algo
|
||||||
@ -825,7 +892,8 @@ enum_secret_keys( void **context, PKT_secret_cert *skc )
|
|||||||
while( (rc=parse_packet(c->iobuf, &pkt)) != -1 ) {
|
while( (rc=parse_packet(c->iobuf, &pkt)) != -1 ) {
|
||||||
if( rc )
|
if( rc )
|
||||||
; /* e.g. unknown packet */
|
; /* e.g. unknown packet */
|
||||||
else if( pkt.pkttype == PKT_SECRET_CERT ) {
|
else if( pkt.pkttype == PKT_SECRET_CERT
|
||||||
|
|| pkt.pkttype == PKT_SECKEY_SUBCERT ) {
|
||||||
copy_secret_cert( skc, pkt.pkt.secret_cert );
|
copy_secret_cert( skc, pkt.pkt.secret_cert );
|
||||||
set_packet_list_mode(save_mode);
|
set_packet_list_mode(save_mode);
|
||||||
return 0; /* found */
|
return 0; /* found */
|
||||||
|
@ -275,7 +275,8 @@ dump_kbnode( KBNODE node )
|
|||||||
fprintf(stderr, " keyid=%08lX\n",
|
fprintf(stderr, " keyid=%08lX\n",
|
||||||
(ulong)node->pkt->pkt.signature->keyid[1] );
|
(ulong)node->pkt->pkt.signature->keyid[1] );
|
||||||
}
|
}
|
||||||
else if( node->pkt->pkttype == PKT_PUBLIC_CERT ) {
|
else if( node->pkt->pkttype == PKT_PUBLIC_CERT
|
||||||
|
|| node->pkt->pkttype == PKT_PUBKEY_SUBCERT ) {
|
||||||
fprintf(stderr, " keyid=%08lX\n", (ulong)
|
fprintf(stderr, " keyid=%08lX\n", (ulong)
|
||||||
keyid_from_pkc( node->pkt->pkt.public_cert, NULL ));
|
keyid_from_pkc( node->pkt->pkt.public_cert, NULL ));
|
||||||
}
|
}
|
||||||
|
@ -87,11 +87,12 @@ struct pubkey_find_info {
|
|||||||
|
|
||||||
/*-- pkclist.c --*/
|
/*-- pkclist.c --*/
|
||||||
void release_pkc_list( PKC_LIST pkc_list );
|
void release_pkc_list( PKC_LIST pkc_list );
|
||||||
int build_pkc_list( STRLIST remusr, PKC_LIST *ret_pkc_list );
|
int build_pkc_list( STRLIST remusr, PKC_LIST *ret_pkc_list, unsigned usage );
|
||||||
|
|
||||||
/*-- skclist.c --*/
|
/*-- skclist.c --*/
|
||||||
void release_skc_list( SKC_LIST skc_list );
|
void release_skc_list( SKC_LIST skc_list );
|
||||||
int build_skc_list( STRLIST locusr, SKC_LIST *ret_skc_list, int unlock );
|
int build_skc_list( STRLIST locusr, SKC_LIST *ret_skc_list,
|
||||||
|
int unlock, unsigned usage );
|
||||||
|
|
||||||
/*-- passphrase.h --*/
|
/*-- passphrase.h --*/
|
||||||
void set_passphrase_fd( int fd );
|
void set_passphrase_fd( int fd );
|
||||||
@ -103,11 +104,10 @@ int make_dek_from_passphrase( DEK *dek, int mode, byte *salt );
|
|||||||
void add_keyring( const char *name );
|
void add_keyring( const char *name );
|
||||||
const char *get_keyring( int sequence );
|
const char *get_keyring( int sequence );
|
||||||
void add_secret_keyring( const char *name );
|
void add_secret_keyring( const char *name );
|
||||||
/*void cache_public_cert( PKT_public_cert *pkc );
|
|
||||||
void cache_user_id( PKT_user_id *uid, u32 *keyid );*/
|
|
||||||
int get_pubkey( PKT_public_cert *pkc, u32 *keyid );
|
int get_pubkey( PKT_public_cert *pkc, u32 *keyid );
|
||||||
int get_pubkey_byname( PKT_public_cert *pkc, const char *name );
|
int get_pubkey_byname( PKT_public_cert *pkc, const char *name );
|
||||||
int get_seckey( PKT_secret_cert *skc, u32 *keyid );
|
int get_seckey( PKT_secret_cert *skc, u32 *keyid );
|
||||||
|
int get_keyblock_byfprint( KBNODE *ret_keyblock, const byte *fprint );
|
||||||
int seckey_available( u32 *keyid );
|
int seckey_available( u32 *keyid );
|
||||||
int get_seckey_byname( PKT_secret_cert *skc, const char *name, int unlock );
|
int get_seckey_byname( PKT_secret_cert *skc, const char *name, int unlock );
|
||||||
int enum_secret_keys( void **context, PKT_secret_cert *skc );
|
int enum_secret_keys( void **context, PKT_secret_cert *skc );
|
||||||
|
16
g10/keyid.c
16
g10/keyid.c
@ -262,7 +262,7 @@ keyid_from_skc( PKT_secret_cert *skc, u32 *keyid )
|
|||||||
md_close(md);
|
md_close(md);
|
||||||
}
|
}
|
||||||
else if( skc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( skc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
lowbits = mpi_get_keyid( skc->d.rsa.rsa_n, keyid );
|
lowbits = mpi_get_keyid( skc->d.rsa.n, keyid );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
keyid[0] = keyid[1] = lowbits = 0;
|
keyid[0] = keyid[1] = lowbits = 0;
|
||||||
@ -311,7 +311,7 @@ keyid_from_pkc( PKT_public_cert *pkc, u32 *keyid )
|
|||||||
md_close(md);
|
md_close(md);
|
||||||
}
|
}
|
||||||
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
lowbits = mpi_get_keyid( pkc->d.rsa.rsa_n, keyid );
|
lowbits = mpi_get_keyid( pkc->d.rsa.n, keyid );
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
keyid[0] = keyid[1] = lowbits = 0;
|
keyid[0] = keyid[1] = lowbits = 0;
|
||||||
@ -344,7 +344,7 @@ nbits_from_pkc( PKT_public_cert *pkc )
|
|||||||
return mpi_get_nbits( pkc->d.dsa.p );
|
return mpi_get_nbits( pkc->d.dsa.p );
|
||||||
}
|
}
|
||||||
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
return mpi_get_nbits( pkc->d.rsa.rsa_n );
|
return mpi_get_nbits( pkc->d.rsa.n );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
@ -363,7 +363,7 @@ nbits_from_skc( PKT_secret_cert *skc )
|
|||||||
return mpi_get_nbits( skc->d.dsa.p );
|
return mpi_get_nbits( skc->d.dsa.p );
|
||||||
}
|
}
|
||||||
else if( skc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( skc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
return mpi_get_nbits( skc->d.rsa.rsa_n );
|
return mpi_get_nbits( skc->d.rsa.n );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
return 0;
|
return 0;
|
||||||
@ -442,8 +442,8 @@ fingerprint_from_skc( PKT_secret_cert *skc, size_t *ret_len )
|
|||||||
pkc.d.dsa.y = skc->d.dsa.y;
|
pkc.d.dsa.y = skc->d.dsa.y;
|
||||||
}
|
}
|
||||||
else if( pkc.pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( pkc.pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
pkc.d.rsa.rsa_n = skc->d.rsa.rsa_n;
|
pkc.d.rsa.n = skc->d.rsa.n;
|
||||||
pkc.d.rsa.rsa_e = skc->d.rsa.rsa_e;
|
pkc.d.rsa.e = skc->d.rsa.e;
|
||||||
}
|
}
|
||||||
p = fingerprint_from_pkc( &pkc, ret_len );
|
p = fingerprint_from_pkc( &pkc, ret_len );
|
||||||
memset(&pkc, 0, sizeof pkc); /* not really needed */
|
memset(&pkc, 0, sizeof pkc); /* not really needed */
|
||||||
@ -489,10 +489,10 @@ fingerprint_from_pkc( PKT_public_cert *pkc, size_t *ret_len )
|
|||||||
MD_HANDLE md;
|
MD_HANDLE md;
|
||||||
|
|
||||||
md = md_open( DIGEST_ALGO_MD5, 0);
|
md = md_open( DIGEST_ALGO_MD5, 0);
|
||||||
p = buf = mpi_get_buffer( pkc->d.rsa.rsa_n, &n, NULL );
|
p = buf = mpi_get_buffer( pkc->d.rsa.n, &n, NULL );
|
||||||
md_write( md, p, n );
|
md_write( md, p, n );
|
||||||
m_free(buf);
|
m_free(buf);
|
||||||
p = buf = mpi_get_buffer( pkc->d.rsa.rsa_e, &n, NULL );
|
p = buf = mpi_get_buffer( pkc->d.rsa.e, &n, NULL );
|
||||||
md_write( md, p, n );
|
md_write( md, p, n );
|
||||||
m_free(buf);
|
m_free(buf);
|
||||||
md_final(md);
|
md_final(md);
|
||||||
|
@ -226,6 +226,7 @@ proc_plaintext( CTX c, PACKET *pkt )
|
|||||||
* textmode filter (sigclass 0x01)
|
* textmode filter (sigclass 0x01)
|
||||||
*/
|
*/
|
||||||
c->mfx.md = md_open( DIGEST_ALGO_RMD160, 0);
|
c->mfx.md = md_open( DIGEST_ALGO_RMD160, 0);
|
||||||
|
md_enable( c->mfx.md, DIGEST_ALGO_SHA1 );
|
||||||
md_enable( c->mfx.md, DIGEST_ALGO_MD5 );
|
md_enable( c->mfx.md, DIGEST_ALGO_MD5 );
|
||||||
rc = handle_plaintext( pt, &c->mfx );
|
rc = handle_plaintext( pt, &c->mfx );
|
||||||
if( rc )
|
if( rc )
|
||||||
|
48
g10/packet.h
48
g10/packet.h
@ -27,6 +27,12 @@
|
|||||||
#include "cipher.h"
|
#include "cipher.h"
|
||||||
#include "filter.h"
|
#include "filter.h"
|
||||||
|
|
||||||
|
#ifndef HAVE_RSA_CIPHER
|
||||||
|
/* although we don't have RSA we need these structures to handle keyrings */
|
||||||
|
typedef struct { MPI e, n; } RSA_public_key;
|
||||||
|
typedef struct { MPI e, n, p, q, d, u; } RSA_secret_key;
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
PKT_NONE =0,
|
PKT_NONE =0,
|
||||||
PKT_PUBKEY_ENC =1, /* public key encrypted packet */
|
PKT_PUBKEY_ENC =1, /* public key encrypted packet */
|
||||||
@ -106,21 +112,9 @@ typedef struct {
|
|||||||
byte pubkey_algo; /* algorithm used for public key scheme */
|
byte pubkey_algo; /* algorithm used for public key scheme */
|
||||||
ulong local_id; /* internal use, valid if > 0 */
|
ulong local_id; /* internal use, valid if > 0 */
|
||||||
union {
|
union {
|
||||||
struct {
|
ELG_public_key elg;
|
||||||
MPI p; /* prime */
|
DSA_public_key dsa;
|
||||||
MPI g; /* group generator */
|
RSA_public_key rsa;
|
||||||
MPI y; /* g^x mod p */
|
|
||||||
} elg;
|
|
||||||
struct {
|
|
||||||
MPI p; /* prime */
|
|
||||||
MPI q; /* group order */
|
|
||||||
MPI g; /* group generator */
|
|
||||||
MPI y; /* g^x mod p */
|
|
||||||
} dsa;
|
|
||||||
struct {
|
|
||||||
MPI rsa_n; /* public modulus */
|
|
||||||
MPI rsa_e; /* public exponent */
|
|
||||||
} rsa;
|
|
||||||
} d;
|
} d;
|
||||||
} PKT_public_cert;
|
} PKT_public_cert;
|
||||||
|
|
||||||
@ -143,27 +137,9 @@ typedef struct {
|
|||||||
byte iv[8]; /* initialization vector for CFB mode */
|
byte iv[8]; /* initialization vector for CFB mode */
|
||||||
} protect;
|
} protect;
|
||||||
union {
|
union {
|
||||||
struct {
|
ELG_secret_key elg;
|
||||||
MPI p; /* prime */
|
DSA_secret_key dsa;
|
||||||
MPI g; /* group generator */
|
RSA_secret_key rsa;
|
||||||
MPI y; /* g^x mod p */
|
|
||||||
MPI x; /* secret exponent */
|
|
||||||
} elg;
|
|
||||||
struct {
|
|
||||||
MPI p; /* prime */
|
|
||||||
MPI q; /* group order */
|
|
||||||
MPI g; /* group generator */
|
|
||||||
MPI y; /* g^x mod p */
|
|
||||||
MPI x; /* secret exponent */
|
|
||||||
} dsa;
|
|
||||||
struct {
|
|
||||||
MPI rsa_n; /* public modulus */
|
|
||||||
MPI rsa_e; /* public exponent */
|
|
||||||
MPI rsa_d; /* secret descryption exponent */
|
|
||||||
MPI rsa_p; /* secret first prime number */
|
|
||||||
MPI rsa_q; /* secret second prime number */
|
|
||||||
MPI rsa_u; /* secret multiplicative inverse */
|
|
||||||
} rsa;
|
|
||||||
} d;
|
} d;
|
||||||
u16 csum; /* checksum */
|
u16 csum; /* checksum */
|
||||||
} PKT_secret_cert;
|
} PKT_secret_cert;
|
||||||
|
@ -1084,15 +1084,15 @@ parse_certificate( IOBUF inp, int pkttype, unsigned long pktlen,
|
|||||||
putchar('\n');
|
putchar('\n');
|
||||||
}
|
}
|
||||||
if( pkttype == PKT_PUBLIC_CERT || pkttype == PKT_PUBKEY_SUBCERT ) {
|
if( pkttype == PKT_PUBLIC_CERT || pkttype == PKT_PUBKEY_SUBCERT ) {
|
||||||
pkt->pkt.public_cert->d.rsa.rsa_n = rsa_pub_mod;
|
pkt->pkt.public_cert->d.rsa.n = rsa_pub_mod;
|
||||||
pkt->pkt.public_cert->d.rsa.rsa_e = rsa_pub_exp;
|
pkt->pkt.public_cert->d.rsa.e = rsa_pub_exp;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
PKT_secret_cert *cert = pkt->pkt.secret_cert;
|
PKT_secret_cert *cert = pkt->pkt.secret_cert;
|
||||||
byte temp[8];
|
byte temp[8];
|
||||||
|
|
||||||
pkt->pkt.secret_cert->d.rsa.rsa_n = rsa_pub_mod;
|
pkt->pkt.secret_cert->d.rsa.n = rsa_pub_mod;
|
||||||
pkt->pkt.secret_cert->d.rsa.rsa_e = rsa_pub_exp;
|
pkt->pkt.secret_cert->d.rsa.e = rsa_pub_exp;
|
||||||
cert->protect.algo = iobuf_get_noeof(inp); pktlen--;
|
cert->protect.algo = iobuf_get_noeof(inp); pktlen--;
|
||||||
if( list_mode )
|
if( list_mode )
|
||||||
printf( "\tprotect algo: %d\n", cert->protect.algo);
|
printf( "\tprotect algo: %d\n", cert->protect.algo);
|
||||||
@ -1112,22 +1112,22 @@ parse_certificate( IOBUF inp, int pkttype, unsigned long pktlen,
|
|||||||
else
|
else
|
||||||
cert->is_protected = 0;
|
cert->is_protected = 0;
|
||||||
/* (See comments at the code for elg keys) */
|
/* (See comments at the code for elg keys) */
|
||||||
n = pktlen; cert->d.rsa.rsa_d = mpi_read(inp, &n, 0 ); pktlen -=n;
|
n = pktlen; cert->d.rsa.d = mpi_read(inp, &n, 0 ); pktlen -=n;
|
||||||
n = pktlen; cert->d.rsa.rsa_p = mpi_read(inp, &n, 0 ); pktlen -=n;
|
n = pktlen; cert->d.rsa.p = mpi_read(inp, &n, 0 ); pktlen -=n;
|
||||||
n = pktlen; cert->d.rsa.rsa_q = mpi_read(inp, &n, 0 ); pktlen -=n;
|
n = pktlen; cert->d.rsa.q = mpi_read(inp, &n, 0 ); pktlen -=n;
|
||||||
n = pktlen; cert->d.rsa.rsa_u = mpi_read(inp, &n, 0 ); pktlen -=n;
|
n = pktlen; cert->d.rsa.u = mpi_read(inp, &n, 0 ); pktlen -=n;
|
||||||
|
|
||||||
cert->csum = read_16(inp); pktlen -= 2;
|
cert->csum = read_16(inp); pktlen -= 2;
|
||||||
if( list_mode ) {
|
if( list_mode ) {
|
||||||
printf("\t[secret values d,p,q,u are not shown]\n"
|
printf("\t[secret values d,p,q,u are not shown]\n"
|
||||||
"\tchecksum: %04hx\n", cert->csum);
|
"\tchecksum: %04hx\n", cert->csum);
|
||||||
}
|
}
|
||||||
/* log_mpidump("rsa n=", cert->d.rsa.rsa_n );
|
/* log_mpidump("rsa n=", cert->d.rsa.n );
|
||||||
log_mpidump("rsa e=", cert->d.rsa.rsa_e );
|
log_mpidump("rsa e=", cert->d.rsa.e );
|
||||||
log_mpidump("rsa d=", cert->d.rsa.rsa_d );
|
log_mpidump("rsa d=", cert->d.rsa.d );
|
||||||
log_mpidump("rsa p=", cert->d.rsa.rsa_p );
|
log_mpidump("rsa p=", cert->d.rsa.p );
|
||||||
log_mpidump("rsa q=", cert->d.rsa.rsa_q );
|
log_mpidump("rsa q=", cert->d.rsa.q );
|
||||||
log_mpidump("rsa u=", cert->d.rsa.rsa_u ); */
|
log_mpidump("rsa u=", cert->d.rsa.u ); */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if( list_mode )
|
else if( list_mode )
|
||||||
|
@ -291,7 +291,7 @@ release_pkc_list( PKC_LIST pkc_list )
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
build_pkc_list( STRLIST remusr, PKC_LIST *ret_pkc_list )
|
build_pkc_list( STRLIST remusr, PKC_LIST *ret_pkc_list, unsigned usage )
|
||||||
{
|
{
|
||||||
PKC_LIST pkc_list = NULL;
|
PKC_LIST pkc_list = NULL;
|
||||||
PKT_public_cert *pkc=NULL;
|
PKT_public_cert *pkc=NULL;
|
||||||
@ -316,7 +316,7 @@ build_pkc_list( STRLIST remusr, PKC_LIST *ret_pkc_list )
|
|||||||
rc = get_pubkey_byname( pkc, answer );
|
rc = get_pubkey_byname( pkc, answer );
|
||||||
if( rc )
|
if( rc )
|
||||||
tty_printf("No such user ID.\n");
|
tty_printf("No such user ID.\n");
|
||||||
else if( !(rc=check_pubkey_algo(pkc->pubkey_algo)) ) {
|
else if( !(rc=check_pubkey_algo2(pkc->pubkey_algo, usage)) ) {
|
||||||
int trustlevel;
|
int trustlevel;
|
||||||
|
|
||||||
rc = check_trust( pkc, &trustlevel );
|
rc = check_trust( pkc, &trustlevel );
|
||||||
@ -350,7 +350,7 @@ build_pkc_list( STRLIST remusr, PKC_LIST *ret_pkc_list )
|
|||||||
free_public_cert( pkc ); pkc = NULL;
|
free_public_cert( pkc ); pkc = NULL;
|
||||||
log_error("skipped '%s': %s\n", remusr->d, g10_errstr(rc) );
|
log_error("skipped '%s': %s\n", remusr->d, g10_errstr(rc) );
|
||||||
}
|
}
|
||||||
else if( !(rc=check_pubkey_algo(pkc->pubkey_algo)) ) {
|
else if( !(rc=check_pubkey_algo2(pkc->pubkey_algo, usage )) ) {
|
||||||
int trustlevel;
|
int trustlevel;
|
||||||
|
|
||||||
rc = check_trust( pkc, &trustlevel );
|
rc = check_trust( pkc, &trustlevel );
|
||||||
|
@ -50,36 +50,20 @@ get_session_key( PKT_pubkey_enc *k, DEK *dek )
|
|||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
if( k->pubkey_algo == PUBKEY_ALGO_ELGAMAL ) {
|
if( k->pubkey_algo == PUBKEY_ALGO_ELGAMAL ) {
|
||||||
ELG_secret_key skey;
|
|
||||||
|
|
||||||
if( DBG_CIPHER ) {
|
if( DBG_CIPHER ) {
|
||||||
log_mpidump("Encr DEK a:", k->d.elg.a );
|
log_mpidump("Encr DEK a:", k->d.elg.a );
|
||||||
log_mpidump(" DEK b:", k->d.elg.b );
|
log_mpidump(" DEK b:", k->d.elg.b );
|
||||||
}
|
}
|
||||||
skey.p = skc->d.elg.p;
|
plain_dek = mpi_alloc_secure( mpi_get_nlimbs(skc->d.elg.p) );
|
||||||
skey.g = skc->d.elg.g;
|
elg_decrypt( plain_dek, k->d.elg.a, k->d.elg.b, &skc->d.elg );
|
||||||
skey.y = skc->d.elg.y;
|
|
||||||
skey.x = skc->d.elg.x;
|
|
||||||
plain_dek = mpi_alloc_secure( mpi_get_nlimbs(skey.p) );
|
|
||||||
elg_decrypt( plain_dek, k->d.elg.a, k->d.elg.b, &skey );
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
}
|
}
|
||||||
#ifdef HAVE_RSA_CIPHER
|
#ifdef HAVE_RSA_CIPHER
|
||||||
else if( k->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( k->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
RSA_secret_key skey;
|
|
||||||
|
|
||||||
if( DBG_CIPHER )
|
if( DBG_CIPHER )
|
||||||
log_mpidump("Encr DEK frame:", k->d.rsa.rsa_integer );
|
log_mpidump("Encr DEK frame:", k->d.rsa.rsa_integer );
|
||||||
|
|
||||||
skey.e = skc->d.rsa.rsa_e;
|
plain_dek = mpi_alloc_secure( mpi_get_nlimbs(skc->d.rsa.n) );
|
||||||
skey.n = skc->d.rsa.rsa_n;
|
rsa_secret( plain_dek, k->d.rsa.rsa_integer, &skc->d.rsa );
|
||||||
skey.p = skc->d.rsa.rsa_p;
|
|
||||||
skey.q = skc->d.rsa.rsa_q;
|
|
||||||
skey.d = skc->d.rsa.rsa_d;
|
|
||||||
skey.u = skc->d.rsa.rsa_u;
|
|
||||||
plain_dek = mpi_alloc_secure( mpi_get_nlimbs(skey.n) );
|
|
||||||
rsa_secret( plain_dek, k->d.rsa.rsa_integer, &skey );
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
}
|
}
|
||||||
#endif/*HAVE_RSA_CIPHER*/
|
#endif/*HAVE_RSA_CIPHER*/
|
||||||
else {
|
else {
|
||||||
|
@ -75,8 +75,6 @@ static int search( PACKET *pkt, KBPOS *kbpos, int secret );
|
|||||||
|
|
||||||
static int keyring_search( PACKET *pkt, KBPOS *kbpos, IOBUF iobuf,
|
static int keyring_search( PACKET *pkt, KBPOS *kbpos, IOBUF iobuf,
|
||||||
const char *fname );
|
const char *fname );
|
||||||
static int keyring_search2( PUBKEY_FIND_INFO info, KBPOS *kbpos,
|
|
||||||
const char *fname);
|
|
||||||
static int keyring_read( KBPOS *kbpos, KBNODE *ret_root );
|
static int keyring_read( KBPOS *kbpos, KBNODE *ret_root );
|
||||||
static int keyring_enum( KBPOS *kbpos, KBNODE *ret_root, int skipsigs );
|
static int keyring_enum( KBPOS *kbpos, KBNODE *ret_root, int skipsigs );
|
||||||
static int keyring_copy( KBPOS *kbpos, int mode, KBNODE root );
|
static int keyring_copy( KBPOS *kbpos, int mode, KBNODE root );
|
||||||
@ -165,36 +163,6 @@ get_keyblock_handle( const char *filename, int secret, KBPOS *kbpos )
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/****************
|
|
||||||
* Find a keyblock from the informations provided in INFO
|
|
||||||
* This can only be used fro public keys
|
|
||||||
*/
|
|
||||||
int
|
|
||||||
find_keyblock( PUBKEY_FIND_INFO info, KBPOS *kbpos )
|
|
||||||
{
|
|
||||||
int i, rc, last_rc=-1;
|
|
||||||
|
|
||||||
for(i=0; i < MAX_RESOURCES; i++ ) {
|
|
||||||
if( resource_table[i].used && !resource_table[i].secret ) {
|
|
||||||
/* note: here we have to add different search functions,
|
|
||||||
* depending on the type of the resource */
|
|
||||||
rc = keyring_search2( info, kbpos, resource_table[i].fname );
|
|
||||||
if( !rc ) {
|
|
||||||
kbpos->resno = i;
|
|
||||||
kbpos->fp = NULL;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if( rc != -1 ) {
|
|
||||||
log_error("error searching resource %d: %s\n",
|
|
||||||
i, g10_errstr(rc));
|
|
||||||
last_rc = rc;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return last_rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/****************
|
/****************
|
||||||
* Search a keyblock which starts with the given packet and put all
|
* Search a keyblock which starts with the given packet and put all
|
||||||
@ -535,9 +503,9 @@ keyring_search( PACKET *req, KBPOS *kbpos, IOBUF iobuf, const char *fname )
|
|||||||
&& !mpi_cmp( req_skc->d.dsa.x, skc->d.dsa.x )
|
&& !mpi_cmp( req_skc->d.dsa.x, skc->d.dsa.x )
|
||||||
)
|
)
|
||||||
|| ( skc->pubkey_algo == PUBKEY_ALGO_RSA
|
|| ( skc->pubkey_algo == PUBKEY_ALGO_RSA
|
||||||
&& !mpi_cmp( req_skc->d.rsa.rsa_n, skc->d.rsa.rsa_n )
|
&& !mpi_cmp( req_skc->d.rsa.n, skc->d.rsa.n )
|
||||||
&& !mpi_cmp( req_skc->d.rsa.rsa_e, skc->d.rsa.rsa_e )
|
&& !mpi_cmp( req_skc->d.rsa.e, skc->d.rsa.e )
|
||||||
&& !mpi_cmp( req_skc->d.rsa.rsa_d, skc->d.rsa.rsa_d )
|
&& !mpi_cmp( req_skc->d.rsa.d, skc->d.rsa.d )
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
@ -561,8 +529,8 @@ keyring_search( PACKET *req, KBPOS *kbpos, IOBUF iobuf, const char *fname )
|
|||||||
&& !mpi_cmp( req_pkc->d.dsa.y, pkc->d.dsa.y )
|
&& !mpi_cmp( req_pkc->d.dsa.y, pkc->d.dsa.y )
|
||||||
)
|
)
|
||||||
|| ( pkc->pubkey_algo == PUBKEY_ALGO_RSA
|
|| ( pkc->pubkey_algo == PUBKEY_ALGO_RSA
|
||||||
&& !mpi_cmp( req_pkc->d.rsa.rsa_n, pkc->d.rsa.rsa_n )
|
&& !mpi_cmp( req_pkc->d.rsa.n, pkc->d.rsa.n )
|
||||||
&& !mpi_cmp( req_pkc->d.rsa.rsa_e, pkc->d.rsa.rsa_e )
|
&& !mpi_cmp( req_pkc->d.rsa.e, pkc->d.rsa.e )
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
@ -584,60 +552,6 @@ keyring_search( PACKET *req, KBPOS *kbpos, IOBUF iobuf, const char *fname )
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
/****************
|
|
||||||
* search one keyring, return 0 if found, -1 if not found or an errorcode.
|
|
||||||
* this version uses the finger print and other informations
|
|
||||||
*/
|
|
||||||
static int
|
|
||||||
keyring_search2( PUBKEY_FIND_INFO info, KBPOS *kbpos, const char *fname )
|
|
||||||
{
|
|
||||||
int rc;
|
|
||||||
PACKET pkt;
|
|
||||||
int save_mode;
|
|
||||||
ulong offset;
|
|
||||||
IOBUF iobuf;
|
|
||||||
|
|
||||||
init_packet(&pkt);
|
|
||||||
save_mode = set_packet_list_mode(0);
|
|
||||||
|
|
||||||
iobuf = iobuf_open( fname );
|
|
||||||
if( !iobuf ) {
|
|
||||||
log_error("can't open '%s'\n", fname );
|
|
||||||
rc = G10ERR_OPEN_FILE;
|
|
||||||
goto leave;
|
|
||||||
}
|
|
||||||
|
|
||||||
while( !(rc=search_packet(iobuf, &pkt, PKT_PUBLIC_CERT, &offset)) ) {
|
|
||||||
PKT_public_cert *pkc = pkt.pkt.public_cert;
|
|
||||||
u32 keyid[2];
|
|
||||||
|
|
||||||
assert( pkt.pkttype == PKT_PUBLIC_CERT );
|
|
||||||
keyid_from_pkc( pkc, keyid );
|
|
||||||
if( keyid[0] == info->keyid[0] && keyid[1] == info->keyid[1]
|
|
||||||
&& pkc->pubkey_algo == info->pubkey_algo ) {
|
|
||||||
/* fixme: shall we check nbits too? (good for rsa keys) */
|
|
||||||
/* fixme: check userid???? */
|
|
||||||
size_t len;
|
|
||||||
byte *fp = fingerprint_from_pkc( pkc, &len );
|
|
||||||
|
|
||||||
if( !memcmp( fp, info->fingerprint, len ) ) {
|
|
||||||
m_free(fp);
|
|
||||||
break; /* found */
|
|
||||||
}
|
|
||||||
m_free(fp);
|
|
||||||
}
|
|
||||||
free_packet(&pkt);
|
|
||||||
}
|
|
||||||
if( !rc )
|
|
||||||
kbpos->offset = offset;
|
|
||||||
|
|
||||||
leave:
|
|
||||||
iobuf_close(iobuf);
|
|
||||||
free_packet(&pkt);
|
|
||||||
set_packet_list_mode(save_mode);
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
keyring_read( KBPOS *kbpos, KBNODE *ret_root )
|
keyring_read( KBPOS *kbpos, KBNODE *ret_root )
|
||||||
|
16
g10/rsa.c
16
g10/rsa.c
@ -38,18 +38,14 @@ void
|
|||||||
g10_rsa_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek )
|
g10_rsa_encrypt( PKT_public_cert *pkc, PKT_pubkey_enc *enc, DEK *dek )
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RSA_CIPHER
|
#ifdef HAVE_RSA_CIPHER
|
||||||
RSA_public_key pkey;
|
|
||||||
|
|
||||||
assert( enc->pubkey_algo == PUBKEY_ALGO_RSA );
|
assert( enc->pubkey_algo == PUBKEY_ALGO_RSA );
|
||||||
|
|
||||||
keyid_from_pkc( pkc, enc->keyid );
|
keyid_from_pkc( pkc, enc->keyid );
|
||||||
enc->d.rsa.rsa_integer = encode_session_key( dek,
|
enc->d.rsa.rsa_integer = encode_session_key( dek,
|
||||||
mpi_get_nbits(pkc->d.rsa.rsa_n) );
|
mpi_get_nbits(pkc->d.rsa.rsa_n) );
|
||||||
pkey.n = pkc->d.rsa.rsa_n;
|
|
||||||
pkey.e = pkc->d.rsa.rsa_e;
|
|
||||||
if( DBG_CIPHER )
|
if( DBG_CIPHER )
|
||||||
log_mpidump("Plain DEK frame: ", enc->d.rsa.rsa_integer);
|
log_mpidump("Plain DEK frame: ", enc->d.rsa.rsa_integer);
|
||||||
rsa_public( enc->d.rsa.rsa_integer, enc->d.rsa.rsa_integer, &pkey);
|
rsa_public( enc->d.rsa.rsa_integer, enc->d.rsa.rsa_integer, &pkc->d.rsa);
|
||||||
if( DBG_CIPHER )
|
if( DBG_CIPHER )
|
||||||
log_mpidump("Encry DEK frame: ", enc->d.rsa.rsa_integer);
|
log_mpidump("Encry DEK frame: ", enc->d.rsa.rsa_integer);
|
||||||
if( opt.verbose ) {
|
if( opt.verbose ) {
|
||||||
@ -68,7 +64,6 @@ g10_rsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
|||||||
MD_HANDLE md, int digest_algo )
|
MD_HANDLE md, int digest_algo )
|
||||||
{
|
{
|
||||||
#ifdef HAVE_RSA_CIPHER
|
#ifdef HAVE_RSA_CIPHER
|
||||||
RSA_secret_key skey;
|
|
||||||
byte *dp;
|
byte *dp;
|
||||||
|
|
||||||
assert( sig->pubkey_algo == PUBKEY_ALGO_RSA );
|
assert( sig->pubkey_algo == PUBKEY_ALGO_RSA );
|
||||||
@ -82,14 +77,7 @@ g10_rsa_sign( PKT_secret_cert *skc, PKT_signature *sig,
|
|||||||
sig->digest_start[1] = dp[1];
|
sig->digest_start[1] = dp[1];
|
||||||
sig->d.rsa.rsa_integer =
|
sig->d.rsa.rsa_integer =
|
||||||
encode_md_value( md, mpi_get_nbits(skc->d.rsa.rsa_n));
|
encode_md_value( md, mpi_get_nbits(skc->d.rsa.rsa_n));
|
||||||
skey.e = skc->d.rsa.rsa_e;
|
rsa_secret( sig->d.rsa.rsa_integer, sig->d.rsa.rsa_integer, &skc->d.rsa );
|
||||||
skey.n = skc->d.rsa.rsa_n;
|
|
||||||
skey.p = skc->d.rsa.rsa_p;
|
|
||||||
skey.q = skc->d.rsa.rsa_q;
|
|
||||||
skey.d = skc->d.rsa.rsa_d;
|
|
||||||
skey.u = skc->d.rsa.rsa_u;
|
|
||||||
rsa_secret( sig->d.rsa.rsa_integer, sig->d.rsa.rsa_integer, &skey);
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
if( opt.verbose ) {
|
if( opt.verbose ) {
|
||||||
char *ustr = get_user_id_string( sig->keyid );
|
char *ustr = get_user_id_string( sig->keyid );
|
||||||
log_info("RSA signature from: %s\n", ustr );
|
log_info("RSA signature from: %s\n", ustr );
|
||||||
|
@ -41,7 +41,6 @@ check_elg( PKT_secret_cert *cert )
|
|||||||
int res;
|
int res;
|
||||||
unsigned nbytes;
|
unsigned nbytes;
|
||||||
u32 keyid[2];
|
u32 keyid[2];
|
||||||
ELG_secret_key skey;
|
|
||||||
char save_iv[8];
|
char save_iv[8];
|
||||||
|
|
||||||
if( cert->is_protected ) { /* remove the protection */
|
if( cert->is_protected ) { /* remove the protection */
|
||||||
@ -93,12 +92,9 @@ check_elg( PKT_secret_cert *cert )
|
|||||||
"\"--change-passphrase\" to convert.\n");
|
"\"--change-passphrase\" to convert.\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
skey.p = cert->d.elg.p;
|
mpi_swap( cert->d.elg.x, test_x );
|
||||||
skey.g = cert->d.elg.g;
|
res = elg_check_secret_key( &cert->d.elg );
|
||||||
skey.y = cert->d.elg.y;
|
mpi_swap( cert->d.elg.x, test_x );
|
||||||
skey.x = test_x;
|
|
||||||
res = elg_check_secret_key( &skey );
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
if( !res ) {
|
if( !res ) {
|
||||||
mpi_free(test_x);
|
mpi_free(test_x);
|
||||||
memcpy( cert->protect.iv, save_iv, 8 );
|
memcpy( cert->protect.iv, save_iv, 8 );
|
||||||
@ -140,7 +136,6 @@ check_dsa( PKT_secret_cert *cert )
|
|||||||
int res;
|
int res;
|
||||||
unsigned nbytes;
|
unsigned nbytes;
|
||||||
u32 keyid[2];
|
u32 keyid[2];
|
||||||
DSA_secret_key skey;
|
|
||||||
char save_iv[8];
|
char save_iv[8];
|
||||||
|
|
||||||
if( cert->is_protected ) { /* remove the protection */
|
if( cert->is_protected ) { /* remove the protection */
|
||||||
@ -183,13 +178,9 @@ check_dsa( PKT_secret_cert *cert )
|
|||||||
return G10ERR_BAD_PASS;
|
return G10ERR_BAD_PASS;
|
||||||
}
|
}
|
||||||
|
|
||||||
skey.p = cert->d.dsa.p;
|
mpi_swap( cert->d.dsa.x, test_x );
|
||||||
skey.q = cert->d.dsa.q;
|
res = dsa_check_secret_key( &cert->d.dsa );
|
||||||
skey.g = cert->d.dsa.g;
|
mpi_swap( cert->d.dsa.x, test_x );
|
||||||
skey.y = cert->d.dsa.y;
|
|
||||||
skey.x = test_x;
|
|
||||||
res = dsa_check_secret_key( &skey );
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
if( !res ) {
|
if( !res ) {
|
||||||
mpi_free(test_x);
|
mpi_free(test_x);
|
||||||
memcpy( cert->protect.iv, save_iv, 8 );
|
memcpy( cert->protect.iv, save_iv, 8 );
|
||||||
@ -227,7 +218,6 @@ check_rsa( PKT_secret_cert *cert )
|
|||||||
int res;
|
int res;
|
||||||
unsigned nbytes;
|
unsigned nbytes;
|
||||||
u32 keyid[2];
|
u32 keyid[2];
|
||||||
RSA_secret_key skey;
|
|
||||||
|
|
||||||
if( cert->is_protected ) { /* remove the protection */
|
if( cert->is_protected ) { /* remove the protection */
|
||||||
DEK *dek = NULL;
|
DEK *dek = NULL;
|
||||||
@ -266,12 +256,7 @@ check_rsa( PKT_secret_cert *cert )
|
|||||||
if( csum != cert->csum )
|
if( csum != cert->csum )
|
||||||
return G10ERR_BAD_PASS;
|
return G10ERR_BAD_PASS;
|
||||||
|
|
||||||
skey.d = cert->d.rsa.rsa_d;
|
res = rsa_check_secret_key( &cert->d.rsa );
|
||||||
skey.p = cert->d.rsa.rsa_p;
|
|
||||||
skey.q = cert->d.rsa.rsa_q;
|
|
||||||
skey.u = cert->d.rsa.rsa_u;
|
|
||||||
res = rsa_check_secret_key( &skey );
|
|
||||||
memset( &skey, 0, sizeof skey );
|
|
||||||
if( !res )
|
if( !res )
|
||||||
return G10ERR_BAD_PASS;
|
return G10ERR_BAD_PASS;
|
||||||
break;
|
break;
|
||||||
|
@ -63,13 +63,14 @@ do_check( PKT_public_cert *pkc, PKT_signature *sig, MD_HANDLE digest )
|
|||||||
MPI result = NULL;
|
MPI result = NULL;
|
||||||
int rc=0;
|
int rc=0;
|
||||||
|
|
||||||
|
if( pkc->version == 4 && pkc->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
||||||
|
log_info("WARNING: This is probably a PGP generated "
|
||||||
|
"ElGamal key which is NOT secure for signatures!\n");
|
||||||
|
|
||||||
if( pkc->timestamp > sig->timestamp )
|
if( pkc->timestamp > sig->timestamp )
|
||||||
return G10ERR_TIME_CONFLICT; /* pubkey newer that signature */
|
return G10ERR_TIME_CONFLICT; /* pubkey newer that signature */
|
||||||
|
|
||||||
if( pkc->pubkey_algo == PUBKEY_ALGO_ELGAMAL ) {
|
if( pkc->pubkey_algo == PUBKEY_ALGO_ELGAMAL ) {
|
||||||
ELG_public_key pkey;
|
|
||||||
|
|
||||||
if( (rc=check_digest_algo(sig->digest_algo)) )
|
if( (rc=check_digest_algo(sig->digest_algo)) )
|
||||||
goto leave;
|
goto leave;
|
||||||
/* make sure the digest algo is enabled (in case of a detached
|
/* make sure the digest algo is enabled (in case of a detached
|
||||||
@ -85,15 +86,10 @@ do_check( PKT_public_cert *pkc, PKT_signature *sig, MD_HANDLE digest )
|
|||||||
}
|
}
|
||||||
md_final( digest );
|
md_final( digest );
|
||||||
result = encode_md_value( digest, mpi_get_nbits(pkc->d.elg.p));
|
result = encode_md_value( digest, mpi_get_nbits(pkc->d.elg.p));
|
||||||
pkey.p = pkc->d.elg.p;
|
if( !elg_verify( sig->d.elg.a, sig->d.elg.b, result, &pkc->d.elg ) )
|
||||||
pkey.g = pkc->d.elg.g;
|
|
||||||
pkey.y = pkc->d.elg.y;
|
|
||||||
if( !elg_verify( sig->d.elg.a, sig->d.elg.b, result, &pkey ) )
|
|
||||||
rc = G10ERR_BAD_SIGN;
|
rc = G10ERR_BAD_SIGN;
|
||||||
}
|
}
|
||||||
else if( pkc->pubkey_algo == PUBKEY_ALGO_DSA ) {
|
else if( pkc->pubkey_algo == PUBKEY_ALGO_DSA ) {
|
||||||
DSA_public_key pkey;
|
|
||||||
|
|
||||||
if( (rc=check_digest_algo(sig->digest_algo)) )
|
if( (rc=check_digest_algo(sig->digest_algo)) )
|
||||||
goto leave;
|
goto leave;
|
||||||
/* make sure the digest algo is enabled (in case of a detached
|
/* make sure the digest algo is enabled (in case of a detached
|
||||||
@ -135,27 +131,22 @@ do_check( PKT_public_cert *pkc, PKT_signature *sig, MD_HANDLE digest )
|
|||||||
md_final( digest );
|
md_final( digest );
|
||||||
result = mpi_alloc( (md_digest_length(sig->digest_algo)
|
result = mpi_alloc( (md_digest_length(sig->digest_algo)
|
||||||
+BYTES_PER_MPI_LIMB-1) / BYTES_PER_MPI_LIMB );
|
+BYTES_PER_MPI_LIMB-1) / BYTES_PER_MPI_LIMB );
|
||||||
mpi_set_buffer( result, md_read(digest, DIGEST_ALGO_SHA1),
|
mpi_set_buffer( result, md_read(digest, sig->digest_algo),
|
||||||
md_digest_length(sig->digest_algo), 0 );
|
md_digest_length(sig->digest_algo), 0 );
|
||||||
pkey.p = pkc->d.dsa.p;
|
if( DBG_CIPHER )
|
||||||
pkey.q = pkc->d.dsa.q;
|
log_mpidump("calc sig frame: ", result);
|
||||||
pkey.g = pkc->d.dsa.g;
|
if( !dsa_verify( sig->d.dsa.r, sig->d.dsa.s, result, &pkc->d.dsa ) )
|
||||||
pkey.y = pkc->d.dsa.y;
|
|
||||||
if( !dsa_verify( sig->d.dsa.r, sig->d.dsa.s, result, &pkey ) )
|
|
||||||
rc = G10ERR_BAD_SIGN;
|
rc = G10ERR_BAD_SIGN;
|
||||||
}
|
}
|
||||||
#ifdef HAVE_RSA_CIPHER
|
#ifdef HAVE_RSA_CIPHER
|
||||||
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
else if( pkc->pubkey_algo == PUBKEY_ALGO_RSA ) {
|
||||||
int i, j, c, old_enc;
|
int i, j, c, old_enc;
|
||||||
byte *dp;
|
byte *dp;
|
||||||
RSA_public_key pkey;
|
|
||||||
const byte *asn;
|
const byte *asn;
|
||||||
size_t mdlen, asnlen;
|
size_t mdlen, asnlen;
|
||||||
|
|
||||||
result = mpi_alloc(40);
|
result = mpi_alloc(40);
|
||||||
pkey.n = pkc->d.rsa.rsa_n;
|
rsa_public( result, sig->d.rsa.rsa_integer, &pkc->d.rsa );
|
||||||
pkey.e = pkc->d.rsa.rsa_e;
|
|
||||||
rsa_public( result, sig->d.rsa.rsa_integer, &pkey );
|
|
||||||
|
|
||||||
old_enc = 0;
|
old_enc = 0;
|
||||||
for(i=j=0; (c=mpi_getbyte(result, i)) != -1; i++ ) {
|
for(i=j=0; (c=mpi_getbyte(result, i)) != -1; i++ ) {
|
||||||
@ -204,8 +195,8 @@ do_check( PKT_public_cert *pkc, PKT_signature *sig, MD_HANDLE digest )
|
|||||||
rc = G10ERR_BAD_PUBKEY;
|
rc = G10ERR_BAD_PUBKEY;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
if( mpi_getbyte(result, mdlen-1) != sig->d.rsa.digest_start[0]
|
if( mpi_getbyte(result, mdlen-1) != sig->digest_start[0]
|
||||||
|| mpi_getbyte(result, mdlen-2) != sig->d.rsa.digest_start[1] ) {
|
|| mpi_getbyte(result, mdlen-2) != sig->digest_start[1] ) {
|
||||||
/* Wrong key used to check the signature */
|
/* Wrong key used to check the signature */
|
||||||
rc = G10ERR_BAD_PUBKEY;
|
rc = G10ERR_BAD_PUBKEY;
|
||||||
goto leave;
|
goto leave;
|
||||||
|
26
g10/sign.c
26
g10/sign.c
@ -116,10 +116,10 @@ sign_file( STRLIST filenames, int detached, STRLIST locusr,
|
|||||||
if( fname && filenames->next && (!detached || encrypt) )
|
if( fname && filenames->next && (!detached || encrypt) )
|
||||||
log_bug("multiple files can only be detached signed");
|
log_bug("multiple files can only be detached signed");
|
||||||
|
|
||||||
if( (rc=build_skc_list( locusr, &skc_list, 1 )) )
|
if( (rc=build_skc_list( locusr, &skc_list, 1, 1 )) )
|
||||||
goto leave;
|
goto leave;
|
||||||
if( encrypt ) {
|
if( encrypt ) {
|
||||||
if( (rc=build_pkc_list( remusr, &pkc_list )) )
|
if( (rc=build_pkc_list( remusr, &pkc_list, 2 )) )
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -150,7 +150,7 @@ sign_file( STRLIST filenames, int detached, STRLIST locusr,
|
|||||||
/* prepare to calculate the MD over the input */
|
/* prepare to calculate the MD over the input */
|
||||||
if( opt.textmode && !outfile )
|
if( opt.textmode && !outfile )
|
||||||
iobuf_push_filter( inp, text_filter, &tfx );
|
iobuf_push_filter( inp, text_filter, &tfx );
|
||||||
mfx.md = md_open(DIGEST_ALGO_RMD160, 0);
|
mfx.md = md_open(opt.def_digest_algo, 0);
|
||||||
if( !multifile )
|
if( !multifile )
|
||||||
iobuf_push_filter( inp, md_filter, &mfx );
|
iobuf_push_filter( inp, md_filter, &mfx );
|
||||||
|
|
||||||
@ -176,7 +176,7 @@ sign_file( STRLIST filenames, int detached, STRLIST locusr,
|
|||||||
skc = skc_rover->skc;
|
skc = skc_rover->skc;
|
||||||
ops = m_alloc_clear( sizeof *ops );
|
ops = m_alloc_clear( sizeof *ops );
|
||||||
ops->sig_class = opt.textmode && !outfile ? 0x01 : 0x00;
|
ops->sig_class = opt.textmode && !outfile ? 0x01 : 0x00;
|
||||||
ops->digest_algo = DIGEST_ALGO_RMD160;
|
ops->digest_algo = opt.def_digest_algo;
|
||||||
ops->pubkey_algo = skc->pubkey_algo;
|
ops->pubkey_algo = skc->pubkey_algo;
|
||||||
keyid_from_skc( skc, ops->keyid );
|
keyid_from_skc( skc, ops->keyid );
|
||||||
ops->last = !skc_rover->next;
|
ops->last = !skc_rover->next;
|
||||||
@ -276,11 +276,11 @@ sign_file( STRLIST filenames, int detached, STRLIST locusr,
|
|||||||
md_final( md );
|
md_final( md );
|
||||||
|
|
||||||
if( sig->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
if( sig->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
||||||
g10_elg_sign( skc, sig, md, DIGEST_ALGO_RMD160 );
|
g10_elg_sign( skc, sig, md, opt.def_digest_algo );
|
||||||
else if( sig->pubkey_algo == PUBKEY_ALGO_DSA )
|
else if( sig->pubkey_algo == PUBKEY_ALGO_DSA )
|
||||||
g10_dsa_sign( skc, sig, md, DIGEST_ALGO_SHA1 );
|
g10_dsa_sign( skc, sig, md, opt.def_digest_algo );
|
||||||
else if( sig->pubkey_algo == PUBKEY_ALGO_RSA )
|
else if( sig->pubkey_algo == PUBKEY_ALGO_RSA )
|
||||||
g10_rsa_sign( skc, sig, md, DIGEST_ALGO_RMD160 );
|
g10_rsa_sign( skc, sig, md, opt.def_digest_algo );
|
||||||
else
|
else
|
||||||
BUG();
|
BUG();
|
||||||
|
|
||||||
@ -369,7 +369,7 @@ clearsign_file( const char *fname, STRLIST locusr, const char *outfile )
|
|||||||
memset( &tfx, 0, sizeof tfx);
|
memset( &tfx, 0, sizeof tfx);
|
||||||
init_packet( &pkt );
|
init_packet( &pkt );
|
||||||
|
|
||||||
if( (rc=build_skc_list( locusr, &skc_list, 1 )) )
|
if( (rc=build_skc_list( locusr, &skc_list, 1, 1 )) )
|
||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
/* prepare iobufs */
|
/* prepare iobufs */
|
||||||
@ -397,7 +397,7 @@ clearsign_file( const char *fname, STRLIST locusr, const char *outfile )
|
|||||||
iobuf_writestr(out, "-----BEGIN PGP SIGNED MESSAGE-----\n"
|
iobuf_writestr(out, "-----BEGIN PGP SIGNED MESSAGE-----\n"
|
||||||
"Hash: RIPEMD160\n\n" );
|
"Hash: RIPEMD160\n\n" );
|
||||||
|
|
||||||
textmd = md_open(DIGEST_ALGO_RMD160, 0);
|
textmd = md_open(opt.def_digest_algo, 0);
|
||||||
iobuf_push_filter( inp, text_filter, &tfx );
|
iobuf_push_filter( inp, text_filter, &tfx );
|
||||||
rc = write_dash_escaped( inp, out, textmd );
|
rc = write_dash_escaped( inp, out, textmd );
|
||||||
if( rc )
|
if( rc )
|
||||||
@ -432,11 +432,11 @@ clearsign_file( const char *fname, STRLIST locusr, const char *outfile )
|
|||||||
md_final( md );
|
md_final( md );
|
||||||
|
|
||||||
if( sig->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
if( sig->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
||||||
g10_elg_sign( skc, sig, md, DIGEST_ALGO_RMD160 );
|
g10_elg_sign( skc, sig, md, opt.def_digest_algo );
|
||||||
else if( sig->pubkey_algo == PUBKEY_ALGO_DSA )
|
else if( sig->pubkey_algo == PUBKEY_ALGO_DSA )
|
||||||
g10_dsa_sign( skc, sig, md, DIGEST_ALGO_SHA1 );
|
g10_dsa_sign( skc, sig, md, opt.def_digest_algo );
|
||||||
else if( sig->pubkey_algo == PUBKEY_ALGO_RSA )
|
else if( sig->pubkey_algo == PUBKEY_ALGO_RSA )
|
||||||
g10_rsa_sign( skc, sig, md, DIGEST_ALGO_RMD160 );
|
g10_rsa_sign( skc, sig, md, opt.def_digest_algo );
|
||||||
else
|
else
|
||||||
BUG();
|
BUG();
|
||||||
|
|
||||||
@ -682,7 +682,7 @@ sign_key( const char *username, STRLIST locusr )
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* build a list of all signators */
|
/* build a list of all signators */
|
||||||
rc=build_skc_list( locusr, &skc_list, 0 );
|
rc=build_skc_list( locusr, &skc_list, 0, 1 );
|
||||||
if( rc )
|
if( rc )
|
||||||
goto leave;
|
goto leave;
|
||||||
|
|
||||||
|
@ -46,7 +46,8 @@ release_skc_list( SKC_LIST skc_list )
|
|||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
build_skc_list( STRLIST locusr, SKC_LIST *ret_skc_list, int unlock )
|
build_skc_list( STRLIST locusr, SKC_LIST *ret_skc_list, int unlock,
|
||||||
|
unsigned usage )
|
||||||
{
|
{
|
||||||
SKC_LIST skc_list = NULL;
|
SKC_LIST skc_list = NULL;
|
||||||
int rc;
|
int rc;
|
||||||
@ -59,8 +60,12 @@ build_skc_list( STRLIST locusr, SKC_LIST *ret_skc_list, int unlock )
|
|||||||
free_secret_cert( skc ); skc = NULL;
|
free_secret_cert( skc ); skc = NULL;
|
||||||
log_error("no default secret key: %s\n", g10_errstr(rc) );
|
log_error("no default secret key: %s\n", g10_errstr(rc) );
|
||||||
}
|
}
|
||||||
else if( !(rc=check_pubkey_algo(skc->pubkey_algo)) ) {
|
else if( !(rc=check_pubkey_algo2(skc->pubkey_algo, usage)) ) {
|
||||||
SKC_LIST r;
|
SKC_LIST r;
|
||||||
|
if( skc->version == 4 && (usage & 1)
|
||||||
|
&& skc->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
||||||
|
log_info("WARNING: This is probably a PGP generated "
|
||||||
|
"ElGamal key which is NOT secure for signatures!\n");
|
||||||
r = m_alloc( sizeof *r );
|
r = m_alloc( sizeof *r );
|
||||||
r->skc = skc; skc = NULL;
|
r->skc = skc; skc = NULL;
|
||||||
r->next = skc_list;
|
r->next = skc_list;
|
||||||
@ -81,8 +86,12 @@ build_skc_list( STRLIST locusr, SKC_LIST *ret_skc_list, int unlock )
|
|||||||
free_secret_cert( skc ); skc = NULL;
|
free_secret_cert( skc ); skc = NULL;
|
||||||
log_error("skipped '%s': %s\n", locusr->d, g10_errstr(rc) );
|
log_error("skipped '%s': %s\n", locusr->d, g10_errstr(rc) );
|
||||||
}
|
}
|
||||||
else if( !(rc=check_pubkey_algo(skc->pubkey_algo)) ) {
|
else if( !(rc=check_pubkey_algo2(skc->pubkey_algo, usage)) ) {
|
||||||
SKC_LIST r;
|
SKC_LIST r;
|
||||||
|
if( skc->version == 4 && (usage & 1)
|
||||||
|
&& skc->pubkey_algo == PUBKEY_ALGO_ELGAMAL )
|
||||||
|
log_info("WARNING: This is probably a PGP generated "
|
||||||
|
"ElGamal key which is NOT secure for signatures!\n");
|
||||||
r = m_alloc( sizeof *r );
|
r = m_alloc( sizeof *r );
|
||||||
r->skc = skc; skc = NULL;
|
r->skc = skc; skc = NULL;
|
||||||
r->next = skc_list;
|
r->next = skc_list;
|
||||||
|
@ -849,6 +849,7 @@ verify_own_certs()
|
|||||||
log_debug("checking secret key %08lX\n", (ulong)keyid[1] );
|
log_debug("checking secret key %08lX\n", (ulong)keyid[1] );
|
||||||
|
|
||||||
/* look wether we can access the public key of this secret key */
|
/* look wether we can access the public key of this secret key */
|
||||||
|
memset( pkc, 0, sizeof *pkc );
|
||||||
rc = get_pubkey( pkc, keyid );
|
rc = get_pubkey( pkc, keyid );
|
||||||
if( rc ) {
|
if( rc ) {
|
||||||
log_error("keyid %08lX: secret key without public key\n",
|
log_error("keyid %08lX: secret key without public key\n",
|
||||||
@ -1146,8 +1147,6 @@ static int
|
|||||||
build_sigrecs( ulong pubkeyid )
|
build_sigrecs( ulong pubkeyid )
|
||||||
{
|
{
|
||||||
TRUSTREC rec, krec, rec2;
|
TRUSTREC rec, krec, rec2;
|
||||||
PUBKEY_FIND_INFO finfo=NULL;
|
|
||||||
KBPOS kbpos;
|
|
||||||
KBNODE keyblock = NULL;
|
KBNODE keyblock = NULL;
|
||||||
KBNODE node;
|
KBNODE node;
|
||||||
int rc=0;
|
int rc=0;
|
||||||
@ -1163,23 +1162,13 @@ build_sigrecs( ulong pubkeyid )
|
|||||||
log_error("%lu: build_sigrecs: can't read dir record\n", pubkeyid );
|
log_error("%lu: build_sigrecs: can't read dir record\n", pubkeyid );
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
finfo = m_alloc_clear( sizeof *finfo );
|
|
||||||
finfo->keyid[0] = rec.r.dir.keyid[0];
|
|
||||||
finfo->keyid[1] = rec.r.dir.keyid[1];
|
|
||||||
if( (rc=read_record( rec.r.dir.keyrec, &krec, RECTYPE_KEY )) ) {
|
if( (rc=read_record( rec.r.dir.keyrec, &krec, RECTYPE_KEY )) ) {
|
||||||
log_error("%lu: build_sigrecs: can't read key record\n", pubkeyid);
|
log_error("%lu: build_sigrecs: can't read key record\n", pubkeyid);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
finfo->pubkey_algo = krec.r.key.pubkey_algo;
|
rc = get_keyblock_byfprint( &keyblock, krec.r.key.fingerprint );
|
||||||
memcpy( finfo->fingerprint, krec.r.key.fingerprint, 20);
|
|
||||||
rc = find_keyblock( finfo, &kbpos );
|
|
||||||
if( rc ) {
|
if( rc ) {
|
||||||
log_error("build_sigrecs: find_keyblock failed\n" );
|
log_error("build_sigrecs: get_keyblock_byfprint failed\n" );
|
||||||
goto leave;
|
|
||||||
}
|
|
||||||
rc = read_keyblock( &kbpos, &keyblock );
|
|
||||||
if( rc ) {
|
|
||||||
log_error("build_sigrecs: read_keyblock failed\n" );
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
/* check all key signatures */
|
/* check all key signatures */
|
||||||
@ -1290,7 +1279,6 @@ build_sigrecs( ulong pubkeyid )
|
|||||||
update_no_sigs( pubkeyid, revoked? 3:1 ); /* no signatures */
|
update_no_sigs( pubkeyid, revoked? 3:1 ); /* no signatures */
|
||||||
|
|
||||||
leave:
|
leave:
|
||||||
m_free( finfo );
|
|
||||||
release_kbnode( keyblock );
|
release_kbnode( keyblock );
|
||||||
if( DBG_TRUST )
|
if( DBG_TRUST )
|
||||||
log_debug("trustdb: build_sigrecs: %s\n", g10_errstr(rc) );
|
log_debug("trustdb: build_sigrecs: %s\n", g10_errstr(rc) );
|
||||||
|
@ -97,6 +97,7 @@ int string_to_digest_algo( const char *string );
|
|||||||
const char * pubkey_algo_to_string( int algo );
|
const char * pubkey_algo_to_string( int algo );
|
||||||
const char * digest_algo_to_string( int algo );
|
const char * digest_algo_to_string( int algo );
|
||||||
int check_pubkey_algo( int algo );
|
int check_pubkey_algo( int algo );
|
||||||
|
int check_pubkey_algo2( int algo, unsigned usage );
|
||||||
int check_digest_algo( int algo );
|
int check_digest_algo( int algo );
|
||||||
|
|
||||||
/*-- smallprime.c --*/
|
/*-- smallprime.c --*/
|
||||||
|
@ -60,5 +60,6 @@
|
|||||||
#define G10ERR_DELETE_FILE 38
|
#define G10ERR_DELETE_FILE 38
|
||||||
#define G10ERR_UNEXPECTED 39
|
#define G10ERR_UNEXPECTED 39
|
||||||
#define G10ERR_TIME_CONFLICT 40
|
#define G10ERR_TIME_CONFLICT 40
|
||||||
|
#define G10ERR_WR_PUBKEY_ALGO 41 /* unusabe pubkey algo */
|
||||||
|
|
||||||
#endif /*G10_ERRORS_H*/
|
#endif /*G10_ERRORS_H*/
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
Wed Apr 8 09:44:33 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
|
* config.links: Applied small fix from Ulf Möller.
|
||||||
|
|
||||||
Mon Apr 6 12:38:52 1998 Werner Koch (wk@isil.d.shuttle.de)
|
Mon Apr 6 12:38:52 1998 Werner Koch (wk@isil.d.shuttle.de)
|
||||||
|
|
||||||
* mpicoder.c (mpi_get_buffer): Removed returned leading zeroes
|
* mpicoder.c (mpi_get_buffer): Removed returned leading zeroes
|
||||||
|
@ -111,7 +111,7 @@ esac
|
|||||||
|
|
||||||
|
|
||||||
case "${target}" in
|
case "${target}" in
|
||||||
*-*-linuxaout* | *-*-linuxoldld*)
|
*-*-linuxaout* | *-*-linuxoldld* | *-*-linux-gnuoldld*)
|
||||||
needs_underscore="y"
|
needs_underscore="y"
|
||||||
;;
|
;;
|
||||||
*-*-linux* | *-sysv* | *-solaris* | *-gnu*)
|
*-*-linux* | *-sysv* | *-solaris* | *-gnu*)
|
||||||
|
@ -72,6 +72,7 @@ g10_errstr( int err )
|
|||||||
X(DELETE_FILE ,"File delete error")
|
X(DELETE_FILE ,"File delete error")
|
||||||
X(UNEXPECTED ,"Unexpected data")
|
X(UNEXPECTED ,"Unexpected data")
|
||||||
X(TIME_CONFLICT ,"Timestamp conflict")
|
X(TIME_CONFLICT ,"Timestamp conflict")
|
||||||
|
X(WR_PUBKEY_ALGO ,"Unusable pubkey algorithm")
|
||||||
|
|
||||||
default: p = buf; sprintf(buf, "g10err=%d", err); break;
|
default: p = buf; sprintf(buf, "g10err=%d", err); break;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user