2005-02-20 14:27:00 +00:00
|
|
|
|
|
|
|
====
|
|
|
|
NEWS
|
|
|
|
====
|
|
|
|
|
2020-11-29 21:31:14 +00:00
|
|
|
- 1.4.56 - 2020-11-29
|
2020-10-25 19:47:31 +00:00
|
|
|
* [core] perf: request processing
|
|
|
|
* [core] http_header_str_contains_token()
|
|
|
|
* [mod_flv_streaming] parse query string w/o copying
|
|
|
|
* [mod_evhost] use local array to split values
|
|
|
|
* [core] remove srv->split_vals
|
|
|
|
* [core] add User-Agent to http_header_e enum
|
|
|
|
* [core] store struct server * in struct connection
|
|
|
|
* [core] use func rc to indicate done reading header
|
|
|
|
* [core] replace connection_set_state w/ assignment
|
|
|
|
* [core] do not pass srv to http header parsing func
|
|
|
|
* [core] cold buffer_string_prepare_append_resize()
|
|
|
|
* [core] chunkqueue_compact_mem()
|
|
|
|
* [core] connection_chunkqueue_compact()
|
|
|
|
* [core] pass con around request, not srv and con
|
|
|
|
* [core] reduce use of struct parse_header_state
|
|
|
|
* [core] perf: HTTP header parsing using \n offsets
|
|
|
|
* [core] no need to pass srv to connection_set_state
|
|
|
|
* [core] perf: connection_read_header_more()
|
|
|
|
* [core] perf: connection_read_header_hoff() hot
|
|
|
|
* [core] inline connection_read_header()
|
|
|
|
* [core] pass ptr to http_request_parse()
|
|
|
|
* [core] more 'const' in request.c prototypes
|
|
|
|
* [core] handle common case of alnum or - field-name
|
|
|
|
* [mod_extforward] simplify code: use light_isxdigit
|
|
|
|
* [core] perf: array.c performance enhancements
|
|
|
|
* [core] mark some data_* funcs cold
|
|
|
|
* [core] http_header.c internal inline funcs
|
|
|
|
* [core] remove unused array_reset()
|
|
|
|
* [core] prefer uint32_t to size_t in base.h
|
|
|
|
* [core] uint32_t for struct buffer sizes
|
|
|
|
* [core] remove unused members of struct server
|
|
|
|
* [core] short-circuit path to clear request.headers
|
|
|
|
* [core] array keys are non-empty in key-value list
|
|
|
|
* [core] keep a->data[] sorted; remove a->sorted[]
|
|
|
|
* [core] __attribute_returns_nonnull__
|
|
|
|
* [core] differentiate array_get_* for ro and rw
|
|
|
|
* [core] (const buffer *) in (struct burl_parts_t)
|
|
|
|
* [core] (const buffer *) for con->server_name
|
|
|
|
* [core] perf: initialize con->conf using memcpy()
|
|
|
|
* [core] run config_setup_connection() fewer times
|
|
|
|
* [core] isolate data_config.c, vector.c
|
|
|
|
* [core] treat con->conditional_is_valid as bitfield
|
|
|
|
* [core] http_header_hkey_get() over const array
|
|
|
|
* [core] inline buffer as part of DATA_UNSET key
|
|
|
|
* [core] inline buffer key for *_patch_connection()
|
|
|
|
* [core] (data_unset *) from array_get_element_klen
|
|
|
|
* [core] inline buffer as part of data_string value
|
|
|
|
* [core] add const to callers of http_header_*_get()
|
|
|
|
* [core] inline array as part of data_array value
|
|
|
|
* [core] const char *op in data_config
|
|
|
|
* [core] buffer string in data_config
|
|
|
|
* [core] streamline config_check_cond()
|
|
|
|
* [core] keep a->data[] sorted (REVERT)
|
|
|
|
* [core] array a->sorted[] as ptrs rather than pos
|
|
|
|
* [core] inline header and env arrays into con
|
|
|
|
* [mod_accesslog] avoid alloc for parsing cookie val
|
|
|
|
* [core] simpler config_check_cond()
|
|
|
|
* [mod_redirect,mod_rewrite] store context_ndx
|
|
|
|
* [core] const char *name in struct plugin
|
|
|
|
* [core] srv->plugin_slots as compact list
|
|
|
|
* [core] rearrange server_config, server members
|
|
|
|
* [core] macros CONST_LEN_STR and CONST_STR_LEN
|
|
|
|
* [core] struct plugin_data_base
|
|
|
|
* [core] improve condition caching perf
|
|
|
|
* [core] config_plugin_values_init() new interface
|
|
|
|
* [mod_access] use config_plugin_values_init()
|
|
|
|
* [core] (const buffer *) from strftime_cache_get()
|
|
|
|
* [core] mv config_setup_connection to connections.c
|
|
|
|
* [core] use (const char *) in config file parsing
|
|
|
|
* [mod_staticfile] use config_plugin_values_init()
|
|
|
|
* [mod_skeleton] use config_plugin_values_init()
|
|
|
|
* [mod_setenv] use config_plugin_values_init()
|
|
|
|
* [mod_alias] use config_plugin_values_init()
|
|
|
|
* [mod_indexfile] use config_plugin_values_init()
|
|
|
|
* [mod_expire] use config_plugin_values_init()
|
|
|
|
* [mod_flv_streaming] use config_plugin_values_init()
|
|
|
|
* [mod_magnet] use config_plugin_values_init()
|
|
|
|
* [mod_usertrack] use config_plugin_values_init()
|
|
|
|
* [mod_userdir] split policy from userdir path build
|
|
|
|
* [mod_userdir] use config_plugin_values_init()
|
|
|
|
* [mod_ssi] use config_plugin_values_init()
|
|
|
|
* [mod_uploadprogress] use config_plugin_values_init()
|
|
|
|
* [mod_status] use config_plugin_values_init()
|
|
|
|
* [mod_cml] use config_plugin_values_init()
|
|
|
|
* [mod_secdownload] use config_plugin_values_init()
|
|
|
|
* [mod_geoip] use config_plugin_values_init()
|
|
|
|
* [mod_evasive] use config_plugin_values_init()
|
|
|
|
* [mod_trigger_b4_dl] use config_plugin_values_init()
|
|
|
|
* [mod_accesslog] use config_plugin_values_init()
|
|
|
|
* [mod_simple_vhost] use config_plugin_values_init()
|
|
|
|
* [mod_evhost] use config_plugin_values_init()
|
|
|
|
* [mod_vhostdb*] use config_plugin_values_init()
|
|
|
|
* [mod_mysql_vhost] use config_plugin_values_init()
|
|
|
|
* [mod_maxminddb] use config_plugin_values_init()
|
|
|
|
* [mod_auth*] use config_plugin_values_init()
|
|
|
|
* [mod_deflate] use config_plugin_values_init()
|
|
|
|
* [mod_compress] use config_plugin_values_init()
|
|
|
|
* [core] add xsendfile* check if xdocroot is NULL
|
|
|
|
* [mod_cgi] use config_plugin_values_init()
|
|
|
|
* [mod_dirlisting] use config_plugin_values_init()
|
|
|
|
* [mod_extforward] use config_plugin_values_init()
|
|
|
|
* [mod_webdav] use config_plugin_values_init()
|
|
|
|
* [core] store addtl data in pcre_keyvalue_buffer
|
|
|
|
* [mod_redirect] use config_plugin_values_init()
|
|
|
|
* [mod_rewrite] use config_plugin_values_init()
|
|
|
|
* [mod_rrdtool] use config_plugin_values_init()
|
|
|
|
* [multiple] gw_backends config_plugin_values_init()
|
|
|
|
* [core] config_get_config_cond_info()
|
|
|
|
* [mod_openssl] use config_plugin_values_init()
|
|
|
|
* [core] use config_plugin_values_init()
|
|
|
|
* [core] collect more config logic into configfile.c
|
|
|
|
* [core] config_plugin_values_init_block()
|
|
|
|
* [core] gw_backend config_plugin_values_init_block
|
|
|
|
* [core] remove old config_insert_values_*() funcs
|
|
|
|
* [multiple] plugin.c handles common FREE_FUNC code
|
|
|
|
* [core] run all trigger and sighup handlers
|
|
|
|
* [mod_wstunnel] change DEBUG_LOG to use log_error()
|
|
|
|
* [core] stat_cache_path_contains_symlink use errh
|
|
|
|
* [core] isolate use of data_config, configfile.h
|
|
|
|
* [core] split cond cache from cond matches
|
|
|
|
* [mod_auth] inline arrays in http_auth_require_t
|
|
|
|
* [core] array_init() arg for initial size
|
|
|
|
* [core] gw_exts_clear_check_local()
|
|
|
|
* [core] gw_backend less pointer chasing
|
|
|
|
* [core] connection_handle_errdoc() separate func
|
|
|
|
* [multiple] prefer (connection *) to (srv *)
|
|
|
|
* [core] create http chunk header on the stack
|
|
|
|
* [multiple] connection hooks no longer get (srv *)
|
|
|
|
* [multiple] plugin_stats array
|
|
|
|
* [core] read up-to fixed size chunk before fionread
|
|
|
|
* [core] default chunk size 8k (was 4k)
|
|
|
|
* [core] pass con around gw_backend instead of srv
|
|
|
|
* [core] log_error_multiline_buffer()
|
|
|
|
* [multiple] reduce direct use of srv->cur_ts
|
|
|
|
* [multiple] extern log_epoch_secs
|
|
|
|
* [multiple] reduce direct use of srv->errh
|
|
|
|
* [multiple] stat_cache singleton
|
|
|
|
* [mod_expire] parse config into structured data
|
|
|
|
* [multiple] generic config array type checking
|
|
|
|
* [multiple] rename r to rc rv rd wr to be different
|
|
|
|
* [core] (minor) config_plugin_keys_t data packing
|
|
|
|
* [core] inline buffer in log_error_st errh
|
|
|
|
* [multiple] store srv->tmp_buf in tb var
|
|
|
|
* [multiple] quiet clang compiler warnings
|
|
|
|
* [core] http_status_set_error_close()
|
|
|
|
* [core] http_request_host_policy w/ http_parseopts
|
|
|
|
* [multiple] con->proto_default_port
|
|
|
|
* [core] store log filename in (log_error_st *)
|
|
|
|
* [core] separate log_error_open* funcs
|
|
|
|
* [core] fdevent uses uint32_t instead of size_t
|
|
|
|
* [mod_webdav] large buffer reuse
|
|
|
|
* [mod_accesslog] flush file log buffer at 8k size
|
|
|
|
* [core] include settings.h where used
|
|
|
|
* [core] static buffers for mtime_cache
|
|
|
|
* [core] convenience macros to check req methods
|
|
|
|
* [core] support multiple error logs
|
|
|
|
* [multiple] omit passing srv to fdevent_handler
|
|
|
|
* [core] remove unused arg to fdevent_fcntl_set_nb*
|
|
|
|
* [core] slightly simpify server_(over)load_check()
|
|
|
|
* [core] isolate fdevent subsystem
|
|
|
|
* [core] isolate stat_cache subsystem
|
|
|
|
* [core] remove include base.h where unused
|
|
|
|
* [core] restart dead piped loggers every 64 sec
|
|
|
|
* [mod_webdav] use copy_file_range() if available
|
|
|
|
* [core] perf: buffer copy and append
|
|
|
|
* [core] copy some srv->srvconf into con->conf
|
|
|
|
* [core] move keep_alive flag into request_st
|
|
|
|
* [core] pass scheme port to http_request_parse()
|
|
|
|
* [core] pass http_parseopts around request.c
|
|
|
|
* [core] rename specific_config to request_config
|
|
|
|
* [core] move request_st,request_config to request.h
|
|
|
|
* [core] pass (request_st *) to request.c funcs
|
|
|
|
* [core] remove unused request_st member 'request'
|
|
|
|
* [core] rename content_length to reqbody_length
|
|
|
|
* [core] t/test_request.c using (request_st *)
|
|
|
|
* [core] (const connection *) in http_header_*_get()
|
|
|
|
* [mod_accesslog] log_access_record() fmt log record
|
|
|
|
* [core] move request start ts into (request_st *)
|
|
|
|
* [core] move addtl request-specific struct members
|
|
|
|
* [core] move addtl request-specific struct members
|
|
|
|
* [core] move plugin_ctx into (request_st *)
|
|
|
|
* [core] move addtl request-specific struct members
|
|
|
|
* [core] move request state into (request_st *)
|
|
|
|
* [core] store (plugin *) in p->data
|
|
|
|
* [core] store subrequest_handler instead of mode
|
|
|
|
* [multiple] copy small struct instead of memcpy()
|
|
|
|
* [multiple] split con, request (very large change)
|
|
|
|
* [core] r->uri.path always set, though might be ""
|
|
|
|
* [core] C99 restrict on some base funcs
|
|
|
|
* [tests] stub out config funcs in test_mod_*
|
|
|
|
* [tests] t/test_mod_userdir
|
|
|
|
* [core] dispatch handler in handle_request func
|
|
|
|
* [core] http_request_parse_target()
|
|
|
|
* [mod_magnet] modify r->target with "uri.path-raw"
|
|
|
|
* [core] remove r->uri.path_raw; generate as needed
|
|
|
|
* [core] http_response_comeback()
|
|
|
|
* [core] http_response_config()
|
|
|
|
* [tests] use buffer_eq_slen() for str comparison
|
|
|
|
* [core] http_status_append() short-circuit 200 OK
|
|
|
|
* [core] mark some chunk.c funcs as pure
|
|
|
|
* [core] use uint32_t in http_header.[ch]
|
|
|
|
* [core] perf: tighten some code in some hot paths
|
|
|
|
* [core] parse header label before end of line
|
|
|
|
* [doc] add link to wiki in doc/outdated/ssl.txt
|
|
|
|
* [doc] src/t/README
|
|
|
|
* [mod_auth] "nonce_secret" option to validate nonce (fixes #2976)
|
|
|
|
* [build] fix build on MacOS X Tiger
|
|
|
|
* [doc] lighttpd.conf: lighttpd choose event-handler
|
|
|
|
* [config] blank server.tag if whitespace-only
|
|
|
|
* [mod_proxy] stream request using HTTP/1.1 chunked (fixes #3006)
|
|
|
|
* [multiple] correct misspellings in comments
|
|
|
|
* [multiple] fix some cc warnings in 32-bit, powerpc
|
|
|
|
* [tests] fix skip count in mod-fastcgi w/o php-cgi
|
|
|
|
* [multiple] ./configure --with-nettle to use Nettle
|
|
|
|
* [core] skip excess close() when FD_CLOEXEC defined
|
|
|
|
* [mod_cgi] remove redundant calls to set FD_CLOEXEC
|
|
|
|
* [core] return EINVAL if stat_cache_get_entry w/o /
|
|
|
|
* [mod_webdav] define PATH_MAX if not defined
|
|
|
|
* [mod_accesslog] process backslash-escapes in fmt
|
|
|
|
* [mod_openssl] disable cert vrfy if ALPN acme-tls/1
|
|
|
|
* [core] add seed before openssl RAND_pseudo_bytes()
|
|
|
|
* [mod_mbedtls] mbedTLS option for TLS
|
|
|
|
* [core] prefer getxattr() instead of get_attr()
|
|
|
|
* [multiple] use *(unsigned char *) with ctypes
|
|
|
|
* [mod_openssl] do not log ECONNRESET unless debug
|
|
|
|
* [mod_openssl] SSL_R_UNEXPECTED_EOF_WHILE_READING
|
|
|
|
* [mod_gnutls] GnuTLS option for TLS (fixes #109)
|
|
|
|
* [mod_openssl] rotate session ticket encryption key
|
|
|
|
* [mod_openssl] set cert from callback in 1.0.2+ (fixes #2842)
|
|
|
|
* [mod_openssl] set chains from callback in 1.0.2+ (#2842)
|
|
|
|
* [core] RFC-strict parse of Content-Length
|
|
|
|
* [build] point ./configure --help to support forum
|
|
|
|
* [core] stricter parse of numerical digits
|
|
|
|
* [multiple] add summaries to top of some modules
|
|
|
|
* [core] sys-crypto-md.h w/ inline message digest fn
|
|
|
|
* [mod_openssl] enable read-ahead, if set, after SNI
|
|
|
|
* [mod_openssl] issue warning for deprecated options
|
|
|
|
* [mod_openssl] use SSL_OP_NO_RENEGOTIATION if avail
|
|
|
|
* [mod_openssl] use openssl feature define for ALPN
|
|
|
|
* [mod_openssl] update default DH params
|
|
|
|
* [core] SecureZeroMemory() on _WIN32
|
|
|
|
* [core] safe memset calls memset() through volatile
|
|
|
|
* [doc] update comments in doc/config/modules.conf
|
|
|
|
* [core] more precise check for request stream flags
|
|
|
|
* [mod_openssl] rotate session ticket encryption key
|
|
|
|
* [mod_openssl] ssl.stek-file to specify encrypt key
|
|
|
|
* [mod_mbedtls] ssl.stek-file to specify encrypt key
|
|
|
|
* [mod_gnutls] ssl.stek-file to specify encrypt key
|
|
|
|
* [mod_openssl] disable session cache; prefer ticket
|
|
|
|
* [mod_openssl] compat with LibreSSL
|
|
|
|
* [mod_openssl] compat with WolfSSL
|
|
|
|
* [mod_openssl] set SSL_OP_PRIORITIZE_CHACHA
|
|
|
|
* [mod_openssl] move SSL_CTX curve conf to new func
|
|
|
|
* [mod_openssl] basic SSL_CONF_cmd for alt TLS libs
|
|
|
|
* [mod_openssl] OCSP stapling (fixes #2469)
|
|
|
|
* [TLS] cert-staple.sh - refresh OCSP responses (#2469)
|
|
|
|
* [mod_openssl] compat with BoringSSL
|
|
|
|
* [mod_gnutls] option to override GnuTLS priority
|
|
|
|
* [mod_gnutls] OCSP stapling (#2469)
|
|
|
|
* [mod_extforward] config warning for module order
|
|
|
|
* [mod_webdav] store webdav.opts as bitflags
|
|
|
|
* [mod_webdav] limit webdav_propfind_dir() recursion
|
|
|
|
* [mod_webdav] unsafe-propfind-follow-symlink option
|
|
|
|
* [mod_webdav] webdav.opts "propfind-depth-infinity"
|
|
|
|
* [mod_openssl] detect certs marked OCSP Must-Staple
|
|
|
|
* [mod_gnutls] detect certs marked OCSP Must-Staple
|
|
|
|
* [mod_openssl] default to set MinProtocol TLSv1.2
|
|
|
|
* [mod_nss] NSS option for TLS (fixes #1218)
|
|
|
|
* [core] fdevent_load_file() shared code
|
|
|
|
* [mod_openssl,mbedtls,gnutls,nss] fdevent_load_file
|
|
|
|
* [core] error if s->socket_perms chmod() fails
|
|
|
|
* [mod_openssl] prefer some WolfSSL native APIs
|
|
|
|
* quiet clang analyzer scan-build warnings
|
|
|
|
* [core] uint32_t is plenty large for path names
|
|
|
|
* [mod_mysql_vhost] deprecated; use mod_vhostdb_mysql
|
|
|
|
* [core] splaytree_djbhash() in splaytree.h (reuse)
|
|
|
|
* [cmake] update deps for src/t/test_*
|
|
|
|
* [cmake] update deps for src/t/test_*
|
|
|
|
* [build] remove tests/mod-userdir.t from builds
|
|
|
|
* [build] fix typo in src/Makefile.am EXTRA_DIST
|
|
|
|
* [core] remove unused mbedtls_enabled flag
|
|
|
|
* [core] store fd in srv->stdin_fd during setup
|
|
|
|
* [multiple] address coverity warnings
|
|
|
|
* [mod_webdav] fix theoretical NULL dereference
|
|
|
|
* [mod_webdav] update rc for PROPFIND allprop
|
|
|
|
* [mod_webdav] build fix: ifdef live_properties
|
|
|
|
* [multiple] address coverity warnings
|
|
|
|
* [meson] fix libmariadb dependency
|
|
|
|
* [meson] add missing libmaxminddb section
|
|
|
|
* [mod_auth,mod_vhostdb] add caching option (fixes #2805)
|
|
|
|
* [mod_authn_ldap,mod_vhostdb_ldap] add timeout opt (#2805)
|
|
|
|
* [mod_auth] accept "nonce-secret" & "nonce_secret"
|
|
|
|
* [mod_openssl] fix build warnings on MacOS X
|
|
|
|
* [core] Nettle assert()s if buffer len > digest sz
|
|
|
|
* [mod_authn_dbi] authn backend employing DBI
|
|
|
|
* [mod_authn_mysql,file] use crypt() to save stack
|
|
|
|
* [mod_vhostdb_dbi] allow strings and ints in config
|
|
|
|
* add ci-build.sh
|
|
|
|
* move ci-build.sh to scripts
|
|
|
|
* [build] build fixes for AIX
|
|
|
|
* [mod_deflate] Brotli support
|
|
|
|
* [build] bzip2 default to not-enabled in build
|
|
|
|
* [mod_deflate] fix typo in config option
|
|
|
|
* [mod_deflate] propagate errs from internal funcs
|
|
|
|
* [mod_deflate] deflate.cache-dir compressed cache
|
|
|
|
* [mod_deflate] mod_deflate subsumes mod_compress
|
|
|
|
* [doc] mod_compress -> mod_deflate
|
|
|
|
* [tests] mod_compress -> mod_deflate
|
|
|
|
* [mod_compress] remove mod_compress
|
|
|
|
* [build] add --with-brotli to CI build
|
|
|
|
* [core] server.feature-flags extensible config
|
|
|
|
* [core] con layer plugin_ctx separate from request
|
|
|
|
* [multiple] con hooks store ctx in con->plugin_ctx
|
|
|
|
* [core] separate funcs to reset (request_st *)
|
|
|
|
* [multiple] rename connection_reset hook to request
|
|
|
|
* [mod_nss] func renames for consistency
|
|
|
|
* [core] detect and reject TLS connect to cleartext
|
|
|
|
* [mod_deflate] quicker check for Content-Encoding
|
|
|
|
* [mod_openssl] read secret data w/ BIO_new_mem_buf
|
|
|
|
* [core] decode Transfer-Encoding: chunked from gw
|
|
|
|
* [mod_fastcgi] decode Transfer-Encoding: chunked
|
|
|
|
* [core] stricter parsing of POST chunked block hdr
|
|
|
|
* [mod_proxy] send HTTP/1.1 requests to backends
|
|
|
|
* [tests] test_base64.c clear buf vs reset
|
|
|
|
* [core] http_header_remove_token()
|
|
|
|
* [mod_webdav] fix inadvertent string truncation
|
|
|
|
* [core] add some missing standard includes
|
|
|
|
* [mod_extforward] attempt to quiet Coverity warning
|
|
|
|
* [mod_authn_dbi,mod_authn_mysql] fix coverity issue
|
|
|
|
* [build] fix SCons build for detection of brotli
|
|
|
|
* [build] SCons build with brotli needs -lm on *BSD
|
|
|
|
* [build] SCons build mod_deflate w/ libm for brotli
|
|
|
|
* [build] SCons brotli needs pkg-config --static
|
|
|
|
* [build] avoid accept_filter_arg compiler warning
|
|
|
|
* [build] SCons fix space/tabs inconsistency
|
|
|
|
* scons: fix check environment
|
|
|
|
* Add avahi service file under doc/avahi/
|
|
|
|
* [mod_webdav] fix fallback if linkat() fails
|
|
|
|
* [mod_proxy] do not forward Expect: 100-continue
|
|
|
|
* [core] chunkqueue_compact_mem() must upd cq->last
|
|
|
|
* [core] dlsym for FAMNoExists() for compat w/ fam
|
|
|
|
* [core] disperse settings.h to appropriate headers
|
|
|
|
* [core] inline buffer_reset()
|
|
|
|
* [mod_extforward] save proto per connection
|
|
|
|
* [mod_extforward] skip after HANDLER_COMEBACK
|
|
|
|
* [core] server.feature-flags to enable h2
|
|
|
|
* [core] HTTP_VERSION_2
|
|
|
|
* [multiple] allow TLS ALPN "h2" if "server.h2proto"
|
|
|
|
* [mod_extforward] preserve changed addr for h2 con
|
|
|
|
* [core] do not send Connection: close if h2
|
|
|
|
* [core] lowercase response hdr field names for h2
|
|
|
|
* [core] recognize status: 421 Misdirected Request
|
|
|
|
* [core] parse h2 pseudo-headers
|
|
|
|
* [core] request_headers_process()
|
|
|
|
* [core] connection_state_machine_loop()
|
|
|
|
* [core] reset connection counters per connection
|
|
|
|
* [mod_accesslog,mod_rrdtool] HTTP/2 basic accounting
|
|
|
|
* [core] connection_set_fdevent_interest()
|
|
|
|
* [core] HTTP2-Settings
|
|
|
|
* [core] adjust http_request_headers_process()
|
|
|
|
* [core] http_header_parse_hoff()
|
|
|
|
* [core] move http_request_headers_process()
|
|
|
|
* [core] reqpool.[ch] for (request_st *)
|
|
|
|
* [multiple] modules read reqbody via fn ptr
|
|
|
|
* [multiple] isolate more con code in connections.c
|
|
|
|
* [core] isolate more resp code in response.c
|
|
|
|
* [core] h2.[ch] with stub funcs (incomplete)
|
|
|
|
* [core] alternate between two joblists
|
|
|
|
* [core] connection transition to HTTP/2; incomplete
|
|
|
|
* [core] mark some error paths with attribute cold
|
|
|
|
* [core] discard 100 102 103 responses from backend
|
|
|
|
* [core] skip write throttle for 100 Continue
|
|
|
|
* [core] adjust (disabled) debug code
|
|
|
|
* [core] update comment
|
|
|
|
* [core] link in ls-hpack (EXPERIMENTAL)
|
|
|
|
* [core] HTTP/2 HPACK using LiteSpeed ls-hpack
|
|
|
|
* [core] h2_send_headers() specialized for resp hdrs
|
|
|
|
* [core] http_request_parse_header() specialized
|
|
|
|
* [core] comment possible future ls-hpack optimize
|
|
|
|
* [mod_status] separate funcs to print request table
|
|
|
|
* [mod_status] adjust to print HTTP/2 requests
|
|
|
|
* [core] redirect to dir using relative-path
|
|
|
|
* [core] ignore empty field-name from backends
|
|
|
|
* [build] fix meson build
|
|
|
|
* [mod_auth] fix crash if auth.require misconfigured (fixes #3023)
|
|
|
|
* [core] fix 1-char trunc of default server.tag
|
|
|
|
* [core] request_acquire(), request_release()
|
|
|
|
* [core] keep pool of (request_st *) for HTTP/2
|
|
|
|
* [mod_status] dedicated funcs for r->state labels
|
|
|
|
* [core] move connections_get_state to connections.c
|
|
|
|
* [core] fix crash on master after graceful restart
|
|
|
|
* [core] defer optimization to read small files
|
|
|
|
* [core] do not require '\0' term for k,v hdr parse
|
|
|
|
* [scripts] cert-staple.sh enhancements
|
|
|
|
* [core] document algorithm used in lighttpd etag
|
|
|
|
* [core] ls-hpack optimizations
|
|
|
|
* [core] fix crash on master if blank line request
|
|
|
|
* [build] fix typo in option description for wolfSSL
|
|
|
|
* [core] use djbhash in gw_backend to choose host
|
|
|
|
* [core] rename md5.[ch] to algo_md5.[ch]
|
|
|
|
* [core] move djbhash(), dekhash() to algo_md.h
|
|
|
|
* [core] rename splaytree.[ch] to algo_splaytree.[ch]
|
|
|
|
* [core] import xxHash v0.8.0
|
|
|
|
* [build] modify build, includes for xxHash v0.8.0
|
|
|
|
* [build] remove ls-hpack/deps
|
|
|
|
* [core] xxhash no inline hints; let compiler choose
|
|
|
|
* [mod_dirlisting] fix config parsing crash
|
|
|
|
* [mod_openssl] clarify trace w/ deprecated options
|
|
|
|
* [doc] refresh doc/config/*/*
|
|
|
|
* [core] code size: disable XXH64(), XXH3()
|
|
|
|
* [doc] update README and INSTALL
|
|
|
|
* [build] add to autogen.sh hint listing reqd pkgs
|
|
|
|
* [core] combine Cookie request headers with ';'
|
|
|
|
* [core] log stream id with debug.log-state-handling
|
|
|
|
* [core] set r->state in h2.c
|
|
|
|
* [mod_ssi] update chunk after shell output redirect
|
|
|
|
* [mod_webdav] preserve bytes_out when chunks merged
|
|
|
|
* [multiple] inline chunkqueue_length()
|
|
|
|
* [core] cold h2_log_response_header*() funcs
|
|
|
|
* [core] update HTTP status codes list from IANA
|
|
|
|
* [mod_wolfssl] standalone module
|
|
|
|
* [core] Content-Length in http_response_send_file()
|
|
|
|
* [core] adjust response header prep for common case
|
|
|
|
* [core] light_isupper(), light_islower()
|
|
|
|
* [core] tst,set,clr macros for r->{rqst,resp}_htags
|
|
|
|
* [core] separate http_header_e from _htags bitmask
|
|
|
|
* [core] http_header_hkey_get_lc() for HTTP/2
|
|
|
|
* [core] array.[ch] using uint32_t instead of size_t
|
|
|
|
* [core] extend (data_string *) to store header id
|
|
|
|
* [multiple] extend enum http_header_e list
|
|
|
|
* [core] http_header_e <=> lshpack_static_hdr_idx
|
|
|
|
* [core] skip ls-hpack decode work unused by lighttpd
|
|
|
|
* [TLS] error if inherit empty TLS cfg from globals
|
|
|
|
* [core] connection_check_expect_100()
|
|
|
|
* [core] support multiple 1xx responses from backend
|
|
|
|
* [core] reload c after chunkqueue_compact_mem()
|
|
|
|
* [core] relay 1xx from backend over HTTP/2
|
|
|
|
* [core] relay 1xx from backend over HTTP/1.1
|
|
|
|
* [core] chunkqueue_{peek,read}_data(), squash
|
|
|
|
* [multiple] TLS modules use chunkqueue_peek_data()
|
|
|
|
* [mod_magnet] magnet.attract-response-start-to
|
|
|
|
* [multiple] code reuse chunkqueue_peek_data()
|
|
|
|
* [core] reuse r->start_hp.tv_sec for r->start_ts
|
|
|
|
* [core] config_plugin_value_tobool() accept "0","1"
|
|
|
|
* [core] graceful and immediate restart option
|
|
|
|
* [mod_ssi] init status var before waitpid()
|
|
|
|
* [core] graceful shutdown timeout option
|
|
|
|
* [core] lighttpd -1 supports pipes (e.g. netcat)
|
|
|
|
* [core] perf adjustments to avoid load miss
|
|
|
|
* [multiple] use sock_addr_get_family in more places
|
|
|
|
* [multiple] inline chunkqueue where always alloc'd
|
|
|
|
* [core] propagate state after writing
|
|
|
|
* [core] server_run_con_queue()
|
|
|
|
* [core] defer handling FDEVENT_HUP and FDEVENT_ERR
|
|
|
|
* [core] handle unexpected EOF reading FILE_CHUNK
|
|
|
|
* [core] short-circuit connection_write_throttle()
|
|
|
|
* [core] walk queue in connection_write_chunkqueue()
|
|
|
|
* [core] connection_joblist global
|
|
|
|
* [core] be more precise checking streaming flags
|
|
|
|
* [core] fdevent_load_file_bytes()
|
|
|
|
* [TLS] use fdevent_load_file_bytes() for STEK file
|
|
|
|
* [core] allow symlinks under /dev for rand devices
|
|
|
|
* [multiple] use light_btst() for hdr existence chk
|
|
|
|
* [mod_deflate] fix potential NULL deref in err case
|
|
|
|
* [core] save errno around close() if fstat() fails
|
|
|
|
* [mod_ssi] use stat_cache_open_rdonly_fstat()
|
|
|
|
* [core] fdevent_dup_cloexec()
|
|
|
|
* [core] dup FILE_CHUNK fd when splitting FILE_CHUNK
|
|
|
|
* [core] stat_cache_path_isdir()
|
|
|
|
* [multiple] use stat_cache_path_isdir()
|
|
|
|
* [mod_mbedtls] quiet CLOSE_NOTIFY after conn reset
|
|
|
|
* [mod_gnutls] quiet CLOSE_NOTIFY after conn reset
|
|
|
|
* [core] limit num ranges in Range requests
|
|
|
|
* [core] remove unused r->content_length
|
|
|
|
* [core] http_response_parse_range() const file sz
|
|
|
|
* [core] pass open fd to http_response_parse_range
|
|
|
|
* [core] stat_cache_get_entry_open()
|
|
|
|
* [core,mod_deflate] leverage cache of open fd
|
|
|
|
* [doc] comment out config disabling Range for .pdf
|
|
|
|
* [core] coalesce nearby ranges in Range requests
|
|
|
|
* [tests] simulate slow, small packets more quickly
|
|
|
|
* [mod_fastcgi] decode chunked is cold code path
|
|
|
|
* [core] fix chunkqueue_compact_mem w/ partial chunk
|
|
|
|
* [core] alloc optim reading file, sending chunked
|
|
|
|
* [core] reuse chunkqueue_compact_mem*()
|
|
|
|
* [mod_cgi] use splice() to send input to CGI
|
|
|
|
* [multiple] ignore openssl 3.0.0 deprecation warns
|
|
|
|
* [mod_openssl] migrate ticket cb to openssl 3.0.0
|
|
|
|
* [mod_openssl] construct OSSL_PARAM on stack
|
|
|
|
* [mod_openssl] merge ssl_tlsext_ticket_key_cb impls
|
|
|
|
* [multiple] openssl 3.0.0 digest interface migrate
|
|
|
|
* [tests] detect multiple SSL/TLS/crypto providers
|
|
|
|
* [core] sys-crypto-md.h consistent interfaces
|
|
|
|
* [wolfssl] wolfSSL_CTX_set_mode differs from others
|
|
|
|
* [multiple] use NSS crypto if no other crypto avail
|
|
|
|
* [multiple] stat_cache_path_stat() for struct st
|
|
|
|
* [TLS] ignore empty "CipherString" in ssl-conf-cmd
|
|
|
|
* [multiple] remove chunk file.start member
|
|
|
|
* [core] modify use of getrlimit() to not be fatal
|
|
|
|
* [mod_webdav] add missing update to cq accounting
|
|
|
|
* [mod_webdav] update defaults after worker_init
|
|
|
|
* [mod_openssl] use newer openssl 3.0.0 func
|
|
|
|
* [core] config_plugin_value_to_int32()
|
|
|
|
* [core] minimize pause during graceful restart
|
|
|
|
* [mod_deflate] use large mmap chunks to compress
|
|
|
|
* [core] stat_cache_entry reference counting
|
|
|
|
* [core] FILE_CHUNK can hold stat_cache_entry ref
|
|
|
|
* [core] http_chunk_append_file_ref_range()
|
|
|
|
* [multiple] use http_chunk_append_file_ref()
|
|
|
|
* [core] always lseek() with shared fd
|
|
|
|
* [core] silence coverity warnings (false positives)
|
|
|
|
* [core] silence coverity warnings in ls-hpack
|
|
|
|
* [core] silence coverity warnings (another try)
|
|
|
|
* [core] fix fd sharing when splitting file chunk
|
|
|
|
* [mod_mbedtls] quiet unused variable warning
|
|
|
|
* [core] use inline funcs in sys-crypto-md.h
|
|
|
|
* [core] add missing declaration for NSS rand
|
|
|
|
* [core] init NSS lib for basic crypto algorithms
|
|
|
|
* [doc] change mod_compress refs to mod_deflate
|
|
|
|
* [doc] replace bzip2 refs with brotli
|
|
|
|
* [build] remove svnversion from versionstamp rule
|
|
|
|
* [doc] /var/run -> /run
|
|
|
|
* [multiple] test for nss includes
|
|
|
|
* [mod_nss] more nss includes fixes
|
|
|
|
* [build] more portable autogen.sh shell script
|
|
|
|
* [mod_webdav] define _NETBSD_SOURCE on NetBSD
|
|
|
|
* [core] silence coverity warnings (another try)
|
|
|
|
* [mod_mbedtls] newer mbedTLS vers support TLSv1.3
|
|
|
|
* [mod_accesslog] update defaults after cycling log
|
|
|
|
* [multiple] add some missing config cleanup
|
|
|
|
* [core] fix (startup) mem leaks in configparser.y
|
2020-11-29 21:31:14 +00:00
|
|
|
* [core] STAILQ_* -> SIMPLEQ_* on OpenBSD
|
|
|
|
* [tests] OpenBSD crypt() support limited to bcrypt
|
|
|
|
* [build] mark dependencies on crypto lib for MD5()
|
|
|
|
* [build] use pkg-config with wolfssl
|
|
|
|
* [mod_wolfssl] use more wolfssl/options.h defines
|
|
|
|
* [mod_wolfssl] cripple SNI if not built OPENSSL_ALL
|
|
|
|
* [mod_wolfssl] need to build --enable-alpn for ALPN
|
|
|
|
* [mod_secdownload] fix compile w/ NSS on FreeBSD
|
|
|
|
* [build] fix lib paths for GnuTLS, NSS
|
|
|
|
* [build] add --with-brotli to meson.build
|
|
|
|
* [build] CMake mod_openssl, mod_wolfssl can coexist
|
|
|
|
* [build] CMake use pkg_check_modules() w/ wolfssl
|
|
|
|
* [build] detect nss3/nss.h or nss/nss.h for NSS
|
|
|
|
* [build] WITHOUT_LIB_CRYPTO option in code
|
|
|
|
* [build] adjust meson.build for use by OpenWRT
|
|
|
|
* [mod_mbedtls] wrap addtl code in preproc defines
|
|
|
|
* [TLS] server.feature-flags "ssl.session-cache"
|
|
|
|
* [core] workaround fragile code in wolfssl types.h
|
|
|
|
* [core] move misplaced error trace to match option
|
|
|
|
* [core] adjust wolfssl workaround for another case
|
|
|
|
* [multiple] consistent order for crypto lib select
|
|
|
|
* [multiple] include mbedtls/config.h after select
|
|
|
|
* [multiple] include wolfssl/options.h after select
|
|
|
|
* [core] set NSS_VER_INCLUDE after crypto lib select
|
|
|
|
* [core] use system xxhash lib if available
|
|
|
|
* [build] fix typo in configure.ac
|
|
|
|
* [build] option to use system-provided libxxhash
|
|
|
|
* [build] meson --with-xxhash option
|
|
|
|
* [doc] refresh doc/config/conf.d/mime.conf
|
|
|
|
* [meson] add matching -I for lua lib version
|
|
|
|
* [build] prepend search for lua version 5.4
|
|
|
|
* [core] use inotify in stat_cache.[ch] on Linux
|
|
|
|
* [build] detect inotify header <sys/inotify.h>
|
|
|
|
* [mod_nss] update session ticket NSS devel comment
|
|
|
|
* [core] set last_used on rd/wr from backend (fixes #3029)
|
|
|
|
* [core] cold func for gw_recv_response error case
|
|
|
|
* [core] use kqueue() instead of FAM/gamin on *BSD
|
|
|
|
* [core] no graceful-restart-bg on OpenBSD, NetBSD
|
|
|
|
* [mod_openssl] add LIBRESSL_VERSION_NUMBER checks
|
|
|
|
* [core] use struct kevent on stack in stat_cache
|
|
|
|
* [core] stat_cache preprocessor paranoia
|
|
|
|
* [mod_openssl] adjust LIBRESSL_VERSION_NUMBER check
|
|
|
|
* [mod_maxminddb] fix config validation typo
|
|
|
|
* [tests] allow LIGHTTPD_EXE_PATH override
|
|
|
|
* [multiple] handle NULL val as empty in *_env_add (fixes #3030)
|
|
|
|
* [core] accept "HTTP/2.0", "HTTP/3.0" from backends (fixes #3031)
|
|
|
|
* [build] check for xxhash in more ways
|
|
|
|
* [core] accept "HTTP/2.0", "HTTP/3.0" from backends (#3031)
|
|
|
|
* [core] http_response_buffer_append_authority()
|
|
|
|
* [core] define SHA*_DIGEST_LENGTH macros if missing
|
|
|
|
* [doc] update optional pkg dependencies in INSTALL
|
|
|
|
* [mod_alias] validate given order, not sorted order
|
|
|
|
* [core] filter out duplicate modules
|
|
|
|
* [mod_cgi] fix crash if initial write to CGI fails
|
|
|
|
* [mod_cgi] ensure tmp file open() before splice()
|
|
|
|
* [multiple] add back-pressure gw data pump (fixes #3033)
|
|
|
|
* [core] fix bug when HTTP/2 frames span chunks
|
|
|
|
* [multiple] more forgiving config str to boolean (fixes #3036)
|
|
|
|
* [core] check for __builtin_expect() availability
|
|
|
|
* [core] quiet more request parse errs unless debug
|
|
|
|
* [core] consolidate chunk size checks
|
|
|
|
* [mod_flv_streaming] use stat_cache_get_entry_open
|
|
|
|
* [mod_webdav] pass full path to webdav_unlinkat()
|
|
|
|
* [mod_webdav] fallbacks if _ATFILE_SOURCE not avail
|
|
|
|
* [mod_fastcgi] move src/fastcgi.h into src/compat/
|
|
|
|
* [mod_status] add additional HTML-encoding
|
|
|
|
* [core] server.v4mapped option
|
|
|
|
* [mod_webdav] workaround for gvfs dir redir bug
|
2020-10-25 19:47:31 +00:00
|
|
|
|
2020-02-01 02:46:34 +00:00
|
|
|
- 1.4.55 - 2020-01-31
|
|
|
|
* [core] fix compile error on Solaris (fixes #2959)
|
|
|
|
* [core] __attribute_pure__
|
|
|
|
* [core] array-specialized buffer_caseless_compare()
|
|
|
|
* [core] specialized buffer_eq_*() for short strings
|
|
|
|
* [core] mark some more funcs w/ __attribute_pure__
|
|
|
|
* [core] use buffer_eq_icase* funcs
|
|
|
|
* [multiple] replace strcasecmp() on short strings
|
|
|
|
* [core] mark some more funcs w/ __attribute_pure__
|
|
|
|
* [mod_webdav] fix startup crash w/ multiple conds (fixes #2958)
|
|
|
|
* [core] cold func http_response_omit_header()
|
|
|
|
* [core] use buffer_eq_icase_ssn func
|
|
|
|
* [core] use buffer_eq_icase_ssn func
|
|
|
|
* [core] correct __attribute_pure__ syntax
|
|
|
|
* [core] allocate unix socket paths with SUN_LEN()+1 (fixes #2962)
|
|
|
|
* Use explicit_memset from NetBSD if available for safe_memclear (fixes #2971)
|
|
|
|
* Also use explicit_memset (NetBSD) with cmake, scons and meson
|
|
|
|
* [cmake]: enable CMAKE_POSITION_INDEPENDENT_CODE by default
|
|
|
|
* [core] improve http_headers[] data struct packing
|
|
|
|
* [core] fdevent_poll() is effective periodic timer
|
|
|
|
* [core] move con state handling to connections*.c
|
|
|
|
* [core] issue config error for invalid ':' (fixes #2980)
|
|
|
|
* [mod_deflate] fix choose encoding parse error (fixes #2981)
|
|
|
|
* [core] retry on some fdevent set/del temporary err
|
|
|
|
* [core] disable stat_cache FAM if FAM conn closed
|
|
|
|
* [mod_auth] http_auth_const_time_memeq improvement
|
|
|
|
* [build] prefer pkg-config for postgres (fixes #2965)
|
|
|
|
* [mod_authn_gssapi] 500 if fail to delegate creds (#2967)
|
|
|
|
* [mod_authn_gssapi] option to store delegated creds (fixes #2967)
|
|
|
|
* [mod_webdav] fix file uploads > 128M (fixes #2970)
|
|
|
|
* [mod_auth] do not use quoted-string for algorithm
|
|
|
|
* [mod_auth] require digest uri= match original URI
|
|
|
|
* [mod_auth] Authentication-Info: nextnonce=...
|
|
|
|
* [mod_auth] http_auth_const_time_memeq_pad()
|
|
|
|
* [mod_auth] http_auth_const_time_memeq() (#2975, #2976)
|
|
|
|
* [build] PGSQL_CFLAGS with pkg-config for postgres (#2965)
|
|
|
|
* [build] PGSQL_CFLAGS with pkg-config for postgres (#2965)
|
|
|
|
* [core] avoid freeaddrinfo() on NULL ptr (fixes #2984)
|
|
|
|
* [core] reject WS following header field-name (fixes #2985)
|
|
|
|
* [core] reject Transfer-Encoding + Content-Length (#2985)
|
|
|
|
* [mod_openssl] reject invalid ALPN
|
|
|
|
* [mod_accesslog] parse multiple cookies (fixes #2986)
|
|
|
|
* [core] Oracle Solaris does not have POLLRDHUP
|
|
|
|
* [multiple] address coverity warnings
|
|
|
|
* [core] preserve %2b and %2B in query string (fixes #2999)
|
|
|
|
* [core] fall back to accept() if accept4() EPERM (fixes #2998)
|
|
|
|
* [mod_auth] close connection after bad password
|
|
|
|
* [core] do not accept() > server.max-connections
|
|
|
|
* [core] save errno before logging if execve() fails
|
|
|
|
* [config] update /var/run -> /run for systemd
|
|
|
|
* [core] Solaris has getloadavg in sys/loadavg.h
|
|
|
|
* [build] Fix build when using nested CMake
|
|
|
|
* [core] fix one-byte OOB read (underflow)
|
|
|
|
|
2019-05-27 12:53:03 +00:00
|
|
|
- 1.4.54 - 2019-05-27
|
|
|
|
* [mod_evhost] handle IPv6 literal addr; add tests
|
|
|
|
* [core] separate server_main_loop() func, mark hot
|
|
|
|
* [core] mark startup/shutdown funcs cold
|
|
|
|
* [core] some server_main_loop() cleanup
|
|
|
|
* [core] fdevent_process()
|
|
|
|
* [core] srv->max_fds_lowat and srv->max_fds_hiwat
|
|
|
|
* [core] remove server.h
|
|
|
|
* [mod_staticfile] search ext array if not empty
|
|
|
|
* [core] store joblist pointer on stack
|
|
|
|
* [core] quickly clear request buffer for reuse
|
|
|
|
* [core] helper funcs for connection_state_machine()
|
|
|
|
* [core] perf: optimize connection_read_header()
|
|
|
|
* [core] parse request in connection_read_header()
|
|
|
|
* [core] log_request_header_on_error in one place
|
|
|
|
* [core] copy request only if might need for logging
|
|
|
|
* [core] make parse_request,request.request same buf
|
|
|
|
* [core] prefer buffer_caseless_compare()
|
|
|
|
* [core] pass req hdrs buffer to http_request_parse
|
|
|
|
* [core] replace con->response.keep_alive
|
|
|
|
* [core] mark log_error_write*() funcs cold
|
|
|
|
* [core] http_request_parse() mark error paths cold
|
|
|
|
* [core] lift code out of request line parse loop
|
|
|
|
* [core] get_http_method_key() match by strlen first
|
|
|
|
* [core] RFC7230 HTTP-version parse
|
|
|
|
* [mod_accesslog] attempt to reconstruct req line
|
|
|
|
* [multiple] minor: remove duplicated conditions
|
|
|
|
* [mod_deflate] honor request for x-gzip, x-bzip2
|
|
|
|
* [mod_auth] minor: adjust config validation
|
|
|
|
* [core] discard oversized trailers
|
|
|
|
* [core] no keep-alive if POLLRDHUP,empty read queue
|
|
|
|
* [core] fix gw_backend spelling of directive in err
|
|
|
|
* [multiple] reduce code dup in list resizing
|
|
|
|
* [core] con->is_ssl_sock
|
|
|
|
* [core] connection_handle_write() updates con state
|
|
|
|
* [core] skip plugins_call_cleanup if not init'ed
|
|
|
|
* [core] simpler loops to run plugin hooks
|
|
|
|
* [core] fix mixed use of srv->split_vals array (fixes #2932)
|
|
|
|
* [core] dispatch events from within event framework
|
|
|
|
* [core] don't call fd event handlers more than once, they might already be gone (fixes segfault)
|
|
|
|
* [core] poll: fdarray uses fd as index, not fde_ndx
|
|
|
|
* [core] map FDEVENT_* to OS system event frameworks
|
|
|
|
* [core] prefer memchr() over strchr()
|
|
|
|
* [core] use openssl to read,discard request body
|
|
|
|
* [mod_openssl] inherit cipherlist from global scope
|
|
|
|
* [mod_openssl] default: ssl.cipher-list = "HIGH"
|
|
|
|
* [mod_proxy] pass Content-Length to backend if > 0
|
|
|
|
* [core] config option to allow GET w/ request body
|
|
|
|
* [core] some fdevent code streamlining
|
|
|
|
* [core] remove fde_ndx member outside fdevents
|
|
|
|
* [core] remove redundant check for allow_http11
|
|
|
|
* [mod_openssl] use 16k static buffer instead of 64k
|
|
|
|
* [core] pull server load checks out of main loop
|
|
|
|
* [core] isolate fdevent processing
|
|
|
|
* [core] release empty chunk buf when nothing read
|
|
|
|
* [core] perf: pass (fdnode *) to epoll and kqueue
|
|
|
|
* [core] modify config parser to handle multiple }
|
|
|
|
* [core] pass (fdnode *) for registered fdevent fd
|
|
|
|
* [mod_auth] http_auth_digest_hex2bin()
|
|
|
|
* [mod_auth] http_auth_info_t digest abstraction
|
|
|
|
* [mod_auth] pass http_auth_require_t for 401 Unauth
|
|
|
|
* [core] no SOCK_NONBLOCK on QNX 7.0
|
|
|
|
* [mod_auth] HTTP Auth Digest algorithm=SHA-256
|
|
|
|
* [core] silence coverity warning
|
|
|
|
* [mod_magnet] fix invalid script return-type crash (fixes #2938)
|
|
|
|
* [build] remove -Wdeclaration-after-statement
|
|
|
|
* [core] pass conf.follow_symlink in more places
|
|
|
|
* [core] fix assertion with server.error-handler (fixes #2941)
|
|
|
|
* [core] extend dir redirection to take HTTP status
|
|
|
|
* [doc] minor adjust create-mime.conf.pl regex match (#2942)
|
|
|
|
* [core] __attribute__((fallthrough)) for GCC 7.0
|
|
|
|
* [core] fdevent_mkstemp_append() (shared)
|
|
|
|
* [core] off_t upload_temp_file_size
|
|
|
|
* [core] clear FDEVENT_RDHUP if no POLLRDHUP
|
|
|
|
* [mod_wstunnel] fix ping-interval for big-endian (fixes #2944)
|
|
|
|
* [core] fix abort in http-parseopts (fixes #2945)
|
|
|
|
* [core] remove repeated slashes in http-parseopts
|
|
|
|
* [core] fix 1.4.52 regression in mem use with POST (fixes #2948)
|
|
|
|
* [multiple] cleaner calloc use in SETDEFAULTS_FUNC
|
|
|
|
* [core] add const to some etag prototypes
|
|
|
|
* [core] __attribute__((format ...))
|
|
|
|
* [core] struct log_error_st for error logging
|
|
|
|
* [core] log_error, log_perror using printf-like fmt
|
|
|
|
* [core] new worker_init hook to follow parent fork
|
|
|
|
* [core] replace open() with fdevent_open_cloexec()
|
|
|
|
* [mod_webdav] major rewrite (fixes #1818)
|
|
|
|
* [core] 200 for OPTIONS /non-existent/path HTTP/1.1 (fixes #2939)
|
|
|
|
* [mod_webdav] surround Lock-Token with "<...>"
|
|
|
|
* [mod_webdav] fix uuid detection macro
|
|
|
|
* [mod_webdav] fix misbehavior on blank nodes in PROPPATCH
|
|
|
|
* [mod_webdav] clean up resources after do{}while(0)
|
|
|
|
* [mod_webdav] check If-Match, If-Unmodified-Since (#1818)
|
|
|
|
* [mod_webdav] deprecated unsafe partial PUT compat
|
|
|
|
* [mod_webdav] provide ETag in more responses
|
|
|
|
* [mod_webdav] platform portability fixes
|
|
|
|
* [mod_webdav] disable elftc_copyfile() on FreeBSD
|
|
|
|
* [mod_webdav] special-case If: (<DAV:no-lock>)
|
|
|
|
* [mod_webdav] check If-None-Match (#1818)
|
|
|
|
* [stat_cache] separate func for symlink policy chk
|
|
|
|
* [stat_cache] separate symlink pol from data struct
|
|
|
|
* [stat_cache] store entries without trailing slash
|
|
|
|
* [stat_cache] pass age param for stat cache cleanup
|
|
|
|
* [stat_cache] remove splaytree ins/del debug code
|
|
|
|
* [stat_cache] FAM: reduce string copying
|
|
|
|
* [stat_cache] FAM: check FAMNextEvent() return code
|
|
|
|
* [stat_cache] FAM: use entry hash index as userdata
|
|
|
|
* [stat_cache] FAM: improve handling modified file
|
|
|
|
* [stat_cache] FAM: ignore follow-symlink config
|
|
|
|
* [stat_cache] FAM: check hash collision before add
|
|
|
|
* [stat_cache] FAM: ignore event with no valid match
|
|
|
|
* [stat_cache] FAM: funcs to invalidate entries
|
|
|
|
* [stat_cache] interfaces to invalidate entries
|
|
|
|
* [mod_webdav] update stat_cache after file mod
|
|
|
|
* [core] use high precision stat timestamp in etag
|
|
|
|
* [scons] adjustment for static build under CentOS
|
|
|
|
* [core] emit trace using path before clearing path
|
|
|
|
* [core] http_chunk_append_file_fd()
|
|
|
|
* [multiple] open target file earlier in some cases
|
|
|
|
* [stat_cache] no longer stat() and open() for stat
|
|
|
|
* [stat_cache] FAM: improve monitoring, cache 16 sec
|
|
|
|
* [stat_cache] FAM: separate routine for FDEVENT_IN
|
|
|
|
* [stat_cache] FAM: whitespace-only change
|
|
|
|
* [mod_webdav] quiet coverity warnings
|
|
|
|
* [doc] highlight relevance of module load order (fixes #2946)
|
|
|
|
* [core] behavior change: stricter URL normalization
|
|
|
|
* [stat_cache] fix compilation error for cmake
|
|
|
|
* [cmake] help cmake on FreeBSD find sys/event.h
|
|
|
|
* [scons] help scons on FreeBSD find sys/event.h
|
|
|
|
* [build] detect FreeBSD elftc_copyfile()
|
|
|
|
* [mod_openssl] use SSL_CTX_set_client_hello_cb()
|
|
|
|
* [core] support weak etags with If-None-Match
|
|
|
|
* [core] store log_state_handling flag on stack
|
|
|
|
* [core] check if splay_tree NULL before invalidate
|
|
|
|
* [mod_webdav] workaround Microsoft-WebDAV-MiniRedir
|
|
|
|
* [mod_webdav] doc Microsoft-WebDAV-MiniRedir bugs
|
|
|
|
* [mod_webdav] invalidate parent dir in stat_cache
|
|
|
|
* [doc] systemd socket activation config example
|
|
|
|
* [core] chunkqueue perf: code reuse
|
|
|
|
* [core] chunkqueue perf: specialized buffer.h funcs
|
|
|
|
* [core] chunkqueue perf: skip opening 0-length file
|
|
|
|
* [core] chunkqueue perf: read small files into mem
|
|
|
|
* [core] buffer_reset() should not be passed NULL
|
|
|
|
* [tests] has_feature() helper func
|
|
|
|
* [tests] skip mod-secdownload HMAC-SHA1,HMAC-SHA256
|
|
|
|
* [core] use high precision stat timestamp on OS X
|
|
|
|
* [mod_magnet] expose server addr (local IP) to lua
|
|
|
|
* [core] adjust http_chunk read() retry loop
|
|
|
|
* [mod_maxminddb] MaxMind GeoIP2 support
|
|
|
|
* [mod_authn_ldap] ldap_set_option LDAP_OPT_RESTART (fixes #2940)
|
|
|
|
|
2019-01-27 04:58:59 +00:00
|
|
|
- 1.4.53 - 2019-01-27
|
|
|
|
* [mod_cml,mod_flv_streaming] fix NULL ptr deref
|
|
|
|
* [mod_simple_vhost] t/test_mod_simple_vhost
|
|
|
|
* [mod_evhost] split uri handler func for testing
|
|
|
|
* [mod_evhost] restructure for unit tests
|
|
|
|
* [mod_evhost] t/test_mod_evhost
|
|
|
|
* [mod_access] restructure for unit tests
|
|
|
|
* [mod_access] t/test_mod_access
|
|
|
|
* [tests] include first.h and NDEBUG early
|
|
|
|
* [core] use kill_signal for gw_proc_kill()
|
|
|
|
* [tests] t/test_keyvalue
|
|
|
|
* [tests] some test config cleanup
|
|
|
|
* [tests] update skip count in mod-fastcgi.t
|
|
|
|
* [multiple] reduce initial buffer sz if large POST (fixes #2922)
|
|
|
|
* [mod_fastcgi] fix NULL ptr deref from bugfix #2922 (fixes #2923)
|
|
|
|
* [tests] more test config cleanup
|
|
|
|
* [core] perf: incremental hash of pathname w/o copy
|
|
|
|
* [core] perf: reuse buffer to redirect to directory
|
|
|
|
* [core] do not free() reused buffer
|
|
|
|
* [core] use connected sock port in dir redirect
|
|
|
|
* [core] http_response_buffer_append_authority()
|
|
|
|
* [core] use con->server_name for dir redir
|
|
|
|
* [core] memeq compare rounded to 64, not next 1M
|
|
|
|
* [core] define MD5_DIGEST_LENGTH 16
|
|
|
|
* [mod_auth] permit additional auth backends to load
|
|
|
|
* [core] send Connection: close if reqbody not read (fixes #2924)
|
|
|
|
* [core] cache rev DNS for localhost for dir redir
|
|
|
|
* [doc/conf] resolve some mime type conflicts from debian buster, regenerate mime.conf
|
|
|
|
* [core] move winsock init to network_init()
|
|
|
|
* [core] move /dev/stdin graceful restart handling
|
|
|
|
* [core] network_srv_sockets_append() shared code
|
|
|
|
* [core] systemd socket activation support
|
|
|
|
* [build] autotools: try mysqlclient.pc and mariadb.pc (fixes #2925)
|
|
|
|
* [mod_expire] look up expire fallback "" explicitly
|
|
|
|
* [multiple] calloc match ptr type (clang --analyze)
|
|
|
|
* [multiple] quiet clang --analyze where trivial
|
|
|
|
* [mod_webdav] compare COPY, MOVE Destination scheme
|
|
|
|
* [core] con->uri.scheme is maintained lowercase
|
|
|
|
* [mod_openssl] ALPN and acme-tls/1 (fixes #2931)
|
|
|
|
* [core] Fix recursive include_shell invocations
|
|
|
|
* [mod_openssl] ssl.privkey directive (optional)
|
|
|
|
|
2018-11-29 03:36:43 +00:00
|
|
|
- 1.4.52 - 2018-11-28
|
|
|
|
* [mysql] MySQL 8 deprecates my_bool
|
|
|
|
* [core] typo in trace
|
|
|
|
* [build] Fix unportable test(1) operator
|
|
|
|
* [core] perf: call connection_reset() fewer times
|
|
|
|
* [core] perf: array_reset_data_strings()
|
|
|
|
* [core] perf: buffer_free_ptr() __attribute__ cold
|
|
|
|
* [core] perf: one-element cache for host normalize
|
|
|
|
* [core] perf: buffer_copy_string_len()
|
|
|
|
* [core] perf: skip redundant prepare copy calls
|
|
|
|
* [core] perf: buffer_align_size() identity if align
|
|
|
|
* [core] perf: size write buffers for reuse
|
|
|
|
* [core] perf: prepend headers directly into write q
|
|
|
|
* [core] perf: copy small strings; better buf reuse
|
|
|
|
* [core] perf: copy small strings; extend last chunk
|
|
|
|
* [core] perf: specialized func for array sorting
|
|
|
|
* [core] perf: append response directly into write q
|
|
|
|
* [core] perf: better buf reuse reading from backend
|
|
|
|
* [core] chunk.c code reuse
|
|
|
|
* [multiple] perf: write headers to backend write cq
|
|
|
|
* [multiple] perf: power-2 alloc large headers
|
|
|
|
* [multiple] perf: use larger initial backend buffer
|
|
|
|
* [core] permit env vars to be set with blank value
|
|
|
|
* [mod_fastcgi] perf: reduce data copies
|
|
|
|
* [mod_fastcgi] perf: reduce data copies
|
|
|
|
* [core] perf: chunk.c chunk pool
|
|
|
|
* [multiple] perf: reuse large buffers w/ backend
|
|
|
|
* [multiple] better packing of struct chunk
|
|
|
|
* [core] perf: inline buffer_append_string_buffer()
|
|
|
|
* [core] slightly simpler flag append to string
|
|
|
|
* [mod_cgi] perf: reuse buffers for creating CGI env
|
|
|
|
* [mod_fastcgi,mod_scgi] perf: env accumulation
|
|
|
|
* [core] Don't call RAND_cleanup with OpenSSL 1.1.x
|
|
|
|
* [mod_openssl] move SSL_shutdown() to separate func
|
|
|
|
* [mod_openssl] SSL_read before second SSL_shutdown
|
|
|
|
* [mod_cgi] perf: use stat_cache for cgi handler
|
|
|
|
* [mod_openssl] prefer using TLS_server_method()
|
|
|
|
* [mod_webdav] return 403 if file should exist
|
|
|
|
* [core] perf: chunkqueue buffers already sized up
|
|
|
|
* [core] perf: simpler buffer_string_space()
|
|
|
|
* [multiple] dynamic handlers hint backend header sz
|
|
|
|
* [core] use chunk_buf_sz instead of hard-coded num
|
|
|
|
* [multiple] perf: simplify chunkqueue_get_memory()
|
|
|
|
* [mod_wstunnel] perf: reuse large buffers
|
|
|
|
* [mod_cgi] perf: cache getenv() results at start up
|
|
|
|
* [core] fix 301 -> 302 overwrite with Location (fixes #2918)
|
|
|
|
* [core] fix setting of headers previously reset (fixes #2919)
|
|
|
|
* [mod_webdav] quiet coverity false positive
|
|
|
|
* [core] server.compat-module-load = "disable"
|
|
|
|
* [core] server.chunkqueue-chunk-sz = 4096
|
|
|
|
* [core] perf: simpler buffer_string_space() (fixed)
|
|
|
|
* [core] perf: faster HTTP pipelined requests
|
|
|
|
* [core] perf: simpler buffer_string_space() (tests)
|
|
|
|
* [mod_cgi] reset reused buffer on internal redir
|
|
|
|
* [core] clear chunk buffer upon release
|
|
|
|
* [mod_fastcgi] minor: copy packet without padding
|
|
|
|
* [mod_redirect,mod_rewrite] use server_name
|
|
|
|
* [mod_fastcgi] transfer chunks minus packet padding
|
|
|
|
* [core] separate func to reset FILE_CHUNK
|
|
|
|
* [core] perf: simple, quick buffer_clear()
|
|
|
|
* [core] perf: small improvement to encoding CGI var
|
|
|
|
* [core] perf: small improvement buffer_string_space
|
|
|
|
* [core] simpler physical path concatenation
|
|
|
|
* [mod_webdav] fix LOCK on incorrect URI path
|
|
|
|
* [mod_webdav] one fewer buffer copy for COPY,MOVE
|
|
|
|
* [core] perf: simplify buffer_move()
|
|
|
|
* [mod_cml] parse query string without modifying it
|
|
|
|
* [core] perf: buffer optimizations
|
|
|
|
* [mod_wstunnel] use buffer_string_length()
|
|
|
|
* [core] perf: inline buffer_copy_buffer()
|
|
|
|
* [core] cygwin helper func for getcwd
|
|
|
|
* [core] cygwin sample to run lighttpd under NSSM
|
|
|
|
* [core] limit con->uri.authority < 1024 octets
|
|
|
|
* [mod_webdav] separate func for each request method
|
|
|
|
* [core] reject decoded url-path without leading '/'
|
|
|
|
* [multiple] validate UTF-8 in url-decoded paths
|
|
|
|
* [mod_proxy] silence coverity false positive
|
|
|
|
* [core] fix typo
|
|
|
|
* [core] buffer_append_path_len()
|
|
|
|
* [core] quiet indexfile warning if mod not loaded
|
2018-10-14 22:34:55 +00:00
|
|
|
|
2018-10-14 22:24:43 +00:00
|
|
|
- 1.4.51 - 2018-10-14
|
|
|
|
* [core] split parsing header line into separate function
|
|
|
|
* [core] explicitly return 0 instead of constant result
|
|
|
|
* [core] header parsing: use goto for error handling
|
|
|
|
* [core,security] process headers after combining folded headers
|
|
|
|
* [core] replace folding whitespace with a single space
|
|
|
|
* [buffer] fix duplicate assert and comment
|
|
|
|
* [core] redo HTTP header line folding
|
|
|
|
* [core] parse header line strings before copying
|
|
|
|
* [core] abstraction to insert/modify response hdrs
|
|
|
|
* [core] code reuse with array_insert_key_value()
|
|
|
|
* [core] simplify parsing hdr key whitespace then :
|
|
|
|
* [core] http_request_parse_reqline() separate func
|
|
|
|
* [core] abstraction layer for HTTP header manip
|
|
|
|
* [core] code reuse with http_response_body_clear()
|
|
|
|
* [mod_proxy] fix proxy.forwarded and proxy.replace-http-host (fixes #2902)
|
|
|
|
* [mod_rewrite] fix url.rewrite-repeat and url.rewrite-if-not-file (fixes #2908)
|
|
|
|
* [core] fastcgi.h link to Open Market License (OML) (fixes #2901)
|
|
|
|
* [mod_proxy,mod_wstunnel] copy full plugin_config (fixes #2903)
|
|
|
|
* [mod_fastcgi,mod_scgi] error on oversized request (fixes #2905)
|
|
|
|
* [mod_auth] send 401 for mismatch HTTP auth scheme (fixes #2906)
|
|
|
|
* [core] code reuse array_match_*() routines
|
|
|
|
* [mod_skeleton] review and simplify
|
|
|
|
* [multiple] code reuse: employ array_match_*()
|
|
|
|
* [doc] lighttpd.service uses network-online.target
|
|
|
|
* [mod_flv_streaming] code simplifications
|
|
|
|
* [mod_authn_pam] mod_auth PAM support (fixes #688)
|
|
|
|
* [mod_sockproxy] add to build
|
|
|
|
* [core] fix include_shell on inline shell commands (fixes #2910)
|
|
|
|
* [multiple] code reuse: using array_*() funcs
|
|
|
|
* [tests] t/test_array.c
|
|
|
|
* [core] array_get_int_ptr()
|
|
|
|
* [core] more memory-efficient fn table for data_*
|
|
|
|
* [tests] #undef NDEBUG before assert.h in t/test_*
|
|
|
|
* [core] inline status_counter routines
|
|
|
|
* [core] log_failed_assert() __attribute__((cold))
|
|
|
|
* [core] http_status_append()
|
|
|
|
* [core] http_method_append()
|
|
|
|
* [core] prefer buffer_append_string_len()
|
|
|
|
* [build] fix SCons build for mod_authn_pam
|
|
|
|
* [mod_userdir] security: skip username "." and ".."
|
|
|
|
* [mod_deflate] null-check to quiet coverity warning
|
|
|
|
* [core] quiet coverity false positive
|
|
|
|
* [multiple] quiet compiler warnings --without-pcre
|
|
|
|
* [mod_secdownload] support if HMAC() is a macro
|
|
|
|
* [TLS] sys-crypto.h abstraction
|
|
|
|
* [TLS] sys-crypto.h abstraction
|
|
|
|
* [build] put request.c in common src
|
|
|
|
* [meson] build fixes for libmariadb and libsasl2
|
|
|
|
* [core] PATH_INFO calculation when basedir is "/" (fixes #2911)
|
|
|
|
* [core] better consistency in buffer_is_equal*()
|
|
|
|
* [core] fix missing param from prev commit
|
|
|
|
* [mod_openssl] no renegotiation in TLS 1.3 (fixes #2912)
|
|
|
|
* [core] reject Transfer-Encoding from proxy (#2913)
|
|
|
|
* [mod_auth] use SHA1_Init,Update,Final
|
|
|
|
* [mod_openssl] add support for wolfSSL
|
|
|
|
* [build] automake support for wolfSSL
|
|
|
|
* [build] SCons support for wolfSSL
|
|
|
|
* [build] meson support for wolfSSL
|
|
|
|
* [build] CMake support for wolfSSL
|
|
|
|
* [core] perf: buffer.c internal inlines
|
|
|
|
* [mod_openssl] wolfSSL does not support SSLv2
|
|
|
|
* [core] perf: buffer_string_append_len()
|
|
|
|
* [core] permit server.error_handler to static file
|
2018-08-13 04:43:56 +00:00
|
|
|
|
2018-08-13 02:27:02 +00:00
|
|
|
- 1.4.50 - 2018-08-13
|
2020-02-22 22:24:12 +00:00
|
|
|
* [mod_extforward] allow explicit IPs to be untrusted (#2860)
|
2018-08-13 02:27:02 +00:00
|
|
|
* [core] fix crash if 'host' empty in config (fixes #2876)
|
|
|
|
* [mod_magnet] fix regression in lighty.stat (fixes #2877)
|
|
|
|
* [core] minor code cleanup in gw_recv_response()
|
|
|
|
* [core] fix rare race condition from backends (fixes #2878)
|
|
|
|
* [mod_proxy] fix segfault in Set-Cookie reverse map (fixes #2879)
|
|
|
|
* [core] fdevent_accept_listenfd() nonblock cloexec
|
|
|
|
* [build] remove m4 AC_PATH_PROG for PKG_CONFIG
|
|
|
|
* [core] some header cleanup
|
|
|
|
* [mod_wstunnel] better Sec-WebSocket-Protocol parse
|
|
|
|
* [mod_magnet] code reuse
|
|
|
|
* [mod_magnet] reduce buffer copies
|
|
|
|
* [mod_fastcgi,mod_scgi] fastcgi.balance,scgi.balance (fixes #2882)
|
|
|
|
* [core] check if SOCK_NONBLOCK is ignored (fixes #2883)
|
|
|
|
* [core] buffer_append_string_encoded_hex_lc()
|
|
|
|
* [core] more efficient hex2int()
|
|
|
|
* [mod_secdownload] compare bin MAC instead of hex
|
|
|
|
* [core] li_tohex_lc() explicitly uses lc hex chars
|
|
|
|
* [core] buffer_append_uint_hex_lc() uses lc hex
|
|
|
|
* [core] buffer_append_string_encoded() uc hex
|
|
|
|
* [tests] reduce test_base64 brute force tests
|
|
|
|
* [tests] remove test_buffer output, except on error
|
|
|
|
* [core] check for continuation in server.tag
|
|
|
|
* [core] CONNECT must be handled before fs hooks
|
|
|
|
* [mod_redirect, mod_rewrite] code reuse (sharing)
|
|
|
|
* [core] data_config_pcre_compile,exec()
|
|
|
|
* [tests] test_request unit tests
|
|
|
|
* [core] http_kv.[ch] method, status, version str
|
|
|
|
* [core] remove unused get_http_status_body_name()
|
|
|
|
* [core] remove proc_open.[ch], reduce stdio.h use
|
|
|
|
* [tests] move src/test_*.c to src/t/
|
|
|
|
* [core] server.http-parseopts URL normalization opt (fixes #1720)
|
|
|
|
* [core] inline some buffer.[ch] routines
|
|
|
|
* [core] remove some duplicative code in log.c
|
|
|
|
* [core] debug server.log-request-header-on-error
|
|
|
|
* [mod_redirect,mod_rewrite] short-circuit earlier
|
|
|
|
* [core] fix buffer_to_upper()
|
|
|
|
* [mod_cgi] handle CGI partial response header write
|
|
|
|
* [mod_redirect,mod_rewrite] pass request URI info
|
|
|
|
* [mod_redirect,mod_rewrite] encoding options (fixes #443, fixes #911)
|
|
|
|
* [mod_redirect,mod_rewrite] fix segfault w/ invalid syntax (fixes #2892)
|
|
|
|
* [mod_fastcgi] fix memleak with FastCGI auth,resp (fixes #2894)
|
|
|
|
* [mod_alias] security: potential path traversal with specific configs
|
|
|
|
* [mod_wstunnel] quiet 32-bit compiler warnings
|
|
|
|
* [core] POLLRDHUP handling for transparent proxying
|
|
|
|
* [mod_redirect,mod_rewrite] support up to 19 match
|
|
|
|
* [core] add missing includes to quiet compiler warn
|
|
|
|
* [mod_redirect,mod_rewrite] base64url encoding opt
|
|
|
|
* [mod_rewrite] require rewrite result to begin '/'
|
|
|
|
* [core] security: use-after-free invalid Range req
|
|
|
|
* [core] reset var if FAMMonitorDirectory() fails
|
|
|
|
* [core] option to propagate TCP FIN to backend host
|
|
|
|
* mod_sockproxy - socket forwarding
|
|
|
|
* [core] workaround Coverity cov-build bug with gcc7
|
|
|
|
* [build] add missing file for test_burl
|
|
|
|
* [core] quell insignificant coverity warning
|
|
|
|
* [core] extend server.http-parseopts
|
2018-08-13 04:43:56 +00:00
|
|
|
* [mod_alias] security: path traversal in mod_alias (in some use cases) (fixes #2898)
|
|
|
|
* [core] security: use-after-free after invalid Range request (fixes #2899)
|
2018-03-12 01:54:44 +00:00
|
|
|
|
2018-03-12 00:23:32 +00:00
|
|
|
- 1.4.49 - 2018-03-11
|
|
|
|
* [core] adjust offset if response header blank line
|
|
|
|
* [mod_accesslog] %{canonical,local,remote}p (fixes #2840)
|
|
|
|
* [core] support POLLRDHUP, where available (#2743)
|
|
|
|
* [mod_proxy] basic support for HTTP CONNECT method (#2060)
|
|
|
|
* [mod_deflate] fix deflate of file > 2MB w/o mmap
|
|
|
|
* [core] fix segfault if tempdirs fill up (fixes #2843)
|
|
|
|
* [mod_compress,mod_deflate] try mmap MAP_PRIVATE
|
|
|
|
* [core] discard from socket using recv MSG_TRUNC
|
|
|
|
* [core] report to stderr if errorlog path ENOENT (fixes #2847)
|
|
|
|
* [core] fix base64 decode when char is unsigned (fixes #2848)
|
|
|
|
* [mod_authn_ldap] fix mem leak when ldap auth fails (fixes #2849)
|
|
|
|
* [core] warn if mod_indexfile after dynamic handler
|
|
|
|
* [core] do not reparse request if async cb
|
|
|
|
* [core] non-blocking write() to piped loggers
|
|
|
|
* [mod_openssl] minor code cleanup; reduce var scope
|
|
|
|
* [mod_openssl] elliptic curve auto selection (fixes #2833)
|
|
|
|
* [core] check for path-info forward down path
|
|
|
|
* [mod_authn_ldap] auth with ldap referrals (fixes #2846)
|
|
|
|
* [core] code cleanup: separate physical path sub
|
|
|
|
* [core] merge redirect/rewrite pattern substitution
|
|
|
|
* [core] fix POST with chunked request body (fixes #2854)
|
|
|
|
* [core] remove unused func
|
|
|
|
* [doc] minor update to *outdated* doc
|
|
|
|
* [mod_wstunnel] fix for frames larger than 64k (fixes #2858)
|
|
|
|
* [core] fix 32-bit compile POST w/ chunked request body (#2854)
|
|
|
|
* [core] add include sys/poll.h on Solaris (fixes #2859)
|
|
|
|
* [core] fix path-info calculation in git master (fixes #2861)
|
|
|
|
* [core] pass array_get_element_klen() const array *
|
|
|
|
* [core] increase stat_cache abstraction
|
|
|
|
* [core] open additional fds O_CLOEXEC
|
|
|
|
* [core] fix CONNECT w strict header parsing enabled
|
|
|
|
* [mod_extforward] CIDR support for trusted proxies (fixes #2860)
|
|
|
|
* [core] re-enable overloaded backends w/ multi wkrs
|
|
|
|
* [autoconf] reduce minimum automake version to 1.13
|
|
|
|
* [mod_auth] constant time compare plain passwords
|
|
|
|
* [mod_auth] check that digest realm matches config
|
|
|
|
* [core] fix incorrect hash algorithm impl
|
2017-11-12 05:53:51 +00:00
|
|
|
|
|
|
|
- 1.4.48 - 2017-11-11
|
2017-11-11 16:13:39 +00:00
|
|
|
* [mod_webdav] fix crash if stat fails, not ENOENT
|
|
|
|
* [core] fix build --disable-ipv6 (fixes #2832)
|
|
|
|
* [scons] Merge branch 'personal/stbuehler/scons-cleanup'
|
|
|
|
* [autobuild] Merge branch 'personal/stbuehler/autobuild-cleanup'
|
|
|
|
* [meson] new build system
|
|
|
|
* [core] fix var.CWD (regression in 1.4.46) (fixes #2835)
|
|
|
|
* [core] fix implicit wildcard IPv4 and IPv6 listen
|
|
|
|
* [autobuild] remove obsolete warning about mmap use
|
|
|
|
* [core] isolate sock_addr manipulation
|
|
|
|
* [stat_cache] remove debug code littered in file
|
|
|
|
* [core] cleanup unused ifndef
|
|
|
|
* [core] cleanup: consolidate FAM code in stat_cache
|
|
|
|
* [core] consolidate backend network write handlers
|
|
|
|
* [autobuild] allow sendfile() in cross-compile (fixes #2836)
|
|
|
|
* [core] quiet pedantic cc warning for excess comma
|
|
|
|
* [core] isolate backend fdevent handler defs
|
|
|
|
* [mod_openssl] error if ssl.engine in wrong section (fixes #2837)
|
|
|
|
* [core] fix lighttpd -1 one-shot graceful shutdown
|
|
|
|
* [mod_cgi] quiet trace if mod_cgi sends SIGTERM (fixes #2838)
|
|
|
|
* [build] fix link of test_configfile.c
|
|
|
|
* [core] quiet coverity false positive
|
|
|
|
* [mod_openssl] more pedantic check of return values
|
|
|
|
* [mod_openssl] allow specifying server cert chain (fixes #2692)
|
|
|
|
* [mod_openssl] ssl.openssl.ssl-conf-cmd (fixes #2758)
|
|
|
|
* [doc] NEWS - fix improper format line breaks
|
|
|
|
* [mod_authn_ldap] replace use of deprecated funcs
|
|
|
|
* [mod_authn_sasl] SASL auth (new) (fixes #2275)
|
|
|
|
* [mod_openssl] quiet trace from TCP probes (#2784)
|
|
|
|
* [core] fix dup typedef compiler warning
|
|
|
|
* [scons] fix various python2/3 incompatibilities
|
|
|
|
* [doc] fix doc/config/conf.d/fastcgi.conf example
|
2017-10-22 20:43:33 +00:00
|
|
|
|
|
|
|
- 1.4.47 - 2017-10-22
|
2017-10-22 19:36:55 +00:00
|
|
|
* [mod_authn_gssapi] needs -lcom_err under Darwin
|
|
|
|
* [core] stricter validation of request-URI begin
|
|
|
|
* [core] fix 1.4.46 regression in config match (fixes #2830)
|
|
|
|
* [core] normalize config addrs for != match (#2830)
|
|
|
|
* [core] normalize config addrs for eq and ne (#2830)
|
|
|
|
* [doc] use https:// URLs to .lighttpd.net resources
|
|
|
|
* [core] fix 1.4.46 regression in Last-Modified
|
2017-10-21 20:37:13 +00:00
|
|
|
|
|
|
|
- 1.4.46 - 2017-10-21
|
2017-10-21 19:42:49 +00:00
|
|
|
* [TLS] mark code that uses -lcrypto but not -lssl
|
|
|
|
* remove redundant calls to end-of-request hooks
|
|
|
|
* [mod_mysql_vhost] remove dev debug code
|
|
|
|
* [core] con interface for read/write; isolate SSL
|
|
|
|
* [core] new plugin hooks to help isolate SSL
|
|
|
|
* [mod_openssl] new module (preliminary layout)
|
|
|
|
* [core] move network_open_file_chunk() to chunk.c
|
|
|
|
* [mod_openssl] move openssl code into mod_openssl
|
|
|
|
* [mod_openssl] move openssl config into mod_openssl
|
|
|
|
* [core] move connection_read_cq() to connections.c
|
|
|
|
* [mod_geoip] call from handle_request_env hook
|
|
|
|
* [build] only mod_openssl depends on -lssl
|
|
|
|
* [mod_auth] enable optional authz if extern authn (fixes #2481)
|
|
|
|
* [mod_openssl] allow ssl.verifyclient on url paths (fixes #2245)
|
|
|
|
* [core] do not emit req/response hdrs w/ blank val
|
|
|
|
* [mod_setenv] directives to overwrite/remove hdrs (fixes #650, fixes #2295)
|
|
|
|
* [mod_secdownload] new directives modify hash path (fixes #646, fixes #1904)
|
|
|
|
* [core] move con throttling to connections-glue.c
|
|
|
|
* [core] support Expect: 100-continue with HTTP/1.1 (fixes #377, #1017, #1953, #2438)
|
|
|
|
* [mod_openssl] use TLS SNI to set host-based certs
|
|
|
|
* [mod_ssi] send #exec cmd="..." output to temp file
|
|
|
|
* [mod_scgi] tests/mod-scgi.t unit tests
|
|
|
|
* [mod_auth] support LDAP groups for HTTP auth (fixes #1817)
|
|
|
|
* [core] use getaddrinfo,inet_pton vs gethostbyname (fixes #2783)
|
|
|
|
* [mod_auth] LDAP escape username in DN and filters
|
|
|
|
* mod_vhostdb* (dbi,mysql,pgsql,ldap) (fixes #485, fixes #1936, fixes #2297)
|
|
|
|
* [mod_auth] have LDAP template replace '?'
|
|
|
|
* apply debian/patches/spelling.patch
|
|
|
|
* [core] permit connection-level state in modules
|
|
|
|
* [TLS] include <openssl/opensslv.h> in rand.c
|
|
|
|
* [core] config match w/ arbitrary HTTP request hdrs (fixes #1556)
|
|
|
|
* [mod_flv_streaming] add end pos param (fixes #1887)
|
|
|
|
* [core] X-LIGHTTPD-KBytes-per-second from backends (fixes #954)
|
|
|
|
* [core] improve accuracy of bandwidth write limits
|
|
|
|
* [core] quicker graceful shutdown
|
|
|
|
* [tests] remove unused file depending on CGI.pm
|
|
|
|
* [doc] doc/initscripts.txt (fixes #2782)
|
|
|
|
* [core] check issetugid() early in main()
|
|
|
|
* [core] combine duplicated getrlimit, network_init
|
|
|
|
* [core] move interval timer near worker event loop
|
|
|
|
* [core] initialize globals at top of main()
|
|
|
|
* [core] graceful restart with SIGUSR1 (fixes #2785)
|
|
|
|
* [mod_authn_mysql] fix minor memleak at shutdown
|
|
|
|
* [mod_rrdtool] no error if loaded but no config
|
|
|
|
* [doc] SIGUSR1 doc and lighttpd-angel SIGUSR1
|
|
|
|
* [mime.conf] add text/markdown to utf-8 list, regenerate mime.conf
|
|
|
|
* [mod_cgi] RFC3875 CGI local-redir strict adherence (#2108)
|
|
|
|
* [mod_cgi] do not send "Status" back to client
|
|
|
|
* [core] add label for 308 Permanent Redirect
|
|
|
|
* [mod_openssl] inherit ssl.* from global scope
|
|
|
|
* [core] handle if backend sends Transfer-Encoding (#2786)
|
|
|
|
* [core] use kqueue in level-triggered mode (fixes #2788)
|
|
|
|
* [mod_fastcgi,mod_scgi] backend spawn EINTR retry (#2788)
|
|
|
|
* [core] config opt to intercept dynamic handler err (fixes #974)
|
|
|
|
* [core] set default server_tag in server.c
|
|
|
|
* [core] include lighttpd vers in server started msg
|
|
|
|
* [core] move version.h logic into server.c
|
|
|
|
* [core] issue trace if max-fds too large (fixes #2789)
|
|
|
|
* [mod_fastcgi,mod_scgi] consistent waitpid handling (fixes #2791)
|
|
|
|
* [mod_cgi] fix CGI local-redir w/ url.rewrite-once (fixes #2793)
|
|
|
|
* [mod_scgi] fix unused_procs bidirectional-links
|
|
|
|
* [mod_scgi] fix potential repeated use of proc->id
|
|
|
|
* [mod_fastcgi,mod_scgi] consolidate backend process accounting (#2788)
|
|
|
|
* [mod_cgi] status 200 OK if no hdrs (deprecated) (#2786)
|
|
|
|
* [core] fix regex condition subst w/ mod_extforward (fixes #2794)
|
|
|
|
* [tests] correct skip count for mod-scgi.t
|
|
|
|
* [mod_vhostdb_ldap] fix inverted logic (coverity)
|
|
|
|
* [mod_cgi] cgi.local-redir = [enable|disable] (#2108, #2793)
|
|
|
|
* [core] $REQUEST_HEADER[...] subsumes other config (#1556)
|
|
|
|
* [mod_usertrack] usertrack.cookie-attrs config opt (fixes #2795)
|
|
|
|
* [core] default server.max-fds=4096 if unspecified (#2789)
|
|
|
|
* update .gitignore, add .gitattributes
|
|
|
|
* [core] reduce con allocation for small max_conns
|
|
|
|
* [config] more specific checks for array lists
|
|
|
|
* [mod_authn_gssapi] needs -lcom_err under cygwin
|
|
|
|
* [mod_cgi,fastcgi,scgi,proxy] fix streaming response (fixes #2796)
|
|
|
|
* [mod_auth] Digest nonce on system with time <=1978
|
|
|
|
* [doc] simple-vhost.debug takes an integer value (fixes #2797)
|
|
|
|
* [core] fix crash if invalid config file (fixes #2798)
|
|
|
|
* [core] remove unused member con->in_joblist
|
|
|
|
* [mod_proxy] remove use of con->got_response
|
|
|
|
* [core] consolidate dynamic handler response parse
|
|
|
|
* [core] remove now-unused buffer_search_string_len
|
|
|
|
* [mod_cgi] eliminate warning when compiled -Os
|
|
|
|
* [mod_scgi] do not reconnect after connect succeeds
|
|
|
|
* [tests] reduce time waiting for backends to start
|
|
|
|
* [core] server.syslog-facility (fixes #2800)
|
|
|
|
* [core] server.syslog-facility (use -1 for unset) (#2800)
|
|
|
|
* [core] allow overriding prior config values (fixes #2799)
|
|
|
|
* [mod_proxy] set Content-Length, if available
|
|
|
|
* [mod_proxy] set X-Forwarded-Host (fixes #418)
|
|
|
|
* [core] remove redundant Content-Length digit check
|
|
|
|
* [core] remove some unused header includes
|
|
|
|
* [core] use con->dst_addr_buf instead of ip recalc
|
|
|
|
* [core] include "fdevent.h" where needed
|
|
|
|
* [core] make stat_cache private to stat_cache.c
|
|
|
|
* [core] collect ioctl FIONREAD code
|
|
|
|
* [core] include <netdb.h> where needed
|
|
|
|
* [core] report file path when mkstemp() fails (fixes #2802)
|
|
|
|
* [core] export http_request_host_policy() for reuse
|
|
|
|
* [mod_extforward] simplify header search
|
|
|
|
* [mod_extforward] consolidate ipstr_to_sockaddr()
|
|
|
|
* [mod_extforward] upd scheme after ipstr validated
|
|
|
|
* [mod_extforward] rearrange code; prep Forwarded
|
|
|
|
* [mod_extforward] support Forwarded HTTP Extension (#2703)
|
|
|
|
* [mod_proxy] support Forwarded HTTP Extension (fixes #2703)
|
|
|
|
* [core] inet_pton(), inet_ntop() on (sock_addr *)
|
|
|
|
* [core] save connection-level proto in con->proto
|
|
|
|
* [mod_extforward] support HAProxy "PROXY" protocol (fixes #2804)
|
|
|
|
* [mod_extforward] fix typos in Forwarded handling
|
|
|
|
* [core] fix stat_cache initialization error
|
|
|
|
* [core] perf: stat_cache_mimetype_by_ext()
|
|
|
|
* [core] inet_ntop_cache now 4-element cache
|
|
|
|
* [mod_openssl] free local_send_buffer at exit
|
|
|
|
* [core] extend mimetype search w/o leading '.'
|
|
|
|
* [core] no SOCK_CLOEXEC on Linux kernel < 2.6.27
|
|
|
|
* [core] inline simple buffer is empty checks
|
|
|
|
* [core] buffer_substr_replace()
|
|
|
|
* [core] sys-strings.h abstraction for strings.h
|
|
|
|
* [mod_proxy] fix backslash escaping
|
|
|
|
* [core] omit default port from normalized host str
|
|
|
|
* [core] fix build issue without ipv6 support
|
|
|
|
* [core] permit strings and integers in config array
|
|
|
|
* [mod_accesslog] flag high precision ts for %T (fixes #2807)
|
|
|
|
* [core] permit strings,ints,arrays in config array
|
|
|
|
* [core] calloc plugin_config for consistent init
|
|
|
|
* [mod_proxy] simple host/url mapping in headers (fixes #152)
|
|
|
|
* [mod_uploadprogress] handle query str progress ID (fixes #2808)
|
|
|
|
* [mod_fastcgi] consolidate backend read code
|
|
|
|
* [mod_proxy,mod_scgi] fix truncated error trace
|
|
|
|
* [core] skip socket shutdown() if con->fd negative
|
|
|
|
* [core] act as transparent proxy after con Upgrade
|
|
|
|
* [core] remove redundant resets of fde_ndx
|
|
|
|
* [core] configparser: fix resource handling in error cases (fixes #2809)
|
|
|
|
* [core] fix crash for invalid syntax in config file (fixes #2810)
|
|
|
|
* [core] prep mod transitions to transparent proxy
|
|
|
|
* [mod_proxy] basic support for Upgrade: websocket (fixes #2811)
|
|
|
|
* [mod_extforward] compile on OSX
|
|
|
|
* [core] set server.max-keep-alive-requests = 100 (fixes #2205)
|
|
|
|
* [core] perf: skip redundant strlen() if len known
|
|
|
|
* [core] optional condition in config "else" clause (fixes #1268)
|
|
|
|
* [mod_cgi] basic support for Upgrade: websocket
|
|
|
|
* [core] buffer to disk streaming to slow backends
|
|
|
|
* [core] silence compiler warnings if !HAVE_FORK
|
|
|
|
* [build] -Werror if --enable-extra-warnings=error
|
|
|
|
* [build] autotools use AC_PROG_CC_STDC macro
|
|
|
|
* [mod_openssl] ssl.ca-crl-file for CRL (fixes #2319)
|
|
|
|
* [mod_openssl] ssl.ca-dn-file (fixes #2694)
|
|
|
|
* [mod_proxy] fix typo identified by coverity
|
|
|
|
* [mod_openssl] ignore client verification error if not enforced
|
|
|
|
* [mod_openssl] fix compile with openssl 1.1.0
|
|
|
|
* [mod_extforward] quiet clang compiler warning
|
|
|
|
* [mod_dirlisting] sort "../" to top of names
|
|
|
|
* [mod_openssl] safer_X509_NAME_oneline() (fixes #2693)
|
|
|
|
* [core] allow earlier plugin init for SSL/TLS
|
|
|
|
* [mod_openssl] adjust use of ssl.ca-dn-file
|
|
|
|
* [core] fix compiler warnings on Mac OS X
|
|
|
|
* [core] server.socket-perms to set perms on unix (fixes #656)
|
|
|
|
* [core] get port from sock_addr if AF_INET,AF_INET6
|
|
|
|
* [core] server.error_handler_404 X-Sendfile ENOENT (#2474)
|
|
|
|
* [core] consolidate fork()/execve() code (#1393)
|
|
|
|
* [core] mv log_error_{open,cycle.close} to server.c
|
|
|
|
* [core] rename fd_close_on_exec()
|
|
|
|
* [core] remove unused includes of stat_cache.h
|
|
|
|
* [core] add missing include of stdlib.h
|
|
|
|
* [core] reduce exposure of unistd.h, other includes
|
|