]> granicus.if.org Git - apache/blob - CHANGES
df83e57f0c78411176262034f97765e0a2765ce0
[apache] / CHANGES
1                                                          -*- coding: utf-8 -*-
2 Changes with Apache 2.5.0
3
4   *) mod_proxy_http2: using single connection for several requests *if*
5      master connection uses HTTP/2 itself. Not yet hardened under load.
6      [Stefan Eissing]
7
8   *) core: Added support for HTTP code 451. PR58985.
9      [Yehuda Katz <yehuda ymkatz.net>, Jim Jagielski]
10
11   *) mod_ssl: Add support for OpenSSL 1.1.0. [Rainer Jung]
12  
13   *) hostname: Test and log useragent_host per-request across various modules,
14      including the scoreboard, expression and rewrite engines, setenvif,
15      authz_host, access_compat, custom logging, ssl and REMOTE_HOST variables.
16      PR55348  [William Rowe]
17  
18   *) core: Track the useragent_host per-request when mod_remoteip or similar
19      modules track a per-request useragent_ip.  Modules should be updated
20      to inquire for ap_get_useragent_host() in place of ap_get_remote_host().
21      [William Rowe]
22
23   *) mod_proxy: Play/restore the TLS-SNI on new backend connections which
24      had to be issued because the remote closed the previous/reusable one
25      during idle (keep-alive) time.  [Yann Ylavic]
26
27   *) mod_proxy_http2: new experimental http2 proxy module for h2: and h2c: proxy
28      urls. Uses, so far, one connection per request, reuses connections.
29      [Stefan Eissing]
30   
31   *) event: use pre_connection hook to properly initialize connection state for
32      slave connections. use protocol_switch hook to initialize server config
33      early based on SNI selected vhost. 
34      [Stefan Eissing]
35   
36   *) mod_http2: allowing link header to specify multiple "rel" values, 
37      space-separated inside a quoted string. Prohibiting push when Link parameter
38      "nopush" is present.
39      [Stefan Eissing]
40
41   *) core: Prevent a server crash in case of an invalid CONNECT request with
42      a custom error page for status code 400 that uses server side includes.
43      PR 58929 [Ruediger Pluem]
44
45   *) mod_ssl: Add SSLOCSPProxyURL to add the possibility to do all queries
46      to OCSP responders through a HTTP proxy. [Ruediger Pluem]
47
48   *) mod_http2: idle connections are returned to async mpms. new hook
49      "pre_close_connection" used to send GOAWAY frame when not already done.
50      Setting event mpm server config "by hand" for the main connection to
51      the correct negotiated server.
52      [Stefan Eissing]
53
54   *) core: new hook "pre_close_connection" which is run before the lingering
55      close of connections is started. This gives protocol handlers one last
56      chance to use a connection before it goes down.
57      [Stefan Eissing]
58
59   *) mod_filter: Fix AddOutputFilterByType with non-content-level filters.
60      PR58856 [Micha Lenk <micha lenk.info>]
61
62   *) mod_cache: Consider Cache-Control: s-maxage in expiration
63      calculations.  [Eric Covener]
64
65   *) mod_cache: Allow caching of responses with an Expires header
66      in the past that also has Cache-Control: max-age or s-maxage.
67      PR55156. [Eric Covener]
68
69   *) ap_expr: expression support for variable HTTP2=on|off
70      [Stefan Eissing]
71
72   *) mod_status/scoreboard: showing connection protocol in new column, new 
73      ap_update_child_status methods for updating server/description. mod_ssl
74      sets vhost negotiated by servername directly.
75      [Stefan Eissing]
76
77   *) mod_http2: keep-alive blocking reads are done with 1 second timeouts to
78      check for MPM stopping. Will announce early GOAWAY and finish processing
79      open streams, then close.
80      [Stefan Eissing]
81
82   *) mod_proxy_hcheck: Provide for dynamic background health
83      checks on reverse proxies associated with BalancerMember
84      workers. [Jim Jagielski]
85
86   *) mod_ssl: handle TIMEOUT on empty SSL input as non-fatal, returning 
87      APR_TIMEUP and preserving connection state for later retry.
88      [Stefan Eissing]
89
90   *) mod_http2: bytes read/written on slave connections are reported via the
91      optional mod_logio functions. Fixes PR 58871.
92
93   *) Added many log numbers to log statements that had none.
94
95   *) core: Add expression support to SetHandler.
96      [Eric Covener]
97
98   *) mod_proxy_fcgi: Suppress HTTP error 503 and message 01075, 
99      "Error dispatching request", when the cause appears to be 
100      due to the client closing the connection. 
101      PR58118.  [Tobias Adolph <adolph lrz.de>]
102
103   *) mod_cgid: Message 02550, failure to flush a response to the client,
104      is now logged at TRACE1 level to match the underlying core output filter
105      severity.  [Eric Covener]
106
107   *) mod_rewrite: Avoid looping on relative substitutions that
108      result in the same filename we started with. PR 58854.
109      [Eric Covener]
110
111   *) mime.types: add common extension "m4a" for MPEG 4 Audio.
112      PR 57895 [Dylan Millikin <dylan.millikin gmail.com>]
113
114   *) mod_ssl: Save some TLS record (application data) fragmentations by
115      including the last and subsequent suitable buckets when coalescing.
116      [Yann Ylavic]
117
118   *) mod_cache_socache: Fix a possible cached entity body corruption when it
119      is received from an origin server in multiple batches and forwarded by
120      mod_proxy.  [Yann Ylavic]
121
122   *) mod_proxy_fdpass: Fix AH01153 error when using the default configuration.
123      In earlier version of httpd, you can explicitelly set the 'flusher' parameter
124      to 'flush' as a workaround. (i.e. flusher=flush)
125      Add documentation for the 'flusher' parameter when defining a proxy worker.
126      [Christophe Jaillet]
127
128   *) mod_ssl: For the "SSLStaplingReturnResponderErrors off" case, make sure
129      to only staple responses with certificate status "good". [Kaspar Brand]
130
131   *) core: Limit to ten the number of tolerated empty lines between request,
132      and consume them before the pipelining check to avoid possible response
133      delay when reading the next request without flushing.  [Yann Ylavic]
134
135   *) mod_session: Introduce SessionExpiryUpdateInterval which allows to
136      configure the session/cookie expiry's update interval. PR 57300.
137      [Paul Spangler <paul.spangler ni.com>]
138
139   *) core: Extend support for asynchronous write completion from the
140      network filter to any connection or request filter. [Graham Leggett]
141
142   *) mpm_event: Free memory earlier when shutting down processes.
143      [Stefan Fritsch]
144
145   *) mod_ssl: Make the output filter more friendly with deferred write and
146      response pipelining. [Yann Ylavic, Joe Orton]
147
148   *) core/util_script: relax alphanumeric filter of environment variable names
149      on Windows to allow '(' and ')' for passing PROGRAMFILES(X86) et.al.
150      unadulterated in 64 bit versions of Windows. PR 46751.  
151      [John <john leineweb de>]
152
153   *) mod_auth_digest: remove AuthDigestEnableQueryStringHack which is no
154      more documented since dec 2012 (r1415960). [Christophe Jaillet]
155
156   *) mod_charset_lite: On EBCDIC platforms, make sure mod_charset_lite runs
157      after other resource-level filters. [Eric Covener]
158
159   *) mod_dir: Responses that go through "FallbackResource" might appear to
160      hang due to unterminated chunked encoding. PR58292. [Eric Covener]
161
162   *) mod_alias: Limit Redirect expressions to directory (Location) context
163      and redirect statuses (implicit or explicit).
164      [Yann Ylavic, Ruediger Pluem]
165
166   *) mod_substitute: Fix configuraton merge order.
167      PR 57641 [<Marc.Stern approach.be>]
168
169   *) mod_ssl: When SSLVerify is disabled (NONE), don't force a renegotiation if
170      the SSLVerifyDepth applied with the default/handshaken vhost differs from
171      the one applicable with the finally selected vhost.  [Yann Ylavic]
172
173   *) http: Don't remove the Content-Length of zero from a HEAD response if
174      it comes from an origin server, module or script.  [Yann Ylavic]
175
176   *) http: Add support for RFC2324/RFC7168. [Graham Leggett]
177
178   *) mod_rewrite: Add support for starting External Rewriting Programs
179      as non-root user on UNIX systems by specifying username and group name
180      as third argument of RewriteMap directive. [Jan Kaluza]
181
182   *) mod_authn_core: Add expression support to AuthName and AuthType.
183      [Graham Leggett]
184
185   *) suexec: Filter out the HTTP_PROXY environment variable because it is
186      treated as alias for http_proxy by some programs. [Stefan Fritsch]
187
188   *) mod_proxy_http: Don't establish or reuse a backend connection before pre-
189      fetching the request body, so to minimize the delay between it is supposed
190      to be alive and the first bytes sent: this is a best effort to prevent the
191      backend from closing because of idle or keepalive timeout in the meantime.
192      Also, handle a new "proxy-flushall" environment variable which allows to
193      flush any forwarded body data immediately. PR 56541+37920. [Yann Ylavic]
194
195   *) core: Define and UnDefine are no longer permitted in
196      directory context. Previously they would always be evaulated
197      as the configuration was read without regard for the directory
198      context. [Eric Covener]
199
200   *) config: For directives that do not expect any arguments, enforce
201      that none are specified in the configuration file. 
202      [Joachim Zobel <jzobel heute-morgen.de>, Eric Covener]
203
204   *) mod_rewrite: Improve 'bad flag delimeters' startup error by showing
205      how the input was tokenized.  PR 56528. [Edward Lu <Chaosed0 gmail.com>]
206
207   *) mod_proxy: Don't put non balancer-member workers in error state by
208      default for connection or 500/503 errors, and honor status=+I for
209      any error.  PR 48388.  [Yann Ylavic]
210
211   *) mod_socache_memcache: Pass expiration time through to memcached. PR 55445.
212      [Faidon Liambotis <paravoid debian.org>, Joe Orton]
213
214   *) ap_expr: Add filemod function for checking file modification dates
215      [Daniel Gruno]
216
217   *) mod_authnz_ldap: Resolve crashes with LDAP authz and non-LDAP authn since 
218      r1608202. [Eric Covener]
219
220   *) core: Ensure that httpd exits with an error status when the MPM fails
221      to run.  [Yann Ylavic]
222
223   *) apreq: Content-Length header should be always interpreted as a decimal.
224      Leading 0 could be erroneously considered as an octal value. PR 56598.
225      [Chris Card <ctcard hotmail com>]
226
227   *) mod_proxy: Now allow for 191 character worker names, with non-fatal
228      errors if name is truncated. PR53218. [Jim Jagielski]
229
230   *) mod_ssl: Add optional function "ssl_get_tls_cb" to allow support
231      for channel bindings.  [Simo Sorce <simo redhat.com>]
232
233   *) mod_proxy_wstunnel: Concurrent websockets messages could be 
234      lost or delayed with ProxyWebsocketAsync enabled.  
235      [Edward Lu <Chaosed0 gmail.com>]
236
237   *) core, mod_info: Add compiled and loaded PCRE versions to version
238      number display.  [Rainer Jung]
239
240   *) mod_authnz_ldap: Return LDAP connections to the pool before the handler
241      is run, instead of waiting until the end of the request. [Eric Covener]
242
243   *) mod_log_config: Add GlobalLog to allow a globally defined log to
244      be inherited by virtual hosts that define a CustomLog.
245      [Edward Lu <Chaosed0 gmail.com>]
246
247   *) mod_proxy_html: support automatic detection of doctype and processing
248      of FPIs.  PR56285 [Micha Lenk <micha lenk info>, Nick Kew]
249
250   *) mod_proxy_html: skip documents shorter than 4 bytes
251      PR 56286 [Micha Lenk <micha lenk info>]
252
253   *) mod_proxy_fdpass: Fix computation of the size of 'struct sockaddr_un'
254      when passed to 'connect()'.
255      [Graham Dumpleton <grahamd apache org>]
256
257   *) core: Add ap_mpm_resume_suspended() API to allow a suspended connection
258      to resume. PR56333 
259      [Artem <artemciy gmail.com>, Edward Lu <Chaosed0 gmail.com>]
260
261   *) core: Add ap_mpm_register_socket_callback_timeout() API. [Eric Covener]
262
263   *) mod_proxy_wstunnel: Honor ProxyWebsocketIdleTimeout in asynchronous
264      processing mode. [Eric Covener]
265
266   *) mod_authnz_ldap: Fail explicitly when the filter is too long. Remove
267      unnecessary apr_pstrdup() and strlen(). [Graham Leggett]
268
269   *) Add the ldap-search option to mod_authnz_ldap, allowing authorization
270      to be based on arbitrary expressions that do not include the username.
271      [Graham Leggett]
272
273   *) Add the ldap function to the expression API, allowing LDAP filters and
274      distinguished names based on expressions to be escaped correctly to
275      guard against LDAP injection. [Graham Leggett]
276
277   *) Add module mod_ssl_ct, which provides an implementation of Certificate
278      Transparency (RFC 6962) for httpd.  [Jeff Trawick]
279
280   *) mod_remoteip: Prevent an external proxy from presenting an internal
281      proxy. PR 55962. [Mike Rumph]
282
283   *) mod_ssl: Add hooks to allow other modules to perform processing at
284      several stages of initialization and connection handling.  See
285      mod_ssl_openssl.h.  [Jeff Trawick]
286
287   *) mod_proxy_wstunnel: Avoid sending error responses down an upgraded
288      websockets connection as it is being close down. [Eric Covener]
289
290   *) mod_proxy_wstunnel: Allow the administrator to cap the amount
291      of time a synchronous websockets connection stays idle with 
292      ProxyWebsocketIdleTimeout. [Eric Covener]
293
294   *) mod_proxy_wstunnel: Change to opt-in for asynchronous support, adding 
295      directives ProxyWebsocketAsync and ProxyWebsocketAsyncDelay. 
296      [Eric Covener]
297
298   *) mod_proxy_wstunnel: Stop leaking websockets backend connections under
299      event MPM (trunk-only). [Eric Covener]
300
301   *) mod_proxy_http: Add detach_backend hook (potentially usable
302      in other proxy scheme handlers).  [Jeff Trawick]
303
304   *) mod_deflate: Add DeflateAlterETag to control how the ETag
305      is modified. The 'NoChange' parameter mimics 2.2.x behavior.
306      PR 45023, PR 39727. [Eric Covener]
307
308   *) mod_rewrite: Add 'BNF' (backreferences-no-plus) flag to RewriteRule to 
309      allow spaces in backreferences to be encoded as %20 instead of '+'.
310      [Eric Covener]
311
312   *) mod_rewrite: Support an optional list of characters to escape in the 
313      argument for the 'B' (escape backreferences) flag. [Eric Covener]
314
315   *) mod_dir: Default to 2.2-like behavior and skip execution when method is
316      neither GET nor POST, such as for DAV requests. PR 54914. [Chris Darroch]
317
318   *) mod_rewrite: Rename the handler that does per-directory internal 
319      redirects to "rewrite-redirect-handler" from "redirect-handler" so
320      it is less ambiguous and less likely to be reused. [Eric Covener]
321
322   *) mod_rewrite: Protect against looping with the [N] flag by enforcing a 
323      default limit of 10000 iterations, and allowing each rule to change its
324      limit. [Eric Covener]
325
326   *) mod_ssl: Fix config merging of SSLOCSPEnable and SSLOCSPOverrideResponder.
327      [Jeff Trawick]
328
329   *) Add HttpContentLengthHeadZero and HttpExpectStrict directives.
330      [Yehuda Sadeh <yehuda inktank com>, Justin Erenkrantz]
331
332   *) mod_ssl: Add -t -DDUMP_CA_CERTS option which dumps the filenames of all
333      configured SSL CA certificates to stdout the same way as DUMP_CERTS does.
334      [Jan Kaluza]
335
336   *) mod_ssl: Don't flush when an EOS is received. Prepares mod_ssl
337      to support write completion. [Graham Leggett]
338
339   *) core: Add parse_errorlog_arg callback to ap_errorlog_provider
340      to allow providers to check the ErrorLog argument. [Jan Kaluza]
341
342   *) mod_cgid: Use the servers Timeout for each read from a CGI script,
343      allow override with new CGIDRequestTimeout directive. PR43494
344      [Eric Covener, Toshikuni Fukaya <toshikuni-fukaya cybozu co jp>]
345
346   *) core: ensure any abnormal exit is reported to stderr if it's a tty.
347      PR 55670 [Nick Kew]
348
349   *) mod_lua: Let the Inter-VM get/set functions work with a global 
350      shared memory pool instead of a per-process pool. [Daniel Gruno]
351
352   *) ldap: Support ldaps when using the Microsoft LDAP SDK.
353      PR 54626. [Jean-Frederic Clere]
354
355   *) mod_authnz_ldap: Change default value of AuthLDAPMaxSubGroupDepth to 0
356      to avoid performance problems when subgroups aren't in use. [Eric Covener]
357
358   *) mod_syslog: New module implementing syslog ap_error_log provider.
359      Previously, this code was part of core, now it's in separate module.
360      [Jan Kaluza]
361
362   *) core: Add ap_errorlog_provider to make ErrorLog logging modular. Move
363      syslog support from core to new mod_syslog. [Jan Kaluza]
364
365   *) mod_status, mod_echo: Fix the display of client addresses.
366      They were truncated to 31 characters which is not enough for IPv6 addresses.
367      PR 54848 [Bernhard Schmidt <berni birkenwald de>]
368
369   *) mod_unique_id: Use output of the PRNG rather than IP address and
370      pid, avoiding sleep() call and possible DNS issues at startup,
371      plus improving randomness for IPv6-only hosts.
372      [Jan Kaluza <jkaluza redhat.com>]
373
374   *) mod_file_cache: mod_file_cache should be able to serve files that
375      haven't had a Content-Type set via e.g. mod_mime. [Eric Covener]
376
377   *) core: merge AllowEncodedSlashes from the base configuration into
378      virtual hosts. [Eric Covener]
379
380   *) AIX: Install DSO's with "cp" instead of "install" in instdso.sh
381      [Eric Covener]
382
383   *) mod_ldap: Don't keep retrying if a new LDAP connection times out.
384      [Eric Covener]
385
386   *) mod_deflate: permit compilation of mod_deflate against a zlib that has
387      been configured with -D Z_PREFIX, which redefines the token "deflate".
388      [Eric Covener]
389
390   *) mod_auth_digest: Use the secret when generating nonces in all cases and
391      not only when AuthName is used in .htaccess files (this change may cause
392      problems if used with round robin load balancers). Don't regenerate the
393      secret on graceful restarts. PR 54637  [Stefan Fritsch]
394
395   *) core: Remove apr_brigade_flatten(), buffering and duplicated code
396      from the HTTP_IN filter, parse chunks in a single pass with zero copy.
397      Reduce memory usage by 48 bytes per request. [Graham Leggett]
398
399   *) core: Stop the HTTP_IN filter from attempting to write error buckets
400      to the output filters, which is bogus in the proxy case. Create a
401      clean mapping from APR codes to HTTP status codes, and use it where
402      needed. [Graham Leggett]
403
404   *) mod_proxy: Ensure network errors detected by the proxy are returned as
405      504 Gateway Timout as opposed to 502 Bad Gateway, in order to be
406      compliant with RFC2616 14.9.4 Cache Revalidation and Reload Controls.
407
408   *) mod_dav: mod_dav overrides dav_fs response on PUT failure. PR 35981
409      [Basant Kumar Kukreja <basant.kukreja sun.com>, Alejandro Alvarez
410      <alejandro.alvarez.ayllon cern.ch>]
411
412   *) mod_ldap: LDAP connections used for authentication were not respecting
413      LDAPConnectionPoolTimeout.  PR 54587
414
415   *) core: ap_rgetline_core now pulls from r->proto_input_filters.
416
417   *) mod_proxy_html: process parsed comments immediately. 
418      Fixes bug where parsed comments may be lost. [Nick Kew]
419
420   *) mod_proxy_html: introduce doctype for HTML 5 [Nick Kew]
421
422   *) mod_proxy_html: fix typo-bug processing "strict" vs "transitional"
423      HTML/XHTML [Nick Kew]
424
425   *) core: Add option to add valgrind support. Use it to reduce false positive
426      warnings in mod_ssl. [Stefan Fritsch]
427
428   *) mod_authn_file, mod_authn_dbd, mod_authn_dbm, mod_authn_socache:
429      Cache the result of the most recent password hash verification for every
430      keep-alive connection. This saves some expensive calculations.
431      [Stefan Fritsch]
432
433   *) http: Remove support for Request-Range header sent by Navigator 2-3 and
434      MSIE 3. [Stefan Fritsch]
435
436   *) core, http: Extend HttpProtocol with an option to enforce stricter HTTP
437      conformance or to only log the found problems. [Stefan Fritsch]
438
439   *) core: Correctly parse an IPv6 literal host specification in an absolute
440      URL in the request line. [Stefan Fritsch]
441
442   *) EventOpt MPM
443
444   *) core: Add LogLevelOverride directive that allows to override the
445      loglevel for clients from certain IPs. This also works for things
446      like the SSL handshake where <If> LogLevel ... </If> is evaluated
447      too late. [Stefan Fritsch]
448
449   *) core: Add new directive Warning to issue warnings from a configuration
450      file. Both Warning and Error now generate a timestamped log message.
451      [Fabien Coelho] 
452
453   *) ap_expr: Add SERVER_PROTOCOL_VERSION, ..._MAJOR, and ..._MINOR
454      variables. [Stefan Fritsch]
455
456   *) core: New directive RegisterHttpMethod for registering non-standard
457      HTTP methods. [Stefan Fritsch]
458
459   *) core: New directive HttpProtocol which allows to disable HTTP/0.9
460      support. [Stefan Fritsch]
461
462   *) mod_allowhandlers: New module to forbid specific handlers for specific
463      directories. [Stefan Fritsch]
464
465   *) mod_systemd: New module, for integration with systemd on Linux.
466      [Jan Kaluza <jkaluza redhat.com>]
467
468   *) WinNT MPM: Store pid and generation for each thread in scoreboard
469      to allow tracking of threads from exiting children via mod_status
470      or other such mechanisms.  [Jeff Trawick]
471
472   *) The following now respect DefaultRuntimeDir/DEFAULT_REL_RUNTIMEDIR:
473      - APIs: ap_log_pid(), ap_remove_pid, ap_read_pid()
474      - mod_cache: thundering herd lock directory
475      - mod_lbmethod_heartbeat, mod_heartmonitor: heartbeat storage file
476      - mod_ldap: shared memory cache
477      - mod_socache_shmcb, mod_socache_dbm: shared memory or dbm for cache
478      [Jeff Trawick]
479
480   *) suexec: Add --enable-suexec-capabilites support on Linux, to use
481      setuid/setgid capability bits rather than a setuid root binary.
482      [Joe Orton]
483
484   *) suexec: Add support for logging to syslog as an alternative to logging
485      to a file; configure --without-suexec-logfile --with-suexec-syslog.  
486      [Joe Orton]
487
488   *) mod_ssl: Add support for TLS Next Protocol Negotiation.  PR 52210.
489      [Matthew Steele <mdsteele google.com>]
490
491   *) cross-compile: allow to provide CC_FOR_BUILD so that gen_test_char will
492      be compiled by the build compiler instead of the host compiler.
493      Also set CC_FOR_BUILD to 'cc' when cross-compilation is detected.
494      PR 51257. [Guenter Knauf]
495
496   *) core: In maintainer mode, replace apr_palloc with a version that
497      initializes the allocated memory with non-zero values, except if
498      AP_DEBUG_NO_ALLOC_POISON is defined. [Stefan Fritsch]
499
500   *) mod_policy: Add a new testing module to help server administrators
501      enforce a configurable level of protocol compliance on their
502      servers and application servers behind theirs. [Graham Leggett]
503
504   *) mod_firehose: Add a new debugging module able to record traffic
505      passing through the server in such a way that connections and/or
506      requests be reconstructed and replayed. [Graham Leggett]
507
508   *) mod_noloris
509
510   *) APREQ
511
512   *) Simple MPM
513
514   *) mod_serf
515
516   [Apache 2.5.0-dev includes those bug fixes and changes with the
517    Apache 2.4.xx tree as documented below, except as noted.]
518
519 Changes with Apache 2.4.x and later:
520
521   *) http://svn.apache.org/viewvc/httpd/httpd/branches/2.4.x/CHANGES?view=markup
522
523 Changes with Apache 2.2.x and later:
524
525   *) http://svn.apache.org/viewvc/httpd/httpd/branches/2.2.x/CHANGES?view=markup
526
527 Changes with Apache 2.0.x and later:
528
529   *) http://svn.apache.org/viewvc/httpd/httpd/branches/2.0.x/CHANGES?view=markup
530