46 lines
1.7 KiB
Diff
46 lines
1.7 KiB
Diff
From ada8c0e37df568c58e3a328c171d6f27bcfbe652 Mon Sep 17 00:00:00 2001
|
|
From: Aurelien DARRAGON <adarragon@haproxy.com>
|
|
Date: Tue, 26 Mar 2024 10:42:48 +0100
|
|
Subject: [PATCH] BUG/MINOR: server: 'source' interface ignored from
|
|
'default-server' directive
|
|
|
|
Sebastien Gross reported that 'interface' keyword ('source' subargument)
|
|
is silently ignored when used from 'default-server' directive despite the
|
|
documentation implicitly stating that the keyword should be supported
|
|
there.
|
|
|
|
When support for 'source' keyword was added to 'default-server' directive
|
|
in dba97077 ("MINOR: server: Make 'default-server' support 'source'
|
|
keyword."), we properly duplicated the conn iface_name from the default-
|
|
server but we forgot to copy the conn iface_len which must be set as well
|
|
since it is used as setsockopt()'s 'optlen' argument in
|
|
tcp_connect_server().
|
|
|
|
It should be backported to all stable versions.
|
|
|
|
(cherry picked from commit bd98db50785b6cef946d38715b48f72e7ca73a59)
|
|
Signed-off-by: Christopher Faulet <cfaulet@haproxy.com>
|
|
|
|
Conflict: NA
|
|
Reference: https://git.haproxy.org/?p=haproxy-2.9.git;a=patch;h=ada8c0e37df568c58e3a328c171d6f27bcfbe652
|
|
---
|
|
src/server.c | 4 +++-
|
|
1 file changed, 3 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/src/server.c b/src/server.c
|
|
index ef70a8f27583..1d88e4a3df1e 100644
|
|
--- a/src/server.c
|
|
+++ b/src/server.c
|
|
@@ -2507,8 +2507,10 @@ static void srv_conn_src_cpy(struct server *srv, const struct server *src)
|
|
srv->conn_src.bind_hdr_occ = src->conn_src.bind_hdr_occ;
|
|
srv->conn_src.tproxy_addr = src->conn_src.tproxy_addr;
|
|
#endif
|
|
- if (src->conn_src.iface_name != NULL)
|
|
+ if (src->conn_src.iface_name != NULL) {
|
|
srv->conn_src.iface_name = strdup(src->conn_src.iface_name);
|
|
+ srv->conn_src.iface_len = src->conn_src.iface_len;
|
|
+ }
|
|
}
|
|
|
|
/*
|