1
0
mirror of git://git.gnupg.org/gnupg.git synced 2025-01-18 14:17:03 +01:00

gpg: Do not use weak digest algos if selected by recipient prefs.

* g10/misc.c (is_weak_digest): New.
(print_digest_algo_note): Use it here.
* g10/sig-check.c (check_signature_end_simple): Use it.
* g10/sign.c (hash_for): Do not use recipient_digest_algo if it is in
the least of weak digest algorithm.
--

If a message is signed and encrypted to several recipients, the to be
used digest algorithm is deduced from the preferences of the
recipient.  This is so that all recipients are able to check the the
signature.  However, if the sender has a declared an algorithm as
week, that algorithm shall not be used - in this case we fallback to
the standard way of selecting an algorithm.

Note that a smarter way of selecting the algo is to check this while
figuring out the algorithm - this needs more testing and thus we do it
the simple way.

Reported-by: Phil Pennock
Signed-off-by: Werner Koch <wk@gnupg.org>
This commit is contained in:
Werner Koch 2020-11-02 13:39:58 +01:00
parent b004701adc
commit 15746d60d4
No known key found for this signature in database
GPG Key ID: E3FDFF218E45B72B
4 changed files with 31 additions and 19 deletions

View File

@ -99,6 +99,7 @@ void print_sha1_keysig_rejected_note (void);
void print_reported_error (gpg_error_t err, gpg_err_code_t skip_if_ec); void print_reported_error (gpg_error_t err, gpg_err_code_t skip_if_ec);
void print_further_info (const char *format, ...) GPGRT_ATTR_PRINTF(1,2); void print_further_info (const char *format, ...) GPGRT_ATTR_PRINTF(1,2);
void additional_weak_digest (const char* digestname); void additional_weak_digest (const char* digestname);
int is_weak_digest (digest_algo_t algo);
/*-- armor.c --*/ /*-- armor.c --*/
char *make_radix64_string( const byte *data, size_t len ); char *make_radix64_string( const byte *data, size_t len );

View File

@ -331,12 +331,11 @@ print_cipher_algo_note (cipher_algo_t algo)
void void
print_digest_algo_note (digest_algo_t algo) print_digest_algo_note (digest_algo_t algo)
{ {
const enum gcry_md_algos galgo = map_md_openpgp_to_gcry (algo);
const struct weakhash *weak;
if(algo >= 100 && algo <= 110) if(algo >= 100 && algo <= 110)
{ {
static int warn=0; static int warn=0;
const enum gcry_md_algos galgo = map_md_openpgp_to_gcry (algo);
if(!warn) if(!warn)
{ {
warn=1; warn=1;
@ -345,10 +344,9 @@ print_digest_algo_note (digest_algo_t algo)
gcry_md_algo_name (galgo)); gcry_md_algo_name (galgo));
} }
} }
else else if (is_weak_digest (algo))
for (weak = opt.weak_digests; weak != NULL; weak = weak->next)
if (weak->algo == galgo)
{ {
const enum gcry_md_algos galgo = map_md_openpgp_to_gcry (algo);
es_fflush (es_stdout); es_fflush (es_stdout);
log_info (_("WARNING: digest algorithm %s is deprecated\n"), log_info (_("WARNING: digest algorithm %s is deprecated\n"),
gcry_md_algo_name (galgo)); gcry_md_algo_name (galgo));
@ -1908,3 +1906,17 @@ additional_weak_digest (const char* digestname)
weak->next = opt.weak_digests; weak->next = opt.weak_digests;
opt.weak_digests = weak; opt.weak_digests = weak;
} }
/* Return true if ALGO is in the list of weak digests. */
int
is_weak_digest (digest_algo_t algo)
{
const enum gcry_md_algos galgo = map_md_openpgp_to_gcry (algo);
const struct weakhash *weak;
for (weak = opt.weak_digests; weak; weak = weak->next)
if (weak->algo == galgo)
return 1;
return 0;
}

View File

@ -488,14 +488,12 @@ check_signature_end_simple (PKT_public_key *pk, PKT_signature *sig,
{ {
gcry_mpi_t result = NULL; gcry_mpi_t result = NULL;
int rc = 0; int rc = 0;
const struct weakhash *weak;
if (!opt.flags.allow_weak_digest_algos) if (!opt.flags.allow_weak_digest_algos)
{ {
for (weak = opt.weak_digests; weak; weak = weak->next) if (is_weak_digest (sig->digest_algo))
if (sig->digest_algo == weak->algo)
{ {
print_digest_rejected_note(sig->digest_algo); print_digest_rejected_note (sig->digest_algo);
return GPG_ERR_DIGEST_ALGO; return GPG_ERR_DIGEST_ALGO;
} }
} }

View File

@ -646,7 +646,7 @@ hash_for (PKT_public_key *pk)
{ {
return opt.def_digest_algo; return opt.def_digest_algo;
} }
else if (recipient_digest_algo) else if (recipient_digest_algo && !is_weak_digest (recipient_digest_algo))
{ {
return recipient_digest_algo; return recipient_digest_algo;
} }
@ -1204,6 +1204,7 @@ sign_file (ctrl_t ctrl, strlist_t filenames, int detached, strlist_t locusr,
&& ((algo = select_algo_from_prefs (pk_list, PREFTYPE_HASH, && ((algo = select_algo_from_prefs (pk_list, PREFTYPE_HASH,
-1, &hint)) > 0)) -1, &hint)) > 0))
{ {
/* Note that we later check that the algo is not weak. */
recipient_digest_algo = algo; recipient_digest_algo = algo;
} }
} }