diff options
author | Werner Koch <[email protected]> | 2020-04-15 09:05:41 +0000 |
---|---|---|
committer | Werner Koch <[email protected]> | 2020-04-15 09:06:59 +0000 |
commit | c0d5c673542b3d517c33fe1a9ab26bcda1a5a95f (patch) | |
tree | ca3222ea7669ea2179e4384382fad19b698fc745 /dirmngr/validate.c | |
parent | regexp: Fix generation of _unicode_mapping.c. (diff) | |
download | gnupg-c0d5c673542b3d517c33fe1a9ab26bcda1a5a95f.tar.gz gnupg-c0d5c673542b3d517c33fe1a9ab26bcda1a5a95f.zip |
sm,dirmngr: Restrict allowed parameters used with rsaPSS.
* sm/certcheck.c (extract_pss_params): Check the used PSS params.
* dirmngr/crlcache.c (finish_sig_check): Ditto.
* dirmngr/validate.c (check_cert_sig): Ditto.
--
GnuPG-bug-id: 4538
# ------------------------ >8 ------------------------
See
https://www.metzdowd.com/pipermail/cryptography/2019-November/035449.html
Signed-off-by: Werner Koch <[email protected]>
Diffstat (limited to 'dirmngr/validate.c')
-rw-r--r-- | dirmngr/validate.c | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/dirmngr/validate.c b/dirmngr/validate.c index 4f893b3ff..901c165ec 100644 --- a/dirmngr/validate.c +++ b/dirmngr/validate.c @@ -1014,7 +1014,31 @@ check_cert_sig (ksba_cert_t issuer_cert, ksba_cert_t cert) gcry_sexp_release (s_sig); return gpg_error (GPG_ERR_DIGEST_ALGO); } - /* log_debug ("PSS hash=%d saltlen=%u\n", algo, saltlen); */ + /* Add some restrictions; see ../sm/certcheck.c for details. */ + switch (algo) + { + case GCRY_MD_SHA1: + case GCRY_MD_SHA256: + case GCRY_MD_SHA384: + case GCRY_MD_SHA512: + case GCRY_MD_SHA3_256: + case GCRY_MD_SHA3_384: + case GCRY_MD_SHA3_512: + break; + default: + log_error ("PSS hash algorithm '%s' rejected\n", + gcry_md_algo_name (algo)); + gcry_sexp_release (s_sig); + return gpg_error (GPG_ERR_DIGEST_ALGO); + } + + if (gcry_md_get_algo_dlen (algo) != saltlen) + { + log_error ("PSS hash algorithm '%s' rejected due to salt length %u\n", + gcry_md_algo_name (algo), saltlen); + gcry_sexp_release (s_sig); + return gpg_error (GPG_ERR_DIGEST_ALGO); + } } algo_name = hash_algo_to_string (algo); |