source: mod_gnutls/CHANGELOG @ b6c7866

Last change on this file since b6c7866 was a900948, checked in by Fiona Klute <fiona.klute@…>, 22 months ago

Support multiple ALPN proposals for proxy TLS connections

The note from the proxy module is split at " " or "," like in mod_ssl.

  • Property mode set to 100644
File size: 11.5 KB
1** Version 0.9.0 UNRELEASED
2- Security fix: Refuse to send or receive any data over a failed TLS
3  connection (commit 72b669eae8c45dda1850e8e5b30a97c918357b51). This
4  could lead to requests on reverse proxy TLS connections being sent
5  in plain text, and might allow faking requests in plain text.
6- Security fix: Reject HTTP requests if they try to access virtual
7  hosts that do not match their TLS connections (commit
8  de3fad3c12f53cdbf082ad675e4b10f521a02811). Additionally check if SNI
9  and Host header match.
10- OCSP stapling is now enabled by default, if possible. OCSP responses
11  are updated regularly and stored in a cache separate from the
12  session cache. The OCSP cache uses mod_socache_shmcb by default
13  (if the module is loaded, no other configuration required).
14- Session tickets are now enabled by default if using GnuTLS 3.6.4 or
15  newer. GnuTLS 3.6.4 introduced automatic rotation for the used key,
16  and TLS 1.3 takes care of other reasons not to use tickets while
17  requiring them for session resumption. Note that there is currently
18  no mechanism to synchronize ticket keys across a cluster of servers.
19- The internal cache implementation has been replaced with
20  mod_socache. Users may need to update their GnuTLSCache settings and
21  load the appropriate socache modules.
22- ALPN (required for HTTP/2) now works correctly with different
23  "Protocols" directives between virtual hosts if building with GnuTLS
24  3.6.3 or newer. Older versions require identical "Protocols"
25  directives for overlapping virtual hosts. Thanks to Vincent Tamet
26  for the bug report!
27- ALPN is now supported for proxy connections, making HTTP/2 proxy
28  connections using mod_proxy_http2 possible.
29- GnuTLSPriorities is optional now and defaults to "NORMAL" if
30  missing. The same applies to GnuTLSProxyPriorities (if TLS proxy is
31  enabled).
32- The manual is now built as a manual page, too, if pandoc is
33  available.
34- OpenPGP support has been removed.
36** Version 0.8.4 (2018-04-13)
37- Support Apache HTTPD 2.4.33 API for proxy TLS connections
38- Support TLS for HTTP/2 connections with mod_http2
39- Fix configuration of OCSP stapling callback
41** Version 0.8.3 (2017-10-20)
42- Use GnuTLS' default DH parameters by default
43- Handle long Server Name Indication data and gracefully ignore
44  unknown SNI types
45- Send SNI for proxy connections
46- Deprecate OpenPGP support like GnuTLS did (will be removed
47  completely in a future release)
48- Do not announce session ticket support for proxy connections
49- Minor documentation updates (SSL_CLIENT_I_DN, reference for SNI)
50- Test suite: Simplify handling of proxy backend servers and OCSP
51  responders
52- Test suite: stability/compatibility fixes
54** Version 0.8.2 (2017-01-08)
55- Test suite: Ensure CRLF line ends in HTTP headers
56- Test suite, gen_ocsp_index.c: Handle serial as fixed order byte array
58** Version 0.8.1 (2016-12-20)
59- Bugfix: Use APR_SIZE_T_FMT for portable apr_size_t formatting
61** Version 0.8.0 (2016-12-11)
62- New: Support for OCSP stapling
63- Bugfix: Access to DBM cache is locked using global mutex
64  "gnutls-cache"
65- Bugfix: GnuTLSSessionTickets is now disabled by default as described
66  in the handbook
67- Fixed memory leak while checking proxy backend certificate
68- Fixed memory leaks in post_config
69- Safely delete session ticket key (requires GnuTLS >= 3.4)
70- Improved error handling in post_config hook
71- Various handbook updates
72- Internal API documentation can be generated using Doxygen
73- Unused code has been removed (conditionals for GnuTLS 2.x and Apache
74  versions before 2.2, internal Lua bytecode structure last used in
75  2011).
76- Test suite: Fixed locking for access to the PGP keyring of the test
77  certificate authority
78- mod_gnutls can be built using Clang (unsupported)
80** Version 0.7.5 (2016-05-28)
81- Sunil Mohan Adapa reported retry loops during session shutdown in
82  cleanup_gnutls_session() due to gnutls_bye() incorrectly returning
83  GNUTLS_E_INTERRUPTED or GNUTLS_E_AGAIN. Setting the GnuTLS session
84  errno in mgs_transport_write() fixes the problem.
85- Import Daniel Kahn Gillmor's patches for GnuPG v2 support from the
86  Debian package.
87- Build system improvements that allow VPATH builds and get "make
88  distcheck" to work
90** Version 0.7.4 (2016-04-13)
91- Support SoftHSM 2 for PKCS #11 testing
92- Increase verbosity of test logs
94** Version 0.7.3 (2016-01-12)
95- Update test suite for compatibility with GnuTLS 3.4, which has
96  stricter key usage checks and priorities than 3.3.
97- Write non-HTML output to mod_status reports if AP_STATUS_SHORT is
98  set (mod_status sets it for requests with the "auto" parameter, e.g.
99  https://localhost/server-status?auto).
100- Register "ssl_is_https" function so the special mod_rewrite variable
101  %{HTTPS} works correctly with mod_gnutls. The new test case for this
102  requires Wget or curl. Fixes Debian bug #514005.
103- Test suite servers listen on IPv4 *and* IPv6 loopback addresses by
104  default (other addresses configurable), which should fix failures
105  due to localhost randomly resolving to either on some distributions.
106- Isolate tests using network namespaces, if possible. This avoids
107  port conflicts with other test cases (so they can run in parallel)
108  and host services.
109- Support for local Apache drop-in config files in the test suite
110  (e.g. to load additional modules needed on Fedora).
111- Try to use markdown to build HTML documentation if pandoc is not
112  available.
113- Disable use of flock if it is unavailable or does not support
114  timeouts (the latter caused the build to fail on Debian Hurd).
115- New test: Disable TLS 1.0 (regression test for Debian bug #754960).
117** Version 0.7.2 (2015-11-21)
118- Bugfix: Non-blocking reads in the input filter could lead to a busy
119  wait in the gnutls_io_input_read function, causing high load on
120  Keep-Alive connections waiting for data, until either more data
121  could be received or the connection was closed. The fix is to pass
122  EAGAIN/EINTR results up to the input filter so they can be handled
123  properly.
124- Close TLS session if the input filter receives EOF (mostly relevant
125  for proper termination of proxy connections).
126- Remove dependency on APR Memcache, which is replaced by the newer
127  version included in the APR Utility Library (libaprutil).
128- Remove dependency on bc. It was used for floating point arithmetic
129  in the test suite, the calculations have been changed to use
130  integers and pure bash code.
132** Version 0.7.1 (2015-10-18)
133- Improved handling of PKCS #11 modules: mod_gnutls now loads either
134  modules specified using GnuTLSP11Module, or the system defaults, but
135  not both. Thanks to Nikos Mavrogiannopoulos for the report and
136  initial patch!
137- Initialize variables to safe defaults during client certificate
138  verification. Certain error code paths did not set them, but they
139  should never be hit due to config validation. This adds another line
140  of defense.
141- Enable C99 support via autoconf
142- Test suite improvements. Most importantly, automake now handles
143  environment setup without any external make calls. Rules to build
144  the certificates are included from the old test makefile. Note that
145  the dependency on GNU make is not new (the test makefile always used
146  GNU make syntax), it just wasn't listed explicitly.
148** Version 0.7 (2015-07-12)
149- Security fix for TLS client authentication (CVE-2015-2091)
150- Bug fixes that enable support for reverse proxy operation
151- Various test suite improvements. Tests are configured through autoconf,
152  so the test suite now works for builds without Monkeysphere support.
153- Add support for TLS connections to back end servers when operating as a
154  reverse proxy (X.509 authentication only at the moment).
155- PKCS #11 support for server keys and certificates
156- Use strict compiler arguments by default (-Wall -Werror -Wextra)
157- Allow limiting the size of certificates exported as SSL_SERVER_CERT
158  and SSL_CLIENT_CERT through the GnuTLSExportCertificates directive
160** Version 0.6 (2014-02-17)
161- Generating DH Params instead of using static ones.
162- Now considering ServerAlias Directives.
163- Major Legacy Code Cleanup.
164- html and pdf and manual documentation generated from markdown sources
165- support monkeysphere validation agent (MSVA) client-certificate verification
166- wider test suite
167- GnuTLSExportCertificates off by default
169** Version 0.5.10 (2011-07-12)
170- Patched a bug responsible for excessive memory consumption by mod_gnutls.
171- Support for proxying from SSL to plain HTTP was added (ie. proxy termination).
173** Version 0.5.9 (2010-09-24)
174- GnuTLSCache none is now an allowed option.
175- Corrected behavior in Keep-Alive connections (do not
176  terminate the connection prematurely)
177- The GnuTLSCache variable now can be given the specific
178  option "gdbm" instead of "dbm". "dbm" will use the berkeley
179  db type of libapr while gdbm will force gdbm to be used.
180  sdbm is no longer being used due to serious limitations.
182** Version 0.5.8 (2010-08-18)
183- Session tickets are enabled by default.
184- Fixes some segmentation faults noticed in some
185  configurations.
187** Version 0.5.7 (2010-07-01)
188- Force usage of SDBM. For some reason the default in
189  my system had issues after reaching a limit of entries.
190  SDBM seems stable so force it.
191- Optimizations in session caching.
192- Added support for session tickets. This allows a
193  server to avoid using a session cache and still support
194  session resumption. This is at the cost of transporting
195  session data during handshake. New option
196  GnuTLSSessionTickets [on|off]
197- Depend on gnutls 2.10.0 to force support for safe
198  renegotiation.
200** Version 0.5.6 (2010-03-24)
201- Corrected issue with firefox and long POST data (by
202  handling EINTR and EAGAIN errors in read).
203- Added support for chained client certificates
204- Corrected more issues related to double frees
207** Version 0.5.5 (2009-06-13)
208- Removed limits on CA certificate loading. Reported by
209  Sander Marechal and Jack Bates.
210- Do not allow sending empty TLS packets even when instructed to.
211  This had the side effect of clients closing connection.
213** Version 0.5.4 (2009-01-04)
214- mod_gnutls.h: modified definition to extern to avoid compilation
215  errors in darwin.
216- Added patch to fix issue with mod_proxy. Investigation and patch by Alain
217  Knaff.
218- libgnutls detection uses pkg-config.
220** Version 0.5.3 (2008-10-16)
221- Corrected bug to allow having an OpenPGP-only web site.
222- Increased Max handshake tries due to interrupted system calls.
224** Version 0.5.2 (2008-06-29)
225- Depend on gnutls 2.4 which has openpgp support in main library.
227** Version 0.5.1 (2008-03-05)
228- Added --disable-srp configure option
229- Better check for memcache (patch by Guillaume Rousse)
230- Corrected possible memory leak in DBM support for resuming sessions.
232** Version 0.5.0-alpha (2008-01-24)
233- Added support for OpenPGP keys. The new directives are:
234  GnuTLSPGPKeyringFile, GnuTLSPGPCertificateFile, GnuTLSPGPKeyFile
236** Version 0.4.2 (2007-12-10)
237- Added support for sending a certificate chain.
238- Corrected bug which did not allow the TLS session cache to be used.
239- Do not allow resuming sessions on different servers.
241** Version 0.4.1 (2007-12-03)
242- Added support for subject alternative names in certificates.
243Only one per certificate is supported.
244- New enviroment variables: SSL_CLIENT_M_VERSION, SSL_CLIENT_S_SAN%,
246- The compatibility mode can now be enabled explicitely with the
247%COMPAT keyword at the GnuTLSPriorities string. It is no longer the default.
248- Check for GnuTLSPriorities directive. This corrects a segfault. Thanks
249to David Hrbáč.
250- Better handling of GnuTLSDHFile and GnuTLSRSAFile.
251- No longer default paths for RSA and DH parameter files.
Note: See TracBrowser for help on using the repository browser.