]> git.ipfire.org Git - thirdparty/haproxy.git/commit
BUG/MEDIUM: http-ana: Report error on write error waiting for the response
authorChristopher Faulet <cfaulet@haproxy.com>
Thu, 1 Aug 2024 13:42:09 +0000 (15:42 +0200)
committerChristopher Faulet <cfaulet@haproxy.com>
Fri, 2 Aug 2024 06:42:28 +0000 (08:42 +0200)
commit0ba6202796fe24099aeff89a5a4b83af99fc027b
tree1e2ec3c8660d5c6078f8ea26cc28a2d8d32f3d7b
parent7a5a30d28a3ee100c62603f7212cc1b313c53311
BUG/MEDIUM: http-ana: Report error on write error waiting for the response

When we are waiting for the server response, if an error is pending on the
frontend side (a write error on client), it is handled as an abort and all
regular response analyzers are removed, except the one responsible to
release the filters, if any. However, while it is handled as an abort, the
error is not reported, as usual, via http_reply_and_close() function. It is
an issue because in that, the channels buffers are not reset.

Because of this bug, it is possible to block a stream infinitely. The
request side is waiting for the response side and the response side is
blocked because filters must be released and this cannot be done because
data remain blocked in channels buffers.

So, in that case, calling http_reply_and_close() with no message is enough
to unblock the stream.

This patch must be backported as far as 2.8.
src/http_ana.c