From: Jeremy Harris Date: Sun, 19 May 2019 11:12:36 +0000 (+0100) Subject: GnuTLS: fix the advertising of acceptable certs by the server. Bug 2389 X-Git-Tag: exim-4.93-RC0~192 X-Git-Url: https://vcs.fsf.org/?a=commitdiff_plain;h=12d95aa62042377fc9f603245a17a43142972447;p=exim.git GnuTLS: fix the advertising of acceptable certs by the server. Bug 2389 --- diff --git a/doc/doc-txt/ChangeLog b/doc/doc-txt/ChangeLog index a204b3784..98a473539 100644 --- a/doc/doc-txt/ChangeLog +++ b/doc/doc-txt/ChangeLog @@ -98,6 +98,10 @@ JH/19 Bug 2398: fix listing of a named-queue. Previously, even with the option queue_list_requires_admin set to false, non-admin users were denied the facility. +JH/20 Bug 2389: fix server advertising of usable certificates, under GnuTLS in + directory-of-certs mode. Previously they were advertised despite the + documentation. + Exim version 4.92 ----------------- diff --git a/src/src/tls-gnu.c b/src/src/tls-gnu.c index dc8cdab5c..423c3a23d 100644 --- a/src/src/tls-gnu.c +++ b/src/src/tls-gnu.c @@ -1143,6 +1143,14 @@ else #endif gnutls_certificate_set_x509_trust_file(state->x509_cred, CS state->exp_tls_verify_certificates, GNUTLS_X509_FMT_PEM); + +#ifdef SUPPORT_CA_DIR + /* Mimic the behaviour with OpenSSL of not advertising a usable-cert list + when using the directory-of-certs config model. */ + + if ((statbuf.st_mode & S_IFMT) == S_IFDIR) + gnutls_certificate_send_x509_rdn_sequence(state->session, 1); +#endif } if (cert_count < 0)