From f297d0dd2771f4993b144b56c6f175504c8d53c4 Mon Sep 17 00:00:00 2001 From: Igor Sysoev Date: Mon, 19 Jul 2010 15:31:46 +0000 Subject: an intercepted error code was not cached --- src/http/ngx_http_upstream.c | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'src') diff --git a/src/http/ngx_http_upstream.c b/src/http/ngx_http_upstream.c index 2f295c2f6..76e949c26 100644 --- a/src/http/ngx_http_upstream.c +++ b/src/http/ngx_http_upstream.c @@ -1720,6 +1720,24 @@ ngx_http_upstream_intercept_errors(ngx_http_request_t *r, r->headers_out.www_authenticate = h; } +#if (NGX_HTTP_CACHE) + + if (u->cacheable && r->cache) { + time_t valid; + + ngx_log_debug1(NGX_LOG_DEBUG_HTTP, r->connection->log, 0, + "http upstream cache fd: %d", r->cache->file.fd); + + valid = ngx_http_file_cache_valid(u->conf->cache_valid, status); + + if (valid) { + r->cache->valid_sec = ngx_time() + valid; + r->cache->error = status; + } + + ngx_http_file_cache_free(r, u->pipe->temp_file); + } +#endif ngx_http_upstream_finalize_request(r, u, status); return NGX_OK; -- cgit