summaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
* release-1.2.9 tagbranches/stable-1.2Maxim Dounin2013-05-131-0/+1
|
* nginx-1.2.9-RELEASErelease-1.2.9Maxim Dounin2013-05-131-0/+18
|
* Fixed chunk size parsing.Maxim Dounin2013-05-131-0/+4
|
* Version bump.Maxim Dounin2013-05-132-3/+3
|
* release-1.2.8 tagMaxim Dounin2013-04-021-0/+1
|
* nginx-1.2.8-RELEASErelease-1.2.8Maxim Dounin2013-04-021-0/+55
|
* Merge of r5138: use of NGX_FILE_ERROR.Maxim Dounin2013-03-295-7/+9
| | | | | | | | | | | | | Use NGX_FILE_ERROR for handling file operations errors. On Win32 platforms 0 is used to indicate errors in file operations, so comparing against either -1 or NGX_OK is not portable. This was not much of an issue in patched code, since only ngx_fd_info() test is actually reachable on Win32 and in worst case it might result in bogus error log entry. Patch by Piotr Sikora.
* Merge of r5133, r5134: peer.free() and peer.get() balance.Maxim Dounin2013-03-294-26/+11
| | | | | | *) Upstream: only call peer.free() if peer.get() selected a peer. *) Upstream: removed double-free workarounds in peer.free() methods.
* Merge of r5130, r5131, r5132: support for Mercurial repositories.Maxim Dounin2013-03-291-43/+39
| | | | | | | | | | | | | | | *) Misc: switch to single export operation in "zip" target. While exporting parts of the tree might be better in some cases, it is awfully slow overseas, and also requires unlocking ssh key multiple times. Exporting the whole repo and removing directories not needed for zip is faster here. It is also a required step before we can switch to Mercurial. *) Misc: removed unused "snapshot" target. *) Misc: support for Mercurial repositories.
* Merge of r5129: split clients configuration parsing.Maxim Dounin2013-03-291-1/+1
| | | | Split clients: check length when parsing configuration.
* Merge of r5127: language in a comment.Maxim Dounin2013-03-291-5/+5
| | | | Fixed language in a comment preceding ngx_http_index_handler().
* Merge of r5117, r5123: allocation errors handing during upgrade.Maxim Dounin2013-03-291-0/+4
| | | | | | | | *) Core: guard against failed allocation during binary upgrade. Patch by Piotr Sikora. *) Core: fixed resource leak if binary upgrade fails due to no memory. Found by Coverity (CID 992320).
* Merge of r5113, r5114: upstream: resolve errors handling.Maxim Dounin2013-03-291-2/+8
| | | | | | | | | | | | | | | | | | | | | | | | | Upstream: call ngx_http_run_posted_requests() on resolve errors. If proxy_pass to a host with dynamic resolution was used to handle a subrequest, and host resolution failed, the main request wasn't run till something else happened on the connection. E.g. request to "/zzz" with the following configuration hanged: addition_types *; resolver 8.8.8.8; location /test { set $ihost xxx; proxy_pass http://$ihost; } location /zzz { add_after_body /test; return 200 "test"; } Report and original version of the patch by Lanshun Zhou, http://mailman.nginx.org/pipermail/nginx-devel/2013-March/003476.html.
* Merge of r5109, r5128: removed unused prototype and macro.Maxim Dounin2013-03-292-4/+0
| | | | | | | | *) Removed unused prototype of ngx_http_find_server_conf(). This function prototype and its implementation was added in r90, but the implementation was removed in r97. *) Removed unused ngx_http_clear_variable() macro.
* Merge of r5098: mp4: fixed handling of too small mdat atoms.Maxim Dounin2013-03-291-0/+7
| | | | | | Mp4: fixed handling of too small mdat atoms (ticket #266). Patch by Gernot Vormayr (with minor changes).
* Merge of r5083: fixed potential segfault in keepalive handler.Maxim Dounin2013-03-291-0/+1
| | | | | | | | | | Fixed potential segfault in ngx_http_keepalive_handler(). In case of error in the read event handling we close a connection by calling ngx_http_close_connection(), that also destroys connection pool. Thereafter, an attempt to free a buffer (added in r4892) that was allocated from the pool could cause SIGSEGV and is meaningless as well (the buffer already freed with the pool).
* Merge of r5082: SSL: retry "sess_id" and "id" allocations.Maxim Dounin2013-03-291-2/+22
| | | | | | | | | | | | | | | SSL: retry "sess_id" and "id" allocations. In case of fully populated SSL session cache with no memory left for new allocations, ngx_ssl_new_session() will try to expire the oldest non-expired session and retry, but only in case when slab allocation fails for "cached_sess", not when slab allocation fails for either "sess_id" or "id", which can happen for number of reasons and results in new session not being cached. Patch fixes this by adding retry logic to "sess_id" & "id" allocations. Patch by Piotr Sikora.
* Merge of r5078: removed zero termination of shm zone names.Maxim Dounin2013-03-292-3/+0
| | | | | | | It was added in r2717 and no longer needed since r2721, where the termination was added to ngx_shm_alloc() and ngx_init_zone_pool(). Since then it only corrupted error messages about invalid zones.
* Merge of r5071: rebuild perl module on headers change.Maxim Dounin2013-03-291-1/+2
| | | | | | | | Configure: rebuild perl module nginx.so if headers are changed. Note: the "-p" argument of cp(1) dropped intentionally, to force nginx.so rebuild. It is considered too boring to properly list all dependencies in Makefile.PL.
* Merge of r5070: fixed false memset warning on Linux.Maxim Dounin2013-03-291-2/+5
| | | | | | Fixed false memset warning on Linux with -O3 (ticket #275). Prodded by John Leach.
* Version bump.Maxim Dounin2013-03-292-3/+3
|
* release-1.2.7 tagMaxim Dounin2013-02-121-0/+1
|
* nginx-1.2.7-RELEASErelease-1.2.7Maxim Dounin2013-02-121-0/+253
|
* Merge of r5005, r5031, r5066: PCRE and OpenSSL for win32 builds.Maxim Dounin2013-02-111-2/+2
|
* Merge of r5027, r5028, r5029: fastcgi_keep_conn fixes.Maxim Dounin2013-02-111-58/+43
| | | | | | | | | | | | | | | | | | | | | | *) FastCGI: fixed wrong connection close with fastcgi_keep_conn. With fastcgi_keep_conn it was possible that connection was closed after FCGI_STDERR record with zero padding and without any further data read yet. This happended as f->state was set to ngx_http_fastcgi_st_padding and then "break" happened, resulting in p->length being set to f->padding, i.e. 0 (which in turn resulted in connection close). Fix is to make sure we continue the loop after f->state is set. *) FastCGI: unconditional state transitions. Checks for f->padding before state transitions make code hard to follow, remove them and make sure we always do another loop iteration after f->state is set to ngx_http_fastcgi_st_padding. *) FastCGI: proper handling of split fastcgi end request. If fastcgi end request record was split between several network packets, with fastcgi_keep_conn it was possible that connection was saved in incorrect state (e.g. with padding bytes not yet read).
* Merge of r5018: secure link: fixed configuration inheritance.Maxim Dounin2013-02-111-2/+15
| | | | | | The "secure_link_secret" directive was always inherited from the outer configuration level even when "secure_link" and "secure_link_md5" were specified on the inner level.
* Merge of r5017: fixed null dereference with resolver and poll.Maxim Dounin2013-02-111-2/+2
| | | | | | | | | Events: fixed null pointer dereference with resolver and poll. A POLLERR signalled by poll() without POLLIN/POLLOUT, as seen on Linux, would generate both read and write events, but there's no write event handler for resolver events. A fix is to only call event handler of an active event.
* Merge of r5014, r5015, r5016, r5030: geoip ipv6 support.Maxim Dounin2013-02-113-18/+163
| | | | | | | | | | | | *) Configure: fixed style of include directories. *) Configure: fixed GeoIP library detection. *) GeoIP: IPv6 support. When using IPv6 databases, IPv4 addresses are looked up as IPv4-mapped IPv6 addresses. Mostly based on a patch by Gregor Kališnik (ticket #250). *) GeoIP: removed pseudo-support of "proxy" and "netspeed" databases.
* Merge of r5013: proxy: fixed proxy_method to always add space.Maxim Dounin2013-02-111-4/+5
| | | | | | Before the patch if proxy_method was specified at http{} level the code to add trailing space wasn't executed, resulting in incorrect requests to upstream.
* Merge of r5012: configure: removed redundant variable assignment.Maxim Dounin2013-02-111-3/+0
|
* Merge of r5004, r5019-r5025: ssl fixes.Maxim Dounin2013-02-111-13/+27
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | *) SSL: speedup loading of configs with many ssl servers. The patch saves one EC_KEY_generate_key() call per server{} block by informing OpenSSL about SSL_OP_SINGLE_ECDH_USE we are going to use before the SSL_CTX_set_tmp_ecdh() call. For a configuration file with 10k simple server{} blocks with SSL enabled this change reduces startup time from 18s to 5s on a slow test box here. *) SSL: removed conditions that always hold true. *) SSL: resetting of flush flag after the data was written. There is no need to flush next chunk of data if it does not contain a buffer with the flush or last_buf flags set. *) SSL: preservation of flush flag for buffered data. Previously, if SSL buffer was not sent we lost information that the data must be flushed. *) SSL: calculation of buffer size moved closer to its usage. No functional changes. *) SSL: avoid calling SSL_write() with zero data size. According to documentation, calling SSL_write() with num=0 bytes to be sent results in undefined behavior. We don't currently call ngx_ssl_send_chain() with empty chain and buffer. This check handles the case of a chain with total data size that is a multiple of NGX_SSL_BUFSIZE, and with the special buffer at the end. In practice such cases resulted in premature connection close and critical error "SSL_write() failed (SSL:)" in the error log. *) SSL: take into account data in the buffer while limiting output. In some rare cases this can result in a more smooth sending rate. *) SSL: fixed ngx_ssl_handshake() with level-triggered event methods. Missing calls to ngx_handle_write_event() and ngx_handle_read_event() resulted in a CPU hog during SSL handshake if an level-triggered event method (e.g. select) was used.
* Merge of r5001: year 2013.Maxim Dounin2013-02-112-4/+4
|
* Merge of r4999, r5003: detect duplicate "events" and "keepalive".Maxim Dounin2013-02-112-0/+8
| | | | | | | | *) Upstream keepalive: detect duplicate "keepalive" directive. A failure to detect duplicate "keepalive" directive resulted in stack exhaustion. *) Events: added check for duplicate "events" directive.
* Merge of r4992: off-by-one with 32/64 upstream backup servers.Maxim Dounin2013-02-112-2/+6
| | | | | | | | Fixed off-by-one during upstream state resetting when switching to backup servers if there were exactly 32 (64 on 64-bit platforms) backup servers configured. Based on patch by Thomas Chen (ticket #257).
* Merge of r4991: fixed proxied HEAD requests with gzip enabled.Maxim Dounin2013-02-112-1/+2
| | | | Fixed HEAD requests handling when proxying is used (ticket #261).
* Merge of r4985, r4986, r4987, r4988, r4989, r5002: access_log gzip.Maxim Dounin2013-02-115-89/+389
| | | | | | | | | | | | | | | | | | | | | | | | | *) Access log: fixed redundant buffer reallocation. Previously a new buffer was allocated for every "access_log" directive with the same file path and "buffer=" parameters, while only one buffer per file is used. *) Reopening log files code moved to a separate function. The code refactored in a way to call custom handler that can do appropriate cleanup work (if any), like flushing buffers, finishing compress streams, finalizing connections to log daemon, etc.. *) Access log: the "flush" parameter of the "access_log" directive. *) Configure: added the NGX_ZLIB define. This was introduced for conditional compilation of the code that requires the zlib library. *) Access log: the "gzip" parameter of the "access_log" directive. Note: this requires zlib version 1.2.0.4 or above to work. *) The data pointer in ngx_open_file_t objects must be initialized. Uninitialized pointer may result in arbitrary segfaults if access_log is used without buffer and without variables in file path. Patch by Tatsuhiko Kubo (ticket #268).
* Merge of r4979, r4982: image filter configuration inheritance.Maxim Dounin2013-02-111-13/+27
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | *) Image filter: configuration inheritance fixes. The image_filter_jpeg_quality, image_filter_sharpen and "image_filter rotate" were inherited incorrectly if a directive with variables was defined, and then redefined to a literal value, i.e. in configurations like image_filter_jpeg_quality $arg_q; location / { image_filter_jpeg_quality 50; } Patch by Ian Babrou, with minor changes. *) Image filter: fixed image_filter rotate inheritance. Configurations like location /i/ { image_filter resize 200 200; image_filter rotate 180; location /i/foo/ { image_filter resize 200 200; } } resulted in rotation incorrectly applied in the location /i/foo, without any way to clear it. Fix is to handle conf->angle/conf->acv consistently with other filter variables and do not try to inherit them if there are transformations defined for current location.
* Merge of r4976: let add_header affect 201 responses (ticket #125).Maxim Dounin2013-02-111-0/+1
|
* Merge of r4983: crypt_r() error handling fixed.Maxim Dounin2013-02-111-14/+13
| | | | | | | | | | | | The crypt_r() function returns NULL on errors, check it explicitly instead of assuming errno will remain 0 if there are no errors (per POSIX, the setting of errno after a successful call to a function is unspecified unless the description of that function specifies that errno shall not be modified). Additionally, dropped unneeded ngx_set_errno(0) and fixed error handling of memory allocation after normal crypt(), which was inapropriate and resulted in null pointer dereference on allocation failures.
* Merge of r4974: avoid sending "100 Continue" on 413.Maxim Dounin2013-02-111-0/+1
| | | | | | Avoid sending "100 Continue" on 413 Request Entity Too Large. Patch by Igor Sysoev.
* Merge of r4993, r4994, r4997, r5000: geo ipv6 support.Maxim Dounin2013-02-113-88/+487
| | | | | | | | | | | | | *) Geo: IPv6 support. The "ranges" mode is still limited to IPv4 only. *) Geo: properly initialize ngx_cidr_t when dealing with "default". *) Geo: made "default" affect both IPv4 and IPv6 when using prefixes. Previously, "default" was equivalent to specifying 0.0.0.0/0, now it's equivalent to specifying both 0.0.0.0/0 and ::/0 (if support for IPv6 is enabled) with the same value. *) Geo: improved code readability.
* Merge of r4968, r4969, r4977, r4980, r4981, r4990: geo fixes.Maxim Dounin2013-02-112-28/+28
| | | | | | | | | | | | | | | | | | | | | | *) Geo: improved ngx_http_geo_block() code readability. *) Geo: fixed the "ranges" without ranges case. The following configuration returned an empty value for $geo: geo $geo { ranges; default default; } *) Fixed return type of internal function that allocates radix tree nodes. *) There's no need to normalize address returned by ngx_ptocidr(). *) Geo: ensure that default entry is always present. If 0.0.0.0/32 entry was present and there was no explicit "default", we failed to add an empty string as a default value. *) Trailing whitespace fix.
* Merge of r4967: ngx_write_fd() and ngx_read_fd() errors handling.Maxim Dounin2013-02-103-6/+6
| | | | | | | | | The ngx_write_fd() and ngx_read_fd() functions return -1 in case of error, so the incorrect comparison with NGX_FILE_ERROR (which is 0 on windows platforms) might result in inaccurate error message in the error log. Also the ngx_errno global variable is being set only if the returned value is -1.
* Merge of r4966: gzip: fixed zlib memLevel adjusting.Maxim Dounin2013-02-101-0/+4
| | | | | | | An incorrect memLevel (lower than 1) might be passed to deflateInit2() if the "gzip_hash" directive is set to a value less than the value of "gzip_window" directive. This resulted in "deflateInit2() failed: -2" alert and an empty reply.
* Merge of r4965: upstream: fixed SIGSEGV with the "if" directive.Maxim Dounin2013-02-101-0/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | Configuration like location / { set $true 1; if ($true) { proxy_pass http://backend; } if ($true) { # nothing } } resulted in segmentation fault due to NULL pointer dereference as the upstream configuration wasn't initialized in an implicit location created by the last if(), but the r->content_handler was set due to first if(). Instead of committing a suicide by dereferencing a NULL pointer, return 500 (Internal Server Error) in such cases, i.e. if uscf is NULL. Better fix would be to avoid such cases by fixing the "if" directive handling, but it's out of scope of this patch. Prodded by Piotr Sikora.
* Merge of r4963: proxy: better error message about unexpected data.Maxim Dounin2013-02-101-1/+2
| | | | Requested by Igor Sysoev.
* Merge of r4962: limit_rate fix.Maxim Dounin2013-02-101-1/+1
| | | | | | Limit rate: fixed integer overflow in limit calculation (ticket #256). Patch by Alexey Antropov.
* Merge of r4961: configure: better check for PCRE JIT.Maxim Dounin2013-02-101-0/+1
| | | | | | | | | | | | | | | | | | | | | | On Mac OS X system toolchain by default prefers include files from /usr/local/include, but libraries from /usr/lib. This might result in various problems, in particular the one outlined below. If the PCRE library is installed into /usr/local/, this results in pcre.h being used from /usr/local/include (with PCRE_CONFIG_JIT defined), but libpcre from /usr/lib (as shipped with the OS, without pcre_free_study() symbol). As a result build fails as we use pcre_free_study() function if we try to compile with PCRE JIT support. Obvious workaround to the root cause is to ask compiler to prefer library from /usr/local/lib via ./configure --with-ld-opt="-L/usr/local/lib". On the other hand, in any case it would be good to check if the function we are going to use is available, hence the change. See thread here for details: http://mailman.nginx.org/pipermail/nginx-devel/2012-December/003074.html Prodded by Piotr Sikora.
* Merge of r4948, r4949, r4964, r4973, r5011: variables.Maxim Dounin2013-02-1012-65/+185
| | | | | | | | | | | | | | | | | | *) Allow the complex value to be defined as an empty string. This makes conversion from strings to complex values possible without the loss of functionality. *) The "auth_basic" directive gained support of variables. *) Fixed variable syntax checking in "set", "geo", "limit_conn_zone", and "perl_set" directives. *) Added checks that disallow adding a variable with an empty name. Added variable name syntax checks to "geo" and "map" directives. *) Variables $pipe, $request_length, $time_iso8601, and $time_local. Log module counterparts are preserved for efficiency. Based on patch by Kiril Kalchev.
* Merge of r4947: xslt: prevented infinite loop.Maxim Dounin2013-02-101-2/+2
| | | | | If XSLT transformation failed and error 500 was handled in the same location, an infinite loop occured that exhausted the stack.