From: phk Date: Mon, 20 Aug 2007 11:05:07 +0000 (+0000) Subject: Fix a long-standing bug in pipe-mode: We must pass the protocol version X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=bbd0cb3e4fbb871ab14f821200e3d8e0eb53eba4;p=varnish Fix a long-standing bug in pipe-mode: We must pass the protocol version across unchanged, otherwise the semantics of the Connection: header cannot be interpreted correctly by the server. wget(1) could trigger this problem and would have to wait for the server to close the (seemingly idle) connection before continuing. git-svn-id: svn+ssh://projects.linpro.no/svn/varnish/trunk@1888 d4fa192b-c00b-0410-8231-f00ffab90ce4 --- diff --git a/varnish-cache/bin/varnishd/cache_http.c b/varnish-cache/bin/varnishd/cache_http.c index 6bb44934..8834437e 100644 --- a/varnish-cache/bin/varnishd/cache_http.c +++ b/varnish-cache/bin/varnishd/cache_http.c @@ -701,17 +701,20 @@ http_copyh(struct http *to, struct http *fm, unsigned n) } static void -http_copyreq(struct http *to, struct http *fm, int forceget) +http_copyreq(struct http *to, struct http *fm, int transparent) { CHECK_OBJ_NOTNULL(fm, HTTP_MAGIC); CHECK_OBJ_NOTNULL(to, HTTP_MAGIC); - if (forceget) - http_SetH(to, HTTP_HDR_REQ, "GET"); - else + if (transparent) http_copyh(to, fm, HTTP_HDR_REQ); + else + http_SetH(to, HTTP_HDR_REQ, "GET"); http_copyh(to, fm, HTTP_HDR_URL); - http_SetH(to, HTTP_HDR_PROTO, "HTTP/1.1"); + if (transparent) + http_copyh(to, fm, HTTP_HDR_PROTO); + else + http_SetH(to, HTTP_HDR_PROTO, "HTTP/1.1"); } void @@ -792,7 +795,7 @@ http_FilterHeader(struct sess *sp, unsigned how) hp = bereq->http; hp->logtag = HTTP_Tx; - http_copyreq(hp, sp->http, how != HTTPH_R_PIPE); + http_copyreq(hp, sp->http, how == HTTPH_R_PIPE); http_FilterFields(sp->wrk, sp->fd, hp, sp->http, how); http_PrintfHeader(sp->wrk, sp->fd, hp, "X-Varnish: %u", sp->xid); http_PrintfHeader(sp->wrk, sp->fd, hp,