From 09a0f039947c6fe1469d5246fa31247e9edef1d6 Mon Sep 17 00:00:00 2001 From: Olivier Houchard Date: Thu, 17 Jan 2019 15:59:13 +0100 Subject: [PATCH] BUG/MEDIUM: servers: Make assign_tproxy_address work when ALPN is set. If an ALPN is set on the server line, then when we reach assign_tproxy_address, the stream_interface's endpoint will be a connection, not a conn_stream, so make sure assign_tproxy_address() handles both cases. This should be backported to 1.9. --- src/backend.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/src/backend.c b/src/backend.c index ab5a629c5..3e327975e 100644 --- a/src/backend.c +++ b/src/backend.c @@ -1021,7 +1021,12 @@ static void assign_tproxy_address(struct stream *s) struct server *srv = objt_server(s->target); struct conn_src *src; struct connection *cli_conn; - struct connection *srv_conn = cs_conn(objt_cs(s->si[1].end)); + struct connection *srv_conn; + + if (objt_cs(s->si[1].end)) + srv_conn = cs_conn(__objt_cs(s->si[1].end)); + else + srv_conn = objt_conn(s->si[1].end); if (srv && srv->conn_src.opts & CO_SRC_BIND) src = &srv->conn_src;