From: Christopher Faulet Date: Wed, 1 Apr 2026 09:17:47 +0000 (+0200) Subject: BUG/MINOR: http_act: Make set/add-headers-bin compatible with ACL conditions X-Git-Tag: v3.4-dev8~66 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=e4b8531d5a1b60494ef54a71d333c091550f5115;p=thirdparty%2Fhaproxy.git BUG/MINOR: http_act: Make set/add-headers-bin compatible with ACL conditions An error is erroneously triggered if a if/unless statement is found after set-headers-bin and add-headers-bin actions. To make it works, during parsing of these actions, we should leave when an unknown argument is found to let the rule parser the opportunity to parse an if/unless statement. No backport needed. --- diff --git a/src/http_act.c b/src/http_act.c index c2aab4ecc..b8d3ce3fb 100644 --- a/src/http_act.c +++ b/src/http_act.c @@ -1712,22 +1712,14 @@ static enum act_parse_ret parse_http_set_headers_bin(const char **args, int *ori return ACT_RET_PRS_ERR; } - cur_arg++; - /* Check if an argument is available */ - if (*args[cur_arg]) { - if (strcmp(args[cur_arg], "prefix") == 0 ) { - if(!*args[cur_arg+1]) { - memprintf(err, "expects 1 argument: ; or 3 arguments: prefix "); - return ACT_RET_PRS_ERR; - } else { - cur_arg++; - rule->arg.http.str = ist(strdup(args[cur_arg])); - } - } else { + if (*args[cur_arg+1] && strcmp(args[cur_arg+1], "prefix") == 0 ) { + if(!*args[cur_arg+2]) { memprintf(err, "expects 1 argument: ; or 3 arguments: prefix "); return ACT_RET_PRS_ERR; } + cur_arg += 2; + rule->arg.http.str = ist(strdup(args[cur_arg])); } *orig_arg = cur_arg + 1;