]> git.ipfire.org Git - thirdparty/haproxy.git/log
thirdparty/haproxy.git
9 days agoMEDIUM: promex: Update the promex applet to use their own buffers 20250724-applets-new-api
Christopher Faulet [Wed, 23 Jul 2025 09:19:29 +0000 (11:19 +0200)] 
MEDIUM: promex: Update the promex applet to use their own buffers

Thanks to this patch, the promex applet is now using its own buffers.
.rcv_buf and .snd_buf callback functions are now defined to use the default
HTX functions. Parts to receive and send data have also been updated to use
the applet API and to remove any dependencies on the stream-connectors and
the channels.

9 days agoMEDIUM: peers: Update the peer applet to use its own buffers
Christopher Faulet [Tue, 22 Jul 2025 17:01:10 +0000 (19:01 +0200)] 
MEDIUM: peers: Update the peer applet to use its own buffers

Thanks to this patch, the peer applet is now using its own buffers. .rcv_buf
and .snd_buf callback functions are now defined to use the default raw
functions. The applet API is now used and any dependencies on the
stream-connectors and the channels were removed.

9 days agoMEDIUM: sink: Update the sink applets to use their own buffers
Christopher Faulet [Tue, 22 Jul 2025 16:46:38 +0000 (18:46 +0200)] 
MEDIUM: sink: Update the sink applets to use their own buffers

Thanks to this patch, the sink applets is now using their own buffers.
.rcv_buf and .snd_buf callback functions are now defined to use the default
raw functions. The applet API is now used and any dependencies on the
stream-connectors and the channels were removed.

9 days agoMEDIUM: log: Update the log applet to use its own buffers
Christopher Faulet [Tue, 22 Jul 2025 16:27:54 +0000 (18:27 +0200)] 
MEDIUM: log: Update the log applet to use its own buffers

Thanks to this patch, the log applet is now using its own buffers. .rcv_buf
and .snd_buf callback functions are now defined to use the default raw
functions. The applet API is now used and any dependencies on the
stream-connectors and the channels were removed.

9 days agoMEDIUM: http-client: Update the http-client applet to use its own buffers
Christopher Faulet [Tue, 22 Jul 2025 14:01:07 +0000 (16:01 +0200)] 
MEDIUM: http-client: Update the http-client applet to use its own buffers

Thanks to this patch, the http-client applet is now using its own buffers.
.rcv_buf and .snd_buf callback functions are now defined to use the default
HTX functions. Parts to receive and send data have also been updated to use
the applet API and to remove any dependencies on the stream-connectors and
the channels.

9 days agoMINOR: httpclient-cli: Reset httpclient HTX buffer instead of removing blocks
Christopher Faulet [Tue, 22 Jul 2025 13:18:46 +0000 (15:18 +0200)] 
MINOR: httpclient-cli: Reset httpclient HTX buffer instead of removing blocks

In the CLI I/O handler interacting with the HTTP client, in HTX mode, after
a dump of the HTX message, data must be removed. Instead of removng all
blocks one by one, we can call htx_reset() because all the message must be
flushed.

9 days agoBUG/MINOR: httpclient-cli: Don't try to dump raw headers in HTX mode
Christopher Faulet [Tue, 22 Jul 2025 13:17:50 +0000 (15:17 +0200)] 
BUG/MINOR: httpclient-cli: Don't try to dump raw headers in HTX mode

In the CLI I/O handler interacting with the HTTP client, we must not try to
push raw headers in HTX mode, because there is no raw data in this
mode. This prevent the HTX dump at the end of the I/O handle.

It is a 3.3-specific issue. No backport needed.

9 days agoMINOR: http-client: Trigger an error if first response block isn't a start-line
Christopher Faulet [Tue, 22 Jul 2025 06:22:06 +0000 (08:22 +0200)] 
MINOR: http-client: Trigger an error if first response block isn't a start-line

The first HTX block of a response must be a start-line. There is no reason
to wait for something else. And if there are output data in the response
channel buffer, it means we must found the start-line.

9 days agoMINOR: http-client: Try to send request body with headers if possible
Christopher Faulet [Tue, 22 Jul 2025 06:16:14 +0000 (08:16 +0200)] 
MINOR: http-client: Try to send request body with headers if possible

There is no reason to yield after sending the request headers, except if the
request was fully sent. If there is a payload, it is better to send it as
well. However, when the whole request was sent, we can leave the I/O handler.

9 days agoCLEANUP: http-client: Remove useless indentation when sending request body
Christopher Faulet [Tue, 22 Jul 2025 06:14:24 +0000 (08:14 +0200)] 
CLEANUP: http-client: Remove useless indentation when sending request body

It was useless to have an indentation to handle HTTPCLIENT_S_REQ_BODY state
in the http-client I/O handler.

9 days agoMEDIUM: dns: Update the dns_session applet to use its own buffers
Christopher Faulet [Mon, 21 Jul 2025 09:39:08 +0000 (11:39 +0200)] 
MEDIUM: dns: Update the dns_session applet to use its own buffers

Thanks to this patch, the dns_session applet is now using its own
buffers. .rcv_buf and .snd_buf callback functions are now defined to use the
default raw functions. Functions to receive and send data have also been
updated to use the applet API and to remove any dependencies on the
stream-connectors and the channels.

9 days agoBUG/MEDIUM: dns: Reset reconnect tempo when connection is finally established
Christopher Faulet [Mon, 21 Jul 2025 09:30:41 +0000 (11:30 +0200)] 
BUG/MEDIUM: dns: Reset reconnect tempo when connection is finally established

