]> git.ipfire.org Git - thirdparty/haproxy.git/commitdiff
BUG/MINOR: hlua: Skip headers when a receive is performed on an HTTP applet
authorChristopher Faulet <cfaulet@haproxy.com>
Fri, 18 Jul 2025 09:14:26 +0000 (11:14 +0200)
committerChristopher Faulet <cfaulet@haproxy.com>
Thu, 24 Jul 2025 10:13:41 +0000 (12:13 +0200)
When an HTTP applet tries to retrieve data, the request headers are still in
the buffer. But, instead of being silently removed, their size is removed
from the amount of data retrieved. When the request payload is fully
retrieved, it is not an issue. But it is a problem when a length is
specified. The data are shorten from the headers size.

So now, we take care to silently remove headers.

This patch must be backported to all stable versions.

src/hlua.c

index e5f71c51d10a396d0b37be395a66a44732ae98ef..3ee00e16cc9b30df0fe7970fb1db0b596879024b 100644 (file)
@@ -5987,6 +5987,8 @@ __LJMP static int hlua_applet_http_recv_yield(lua_State *L, int status, lua_KCon
                        case HTX_BLK_DATA:
                                v = htx_get_blk_value(htx, blk);
                                luaL_addlstring(&luactx->b, v.ptr, vlen);
+                               if (len > 0)
+                                       len -= vlen;
                                break;
 
                        case HTX_BLK_TLR:
@@ -6000,8 +6002,6 @@ __LJMP static int hlua_applet_http_recv_yield(lua_State *L, int status, lua_KCon
 
                c_rew(req, vlen);
                count -= vlen;
-               if (len > 0)
-                       len -= vlen;
                if (sz == vlen)
                        blk = htx_remove_blk(htx, blk);
                else {