import CS squid-5.5-6.el9
This commit is contained in:
		
							parent
							
								
									ea69b16138
								
							
						
					
					
						commit
						db1800b931
					
				
							
								
								
									
										158
									
								
								SOURCES/squid-5.5-halfclosed.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										158
									
								
								SOURCES/squid-5.5-halfclosed.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,158 @@ | ||||
| diff --git a/src/client_side.cc b/src/client_side.cc
 | ||||
| index 4eb6976..63f1b66 100644
 | ||||
| --- a/src/client_side.cc
 | ||||
| +++ b/src/client_side.cc
 | ||||
| @@ -957,7 +957,7 @@ ConnStateData::kick()
 | ||||
|       * We are done with the response, and we are either still receiving request | ||||
|       * body (early response!) or have already stopped receiving anything. | ||||
|       * | ||||
| -     * If we are still receiving, then clientParseRequest() below will fail.
 | ||||
| +     * If we are still receiving, then parseRequests() below will fail.
 | ||||
|       * (XXX: but then we will call readNextRequest() which may succeed and | ||||
|       * execute a smuggled request as we are not done with the current request). | ||||
|       * | ||||
| @@ -977,28 +977,12 @@ ConnStateData::kick()
 | ||||
|       * Attempt to parse a request from the request buffer. | ||||
|       * If we've been fed a pipelined request it may already | ||||
|       * be in our read buffer. | ||||
| -     *
 | ||||
| -     \par
 | ||||
| -     * This needs to fall through - if we're unlucky and parse the _last_ request
 | ||||
| -     * from our read buffer we may never re-register for another client read.
 | ||||
|       */ | ||||
|   | ||||
| -    if (clientParseRequests()) {
 | ||||
| -        debugs(33, 3, clientConnection << ": parsed next request from buffer");
 | ||||
| -    }
 | ||||
| +    parseRequests();
 | ||||
|   | ||||
| -    /** \par
 | ||||
| -     * Either we need to kick-start another read or, if we have
 | ||||
| -     * a half-closed connection, kill it after the last request.
 | ||||
| -     * This saves waiting for half-closed connections to finished being
 | ||||
| -     * half-closed _AND_ then, sometimes, spending "Timeout" time in
 | ||||
| -     * the keepalive "Waiting for next request" state.
 | ||||
| -     */
 | ||||
| -    if (commIsHalfClosed(clientConnection->fd) && pipeline.empty()) {
 | ||||
| -        debugs(33, 3, "half-closed client with no pending requests, closing");
 | ||||
| -        clientConnection->close();
 | ||||
| +    if (!isOpen())
 | ||||
|          return; | ||||
| -    }
 | ||||
|   | ||||
|      /** \par | ||||
|       * At this point we either have a parsed request (which we've | ||||
| @@ -1935,16 +1919,11 @@ ConnStateData::receivedFirstByte()
 | ||||
|      resetReadTimeout(Config.Timeout.request); | ||||
|  } | ||||
|   | ||||
| -/**
 | ||||
| - * Attempt to parse one or more requests from the input buffer.
 | ||||
| - * Returns true after completing parsing of at least one request [header]. That
 | ||||
| - * includes cases where parsing ended with an error (e.g., a huge request).
 | ||||
| - */
 | ||||
| -bool
 | ||||
| -ConnStateData::clientParseRequests()
 | ||||
| +/// Attempt to parse one or more requests from the input buffer.
 | ||||
| +/// May close the connection.
 | ||||
| +void
 | ||||
| +ConnStateData::parseRequests()
 | ||||
|  { | ||||
| -    bool parsed_req = false;
 | ||||
| -
 | ||||
|      debugs(33, 5, HERE << clientConnection << ": attempting to parse"); | ||||
|   | ||||
|      // Loop while we have read bytes that are not needed for producing the body | ||||
| @@ -1989,8 +1968,6 @@ ConnStateData::clientParseRequests()
 | ||||
|   | ||||
|              processParsedRequest(context); | ||||
|   | ||||
| -            parsed_req = true; // XXX: do we really need to parse everything right NOW ?
 | ||||
| -
 | ||||
|              if (context->mayUseConnection()) { | ||||
|                  debugs(33, 3, HERE << "Not parsing new requests, as this request may need the connection"); | ||||
|                  break; | ||||
| @@ -2003,8 +1980,19 @@ ConnStateData::clientParseRequests()
 | ||||
|          } | ||||
|      } | ||||
|   | ||||
| -    /* XXX where to 'finish' the parsing pass? */
 | ||||
| -    return parsed_req;
 | ||||
| +    debugs(33, 7, "buffered leftovers: " << inBuf.length());
 | ||||
| +
 | ||||
| +    if (isOpen() && commIsHalfClosed(clientConnection->fd)) {
 | ||||
| +        if (pipeline.empty()) {
 | ||||
| +            // we processed what we could parse, and no more data is coming
 | ||||
| +            debugs(33, 5, "closing half-closed without parsed requests: " << clientConnection);
 | ||||
| +            clientConnection->close();
 | ||||
| +        } else {
 | ||||
| +            // we parsed what we could, and no more data is coming
 | ||||
| +            debugs(33, 5, "monitoring half-closed while processing parsed requests: " << clientConnection);
 | ||||
| +            flags.readMore = false; // may already be false
 | ||||
| +        }
 | ||||
| +    }
 | ||||
|  } | ||||
|   | ||||
|  void | ||||
| @@ -2021,18 +2009,7 @@ ConnStateData::afterClientRead()
 | ||||
