The internal function responsible to receive data for TCP applets with
internal buffers is buggy. Indeed, for these applets, the buffer API is used
to get data. So there is no tests on the SE to properly detect connection
shutdowns. So, it must be performed by hand after the call to b_getblk_nc().
This patch must be backported as far as 3.0.
(cherry picked from commit
c64781c2c8b307fba7499fc70102d4246e850240)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
(cherry picked from commit
ecc8126ef97836044b1bc962fd4b9c91e89c353f)
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
size_t len2;
/* Read the maximum amount of data available. */
- if (luactx->appctx->flags & APPCTX_FL_INOUT_BUFS)
+ if (luactx->appctx->flags & APPCTX_FL_INOUT_BUFS) {
ret = b_getblk_nc(&luactx->appctx->inbuf, &blk1, &len1, &blk2, &len2, 0, b_data(&luactx->appctx->inbuf));
+ if (ret == 0 && se_fl_test(luactx->appctx->sedesc, SE_FL_SHW))
+ ret = -1;
+ }
else
ret = co_getblk_nc(sc_oc(sc), &blk1, &len1, &blk2, &len2);