The issue was introduced by commit 27236f221 ("BUG/MINOR: dns: add tempo
between 2 connection attempts for dns servers"). In this patch, to delay the
reconnection, a timer is used on the appctx when it is created. This
postpones the appctx initialization. However, once initialized, the
expiration time of the underlying task is not reset. So, it is always
considered as expired and the appctx is woken up in loop.

The fix is quite simple. In dns_session_init(), the expiration time of the
appctx's task is alwaus set to TICK_ETERNITY.

This patch must be backported everywhere the commit above was backported. So
as far as 2.8 for now but possibly to all stable versions.

9 days agoMEDIUM: hlua: Update the socket applet to use its own buffers
Christopher Faulet [Fri, 18 Jul 2025 14:53:20 +0000 (16:53 +0200)] 
MEDIUM: hlua: Update the socket applet to use its own buffers

Thanks to this patch, the lua cosocket applet is now using its own
buffers. .rcv_buf and .snd_buf callback functions are now defined to use the
default raw functions. Functions to receive and send data have also been
updated to use the applet API and to remove any dependencies on the
stream-connectors and the channels.

9 days agoBUG/MEDIUM: hlua: Report to SC when output data are blocked on a lua socket
Christopher Faulet [Fri, 18 Jul 2025 14:09:20 +0000 (16:09 +0200)] 
BUG/MEDIUM: hlua: Report to SC when output data are blocked on a lua socket

It is a fix similar to the previous one ("BUG/MEDIUM: hlua: Report to SC
when data were consumed on a lua socket"), but for the write side. The
writer must notify the cosocket it needs more space in the request buffer to
produce more data by calling sc_need_room(). Otherwise, there is nothing to
prevent to wake the cosocket applet up again and again.

This patch must be backported as far as 2.8, and maybe to 2.6 too.

9 days agoBUG/MEDIUM: hlua: Report to SC when data were consumed on a lua socket
Christopher Faulet [Fri, 18 Jul 2025 14:07:16 +0000 (16:07 +0200)] 
BUG/MEDIUM: hlua: Report to SC when data were consumed on a lua socket

The lua cosocket are quite strange. There is an applet used to handle the
connection and writer and readers subscribed on it to write or read
data. Writers and readers are tasks woken up by the cosocket applet when
data can be consumed or produced, depending on the channels buffers
state. Then the cosocket applet is woken up by writers and readers when read
or write events were performed.

It means the cosocket applet has only few information on what was produced
or consumed. It is the writers and readers responsibility to notify any
blocking. Among other things, the readers must take care to notify the
stream on top of the cosocket applet that some data was consumed. Otherwise,
it may remain blocked, waiting for a write event (a write event from the
stream point of view is a read event from the cosocket point of view).

Thie patch must be backported as far as 2.8, and maybe to 2.6 too.

9 days agoMEDIUM: hlua: Update the http applet to use its own buffers
Christopher Faulet [Fri, 18 Jul 2025 10:07:20 +0000 (12:07 +0200)] 
MEDIUM: hlua: Update the http applet to use its own buffers

Thanks to this patch, the lua HTTP applet is now using its own buffers.
.rcv_buf and .snd_buf callback functions are now defined to use the default
HTX functions. Functions to receive and send data have also been updated to
use the applet API and to remove any dependencies on the stream-connectors
and the channels.

9 days agoMINOR: hlua: Use the buffer instead of the HTTP message to get HTTP headers
Christopher Faulet [Fri, 18 Jul 2025 10:07:05 +0000 (12:07 +0200)] 
MINOR: hlua: Use the buffer instead of the HTTP message to get HTTP headers

hlua_http_get_headers() function was using the HTTP message from the stream
TXN to retrieve headers from a message. However, this will be an issue to
update the lua HTTP applet to use its own buffers. Indeed, in that case,
information from the channels will be unavailable. So now,
hlua_http_get_headers() is now using a buffer containing an HTX message. It
is just an API change bacause, internally, the function was already
manipulation an HTX message.

9 days agoMINOR: hlua: Fill the request array on the first HTTP applet run
Christopher Faulet [Thu, 17 Jul 2025 09:58:29 +0000 (11:58 +0200)] 
MINOR: hlua: Fill the request array on the first HTTP applet run

When a lua HTTP applet is created, a "request" object is created, filled
with the request information (method, path, headers...), to be able to
easily retrieve these information from the script. However, this was done
when thee appctx was created, retrieving the info from the request channel.

To be ale to update the applet to use its own buffer, it is now performed on
the first applet run. Indead, when the applet is created, the info are not
forwarded yet and should not be accessed. Note that for now, information are
still retrieved from the channel.

9 days agoMEDIUM: hlua: Update the tcp applet to use its own buffers
Christopher Faulet [Wed, 16 Jul 2025 13:28:11 +0000 (15:28 +0200)] 
MEDIUM: hlua: Update the tcp applet to use its own buffers

Thanks to this patch, the lua TCP applet is now using its own buffers.
.rcv_buf and .snd_buf callback functions are now defined to use the default
raw functions. Other changes are quite light. Mainly, end of stream and
errors are reported on the appctx instead of the stream-endpoint descriptor.

9 days agoMINOR: applet: Improve applet API to take care of inbuf/outbuf alloc failures
Christopher Faulet [Thu, 17 Jul 2025 13:08:55 +0000 (15:08 +0200)] 
MINOR: applet: Improve applet API to take care of inbuf/outbuf alloc failures

applet_get_inbuf() and applet_get_outbuf() functions were not testing if the
buffers were available. So, the caller had to check them before calling one
of these functions. It is not really handy. So now, these functions take
care to have a fully usable buffer before returning. Otherwise NULL is
returned.

9 days agoMINOR: applet: Add HTX versions for applet_input_data() and applet_output_room()
Christopher Faulet [Thu, 17 Jul 2025 13:45:36 +0000 (15:45 +0200)] 
MINOR: applet: Add HTX versions for applet_input_data() and applet_output_room()

It will be useful for HTX applets because availale data in the input buffer and
available space in the output buffer are computed from the HTX message and not
the buffer itself. So now, applet_htx_input_data() and applet_htx_output_room()
functions can be used.

9 days agoBUG/MEDIUM: Remove sync sends from streams to applets
Christopher Faulet [Tue, 22 Jul 2025 13:15:34 +0000 (15:15 +0200)] 
BUG/MEDIUM: Remove sync sends from streams to applets

When the applet API was reviewed to use dedicated buffers, the support for
sends from the streams to applets was added. Unfortunately, it was not a
good idea because this way it is possible to deliver data to an applet and
release it just after, truncated data. Indeed, the release stage for applets
is related to the stream release itself. However, unlike the multiplexers,
the applets cannot survive to a stream for now.

So, for now, the sync sends from the streams is removed for applets, waiting
for a better way to handle the applets release stage.

Note that this only concerns applets using their own buffers. And of now,
the bug is harmless because all refactored applets are on server side and
consume data first. But this will be an issue with the HTTP client.

This patch should be backported as far as 3.0 after a period of observation.

9 days agoBUG/MINOR: applet: Fix applet_getword() to not return one extra byte
Christopher Faulet [Tue, 22 Jul 2025 16:23:57 +0000 (18:23 +0200)] 
BUG/MINOR: applet: Fix applet_getword() to not return one extra byte

applet_getword() function is returning one extra byte when a string is
returned because the "ret" variable is not reset before the loop on the
data. The patch also fixes applet_getline().

It is a 3.3-specific issue. No need to backport.

9 days agoBUG/MEDIUM: stconn: Fix conditions to know an applet can get data from stream
Christopher Faulet [Fri, 18 Jul 2025 07:09:28 +0000 (09:09 +0200)] 
BUG/MEDIUM: stconn: Fix conditions to know an applet can get data from stream

sc_is_send_allowed() function is used to know if an applet is able to
receive data from the stream. But this function was designed for applets
using the channels buffer. It is not adapted to applets using their own
buffers.

when the SE_FL_WAIT_DATA flag is set, it means the applet is waiting for
more data and should not be woken up without new data. For applets using
channels buffer, just testing the flag is enough because process_stream()
will remove if when more data will be available. For applets using their own
buffers, it is more complicated. Some data may be blocked in the output
channel buffer. In that case, and when the applet input buffer can receive
daa, the applet can be woken up.

This patch must be backported as far as 3.0 after a period of observation.

9 days agoBUG/MEDIUM: applet: State inbuf is no longer full if input data are skipped
Christopher Faulet [Fri, 18 Jul 2025 07:05:45 +0000 (09:05 +0200)] 
BUG/MEDIUM: applet: State inbuf is no longer full if input data are skipped

When data are skipped from the input buffer of an applet, we must take care
to notify the input buffer is no longer full. Otherwise, this could prevent
the stream to push data to the applet.

It is 3.3-specific. No backport needed.

9 days agoBUG/MINOR: hlua: Skip headers when a receive is performed on an HTTP applet
Christopher Faulet [Fri, 18 Jul 2025 09:14:26 +0000 (11:14 +0200)] 
BUG/MINOR: hlua: Skip headers when a receive is performed on an HTTP applet

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.

9 days agoCLEANUP: acme: fix wrong spelling of "resources"
Ilia Shipitsin [Wed, 23 Jul 2025 19:58:36 +0000 (21:58 +0200)] 
CLEANUP: acme: fix wrong spelling of "resources"

"ressources" was used as a variable name, let's use English variant
to make spell check happier

10 days agoBUG/MINOR: acme: allow "processing" in challenge requests
William Lallemand [Wed, 23 Jul 2025 12:32:18 +0000 (14:32 +0200)] 
BUG/MINOR: acme: allow "processing" in challenge requests

Allow the "processing" status in the challenge object when requesting
to do the challenge, in addition to "pending".

According to RFC 8555 https://datatracker.ietf.org/doc/html/rfc8555/#section-7.1.6

   Challenge objects are created in the "pending" state.  They
   transition to the "processing" state when the client responds to the
   challenge (see Section 7.5.1)

However some CA could respond with a "processing" state without ever
transitioning to "pending".

Must be backported to 3.2.

10 days agoMINOR: acme: remove acme_req_auth() and use acme_post_as_get() instead
William Lallemand [Wed, 23 Jul 2025 12:05:16 +0000 (14:05 +0200)] 
MINOR: acme: remove acme_req_auth() and use acme_post_as_get() instead

acme_req_auth() is only a call to acme_post_as_get() now, there's no
reason to keep the function. This patch removes it.

10 days agoMEDIUM: mux-quic: support backend private connection
Amaury Denoyelle [Tue, 22 Jul 2025 14:45:39 +0000 (16:45 +0200)] 
MEDIUM: mux-quic: support backend private connection

If a backend connection is private, it should not be reused outside of
its original attached session. As such, on stream detach operation, such
connection is never inserted into server idle/avail list. Instead, it is
stored directly on the session.

The purpose of this commit is to implement proper handling of private
backend connections via QUIC multiplexer.

10 days agoMINOR: mux-quic: do not reuse connection if app already shut
Amaury Denoyelle [Wed, 23 Jul 2025 07:41:46 +0000 (09:41 +0200)] 
MINOR: mux-quic: do not reuse connection if app already shut

QUIC connection graceful closure is performed in two steps. First, the
application layer is closed. In the context of HTTP/3, this is done with
a GOAWAY frame emission, which forbids opening of new streams. Then the
whole connection is terminated via CONNECTION_CLOSE which is the final
emitted frame.

This commit ensures that when app layer is shut for a backend
connection, this connection is removed from either idle or avail server
tree. The objective is to prevent stream layer to try to reuse a
connection if no new stream can be attached on it.

New BUG_ON checks are inserted in qmux_strm_attach() and h3_attach() to
ensure that this assertion is always true.

10 days agoMEDIUM: mux-quic: implement be connection reuse
Amaury Denoyelle [Tue, 22 Jul 2025 09:36:34 +0000 (11:36 +0200)] 
MEDIUM: mux-quic: implement be connection reuse

Implement support for QUIC connection reuse on the backend side. The
main change is done during detach stream operation. If a connection is
idle, it is inserted in the server list. Else, it is stored in the
server avail tree if there is room for more streams.

For non idle connection, qmux_avail_streams() is reused to detect that
stream flow-control limit is not yet reached. If this is the case, the
connection is not inserted in the avail tree, so it cannot be reuse,
even if flow-control is unblocked later by the peer. This latter point
could be improved in the future.

Note that support for QUIC private connections is still missing. Reuse
code will evolved to fully support this case.

10 days agoMINOR: mux-quic: store session in QCS instance
Amaury Denoyelle [Tue, 22 Jul 2025 16:27:40 +0000 (18:27 +0200)] 
MINOR: mux-quic: store session in QCS instance

Add a new <sess> member into QCS structure. It is used to store the
parent session of the stream on attach operation. This is only done for
backend side.

This new member will become necessary when connection reuse will be
implemented. <owner> member of connection is not suitable as it could be
set to NULL, notably after a session_add_conn() failure.

Also, a single BE conn can be shared along different session instance,
in particular when using aggressive/always reuse mode. Thus it is
necessary to linked each QCS instance with its session.

10 days agoMINOR: mux-quic: disable glitch on backend side
Amaury Denoyelle [Wed, 23 Jul 2025 12:36:17 +0000 (14:36 +0200)] 
MINOR: mux-quic: disable glitch on backend side

For now, QUIC glitch limit counter is only available on the frontend
side. Thus, disable incrementation on the backend side for now. Also,
session is only available as conn <owner> reliably on the frontend side,
so session_add_glitch_ctr() operation is also securised.

10 days agoMINOR: mux-quic: correctly implement backend timeout
Amaury Denoyelle [Tue, 22 Jul 2025 13:44:17 +0000 (15:44 +0200)] 
MINOR: mux-quic: correctly implement backend timeout

qcc_refresh_timeout() is the function called on QUIC MUX activity. Its
purpose is to update the timeout by selecting the correct value
depending on the connection state.

Prior to this patch, backend connections were mostly ignored by the
function. However, the default server timeout was selecting as a
fallback. This is incompatible with backend connections reuse.

This patch fixes timeout applied on backend connections. Only values
specific to frontend which are http-request and http-keep-alive timeouts
are now ignored for a backend connection. Also, fallback timeout is only
used for frontend connections.

This patch ensures that an idle backend connection won't be deleted due
to server timeout. This is necessary for proper connection reuse which
will be implemented in a future patch.

10 days agoMINOR: mux-quic: refactor timeout code
Amaury Denoyelle [Tue, 8 Jul 2025 08:44:44 +0000 (10:44 +0200)] 
MINOR: mux-quic: refactor timeout code

This commit is a small reorganization of condition used into
qcc_refresh_timeout(). Its objective is to render the code more logical
before the next patch which will ensure that timeout is properly set for
backend connections.

10 days agoBUG/MINOR: mux-quic: ensure close-spread-time is properly applied
Amaury Denoyelle [Tue, 8 Jul 2025 08:31:46 +0000 (10:31 +0200)] 
BUG/MINOR: mux-quic: ensure close-spread-time is properly applied

If a connection remains on a proxy currently disabled or stopped, a
special spread timeout is set if active close is configured. For QUIC
MUX, this is set via qcc_refresh_timeout() as with all other timeout
values.

Fix this closing timeout setting : it is now used as an override to any
other timeout that may have been chosen if calculated spread time is
lower than the previously selected value. This is done for backend
connections as well.

This should be backported up to 2.6 after a period of observation.

10 days agoBUG/MINOR mux-quic: apply correctly timeout on output pending data
Amaury Denoyelle [Tue, 8 Jul 2025 08:30:46 +0000 (10:30 +0200)] 
BUG/MINOR mux-quic: apply correctly timeout on output pending data

When no stream is attached, mux layer is responsible to maintain a
timeout. The first criteria is to apply client/server timeout if there
is still data waiting for emission.

Previously, <hreq> qcc member was used to determine this state. However,
this only covers bidirectional streams. Fix this by testing if
<send_list> is empty or not. This is enough to take into account both
bidi and uni streams.

Theorically, this should be backported to every stable versions.
However, send-list is not available on 2.6 and there is no alternative
to quickly determine if there is waiting output data. Thus, it's better
to backport it up to 2.8 only.

10 days agoBUG/MEDIUM: acme: use POST-as-GET instead of GET for resources
William Lallemand [Wed, 23 Jul 2025 10:32:34 +0000 (12:32 +0200)] 
BUG/MEDIUM: acme: use POST-as-GET instead of GET for resources

The requests that checked the status of the challenge and the retrieval
of the certificate were done using a GET.

This is working with letsencrypt and other CA providers, but it might
not work everywhere. RFC 8555 specifies that only the directory and
newNonce resources MUST work with a GET requests, but everything else
must use POST-as-GET.

Must be backported to 3.2.

11 days agoMINOR: log: explicitly ignore "log-steps" on backends
Aurelien DARRAGON [Tue, 22 Jul 2025 08:14:47 +0000 (10:14 +0200)] 
MINOR: log: explicitly ignore "log-steps" on backends

"log-steps" was already ignored if directly defined in a backend section,
however, when defined in a defaults section it was inherited to all
proxies no matter their capability (ie: including backends).

As configurations often contain more backends than frontends, this would
result in wasted memory given that the log-steps setting is only
considered on frontends.

Let's fix that by preventing the inheritance from defaults section to
anything else than frontends. Also adjust the documentation to mention
that the setting in not relevant for backends.

11 days agoBUG/MINOR: h3: fix uninitialized value in h3_req_headers_send()
Amaury Denoyelle [Tue, 22 Jul 2025 07:39:27 +0000 (09:39 +0200)] 
BUG/MINOR: h3: fix uninitialized value in h3_req_headers_send()

Due to the introduction of smallbuf usage for HTTP/3 headers emission,
ret variable may be used uninitialized if buffer allocation fails due to
not enough room in QUIC connection window.

Fix this by setting ret value to 0.

Function variable declaration are also adjusted so that the pattern is
similar to h3_resp_headers_send(). Finally, outbuf buffer is also
removed as it is now unused.

No need to backport.

12 days agoMINOR: h3: add traces to h3_req_headers_send()
Amaury Denoyelle [Fri, 18 Jul 2025 13:52:47 +0000 (15:52 +0200)] 
MINOR: h3: add traces to h3_req_headers_send()

Add traces during HTTP/3 request encoding. This operation is performed
on the backend side.

12 days agoMINOR: h3: use smallbuf for request header emission
Amaury Denoyelle [Wed, 16 Jul 2025 15:32:52 +0000 (17:32 +0200)] 
MINOR: h3: use smallbuf for request header emission

Similarly to HTTP/3 response encoding, a small buffer is first allocated
for the request encoding on the backend side. If this is not sufficient,
the smallbuf is replaced by a standard buffer and encoding is restarted.

This is useful to reduce the window usage over a connection of smaller
requests.

12 days agoMINOR: ssl: Remove ClientHello specific traces if !HAVE_SSL_CLIENT_HELLO_CB
Remi Tricot-Le Breton [Tue, 15 Jul 2025 08:45:11 +0000 (10:45 +0200)] 
MINOR: ssl: Remove ClientHello specific traces if !HAVE_SSL_CLIENT_HELLO_CB

SSL libraries like wolfSSL that don't have the clienthello callback
mechanism enabled do not need to have the traces that are only called
from the said callback.
The code added to parse the ciphers relied on a function that wes not
defined in wolfSSL (SSL_CIPHER_find).

12 days agoMINOR: ssl: Dump ciphers and sigalgs details in trace with 'advanced' verbosity
Remi Tricot-Le Breton [Tue, 15 Jul 2025 08:45:10 +0000 (10:45 +0200)] 
MINOR: ssl: Dump ciphers and sigalgs details in trace with 'advanced' verbosity

The contents of the extensions were only dumped with verbosity
'complete' which meant that the 'advanced' verbosity was pretty much
useless despite what its name implies (it was the same as the 'simple'
one).
The 'advanced' verbosity is now the "maximum" one, using 'complete'
would not add any extra information yet, but it leaves more room for
some actually large traces to be dumped later on (some complete
ClientHello dumps for instance).

12 days agoMINOR: ssl: Add curves in ssl traces
Remi Tricot-Le Breton [Tue, 15 Jul 2025 08:45:09 +0000 (10:45 +0200)] 
MINOR: ssl: Add curves in ssl traces

Dump the ClientHello curves in the SSL traces.

12 days agoMINOR: ssl: Add curve id to curve name table and mapping functions
Remi Tricot-Le Breton [Tue, 15 Jul 2025 08:45:08 +0000 (10:45 +0200)] 
MINOR: ssl: Add curve id to curve name table and mapping functions

The SSL libraries like OpenSSL for instance do not seem to actually
provide a public mapping between IANA defined curve IDs and curve names,
or even a mapping between curve IDs and internal NIDs.
This new table regroups all those information in a single table so that
we can convert curve names (be it SECG or NIST format) to curve IDs or
NIDs.
The previously existing 'curves2nid' function now uses the new table,
and a new 'curveid2str' one is added.

12 days agoMINOR: ssl: Add ciphers in ssl traces
Remi Tricot-Le Breton [Tue, 15 Jul 2025 08:45:07 +0000 (10:45 +0200)] 
MINOR: ssl: Add ciphers in ssl traces

Decode the contents of the ClientHello ciphers extension and dump a
human readable list in the ssl traces.

12 days agoBUG/MINOR: hq-interop: fix FIN transmission
Amaury Denoyelle [Mon, 21 Jul 2025 09:29:34 +0000 (11:29 +0200)] 
BUG/MINOR: hq-interop: fix FIN transmission

Since the following patch, app_ops layer is now responsible to report
that HTX block was the last transmitted so that FIN STREAM can be set.
This is mandatory to properly support HTTP 1xx interim responses.

  f349df44b4e21d8bf9b575a0aa869056a2ebaa58
  MINOR: qmux: change API for snd_buf FIN transmission

This change was correctly implemented in HTTP/3 code, however an issue
appeared on hq-interop transcoder in case zero-copy DATA transfer is
performed when HTX buffer is swapped. If this occured during the
transfer of the last HTX block, EOM is not detected and thus STREAM FIN
is never set.

Most of the times, QMUX shut callback is called immediately after. This
results in an emission of a RESET_STREAM to the client, which prevents
the data transfer.

To fix this, use the same method as HTTP/3 : HTX EOM flag status is
checked before any transfer, thus preserving it even after a zero-copy.

Criticity of this bug is low as hq-interop is experimental and is mostly
used for interop testing.

This should fix github issue #3038.

This patch must be backported wherever the above one is.

12 days agoBUG/MINOR: logs: fix log-steps extra log origins selection
Aurelien DARRAGON [Mon, 21 Jul 2025 13:18:37 +0000 (15:18 +0200)] 
BUG/MINOR: logs: fix log-steps extra log origins selection

Willy noticed that it was not possible to select extra log origins using
log-steps directive. Extra origins are the one registered using
log_orig_register() such as http-req.

Reason was the error path was always executed during extra log origin
matching for log-steps parser, while it should only be executed if no
match was found.

It should be backported to 3.1.

12 days agoBUG/MEDIUM: threads: Disable the workaround to load libgcc_s on macOS
Olivier Houchard [Thu, 17 Jul 2025 17:27:39 +0000 (19:27 +0200)] 
BUG/MEDIUM: threads: Disable the workaround to load libgcc_s on macOS

Don't use the workaround to load libgcc_s on macOS. It is not needed
there, and it causes issues, as recent macOS dislike processes that fork
after threads where created (and the workaround creates a temporary
thread). This fixes crashes on macOS at least when using master-worker,
and using the system resolver.

This should fix Github issue #3035

This should be backported up to 2.8.

12 days agoBUILD: debug: add missed guard USE_CPU_AFFINITY to show cpu bindings
Valentine Krasnobaeva [Mon, 21 Jul 2025 09:07:47 +0000 (11:07 +0200)] 
BUILD: debug: add missed guard USE_CPU_AFFINITY to show cpu bindings

Not all platforms support thread-cpu bindings, so let's put
cpu_topo_dump_summary() under USE_CPU_AFFINITY guards.

Only needs to be backported if 1cc0e023ce ("MINOR: debug: add thread-cpu
bindings info in 'show dev' output") is backported.

2 weeks agoMINOR: quic: Remove pool_head_quic_be_cc_buf pool
Frederic Lecaille [Thu, 17 Jul 2025 17:23:50 +0000 (19:23 +0200)] 
MINOR: quic: Remove pool_head_quic_be_cc_buf pool

This patch impacts the QUIC frontends. It reverts this patch

    MINOR: quic-be: add a "CC connection" backend TX buffer pool

which adds <pool_head_quic_be_cc_buf> new pool to allocate CC (connection closed state)
TX buffers with bigger object size than the one for <pool_head_quic_cc_buf>.
Indeed the QUIC backends must be able to send at least 1200 bytes Initial packets.

For now on, both the QUIC frontends and backend use the same pool with
MAX(QUIC_INITIAL_IPV6_MTU, QUIC_INITIAL_IPV4_MTU)(1252 bytes) as object size.

2 weeks agoMINOR: debug: add thread-cpu bindings info in 'show dev' output
Valentine Krasnobaeva [Thu, 17 Jul 2025 10:05:46 +0000 (12:05 +0200)] 
MINOR: debug: add thread-cpu bindings info in 'show dev' output

Add thread-cpu bindings info in 'show dev' output, as it can be useful for
debugging.

2 weeks agoMINOR: debug: align output style of debug_parse_cli_show_dev with cpu_dump_topology
Valentine Krasnobaeva [Thu, 17 Jul 2025 10:03:47 +0000 (12:03 +0200)] 
MINOR: debug: align output style of debug_parse_cli_show_dev with cpu_dump_topology

Align titles style of debug_parse_cli_show_dev() with
cpu_dump_topology(). We will call the latter inside of
debug_parse_cli_show_dev() to show thread-cpu bindings info.

2 weeks agoMINOR: cpu-topo: write thread-cpu bindings into trash buffer
Valentine Krasnobaeva [Thu, 17 Jul 2025 16:18:20 +0000 (18:18 +0200)] 
MINOR: cpu-topo: write thread-cpu bindings into trash buffer

Write thread-cpu bindings and cluster summary into provided trash buffer.
Like this we can call this function in any place, when this info is needed.

2 weeks agoMINOR: cpu-topo: split cpu_dump_topology() to show its summary in show dev
Valentine Krasnobaeva [Thu, 17 Jul 2025 10:05:33 +0000 (12:05 +0200)] 
MINOR: cpu-topo: split cpu_dump_topology() to show its summary in show dev

cpu_dump_topology() prints details about each enabled CPU and a summary with
clusters info and thread-cpu bindings. The latter is often usefull for
debugging and we want to add it in the 'show dev' output.

So, let's split cpu_dump_topology() in two parts: cpu_topo_debug() to print the
details about each enabled CPU; and cpu_topo_dump_summary() to print only the
summary.

In the next commit we will modify cpu_topo_dump_summary() to write into local
trash buffer and it could be easily called from debug_parse_cli_show_dev().

2 weeks agoBUG/MINOR: halog: exit with error when some output filters are set simultaneosly
Valentine Krasnobaeva [Wed, 16 Jul 2025 12:35:28 +0000 (14:35 +0200)] 
BUG/MINOR: halog: exit with error when some output filters are set simultaneosly

Exit with an error if multiple output filters (-ic, -srv, -st, -tc, -u*, etc.)
are used at the same time.

halog is designed to process and display output for only one filter at a time.
Using multiple filters simultaneously can cause a crash because the program is
not designed to manage multiple, separate result sets (e.g., one for
IP counts, another for URLs).

Supporting simultaneous filters would require a redesign to collect entries for
each filter in separate ebtree. This would negatively impact performance and is
not requested for the moment. This patch prevents the crash by checking filter
combinations just after the command line parsing.

This issue was reported in GitHUB #3031.
This should be backported in all stable versions.

2 weeks agoBUG/MEDIUM: quic-be: CC buffer released from wrong pool
Frederic Lecaille [Thu, 17 Jul 2025 09:27:59 +0000 (11:27 +0200)] 
BUG/MEDIUM: quic-be: CC buffer released from wrong pool

The "connection close state" TX buffer is used to build the datagram with
basically a CONNECTION_CLOSE frame to notify the peer about the connection
closure. It allows the quic_conn memory release and its replacement by a lighter
quic_cc_conn struct.

For the QUIC backend, there is a dedicated pool to build such datagrams from
bigger TX buffers. But from quic_conn_release(), this is the pool dedicated
to the QUIC frontends which was used to release the QUIC backend TX buffers.

This patch simply adds a test about the target of the connection to release
the "connection close state" TX buffers from the correct pool.

No backport needed.

2 weeks agoDOC: connection: explain the rules for idle/safe/avail connections
Willy Tarreau [Wed, 16 Jul 2025 16:52:09 +0000 (18:52 +0200)] 
DOC: connection: explain the rules for idle/safe/avail connections

It's super difficult to find the rules that operate idle conns depending
on their idle/safe/avail/private status. Some are in lists, others not.
Some are in trees, others not. Some have a flag set, others not. This
documents the rules before the definitions in connection-t.h. It could
even be backported to help during backport sessions.

2 weeks agoMINOR: quic: Get rid of qc_is_listener()
Frederic Lecaille [Wed, 16 Jul 2025 14:35:31 +0000 (16:35 +0200)] 
MINOR: quic: Get rid of qc_is_listener()

Replace all calls to qc_is_listener() (resp. !qc_is_listener()) by calls to
objt_listener() (resp. objt_server()).
Remove qc_is_listener() implement and QUIC_FL_CONN_LISTENER the flag it
relied on.

2 weeks agoDEV: gdb: add a memprofile decoder to the debug tools
Willy Tarreau [Wed, 16 Jul 2025 12:42:34 +0000 (14:42 +0200)] 
DEV: gdb: add a memprofile decoder to the debug tools

"memprof_dump" will visit memprofile entries and dump them in a
synthetic format counting allocations/releases count/size, type
and calling address.

2 weeks agoBUG/MINOR: applet: Don't trigger BUG_ON if the tid is not on appctx init
Christopher Faulet [Wed, 16 Jul 2025 09:29:49 +0000 (11:29 +0200)] 
BUG/MINOR: applet: Don't trigger BUG_ON if the tid is not on appctx init

When an appctx is initialized, there is a BUG_ON() to be sure the appctx is
really initialized on the right thread to avoid bugs on the thread
affinity. However, it is possible to not choose the thread when the appctx
is created and let it starts on any thread. In that case, the thread
affinity is set when the appctx is initialized. So, we must take cate to not
trigger the BUG_ON() in that case.

For now, we never hit the bug because the thread affinity is always set
during the appctx creation.

This patch must be backport as far as 2.8.

2 weeks agoMINOR: h3: remove unused outbuf in h3_resp_headers_send()
Amaury Denoyelle [Tue, 15 Jul 2025 16:17:14 +0000 (18:17 +0200)] 
MINOR: h3: remove unused outbuf in h3_resp_headers_send()

Cleanup h3_resp_headers_send() by removing outbuf buffer variable which
is not necessary anymore.

2 weeks agoBUG/MINOR: quic: Wrong source address use on FreeBSD
Frederic Lecaille [Fri, 11 Jul 2025 07:02:22 +0000 (09:02 +0200)] 
BUG/MINOR: quic: Wrong source address use on FreeBSD

The bug is a listener only one, and only occured on FreeBSD.

The FreeBSD issue has been reported here:
https://forums.freebsd.org/threads/quic-http-3-with-haproxy.98443/
where QUIC traces could reveal that sendmsg() calls lead to EINVAL
syscall errnos.

Such a similar issue could be reproduced from a FreeBSD 14-2 VM
with reg-tests/quic/retry.vtc as reg test.

As noted by Olivier, this issue could be fixed within the VM binding
the listener socket to INADDR_ANY.

That said, the symptoms are not exactly the same as the one reporte by the user.
What could be observed from such a VM is that if the first recvmsg() call
returns the datagram destination address, and if the listener
listening address is bound to a specific address, the calls to
sendmsg() fail because of the IP_SENDSRCADDR ip option value
set by cmsg_set_saddr(). According to the ip(4) freebsd manual
such an IP options must be used if the listening socket is
bound to a specific address. It is to be noted that into a VM
the first call to recvmsg() of the first connection does not return the datagram
destination address. This leads the first quic_conn to be initialized without
->local_addr value. This is this value which is used by IP_SENDSRCADDR
ip option. In this case, the sendmsg() calls (without IP_SENDSRCADDR)
never fail. The issue appears at the second condition.

This patch replaces the conditions to use IP_SENDSRCADDR to a call to
qc_may_use_saddr(). This latter also checks that the listener listening
address is not INADDR_ANY to allow the use of the source address.
It is generalized to all the OSes. Indeed, there is no reason to set the source
address when the listener is bound to a specific address.

Must be backported as far as 2.8.

2 weeks agoBUG/MINOR: h3: properly handle interim response on BE side
Amaury Denoyelle [Fri, 11 Jul 2025 14:06:51 +0000 (16:06 +0200)] 
BUG/MINOR: h3: properly handle interim response on BE side

On backend side, H3 layer is responsible to decode a HTTP/3 response
into an HTX message. Multiple responses may be received on a single
stream with interim status codes prior to the final one.

h3_resp_headers_to_htx() is the function used solely on backend side
responsible for H3 response to HTX transcoding. This patch extends it to
be able to properly support interim responses. When such a response is
received, the new flag H3_SF_RECV_INTERIM is set. This is converted to
QMUX qcs flag QC_SF_EOI_SUSPENDED.

The objective of this latter flag is to prevent stream EOI to be
reported during stream rcv_buf callback, even if HTX message contains
EOM and is empty. QC_SF_EOI_SUSPENDED will be cleared when the final
response is finally converted, which unblock stream EOI notification for
next rcv_buf invocations. Note however that HTX EOM is untouched : it is
always set for both interim and final response reception.

As a minor adjustment, HTX_SL_F_BODYLESS is always set for interim
responses.

Contrary to frontend interim response handling, a flag is necessary on
QMUX layer. This is because H3 to HTX transcoding and rcv_buf callback
are two distinct operations, called under different context (MUX vs
stream tasklet).

Also note that H3 layer has two distinct flags for interim response
handling, one only used as a server (FE side) and the other as a client
(BE side). It was preferred to used two distinct flags which is
considered less error-prone, contrary to a single unified flag which
would require to always set the proxy side to ensure it is relevant or
not.

No need to backport.

2 weeks agoBUG/MEDIUM: h3: handle interim response properly on FE side
Amaury Denoyelle [Fri, 11 Jul 2025 12:25:30 +0000 (14:25 +0200)] 
BUG/MEDIUM: h3: handle interim response properly on FE side

On frontend side, HTTP/3 layer is responsible to transcode an HTX
response message into HTTP/3 HEADERS frame. This operations is handled
via h3_resp_headers_send().

Prior to this patch, if HTX EOM was encountered in the HTX message after
response transcoding, <fin> was reported to the QMUX layer. This will in
turn cause FIN stream bit to be set when the response is emitted.
However, this is not correct as a single HTX response can be constitued
of several interim message, each delimited by EOM block.

Most of the time, this bug will cause the client to close the connection
as it is invalid to receive an interim response with FIN bit set.

Fixes this by now properly differentiate interim and final response.
During interim response transcoding, the new flag H3_SF_SENT_INTERIM
will be set, which will prevent <fin> to be reported. Thus, <fin> will
only be notified for the final response.

This must be backported up to 2.6. Note that it relies on the previous
patch which also must be taken.

2 weeks agoMINOR: qmux: change API for snd_buf FIN transmission
Amaury Denoyelle [Thu, 10 Jul 2025 13:27:23 +0000 (15:27 +0200)] 
MINOR: qmux: change API for snd_buf FIN transmission

Previous patches have fixes interim response encoding via
h3_resp_headers_send(). However, it is still necessary to adjust h3
layer state-machine so that several successive HTTP responses are
accepted for a single stream.

Prior to this, QMUX was responsible to decree that the final HTX message
was encoded so that FIN stream can be emitted. However, with interim
response, MUX is in fact unable to properly determine this. As such,
this is the responsibility of the application protocol layer. To reflect
this, app_ops snd_buf callback is modified so that a new output argument
<fin> is added to it.

Note that for now this commit does not bring any functional change.
However, it will be necessary for the following patch. As such, it
should be backported prior to it to every versions as necessary.

2 weeks agoBUG/MINOR: h3: ensure that invalid status code are not encoded (FE side)
Amaury Denoyelle [Tue, 15 Jul 2025 16:15:36 +0000 (18:15 +0200)] 
BUG/MINOR: h3: ensure that invalid status code are not encoded (FE side)

On frontend side, H3 layer transcodes HTX status code into HTTP/3
HEADERS frame. This is done by calling qpack_encode_int_status().

Prior to this patch, the latter function was also responsible to reject
an invalid value, which guarantee that only valid codes are encoded
(between 100 and 999 values). However, this is not practical as it is
impossible to differentiate between an invalid code error and a buffer
room exhaustation.

Changes this so that now HTTP/3 layer first ensures that HTX code is
valid. The stream is closed with H3_INTERNAL_ERROR if invalid value is
present. Thus, qpack_encode_int_status() will only report an error due
to buffer room exhaustion. If a small buffer is used, a standard buffer
will be reallocated which should be sufficient to encode the response.

The impact of this bug is minimal. Its main benefit is code clarity,
while also removing an unnecessary realloc when confronting with an
invalid HTTP code.

This should be backported at least up to 3.1. Prior to it, smallbuf
mechanism isn't present, hence the impact of this patch is less
important. However, it may still be backported to older versions, which
should facilitate picking patches for HTTP 1xx interim response support.

2 weeks agoBUG/MINOR: h3: properly realloc buffer after interim response encoding
Amaury Denoyelle [Tue, 15 Jul 2025 08:59:07 +0000 (10:59 +0200)] 
BUG/MINOR: h3: properly realloc buffer after interim response encoding

Previous commit fixes encoding of several following HTTP response
message when interim status codes are first reported. However,
h3_resp_headers_send() still was unable to interrupt encoding if output
buffer room was not sufficient. This case may be likely because small
buffers are used for headers encoding.

This commit fixes this situation. If output buffer is not empty prior to
response encoding, this means that a previous interim response message
was already encoded before. In this case, and if remaining space is not
sufficient, use buffer release mechanism : this allows to restart
response encoding by using a newer buffer. This process has already been
used for DATA and trailers encoding.

This must be backported up to 2.6. However, note that buffer release
mechanism is not present for version 2.8 and lower. In this case, qcs
flag QC_SF_BLK_MROOM should be enough as a replacement.

2 weeks agoBUG/MEDIUM: h3: do not overwrite interim with final response
Amaury Denoyelle [Tue, 15 Jul 2025 08:58:06 +0000 (10:58 +0200)] 
BUG/MEDIUM: h3: do not overwrite interim with final response

An HTTP response may contain several interim response message prior (1xx
status) to a final response message (all other status codes). This may
cause issues with h3_resp_headers_send() called for response encoding
which assumes that it is only call one time per stream, most notably
during output buffer handling.

This commit fixes output buffer handling when h3_resp_headers_send() is
called multiple times due to an interim response. Prior to it, interim
response was overwritten with newer response message. Most of the time,
this resulted in error for the client due to QPACK decoding failure.
This is now fixed so that each response is encoded one after the other.

Note that if encoding of several responses is bigger than output buffer,
an error is reported. This can definitely occurs as small buffer are
used during header encoding. This situation will be improved by the next
patch.

This must be backported up to 2.6.

2 weeks agoMINOR: debug: report haproxy and operating system info in panic dumps
Willy Tarreau [Tue, 15 Jul 2025 13:21:23 +0000 (15:21 +0200)] 
MINOR: debug: report haproxy and operating system info in panic dumps

The goal is to help figure the OS version (kernel and userland), any
virtualization/containers, and the haproxy version and build features.
Sometimes even reporters themselve can be mistaken about the running
version or environment. Also printing this at the top hepls draw a
visual delimitation between warnings and panic. Now we get something
like this:

  PANIC! Thread 1 is about to kill the process.

  HAProxy info:
    version: 3.3-dev3-c863c0-18
    features: +51DEGREES +ACCEPT4 +BACKTRACE -CLOSEFROM +CPU_AFFINITY (...)

  Operating system info:
    virtual machine: no
    container: no
    kernel: Linux 6.1.131 #1 SMP PREEMPT_DYNAMIC Fri Mar 14 01:04:55 CET 2025 x86_64
    userland: Slackware 15.0 x86_64

  * Thread 1 : id=0x7f615a8775c0 act=1 glob=0 wq=1 rq=0 tl=0 tlsz=0 rqsz=0
        1/1    stuck=0 prof=0 harmless=0 isolated=0
               cpu_ns: poll=1835010197 now=1835066102 diff=55905
               (...)

2 weeks agoMEDIUM: proxy: register a post-section cleanup function
Willy Tarreau [Fri, 11 Jul 2025 06:58:48 +0000 (08:58 +0200)] 
MEDIUM: proxy: register a post-section cleanup function

For listen/frontend/backend, we now want to be able to clean up the
default-server directive that's no longer used past the end of the
section. For this we register a post-section function and perform the
cleanup there.

2 weeks agoMEDIUM: proxy: no longer allocate the default-server entry by default
Willy Tarreau [Fri, 11 Jul 2025 06:40:17 +0000 (08:40 +0200)] 
MEDIUM: proxy: no longer allocate the default-server entry by default

The default-server entry used to always be allocated. Now we'll postpone
its allocation for the first time we need it, i.e. during a "default-server"
directive, or when inheriting a defaults section which has one. The memory
savings are significant, on a large configuration with 100k backends and
no default-server directive, the memory usage dropped from 800MB RSS to
420MB (380 MB saved). It should be possible to also address configs using
default-server by releasing this entry when leaving the proxy section,
which is not done yet.

2 weeks agoMINOR: proxy: add checks for defsrv's validity
Willy Tarreau [Thu, 10 Jul 2025 15:03:13 +0000 (17:03 +0200)] 
MINOR: proxy: add checks for defsrv's validity

Now we only copy the default server's settings if such a default server
exists, otherwise we only initialize it. At the moment it always exists.

The change is mostly performed in srv_settings_cpy() since that's where
each caller passes through, and there's no point duplicating that test
everywhere.

2 weeks agoMEDIUM: proxy: take the defsrv out of the struct proxy
Willy Tarreau [Thu, 10 Jul 2025 14:16:24 +0000 (16:16 +0200)] 
MEDIUM: proxy: take the defsrv out of the struct proxy

The server struct has gone huge over time (~3.8kB), and having a copy
of it in the defsrv section of the struct proxy costs a lot of RAM,
that is not needed anymore at run time.

This patch replaces this struct with a dynamically allocated one. The
field is allocated and initialized during alloc_new_proxy() and is
freed when the proxy is destroyed for now. But the goal will be to
support freeing it after parsing the section.

2 weeks agoCLEANUP: server: be sure never to compare src against a non-existing defsrv
Willy Tarreau [Thu, 10 Jul 2025 14:42:42 +0000 (16:42 +0200)] 
CLEANUP: server: be sure never to compare src against a non-existing defsrv

The test in srv_ssl_settings_cpy() comparing src to the server's proxy's
default server does work but it's a subtle trap. Indeed, no check is made
on srv->proxy to be valid, and this only works because the compiler is
comparing pointer offsets. During the boot, it's common to have NULL here
in srv->proxy and of course in this case srv does not match that value
which is NULL plus epsilon. But when trying to turn defsrv to a dynamic
pointer instead, then the compiler is forced to dereference this NULL
srv->proxy and dies during init.

Let's always add the null check for srv->proxy before the test to avoid
this situation.

No backport is needed since the problem cannot happen yet.

2 weeks agoCLEANUP: stream: use server_find_by_addr() in sticking_rule_find_target()
Willy Tarreau [Thu, 10 Jul 2025 12:47:35 +0000 (14:47 +0200)] 
CLEANUP: stream: use server_find_by_addr() in sticking_rule_find_target()

This makes this function a bit less of a mess by no longer manipulating
the low-level server address nodes nor the proxy lock.

2 weeks agoCLEANUP: server: add server_find_by_addr()
Willy Tarreau [Thu, 10 Jul 2025 12:43:28 +0000 (14:43 +0200)] 
CLEANUP: server: add server_find_by_addr()

Server lookup by address requires locking and manipulation of the tree
from user code. Let's provide server_find_by_addr() which does that for
us.

2 weeks agoCLEANUP: server: simplify server_find_by_id()
Willy Tarreau [Wed, 9 Jul 2025 14:35:27 +0000 (16:35 +0200)] 
CLEANUP: server: simplify server_find_by_id()

At a few places we're seeing some open-coding of the same function, likely
because it looks overkill for what it's supposed to do, due to extraneous
tests that are not needed (e.g. check of the backend's PR_CAP_BE etc).
Let's just remove all these superfluous tests and inline it so that it
feels more suitable for use everywhere it's needed.

2 weeks agoCLEANUP: stream: lookup server ID using standard functions
Willy Tarreau [Wed, 9 Jul 2025 14:20:09 +0000 (16:20 +0200)] 
CLEANUP: stream: lookup server ID using standard functions

The server lookup in sticking_rule_find_target() uses an open-coded tree
search while we have a function for this server_find_by_id(). In addition,
due to the way it's coded, the stick-table lock also covers the server
lookup by accident instead of being released earlier. This is not a real
problem though since such feature is rarely used nowadays.

Let's clean all this stuff by first retrieving the ID under the lock and
then looking up the corresponding server.

2 weeks agoCLEANUP: cfgparse: lookup proxy ID using existing functions
Willy Tarreau [Wed, 9 Jul 2025 14:13:44 +0000 (16:13 +0200)] 
CLEANUP: cfgparse: lookup proxy ID using existing functions

The code used to detect proxy id conflicts uses an open-coded lookup
in the ID tree which is not necessary since we already have functions
for this. Let's switch to that instead.

2 weeks agoCLEANUP: server: use server_find_by_name() where relevant
Willy Tarreau [Thu, 10 Jul 2025 09:10:36 +0000 (11:10 +0200)] 
CLEANUP: server: use server_find_by_name() where relevant

Instead of open-coding a tree lookup, in sticking rules and server_find(),
let's just rely on server_find_by_name() which now does exactly the same.

2 weeks agoCLEANUP: server: rename findserver() to server_find_by_name()
Willy Tarreau [Thu, 10 Jul 2025 09:07:51 +0000 (11:07 +0200)] 
CLEANUP: server: rename findserver() to server_find_by_name()

Now it's more logical and matches what is done in the rest of these
functions. server_find() now relies on it.

2 weeks agoCLEANUP: server: rename server_find_by_name() to server_find()
Willy Tarreau [Thu, 10 Jul 2025 08:59:06 +0000 (10:59 +0200)] 
CLEANUP: server: rename server_find_by_name() to server_find()

This function doesn't just look at the name but also the ID when the
argument starts with a '#'. So the name is not correct and explains
why this function is not always used when the name only is needed,
and why the list-based findserver() is used instead. So let's just
call the function "server_find()", and rename its generation-id based
cousin "server_find_unique()".

2 weeks agoMINOR: server: use the tree to look up the server name in findserver()
Willy Tarreau [Thu, 10 Jul 2025 09:06:41 +0000 (11:06 +0200)] 
MINOR: server: use the tree to look up the server name in findserver()

Let's just use the tree-based lookup instead of walking through the list.
This function is used to find duplicates in "track" statements and a few
such places, so it's important not to waste too much time on large setups.

2 weeks agoREORG: server: move findserver() from proxy.c to server.c
Willy Tarreau [Thu, 10 Jul 2025 08:56:34 +0000 (10:56 +0200)] 
REORG: server: move findserver() from proxy.c to server.c

The reason this function was overlooked is that it had mostly equivalent
ones in server.c, let's move them together.

2 weeks agoCLEANUP: server: do not check for duplicates anymore in findserver()
Willy Tarreau [Thu, 10 Jul 2025 08:48:05 +0000 (10:48 +0200)] 
CLEANUP: server: do not check for duplicates anymore in findserver()

findserver() used to check for duplicate server names. These are no
longer accepted in 3.3 so let's get rid of that test and simplify the
code. Note that the function still only uses the list instead of the
tree.

3 weeks ago[RELEASE] Released version 3.3-dev3 v3.3-dev3
Willy Tarreau [Fri, 11 Jul 2025 14:45:50 +0000 (16:45 +0200)] 
[RELEASE] Released version 3.3-dev3

Released version 3.3-dev3 with the following main changes :
    - BUG/MINOR: quic-be: Wrong retry_source_connection_id check
    - MEDIUM: sink: change the sink mode type to PR_MODE_SYSLOG
    - MEDIUM: server: move _srv_check_proxy_mode() checks from server init to finalize
    - MINOR: server: move send-proxy* incompatibility check in _srv_check_proxy_mode()
    - MINOR: mailers: warn if mailers are configured but not actually used
    - BUG/MEDIUM: counters/server: fix server and proxy last_change mixup
    - MEDIUM: server: add and use a separate last_change variable for internal use
    - MEDIUM: proxy: add and use a separate last_change variable for internal use
    - MINOR: counters: rename last_change counter to last_state_change
    - MINOR: ssl: check TLS1.3 ciphersuites again in clienthello with recent AWS-LC
    - BUG/MEDIUM: hlua: Forbid any L6/L7 sample fetche functions from lua services
    - BUG/MEDIUM: mux-h2: Properly handle connection error during preface sending
    - BUG/MINOR: jwt: Copy input and parameters in dedicated buffers in jwt_verify converter
    - DOC: Fix 'jwt_verify' converter doc
    - MINOR: jwt: Rename pkey to pubkey in jwt_cert_tree_entry struct
    - MINOR: jwt: Remove unused parameter in convert_ecdsa_sig
    - MAJOR: jwt: Allow certificate instead of public key in jwt_verify converter
    - MINOR: ssl: Allow 'commit ssl cert' with no privkey
    - MINOR: ssl: Prevent delete on certificate used by jwt_verify
    - REGTESTS: jwt: Add test with actual certificate passed to jwt_verify
    - REGTESTS: jwt: Test update of certificate used in jwt_verify
    - DOC: 'jwt_verify' converter now supports certificates
    - REGTESTS: restrict execution to a single thread group
    - MINOR: ssl: Introduce new smp_client_hello_parse() function
    - MEDIUM: stats: add persistent state to typed output format
    - BUG/MINOR: httpclient: wrongly named httpproxy flag
    - MINOR: ssl/ocsp: stop using the flags from the httpclient CLI
    - MEDIUM: httpclient: split the CLI from the actual httpclient API
    - MEDIUM: httpclient: implement a way to use directly htx data
    - MINOR: httpclient/cli: add --htx option
    - BUILD: dev/phash: remove the accidentally committed a.out file
    - BUG/MINOR: ssl: crash in ssl_sock_io_cb() with SSL traces and idle connections
    - BUILD/MEDIUM: deviceatlas: fix when installed in custom locations.
    - DOC: deviceatlas build clarifications
    - BUG/MINOR: ssl/ocsp: fix definition discrepancies with ocsp_update_init()
    - MINOR: proto-tcp: Add support for TCP MD5 signature for listeners and servers
    - BUILD: cfgparse-tcp: Add _GNU_SOURCE for TCP_MD5SIG_MAXKEYLEN
    - BUG/MINOR: proto-tcp: Take care to initialized tcp_md5sig structure
    - BUG/MINOR: http-act: Fix parsing of the expression argument for pause action
    - MEDIUM: httpclient: add a Content-Length when the payload is known
    - CLEANUP: ssl: Rename ssl_trace-t.h to ssl_trace.h
    - MINOR: pattern: add a counter of added/freed patterns
    - CI: set DEBUG_STRICT=2 for coverity scan
    - CI: enable USE_QUIC=1 for OpenSSL versions >= 3.5.0
    - CI: github: add an OpenSSL 3.5.0 job
    - CI: github: update the stable CI to ubuntu-24.04
    - BUG/MEDIUM: quic: SSL/TCP handshake failures with OpenSSL 3.5
    - CI: github: update to OpenSSL 3.5.1
    - BUG/MINOR: quic: Missing TLS 1.3 QUIC cipher suites and groups inits (OpenSSL 3.5 QUIC API)
    - BUG/MINOR: quic-be: Malformed coalesced Initial packets
    - MINOR: quic: Prevent QUIC backend use with the OpenSSL QUIC compatibility module (USE_OPENSS_COMPAT)
    - MINOR: reg-tests: first QUIC+H3 reg tests (QUIC address validation)
    - MINOR: quic-be: Set the backend alpn if not set by conf
    - MINOR: quic-be: TLS version restriction to 1.3
    - MINOR: cfgparse: enforce QUIC MUX compat on server line
    - MINOR: server: support QUIC for dynamic servers
    - CI: github: skip a ssl library version when latest is already in the list
    - MEDIUM: resolvers: switch dns-accept-family to "auto" by default
    - BUG/MINOR: resolvers: don't lower the case of binary DNS format
    - MINOR: resolvers: do not duplicate the hostname_dn field
    - MINOR: proto-tcp: Register a feature to report TCP MD5 signature support
    - BUG/MINOR: listener: really assign distinct IDs to shards
    - MINOR: quic: Prevent QUIC build with OpenSSL 3.5 new QUIC API version < 3.5.1
    - BUG/MEDIUM: quic: Crash after QUIC server callbacks restoration (OpenSSL 3.5)
    - REGTESTS: use two haproxy instances to distinguish the QUIC traces
    - BUG/MEDIUM: http-client: Don't wake http-client applet if nothing was xferred
    - BUG/MEDIUM: http-client: Properly inc input data when HTX blocks are xferred
    - BUG/MEDIUM: http-client: Ask for more room when request data cannot be xferred
    - BUG/MEDIUM: http-client: Test HTX_FL_EOM flag before commiting the HTX buffer
    - BUG/MINOR: http-client: Ignore 1XX interim responses in non-HTX mode
    - BUG/MINOR: http-client: Reject any 101-switching-protocols response
    - BUG/MEDIUM: http-client: Drain the request if an early response is received
    - BUG/MEDIUM: http-client: Notify applet has more data to deliver until the EOM
    - BUG/MINOR: h3: fix https scheme request encoding for BE side
    - MINOR: h1-htx: Add function to format an HTX message in its H1 representation
    - BUG/MINOR: mux-h1: Use configured error files if possible for early H1 errors
    - BUG/MINOR: h1-htx: Don't forget to init flags in h1_format_htx_msg function
    - CLEANUP: assorted typo fixes in the code, commits and doc
    - BUILD: adjust scripts/build-ssl.sh to modern CMake system of QuicTLS
    - MINOR: debug: add distro name and version in postmortem

3 weeks agoMINOR: debug: add distro name and version in postmortem
Valentine Krasnobaeva [Thu, 10 Jul 2025 08:59:57 +0000 (10:59 +0200)] 
MINOR: debug: add distro name and version in postmortem

Since 2012, systemd compliant distributions contain
/etc/os-release file. This file has some standardized format, see details at
https://www.freedesktop.org/software/systemd/man/latest/os-release.html.

Let's read it in feed_post_mortem_linux() to gather more info about the
distribution.

(cherry picked from commit f1594c41368baf8f60737b229e4359fa7e1289a9)
Signed-off-by: Willy Tarreau <w@1wt.eu>
3 weeks agoBUILD: adjust scripts/build-ssl.sh to modern CMake system of QuicTLS
Ilia Shipitsin [Thu, 10 Jul 2025 18:12:35 +0000 (20:12 +0200)] 
BUILD: adjust scripts/build-ssl.sh to modern CMake system of QuicTLS

QuicTLS in master branch has migrated to CMake, let's adopt script to
it. Previous OpenSSL+QuicTLS patch is built as usual.

3 weeks agoCLEANUP: assorted typo fixes in the code, commits and doc
Ilia Shipitsin [Wed, 9 Jul 2025 19:05:55 +0000 (21:05 +0200)] 
CLEANUP: assorted typo fixes in the code, commits and doc

Corrected various spelling and phrasing errors to improve clarity and consistency.

3 weeks agoBUG/MINOR: h1-htx: Don't forget to init flags in h1_format_htx_msg function
Christopher Faulet [Thu, 10 Jul 2025 12:10:41 +0000 (14:10 +0200)] 
BUG/MINOR: h1-htx: Don't forget to init flags in h1_format_htx_msg function

The regression was introduced by commit 187ae28 ("MINOR: h1-htx: Add
function to format an HTX message in its H1 representation"). We must be
sure the flags variable must be initialized in h1_format_htx_msg() function.

This patch must be backported with the commit above.

3 weeks agoBUG/MINOR: mux-h1: Use configured error files if possible for early H1 errors
Christopher Faulet [Thu, 10 Jul 2025 08:10:37 +0000 (10:10 +0200)] 
BUG/MINOR: mux-h1: Use configured error files if possible for early H1 errors

The H1 multiplexer is able to produce some errors on its own to report early
errors, before the stream is created. In that case, the error files of the
proxy were tested to detect empty files (or /dev/null) but they were not
used to produce the error itself.

But the documentation states that configured error files are used in all
cases. And in fact, it is not really a problem to use these files. We must
just format a full HTX message. Thanks to the previous patch, it is now
possible.

This patch should fix the issue #3032. It should be backported to 3.2. For
older versions, it must be discussed but it should be quite easy to do.

3 weeks agoMINOR: h1-htx: Add function to format an HTX message in its H1 representation
Christopher Faulet [Thu, 10 Jul 2025 08:06:13 +0000 (10:06 +0200)] 
MINOR: h1-htx: Add function to format an HTX message in its H1 representation

The function h1_format_htx_msg() can now be used to convert a valid HTX
message in its H1 representation. No validity test is performed, the HTX
message must be valid. Only trailers are silently ignored if the message is
not chunked. In addition, the destination buffer must be empty. 1XX interim
responses should be supported. But again, there is no validity tests.

3 weeks agoBUG/MINOR: h3: fix https scheme request encoding for BE side
Amaury Denoyelle [Wed, 9 Jul 2025 15:30:29 +0000 (17:30 +0200)] 
BUG/MINOR: h3: fix https scheme request encoding for BE side

An HTTP/3 request must contains :scheme pseudo-header. Currently, only
"https" value is expected due to QUIC transport layer in use.

However, https value is incorrectly encoded due to a QPACK index value
mismatch in qpack_encode_scheme(). Fix it to ensure that scheme is now
properly set for HTTP/3 requests on the backend side.

No need to backport this.

3 weeks agoBUG/MEDIUM: http-client: Notify applet has more data to deliver until the EOM
Christopher Faulet [Wed, 9 Jul 2025 13:20:41 +0000 (15:20 +0200)] 
BUG/MEDIUM: http-client: Notify applet has more data to deliver until the EOM

When we leave the I/O handler with an unfinished request, we must report the
applet has more data to deliver. Otherwise, when the channel request buffer
is emptied, the http-client applet is not always woken up to forward the
remaining request data.

This issue was probably revealed by commit "BUG/MEDIUM: http-client: Don't
wake http-client applet if nothing was xferred". It is only an issue with
large POSTs, when the payload is streamed.

This patch must be backported as far as 2.6 with the commit above. But on
older versions, the applet API may differ. So be careful.

3 weeks agoBUG/MEDIUM: http-client: Drain the request if an early response is received
Christopher Faulet [Tue, 8 Jul 2025 06:45:10 +0000 (08:45 +0200)] 
BUG/MEDIUM: http-client: Drain the request if an early response is received

When a large request is sent, it is possible to have a response before the
end of the request. It is valid from HTTP perspective but it is an issue
with the current design of the http-client. Indded, the request and the
response are handled sequentially. So the response will be blocked, waiting
for the end of the request. Most of time, it is not an issue, except when
the request transfer is blocked. In that case, the applet is blocked.

With the current API, it is not possible to handle early response and
continue the request transfer. So, this case cannot be handle. In that case,
it seems reasonnable to drain the request if a response is received. This
way, the request transfer, from the caller point of view, is never blocked
and the response can be properly processed.

To do so, the action flag HTTPCLIENT_FA_DRAIN_REQ is added to the
http-client. When it is set, the request payload is just dropped. In that
case, we take care to not report the end of input to properly report the
request was truncated, especially in logs.

It is only an issue with large POSTs, when the payload is streamed.

This patch must be backported as far as 2.6.

3 weeks agoBUG/MINOR: http-client: Reject any 101-switching-protocols response
Christopher Faulet [Tue, 8 Jul 2025 06:57:16 +0000 (08:57 +0200)] 
BUG/MINOR: http-client: Reject any 101-switching-protocols response

Protocol updages are not supported by the http-client. So report an error is
a 101-switching-protocols response is received. Of course, it is unexpected
because the API is not designed to support upgrades. But it is better to
properly handle this case.

This patch could be backported as far as 2.6. It depends on the commit
"BUG/MINOR: http-client: Ignore 1XX interim responses in non-HTX mode".

3 weeks agoBUG/MINOR: http-client: Ignore 1XX interim responses in non-HTX mode
Christopher Faulet [Tue, 8 Jul 2025 06:38:31 +0000 (08:38 +0200)] 
BUG/MINOR: http-client: Ignore 1XX interim responses in non-HTX mode

When the response is re-formatted in raw message, the 1XX interim responses
must be skipped. Otherwise, information of the first interim response will
be saved (status line and headers) and those from the final response will be
dropped.

Note that for now, in HTX-mode, the interim messages are removed.

This patch must be backported as far as 2.6.