|      if (pipeline.empty()) | ||||
|          fd_note(clientConnection->fd, "Reading next request"); | ||||
|   | ||||
| -    if (!clientParseRequests()) {
 | ||||
| -        if (!isOpen())
 | ||||
| -            return;
 | ||||
| -        // We may get here if the client half-closed after sending a partial
 | ||||
| -        // request. See doClientRead() and shouldCloseOnEof().
 | ||||
| -        // XXX: This partially duplicates ConnStateData::kick().
 | ||||
| -        if (pipeline.empty() && commIsHalfClosed(clientConnection->fd)) {
 | ||||
| -            debugs(33, 5, clientConnection << ": half-closed connection, no completed request parsed, connection closing.");
 | ||||
| -            clientConnection->close();
 | ||||
| -            return;
 | ||||
| -        }
 | ||||
| -    }
 | ||||
| +    parseRequests();
 | ||||
|   | ||||
|      if (!isOpen()) | ||||
|          return; | ||||
| @@ -3789,7 +3766,7 @@ ConnStateData::notePinnedConnectionBecameIdle(PinnedIdleContext pic)
 | ||||
|      startPinnedConnectionMonitoring(); | ||||
|   | ||||
|      if (pipeline.empty()) | ||||
| -        kick(); // in case clientParseRequests() was blocked by a busy pic.connection
 | ||||
| +        kick(); // in case parseRequests() was blocked by a busy pic.connection
 | ||||
|  } | ||||
|   | ||||
|  /// Forward future client requests using the given server connection. | ||||
| diff --git a/src/client_side.h b/src/client_side.h
 | ||||
| index 2793673..7c8d86b 100644
 | ||||
| --- a/src/client_side.h
 | ||||
| +++ b/src/client_side.h
 | ||||
| @@ -93,7 +93,6 @@ public:
 | ||||
|      virtual void doneWithControlMsg(); | ||||
|   | ||||
|      /// Traffic parsing | ||||
| -    bool clientParseRequests();
 | ||||
|      void readNextRequest(); | ||||
|   | ||||
|      /// try to make progress on a transaction or read more I/O | ||||
| @@ -422,6 +421,7 @@ private:
 | ||||
|   | ||||
|      void checkLogging(); | ||||
|   | ||||
| +    void parseRequests();
 | ||||
|      void clientAfterReadingRequests(); | ||||
|      bool concurrentRequestQueueFilled() const; | ||||
|   | ||||
| diff --git a/src/tests/stub_client_side.cc b/src/tests/stub_client_side.cc
 | ||||
| index acf61c4..b1d82bf 100644
 | ||||
| --- a/src/tests/stub_client_side.cc
 | ||||
| +++ b/src/tests/stub_client_side.cc
 | ||||
| @@ -14,7 +14,7 @@
 | ||||
|  #include "tests/STUB.h" | ||||
|   | ||||
|  #include "client_side.h" | ||||
| -bool ConnStateData::clientParseRequests() STUB_RETVAL(false)
 | ||||
| +void ConnStateData::parseRequests() STUB
 | ||||
|  void ConnStateData::readNextRequest() STUB | ||||
|  bool ConnStateData::isOpen() const STUB_RETVAL(false) | ||||
|  void ConnStateData::kick() STUB | ||||
| @ -2,7 +2,7 @@ | ||||
| 
 | ||||
| Name:     squid | ||||
| Version:  5.5 | ||||
| Release:  5%{?dist} | ||||
| Release:  6%{?dist} | ||||
| Summary:  The Squid proxy caching server | ||||
| Epoch:    7 | ||||
| # See CREDITS for breakdown of non GPLv2+ code | ||||
| @ -44,6 +44,8 @@ Patch206: squid-5.0.6-openssl3.patch | ||||
| Patch207: squid-5.0.6-active-ftp.patch | ||||
| # https://bugzilla.redhat.com/show_bug.cgi?id=1988122 | ||||
| Patch208: squid-5.1-test-store-cppsuite.patch | ||||
| # https://bugzilla.redhat.com/show_bug.cgi?id=2231827 | ||||
| Patch209: squid-5.5-halfclosed.patch | ||||
| 
 | ||||
| # Security patches | ||||
| # https://bugzilla.redhat.com/show_bug.cgi?id=2100721 | ||||
| @ -123,6 +125,7 @@ lookup program (dnsserver), a program for retrieving FTP data | ||||
| %patch206 -p1 -b .openssl3 | ||||
| %patch207 -p1 -b .active-ftp | ||||
| %patch208 -p1 -b .test-store-cpp | ||||
| %patch209 -p1 -b .halfclosed | ||||
| 
 | ||||
| %patch501 -p1 -b .CVE-2021-46784 | ||||
| %patch502 -p1 -b .CVE-2022-41318 | ||||
| @ -352,6 +355,9 @@ fi | ||||
| 
 | ||||
| 
 | ||||
| %changelog | ||||
| * Wed Aug 16 2023 Luboš Uhliarik <luhliari@redhat.com> - 7:5.5-6 | ||||
| - Resolves: #2231827 - Crash with half_closed_client on | ||||
| 
 | ||||
| * Tue Dec 06 2022 Tomas Korbar <tkorbar@redhat.com> - 7:5.5-5 | ||||
| - Resolves: #2151188 - [RFE] Add the "IP_BIND_ADDRESS_NO_PORT" | ||||
|   flag to sockets created for outgoing connections in the squid source code. | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user