blob: e1be317b1fb10f6bc9ad6df251a92105a5f1f079 [file] [log] [blame]
willy tarreau036e1ce2005-12-17 13:46:33 +01001ChangeLog :
2===========
willy tarreau4302f492005-12-18 01:00:37 +01003
Willy Tarreau9de10ce2023-04-28 21:52:13 +020042023/04/28 : 2.8-dev9
5 - MINOR: quic: Move traces at proto level
6 - BUG/MINOR: quic: Possible memory leak from TX packets
7 - BUG/MINOR: quic: Possible leak during probing retransmissions
8 - BUG/MINOR: quic: Useless probing retransmission in draining or killing state
9 - BUG/MINOR: quic: Useless I/O handler task wakeups (draining, killing state)
10 - CLEANUP: quic: rename frame types with an explicit prefix
11 - CLEANUP: quic: rename frame variables
12 - CLEANUP: quic: Remove useless parameters passes to qc_purge_tx_buf()
13 - CLEANUP: quic: Rename <buf> variable to <token> in quic_generate_retry_token()
14 - CLEANUP: quic: Rename <buf> variable into quic_padding_check()
15 - CLEANUP: quic: Rename <buf> variable into quic_rx_pkt_parse()
16 - CLEANUP: quic: Rename <buf> variable for several low level functions
17 - CLEANUP: quic: Make qc_build_pkt() be more readable
18 - CLEANUP: quic: Rename quic_get_dgram_dcid() <buf> variable
19 - CLEANUP: quic: Rename several <buf> variables at low level
20 - CLEANUP: quic: Rename <buf> variable into quic_packet_read_long_header()
21 - CLEANUP: quic: Rename <buf> variable into qc_parse_hd_form()
22 - CLEANUP: quic: Rename several <buf> variables into quic_sock.c
23 - DEBUG: crash using an invalid opcode on x86/x86_64 instead of an invalid access
24 - DEBUG: crash using an invalid opcode on aarch64 instead of an invalid access
25 - DEV: h2: add a script "mkhdr" to build h2 frames from scratch
26 - DEV: h2: support reading frame payload from a file
27 - MINOR: acme.sh: add the deploy script for acme.sh in admin directory
28 - BUG/MEDIUM: mux-quic: do not emit RESET_STREAM for unknown length
29 - BUG/MEDIUM: mux-quic: improve streams fairness to prevent early timeout
30 - BUG/MINOR: quic: prevent buggy memcpy for empty STREAM
31 - MINOR: mux-quic: do not set buffer for empty STREAM frame
32 - MINOR: mux-quic: do not allocate Tx buf for empty STREAM frame
33 - MINOR: quic: finalize affinity change as soon as possible
34 - BUG/MINOR: quic: fix race on quic_conns list during affinity rebind
35 - CI: switch to Fastly CDN to download LibreSSL
36 - BUILD: ssl: switch LibreSSL to Fastly CDN
37 - BUG/MINOR: clock: fix a few occurrences of 'now' being used in place of 'date'
38 - BUG/MINOR: spoe: use "date" not "now" in debug messages
39 - BUG/MINOR: activity: show wall-clock date, not internal date in show activity
40 - BUG/MINOR: opentracing: use 'date' instead of 'now' in debug output
41 - Revert "BUG/MINOR: clock: fix a few occurrences of 'now' being used in place of 'date'"
42 - BUG/MINOR: calltrace: fix 'now' being used in place of 'date'
43 - BUG/MINOR: trace: show wall-clock date, not internal date in show activity
44 - BUG/MINOR: hlua: return wall-clock date, not internal date in core.now()
45 - BUG/MEDIUM: spoe: Don't start new applet if there are enough idle ones
46 - BUG/MINOR: stconn: Fix SC flags with same value
47 - BUG/MINOR: resolvers: Use sc_need_room() to wait more room when dumping stats
48 - BUG/MEDIUM: tcpcheck: Don't eval custom expect rule on an empty buffer
49 - BUG/MINOR: stats: report the correct start date in "show info"
50 - MINOR: time: add conversions to/from nanosecond timestamps
51 - MINOR: time: replace calls to tv_ms_elapsed() with a linear subtract
52 - MINOR: spoe: switch the timeval-based timestamps to nanosecond timestamps
53 - MEDIUM: tree-wide: replace timeval with nanoseconds in tv_accept and tv_request
54 - MINOR: stats: use nanoseconds, not timeval to compute uptime
55 - MINOR: activity: use nanoseconds, not timeval to compute uptime
56 - MINOR: checks: use a nanosecond counters instead of timeval for checks->start
57 - MINOR: clock: do not use now.tv_sec anymore
58 - MEDIUM: clock: replace timeval "now" with integer "now_ns"
59 - MINOR: clock: replace the timeval start_time with start_time_ns
60 - MINOR: sample: Add bc_rtt and bc_rttvar
61 - MINOR: quic: use real sending rate measurement
62 - MINOR: proxy: factorize send rate measurement
63
Willy Tarreau3b50e5c2023-04-23 10:21:37 +0200642023/04/23 : 2.8-dev8
65 - BUG/MEDIUM: cli: Set SE_FL_EOI flag for '_getsocks' and 'quit' commands
66 - BUG/MEDIUM: cli: Eat output data when waiting for appctx shutdown
67 - BUG/MEDIUM: http-client: Eat output data when waiting for appctx shutdown
68 - BUG/MEDIUM: stats: Eat output data when waiting for appctx shutdown
69 - BUG/MEDIUM: log: Eat output data when waiting for appctx shutdown
70 - BUG/MEDIUM: dns: Kill idle DNS sessions during stopping stage
71 - BUG/MINOR: resolvers: Wakeup DNS idle task on stopping
72 - BUG/MEDIUM: resolvers: Force the connect timeout for DNS resolutions
73 - MINOR: hlua: Stop to check the SC state when executing a hlua cli command
74 - BUG/MEDIUM: mux-h1: Report EOI when a TCP connection is upgraded to H2
75 - BUG/MEDIUM: mux-h2: Never set SE_FL_EOS without SE_FL_EOI or SE_FL_ERROR
76 - MINOR: quic: Trace fix in quic_pto_pktns() (handshaske status)
77 - BUG/MINOR: quic: Wrong packet number space probing before confirmed handshake
78 - MINOR: quic: Modify qc_try_rm_hp() traces
79 - MINOR: quic: Dump more information at proto level when building packets
80 - MINOR: quic: Add a trace for packet with an ACK frame
81 - MINOR: activity: add a line reporting the average CPU usage to "show activity"
82 - BUG/MINOR: stick_table: alert when type len has incorrect characters
83 - MINOR: thread: keep a bitmask of enabled groups in thread_set
84 - MINOR: fd: optimize fd_claim_tgid() for use in fd_insert()
85 - MINOR: fd: add a lock bit with the tgid
86 - MINOR: fd: implement fd_migrate_on() to migrate on a non-local thread
87 - MINOR: receiver: reserve special values for "shards"
88 - MINOR: bind-conf: support a new shards value: "by-group"
89 - BUG/MEDIUM: fd: don't wait for tmask to stabilize if we're not in it.
90 - MINOR: quic: Add packet loss and maximum cc window to "show quic"
91 - BUG/MINOR: quic: Ignored less than 1ms RTTs
92 - MINOR: quic: Add connection flags to traces
93 - BUG/MEDIUM: quic: Code sanitization about acknowledgements requirements
94 - BUG/MINOR: quic: Possible wrapped values used as ACK tree purging limit.
95 - BUG/MINOR: quic: SIGFPE in quic_cubic_update()
96 - MINOR: quic: Display the packet number space flags in traces
97 - MINOR: quic: Remove a useless test about probing in qc_prep_pkts()
98 - BUG/MINOR: quic: Wrong Application encryption level selection when probing
99 - CI: bump "actions/checkout" to v3 for cross zoo matrix
100 - CI: enable monthly test on Fedora Rawhide
101 - BUG/MINOR: stream: Fix test on SE_FL_ERROR on the wrong entity
102 - BUG/MEDIUM: stream: Report write timeouts before testing the flags
103 - BUG/MEDIUM: stconn: Do nothing in sc_conn_recv() when the SC needs more room
104 - MINOR: stream: Uninline and export sess_set_term_flags() function
105 - MINOR: filters: Review and simplify errors handling
106 - REGTESTS: fix the race conditions in log_uri.vtc
107 - MINOR: channel: Forwad close to other side on abort
108 - MINOR: stream: Introduce stream_abort() to abort on both sides in same time
109 - MINOR: stconn: Rename SC_FL_SHUTR_NOW in SC_FL_ABRT_WANTED
110 - MINOR: channel/stconn: Replace channel_shutr_now() by sc_schedule_abort()
111 - MINOR: stconn: Rename SC_FL_SHUTW_NOW in SC_FL_SHUT_WANTED
112 - MINOR: channel/stconn: Replace channel_shutw_now() by sc_schedule_shutdown()
113 - MINOR: stconn: Rename SC_FL_SHUTR in SC_FL_ABRT_DONE
114 - MINOR: channel/stconn: Replace sc_shutr() by sc_abort()
115 - MINOR: stconn: Rename SC_FL_SHUTW in SC_FL_SHUT_DONE
116 - MINOR: channel/stconn: Replace sc_shutw() by sc_shutdown()
117 - MINOR: tree-wide: Replace several chn_cons() by the corresponding SC
118 - MINOR: tree-wide: Replace several chn_prod() by the corresponding SC
119 - BUG/MINOR: cli: Don't close when SE_FL_ERR_PENDING is set in cli analyzer
120 - MINOR: stconn: Stop to set SE_FL_ERROR on sending path
121 - MEDIUM: stconn: Forbid applets with more to deliver if EOI was reached
122 - MINOR: stconn: Don't clear SE_FL_ERROR when endpoint is reset
123 - MINOR: stconn: Add a flag to ack endpoint errors at SC level
124 - MINOR: backend: Set SC_FL_ERROR on connection error
125 - MINOR: stream: Set SC_FL_ERROR on channels' buffer allocation error
126 - MINOR: tree-wide: Test SC_FL_ERROR with SE_FL_ERROR from upper layer
127 - MEDIUM: tree-wide: Stop to set SE_FL_ERROR from upper layer
128 - MEDIUM: backend: Stop to use SE flags to detect connection errors
129 - MEDIUM: stream: Stop to use SE flags to detect read errors from analyzers
130 - MEDIUM: stream: Stop to use SE flags to detect endpoint errors
131 - MEDIUM: stconn: Rely on SC flags to handle errors instead of SE flags
132 - BUG/MINOR: stconn: Don't set SE_FL_ERROR at the end of sc_conn_send()
133 - BUG/MINOR: quic: Do not use ack delay during the handshakes
134 - CLEANUP: use "offsetof" where appropriate
135 - MINOR: ssl: remove OpenSSL 1.0.2 mention into certificate loading error
136 - BUG/MEDIUM: http-ana: Properly switch the request in tunnel mode on upgrade
137 - BUG/MEDIUM: log: Properly handle client aborts in syslog applet
138 - MINOR: stconn: Add a flag to report EOS at the stream-connector level
139 - MINOR: stconn: Propagate EOS from a mux to the attached stream-connector
140 - MINOR: stconn: Propagate EOS from an applet to the attached stream-connector
141 - MINOR: mux-h2: make the initial window size configurable per side
142 - MINOR: mux-h2: make the max number of concurrent streams configurable per side
143 - BUG/MINOR: task: allow to use tasklet_wakeup_after with tid -1
144 - CLEANUP: quic: remove unused QUIC_LOCK label
145 - CLEANUP: quic: remove unused scid_node
146 - CLEANUP: quic: remove unused qc param on stateless reset token
147 - CLEANUP: quic: rename quic_connection_id vars
148 - MINOR: quic: remove uneeded tasklet_wakeup after accept
149 - MINOR: quic: adjust Rx packet type parsing
150 - MINOR: quic: adjust quic CID derive API
151 - MINOR: quic: remove TID ref from quic_conn
152 - MEDIUM: quic: use a global CID trees list
153 - MINOR: quic: remove TID encoding in CID
154 - MEDIUM: quic: handle conn bootstrap/handshake on a random thread
155 - MINOR: quic: do not proceed to accept for closing conn
156 - MINOR: protocol: define new callback set_affinity
157 - MINOR: quic: delay post handshake frames after accept
158 - MEDIUM: quic: implement thread affinity rebinding
159 - BUG/MINOR: quic: transform qc_set_timer() as a reentrant function
160 - MINOR: quic: properly finalize thread rebinding
161 - MAJOR: quic: support thread balancing on accept
162 - MINOR: listener: remove unneeded local accept flag
163 - BUG/MINOR: http-ana: Update analyzers on both sides when switching in TUNNEL mode
164 - CLEANUP: backend: Remove useless debug message in assign_server()
165 - CLEANUP: cli: Remove useless debug message in cli_io_handler()
166 - BUG/MEDIUM: stconn: Propagate error on the SC on sending path
167 - MINOR: config: add "no-alpn" support for bind lines
168 - REGTESTS: add a new "ssl_alpn" test to test ALPN negotiation
169 - DOC: add missing documentation for "no-alpn" on bind lines
170 - MINOR: ssl: do not set ALPN callback with the empty string
171 - MINOR: ssl_crtlist: dump "no-alpn" on "show crtlist" when "no-alpn" was set
172 - MEDIUM: config: set useful ALPN defaults for HTTPS and QUIC
173 - BUG/MEDIUM: quic: prevent crash on Retry sending
174 - BUG/MINOR: cfgparse: make sure to include openssl-compat
175 - MINOR: clock: add now_mono_time_fast() function
176 - MINOR: clock: add now_cpu_time_fast() function
177 - MEDIUM: hlua: reliable timeout detection
178 - MEDIUM: hlua: introduce tune.lua.burst-timeout
179 - CLEANUP: hlua: avoid confusion between internal timers and tick based timers
180 - MINOR: hlua: hook yield on known lua state
181 - MINOR: hlua: safe coroutine.create()
182 - BUG/MINOR: quic: Stop removing ACK ranges when building packets
183 - MINOR: quic: Do not allocate too much ack ranges
184 - BUG/MINOR: quic: Unchecked buffer length when building the token
185 - BUG/MINOR: quic: Wrong Retry token generation timestamp computing
186 - BUG/MINOR: mux-quic: fix crash with app ops install failure
187 - BUG/MINOR: mux-quic: properly handle STREAM frame alloc failure
188 - BUG/MINOR: h3: fix crash on h3s alloc failure
189 - BUG/MINOR: quic: prevent crash on qc_new_conn() failure
190 - BUG/MINOR: quic: consume Rx datagram even on error
191 - CLEANUP: errors: fix obsolete function comments
192 - CLEANUP: server: fix update_status() function comment
193 - MINOR: server/event_hdl: add proxy_uuid to event_hdl_cb_data_server
194 - MINOR: hlua/event_hdl: rely on proxy_uuid instead of proxy_name for lookups
195 - MINOR: hlua/event_hdl: expose proxy_uuid variable in server events
196 - MINOR: hlua/event_hdl: fix return type for hlua_event_hdl_cb_data_push_args
197 - MINOR: server/event_hdl: prepare for upcoming refactors
198 - BUG/MINOR: event_hdl: don't waste 1 event subtype slot
199 - CLEANUP: event_hdl: updating obsolete comment for EVENT_HDL_CB_DATA
200 - CLEANUP: event_hdl: fix comment typo about _sync assertion
201 - MINOR: event_hdl: dynamically allocated event data members
202 - MINOR: event_hdl: provide event->when for advanced handlers
203 - MINOR: hlua/event_hdl: timestamp for events
204 - DOC: lua: restore 80 char limitation
205 - BUG/MINOR: server: incorrect report for tracking servers leaving drain
206 - MINOR: server: explicitly commit state change in srv_update_status()
207 - BUG/MINOR: server: don't miss proxy stats update on server state transitions
208 - BUG/MINOR: server: don't miss server stats update on server state transitions
209 - BUG/MINOR: server: don't use date when restoring last_change from state file
210 - MINOR: server: central update for server counters on state change
211 - MINOR: server: propagate server state change to lb through single function
212 - MINOR: server: propagate lb changes through srv_lb_propagate()
213 - MINOR: server: change adm_st_chg_cause storage type
214 - MINOR: server: srv_append_status refacto
215 - MINOR: server: change srv_op_st_chg_cause storage type
216 - CLEANUP: server: remove unused variables in srv_update_status()
217 - CLEANUP: server: fix srv_set_{running, stopping, stopped} function comment
218 - MINOR: server: pass adm and op cause to srv_update_status()
219 - MEDIUM: server: split srv_update_status() in two functions
220 - MINOR: server/event_hdl: prepare for server event data wrapper
221 - MINOR: quic: support migrating the listener as well
222 - MINOR: quic_sock: index li->per_thr[] on local thread id, not global one
223 - MINOR: listener: support another thread dispatch mode: "fair"
224 - MINOR: receiver: add a struct shard_info to store info about each shard
225 - MINOR: receiver: add RX_F_MUST_DUP to indicate that an rx must be duped
226 - MEDIUM: proto: duplicate receivers marked RX_F_MUST_DUP
227 - MINOR: proto: skip socket setup for duped FDs
228 - MEDIUM: config: permit to start a bind on multiple groups at once
229 - MINOR: listener: make accept_queue index atomic
230 - MEDIUM: listener: rework thread assignment to consider all groups
231 - MINOR: listener: use a common thr_idx from the reference listener
232 - MINOR: listener: resync with the thread index before heavy calculations
233 - MINOR: listener: make sure to avoid ABA updates in per-thread index
234 - MINOR: listener: always compare the local thread as well
235 - MINOR: Make `tasklet_free()` safe to be called with `NULL`
236 - CLEANUP: Stop checking the pointer before calling `tasklet_free()`
237 - CLEANUP: Stop checking the pointer before calling `pool_free()`
238 - CLEANUP: Stop checking the pointer before calling `task_free()`
239 - CLEANUP: Stop checking the pointer before calling `ring_free()`
240 - BUG/MINOR: cli: clarify error message about stats bind-process
241 - CI: cirrus-ci: bump FreeBSD image to 13-1
242 - REGTESTS: remove unsupported "stats bind-process" keyword
243 - CI: extend spellchecker whitelist, add "clen" as well
244 - CLEANUP: assorted typo fixes in the code and comments
245 - BUG/MINOR: sock_inet: use SO_REUSEPORT_LB where available
246 - BUG/MINOR: tools: check libssl and libcrypto separately
247 - BUG/MINOR: config: fix NUMA topology detection on FreeBSD
248 - BUILD: sock_inet: forward-declare struct receiver
249 - BUILD: proto_tcp: export the correct names for proto_tcpv[46]
250 - CLEANUP: protocol: move the l3_addrlen to plug a hole in proto_fam
251 - CLEANUP: protocol: move the nb_receivers to plug a hole in protocol
252 - REORG: listener: move the bind_conf's thread setup code to listener.c
253 - MINOR: proxy: make proxy_type_str() recognize peers sections
254 - MEDIUM: peers: call bind_complete_thread_setup() to finish the config
255 - MINOR: protocol: add a flags field to store info about protocols
256 - MINOR: protocol: move the global reuseport flag to the protocols
257 - MINOR: listener: automatically adjust shards based on support for SO_REUSEPORT
258 - MINOR: protocol: add a function to check if some features are supported
259 - MINOR: sock: add a function to check for SO_REUSEPORT support at runtime
260 - MINOR: protocol: perform a live check for SO_REUSEPORT support
261 - MINOR: listener: do not restrict CLI to first group anymore
262 - MINOR: listener: add a new global tune.listener.default-shards setting
263 - MEDIUM: listener: switch the default sharding to by-group
264
Willy Tarreau768b6282023-04-08 17:38:39 +02002652023/04/08 : 2.8-dev7
266 - BUG/MINOR: stats: Don't replace sc_shutr() by SE_FL_EOS flag yet
267 - BUG/MEDIUM: mux-h2: Be able to detect connection error during handshake
268 - BUG/MINOR: quic: Missing padding in very short probe packets
269 - MINOR: proxy/pool: prevent unnecessary calls to pool_gc()
270 - CLEANUP: proxy: remove stop_time related dead code
271 - DOC/MINOR: reformat configuration.txt's "quoting and escaping" table
272 - MINOR: http_fetch: Add support for empty delim in url_param
273 - MINOR: http_fetch: add case insensitive support for smp_fetch_url_param
274 - MINOR: http_fetch: Add case-insensitive argument for url_param/urlp_val
275 - REGTESTS : Add test support for case insentitive for url_param
276 - BUG/MEDIUM: proxy/sktable: prevent watchdog trigger on soft-stop
277 - BUG/MINOR: backend: make be_usable_srv() consistent when stopping
278 - BUG/MINOR: ssl: Remove dead code in cli_parse_update_ocsp_response
279 - BUG/MINOR: ssl: Fix potential leak in cli_parse_update_ocsp_response
280 - BUG/MINOR: ssl: ssl-(min|max)-ver parameter not duplicated for bundles in crt-list
281 - BUG/MINOR: quic: Wrong use of now_ms timestamps (cubic algo)
282 - MINOR: quic: Add recovery related information to "show quic"
283 - BUG/MINOR: quic: Wrong use of now_ms timestamps (newreno algo)
284 - BUG/MINOR: quic: Missing max_idle_timeout initialization for the connection
285 - MINOR: quic: Implement cubic state trace callback
286 - MINOR: quic: Adjustments for generic control congestion traces
287 - MINOR: quic: Traces adjustments at proto level.
288 - MEDIUM: quic: Ack delay implementation
289 - BUG/MINOR: quic: Wrong rtt variance computing
290 - MINOR: cli: support filtering on FD types in "show fd"
291 - MINOR: quic: Add a fake congestion control algorithm named "nocc"
292 - CI: run smoke tests on config syntax to check memory related issues
293 - CLEANUP: assorted typo fixes in the code and comments
294 - CI: exclude doc/{design-thoughts,internals} from spell check
295 - BUG/MINOR: quic: Remaining useless statements in cubic slow start callback
296 - BUG/MINOR: quic: Cubic congestion control window may wrap
297 - MINOR: quic: Add missing traces in cubic algorithm implementation
298 - BUG/MAJOR: quic: Congestion algorithms states shared between the connection
299 - BUG/MINOR: ssl: Undefined reference when building with OPENSSL_NO_DEPRECATED
300 - BUG/MINOR: quic: Remove useless BUG_ON() in newreno and cubic algo implementation
301 - MINOR: http-act: emit a warning when a header field name contains forbidden chars
302 - DOC: config: strict-sni allows to start without certificate
303 - MINOR: quic: Add trace to debug idle timer task issues
304 - BUG/MINOR: quic: Unexpected connection closures upon idle timer task execution
305 - BUG/MINOR: quic: Wrong idle timer expiration (during 20s)
306 - BUILD: quic: 32bits compilation issue in cli_io_handler_dump_quic()
307 - BUG/MINOR: quic: Possible wrong PTO computing
308 - BUG/MINOR: tcpcheck: Be able to expect an empty response
309 - BUG/MEDIUM: stconn: Add a missing return statement in sc_app_shutr()
310 - BUG/MINOR: stream: Fix test on channels flags to set clientfin/serverfin touts
311 - MINOR: applet: Uninline appctx_free()
312 - MEDIUM: applet/trace: Register a new trace source with its events
313 - CLEANUP: stconn: Remove remaining debug messages
314 - BUG/MEDIUM: channel: Improve reports for shut in co_getblk()
315 - BUG/MEDIUM: dns: Properly handle error when a response consumed
316 - MINOR: stconn: Remove unecessary test on SE_FL_EOS before receiving data
317 - MINOR: stconn/channel: Move CF_READ_DONTWAIT into the SC and rename it
318 - MINOR: stconn/channel: Move CF_SEND_DONTWAIT into the SC and rename it
319 - MINOR: stconn/channel: Move CF_NEVER_WAIT into the SC and rename it
320 - MINOR: stconn/channel: Move CF_EXPECT_MORE into the SC and rename it
321 - MINOR: mux-pt: Report end-of-input with the end-of-stream after a read
322 - BUG/MINOR: mux-h1: Properly report EOI/ERROR on read0 in h1_rcv_pipe()
323 - CLEANUP: mux-h1/mux-pt: Remove useless test on SE_FL_SHR/SE_FL_SHW flags
324 - MINOR: mux-h1: Report an error to the SE descriptor on truncated message
325 - MINOR: stconn: Always ack EOS at the end of sc_conn_recv()
326 - MINOR: stconn/applet: Handle EOI in the applet .wake callback function
327 - MINOR: applet: No longer set EOI on the SC
328 - MINOR: stconn/applet: Handle EOS in the applet .wake callback function
329 - MEDIUM: cache: Use the sedesc to report and detect end of processing
330 - MEDIUM: cli: Use the sedesc to report and detect end of processing
331 - MINOR: dns: Remove the test on the opposite SC state to send requests
332 - MEDIUM: dns: Use the sedesc to report and detect end of processing
333 - MEDIUM: spoe: Use the sedesc to report and detect end of processing
334 - MEDIUM: hlua/applet: Use the sedesc to report and detect end of processing
335 - MEDIUM: log: Use the sedesc to report and detect end of processing
336 - MEDIUM: peers: Use the sedesc to report and detect end of processing
337 - MINOR: sink: Remove the tests on the opposite SC state to process messages
338 - MEDIUM: sink: Use the sedesc to report and detect end of processing
339 - MEDIUM: stats: Use the sedesc to report and detect end of processing
340 - MEDIUM: promex: Use the sedesc to report and detect end of processing
341 - MEDIUM: http_client: Use the sedesc to report and detect end of processing
342 - MINOR: stconn/channel: Move CF_EOI into the SC and rename it
343 - MEDIUM: tree-wide: Move flags about shut from the channel to the SC
344 - MINOR: tree-wide: Simplifiy some tests on SHUT flags by accessing SCs directly
345 - MINOR: stconn/applet: Add BUG_ON_HOT() to be sure SE_FL_EOS is never set alone
346 - MINOR: server: add SRV_F_DELETED flag
347 - BUG/MINOR: server/del: fix srv->next pointer consistency
348 - BUG/MINOR: stats: properly handle server stats dumping resumption
349 - BUG/MINOR: sink: free forward_px on deinit()
350 - BUG/MINOR: log: free log forward proxies on deinit()
351 - MINOR: server: always call ssl->destroy_srv when available
352 - MINOR: server: correctly free servers on deinit()
353 - BUG/MINOR: hlua: hook yield does not behave as expected
354 - MINOR: hlua: properly handle hlua_process_task HLUA_E_ETMOUT
355 - BUG/MINOR: hlua: enforce proper running context for register_x functions
356 - MINOR: hlua: Fix two functions that return nothing useful
357 - MEDIUM: hlua: Dynamic list of frontend/backend in Lua
358 - MINOR: hlua_fcn: alternative to old proxy and server attributes
359 - MEDIUM: hlua_fcn: dynamic server iteration and indexing
360 - MEDIUM: hlua_fcn/api: remove some old server and proxy attributes
361 - CLEANUP: hlua: fix conflicting comment in hlua_ctx_destroy()
362 - MINOR: hlua: add simple hlua reference handling API
363 - MINOR: hlua: fix return type for hlua_checkfunction() and hlua_checktable()
364 - BUG/MINOR: hlua: fix reference leak in core.register_task()
365 - BUG/MINOR: hlua: fix reference leak in hlua_post_init_state()
366 - BUG/MINOR: hlua: prevent function and table reference leaks on errors
367 - CLEANUP: hlua: use hlua_ref() instead of luaL_ref()
368 - CLEANUP: hlua: use hlua_pushref() instead of lua_rawgeti()
369 - CLEANUP: hlua: use hlua_unref() instead of luaL_unref()
370 - MINOR: hlua: simplify lua locking
371 - BUG/MEDIUM: hlua: prevent deadlocks with main lua lock
372 - MINOR: hlua_fcn: add server->get_rid() method
373 - MINOR: hlua: support for optional arguments to core.register_task()
374 - DOC: lua: silence "literal block ends without a blank line" Sphinx warnings
375 - DOC: lua: silence "Unexpected indentation" Sphinx warnings
376 - BUG/MINOR: event_hdl: fix rid storage type
377 - BUG/MINOR: event_hdl: make event_hdl_subscribe thread-safe
378 - MINOR: event_hdl: global sublist management clarification
379 - BUG/MEDIUM: event_hdl: clean soft-stop handling
380 - BUG/MEDIUM: event_hdl: fix async data refcount issue
381 - MINOR: event_hdl: normal tasks support for advanced async mode
382 - MINOR: event_hdl: add event_hdl_async_equeue_isempty() function
383 - MINOR: event_hdl: add event_hdl_async_equeue_size() function
384 - MINOR: event_hdl: pause/resume for subscriptions
385 - MINOR: proxy: add findserver_unique_id() and findserver_unique_name()
386 - MEDIUM: hlua/event_hdl: initial support for event handlers
387 - MINOR: hlua/event_hdl: per-server event subscription
388 - EXAMPLES: add basic event_hdl lua example script
389 - MINOR: http-ana: Add a HTTP_MSGF flag to state the Expect header was checked
390 - BUG/MINOR: http-ana: Don't switch message to DATA when waiting for payload
391 - BUG/MINOR: quic: Possible crashes in qc_idle_timer_task()
392 - MINOR: quic: derive first DCID from client ODCID
393 - MINOR: quic: remove ODCID dedicated tree
394 - MINOR: quic: remove address concatenation to ODCID
395 - BUG/MINOR: mworker: unset more internal variables from program section
396 - BUG/MINOR: errors: invalid use of memprintf in startup_logs_init()
397 - MINOR: applet: Use unsafe version to get stream from SC in the trace function
398 - BUG/MUNOR: http-ana: Use an unsigned integer for http_msg flags
399 - MINOR: compression: Make compression offload a flag
400 - MINOR: compression: Prepare compression code for request compression
401 - MINOR: compression: Store algo and type for both request and response
402 - MINOR: compression: Count separately request and response compression
403 - MEDIUM: compression: Make it so we can compress requests as well.
404 - BUG/MINOR: lua: remove incorrect usage of strncat()
405 - CLEANUP: tcpcheck: remove the only occurrence of sprintf() in the code
406 - CLEANUP: ocsp: do no use strpcy() to copy a path!
407 - CLEANUP: tree-wide: remove strpcy() from constant strings
408 - CLEANUP: opentracing: remove the last two occurrences of strncat()
409 - BUILD: compiler: fix __equals_1() on older compilers
410 - MINOR: compiler: define a __attribute__warning() macro
411 - BUILD: bug.h: add a warning in the base API when unsafe functions are used
412 - BUG/MEDIUM: listeners: Use the right parameters for strlcpy2().
413
Willy Tarreau4c7588d2023-03-28 13:58:56 +02004142023/03/28 : 2.8-dev6
415 - BUG/MEDIUM: mux-pt: Set EOS on error on sending path if read0 was received
416 - MINOR: ssl: Change the ocsp update log-format
417 - MINOR: ssl: Use ocsp update task for "update ssl ocsp-response" command
418 - BUG/MINOR: ssl: Fix double free in ocsp update deinit
419 - MINOR: ssl: Accept certpath as param in "show ssl ocsp-response" CLI command
420 - MINOR: ssl: Add certificate path to 'show ssl ocsp-response' output
421 - BUG/MEDIUM: proxy: properly stop backends on soft-stop
422 - BUG/MEDIUM: resolvers: Properly stop server resolutions on soft-stop
423 - DEBUG: cli/show_fd: Display connection error code
424 - DEBUG: ssl-sock/show_fd: Display SSL error code
425 - BUG/MEDIUM: mux-h1: Don't block SE_FL_ERROR if EOS is not reported on H1C
426 - BUG/MINOR: tcp_sample: fix a bug in fc_dst_port and fc_dst_is_local sample fetches
427 - BUG/MINOR: quic: Missing STREAM frame length updates
428 - BUG/MEDIUM: connection: Preserve flags when a conn is removed from an idle list
429 - BUG/MINOR: mux-h2: make sure the h2c task exists before refreshing it
430 - MINOR: buffer: add br_count() to return the number of allocated bufs
431 - MINOR: buffer: add br_single() to check if a buffer ring has more than one buf
432 - BUG/MEDIUM: mux-h2: only restart sending when mux buffer is decongested
433 - BUG/MINOR: mux-h2: set CO_SFL_STREAMER when sending lots of data
434 - BUG/MINOR: quic: Missing STREAM frame data pointer updates
435 - MINOR: stick-table: add sc-add-gpc() to http-after-response
436 - MINOR: doc: missing entries for sc-add-gpc()
437 - BUG/MAJOR: qpack: fix possible read out of bounds in static table
438 - OPTIM: mux-h1: limit first read size to avoid wrapping
439 - MINOR: mux-h2: set CO_SFL_MSG_MORE when sending multiple buffers
440 - MINOR: ssl-sock: pass the CO_SFL_MSG_MORE info down the stack
441 - MINOR: quic: Stop stressing the acknowledgments process (RX ACK frames)
442 - BUG/MINOR: quic: Dysfunctional 01RTT packet number space probing
443 - BUG/MEDIUM: stream: do not try to free a failed stream-conn
444 - BUG/MEDIUM: mux-h2: do not try to free an unallocated h2s->sd
445 - BUG/MEDIUM: mux-h2: erase h2c->wait_event.tasklet on error path
446 - BUG/MEDIUM: stconn: don't set the type before allocation succeeds
447 - BUG/MINOR: stconn: fix sedesc memory leak on stream allocation failure
448 - MINOR: dynbuf: set POOL_F_NO_FAIL on buffer allocation
449 - MINOR: pools: preset the allocation failure rate to 1% with -dMfail
450 - BUG/MEDIUM: mux-h1: properly destroy a partially allocated h1s
451 - BUG/MEDIUM: applet: only set appctx->sedesc on successful allocation
452 - BUG/MINOR: quic: wake up MUX on probing only for 01RTT
453 - BUG/MINOR: quic: ignore congestion window on probing for MUX wakeup
454 - BUILD: thread: implement thread_harmless_end_sig() for threadless builds
455 - BUILD: thread: silence a build warning when threads are disabled
456 - MINOR: debug: support dumping the libs addresses when running in verbose mode
457 - BUG/MINOR: illegal use of the malloc_trim() function if jemalloc is used
458 - BUG/MINOR: trace: fix hardcoded level for TRACE_PRINTF
459 - BUG/MEDIUM: mux-quic: release data from conn flow-control on qcs reset
460 - MINOR: mux-quic: complete traces for qcs emission
461 - MINOR: mux-quic: adjust trace level for MAX_DATA/MAX_STREAM_DATA recv
462 - MINOR: mux-quic: add flow-control info to minimal trace level
463 - MINOR: pools: make sure 'no-memory-trimming' is always used
464 - MINOR: pools: intercept malloc_trim() instead of trying to plug holes
465 - MEDIUM: pools: move the compat code from trim_all_pools() to malloc_trim()
466 - MINOR: pools: export trim_all_pools()
467 - MINOR: pattern: use trim_all_pools() instead of a conditional malloc_trim()
468 - MINOR: tools: relax dlopen() on malloc/free checks
469 - MEDIUM: tools: further relax dlopen() checks too consider grouped symbols
470 - BUG/MINOR: pools: restore detection of built-in allocator
471 - MINOR: pools: report a replaced memory allocator instead of just malloc_trim()
472 - BUG/MINOR: h3: properly handle incomplete remote uni stream type
473 - BUG/MINOR: mux-quic: prevent CC status to be erased by shutdown
474 - MINOR: mux-quic: interrupt qcc_recv*() operations if CC scheduled
475 - MINOR: mux-quic: ensure CONNECTION_CLOSE is scheduled once per conn
476 - MINOR: mux-quic: close on qcs allocation failure
477 - MINOR: mux-quic: close on frame alloc failure
478 - BUG/MINOR: syslog: Request for more data if message was not fully received
479 - BUG/MEDIUM: stats: Consume the request except when parsing the POST payload
480 - DOC: config: set-var() dconv rendering issues
481 - BUG/MEDIUM: mux-h1: Wakeup H1C on shutw if there is no I/O subscription
482 - BUG/MINOR: applet/new: fix sedesc freeing logic
483 - BUG/MINOR: quic: Missing STREAM frame type updated
484 - BUILD: da: extends CFLAGS to support API v3 from 3.1.7 and onwards.
485 - BUG/MINOR: ssl: Stop leaking `err` in ssl_sock_load_ocsp()
486
Willy Tarreaufc0ad292023-03-10 16:28:37 +01004872023/03/10 : 2.8-dev5
488 - MINOR: ssl: rename confusing ssl_bind_kws
489 - BUG/MINOR: config: crt-list keywords mistaken for bind ssl keywords
490 - BUG/MEDIUM: http-ana: Detect closed SC on opposite side during body forwarding
491 - BUG/MEDIUM: stconn: Don't rearm the read expiration date if EOI was reached
492 - MINOR: global: Add an option to disable the data fast-forward
493 - MINOR: haproxy: Add an command option to disable data fast-forward
494 - REGTESTS: Remove unsupported feature command in http_splicing.vtc
495 - BUG/MEDIUM: wdt: fix wrong thread being checked for sleeping
496 - BUG/MINOR: sched: properly report long_rq when tasks remain in the queue
497 - BUG/MEDIUM: sched: allow a bit more TASK_HEAVY to be processed when needed
498 - MINOR: threads: add flags to know if a thread is started and/or running
499 - MINOR: h3/hq-interop: handle no data in decode_qcs() with FIN set
500 - BUG/MINOR: mux-quic: transfer FIN on empty STREAM frame
501 - BUG/MINOR: mworker: prevent incorrect values in uptime
502 - MINOR: h3: add traces on decode_qcs callback
503 - BUG/MINOR: quic: Possible unexpected counter incrementation on send*() errors
504 - MINOR: quic: Add new traces about by connection RX buffer handling
505 - MINOR: quic: Move code to wakeup the timer task to avoid anti-amplication deadlock
506 - BUG/MINOR: quic: Really cancel the connection timer from qc_set_timer()
507 - MINOR: quic: Simplication for qc_set_timer()
508 - MINOR: quic: Kill the connections on ICMP (port unreachable) packet receipt
509 - MINOR: quic: Add traces to qc_kill_conn()
510 - MINOR: quic: Make qc_dgrams_retransmit() return a status.
511 - BUG/MINOR: quic: Missing call to task_queue() in qc_idle_timer_do_rearm()
512 - MINOR: quic: Add a trace to identify connections which sent Initial packet.
513 - MINOR: quic: Add <pto_count> to the traces
514 - BUG/MINOR: quic: Do not probe with too little Initial packets
515 - BUG/MINOR: quic: Wrong initialization for io_cb_wakeup boolean
516 - BUG/MINOR: quic: Do not drop too small datagrams with Initial packets
517 - BUG/MINOR: quic: Missing padding for short packets
518 - MINOR: quic: adjust request reject when MUX is already freed
519 - BUG/MINOR: quic: also send RESET_STREAM if MUX released
520 - BUG/MINOR: quic: acknowledge STREAM frame even if MUX is released
521 - BUG/MINOR: h3: prevent hypothetical demux failure on int overflow
522 - MEDIUM: h3: enforce GOAWAY by resetting higher unhandled stream
523 - MINOR: mux-quic: define qc_shutdown()
524 - MINOR: mux-quic: define qc_process()
525 - MINOR: mux-quic: implement client-fin timeout
526 - MEDIUM: mux-quic: properly implement soft-stop
527 - MINOR: quic: mark quic-conn as jobs on socket allocation
528 - MEDIUM: quic: trigger fast connection closing on process stopping
529 - MINOR: mux-h2/traces: do not log h2s pointer for dummy streams
530 - MINOR: mux-h2/traces: add a missing TRACE_LEAVE() in h2s_frt_handle_headers()
531 - BUG/MEDIUM: quic: Missing TX buffer draining from qc_send_ppkts()
532 - DEBUG: stream: Add a BUG_ON to never exit process_stream with an expired task
533 - DOC: config: Fix description of options about HTTP connection modes
534 - MINOR: proxy: Only consider backend httpclose option for server connections
535 - BUG/MINOR: haproxy: Fix option to disable the fast-forward
536 - DOC: config: Add the missing tune.fail-alloc option from global listing
537 - MINOR: cfgcond: Implement strstr condition expression
538 - MINOR: cfgcond: Implement enabled condition expression
539 - REGTESTS: Skip http_splicing.vtc script if fast-forward is disabled
540 - REGTESTS: Fix ssl_errors.vtc script to wait for connections close
541 - BUG/MINOR: mworker: stop doing strtok directly from the env
542 - BUG/MEDIUM: mworker: prevent inconsistent reload when upgrading from old versions
543 - BUG/MEDIUM: mworker: don't register mworker_accept_wrapper() when master FD is wrong
544 - MINOR: startup: HAPROXY_STARTUP_VERSION contains the version used to start
545 - BUG/MINOR: cache: Cache response even if request has "no-cache" directive
546 - BUG/MINOR: cache: Check cache entry is complete in case of Vary
547 - MINOR: compiler: add a TOSTR() macro to turn a value into a string
548 - BUG/MINOR: lua/httpclient: missing free in hlua_httpclient_send()
549 - BUG/MEDIUM: httpclient/lua: fix a race between lua GC and hlua_ctx_destroy
550 - MEDIUM: channel: Remove CF_READ_NOEXP flag
551 - MAJOR: channel: Remove flags to report READ or WRITE errors
552 - DEBUG: stream/trace: Add sedesc flags in trace messages
553 - MINOR: channel/stconn: Move rto/wto from the channel to the stconn
554 - MEDIUM: channel/stconn: Move rex/wex timer from the channel to the sedesc
555 - MEDIUM: stconn: Don't requeue the stream's task after I/O
556 - MEDIUM: stconn: Replace read and write timeouts by a unique I/O timeout
557 - MEDIUM: stconn: Add two date to track successful reads and blocked sends
558 - MINOR: applet/stconn: Add a SE flag to specify an endpoint does not expect data
559 - MAJOR: stream: Use SE descriptor date to detect read/write timeouts
560 - MINOR: stream: Dump the task expiration date in trace messages
561 - MINOR: stream: Report rex/wex value using the sedesc date in trace messages
562 - MINOR: stream: Use relative expiration date in trace messages
563 - MINOR: stconn: Always report READ/WRITE event on shutr/shutw
564 - CLEANUP: stconn: Remove old read and write expiration dates
565 - MINOR: stconn: Set half-close timeout using proxy settings
566 - MINOR: stconn: Remove half-closed timeout
567 - REGTESTS: cache: Use rxresphdrs to only get headers for 304 responses
568 - MINOR: stconn: Add functions to set/clear SE_FL_EXP_NO_DATA flag from endpoint
569 - BUG/MINOR: proto_ux: report correct error when bind_listener fails
570 - BUG/MINOR: protocol: fix minor memory leak in protocol_bind_all()
571 - MINOR: proto_uxst: add resume method
572 - MINOR: listener/api: add lli hint to listener functions
573 - MINOR: listener: add relax_listener() function
574 - MINOR: listener: workaround for closing a tiny race between resume_listener() and stopping
575 - MINOR: listener: make sure we don't pause/resume bypassed listeners
576 - BUG/MEDIUM: listener: fix pause_listener() suspend return value handling
577 - BUG/MINOR: listener: fix resume_listener() resume return value handling
578 - BUG/MEDIUM: resume from LI_ASSIGNED in default_resume_listener()
579 - MINOR: listener: pause_listener() becomes suspend_listener()
580 - BUG/MEDIUM: listener/proxy: fix listeners notify for proxy resume
581 - BUG/MINOR: sock_unix: match finalname with tempname in sock_unix_addrcmp()
582 - MEDIUM: proto_ux: properly suspend named UNIX listeners
583 - MINOR: proto_ux: ability to dump ABNS names in error messages
584 - MINOR: haproxy: always protocol unbind on startup error path
585 - BUILD: quic: 32-bits compilation issue with %zu in quic_rx_pkts_del()
586 - BUG/MINOR: ring: do not realign ring contents on resize
587 - MEDIUM: ring: make the offset relative to the head/tail instead of absolute
588 - CLEANUP: ring: remove the now unused ring's offset
589 - MINOR: config: add HAPROXY_BRANCH environment variable
590 - BUILD: thead: Fix several 32 bits compilation issues with uint64_t variables
591 - BUG/MEDIUM: fd: avoid infinite loops in fd_add_to_fd_list and fd_rm_from_fd_list
592 - BUG/MEDIUM: h1-htx: Never copy more than the max data allowed during parsing
593 - BUG/MINOR: stream: Remove BUG_ON about the task expiration in process_stream()
594 - MINOR: stream: Handle stream's timeouts in a dedicated function
595 - MEDIUM: stream: Eventually handle stream timeouts when exiting process_stream()
596 - MINOR: stconn: Report a send activity when endpoint is willing to consume data
597 - BUG/MEDIUM: stconn: Report a blocked send if some output data are not consumed
598 - MEDIUM: mux-h1: Don't expect data from server as long as request is unfinished
599 - MEDIUM: mux-h2: Don't expect data from server as long as request is unfinished
600 - MEDIUM: mux-quic: Don't expect data from server as long as request is unfinished
601 - DOC: config: Clarify the meaning of 'hold' in the 'resolvers' section
602 - DOC: config: Replace TABs by spaces
603 - BUG/MINOR: fd: used the update list from the fd's group instead of tgid
604 - BUG/MEDIUM: fd: make fd_delete() support being called from a different group
605 - CLEANUP: listener: only store conn counts for local threads
606 - MINOR: tinfo: make thread_set functions return nth group/mask instead of first
607 - MEDIUM: quic: improve fatal error handling on send
608 - MINOR: quic: consider EBADF as critical on send()
609 - BUG/MEDIUM: connection: Clear flags when a conn is removed from an idle list
610 - BUG/MINOR: mux-h1: Don't report an error on an early response close
611 - BUG/MINOR: http-check: Don't set HTX_SL_F_BODYLESS flag with a log-format body
612 - BUG/MINOR: http-check: Skip C-L header for empty body when it's not mandatory
613 - BUG/MINOR: http-fetch: recognize IPv6 addresses in square brackets in req.hdr_ip()
614 - REGTEST: added tests covering smp_fetch_hdr_ip()
615 - MINOR: quic: simplify return path in send functions
616 - MINOR: quic: implement qc_notify_send()
617 - MINOR: quic: purge txbuf before preparing new packets
618 - MEDIUM: quic: implement poller subscribe on sendto error
619 - MINOR: quic: notify on send ready
620 - BUG/MINOR: http-ana: Don't increment conn_retries counter before the L7 retry
621 - BUG/MINOR: http-ana: Do a L7 retry on read error if there is no response
622 - BUG/MEDIUM: http-ana: Don't close request side when waiting for response
623 - BUG/MINOR: mxu-h1: Report a parsing error on abort with pending data
624 - MINOR: ssl: Destroy ocsp update http_client during cleanup
625 - MINOR: ssl: Reinsert ocsp update entries later in case of unknown error
626 - MINOR: ssl: Add ocsp update success/failure counters
627 - MINOR: ssl: Store specific ocsp update errors in response and update ctx
628 - MINOR: ssl: Add certificate's path to certificate_ocsp structure
629 - MINOR: ssl: Add 'show ssl ocsp-updates' CLI command
630 - MINOR: ssl: Add sample fetches related to OCSP update
631 - MINOR: ssl: Use dedicated proxy and log-format for OCSP update
632 - MINOR: ssl: Reorder struct certificate_ocsp members
633 - MINOR: ssl: Increment OCSP update replay delay in case of failure
634 - MINOR: ssl: Add way to dump ocsp response in base64
635 - MINOR: ssl: Add global options to modify ocsp update min/max delay
636 - REGTESTS: ssl: Fix ocsp update crt-lists
637 - REGTESTS: ssl: Add test for new ocsp update cli commands
638 - MINOR: ssl: Add ocsp-update information to "show ssl crt-list"
639 - BUG/MINOR: ssl: Fix ocsp-update when using "add ssl crt-list"
640 - MINOR: ssl: Replace now.tv_sec with date.tv_sec in ocsp update task
641 - BUG/MINOR: ssl: Use 'date' instead of 'now' in ocsp stapling callback
642 - BUG/MEDIUM: quic: properly handle duplicated STREAM frames
643 - BUG/MINOR: cli: fix CLI handler "set anon global-key" call
644 - MINOR: http_ext: adding some documentation, forgot to inline function
645 - BUG/MINOR: quic: Do not send too small datagrams (with Initial packets)
646 - MINOR: quic: Add a BUG_ON_HOT() call for too small datagrams
647 - BUG/MINOR: quic: Ensure to be able to build datagrams to be retransmitted
648 - BUG/MINOR: quic: v2 Initial packets decryption failed
649 - MINOR: quic: Add traces about QUIC TLS key update
650 - BUG/MINOR: quic: Remove force_ack for Initial,Handshake packets
651 - BUG/MINOR: quic: Ensure not to retransmit packets with no ack-eliciting frames
652 - BUG/MINOR: quic: Do not resend already acked frames
653 - BUG/MINOR: quic: Missing detections of amplification limit reached
654 - MINOR: quic: Send PING frames when probing Initial packet number space
655 - BUG/MEDIUM: quic: do not crash when handling STREAM on released MUX
656 - BUG/MAJOR: fd/thread: fix race between updates and closing FD
657 - BUG/MEDIUM: dns: ensure ring offset is properly reajusted to head
658 - BUG/MINOR: mux-quic: properly init STREAM frame as not duplicated
659 - MINOR: quic: Do not accept wrong active_connection_id_limit values
660 - MINOR: quic: Store the next connection IDs sequence number in the connection
661 - MINOR: quic: Typo fix for ACK_ECN frame
662 - MINOR: quic: RETIRE_CONNECTION_ID frame handling (RX)
663 - MINOR: quic: Useless TLS context allocations in qc_do_rm_hp()
664 - MINOR: quic: Add spin bit support
665 - MINOR: quic: Add transport parameters to "show quic"
666 - BUG/MEDIUM: sink/forwarder: ensure ring offset is properly readjusted to head
667 - BUG/MINOR: dns: fix ring offset calculation on first read
668 - BUG/MINOR: dns: fix ring offset calculation in dns_resolve_send()
669 - MINOR: jwt: Add support for RSA-PSS signatures (PS256 algorithm)
670 - MINOR: h3: add traces on h3_init_uni_stream() error paths
671 - MINOR: quic: create a global list dedicated for closing QUIC conns
672 - MINOR: quic: handle new closing list in show quic
673 - MEDIUM: quic: release closing connections on stopping
674 - BUG/MINOR: quic: Wrong RETIRE_CONNECTION_ID sequence number check
675 - MINOR: fd/cli: report the polling mask in "show fd"
676 - CLEANUP: sock: always perform last connection updates before wakeup
677 - MINOR: quic: Do not stress the peer during retransmissions of lost packets
678 - BUG/MINOR: init: properly detect NUMA bindings on large systems
679 - BUG/MINOR: thread: report thread and group counts in the correct order
680 - BUG/MAJOR: fd/threads: close a race on closing connections after takeover
681 - MINOR: debug: add random delay injection with "debug dev delay-inj"
682 - BUG/MINOR: mworker: use MASTER_MAXCONN as default maxconn value
683 - BUG/MINOR: quic: Missing listener accept queue tasklet wakeups
684 - MINOR: quic_sock: un-statify quic_conn_sock_fd_iocb()
685 - DOC: config: fix typo "dependeing" in bind thread description
686 - DOC/CLEANUP: fix typos
687
Willy Tarreauc80560b2023-02-14 16:55:17 +01006882023/02/14 : 2.8-dev4
689 - BUG/MINOR: stats: fix source buffer size for http dump
690 - BUG/MEDIUM: stats: fix resolvers dump
691 - BUG/MINOR: stats: fix ctx->field update in stats_dump_proxy_to_buffer()
692 - BUG/MINOR: stats: fix show stats field ctx for servers
693 - BUG/MINOR: stats: fix STAT_STARTED behavior with full htx
694 - MINOR: quic: Update version_information transport parameter to draft-14
695 - BUG/MINOR: stats: Prevent HTTP "other sessions" counter underflows
696 - BUG/MEDIUM: thread: fix extraneous shift in the thread_set parser
697 - BUG/MEDIUM: listener/thread: bypass shards setting on failed thread resolution
698 - BUG/MINOR: ssl/crt-list: warn when a line is malformated
699 - BUG/MEDIUM: stick-table: do not leave entries in end of window during purge
700 - BUG/MINOR: clock: do not mix wall-clock and monotonic time in uptime calculation
701 - BUG/MEDIUM: cache: use the correct time reference when comparing dates
702 - MEDIUM: clock: force internal time to wrap early after boot
703 - BUILD: ssl/ocsp: ssl_ocsp-t.h depends on ssl_sock-t.h
704 - MINOR: ssl/ocsp: add a function to check the OCSP update configuration
705 - MINOR: cfgparse/server: move (min/max)conn postparsing logic into dedicated function
706 - BUG/MINOR: server/add: ensure minconn/maxconn consistency when adding server
707 - BUG/MEDIUM: stconn: Schedule a shutw on shutr if data must be sent first
708 - BUG/MEDIUM: quic: fix crash when "option nolinger" is set in the frontend
709 - MINOR: quic: implement a basic "show quic" CLI handler
710 - MINOR: quic: display CIDs and state in "show quic"
711 - MINOR: quic: display socket info on "show quic"
712 - MINOR: quic: display infos about various encryption level on "show quic"
713 - MINOR: quic: display Tx stream info on "show quic"
714 - MINOR: quic: filter closing conn on "show quic"
715 - BUG/MINOR: quic: fix filtering of closing connections on "show quic"
716 - BUG/MEDIUM: stconn: Don't needlessly wake the stream on send during fast-forward
717 - BUG/MINOR: quic: fix type bug on "show quic" for 32-bits arch
718 - BUG/MINOR: mworker: fix uptime for master process
719 - BUG/MINOR: clock/stats: also use start_time not start_date in HTML info
720 - BUG/MEDIUM: stconn: stop to enable/disable reads from streams via si_update_rx
721 - BUG/MEDIUM: quic: Buffer overflow when looking through QUIC CLI keyword list
722 - DOC: proxy-protocol: fix wrong byte in provided example
723 - MINOR: ssl-ckch: Stop to test CF_WRITE_ERROR to commit CA/CRL file
724 - MINOR: bwlim: Remove useless test on CF_READ_ERROR to detect the last packet
725 - BUG/MINOR: http-ana: Fix condition to set LAST termination flag
726 - BUG/MINOR: mux-h1: Don't report an H1C error on client timeout
727 - BUG/MEDIUM: spoe: Don't set the default traget for the SPOE agent frontend
728 - BUG/MINOR: quic: Wrong datagram dispatch because of qc_check_dcid()
729 - BUG/CRITICAL: http: properly reject empty http header field names
730
Willy Tarreaue74d77b2023-02-04 10:51:05 +01007312023/02/04 : 2.8-dev3
732 - BUG/MINOR: sink: make sure to always properly unmap a file-backed ring
733 - DEV: haring: add a new option "-r" to automatically repair broken files
734 - BUG/MINOR: ssl: Fix leaks in 'update ssl ocsp-response' CLI command
735 - MINOR: ssl: Remove debug fprintf in 'update ssl ocsp-response' cli command
736 - MINOR: connection: add a BUG_ON() to detect destroying connection in idle list
737 - MINOR: mux-quic/h3: send SETTINGS as soon as transport is ready
738 - BUG/MINOR: h3: fix GOAWAY emission
739 - BUG/MEDIUM: mux-quic: fix crash on H3 SETTINGS emission
740 - BUG/MEDIUM: hpack: fix incorrect huffman decoding of some control chars
741 - BUG/MINOR: log: release global log servers on exit
742 - BUG/MINOR: ring: release the backing store name on exit
743 - BUG/MINOR: sink: free the forwarding task on exit
744 - CLEANUP: trace: remove the QUIC-specific ifdefs
745 - MINOR: trace: add a TRACE_ENABLED() macro to determine if a trace is active
746 - MINOR: trace: add a trace_no_cb() dummy callback for when to use no callback
747 - MINOR: trace: add the long awaited TRACE_PRINTF()
748 - MINOR: h2: add h2_phdr_to_ist() to make ISTs from pseudo headers
749 - MEDIUM: mux-h2/trace: add tracing support for headers
750 - CLEANUP: mux-h2/trace: shorten the name of the header enc/dec functions
751 - DEV: hpack: fix `trash` build regression
752 - MINOR: http_htx: add http_append_header() to append value to header
753 - MINOR: http_htx: add http_prepend_header() to prepend value to header
754 - MINOR: sample: add ARGC_OPT
755 - MINOR: proxy: introduce http only options
756 - MINOR: proxy/http_ext: introduce proxy forwarded option
757 - REGTEST: add ifnone-forwardfor test
758 - MINOR: proxy: move 'forwardfor' option to http_ext
759 - MINOR: proxy: move 'originalto' option to http_ext
760 - MINOR: http_ext: introduce http ext converters
761 - MINOR: http_ext: add rfc7239_is_valid converter
762 - MINOR: http_ext: add rfc7239_field converter
763 - MINOR: http_ext: add rfc7239_n2nn converter
764 - MINOR: http_ext: add rfc7239_n2np converter
765 - REGTEST: add RFC7239 forwarded header tests
766 - OPTIM: http_ext/7239: introduce c_mode to save some space
767 - MINOR: http_ext/7239: warn the user when fetch is not available
768 - MEDIUM: proxy/http_ext: implement dynamic http_ext
769 - MINOR: cfgparse/http_ext: move post-parsing http_ext steps to http_ext
770 - DOC: config: fix option spop-check proxy compatibility
771 - BUG/MINOR: fcgi-app: prevent 'use-fcgi-app' in default section
772 - DOC: config: 'http-send-name-header' option may be used in default section
773 - BUG/MINOR: mux-h2: Fix possible null pointer deref on h2c in _h2_trace_header()
774 - BUG/MINOR: http_ext/7239: ipv6 dumping relies on out of scope variables
775 - BUG/MEDIUM: h3: do not crash if no buf space for trailers
776 - OPTIM: h3: skip buf realign if no trailer to encode
777 - MINOR: mux-quic/h3: define stream close callback
778 - BUG/MEDIUM: h3: handle STOP_SENDING on control stream
779 - BUG/MINOR: h3: reject RESET_STREAM received for control stream
780 - MINOR: h3: add missing traces on closure
781 - BUG/MEDIUM: ssl: wrong eviction from the session cache tree
782 - BUG/MINOR: h3: fix crash due to h3 traces
783 - BUG/MINOR: h3: fix crash due to h3 traces
784 - BUG/MEDIUM: thread: consider secondary threads as idle+harmless during boot
785 - BUG/MINOR: stats: use proper buffer size for http dump
786 - BUILD: makefile: fix PCRE overriding specific lib path
787 - MINOR: quic: remove fin from quic_stream frame type
788 - MINOR: quic: ensure offset is properly set for STREAM frames
789 - MINOR: quic: define new functions for frame alloc
790 - MINOR: quic: refactor frame deallocation
791 - MEDIUM: quic: implement a retransmit limit per frame
792 - MINOR: quic: add config for retransmit limit
793 - OPTIM: htx: inline the most common memcpy(8)
794 - CLEANUP: quic: no need for atomics on packet refcnt
795 - MINOR: stats: add by HTTP version cumulated number of sessions and requests
796 - BUG/MINOR: quic: Possible stream truncations under heavy loss
797 - BUG/MINOR: quic: Too big PTO during handshakes
798 - MINOR: quic: Add a trace about variable states in qc_prep_fast_retrans()
799 - BUG/MINOR: quic: Do not ignore coalesced packets in qc_prep_fast_retrans()
800 - MINOR: quic: When probing Handshake packet number space, also probe the Initial one
801 - BUG/MAJOR: quic: Possible crash when processing 1-RTT during 0-RTT session
802 - MEDIUM: quic: Remove qc_conn_finalize() from the ClientHello TLS callbacks
803 - BUG/MINOR: quic: Unchecked source connection ID
804 - MEDIUM: listener: move the analysers mask to the bind_conf
805 - MINOR: listener: move maxseg and tcp_ut to bind_conf
806 - MINOR: listener: move maxaccept from listener to bind_conf
807 - MINOR: listener: move the backlog setting from listener to bind_conf
808 - MINOR: listener: move the maxconn parameter to the bind_conf
809 - MINOR: listener: move the ->accept callback to the bind_conf
810 - MINOR: listener: remove the useless ->default_target field
811 - MINOR: listener: move the nice field to the bind_conf
812 - MINOR: listener: move the NOLINGER option to the bind_conf
813 - MINOR: listener: move the NOQUICKACK option to the bind_conf
814 - MINOR: listener: move the DEF_ACCEPT option to the bind_conf
815 - MINOR: listener: move TCP_FO to bind_conf
816 - MINOR: listener: move the ACC_PROXY and ACC_CIP options to bind_conf
817 - MINOR: listener: move LI_O_UNLIMITED and LI_O_NOSTOP to bind_conf
818 - MINOR: listener: get rid of LI_O_TCP_L4_RULES and LI_O_TCP_L5_RULES
819 - CLEANUP: listener: remove the now unused options field
820 - MINOR: listener: remove the now useless LI_F_QUIC_LISTENER flag
821 - CLEANUP: config: remove test for impossible case regarding bind thread mask
822 - MINOR: thread: add a simple thread_set API
823 - MEDIUM: listener/config: make the "thread" parser rely on thread_sets
824 - CLEANUP: config: stop using bind_tgroup and bind_thread
825 - CLEANUP: listener/thread: remove now unused bind_conf's bind_tgroup/bind_thread
826 - CLEANUP: listener/config: remove the special case for shards==1
827 - MEDIUM: config: restrict shards, not bind_conf to one group each
828 - BUG/MEDIUM: quic: do not split STREAM frames if no space
829 - BUILD: thread: fix build warnings with older gcc compilers
830
Willy Tarreau0f29b342023-01-22 14:20:57 +01008312023/01/22 : 2.8-dev2
832 - CLEANUP: htx: fix a typo in an error message of http_str_to_htx
833 - DOC: config: added optional rst-ttl argument to silent-drop in action lists
834 - BUG/MINOR: ssl: Fix crash in 'update ssl ocsp-response' CLI command
835 - BUG/MINOR: ssl: Crash during cleanup because of ocsp structure pointer UAF
836 - MINOR: ssl: Create temp X509_STORE filled with cert chain when checking ocsp response
837 - MINOR: ssl: Only set ocsp->issuer if issuer not in cert chain
838 - MINOR: ssl: Release ssl_ocsp_task_ctx.cur_ocsp when destroying task
839 - MINOR: ssl: Detect more OCSP update inconsistencies
840 - BUG/MINOR: ssl: Fix OCSP_CERTID leak when same certificate is used multiple times
841 - MINOR: ssl: Limit ocsp_uri buffer size to minimum
842 - MINOR: ssl: Remove mention of ckch_store in error message of cli command
843 - MINOR: channel: Don't test CF_READ_NULL while CF_SHUTR is enough
844 - REORG: channel: Rename CF_READ_NULL to CF_READ_EVENT
845 - REORG: channel: Rename CF_WRITE_NULL to CF_WRITE_EVENT
846 - MEDIUM: channel: Use CF_READ_EVENT instead of CF_READ_PARTIAL
847 - MEDIUM: channel: Use CF_WRITE_EVENT instead of CF_WRITE_PARTIAL
848 - MINOR: channel: Remove CF_READ_ACTIVITY
849 - MINOR: channel: Remove CF_WRITE_ACTIVITY
850 - MINOR: channel: Remove CF_ANA_TIMEOUT and report CF_READ_EVENT instead
851 - MEDIUM: channel: Remove CF_READ_ATTACHED and report CF_READ_EVENT instead
852 - MINOR: channel: Stop to test CF_READ_ERROR flag if CF_SHUTR is enough
853 - MINOR: channel/applets: Stop to test CF_WRITE_ERROR flag if CF_SHUTW is enough
854 - DOC: management: add details on "Used" status
855 - DOC: management: add details about @system-ca in "show ssl ca-file"
856 - BUG/MINOR: mux-quic: fix transfer of empty HTTP response
857 - MINOR: mux-quic: add traces for flow-control limit reach
858 - MAJOR: mux-quic: rework stream sending priorization
859 - MEDIUM: h3: send SETTINGS before STREAM frames
860 - MINOR: mux-quic: use send-list for STOP_SENDING/RESET_STREAM emission
861 - MINOR: mux-quic: use send-list for immediate sending retry
862 - BUG/MINOR: h1-htx: Remove flags about protocol upgrade on non-101 responses
863 - BUG/MINOR: hlua: Fix Channel.line and Channel.data behavior regarding the doc
864 - BUG/MINOR: resolvers: Wait the resolution execution for a do_resolv action
865 - BUG/MINOR: ssl: Remove unneeded pointer check in ocsp cli release function
866 - BUG/MINOR: ssl: Missing ssl_conf pointer check when checking ocsp update inconsistencies
867 - DEV: tcploop: add minimal support for unix sockets
868 - BUG/MEDIUM: listener: duplicate inherited FDs if needed
869 - BUG/MINOR: ssl: OCSP minimum update threshold not properly set
870 - MINOR: ssl: Treat ocsp-update inconsistencies as fatal errors
871 - MINOR: ssl: Do not wake ocsp update task if update tree empty
872 - MINOR: ssl: Reinsert updated ocsp response later in tree in case of http error
873 - REGTEST: ssl: Add test for 'update ssl ocsp-response' CLI command
874 - OPTIM: global: move byte counts out of global and per-thread
875 - BUG/MEDIUM: peers: make "show peers" more careful about partial initialization
876 - BUG/MINOR: promex: Don't forget to consume the request on error
877 - MINOR: http-ana: Add a function to set HTTP termination flags
878 - MINOR: http-ana: Use http_set_term_flags() in most of HTTP analyzers
879 - BUG/MINOR: http-ana: Report SF_FINST_R flag on error waiting the request body
880 - MINOR: http-ana: Use http_set_term_flags() when waiting the request body
881 - BUG/MINOR: http-fetch: Don't block HTTP sample fetch eval in HTTP_MSG_ERROR state
882 - MAJOR: http-ana: Review error handling during HTTP payload forwarding
883 - CLEANUP: http-ana: Remove HTTP_MSG_ERROR state
884 - BUG/MEDIUM: mux-h2: Don't send CANCEL on shutw when response length is unkown
885 - MINOR: htx: Add an HTX value for the extra field is payload length is unknown
886 - BUG/MINOR: http-ana: make set-status also update txn->status
887 - BUG/MINOR: listeners: fix suspend/resume of inherited FDs
888 - DOC: config: fix wrong section number for "protocol prefixes"
889 - DOC: config: fix aliases for protocol prefixes "udp4@" and "udp6@"
890 - DOC: config: mention the missing "quic4@" and "quic6@" in protocol prefixes
891 - MINOR: listener: also support "quic+" as an address prefix
892 - CLEANUP: stconn: always use se_fl_set_error() to set the pending error
893 - BUG/MEDIUM: stconn: also consider SE_FL_EOI to switch to SE_FL_ERROR
894 - MINOR: quic: Useless test about datagram destination addresses
895 - MINOR: quic: Disable the active connection migrations
896 - MINOR: quic: Add "no-quic" global option
897 - MINOR: sample: Add "quic_enabled" sample fetch
898 - MINOR: quic: Replace v2 draft definitions by those of the final 2 version
899 - BUG/MINOR: mux-fcgi: Correctly set pathinfo
900 - DOC: config: fix "Address formats" chapter syntax
901 - BUG/MEDIUM: jwt: Properly process ecdsa signatures (concatenated R and S params)
902 - BUILD: ssl: add ECDSA_SIG_set0() for openssl < 1.1 or libressl < 2.7
903 - Revert "BUILD: ssl: add ECDSA_SIG_set0() for openssl < 1.1 or libressl < 2.7"
904 - BUG/MINOR: ssl: Fix compilation with OpenSSL 1.0.2 (missing ECDSA_SIG_set0)
905 - BUG/MINOR: listener: close tiny race between resume_listener() and stopping
906 - BUG/MINOR: h3: properly handle connection headers
907 - MINOR: h3: extend function for QUIC varint encoding
908 - MINOR: h3: implement TRAILERS encoding
909 - BUG/MINOR: bwlim: Check scope for period expr for set-bandwitdh-limit actions
910 - MEDIUM: bwlim: Support constants limit or period on set-bandwidth-limit actions
911 - BUG/MINOR: bwlim: Fix parameters check for set-bandwidth-limit actions
912 - MINOR: h3: implement TRAILERS decoding
913 - BUG/MEDIUM: fd/threads: fix again incorrect thread selection in wakeup broadcast
914 - BUG/MINOR: thread: always reload threads_enabled in loops
915 - MINOR: threads: add a thread_harmless_end() version that doesn't wait
916 - BUG/MEDIUM: debug/thread: make the debug handler not wait for !rdv_requests
917 - BUG/MINOR: mux-h2: make sure to produce a log on invalid requests
918 - BUG/MINOR: mux-h2: add missing traces on failed headers decoding
919 - BUILD: hpack: include global.h for the trash that is needed in debug mode
920 - BUG/MINOR: jwt: Wrong return value checked
921 - BUG/MINOR: quic: Do not request h3 clients to close its unidirection streams
922 - MEDIUM: quic-sock: fix udp source address for send on listener socket
923
Willy Tarreau40c88f92023-01-07 09:45:17 +01009242023/01/07 : 2.8-dev1
925 - MEDIUM: 51d: add support for 51Degrees V4 with Hash algorithm
926 - MINOR: debug: support pool filtering on "debug dev memstats"
927 - MINOR: debug: add a balance of alloc - free at the end of the memstats dump
928 - LICENSE: wurfl: clarify the dummy library license.
929 - MINOR: event_hdl: add event handler base api
930 - DOC/MINOR: api: add documentation for event_hdl feature
931 - MEDIUM: ssl: rename the struct "cert_key_and_chain" to "ckch_data"
932 - MINOR: quic: remove qc from quic_rx_packet
933 - MINOR: quic: complete traces in qc_rx_pkt_handle()
934 - MINOR: quic: extract datagram parsing code
935 - MINOR: tools: add port for ipcmp as optional criteria
936 - MINOR: quic: detect connection migration
937 - MINOR: quic: ignore address migration during handshake
938 - MINOR: quic: startup detect for quic-conn owned socket support
939 - MINOR: quic: test IP_PKTINFO support for quic-conn owned socket
940 - MINOR: quic: define config option for socket per conn
941 - MINOR: quic: allocate a socket per quic-conn
942 - MINOR: quic: use connection socket for emission
943 - MEDIUM: quic: use quic-conn socket for reception
944 - MEDIUM: quic: move receive out of FD handler to quic-conn io-cb
945 - MINOR: mux-quic: rename duplicate function names
946 - MEDIUM: quic: requeue datagrams received on wrong socket
947 - MINOR: quic: reconnect quic-conn socket on address migration
948 - MINOR: quic: activate socket per conn by default
949 - BUG/MINOR: ssl: initialize SSL error before parsing
950 - BUG/MINOR: ssl: initialize WolfSSL before parsing
951 - BUG/MINOR: quic: fix fd leak on startup check quic-conn owned socket
952 - BUG/MEDIIM: stconn: Flush output data before forwarding close to write side
953 - MINOR: server: add srv->rid (revision id) value
954 - MINOR: stats: add server revision id support
955 - MINOR: server/event_hdl: add support for SERVER_ADD and SERVER_DEL events
956 - MINOR: server/event_hdl: add support for SERVER_UP and SERVER_DOWN events
957 - BUG/MEDIUM: checks: do not reschedule a possibly running task on state change
958 - BUG/MINOR: checks: make sure fastinter is used even on forced transitions
959 - CLEANUP: assorted typo fixes in the code and comments
960 - MINOR: mworker: display an alert upon a wait-mode exit
961 - BUG/MEDIUM: mworker: fix segv in early failure of mworker mode with peers
962 - BUG/MEDIUM: mworker: create the mcli_reload socketpairs in case of upgrade
963 - BUG/MINOR: checks: restore legacy on-error fastinter behavior
964 - MINOR: check: use atomic for s->consecutive_errors
965 - MINOR: stats: properly handle ST_F_CHECK_DURATION metric
966 - MINOR: mworker: remove unused legacy code in mworker_cleanlisteners
967 - MINOR: peers: unused code path in process_peer_sync
968 - BUG/MINOR: init/threads: continue to limit default thread count to max per group
969 - CLEANUP: init: remove useless assignment of nbthread
970 - BUILD: atomic: atomic.h may need compiler.h on ARMv8.2-a
971 - BUILD: makefile/da: also clean Os/ in Device Atlas dummy lib dir
972 - BUG/MEDIUM: httpclient/lua: double LIST_DELETE on end of lua task
973 - CLEANUP: pools: move the write before free to the uaf-only function
974 - CLEANUP: pool: only include pool-os from pool.c not pool.h
975 - REORG: pool: move all the OS specific code to pool-os.h
976 - CLEANUP: pools: get rid of CONFIG_HAP_POOLS
977 - DEBUG: pool: show a few examples in -dMhelp
978 - MINOR: pools: make DEBUG_UAF a runtime setting
979 - BUG/MINOR: promex: create haproxy_backend_agg_server_status
980 - MINOR: promex: introduce haproxy_backend_agg_check_status
981 - DOC: promex: Add missing backend metrics
982 - BUG/MAJOR: fcgi: Fix uninitialized reserved bytes
983 - REGTESTS: fix the race conditions in iff.vtc
984 - CI: github: reintroduce openssl 1.1.1
985 - BUG/MINOR: quic: properly handle alloc failure in qc_new_conn()
986 - BUG/MINOR: quic: handle alloc failure on qc_new_conn() for owned socket
987 - CLEANUP: mux-quic: remove unused attribute on qcs_is_close_remote()
988 - BUG/MINOR: mux-quic: remove qcs from opening-list on free
989 - BUG/MINOR: mux-quic: handle properly alloc error in qcs_new()
990 - CI: github: split ssl lib selection based on git branch
991 - REGTESTS: startup: check maxconn computation
992 - BUG/MINOR: startup: don't use internal proxies to compute the maxconn
993 - REGTESTS: startup: change the expected maxconn to 11000
994 - CI: github: set ulimit -n to a greater value
995 - REGTESTS: startup: activate automatic_maxconn.vtc
996 - MINOR: sample: add param converter
997 - CLEANUP: ssl: remove check on srv->proxy
998 - BUG/MEDIUM: freq-ctr: Don't compute overshoot value for empty counters
999 - BUG/MEDIUM: resolvers: Use tick_first() to update the resolvers task timeout
1000 - REGTESTS: startup: add alternatives values in automatic_maxconn.vtc
1001 - BUG/MEDIUM: h3: reject request with invalid header name
1002 - BUG/MEDIUM: h3: reject request with invalid pseudo header
1003 - MINOR: http: extract content-length parsing from H2
1004 - BUG/MEDIUM: h3: parse content-length and reject invalid messages
1005 - CI: github: remove redundant ASAN loop
1006 - CI: github: split matrix for development and stable branches
1007 - BUG/MEDIUM: mux-h1: Don't release H1 stream upgraded from TCP on error
1008 - BUG/MINOR: mux-h1: Fix test instead a BUG_ON() in h1_send_error()
1009 - MINOR: http-htx: add BUG_ON to prevent API error on http_cookie_register
1010 - BUG/MEDIUM: h3: fix cookie header parsing
1011 - BUG/MINOR: h3: fix memleak on HEADERS parsing failure
1012 - MINOR: h3: check return values of htx_add_* on headers parsing
1013 - MINOR: ssl: Remove unneeded buffer allocation in show ocsp-response
1014 - MINOR: ssl: Remove unnecessary alloc'ed trash chunk in show ocsp-response
1015 - BUG/MINOR: ssl: Fix memory leak of find_chain in ssl_sock_load_cert_chain
1016 - MINOR: stats: provide ctx for dumping functions
1017 - MINOR: stats: introduce stats field ctx
1018 - BUG/MINOR: stats: fix show stat json buffer limitation
1019 - MINOR: stats: make show info json future-proof
1020 - BUG/MINOR: quic: fix crash on PTO rearm if anti-amplification reset
1021 - BUILD: 51d: fix build issue with recent compilers
1022 - REGTESTS: startup: disable automatic_maxconn.vtc
1023 - BUILD: peers: peers-t.h depends on stick-table-t.h
1024 - BUG/MEDIUM: tests: use tmpdir to create UNIX socket
1025 - BUG/MINOR: mux-h1: Report EOS on parsing/internal error for not running stream
1026 - BUG/MINOR:: mux-h1: Never handle error at mux level for running connection
1027 - BUG/MEDIUM: stats: Rely on a local trash buffer to dump the stats
1028 - OPTIM: pool: split the read_mostly from read_write parts in pool_head
1029 - MINOR: pool: make the thread-local hot cache size configurable
1030 - MINOR: freq_ctr: add opportunistic versions of swrate_add()
1031 - MINOR: pool: only use opportunistic versions of the swrate_add() functions
1032 - REGTESTS: ssl: enable the ssl_reuse.vtc test for WolfSSL
1033 - BUG/MEDIUM: mux-quic: fix double delete from qcc.opening_list
1034 - BUG/MEDIUM: quic: properly take shards into account on bind lines
1035 - BUG/MINOR: quic: do not allocate more rxbufs than necessary
1036 - MINOR: ssl: Add a lock to the OCSP response tree
1037 - MINOR: httpclient: Make the CLI flags public for future use
1038 - MINOR: ssl: Add helper function that extracts an OCSP URI from a certificate
1039 - MINOR: ssl: Add OCSP request helper function
1040 - MINOR: ssl: Add helper function that checks the validity of an OCSP response
1041 - MINOR: ssl: Add "update ssl ocsp-response" cli command
1042 - MEDIUM: ssl: Add ocsp_certid in ckch structure and discard ocsp buffer early
1043 - MINOR: ssl: Add ocsp_update_tree and helper functions
1044 - MINOR: ssl: Add crt-list ocsp-update option
1045 - MINOR: ssl: Store 'ocsp-update' mode in the ckch_data and check for inconsistencies
1046 - MEDIUM: ssl: Insert ocsp responses in update tree when needed
1047 - MEDIUM: ssl: Add ocsp update task main function
1048 - MEDIUM: ssl: Start update task if at least one ocsp-update option is set to on
1049 - DOC: ssl: Add documentation for ocsp-update option
1050 - REGTESTS: ssl: Add tests for ocsp auto update mechanism
1051 - MINOR: ssl: Move OCSP code to a dedicated source file
1052 - BUG/MINOR: ssl/ocsp: check chunk_strcpy() in ssl_ocsp_get_uri_from_cert()
1053 - CLEANUP: ssl/ocsp: add spaces around operators
1054 - BUG/MEDIUM: mux-h2: Refuse interim responses with end-stream flag set
1055 - BUG/MINOR: pool/stats: Use ullong to report total pool usage in bytes in stats
1056 - BUG/MINOR: ssl/ocsp: httpclient blocked when doing a GET
1057 - MINOR: httpclient: don't add body when istlen is empty
1058 - MEDIUM: httpclient: change the default log format to skip duplicate proxy data
1059 - BUG/MINOR: httpclient/log: free of invalid ptr with httpclient_log_format
1060 - MEDIUM: mux-quic: implement shutw
1061 - MINOR: mux-quic: do not count stream flow-control if already closed
1062 - MINOR: mux-quic: handle RESET_STREAM reception
1063 - MEDIUM: mux-quic: implement STOP_SENDING emission
1064 - MINOR: h3: use stream error when needed instead of connection
1065 - CI: github: enable github api authentication for OpenSSL tags read
1066 - BUG/MINOR: mux-quic: ignore remote unidirectional stream close
1067 - CI: github: use the GITHUB_TOKEN instead of a manually generated token
1068 - BUILD: makefile: build the features list dynamically
1069 - BUILD: makefile: move common options-oriented macros to include/make/options.mk
1070 - BUILD: makefile: sort the features list
1071 - BUILD: makefile: initialize all build options' variables at once
1072 - BUILD: makefile: add a function to collect all options' CFLAGS/LDFLAGS
1073 - BUILD: makefile: start to automatically collect CFLAGS/LDFLAGS
1074 - BUILD: makefile: ensure that all USE_* handlers appear before CFLAGS are used
1075 - BUILD: makefile: clean the wolfssl include and lib generation rules
1076 - BUILD: makefile: make sure to also ignore SSL_INC when using wolfssl
1077 - BUILD: makefile: reference libdl only once
1078 - BUILD: makefile: make sure LUA_INC and LUA_LIB are always initialized
1079 - BUILD: makefile: do not restrict Lua's prepend path to empty LUA_LIB_NAME
1080 - BUILD: makefile: never force -latomic, set USE_LIBATOMIC instead
1081 - BUILD: makefile: add an implicit USE_MATH variable for -lm
1082 - BUILD: makefile: properly report USE_PCRE/USE_PCRE2 in features
1083 - CLEANUP: makefile: properly indent ifeq/ifneq conditional blocks
1084 - BUILD: makefile: rework 51D to split v3/v4
1085 - BUILD: makefile: support LIBCRYPT_LDFLAGS
1086 - BUILD: makefile: support RT_LDFLAGS
1087 - BUILD: makefile: support THREAD_LDFLAGS
1088 - BUILD: makefile: support BACKTRACE_LDFLAGS
1089 - BUILD: makefile: support SYSTEMD_LDFLAGS
1090 - BUILD: makefile: support ZLIB_CFLAGS and ZLIB_LDFLAGS
1091 - BUILD: makefile: support ENGINE_CFLAGS
1092 - BUILD: makefile: support OPENSSL_CFLAGS and OPENSSL_LDFLAGS
1093 - BUILD: makefile: support WOLFSSL_CFLAGS and WOLFSSL_LDFLAGS
1094 - BUILD: makefile: support LUA_CFLAGS and LUA_LDFLAGS
1095 - BUILD: makefile: support DEVICEATLAS_CFLAGS and DEVICEATLAS_LDFLAGS
1096 - BUILD: makefile: support PCRE[2]_CFLAGS and PCRE[2]_LDFLAGS
1097 - BUILD: makefile: refactor support for 51DEGREES v3/v4
1098 - BUILD: makefile: support WURFL_CFLAGS and WURFL_LDFLAGS
1099 - BUILD: makefile: make all OpenSSL variants use the same settings
1100 - BUILD: makefile: remove the special case of the SSL option
1101 - BUILD: makefile: only consider settings from enabled options
1102 - BUILD: makefile: also list per-option settings in 'make opts'
1103 - BUG/MINOR: debug: don't mask the TH_FL_STUCK flag before dumping threads
1104 - MINOR: cfgparse-ssl: avoid a possible crash on OOM in ssl_bind_parse_npn()
1105 - BUG/MINOR: ssl: Missing goto in error path in ocsp update code
1106 - BUG/MINOR: stick-table: report the correct action name in error message
1107 - CI: Improve headline in matrix.py
1108 - CI: Add in-memory cache for the latest OpenSSL/LibreSSL
1109 - CI: Use proper `if` blocks instead of conditional expressions in matrix.py
1110 - CI: Unify the `GITHUB_TOKEN` name across matrix.py and vtest.yml
1111 - CI: Explicitly check environment variable against `None` in matrix.py
1112 - CI: Reformat `matrix.py` using `black`
1113 - MINOR: config: add environment variables for default log format
1114 - REGTESTS: Remove REQUIRE_VERSION=1.9 from all tests
1115 - REGTESTS: Remove REQUIRE_VERSION=2.0 from all tests
1116 - REGTESTS: Remove tests with REQUIRE_VERSION_BELOW=1.9
1117 - BUG/MINOR: http-fetch: Only fill txn status during prefetch if not already set
1118 - BUG/MAJOR: buf: Fix copy of wrapping output data when a buffer is realigned
1119 - DOC: config: fix alphabetical ordering of http-after-response rules
1120 - MINOR: http-rules: Add missing actions in http-after-response ruleset
1121 - DOC: config: remove duplicated "http-response sc-set-gpt0" directive
1122 - BUG/MINOR: proxy: free orgto_hdr_name in free_proxy()
1123 - REGTEST: fix the race conditions in json_query.vtc
1124 - REGTEST: fix the race conditions in add_item.vtc
1125 - REGTEST: fix the race conditions in digest.vtc
1126 - REGTEST: fix the race conditions in hmac.vtc
1127 - BUG/MINOR: fd: avoid bad tgid assertion in fd_delete() from deinit()
1128 - BUG/MINOR: http: Memory leak of http redirect rules' format string
1129 - MEDIUM: stick-table: set the track-sc limit at boottime via tune.stick-counters
1130 - MINOR: stick-table: implement the sc-add-gpc() action
1131
Willy Tarreaueaded982022-12-01 15:25:34 +010011322022/12/01 : 2.8-dev0
1133 - MINOR: version: mention that it's development again
1134
Willy Tarreau437fd282022-12-01 15:16:46 +010011352022/12/01 : 2.7.0
1136 - MINOR: ssl: forgotten newline in error messages on ca-file
1137 - BUG/MINOR: ssl: shut the ca-file errors emitted during httpclient init
1138 - DOC: config: provide some configuration hints for "http-reuse"
1139 - DOC: config: refer to section about quoting in the "add_item" converter
1140 - DOC: halog: explain how to use -ac and -ad in the help message
1141 - DOC: config: clarify the fact that SNI should not be used in HTTP scenarios
1142 - DOC: config: mention that a single monitor-uri rule is supported
1143 - DOC: config: explain how default matching method for ACL works
1144 - DOC: config: clarify the fact that "retries" is not just for connections
1145 - BUILD: halog: fix missing double-quote at end of help line
1146 - DOC: config: clarify the -m dir and -m dom pattern matching methods
1147 - MINOR: activity: report uptime in "show activity"
1148 - REORG: activity/cli: move the "show activity" handler to activity.c
1149 - DEV: poll: add support for epoll
1150 - DEV: tcploop: centralize the polling code into wait_for_fd()
1151 - DEV: tcploop: add support for POLLRDHUP when supported
1152 - DEV: tcploop: do not report an error on POLLERR
1153 - DEV: tcploop: add optional support for epoll
1154 - SCRIPTS: announce-release: add a link to the data plane API
1155 - CLEANUP: stick-table: fill alignment holes in the stktable struct
1156 - MINOR: stick-table: store a per-table hash seed and use it
1157 - MINOR: stick-table: show the shard number in each entry's "show table" output
1158 - CLEANUP: ncbuf: remove ncb_blk args by value
1159 - CLEANUP: ncbuf: inline small functions
1160 - CLEANUP: ncbuf: use standard BUG_ON with DEBUG_STRICT
1161 - BUG/MINOR: quic: Endless loop during retransmissions
1162 - MINOR: mux-h2: add the expire task and its expiration date in "show fd"
1163 - BUG/MINOR: peers: always initialize the stksess shard value
1164 - REGTESTS: fix peers-related regtests regarding "show table"
1165 - BUG/MEDIUM: mux-h1: Close client H1C on EOS when there is no output data
1166 - MINOR: stick-table: change the API of the function used to calculate the shard
1167 - CLEANUP: peers: factor out the key len calculation in received updates
1168 - BUG/MINOR: peers: always update the stksess shard number on incoming updates
1169 - CLEANUP: assorted typo fixes in the code and comments
1170 - MINOR: mux-h1: add the expire task and its expiration date in "show fd"
1171 - MINOR: debug: improve error handling on the memstats command parser
1172 - BUILD: quic: allow build with USE_QUIC and USE_OPENSSL_WOLFSSL
1173 - CLEANUP: anon: clarify the help message on "debug dev hash"
1174 - MINOR: debug: relax access restrictions on "debug dev hash" and "memstats"
1175 - SCRIPTS: run-regtests: add a version check
1176 - MINOR: version: mention that it's stable now
1177
Willy Tarreau0279df92022-11-24 17:13:05 +010011782022/11/24 : 2.7-dev10
1179 - MEDIUM: tcp-act: add parameter rst-ttl to silent-drop
1180 - BUG/MAJOR: quic: Crash upon retransmission of dgrams with several packets
1181 - MINOR: cli: print parsed command when not found
1182 - BUG/MAJOR: quic: Crash after discarding packet number spaces
1183 - CLEANUP: quic: replace "choosen" with "chosen" all over the code
1184 - MINOR: cli/pools: store "show pools" results into a temporary array
1185 - MINOR: cli/pools: add sorting capabilities to "show pools"
1186 - MINOR: cli/pools: add pool name filtering capability to "show pools"
1187 - DOC: configuration: fix quic prefix typo
1188 - MINOR: quic: report error if force-retry without cluster-secret
1189 - MINOR: global: generate random cluster.secret if not defined
1190 - BUG/MINOR: resolvers: do not run the timeout task when there's no resolution
1191 - BUG/MINOR: server/idle: at least use atomic stores when updating max_used_conns
1192 - MINOR: server/idle: make the next_takeover index per-tgroup
1193 - BUILD: listener: fix build warning on global_listener_rwlock without threads
1194 - BUG/MAJOR: sched: protect task during removal from wait queue
1195 - BUILD: sched: fix build with DEBUG_THREAD with the previous commit
1196 - DOC: quic: add note on performance issue with listener contention
1197 - BUG/MINOR: cfgparse-listen: fix ebpt_next_dup pointer dereference on proxy "from" inheritance
1198 - BUG/MINOR: log: fix parse_log_message rfc5424 size check
1199 - CLEANUP: arg: remove extra check in make_arg_list arg escaping
1200 - CLEANUP: tools: extra check in utoa_pad
1201 - MINOR: h1: Consider empty port as invalid in authority for CONNECT
1202 - MINOR: http: Considere empty ports as valid default ports
1203 - BUG/MINOR: http-htx: Normalized absolute URIs with an empty port
1204 - BUG/MINOR: h1: Replace authority validation to conform RFC3986
1205 - REG-TESTS: http: Add more tests about authority/host matching
1206 - BUG/MINOR: http-htx: Don't consider an URI as normalized after a set-uri action
1207 - BUG/MEDIUM: mux-h1: Don't release H1C on timeout if there is a SC attached
1208 - BUG/MEDIUM: mux-h1: Subscribe for reads on error on sending path
1209 - BUILD: http-htx: Silent build error about a possible NULL start-line
1210 - DOC: configuration.txt: add default_value for table_idle signature
1211 - BUILD: ssl-sock: Silent error about NULL deref in ssl_sock_bind_verifycbk()
1212 - BUG/MEDIUM: mux-h1: Remove H1C_F_WAIT_NEXT_REQ flag on a next request
1213 - BUG/MINOR: mux-h1: Fix handling of 408-Request-Time-Out
1214 - MINOR: mux-h1: Remove H1C_F_WAIT_NEXT_REQ in functions handling errors
1215 - MINOR: mux-h1: Avoid useless call to h1_send() if no error is sent
1216 - DOC: configuration.txt: fix typo in table_idle signature
1217 - BUILD: stick-tables: fix build breakage in xxhash on older compilers
1218 - BUILD: compiler: include compiler's definitions before ours
1219 - BUILD: quic: global.h is needed in cfgparse-quic
1220 - CLEANUP: tools: do not needlessly include xxhash nor cli from tools.h
1221 - BUILD: flags: really restrict the cases where flags are exposed
1222 - BUILD: makefile: minor reordering of objects by build time
1223 - BUILD: quic: silence two invalid build warnings at -O1 with gcc-6.5
1224 - BUILD: quic: use openssl-compat.h instead of openssl/ssl.h
1225 - MEDIUM: ssl: add minimal WolfSSL support with OpenSSL compatibility mode
1226 - MINOR: sample: make the rand() sample fetch function use the statistical_prng
1227 - MINOR: auth: silence null dereference warning in check_user()
1228 - CLEANUP: peers: fix format string for status messages (int signedness)
1229 - CLEANUP: qpack: fix format string in debugging code (int signedness)
1230 - CLEANUP: qpack: properly use the QPACK macros not HPACK ones in debug code
1231 - BUG/MEDIUM: quic: fix datagram dropping on queueing failed
1232
Willy Tarreaua0abec82022-11-18 17:48:49 +010012332022/11/18 : 2.7-dev9
1234 - BUILD: quic: QUIC mux build fix for 32-bit build
1235 - BUILD: scripts: disable tests build on QuicTLS build
1236 - BUG/MEDIUM: httpclient: segfault when the httpclient parser fails
1237 - BUILD: ssl_sock: fix null dereference for QUIC build
1238 - BUILD: quic: Fix build for m68k cross-compilation
1239 - BUG/MINOR: quic: fix buffer overflow on retry token generation
1240 - MINOR: quic: add version field on quic_rx_packet
1241 - MINOR: quic: extend pn_offset field from quic_rx_packet
1242 - MINOR: quic: define first packet flag
1243 - MINOR: quic: extract connection retrieval
1244 - MINOR: quic: split and rename qc_lstnr_pkt_rcv()
1245 - MINOR: quic: refactor packet drop on reception
1246 - MINOR: quic: extend Retry token check function
1247 - BUG/MINOR: log: Preserve message facility when the log target is a ring buffer
1248 - BUG/MINOR: ring: Properly parse connect timeout
1249 - BUG/MEDIUM: httpclient/lua: crash when the lua task timeout before the httpclient
1250 - BUG/MEDIUM: httpclient: check if the httpclient was released in the IO handler
1251 - REGTESTS: httpclient/lua: test the lua task timeout with the httpclient
1252 - CI: github: dump the backtrace of coredumps in the alpine container
1253 - BUILD: Makefile: add "USE_SHM_OPEN" on the linux-musl target
1254 - DOC: lua: add a note about compression w/ httpclient
1255 - CLEANUP: mworker/cli: rename the status function to loadstatus
1256 - MINOR: mworker/cli: does no try to dump the startup-logs w/o USE_SHM_OPEN
1257 - MINOR: list: fixing typo in MT_LIST_LOCK_ELT
1258 - DOC/MINOR: list: fixing MT_LIST_LOCK_ELT macro documentation
1259 - MINOR: list: adding MT_LIST_APPEND_LOCKED macro
1260 - BUG/MINOR: mux-quic: complete flow-control for uni streams
1261 - BUG/MEDIUM: compression: handle rewrite errors when updating response headers
1262 - MINOR: quic: do not crash on unhandled sendto error
1263 - MINOR: quic: display unknown error sendto counter on stat page
1264 - MINOR: peers: Support for peer shards
1265 - MINOR: peers: handle multiple resync requests using shards
1266 - BUG/MINOR: sink: Only use backend capability for the sink proxies
1267 - BUG/MINOR: sink: Set default connect/server timeout for implicit ring buffers
1268 - MINOR: ssl: add the SSL error string when failing to load a certificate
1269 - MINOR: ssl: add the SSL error string before the chain
1270 - MEDIUM: ssl: be stricter about chain error
1271 - BUG/MAJOR: stick-table: don't process store-response rules for applets
1272 - MINOR: quic: remove unnecessary quic_session_accept()
1273 - BUG/MINOR: quic: fix subscribe operation
1274 - BUG/MINOR: log: fixing bug in tcp syslog_io_handler Octet-Counting
1275 - MINOR: ssl: dump the SSL string error when SSL_CTX_use_PrivateKey() failed.
1276 - MINOR: quic: add counter for interrupted reception
1277 - BUG/MINOR: quic: fix race condition on datagram purging
1278 - CI: add monthly gcc cross compile jobs
1279 - CLEANUP: assorted typo fixes in the code and comments
1280 - CLEANUP: ssl: remove dead code in ssl_sock_load_pem_into_ckch()
1281 - BUG/MINOR: httpclient: fixed memory allocation for the SSL ca_file
1282 - BUG/MINOR: ssl: Memory leak of DH BIGNUM fields
1283 - BUG/MINOR: ssl: Memory leak of AUTHORITY_KEYID struct when loading issuer
1284 - BUG/MINOR: ssl: ocsp structure not freed properly in case of error
1285 - CI: switch to the "latest" LibreSSL
1286 - CI: enable QUIC for LibreSSL builds
1287 - BUG/MEDIUM: ssl: Verify error codes can exceed 63
1288 - MEDIUM: ssl: {ca,crt}-ignore-err can now use error constant name
1289 - MINOR: ssl: x509_v_err_str converter transforms an integer to a X509_V_ERR name
1290 - CLEANUP: cli: rename dynamic error printing state
1291 - MINOR: cli: define usermsgs print context
1292 - MINOR: server: clear prefix on stderr logs after add server
1293 - BUG/MINOR: ssl: bind_conf is uncorrectly accessed when using QUIC
1294 - BUILD: ssl_utils: fix build on gcc versions before 8
1295 - BUILD: debug: remove unnecessary quotes in HA_WEAK() calls
1296 - CI: emit the compiler's version in the build reports
1297 - IMPORT: xxhash: update xxHash to version 0.8.1
1298 - IMPORT: slz: declare len to fix debug build when optimal match is enabled
1299 - IMPORT: slz: mention the potential header in slz_finish()
1300 - IMPORT: slz: define and use a __fallthrough statement for switch/case
1301 - BUILD: compiler: add a macro to detect if another one is set and equals 1
1302 - BUILD: compiler: add a default definition for __has_attribute()
1303 - BUILD: compiler: define a __fallthrough statement for switch/case
1304 - BUILD: sample: use __fallthrough in smp_is_rw() and smp_dup()
1305 - BUILD: quic: use __fallthrough in quic_connect_server()
1306 - BUILD: ssl/crt-list: use __fallthrough in cli_io_handler_add_crtlist()
1307 - BUILD: ssl: use __fallthrough in cli_io_handler_commit_{cert,cafile_crlfile}()
1308 - BUILD: ssl: use __fallthrough in cli_io_handler_tlskeys_files()
1309 - BUILD: hlua: use __fallthrough in hlua_post_init_state()
1310 - BUILD: stream: use __fallthrough in stats_dump_full_strm_to_buffer()
1311 - BUILD: tcpcheck: use __fallthrough in check_proxy_tcpcheck()
1312 - BUILD: stats: use __fallthrough in stats_dump_proxy_to_buffer()
1313 - BUILD: peers: use __fallthrough in peer_io_handler()
1314 - BUILD: hash: use __fallthrough in hash_djb2()
1315 - BUILD: tools: use __fallthrough in url_decode()
1316 - BUILD: args: use __fallthrough in make_arg_list()
1317 - BUILD: acl: use __fallthrough in parse_acl_expr()
1318 - BUILD: spoe: use __fallthrough in spoe_handle_appctx()
1319 - BUILD: logs: use __fallthrough in build_log_header()
1320 - BUILD: check: use __fallthrough in __health_adjust()
1321 - BUILD: http_act: use __fallthrough in parse_http_del_header()
1322 - BUILD: h1_htx: use __fallthrough in h1_parse_chunk()
1323 - BUILD: vars: use __fallthrough in var_accounting_{diff,add}()
1324 - BUILD: map: use __fallthrough in cli_io_handler_*()
1325 - BUILD: compression: use __fallthrough in comp_http_payload()
1326 - BUILD: stconn: use __fallthrough in various shutw() functions
1327 - BUILD: prometheus: use __fallthrough in promex_dump_metrics() and IO handler()
1328 - CLEANUP: ssl: remove printf in bind_parse_ignore_err
1329 - BUG/MINOR: ssl: crt-ignore-err memory leak with 'all' parameter
1330 - BUG/MINOR: ssl: Fix potential overflow
1331 - CLEANUP: stick-table: remove the unused table->exp_next
1332 - OPTIM: stick-table: avoid atomic ops in stktable_requeue_exp() when possible
1333 - BUG/MEDIUM: stick-table: fix a race condition when updating the expiration task
1334 - MEDIUM: http-ana: remove set-cookie2 support
1335 - BUG/MEDIUM: wdt/clock: properly handle early task hangs
1336 - MINOR: deinit: add a "quick-exit" option to bypass the deinit step
1337 - OPTIM: ebtree: make ebmb_insert_prefix() keep a copy the new node's pfx
1338 - OPTIM: ebtree: make ebmb_insert_prefix() keep a copy the new node's key
1339 - MINOR: ssl: ssl_sock_load_cert_chain() display error strings
1340 - MINOR: ssl: reintroduce ERR_GET_LIB(ret) == ERR_LIB_PEM in ssl_sock_load_pem_into_ckch()
1341 - BUG/MINOR: http-htx: Fix error handling during parsing http replies
1342 - BUG/MINOR: resolvers: Don't wait periodic resolution on healthcheck failure
1343 - BUG/MINOR: resolvers: Set port before IP address when processing SRV records
1344 - BUG/MINOR: mux-fcgi: Be sure to send empty STDING record in case of zero-copy
1345 - BUG/MEDIUM: mux-fcgi: Avoid value length overflow when it doesn't fit at once
1346 - BUG/MINOR: ssl: SSL_load_error_strings might not be defined
1347 - MINOR: pool/debug: create a new pool_alloc_flag() macro
1348 - MINOR: dynbuf: switch allocation and release to macros to better track users
1349 - BUG/MINOR: mux-h1: Do not send a last null chunk on body-less answers
1350 - REG-TESTS: cache: Remove T-E header for 304-Not-Modified responses
1351 - DOC: config: fix alphabetical ordering of global section
1352 - MINOR: trace: split the CLI "trace" parser in CLI vs statement
1353 - MEDIUM: trace: create a new "trace" statement in the "global" section
1354 - BUG/MEDIUM: ring: fix creation of server in uninitialized ring
1355 - BUILD: quic: fix dubious 0-byte overflow on qc_release_lost_pkts
1356 - BUILD: makefile: mark poll and tcploop targets as phony
1357 - BUILD: makefile: properly pass CC to sub-projects
1358 - BUILD: makefile: move default verbosity settings to include/make/verbose.mk
1359 - BUILD: makefile: use $(cmd_MAKE) in quiet mode
1360 - BUILD: makefile: move the compiler option detection stuff to compiler.mk
1361 - DEV: poll: make the connect() step an action as well
1362 - DEV: poll: strip the "do_" prefix from reported function names
1363 - DEV: poll: indicate the FD's side in front of its value
1364 - BUG/MINOR: pool/cli: use ullong to report total pool usage in bytes
1365 - MINOR: mux-h1: Remove usless code inside shutr callback
1366 - CLEANUP: mux-h1; Rename H1S_F_ERROR flag into H1S_F_ERROR_MASK
1367 - REORG: mux-h1: Reorg the H1C structure
1368 - CLEANUP: mux-h1: Rename H1C_F_ST_ERROR and H1C_F_ST_SILENT_SHUT flags
1369 - MINOR: mux-h1: Add a dedicated enum to deal with H1 connection state
1370 - MEDIUM: mux-h1: Handle H1C states via its state field instead of H1C_F_ST_*
1371 - MINOR: mux-h1: Don't handle subscribe for reads in h1_process_demux()
1372 - CLEANUP: mux-h1: Rename H1C_F_ERR_PENDING into H1C_F_ABRT_PENDING
1373 - MINOR: mux-h1: Add flag on H1 stream to deal with internal errors
1374 - MEDIUM: mux-h1: Rely on the H1C to deal with shutdown for reads
1375 - CLEANUP: mux-h1: Reorder H1 connection flags to avoid holes
1376 - MEDIUM: mux-h1: Don't report a final error whe a message is aborted
1377 - MEDIUM: mux-pt: Don't always set a final error on SE on the sending path
1378 - MEDIUM: mux-h2: Introduce flags to deal with connection read/write errors
1379 - CLEANUP: mux-h2: Remove unused fields in h2c structures
1380 - MEDIUM: mux-fcgi: Introduce flags to deal with connection read/write errors
1381 - MINOR: sconn: Set SE_FL_ERROR only when there is no more data to read
1382 - MINOR: mux-h1: Rely on a H1S flag to know a WS key was found or not
1383 - DOC: lua-api: Remove warning about the lua filters
1384 - BUG/MEDIUM: listener: Fix race condition when updating the global mngmt task
1385 - CLEANUP: listener: Remove useless task_queue from manage_global_listener_queue
1386 - BUG/MINOR: mux-h1: Fix error handling when H1S allocation failed on client side
1387 - DOC: internal: commit notes about polling states and flags
1388 - DOC: internal: commit notes about polling states and flags on connect()
1389 - CLEANUP: mux-h1: Don't test h1c in h1_shutw_conn()
1390 - BUG/MINOR: http_ana/txn: don't re-initialize txn and req var lists
1391 - BUG/MEDIUM: raw-sock: Don't report connection error if something was received
1392 - BUG/MINOR: ssl: don't initialize the keylog callback when not required
1393 - BUILD: Makefile: enable USE_SHM_OPEN by default on freebsd
1394 - BUG/MEDIUM: peers: messages about unkown tables not correctly ignored
1395 - MINOR: cfgparse: Always check the section position
1396 - MEDIUM: thread: Restric nbthread/thread-group(s) to very first global sections
1397 - BUILD: peers: Remove unused variables
1398 - MINOR: ncbuf: complete doc for ncb_advance()
1399 - BUG/MEDIUM: quic: fix unsuccessful handshakes on ncb_advance error
1400 - BUG/MEDIUM: quic: fix memleak for out-of-order crypto data
1401 - MINOR: quic: complete traces/debug for handshake
1402
Willy Tarreauea8aebe2022-10-14 20:45:23 +020014032022/10/14 : 2.7-dev8
1404 - BUG/MINOR: checks: update pgsql regex on auth packet
1405 - DOC: config: Fix pgsql-check documentation to make user param mandatory
1406 - CLEANUP: mux-quic: remove usage of non-standard ull type
1407 - CLEANUP: quic: remove global var definition in quic_tls header
1408 - BUG/MINOR: quic: adjust quic_tls prototypes
1409 - CLEANUP: quic: fix headers
1410 - CLEANUP: quic: remove unused function prototype
1411 - CLEANUP: quic: remove duplicated varint code from xprt_quic.h
1412 - CLEANUP: quic: create a dedicated quic_conn module
1413 - BUG/MINOR: mux-quic: ignore STOP_SENDING for locally closed stream
1414 - BUG/MEDIUM: lua: Don't crash in hlua_lua2arg_check on failure
1415 - BUG/MEDIUM: lua: handle stick table implicit arguments right.
1416 - BUILD: h1: silence an initiialized warning with gcc-4.7 and -Os
1417 - MINOR: fd: add a new function to only raise RLIMIT_NOFILE
1418 - MINOR: init: do not try to shrink existing RLIMIT_NOFIlE
1419 - BUG/MINOR: http-fetch: Update method after a prefetch in smp_fetch_meth()
1420 - BUILD: http_fetch: silence an uninitiialized warning with gcc-4/5/6 at -Os
1421 - BUG/MINOR: hlua: hlua_channel_insert_data() behavior conflicts with documentation
1422 - MINOR: quic: limit usage of ssl_sock_ctx in favor of quic_conn
1423 - MINOR: mux-quic: check quic-conn return code on Tx
1424 - CLEANUP: quic: fix indentation
1425 - MEDIUM: quic: retrieve frontend destination address
1426 - CLEANUP: Reapply ist.cocci (2)
1427 - CLEANUP: Reapply strcmp.cocci
1428 - CLEANUP: quic/receiver: remove the now unused tx_qring list
1429 - BUG/MINOR: quic: set IP_PKTINFO socket option for QUIC receivers only
1430 - MINOR: hlua: some luaL_checktype() calls were not guarded with MAY_LJMP
1431 - DOC: configuration: missing 'if' in tcp-request content example
1432 - MINOR: hlua: removing ambiguous lua_pushvalue with 0 index
1433 - BUG/MAJOR: stick-tables: do not try to index a server name for applets
1434 - MINOR: plock: support disabling exponential back-off
1435 - MINOR: freq_ctr: use the thread's local time whenever possible
1436 - MEDIUM: stick-table: switch the table lock to rwlock
1437 - MINOR: stick-table: do not take an exclusive lock when downing ref_cnt
1438 - MINOR: stick-table: move the write lock inside stktable_touch_with_exp()
1439 - MEDIUM: stick-table: only take the lock when needed in stktable_touch_with_exp()
1440 - MEDIUM: stick-table: make stksess_kill_if_expired() avoid the exclusive lock
1441 - MEDIUM: stick-table: return inserted entry in __stktable_store()
1442 - MEDIUM: stick-table: free newly allocated stkess if it couldn't be inserted
1443 - MEDIUM: stick-table: switch to rdlock in stktable_lookup() and lookup_key()
1444 - MEDIUM: stick-table: make stktable_get_entry() look up under a read lock
1445 - MEDIUM: stick-table: do not take a lock to update t->current anymore.
1446 - MEDIUM: stick-table: make stktable_set_entry() look up under a read lock
1447 - MEDIUM: stick-table: requeue the expiration task out of the exclusive lock
1448 - MINOR: stick-table: split stktable_store() between key and requeue
1449 - MEDIUM: stick-table: always use atomic ops to requeue the table's task
1450 - MEDIUM: stick-table: requeue the wakeup task out of the write lock
1451 - BUG/MINOR: stick-table: fix build with DEBUG_THREAD
1452 - REORG: mux-fcgi: Extract flags and enums into mux_fcgi-t.h
1453 - MINOR: flags/mux-fcgi: Decode FCGI connection and stream flags
1454 - BUG/MEDIUM: mux-h1: Add connection error handling when reading/sending on a pipe
1455 - BUG/MEDIUM: mux-h1: Handle abort with an incomplete message during parsing
1456 - BUG/MINOR: server: make sure "show servers state" hides private bits
1457 - MINOR: checks: use the lighter PRNG for spread checks
1458 - MEDIUM: checks: spread the checks load over random threads
1459 - CI: SSL: use proper version generating when "latest" semantic is used
1460 - CI: SSL: temporarily stick to LibreSSL=3.5.3
1461 - MINOR: quic: New quic_cstream object implementation
1462 - MINOR: quic: Extract CRYPTO frame parsing from qc_parse_pkt_frms()
1463 - MINOR: quic: Use a non-contiguous buffer for RX CRYPTO data
1464 - BUG/MINOR: quic: Stalled 0RTT connections with big ClientHello TLS message
1465 - MINOR: quic: Split the secrets key allocation in two parts
1466 - CLEANUP: quic: remove unused rxbufs member in receiver
1467 - CLEANUP: quic: improve naming for rxbuf/datagrams handling
1468 - MINOR: quic: implement datagram cleanup for quic_receiver_buf
1469 - MINOR: ring: ring_cast_from_area() cast from an allocated area
1470 - MINOR: buffers: split b_force_xfer() into b_cpy() and b_force_xfer()
1471 - MINOR: logs: startup-logs can use a shm for logging the reload
1472 - MINOR: mworker/cli: reload command displays the startup-logs
1473 - MEDIUM: quic: respect the threads assigned to a bind line
1474 - DOC: management: update the "reload" command of the master CLI
1475 - BUILD: ssl_sock: bind_conf uninitialized in ssl_sock_bind_verifycbk()
1476 - BUG/MEDIUM: httpclient: Don't set EOM flag on an empty HTX message
1477 - MINOR: httpclient/lua: Don't set req_payload callback if body is empty
1478 - DOC/CLEANUP: lua-api: some minor corrections
1479 - DOC: lua-api: updating toolbox link
1480 - DOC/CLEANUP: lua-api: removing duplicate core.proxies attribute
1481 - DOC: management: add forgotten "show startup-logs"
1482 - DOC: management: "show startup-logs" for master CLI
1483 - CI: Replace the deprecated `::set-output` command by writing to $GITHUB_OUTPUT in matrix.py
1484 - CI: Replace the deprecated `::set-output` command by writing to $GITHUB_OUTPUT in workflow definition
1485
Willy Tarreaudd4a2a62022-10-03 15:20:38 +020014862022/10/03 : 2.7-dev7
1487 - BUG/MEDIUM: mux-quic: fix nb_hreq decrement
1488 - CLEANUP: httpclient: deleted unused variables
1489 - MINOR: httpclient: enabled the use of SNI presets
1490 - OPTIM: hpack-huff: reduce the cache footprint of the huffman decoder
1491 - BUG/MINOR: mux-quic: do not keep detached qcs with empty Tx buffers
1492 - REORG: mux-quic: extract traces in a dedicated source file
1493 - REORG: mux-quic: export HTTP related function in a dedicated file
1494 - MINOR: mux-quic: refactor snd_buf
1495 - BUG/MEDIUM: mux-quic: properly trim HTX buffer on snd_buf reset
1496 - BUG/MINOR: mux-h1: Account consumed output data on synchronous connection error
1497 - BUG/MINOR: log: improper behavior when escaping log data
1498 - CLEANUP: tools: removing escape_chunk() function
1499 - MINOR: clock: split local and global date updates
1500 - MINOR: pollers: only update the local date during busy polling
1501 - MINOR: clock: do not update the global date too often
1502 - REGTESTS: 4be_1srv_smtpchk_httpchk_layer47errors: Return valid SMTP replies
1503 - MINOR: smtpchk: Update expect rule to fully match replies to EHLO commands
1504 - BUG/MINOR: smtpchk: SMTP Service check should gracefully close SMTP transaction
1505 - MINOR: list: documenting mt_list_for_each_entry_safe() macro
1506 - CLEANUP: list: Fix mt_list_for_each_entry_safe indentation
1507 - BUG/MINOR: hlua: Remove \n in Lua error message built with memprintf
1508 - MINOR: hlua: Allow argument on lua-lod(-per-thread) directives
1509 - BUG/MINOR: anon: memory illegal accesses in tools.c with hash_anon and hash_ipanon
1510 - MEDIUM: mworker/cli: keep the connection of the FD that ask for a reload
1511 - BUG/MINOR: hlua: fixing ambiguous sizeof in hlua_load_per_thread
1512 - MINOR: mworker/cli: replace close() by fd_delete()
1513 - MINOR: mworker: store and shows loading status
1514 - MINOR: mworker: mworker_cli_proxy_new_listener() returns a bind_conf
1515 - MINOR: mworker: stores the mcli_reload bind_conf
1516 - MINOR: mworker/cli: the mcli_reload bind_conf only send the reload status
1517 - DOC: management: describe the new reload command behavior
1518 - CLEANUP: list: fix again some style issues in the recent comments
1519 - BUG/MINOR: stream: Perform errors handling in right order in stream_new()
1520 - BUG/MEDIUM: stconn: Reset SE descriptor when we fail to create a stream
1521 - BUG/MEDIUM: resolvers: Remove aborted resolutions from query_ids tree
1522 - DOC: management: add timeout on the "reload" command
1523 - BUG/MINOR: ring: fix the size check in ring_make_from_area()
1524 - BUG/MINOR: config: don't count trailing spaces as empty arg
1525 - Revert "BUG/MINOR: config: don't count trailing spaces as empty arg"
1526 - BUG/MINOR: hlua: fixing hlua_http_msg_del_data behavior
1527 - BUG/MINOR: hlua: fixing hlua_http_msg_insert_data behavior
1528 - MINOR: cli: Add anonymization on a missed element for 'show sess all'
1529 - MINOR: cli: remove error message with 'set anon on|off'
1530 - MINOR: tools: modify hash_ipanon in order to use it in cli
1531 - MINOR: cli: use hash_ipanon to anonymized address
1532 - MINOR: cli: Add an anonymization on a missed element in 'show server state'
1533 - MINOR: config: correct errors about argument number in condition in cfgparse.c
1534 - MINOR: config: Add other keywords when dump the anonymized configuration file
1535 - MINOR: config: Add option line when the configuration file is dumped
1536 - MINOR: cli: correct commentary and replace 'set global-key' name
1537 - MINOR: tools: Impprove hash_ipanon to support dgram sockets and port offsets
1538 - MINOR: tools: Impprove hash_ipanon to not hash FD-based addresses
1539 - BUG/MINOR: hlua: _hlua_http_msg_delete incorrect behavior when offset is used
1540 - DOC: management: httpclient can resolve server names in URLs
1541 - BUG/MINOR: hlua: prevent crash when loading numerous arguments using lua-load(per-thread)
1542 - DOC/CLEANUP: lua-api: removing duplicate date functions doc
1543 - MINOR: hlua: ambiguous lua_pushvalue with 0 index
1544 - BUG/MINOR: config: don't count trailing spaces as empty arg (v2)
1545 - BUG/MEDIUM: config: count line arguments without dereferencing the output
1546 - BUG/MAJOR: conn-idle: fix hash indexing issues on idle conns
1547 - BUG/MINOR: config: insufficient syntax check of the global "maxconn" value
1548 - BUG/MINOR: backend: only enforce turn-around state when not redispatching
1549
Willy Tarreau4b10a5c2022-09-17 12:24:53 +020015502022/09/17 : 2.7-dev6
1551 - MINOR: Revert part of clarifying samples support per os commit
1552 - BUILD: makefile: enable crypt(3) for NetBSD
1553 - BUG/MINOR: quic: Retransmitted frames marked as acknowledged
1554 - BUG/MINOR: quic: Possible crash with "tls-ticket-keys" on QUIC bind lines
1555 - MINOR: http-check: Remove support for headers/body in "option httpchk" version
1556 - BUG/MINOR: h1: Support headers case adjustment for TCP proxies
1557 - BUG/MINOR: quic: Possible crash when verifying certificates
1558 - BUILD: quic: add some ifdef around the SSL_ERROR_* for libressl
1559 - BUILD: ssl: fix ssl_sock_switchtx_cbk when no client_hello_cb
1560 - BUILD: quic: temporarly ignore chacha20_poly1305 for libressl
1561 - BUILD: quic: enable early data only with >= openssl 1.1.1
1562 - BUILD: ssl: fix the ifdef mess in ssl_sock_initial_ctx
1563 - BUILD: quic: fix the #ifdef in ssl_quic_initial_ctx()
1564 - MINOR: quic: add QUIC support when no client_hello_cb
1565 - MINOR: quic: Add traces about sent or resent TX frames
1566 - MINOR: quic: No TRACE_LEAVE() in retrieve_qc_conn_from_cid()
1567 - BUG/MINOR: quic: Wrong connection ID to thread ID association
1568 - BUG/MINOR: task: always reset a new tasklet's call date
1569 - BUG/MINOR: task: make task_instant_wakeup() work on a task not a tasklet
1570 - MINOR: task: permanently enable latency measurement on tasklets
1571 - CLEANUP: task: rename ->call_date to ->wake_date
1572 - BUG/MINOR: sched: properly account for the CPU time of dying tasks
1573 - MINOR: sched: store the current profile entry in the thread context
1574 - BUG/MINOR: stream/sched: take into account CPU profiling for the last call
1575 - MINOR: tasks: do not keep cpu and latency times in struct task
1576 - MINOR: tools: add generic pointer hashing functions
1577 - CLEANUP: activity: make memprof use the generic ptr_hash() function
1578 - CLEANUP: activity: make taskprof use ptr_hash()
1579 - MINOR: debug: add struct ha_caller to describe a calling location
1580 - CLEANUP: debug: use struct ha_caller for memstat
1581 - DEBUG: task: define a series of wakeup types for tasks and tasklets
1582 - DEBUG: task: use struct ha_caller instead of arrays of file:line
1583 - DEBUG: applet: instrument appctx_wakeup() to log the caller's location
1584 - DEBUG: task: simplify the caller recording in DEBUG_TASK
1585 - CLEANUP: task: move tid and wake_date into the common part
1586 - CLEANUP: sched: remove duplicate code in run_tasks_from_list()
1587 - CLEANUP: activity: make the number of sched activity entries more configurable
1588 - DEBUG: resolvers: unstatify process_resolvers() to make it appear in profiling
1589 - DEBUG: quic: export the few task handlers that often appear in task dumps
1590 - MEDIUM: tasks/activity: combine the called function with the caller
1591 - MINOR: tasks/activity: improve the caller-callee activity hash
1592 - MINOR: activity/cli: support aggregating task profiling outputs
1593 - MINOR: activity/cli: support sorting task profiling by total CPU time
1594 - BUG/MINOR: signals/poller: set the poller timeout to 0 when there are signals
1595 - BUG/MINOR: quic: Speed up the handshake completion only one time
1596 - BUG/MINOR: quic: Trace fix about packet number space information.
1597 - BUG/MINOR: h3: Crash when h3 trace verbosity is "minimal"
1598 - MINOR: h3: Add the quic_conn object to h3 traces
1599 - MINOR: h3: Missing connection argument for a TRACE_LEAVE() argument
1600 - MINOR: h3: Send the h3 settings with others streams (requests)
1601 - MINOR: dev/udp: Apply the corruption to both directions
1602 - BUILD: udp-perturb: Add a make target for udp-perturb tool
1603 - BUG/MINOR: signals/poller: ensure wakeup from signals
1604 - CI: cirrus-ci: bump FreeBSD image to 13-1
1605 - DEV: flags: fix usage message to reflect available options
1606 - DEV: flags: add missing CO_FL_FDLESS connection flag
1607 - MINOR: flags: add a new file to host flag dumping macros
1608 - MINOR: flags: implement a macro used to dump enums inside masks
1609 - MINOR: flags/channel: use flag dumping for channel flags and analysers
1610 - MINOR: flags/connection: use flag dumping for connection flags
1611 - MINOR: flags/stconn: use flag dumping for stconn and sedesc flags
1612 - MINOR: flags/stream: use flag dumping for stream error type
1613 - MINOR: flags/stream: use flag dumping for stream flags
1614 - MINOR: flags/task: use flag dumping for task state
1615 - MINOR: flags/http_ana: use flag dumping for txn flags
1616 - DEV: flags: remove the now unused SHOW_FLAG() definition
1617 - DEV: flags: remove the now useless intermediary functions
1618 - MINOR: flags/htx: use flag dumping to show htx and start-line flags
1619 - MINOR: flags/http_ana: use flag dumping to show http msg states
1620 - BUG/MEDIUM: proxy: ensure pause_proxy() and resume_proxy() own PROXY_LOCK
1621 - MINOR: listener: small API change
1622 - MINOR: proxy/listener: support for additional PAUSED state
1623 - BUG/MINOR: stats: fixing stat shows disabled frontend status as 'OPEN'
1624 - BUILD: flags: fix build warning in some macros used by show_flags
1625 - BUILD: flags: fix the fallback macros for missing stdio
1626 - CLEANUP: pollers: remove dead code in the polling loop
1627 - BUG/MINOR: mux-h1: Increment open_streams counter when H1 stream is created
1628 - REGTESTS: healthcheckmail: Relax matching on the healthcheck log message
1629 - CLEANUP: listener: function comment typo in stop_listener()
1630 - BUG/MINOR: listener: null pointer dereference suspected by coverity
1631 - MINOR: flags/fd: decode FD flags states
1632 - REORG: mux-h2: extract flags and enums into mux_h2-t.h
1633 - MINOR: flags/mux-h2: decode H2C and H2S flags
1634 - REGTESTS: log: test the log-forward feature
1635 - BUG/MEDIUM: sink: bad init sequence on tcp sink from a ring.
1636 - REGTESTS: ssl/log: test the log-forward with SSL
1637 - MEDIUM: httpclient: httpclient_create_proxy() creates a proxy for httpclient
1638 - MEDIUM: httpclient: allow to use another proxy
1639 - DOC: fix TOC in starter guide for subsection 3.3.8. Statistics
1640 - MINOR: httpclient: export httpclient_create_proxy()
1641 - MEDIUM: quic: separate path for rx and tx with set_encryption_secrets
1642 - BUG/MEDIUM: mux-quic: fix crash on early app-ops release
1643 - REORG: mux-h1: extract flags and enums into mux_h1-t.h
1644 - MINOR: flags/mux-h1: decode H1C and H1S flags
1645 - CLEANUP: mux-quic: remove stconn usage in h3/hq
1646 - BUG/MINOR: mux-quic: do not remotely close stream too early
1647 - CLEANUP: exclude udp-perturb with .gitignore
1648 - BUG/MEDIUM: server: segv when adding server with hostname from CLI
1649 - CLEANUP: quic,ssl: fix tiny typos in C comments
1650 - BUG/MEDIUM: captures: free() an error capture out of the proxy lock
1651 - BUILD: fd: fix a build warning on the DWCAS
1652 - MINOR: anon: add new macros and functions to anonymize contents
1653 - MINOR: anon: store the anonymizing key in the global structure
1654 - MINOR: anon: store the anonymizing key in the CLI's appctx
1655 - MINOR: cli: anonymize commands 'show sess' and 'show sess all'
1656 - MINOR: cli: anonymize 'show servers state' and 'show servers conn'
1657 - MINOR: config: add command-line -dC to dump the configuration file
1658 - SCRIPTS: announce-release: update some URLs to https
1659
Willy Tarreau3bb2b5d2022-09-02 19:36:50 +020016602022/09/02 : 2.7-dev5
1661 - BUG/MINOR: mux-quic: Fix memleak on QUIC stream buffer for unacknowledged data
1662 - BUG/MEDIUM: cpu-map: fix thread 1's affinity affecting all threads
1663 - MINOR: cpu-map: remove obsolete diag warning about combined ranges
1664 - BUG/MAJOR: mworker: fix infinite loop on master with no proxies.
1665 - REGTESTS: launch http_reuse_always in mworker mode
1666 - BUG/MINOR: quix: Memleak for non in flight TX packets
1667 - BUG/MINOR: quic: Wrong list_for_each_entry() use when building packets from qc_do_build_pkt()
1668 - BUG/MINOR: quic: Safer QUIC frame builders
1669 - MINOR: quic: Replace MT_LISTs by LISTs for RX packets.
1670 - BUG/MEDIUM: applet: fix incorrect check for abnormal return condition from handler
1671 - BUG/MINOR: applet: make the call_rate only count the no-progress calls
1672 - MEDIUM: peers: limit the number of updates sent at once
1673 - BUILD: tcp_sample: fix build of get_tcp_info() on OpenBSD
1674 - BUG/MINOR: resolvers: return the correct value in resolvers_finalize_config()
1675 - BUG/MINOR: mworker: does not create the "default" resolvers in wait mode
1676 - BUG/MINOR: tcpcheck: Disable QUICKACK only if data should be sent after connect
1677 - REGTESTS: Fix prometheus script to perform HTTP health-checks
1678 - MINOR: resolvers: shut the warning when "default" resolvers is implicit
1679 - Revert "BUG/MINOR: quix: Memleak for non in flight TX packets"
1680 - BUG/MINOR: quic: Leak in qc_release_lost_pkts() for non in flight TX packets
1681 - BUG/MINOR: quic: Stalled connections (missing I/O handler wakeup)
1682 - CLEANUP: quic: No more use ->rx_list MT_LIST entry point (quic_rx_packet)
1683 - CLEANUP: quic: Remove a useless check in qc_lstnr_pkt_rcv()
1684 - MINOR: quic: Remove useless traces about references to TX packets
1685 - Revert "MINOR: quic: Remove useless traces about references to TX packets"
1686 - DOC: configuration: do-resolve doesn't work with a port in the string
1687 - MINOR: sample: add the host_only and port_only converters
1688 - BUG/MINOR: httpclient: fix resolution with port
1689 - DOC: configuration.txt: do-resolve must use host_only to remove its port.
1690 - BUG/MINOR: quic: Null packet dereferencing from qc_dup_pkt_frms() trace
1691 - BUG/MINOR: quic: Frames added to packets even if not built.
1692 - BUG/MEDIUM: spoe: Properly update streams waiting for a ACK in async mode
1693 - BUG/MEDIUM: peers: Add connect and server timeut to peers proxy
1694 - BUG/MEDIUM: peers: Don't use resync timer when local resync is in progress
1695 - BUG/MEDIUM: peers: Don't start resync on reload if local peer is not up-to-date
1696 - BUG/MINOR: hlua: Rely on CF_EOI to detect end of message in HTTP applets
1697 - BUG/MEDIUM: mux-h1: do not refrain from signaling errors after end of input
1698 - BUG/MINOR: epoll: do not actively poll for Rx after an error
1699 - MINOR: raw-sock: don't try to send if an error was already reported
1700 - BUG/MINOR: quic: Missing header protection AES cipher context initialisations (draft-v2)
1701 - MINOR: quic: Add a trace to distinguish the datagram from the packets inside
1702 - BUG/MINOR: ssl: fix deinit of the ca-file tree
1703 - BUG/MINOR: ssl: leak of ckch_inst_link in ckch_inst_free()
1704 - BUG/MINOR: tcpcheck: Disable QUICKACK for default tcp-check (with no rule)
1705 - BUG/MEDIUM: ssl: Fix a UAF when old ckch instances are released
1706 - BUG/MINOR: ssl: revert two wrong fixes with ckhi_link
1707 - BUG/MINOR: dev/udp: properly preset the rx address size
1708 - BUILD: debug: make sure debug macros are never empty
1709 - MINOR: quic: Move traces about RX/TX bytes from QUIC_EV_CONN_PRSAFRM event
1710 - BUG/MINOR: quic: TX frames memleak
1711 - BUG/MINOR: ssl: leak of ckch_inst_link in ckch_inst_free() v2
1712 - MINOR: sink/ring: rotate non-empty file-backed contents only
1713 - BUG/MINOR: regex: Properly handle PCRE2 lib compiled without JIT support
1714 - REGTESTS: http_request_buffer: Add a barrier to not mix up log messages
1715 - BUG/MEDIUM: mux-h1: always use RST to kill idle connections in pools
1716 - MINOR: backend: always satisfy the first req reuse rule with l7 retries
1717 - BUG/MINOR: quic: Do not ack when probing
1718 - MINOR: quic: Add TX frames addresses to traces to several trace events
1719 - MINOR: quic: Trace typo fix in qc_release_frm()
1720 - BUG/MINOR: quic: Frames leak during retransmissions
1721 - BUG/MINOR: h2: properly set the direction flag on HTX response
1722 - BUG/MEDIUM: httpclient: always detach the caller before self-killing
1723 - BUG/MINOR: httpclient: only ask for more room on failed writes
1724 - BUG/MINOR: httpclient: keep-alive was accidentely disabled
1725 - MEDIUM: httpclient: enable ALPN support on outgoing https connections
1726 - BUG/MINOR: mux-h2: fix the "show fd" dest buffer for the subscriber
1727 - BUG/MINOR: mux-h1: fix the "show fd" dest buffer for the subscriber
1728 - BUG/MINOR: mux-fcgi: fix the "show fd" dest buffer for the subscriber
1729 - DEBUG: stream: minor rearrangement of a few fields in struct stream.
1730 - MINOR: debug: report applet pointer and handler in crashes when known
1731 - MINOR: mux-h2: extract the stream dump function out of h2_show_fd()
1732 - MINOR: mux-h2: extract the connection dump function out of h2_show_fd()
1733 - MINOR: muxes: add a "show_sd" helper to complete "show sess" dumps
1734 - MINOR: mux-h2: provide a "show_sd" helper to output stream debugging info
1735 - MINOR: mux-h2: insert line breaks in "show sess all" output for legibility
1736 - MINOR: mux-quic: provide a "show_sd" helper to output stream debugging info
1737 - MINOR: mux-h1: split "show_fd" into connection and stream
1738 - MINOR: mux-h1: provide a "show_sd" helper to output stream debugging info
1739 - BUG/MINOR: http-act: initialize http fmt head earlier
1740
Willy Tarreauf5320192022-08-20 15:56:31 +020017412022/08/20 : 2.7-dev4
1742 - BUG/MEDIUM: quic: Wrong packet length check in qc_do_rm_hp()
1743 - MINOR: quic: Too much useless traces in qc_build_frms()
1744 - BUG/MEDIUM: quic: Missing AEAD TAG check after removing header protection
1745 - MINOR: quic: Replace pool_zalloc() by pool_malloc() for fake datagrams
1746 - MINOR: debug: make the mem_stats section aligned to void*
1747 - MINOR: debug: store and report the pool's name in struct mem_stats
1748 - MINOR: debug: also store the function name in struct mem_stats
1749 - MINOR: debug/memstats: automatically determine first column size
1750 - MINOR: debug/memstats: permit to pass the size to free()
1751 - CLEANUP: mux-quic: remove loop on sending frames
1752 - MINOR: quic: replace custom buf on Tx by default struct buffer
1753 - MINOR: quic: release Tx buffer on each send
1754 - MINOR: quic: refactor datagram commit in Tx buffer
1755 - MINOR: quic: skip sending if no frame to send in io-cb
1756 - BUG/MINOR: mux-quic: open stream on STOP_SENDING
1757 - BUG/MINOR: quic: fix crash on handshake io-cb for null next enc level
1758 - BUG/MEDIUM: quic: always remove the connection from the accept list on close
1759 - BUG/MEDIUM: poller: use fd_delete() to release the poller pipes
1760 - BUG/MEDIUM: task: relax one thread consistency check in task_unlink_wq()
1761 - MEDIUM: quic: xprt traces rework
1762 - BUILD: stconn: fix build warning at -O3 about possible null sc
1763 - MINOR: quic: Remove useless lock for RX packets
1764 - BUG/MINOR: quic: Possible infinite loop in quic_build_post_handshake_frames()
1765 - CLEANUP: quic: Remove trailing spaces
1766 - MINOR: mux-quic: adjust enter/leave traces
1767 - MINOR: mux-quic: define protocol error traces
1768 - CLEANUP: mux-quic: adjust traces level
1769 - MINOR: mux-quic: define new traces
1770 - BUG/MEDIUM: mux-quic: fix crash due to invalid trace arg
1771 - BUG/MEDIUM: quic: Possible use of uninitialized <odcid> variable in qc_lstnr_params_init()
1772 - BUG/MEDIUM: ring: fix too lax 'size' parser
1773 - BUG/MEDIUM: quic: Wrong use of <token_odcid> in qc_lsntr_pkt_rcv()
1774 - BUILD: ring: forward-declare struct appctx to avoid a build warning
1775 - MINOR: ring: support creating a ring from a linear area
1776 - MINOR: ring: add support for a backing-file
1777 - DEV: haring: add a simple utility to read file-backed rings
1778 - DEV: haring: support remapping LF in contents with CR VT
1779 - BUG/MINOR: quic: memleak on wrong datagram receipt
1780 - BUILD: sink: replace S_IRUSR, S_IWUSR with their octal value
1781 - MINOR: ring: archive a previous file-backed ring on startup
1782 - BUG/MINOR: mux-quic: fix crash with traces in qc_detach()
1783 - BUG/MINOR: quic: MIssing check when building TX packets
1784 - BUG/MINOR: quic: Wrong status returned by qc_pkt_decrypt()
1785 - MINOR: memprof: export the minimum definitions for memory profiling
1786 - MINOR: pool/memprof: report pool alloc/free in memory profiling
1787 - MINOR: pools/memprof: store and report the pool's name in each bin
1788 - MINOR: chunk: inline alloc_trash_chunk()
1789 - MINOR: stick-table: Add table_expire() and table_idle() new converters
1790 - CLEANUP: exclude haring with .gitignore
1791 - MINOR: quic: adjust quic_frame flag manipulation
1792 - MINOR: h3: report error on control stream close
1793 - MINOR: qpack: report error on enc/dec stream close
1794 - BUG/MEDIUM: mux-quic: reject uni stream ID exceeding flow control
1795 - MINOR: mux-quic: adjust traces on stream init
1796 - MINOR: mux-quic: add missing args on some traces
1797 - MINOR: quic: refactor application send
1798 - BUG/MINOR: quic: do not notify MUX on frame retransmit
1799 - BUG/MEDIUM: http-ana: fix crash or wrong header deletion by http-restrict-req-hdr-names
1800 - BUG/MINOR: quic: Missing initializations for ducplicated frames.
1801 - BUG/MEDIUM: quic: fix crash on MUX send notification
1802 - REORG: h2: extract cookies concat function in http_htx
1803 - REGTESTS: add test for HTTP/2 cookies concatenation
1804 - MEDIUM: h3: concatenate multiple cookie headers
1805 - MINOR: applet: add a function to reset the svcctx of an applet
1806 - BUG/MEDIUM: cli: always reset the service context between commands
1807 - BUG/MEDIUM: mux-h2: do not fiddle with ->dsi to indicate demux is idle
1808 - MINOR: mux-h2/traces: report transition to SETTINGS1 before not after
1809 - MINOR: mux-h2: make streams know if they need to send more data
1810 - BUG/MINOR: mux-h2: send a CANCEL instead of ES on truncated writes
1811 - BUG/MINOR: quic: Possible crashes when dereferencing ->pkt quic_frame struct member
1812 - MINOR: quic: Add frame addresses to QUIC_EV_CONN_PRSAFRM event traces
1813 - BUG/MINOR: quic: Wrong splitted duplicated frames handling
1814 - MINOR: quic: Add the QUIC connection to mux traces
1815 - MINOR: quic: Trace fix in qc_release_frm()
1816 - BUG/MAJOR: log-forward: Fix log-forward proxies not fully initialized
1817 - BUG/MAJOR: log-forward: Fix ssl layer not initialized on bind even if configured
1818 - MINOR: quic: Add reusable cipher contexts for header protection
1819 - BUG/MINOR: ssl/cli: error when the ca-file is empty
1820 - MINOR: ssl: handle ca-file appending in cafile_entry
1821 - MINOR: ssl/cli: implement "add ssl ca-file"
1822
Willy Tarreau87e95d32022-08-07 17:28:59 +020018232022/08/07 : 2.7-dev3
1824 - BUILD: makefile: Fix install(1) handling for OpenBSD/NetBSD/Solaris/AIX
1825 - BUG/MEDIUM: tools: avoid calling dlsym() in static builds (try 2)
1826 - MINOR: resolvers: resolvers_destroy() deinit and free a resolver
1827 - BUG/MINOR: resolvers: shut off the warning for the default resolvers
1828 - BUG/MINOR: ssl: allow duplicate certificates in ca-file directories
1829 - BUG/MINOR: tools: fix statistical_prng_range()'s output range
1830 - BUG/MINOR: quic: do not send CONNECTION_CLOSE_APP in initial/handshake
1831 - BUILD: debug: Add braces to if statement calling only CHECK_IF()
1832 - BUG/MINOR: fd: Properly init the fd state in fd_insert()
1833 - BUG/MEDIUM: fd/threads: fix incorrect thread selection in wakeup broadcast
1834 - MINOR: init: load OpenSSL error strings
1835 - MINOR: ssl: enhance ca-file error emitting
1836 - BUG/MINOR: mworker/cli: relative pid prefix not validated anymore
1837 - BUG/MAJOR: mux_quic: fix invalid PROTOCOL_VIOLATION on POST data overlap
1838 - BUG/MEDIUM: mworker: proc_self incorrectly set crashes upon reload
1839 - BUILD: add detection for unsupported compiler models
1840 - BUG/MEDIUM: stconn: Only reset connect expiration when processing backend side
1841 - BUG/MINOR: backend: Fallback on RR algo if balance on source is impossible
1842 - BUG/MEDIUM: master: force the thread count earlier
1843 - BUG/MAJOR: poller: drop FD's tgid when masks don't match
1844 - DEBUG: fd: detect possibly invalid tgid in fd_insert()
1845 - BUG/MINOR: sockpair: wrong return value for fd_send_uxst()
1846 - MINOR: sockpair: move send_fd_uxst() error message in caller
1847 - Revert "BUG/MINOR: peers: set the proxy's name to the peers section name"
1848 - DEBUG: fd: split the fd check
1849 - MEDIUM: resolvers: continue startup if network is unavailable
1850 - BUG/MINOR: fd: always remove late updates when freeing fd_updt[]
1851 - MINOR: cli: emit a warning when _getsocks was used more than once
1852 - BUG/MINOR: mworker: PROC_O_LEAVING used but not updated
1853 - Revert "MINOR: cli: emit a warning when _getsocks was used more than once"
1854 - MINOR: cli: warning on _getsocks when socket were closed
1855 - BUG/MEDIUM: mux-quic: fix missing EOI flag to prevent streams leaks
1856 - MINOR: quic: Congestion control architecture refactoring
1857 - MEDIUM: quic: Cubic congestion control algorithm implementation
1858 - MINOR: quic: New "quic-cc-algo" bind keyword
1859 - BUG/MINOR: quic: loss time limit variable computed but not used
1860 - MINOR: quic: Stop looking for packet loss asap
1861 - BUG/MAJOR: quic: Useless resource intensive loop qc_ackrng_pkts()
1862 - MINOR: quic: Send packets as much as possible from qc_send_app_pkts()
1863 - BUG/MEDIUM: queue/threads: limit the number of entries dequeued at once
1864 - MAJOR: threads/plock: update the embedded library
1865 - MINOR: thread: provide an alternative to pthread's rwlock
1866 - DEBUG: tools: provide a tree dump function for ebmbtrees as well
1867 - MINOR: ebtree: add ebmb_lookup_shorter() to pursue lookups
1868 - BUG/MEDIUM: pattern: only visit equivalent nodes when skipping versions
1869 - BUG/MINOR: mux-quic: prevent crash if conn released during IO callback
1870 - CLEANUP: mux-quic: remove useless app_ops is_active callback
1871 - BUG/MINOR: mux-quic: do not free conn if attached streams
1872 - MINOR: mux-quic: save proxy instance into qcc
1873 - MINOR: mux-quic: use timeout server for backend conns
1874 - MEDIUM: mux-quic: adjust timeout refresh
1875 - MINOR: mux-quic: count in-progress requests
1876 - MEDIUM: mux-quic: implement http-keep-alive timeout
1877 - MINOR: peers: Add a warning about incompatible SSL config for the local peer
1878 - MINOR: peers: Use a dedicated reconnect timeout when stopping the local peer
1879 - BUG/MEDIUM: peers: limit reconnect attempts of the old process on reload
1880 - BUG/MINOR: peers: Use right channel flag to consider the peer as connected
1881 - BUG/MEDIUM: dns: Properly initialize new DNS session
1882 - BUG/MINOR: backend: Don't increment conn_retries counter too early
1883 - MINOR: server: Constify source server to copy its settings
1884 - REORG: server: Export srv_settings_cpy() function
1885 - BUG/MEDIUM: proxy: Perform a custom copy for default server settings
1886 - BUG/MINOR: quic: Missing in flight ack eliciting packet counter decrement
1887 - BUG/MEDIUM: quic: Floating point exception in cubic_root()
1888 - MINOR: h3: support HTTP request framing state
1889 - MINOR: mux-quic: refresh timeout on frame decoding
1890 - MINOR: mux-quic: refactor refresh timeout function
1891 - MEDIUM: mux-quic: implement http-request timeout
1892 - BUG/MINOR: quic: Avoid sending truncated datagrams
1893 - BUG/MINOR: ring/cli: fix a race condition between the writer and the reader
1894 - BUG/MEDIUM: sink: Set the sink ref for forwarders created during ring parsing
1895 - BUG/MINOR: sink: fix a race condition between the writer and the reader
1896 - BUG/MINOR: quic: do not reject datagrams matching minimum permitted size
1897 - MINOR: quic: Add two new stats counters for sendto() errors
1898 - BUG/MINOR: quic: Missing Initial packet dropping case
1899 - MINOR: quic: explicitely ignore sendto error
1900 - BUG/MINOR: quic: adjust errno handling on sendto
1901 - BUG/MEDIUM: quic: break out of the loop in quic_lstnr_dghdlr
1902 - MINOR: threads: report the number of thread groups in build options
1903 - MINOR: config: automatically preset MAX_THREADS based on MAX_TGROUPS
1904 - BUILD: SSL: allow to pass additional configure args to QUICTLS
1905 - CI: enable weekly "m32" builds on x86_64
1906 - CLEANUP: assorted typo fixes in the code and comments
1907 - BUG/MEDIUM: fix DH length when EC key is used
1908 - REGTESTS: ssl: adopt tests to OpenSSL-3.0.N
1909 - REGTESTS: ssl: adopt tests to OpenSSL-3.0.N
1910 - REGTESTS: ssl: fix grep invocation to use extended regex in ssl_generate_certificate.vtc
1911 - BUILD: cfgparse: always defined _GNU_SOURCE for sched.h and crypt.h
1912
Willy Tarreau2200a9c2022-07-16 17:17:22 +020019132022/07/16 : 2.7-dev2
1914 - BUG/MINOR: qpack: fix build with QPACK_DEBUG
1915 - MINOR: h3: handle errors on HEADERS parsing/QPACK decoding
1916 - BUG/MINOR: qpack: abort on dynamic index field line decoding
1917 - MINOR: qpack: properly handle invalid dynamic table references
1918 - MINOR: task: Add tasklet_wakeup_after()
1919 - BUG/MINOR: quic: Dropped packets not counted (with RX buffers full)
1920 - MINOR: quic: Add new stats counter to diagnose RX buffer overrun
1921 - MINOR: quic: Duplicated QUIC_RX_BUFSZ definition
1922 - MINOR: quic: Improvements for the datagrams receipt
1923 - CLEANUP: h2: Typo fix in h2_unsubcribe() traces
1924 - MINOR: quic: Increase the QUIC connections RX buffer size (upto 64Kb)
1925 - CLEANUP: mux-quic: adjust comment on qcs_consume()
1926 - MINOR: ncbuf: implement ncb_is_fragmented()
1927 - BUG/MINOR: mux-quic: do not signal FIN if gap in buffer
1928 - MINOR: fd: add a new FD_DISOWN flag to prevent from closing a deleted FD
1929 - BUG/MEDIUM: ssl/fd: unexpected fd close using async engine
1930 - MINOR: tinfo: make tid temporarily still reflect global ID
1931 - CLEANUP: config: remove unused proc_mask()
1932 - MINOR: debug: remove mask support from "debug dev sched"
1933 - MEDIUM: task: add and preset a thread ID in the task struct
1934 - MEDIUM: task/debug: move the ->thread_mask integrity checks to ->tid
1935 - MAJOR: task: use t->tid instead of ffsl(t->thread_mask) to take the thread ID
1936 - MAJOR: task: replace t->thread_mask with 1<<t->tid when thread mask is needed
1937 - CLEANUP: task: remove thread_mask from the struct task
1938 - MEDIUM: applet: only keep appctx_new_*() and drop appctx_new()
1939 - MEDIUM: task: only keep task_new_*() and drop task_new()
1940 - MINOR: applet: always use task_new_on() on applet creation
1941 - MEDIUM: task: remove TASK_SHARED_WQ and only use t->tid
1942 - MINOR: task: replace task_set_affinity() with task_set_thread()
1943 - CLEANUP: task: remove the unused task_unlink_rq()
1944 - CLEANUP: task: remove the now unused TASK_GLOBAL flag
1945 - MINOR: task: make rqueue_ticks atomic
1946 - MEDIUM: task: move the shared runqueue to one per thread
1947 - MEDIUM: task: replace the global rq_lock with a per-rq one
1948 - MINOR: task: remove grq_total and use rq_total instead
1949 - MINOR: task: replace global_tasks_mask with a check for tree's emptiness
1950 - MEDIUM: task: use regular eb32 trees for the run queues
1951 - MEDIUM: queue: revert to regular inter-task wakeups
1952 - MINOR: thread: make wake_thread() take care of the sleeping threads mask
1953 - MINOR: thread: move the flags to the shared cache line
1954 - MINOR: thread: only use atomic ops to touch the flags
1955 - MINOR: poller: centralize poll return handling
1956 - MEDIUM: polling: make update_fd_polling() not care about sleeping threads
1957 - MINOR: poller: update_fd_polling: wake a random other thread
1958 - MEDIUM: thread: add a new per-thread flag TH_FL_NOTIFIED to remember wakeups
1959 - MEDIUM: tasks/fd: replace sleeping_thread_mask with a TH_FL_SLEEPING flag
1960 - MINOR: tinfo: add the tgid to the thread_info struct
1961 - MINOR: tinfo: replace the tgid with tgid_bit in tgroup_info
1962 - MINOR: tinfo: add the mask of enabled threads in each group
1963 - MINOR: debug: use ltid_bit in ha_thread_dump()
1964 - MINOR: wdt: use ltid_bit in wdt_handler()
1965 - MINOR: clock: use ltid_bit in clock_report_idle()
1966 - MINOR: thread: use ltid_bit in ha_tkillall()
1967 - MINOR: thread: add a new all_tgroups_mask variable to know about active tgroups
1968 - CLEANUP: thread: remove thread_sync_release() and thread_sync_mask
1969 - MEDIUM: tinfo: add a dynamic thread-group context
1970 - MEDIUM: thread: make stopping_threads per-group and add stopping_tgroups
1971 - MAJOR: threads: change thread_isolate to support inter-group synchronization
1972 - MINOR: thread: add is_thread_harmless() to know if a thread already is harmless
1973 - MINOR: debug: mark oneself harmless while waiting for threads to finish
1974 - MINOR: wdt: do not rely on threads_to_dump anymore
1975 - MEDIUM: debug: make the thread dumper not rely on a thread mask anymore
1976 - BUILD: debug: fix build issue on clang with previous commit
1977 - BUILD: debug: re-export thread_dump_state
1978 - BUG/MEDIUM: threads: fix incorrect thread group being used on soft-stop
1979 - BUG/MEDIUM: thread: check stopping thread against local bit and not global one
1980 - MINOR: proxy: use tg->threads_enabled in hard_stop() to detect stopped threads
1981 - BUILD: Makefile: Add Lua 5.4 autodetect
1982 - CI: re-enable gcc asan builds
1983 - MEDIUM: mworker: set the iocb of the socketpair without using fd_insert()
1984 - MINOR: fd: Add BUG_ON checks on fd_insert()
1985 - CLEANUP: mworker: rename mworker_pipe to mworker_sockpair
1986 - CLEANUP: mux-quic: do not export qc_get_ncbuf
1987 - REORG: mux-quic: reorganize flow-control fields
1988 - MINOR: mux-quic: implement accessor for sedesc
1989 - MEDIUM: mux-quic: refactor streams opening
1990 - MINOR: mux-quic: rename qcs flag FIN_RECV to SIZE_KNOWN
1991 - MINOR: mux-quic: emit FINAL_SIZE_ERROR on invalid STREAM size
1992 - BUG/MINOR: peers/config: always fill the bind_conf's argument
1993 - BUG/MEDIUM: peers/config: properly set the thread mask
1994 - CLEANUP: bwlim: Set pointers to NULL when memory is released
1995 - BUG/MINOR: http-check: Preserve headers if not redefined by an implicit rule
1996 - BUG/MINOR: http-act: Properly generate 103 responses when several rules are used
1997 - BUG/MEDIUM: thread: mask stopping_threads with threads_enabled when checking it
1998 - CLEANUP: thread: also remove a thread's bit from stopping_threads on stop
1999 - BUG/MINOR: peers: fix possible NULL dereferences at config parsing
2000 - BUG/MINOR: http-htx: Fix scheme based normalization for URIs wih userinfo
2001 - MINOR: http: Add function to get port part of a host
2002 - MINOR: http: Add function to detect default port
2003 - BUG/MEDIUM: h1: Improve authority validation for CONNCET request
2004 - MINOR: http-htx: Use new HTTP functions for the scheme based normalization
2005 - BUG/MEDIUM: http-fetch: Don't fetch the method if there is no stream
2006 - REGTEESTS: filters: Fix CONNECT request in random-forwarding script
2007 - MEDIUM: mworker/systemd: send STATUS over sd_notify
2008 - BUG/MINOR: mux-h1: Be sure to commit htx changes in the demux buffer
2009 - BUG/MEDIUM: http-ana: Don't wait to have an empty buf to switch in TUNNEL state
2010 - BUG/MEDIUM: mux-h1: Handle connection error after a synchronous send
2011 - MEDIUM: epoll: don't synchronously delete migrated FDs
2012 - BUILD: debug: silence warning on gcc-5
2013 - BUILD: http: silence an uninitialized warning affecting gcc-5
2014 - BUG/MEDIUM: mux-quic: fix server chunked encoding response
2015 - REORG: mux-quic: rename stream initialization function
2016 - MINOR: mux-quic: rename stream purge function
2017 - MINOR: mux-quic: add traces on frame parsing functions
2018 - MINOR: mux-quic: implement qcs_alert()
2019 - MINOR: mux-quic: filter send/receive-only streams on frame parsing
2020 - MINOR: mux-quic: do not ack STREAM frames on unrecoverable error
2021 - MINOR: mux-quic: support stream opening via MAX_STREAM_DATA
2022 - MINOR: mux-quic: define basic stream states
2023 - MINOR: mux-quic: use stream states to mark as detached
2024 - MEDIUM: mux-quic: implement RESET_STREAM emission
2025 - MEDIUM: mux-quic: implement STOP_SENDING handling
2026 - BUG/MEDIUM: debug: fix possible hang when multiple threads dump at once
2027 - BUG/MINOR: quic: fix closing state on NO_ERROR code sent
2028 - CLEANUP: quic: clean up include on quic_frame-t.h
2029 - MINOR: quic: define a generic QUIC error type
2030 - MINOR: mux-quic: support app graceful shutdown
2031 - MINOR: mux-quic/h3: prepare CONNECTION_CLOSE on release
2032 - MEDIUM: quic: send CONNECTION_CLOSE on released MUX
2033 - CLEANUP: mux-quic: move qc_release()
2034 - MINOR: mux-quic: send one last time before release
2035 - MINOR: h3: store control stream in h3c
2036 - MINOR: h3: implement graceful shutdown with GOAWAY
2037 - BUG/MINOR: threads: produce correct global mask for tgroup > 1
2038 - BUG/MEDIUM: cli/threads: make "show threads" more robust on applets
2039 - BUG/MINOR: thread: use the correct thread's group in ha_tkillall()
2040 - BUG/MINOR: debug: enter ha_panic() only once
2041 - BUG/MEDIUM: debug: fix parallel thread dumps again
2042 - MINOR: cli/streams: show a stream's tgid next to its thread ID
2043 - DEBUG: cli: add a new "debug dev deadlock" expert command
2044 - MINOR: cli/activity: add a thread number argument to "show activity"
2045 - CLEANUP: applet: remove the obsolete command context from the appctx
2046 - MEDIUM: config: remove deprecated "bind-process" directives from frontends
2047 - MEDIUM: config: remove the "process" keyword on "bind" lines
2048 - MINOR: listener/config: make "thread" always support up to LONGBITS
2049 - CLEANUP: fd: get rid of the __GET_{NEXT,PREV} macros
2050 - MEDIUM: debug/threads: make the lock debugging take tgroups into account
2051 - MEDIUM: proto: stop protocols under thread isolation during soft stop
2052 - MEDIUM: poller: program the update in fd_update_events() for a migrated FD
2053 - MEDIUM: poller: disable thread-groups for poll() and select()
2054 - MINOR: thread: remove MAX_THREADS limitation
2055 - MEDIUM: cpu-map: replace the process number with the thread group number
2056 - MINOR: mworker/threads: limit the mworker sockets to group 1
2057 - MINOR: cli/threads: always bind CLI to thread group 1
2058 - MINOR: fd/thread: get rid of thread_mask()
2059 - MEDIUM: task/thread: move the task shared wait queues per thread group
2060 - MINOR: task: move the niced_tasks counter to the thread group context
2061 - DOC: design: add some thoughts about how to handle the update_list
2062 - MEDIUM: conn: make conn_backend_get always scan the same group
2063 - MAJOR: fd: remove pending updates upon real close
2064 - MEDIUM: fd/poller: make the update-list per-group
2065 - MINOR: fd: delete unused updates on close()
2066 - MINOR: fd: make fd_insert() apply the thread mask itself
2067 - MEDIUM: fd: add the tgid to the fd and pass it to fd_insert()
2068 - MINOR: cli/fd: show fd's tgid and refcount in "show fd"
2069 - MINOR: fd: add functions to manipulate the FD's tgid
2070 - MINOR: fd: add fd_get_running() to atomically return the running mask
2071 - MAJOR: fd: grab the tgid before manipulating running
2072 - MEDIUM: fd/poller: turn polled_mask to group-local IDs
2073 - MEDIUM: fd/poller: turn update_mask to group-local IDs
2074 - MEDIUM: fd/poller: turn running_mask to group-local IDs
2075 - MINOR: fd: make fd_clr_running() return the previous value instead
2076 - MEDIUM: fd: make thread_mask now represent group-local IDs
2077 - MEDIUM: fd: make fd_insert() take local thread masks
2078 - MEDIUM: fd: make fd_insert/fd_delete atomically update fd.tgid
2079 - MEDIUM: fd: quit fd_update_events() when FD is closed
2080 - MEDIUM: thread: change thread_resolve_group_mask() to return group-local values
2081 - MEDIUM: listener: switch bind_thread from global to group-local
2082 - MINOR: fd: add fd_reregister_all() to deal with boot-time FDs
2083 - MEDIUM: fd: support stopping FDs during starting
2084 - MAJOR: pollers: rely on fd_reregister_all() at boot time
2085 - MAJOR: poller: only touch/inspect the update_mask under tgid protection
2086 - MEDIUM: fd: support broadcasting updates for foreign groups in updt_fd_polling
2087 - CLEANUP: threads: remove the now unused all_threads_mask and tid_bit
2088 - MINOR: config: change default MAX_TGROUPS to 16
2089 - BUG/MEDIUM: tools: avoid calling dlsym() in static builds
2090
Willy Tarreauf9de4e92022-06-24 22:09:05 +020020912022/06/24 : 2.7-dev1
2092 - BUG/MINOR: ssl_ckch: Free error msg if commit changes on a cert entry fails
2093 - BUG/MINOR: ssl_ckch: Free error msg if commit changes on a CA/CRL entry fails
2094 - BUG/MEDIUM: ssl_ckch: Don't delete a cert entry if it is being modified
2095 - BUG/MEDIUM: ssl_ckch: Don't delete CA/CRL entry if it is being modified
2096 - BUG/MINOR: ssl_ckch: Don't duplicate path when replacing a cert entry
2097 - BUG/MINOR: ssl_ckch: Don't duplicate path when replacing a CA/CRL entry
2098 - BUG/MEDIUM: ssl_ckch: Rework 'commit ssl cert' to handle full buffer cases
2099 - BUG/MEDIUM: ssl_ckch: Rework 'commit ssl ca-file' to handle full buffer cases
2100 - BUG/MEDIUM: ssl/crt-list: Rework 'add ssl crt-list' to handle full buffer cases
2101 - BUG/MEDIUM: httpclient: Don't remove HTX header blocks before duplicating them
2102 - BUG/MEDIUM: httpclient: Rework CLI I/O handler to handle full buffer cases
2103 - MEDIUM: httpclient: Don't close CLI applet at the end of a response
2104 - MEDIUM: http-ana: Always report rewrite failures as PRXCOND in logs
2105 - CLEANUP: Re-apply xalloc_size.cocci (2)
2106 - REGTESTS: abortonclose: Add a barrier to not mix up log messages
2107 - REGTESTS: http_request_buffer: Increase client timeout to wait "slow" clients
2108 - CLEANUP: ssl_ckch: Use corresponding enum for commit_cacrlfile_ctx.cafile_type
2109 - MINOR: ssl_ckch: Simplify I/O handler to commit changes on CA/CRL entry
2110 - BUG/MINOR: ssl_ckch: Use right type for old entry in show_crlfile_ctx
2111 - BUG/MINOR: ssl_ckch: Dump CRL transaction only once if show command yield
2112 - BUG/MINOR: ssl_ckch: Dump CA transaction only once if show command yield
2113 - BUG/MINOR: ssl_ckch: Dump cert transaction only once if show command yield
2114 - BUG/MINOR: ssl_ckch: Init right field when parsing "commit ssl crl-file" cmd
2115 - CLEANUP: ssl_ckch: Remove unused field in commit_cacrlfile_ctx structure
2116 - MINOR: ssl_ckch: Simplify structure used to commit changes on CA/CRL entries
2117 - MINOR: ssl_ckch: Remove service context for "set ssl cert" command
2118 - MINOR: ssl_ckch: Remove service context for "set ssl ca-file" command
2119 - MINOR: ssl_ckch: Remove service context for "set ssl crl-file" command
2120 - BUG/MINOR: ssl_ckch: Fix possible uninitialized value in show_cert I/O handler
2121 - BUG/MINOR: ssl_ckch: Fix possible uninitialized value in show_cafile I/O handler
2122 - BUG/MINOR: ssl_ckch: Fix possible uninitialized value in show_crlfile I/O handler
2123 - BUILD: ssl_ckch: Fix build error about a possible uninitialized value
2124 - BUG/MINOR: ssl_ckch: Fix another possible uninitialized value
2125 - REGTESTS: http_abortonclose: Extend supported versions
2126 - REGTESTS: restrict_req_hdr_names: Extend supported versions
2127 - MINOR: connection: support HTTP/3.0 for smp_*_http_major fetch
2128 - MINOR: h3: add h3c pointer into h3s instance
2129 - MINOR: mux-quic: simplify decode_qcs API
2130 - MINOR: mux-quic/h3: adjust demuxing function return values
2131 - BUG/MINOR: h3: fix return value on decode_qcs on error
2132 - BUILD: quic: fix anonymous union for gcc-4.4
2133 - BUILD: compiler: implement unreachable for older compilers too
2134 - DEV: tcploop: reorder options in the usage message
2135 - DEV: tcploop: make the current address the default address
2136 - DEV: tcploop: make it possible to change the target address of a connect()
2137 - DEV: tcploop: factor out the socket creation
2138 - DEV: tcploop: permit port 0 to ease handling of default options
2139 - DEV: tcploop: add a new "bind" command to bind to ip/port.
2140 - DEV: tcploop: add minimal UDP support
2141 - BUG/MINOR: trace: Test server existence for health-checks to get proxy
2142 - BUG/MINOR: checks: Properly handle email alerts in trace messages
2143 - BUG/MEDIUM: mailers: Set the object type for check attached to an email alert
2144 - REGTESTS: healthcheckmail: Update the test to be functionnal again
2145 - REGTESTS: healthcheckmail: Relax health-check failure condition
2146 - BUG/MINOR: h3: fix incorrect BUG_ON assert on SETTINGS parsing
2147 - MEDIUM: mux-h2: try to coalesce outgoing WINDOW_UPDATE frames
2148 - OPTIM: mux-h2: increase h2_settings_initial_window_size default to 64k
2149 - BUG/MINOR: h3: fix frame type definition
2150 - BUG/MEDIUM: h3: fix SETTINGS parsing
2151 - BUG/MINOR: cli/stats: add missing trailing LF after JSON outputs
2152 - BUG/MINOR: server: do not enable DNS resolution on disabled proxies
2153 - BUG/MINOR: cli/stats: add missing trailing LF after "show info json"
2154 - DOC: design: update the notes on thread groups
2155 - BUG/MEDIUM: mux-quic: fix flow control connection Tx level
2156 - MINOR: mux-quic: complete BUG_ON on TX flow-control enforcing
2157 - BUG/MINOR: mux-quic: fix memleak on frames rejected by transport
2158 - BUG/MINOR: tcp-rules: Make action call final on read error and delay expiration
2159 - CLEANUP: check: Remove useless tests on check's stream-connector
2160 - BUG/MEDIUM: stconn: Don't wakeup applet for send if it won't consume data
2161 - BUG/MEDIUM: cli: Notify cli applet won't consume data during request processing
2162 - BUG/MEDIUM: mux-quic: fix segfault on flow-control frame cleanup
2163 - MINOR: task: move profiling bit to per-thread
2164 - CLEANUP: quic: use task_new_on() for single-threaded tasks
2165 - MINOR: tinfo: remove the global thread ID bit (tid_bit)
2166 - CLEANUP: hlua: check for at least 2 threads on a task
2167 - MINOR: thread: get rid of MAX_THREADS_MASK
2168 - OPTIM: task: do not consult shared WQ when we're already full
2169 - DOC: design: update the task vs thread affinity requirements
2170 - MINOR: qpack: add comments and remove a useless trace
2171 - MINOR: qpack: reduce dependencies on other modules
2172 - BUG/MINOR: qpack: support header litteral name decoding
2173 - MINOR: qpack: add ABORT_NOW on unimplemented decoding
2174 - BUG/MINOR: h3/qpack: deal with too many headers
2175 - MINOR: qpack: improve decoding function
2176 - MINOR: qpack: implement standalone decoder tool
2177 - BUG/BUILD: h3: fix wrong label name
2178 - BUG/MINOR: quic: Stop hardcoding Retry packet Version field
2179 - MINOR: quic: Add several nonce and key definitions for Retry tag
2180 - BUG/MINOR: quic: Wrong PTO calculation
2181 - MINOR: quic: Parse long packet version from qc_parse_hd_form()
2182 - CLEANUP: quid: QUIC draft-28 no more supported
2183 - MEDIUM: quic: Add QUIC v2 draft support
2184 - MINOR: quic: Released QUIC TLS extension for QUIC v2 draft
2185 - MEDIUM: quic: Compatible version negotiation implementation (draft-08)
2186 - CLEANUP: quic: Remove any reference to boringssl
2187 - BUG/MINOR: task: fix thread assignment in tasklet_kill()
2188 - BUG/MEDIUM: stream: Properly handle destructive client connection upgrades
2189 - MINOR: stream: Rely on stconn flags to abort stream destructive upgrade
2190 - CLEANUP: stconn: Don't expect to have no sedesc on detach
2191 - BUG/MINOR: log: Properly test connection retries to fix dontlog-normal option
2192 - MINOR: hlua: don't dump empty entries in hlua_traceback()
2193 - MINOR: hlua: add a new hlua_show_current_location() function
2194 - MEDIUM: debug: add a tainted flag when a shared library is loaded
2195 - MEDIUM: debug: detect redefinition of symbols upon dlopen()
2196 - BUILD: quic: Wrong HKDF label constant variable initializations
2197 - BUG/MINOR: quic: Unexpected half open connection counter wrapping
2198 - BUG/MINOR: quic_stats: Duplicate "quic_streams_data_blocked_bidi" field name
2199 - BUG/MINOR: quic: purge conn Rx packet list on release
2200 - BUG/MINOR: quic: free rejected Rx packets
2201 - BUG/MINOR: qpack: abort on dynamic index field line decoding
2202 - BUG/MEDIUM: ssl/cli: crash when crt inserted into a crt-list
2203 - REGTESTS: ssl: add the same cert for client/server
2204 - BUG/MINOR: quic: Acknowledgement must be forced during handshake
2205 - MINOR: quic: Dump version_information transport parameter
2206 - BUG/MEDIUM: mworker: use default maxconn in wait mode
2207 - MINOR: intops: add a function to return a valid bit position from a mask
2208 - TESTS: add a unit test for one_among_mask()
2209 - BUILD: ssl_ckch: fix "maybe-uninitialized" build error on gcc-9.4 + ARM
2210 - BUG/MINOR: ssl: Do not look for key in extra files if already in pem
2211 - BUG/MINOR: quic: Missing acknowledgments for trailing packets
2212 - BUG/MINOR: http-ana: Set method to HTTP_METH_OTHER when an HTTP txn is created
2213 - BUG/MINOR: http-fetch: Use integer value when possible in "method" sample fetch
2214 - MINOR: freq_ctr: Add a function to get events excess over the current period
2215 - BUG/MINOR: stream: only free the req/res captures when set
2216 - CLEANUP: pool/tree-wide: remove suffix "_pool" from certain pool names
2217 - MEDIUM: debug: improve DEBUG_MEM_STATS to also report pool alloc/free
2218 - BUG/MINOR: quic: Wrong reuse of fulfilled dgram RX buffer
2219 - BUG/MAJOR: quic: Big RX dgrams leak when fulfilling a buffer
2220 - BUG/MAJOR: quic: Big RX dgrams leak with POST requests
2221 - BUILD: quic+h3: 32-bit compilation errors fixes
2222 - MEDIUM: bwlim: Add support of bandwith limitation at the stream level
2223
Willy Tarreau29698e32022-05-31 17:05:27 +020022242022/05/31 : 2.7-dev0
2225 - MINOR: version: it's development again
2226
Willy Tarreaua1efc042022-05-31 16:58:21 +020022272022/05/31 : 2.6.0
2228 - DOC: Fix formatting in configuration.txt to fix dconv
2229 - CLEANUP: tcpcheck: Remove useless test on the stream-connector in tcpcheck_main
2230 - CLEANUP: muxes: Consider stream's sd as defined in .show_fd callback functions
2231 - MINOR: quic: Ignore out of packet padding.
2232 - CLEANUP: quic: Useless QUIC_CONN_TX_BUF_SZ definition
2233 - CLEANUP: quic: No more used handshake output buffer
2234 - MINOR: quic: QUIC transport parameters split.
2235 - MINOR: quic: Transport parameters dump
2236 - DOC: quic: Update documentation for QUIC Retry
2237 - MINOR: quic: Tunable "max_idle_timeout" transport parameter
2238 - MINOR: quic: Tunable "initial_max_streams_bidi" transport parameter
2239 - MINOR: quic: Clarifications about transport parameters value
2240 - MINOIR: quic_stats: add QUIC connection errors counters
2241 - BUG/MINOR: quic: Largest RX packet numbers mixing
2242 - MINOR: quic_stats: Add transport new counters (lost, stateless reset, drop)
2243 - DOC: quic: Documentation update for QUIC
2244 - MINOR: quic: Connection TX buffer setting renaming.
2245 - MINOR: h3: Add a statistics module for h3
2246 - MINOR: quic: Send STOP_SENDING frames if mux is released
2247 - MINOR: quic: Do not drop packets with RESET_STREAM frames
2248 - BUG/MINOR: qpack: fix buffer API usage on prefix integer encoding
2249 - BUG/MINOR: qpack: support bigger prefix-integer encoding
2250 - BUG/MINOR: h3: do not report bug on unknown method
2251 - SCRIPTS: add make-releases-json to recreate a releases.json file in download dirs
2252 - SCRIPTS: make publish-release try to launch make-releases-json
2253 - MINOR: htx: add an unchecked version of htx_get_head_blk()
2254 - BUILD: htx: use the unchecked version of htx_get_head_blk() where needed
2255 - BUILD: quic: use inttypes.h instead of stdint.h
2256 - DOC: internal: remove totally outdated diagrams
2257 - DOC: remove the outdated ROADMAP file
2258 - DOC: add maintainers for QUIC and HTTP/3
2259 - MINOR: h3: define h3 trace module
2260 - MINOR: h3: add traces on frame recv
2261 - MINOR: h3: add traces on frame send
2262 - MINOR: h3: add traces on h3s init/end
2263 - EXAMPLES: remove completely outdated acl-content-sw.cfg
2264 - BUILD: makefile: reorder objects by build time
2265 - DOC: fix a few spelling mistakes in the docs
2266 - BUG/MEDIUM: peers/cli: fix "show peers" crash
2267 - CLEANUP: peers/cli: stop misusing the appctx local variable
2268 - CLEANUP: peers/cli: make peers_dump_peer() take an appctx instead of an stconn
2269 - BUG/MINOR: peers: set the proxy's name to the peers section name
2270 - MINOR: server: indicate when no address was expected for a server
2271 - BUG/MINOR: peers: detect and warn on init_addr/resolvers/check/agent-check
2272 - DOC: peers: indicate that some server settings are not usable
2273 - DOC: peers: clarify when entry expiration date is renewed.
2274 - DOC: peers: fix port number and addresses on new peers section format
2275 - DOC: gpc/gpt: add commments of gpc/gpt array definitions on stick tables.
2276 - DOC: install: update supported OpenSSL versions in the INSTALL doc
2277 - MINOR: ncbuf: adjust ncb_data with NCBUF_NULL
2278 - BUG/MINOR: h3: fix frame demuxing
2279 - BUG/MEDIUM: h3: fix H3_EXCESSIVE_LOAD when receiving H3 frame header only
2280 - BUG/MINOR: quic: Fix QUIC_EV_CONN_PRSAFRM event traces
2281 - CLEANUP: quic: remove useless check on local UNI stream reception
2282 - BUG/MINOR: qpack: do not consider empty enc/dec stream as error
2283 - DOC: intro: adjust the numbering of paragrams to keep the output ordered
2284 - MINOR: version: mention that it's LTS now.
2285
Willy Tarreau0edb9972022-05-27 19:49:31 +020022862022/05/27 : 2.6-dev12
2287 - CLEANUP: tools: Clean up non-QUIC error message handling in str2sa_range()
2288 - BUG/MEDIUM: tools: Fix `inet_ntop` usage in sa2str
2289 - CLEANUP: tools: Crash if inet_ntop fails due to ENOSPC in sa2str
2290 - BUG/MEDIUM: mux-quic: adjust buggy proxy closing support
2291 - Revert "MINOR: quic: activate QUIC traces at compilation"
2292 - Revert "MINOR: mux-quic: activate qmux traces on stdout via macro"
2293 - CLEANUP: init: address a coverity warning about possible multiply overflow
2294 - BUG/MEDIUM: http: Properly reject non-HTTP/1.x protocols
2295 - MEDIUM: h1: enlarge the scope of accepted version chars with accept-invalid-http-request
2296 - BUG/MEDIUM: resolvers: Don't defer resolutions release in deinit function
2297 - BUG/MEDIUM: peers: fix segfault using multiple bind on peers sections
2298 - BUG/MEDIUM: peers: prevent unitialized multiple listeners on peers section
2299 - BUG/MINOR: task: Don't defer tasks release when HAProxy is stopping
2300 - MINOR: h3: mark ncbuf as const on h3_b_dup
2301 - MINOR: mux-quic: do not alloc quic_stream_desc for uni remote stream
2302 - MINOR: mux-quic: delay cs_endpoint allocation
2303 - MINOR: mux-quic: add traces in qc_recv()
2304 - MINOR: mux-quic: adjust return value of decode_qcs
2305 - CLEANUP: h3: rename struct h3 -> h3c
2306 - CLEANUP: h3: rename uni stream type constants
2307 - BUG/MINOR: h3: prevent overflow when parsing SETTINGS
2308 - MINOR: h3: refactor h3_control_send()
2309 - MINOR: quic: support CONNECTION_CLOSE_APP emission
2310 - MINOR: mux-quic: disable read on CONNECTION_CLOSE emission
2311 - MINOR: h3: reject too big frames
2312 - MINOR: mux-quic: emit STREAM_STATE_ERROR in qcc_recv
2313 - BUG/MINOR: mux-quic: refactor uni streams TX/send H3 SETTINGS
2314 - MINOR: h3/qpack: use qcs as type in decode callbacks
2315 - MINOR: h3: define stream type
2316 - MINOR: h3: refactor uni streams initialization
2317 - MINOR: h3: check if frame is valid for stream type
2318 - MINOR: h3: define non-h3 generic parsing function
2319 - MEDIUM: quic: refactor uni streams RX
2320 - CLEANUP: h3: remove h3 uni tasklet
2321 - MINOR: h3: abort read on unknown uni stream
2322 - MINOR: h3: refactor SETTINGS parsing/error reporting
2323 - Revert "BUG/MINOR: task: Don't defer tasks release when HAProxy is stopping"
2324 - DOC: configuration: add a warning for @system-ca on bind
2325 - CLEANUP: init: address another coverity warning about a possible multiply overflow
2326 - BUG/MINOR: ssl/lua: use correctly cert_ext in CertCache.set()
2327 - BUG/MEDIUM: sample: Fix adjusting size in word converter
2328 - REGTESTS: Do not use REQUIRE_VERSION for HAProxy 2.5+ (2)
2329 - CLEANUP: conn_stream: remove unneeded exclusion of RX_WAIT_EP from RXBLK_ANY
2330 - CLEANUP: conn_stream: rename the cs_endpoint's context to "conn"
2331 - MINOR: conn_stream: add new sets of functions to set/get endpoint flags
2332 - DEV: coccinelle: add cs_endp_flags.cocci
2333 - CLEANUP: conn_stream: apply cs_endp_flags.cocci tree-wide
2334 - DEV: coccinelle: add endp_flags.cocci
2335 - CLEANUP: conn_stream: apply endp_flags.cocci tree-wide
2336 - CLEANUP: conn_stream: rename the stream endpoint flags CS_EP_* to SE_FL_*
2337 - CLEANUP: conn_stream: rename the cs_endpoint's target to "se"
2338 - CLEANUP: conn_stream: rename cs_endpoint to sedesc (stream endpoint descriptor)
2339 - CLEANUP: applet: rename the sedesc pointer from "endp" to "sedesc"
2340 - CLEANUP: conn_stream: rename the conn_stream's endp to sedesc
2341 - CLEANUP: conn_stream: rename cs_app_* to sc_app_*
2342 - CLEANUP: conn_stream: tree-wide rename to stconn (stream connector)
2343 - CLEANUP: mux-h1: add and use h1s_sc() to retrieve the stream connector
2344 - CLEANUP: mux-h2: add and use h2s_sc() to retrieve the stream connector
2345 - CLEANUP: mux-fcgi: add and use fcgi_strm_sc() to retrieve the stream connector
2346 - CLEANUP: mux-pt: add and use pt_sc() to retrieve the stream connector
2347 - CLEANUP: stdesc: rename the stream connector ->cs field to ->sc
2348 - CLEANUP: stream: rename "csf" and "csb" to "scf" and "scb"
2349 - CLEANUP: stconn: tree-wide rename stream connector flags CS_FL_* to SC_FL_*
2350 - CLEANUP: stconn: tree-wide rename stconn states CS_ST/SB_* to SC_ST/SB_*
2351 - MINOR: check: export wake_srv_chk()
2352 - MINOR: conn_stream: test the various ops functions before calling them
2353 - MEDIUM: stconn: merge the app_ops and the data_cb fields
2354 - MINOR: applet: add new wrappers to put chk/blk/str/chr to channel from appctx
2355 - CLEANUP: applet: use applet_put*() everywhere possible
2356 - CLEANUP: stconn: rename cs_{i,o}{b,c} to sc_{i,o}{b,c}
2357 - CLEANUP: stconn: rename cs_{check,strm,strm_task} to sc_strm_*
2358 - CLEANUP: stconn: rename cs_conn() to sc_conn()
2359 - CLEANUP: stconn: rename cs_mux() to sc_mux_strm()
2360 - CLEANUP: stconn: rename cs_conn_mux() to sc_mux_ops()
2361 - CLEANUP: stconn: rename cs_appctx() to sc_appctx()
2362 - CLEANUP: stconn: rename __cs_endp_target() to __sc_endp()
2363 - CLEANUP: stconn: rename cs_get_data_name() to sc_get_data_name()
2364 - CLEANUP: stconn: rename cs_conn_*() to sc_conn_*()
2365 - CLEANUP: stconn: rename cs_conn_get_first() to conn_get_first_sc()
2366 - CLEANUP: stconn: rename cs_ep_set_error() to se_fl_set_error()
2367 - CLEANUP: stconn: make a few functions take a const argument
2368 - CLEANUP: stconn: use a single function to know if SC may send to SE
2369 - MINOR: stconn: consider CF_SHUTW for sc_is_send_allowed()
2370 - MINOR: stconn: remove calls to cs_done_get()
2371 - MEDIUM: stconn: always rely on CF_SHUTR in addition to cs_rx_blocked()
2372 - MEDIUM: stconn: remove SE_FL_RXBLK_SHUT
2373 - MINOR: stconn: rename SE_FL_RXBLK_CONN to SE_FL_APPLET_NEED_CONN
2374 - MEDIUM: stconn: take SE_FL_APPLET_NEED_CONN out of the RXBLK_ANY flags
2375 - CLEANUP: stconn: rename cs_rx_room_{blk,rdy} to sc_{need,have}_room()
2376 - CLEANUP: stconn: rename cs_rx_chan_{blk,rdy} to sc_{wont,will}_read()
2377 - CLEANUP: stconn: rename cs_rx_buff_{blk,rdy} to sc_{need,have}_buff()
2378 - MINOR: stconn: start to rename cs_rx_endp_{more,done}() to se_have_{no_,}more_data()
2379 - MINOR: stconn: add sc_is_recv_allowed() to check for ability to receive
2380 - CLEANUP: stconn: rename SE_FL_RX_WAIT_EP to SE_FL_HAVE_NO_DATA
2381 - MEDIUM: stconn: move the RXBLK flags to the stream connector
2382 - CLEANUP: stconn: rename SE_FL_WANT_GET to SE_FL_WILL_CONSUME
2383 - CLEANUP: stconn: remove cs_tx_blocked() and cs_tx_endp_ready()
2384 - CLEANUP: stconn: rename cs_{want,stop}_get() to se_{will,wont}_consume()
2385 - CLEANUP: stconn: rename cs_cant_get() to se_need_more_data()
2386 - CLEANUP: stconn: rename cs_{new,create,free,destroy}_* to sc_*
2387 - CLEANUP: stconn: rename remaining management functions from cs_* to sc_*
2388 - CLEANUP: stconn: rename cs{,_get}_{src,dst} to sc_*
2389 - CLEANUP: stconn: rename cs_{shut,chk}* to sc_*
2390 - CLEANUP: stconn: rename final state manipulation functions from cs_* to sc_*
2391 - CLEANUP: quic: drop the name "conn_stream" from the pool variable names
2392 - REORG: rename cs_utils.h to sc_strm.h
2393 - REORG: stconn: rename conn_stream.{c,h} to stconn.{c,h}
2394 - CLEANUP: muxes: rename "get_first_cs" to "get_first_sc"
2395 - DEV: flags: use "sc" for stream conns instead of "cs"
2396 - CLEANUP: check: rename all occurrences of stconn "cs" to "sc"
2397 - CLEANUP: connection: rename all occurrences of stconn "cs" to "sc"
2398 - CLEANUP: stconn: rename all occurrences of stconn "cs" to "sc"
2399 - CLEANUP: quic/h3: rename all occurrences of stconn "cs" to "sc"
2400 - CLEANUP: stream: rename all occurrences of stconn "cs" to "sc"
2401 - CLEANUP: promex: rename all occurrences of stconn "cs" to "sc"
2402 - CLEANUP: stats: rename all occurrences of stconn "cs" to "sc"
2403 - CLEANUP: cli: rename all occurrences of stconn "cs" to "sc"
2404 - CLEANUP: applet: rename all occurrences of stconn "cs" to "sc"
2405 - CLEANUP: cache: rename all occurrences of stconn "cs" to "sc"
2406 - CLEANUP: dns: rename all occurrences of stconn "cs" to "sc"
2407 - CLEANUP: spoe: rename all occurrences of stconn "cs" to "sc"
2408 - CLEANUP: hlua: rename all occurrences of stconn "cs" to "sc"
2409 - CLEANUP: log-forward: rename all occurrences of stconn "cs" to "sc"
2410 - CLEANUP: http-client: rename all occurrences of stconn "cs" to "sc"
2411 - CLEANUP: mux-fcgi: rename all occurrences of stconn "cs" to "sc"
2412 - CLEANUP: mux-h1: rename all occurrences of stconn "cs" to "sc"
2413 - CLEANUP: mux-h2: rename all occurrences of stconn "cs" to "sc"
2414 - CLEANUP: mux-pt: rename all occurrences of stconn "cs" to "sc"
2415 - CLEANUP: peers: rename all occurrences of stconn "cs" to "sc"
2416 - CLEANUP: sink: rename all occurrences of stconn "cs" to "sc"
2417 - CLEANUP: sslsock: remove only occurrence of local variable "cs"
2418 - CLEANUP: applet: rename appctx_cs() to appctx_sc()
2419 - CLEANUP: stream: rename stream_upgrade_from_cs() to stream_upgrade_from_sc()
2420 - CLEANUP: obj_type: rename OBJ_TYPE_CS to OBJ_TYPE_SC
2421 - CLEANUP: stconn: replace a few remaining occurrences of CS in comments or traces
2422 - DOC: internal: update the muxes doc to mention the stconn
2423 - CLEANUP: mux-quic: rename the "endp" field to "sd"
2424 - CLEANUP: mux-h1: rename the "endp" field to "sd"
2425 - CLEANUP: mux-h2: rename the "endp" field to "sd"
2426 - CLEANUP: mux-fcgi: rename the "endp" field to "sd"
2427 - CLEANUP: mux-pt: rename the "endp" field to "sd"
2428 - CLEANUP: stconn: rename a few "endp" arguments and variables to "sd"
2429 - MINOR: stconn: turn SE_FL_WILL_CONSUME to SE_FL_WONT_CONSUME
2430 - CLEANUP: stream: remove unneeded test on appctx during initialization
2431 - CLEANUP: stconn: remove the new unneeded SE_FL_APP_MASK
2432 - DEV: flags: fix "siet" shortcut name
2433 - DEV: flags: rename the "endp" shortcut to "sd" for "stream descriptor"
2434 - DEV: flags: reorder a few SC/SE flags
2435 - DOC: internal: add a description of the stream connectors and descriptors
2436
Willy Tarreau137c8fd2022-05-20 23:31:51 +020024372022/05/20 : 2.6-dev11
2438 - CI: determine actual LibreSSL version dynamically
2439 - BUG/MEDIUM: ncbuf: fix null buffer usage
2440 - MINOR: ncbuf: fix warnings for testing build
2441 - MEDIUM: http-ana: Add a proxy option to restrict chars in request header names
2442 - MEDIUM: ssl: Delay random generator initialization after config parsing
2443 - MINOR: ssl: Add 'ssl-propquery' global option
2444 - MINOR: ssl: Add 'ssl-provider' global option
2445 - CLEANUP: Add missing header to ssl_utils.c
2446 - CLEANUP: Add missing header to hlua_fcn.c
2447 - CLEANUP: Remove unused function hlua_get_top_error_string
2448 - BUILD: fix build warning on solaris based systems with __maybe_unused.
2449 - MINOR: tools: add get_exec_path implementation for solaris based systems.
2450 - BUG/MINOR: ssl: Fix crash when no private key is found in pem
2451 - CLEANUP: conn-stream: Remove cs_applet_shut declaration from header file
2452 - MINOR: applet: Prepare appctx to own the session on frontend side
2453 - MINOR: applet: Let the frontend appctx release the session
2454 - MINOR: applet: Change return value for .init callback function
2455 - MINOR: stream: Export stream_free()
2456 - MINOR: applet: Add appctx_init() helper fnuction
2457 - MINOR: applet: Add a function to finalize frontend appctx startup
2458 - MINOR: applet: Add function to release appctx on error during init stage
2459 - MEDIUM: dns: Refactor dns appctx creation
2460 - MEDIUM: spoe: Refactor SPOE appctx creation
2461 - MEDIUM: lua: Refactor cosocket appctx creation
2462 - MEDIUM: httpclient: Refactor http-client appctx creation
2463 - MINOR: sink: Add a ref to sink in the sink_forward_target structure
2464 - MEDIUM: sink: Refactor sink forwarder appctx creation
2465 - MINOR: peers: Add a ref to peers section in the peer structure
2466 - MEDIUM: peers: Refactor peer appctx creation
2467 - MINOR: applet: Add API to start applet on a thread subset
2468 - MEDIUM: applet: Add support for async appctx startup on a thread subset
2469 - MINOR: peers: Track number of applets run by thread
2470 - MEDIUM: peers: Balance applets across threads
2471 - MINOR: conn-stream/applet: Stop setting appctx as the endpoint context
2472 - CLEANUP: proxy: Remove dead code when parsing "http-restrict-req-hdr-names" option
2473 - REGTESTS: abortonclose: Fix some race conditions
2474 - MINOR: ssl: Add 'ssl-provider-path' global option
2475 - CLEANUP: http_ana: Make use of the return value of stream_generate_unique_id()
2476 - BUG/MINOR: spoe: Fix error handling in spoe_init_appctx()
2477 - CLEANUP: peers: Remove unreachable code in peer_session_create()
2478 - CLEANUP: httpclient: Remove useless test on ss_dst in httpclient_applet_init()
2479 - BUG/MEDIUM: quic: fix Rx buffering
2480 - OPTIM: quic: realign empty Rx buffer
2481 - BUG/MINOR: ncbuf: fix ncb_is_empty()
2482 - MINOR: ncbuf: refactor ncb_advance()
2483 - BUG/MINOR: mux-quic: update session's idle delay before stream creation
2484 - MINOR: h3: do not wait a complete frame for demuxing
2485 - MINOR: h3: flag demux as full on HTX full
2486 - MEDIUM: mux-quic: implement recv on io-cb
2487 - MINOR: mux-quic: remove qcc_decode_qcs() call in XPRT
2488 - MINOR: mux-quic: reorganize flow-control frames emission
2489 - MINOR: mux-quic: implement MAX_STREAM_DATA emission
2490 - MINOR: mux-quic: implement MAX_DATA emission
2491 - BUG/MINOR: mux-quic: support nul buffer with qc_free_ncbuf()
2492 - MINOR: mux-quic: free RX buf if empty
2493 - BUG/MEDIUM: config: Reset outline buffer size on realloc error in readcfgfile()
2494 - BUG/MINOR: check: Reinit the buffer wait list at the end of a check
2495 - MEDIUM: check: No longer shutdown the connection in .wake callback function
2496 - REORG: check: Rename and export I/O callback function
2497 - MEDIUM: check: Use the CS to handle subscriptions for read/write events
2498 - BUG/MINOR: quic: break for error on sendto
2499 - MINOR: quic: abort on unlisted errno on sendto()
2500 - MINOR: quic: detect EBADF on sendto()
2501 - BUG/MEDIUM: quic: fix initialization for local/remote TPs
2502 - CLEANUP: quic: adjust comment/coding style for TPs init
2503 - BUG/MINOR: cfgparse: abort earlier in case of allocation error
2504 - MINOR: quic: Dump initial derived secrets
2505 - MINOR: quic_tls: Add quic_tls_derive_retry_token_secret()
2506 - MINOR: quic_tls: Add quic_tls_decrypt2() implementation
2507 - MINOR: quic: Retry implementation
2508 - MINOR: cfgparse: Update for "cluster-secret" keyword for QUIC Retry
2509 - MINOR: quic: Move quic_lstnr_dgram_dispatch() out of xprt_quic.c
2510 - BUILD: stats: Missing headers inclusions from stats.h
2511 - MINOR: quic_stats: Add a new stats module for QUIC
2512 - MINOR: quic: Attach proxy QUIC stats counters to the QUIC connection
2513 - BUG/MINOR: quic: Fix potential memory leak during QUIC connection allocations
2514 - MINOR: quic: QUIC stats counters handling
2515 - MINOR: quic: Add tune.quic.retry-threshold keyword
2516 - MINOR: quic: Dynamic Retry implementation
2517 - MINOR: quic/mux-quic: define CONNECTION_CLOSE send API
2518 - MINOR: mux-quic: emit FLOW_CONTROL_ERROR
2519 - MINOR: mux-quic: emit STREAM_LIMIT_ERROR
2520 - MINOR: mux-quic: close connection on error if different data at offset
2521 - BUG/MINOR: peers: fix error reporting of "bind" lines
2522 - CLEANUP: config: improve address parser error report for unmatched protocols
2523 - CLEANUP: config: provide cleare hints about unsupported QUIC addresses
2524 - MINOR: protocol: replace ctrl_type with xprt_type and clarify it
2525 - MINOR: listener: provide a function to process all of a bind_conf's arguments
2526 - MINOR: config: use the new bind_parse_args_list() to parse a "bind" line
2527 - CLEANUP: listener: add a comment about what the BC_SSL_O_* flags are for
2528 - MINOR: listener: add a new "options" entry in bind_conf
2529 - CLEANUP: listener: replace all uses of bind_conf->is_ssl with BC_O_USE_SSL
2530 - CLEANUP: listener: replace bind_conf->generate_cers with BC_O_GENERATE_CERTS
2531 - CLEANUP: listener: replace bind_conf->quic_force_retry with BC_O_QUIC_FORCE_RETRY
2532 - CLEANUP: listener: store stream vs dgram at the bind_conf level
2533 - MINOR: listener: detect stream vs dgram conflict during parsing
2534 - MINOR: listener: set the QUIC xprt layer immediately after parsing the args
2535 - MINOR: listener/ssl: set the SSL xprt layer only once the whole config is known
2536 - MINOR: connection: add flag MX_FL_FRAMED to mark muxes relying on framed xprt
2537 - MINOR: config: detect and report mux and transport incompatibilities
2538 - MINOR: listener: automatically select a QUIC mux with a QUIC transport
2539 - MINOR: listener: automatically enable SSL if a QUIC transport is found
2540 - BUG/MINOR: quic: Fixe a typo in qc_idle_timer_task()
2541 - BUG/MINOR: quic: Missing <conn_opening> stats counter decrementation
2542 - BUILD/MINOR: cpuset fix build for FreeBSD 13.1
2543 - CI: determine actual OpenSSL version dynamically
2544
Willy Tarreau37033252022-05-14 16:05:50 +020025452022/05/14 : 2.6-dev10
2546 - MINOR: ssl: ignore dotfiles when loading a dir w/ ca-file
2547 - MEDIUM: ssl: ignore dotfiles when loading a dir w/ crt
2548 - BUG/MINOR: ssl: Fix typos in crl-file related CLI commands
2549 - MINOR: compiler: add a new macro to set an attribute on an enum when possible
2550 - BUILD: stats: conditionally mark obsolete stats states as deprecated
2551 - BUILD: ssl: work around bogus warning in gcc 12's -Wformat-truncation
2552 - BUILD: debug: work around gcc-12 excessive -Warray-bounds warnings
2553 - BUILD: listener: shut report of possible null-deref in listener_accept()
2554 - BUG/MEDIUM: ssl: fix the gcc-12 broken fix :-(
2555 - DOC: install: update gcc version requirements
2556 - BUILD: makefile: add -Wfatal-errors to the default flags
2557 - BUG/MINOR: server: Make SRV_STATE_LINE_MAXLEN value from 512 to 2kB (2000 bytes).
2558 - BUG/MAJOR: dns: multi-thread concurrency issue on UDP socket
2559 - BUG/MINOR: mux-h2: mark the stream as open before processing it not after
2560 - MINOR: mux-h2: report a trace event when failing to create a new stream
2561 - DOC: configuration: add the httpclient keywords to the global keywords index
2562 - MINOR: quic: Add a debug counter for sendto() errors
2563 - BUG/MINOR: quic: Dropped peer transport parameters
2564 - BUG/MINOR: quic: Wrong unit for ack delay for incoming ACK frames
2565 - MINOR: quic: Congestion controller event trace fix (loss)
2566 - MINOR: quic: Add correct ack delay values to ACK frames
2567 - MINOR: config: Add "cluster-secret" new global keyword
2568 - MINOR: quic-tls: Add quic_hkdf_extract_and_expand() for HKDF
2569 - MINOR: quic: new_quic_cid() code moving
2570 - MINOR: quic: Initialize stateless reset tokens with HKDF secrets
2571 - MINOR: qc_new_conn() rework for stateless reset
2572 - MINOR: quic: Stateless reset token copy to transport parameters
2573 - MINOR: quic: Send stateless reset tokens
2574 - MINOR: quic: Short packets always embed a trailing AEAD TAG
2575 - CLEANUP: quic: wrong use of eb*entry() macro
2576 - CLEANUP: quic: Useless use of pointer for quic_hkdf_extract()
2577 - CLEANUP: quic_tls: QUIC_TLS_IV_LEN defined two times
2578 - MINOR: ncbuf: define non-contiguous buffer
2579 - MINOR: ncbuf: complete API and define block interal abstraction
2580 - MINOR: ncbuf: optimize storage for the last gap
2581 - MINOR: ncbuf: implement insertion
2582 - MINOR: ncbuf: define various insertion modes
2583 - MINOR: ncbuf: implement advance
2584 - MINOR: ncbuf: write unit tests
2585 - BUG/MEDIUM: lua: fix argument handling in data removal functions
2586 - DOC/MINOR: fix typos in the lua-api document
2587 - BUG/MEDIUM: wdt: don't trigger the watchdog when p is unitialized
2588 - MINOR: mux-h1: Add global option accpet payload for any HTTP/1.0 requests
2589 - CLEANUP: mux-h1: Fix comments and error messages for global options
2590 - MINOR: conn_stream: make cs_set_error() work on the endpoint instead
2591 - CLEANUP: mux-h1: always take the endp from the h1s not the cs
2592 - CLEANUP: mux-h2: always take the endp from the h2s not the cs
2593 - CLEANUP: mux-pt: always take the endp from the context not the cs
2594 - CLEANUP: mux-fcgi: always take the endp from the fstrm not the cs
2595 - CLEANUP: mux-quic: always take the endp from the qcs not the cs
2596 - CLEANUP: applet: use the appctx's endp instead of cs->endp
2597 - MINOR: conn_stream: add a pointer back to the cs from the endpoint
2598 - MINOR: mux-h1: remove the now unneeded h1s->cs
2599 - MINOR: mux-h2: make sure any h2s always has an endpoint
2600 - MINOR: mux-h2: remove the now unneeded conn_stream from the h2s
2601 - MINOR: mux-fcgi: make sure any stream always has an endpoint
2602 - MINOR: mux-fcgi: remove the now unneeded conn_stream from the fcgi_strm
2603 - MINOR: mux-quic: remove the now unneeded conn_stream from the qcs
2604 - MINOR: mux-pt: remove the now unneeded conn_stream from the context
2605 - CLEANUP: muxes: make mux->attach/detach take a conn_stream endpoint
2606 - MINOR: applet: replace cs_applet_shut() with appctx_shut()
2607 - MINOR: applet: add appctx_strm() and appctx_cs() to access common fields
2608 - CLEANUP: applet: remove the unneeded appctx->owner
2609 - CLEANUP: conn_stream: merge cs_new_from_{mux,applet} into cs_new_from_endp()
2610 - MINOR: ext-check: indicate the transport and protocol of a server
2611 - BUG/MEDIUM: mux-quic: fix a thinko in the latest cs/endpoint cleanup
2612 - MINOR: tools: improve error message accuracy in str2sa_range
2613 - MINOR: config: make sure never to mix dgram and stream protocols on a bind line
2614 - BUG/MINOR: ncbuf: fix coverity warning on uninit sz_data
2615 - MINOR: xprt_quic: adjust flow-control according to bufsize
2616 - MEDIUM: mux-quic/h3/hq-interop: use ncbuf for bidir streams
2617 - MEDIUM: mux-quic/h3/qpack: use ncbuf for uni streams
2618 - CLEANUP: mux-quic: remove unused fields for Rx
2619 - CLEANUP: quic: remove unused quic_rx_strm_frm
2620
Willy Tarreaue9797962022-05-08 11:44:15 +020026212022/05/08 : 2.6-dev9
2622 - MINOR: mux-quic: support full request channel buffer
2623 - BUG/MINOR: h3: fix parsing of unknown frame type with null length
2624 - CLEANUP: backend: make alloc_{bind,dst}_address() idempotent
2625 - MEDIUM: stream: remove the confusing SF_ADDR_SET flag
2626 - MINOR: conn_stream: remove the now unused CS_FL_ADDR_*_SET flags
2627 - CLEANUP: protocol: make sure the connect_* functions always receive a dst
2628 - MINOR: connection: get rid of the CO_FL_ADDR_*_SET flags
2629 - MINOR: session: get rid of the now unused SESS_FL_ADDR_*_SET flags
2630 - CLEANUP: mux: Useless xprt_quic-t.h inclusion
2631 - MINOR: quic: Make the quic_conn be aware of the number of streams
2632 - BUG/MINOR: quic: Dropped retransmitted STREAM frames
2633 - BUG/MINOR: mux_quic: Dropped packet upon retransmission for closed streams
2634 - MEDIUM: httpclient: remove url2sa to use a more flexible parser
2635 - MEDIUM: httpclient: http-request rules for resolving
2636 - MEDIUM: httpclient: allow address and port change for resolving
2637 - CLEANUP: httpclient: remove the comment about resolving
2638 - MINOR: httpclient: handle unix and other socket types in dst
2639 - MINOR: httpclient: rename dash by dot in global option
2640 - MINOR: init: exit() after pre-check upon error
2641 - MINOR: httpclient: cleanup the error handling in init
2642 - MEDIUM: httpclient: hard-error when SSL is configured
2643 - MINOR: httpclient: allow to configure the ca-file
2644 - MINOR: httpclient: configure the resolvers section to use
2645 - MINOR: httpclient: allow ipv4 or ipv6 preference for resolving
2646 - DOC: configuration: httpclient global option
2647 - MINOR: conn-stream: Add mask from flags set by endpoint or app layer
2648 - BUG/MEDIUM: conn-stream: Only keep app layer flags of the endpoint on reset
2649 - BUG/MEDIUM: mux-fcgi: Be sure to never set EOM flag on an empty HTX message
2650 - BUG/MEDIUM: mux-h1: Be able to handle trailers when C-L header was specified
2651 - DOC: config: Update doc for PR/PH session states to warn about rewrite failures
2652 - MINOR: resolvers: cleanup alert/warning in parse-resolve-conf
2653 - MINOR: resolvers: move the resolv.conf parser in parse_resolv_conf()
2654 - MINOR: resolvers: resolvers_new() create a resolvers with default values
2655 - BUILD: debug: unify the definition of ha_backtrace_to_stderr()
2656 - BUG/MINOR: tcp/http: release the expr of set-{src,dst}[-port]
2657 - MEDIUM: resolvers: create a "default" resolvers section at startup
2658 - DOC: resolvers: default resolvers section
2659 - BUG/MINOR: startup: usage() when no -cc arguments
2660 - BUG/MEDIUM: resolvers: make "show resolvers" properly yield
2661 - BUG/MEDIUM: cli: make "show cli sockets" really yield
2662 - BUG/MINOR: proxy/cli: don't enumerate internal proxies on "show backend"
2663 - BUG/MINOR: map/cli: protect the backref list during "show map" errors
2664 - BUG/MINOR: map/cli: make sure patterns don't vanish under "show map"'s init
2665 - BUG/MINOR: ssl/cli: fix "show ssl ca-file/crl-file" not to mix cli+ssl contexts
2666 - BUG/MINOR: ssl/cli: fix "show ssl ca-file <name>" not to mix cli+ssl contexts
2667 - BUG/MINOR: ssl/cli: fix "show ssl crl-file" not to mix cli+ssl contexts
2668 - BUG/MINOR: ssl/cli: fix "show ssl cert" not to mix cli+ssl contexts
2669 - CLEANUP: ssl/cli: do not loop on unknown states in "add ssl crt-list" handler
2670 - MINOR: applet: reserve some generic storage in the applet's context
2671 - CLEANUP: applet: make appctx_new() initialize the whole appctx
2672 - CLEANUP: stream/cli: take the "show sess" context definition out of the appctx
2673 - CLEANUP: stream/cli: stop using appctx->st2 for the dump state
2674 - CLEANUP: stream/cli: remove the unneeded init state from "show sess"
2675 - CLEANUP: stream/cli: remove the unneeded STATE_FIN state from "show sess"
2676 - CLEANUP: stream/cli: remove the now unneeded dump state from "show sess"
2677 - CLEANUP: proxy/cli: take the "show errors" context definition out of the appctx
2678 - CLEANUP: stick-table/cli: take the "show table" context definition out of the appctx
2679 - CLEANUP: stick-table/cli: stop using appctx->st2 for the dump state
2680 - CLEANUP: stick-table/cli: remove the unneeded STATE_INIT for "show table"
2681 - CLEANUP: map/cli: take the "show map" context definition out of the appctx
2682 - CLEANUP: map/cli: stop using cli.i0/i1 to store the generation numbers
2683 - CLEANUP: map/cli: stop using appctx->st2 for the dump state
2684 - CLEANUP: map/cli: always detach the backref from the list after "show map"
2685 - CLEANUP: peers/cli: take the "show peers" context definition out of the appctx
2686 - CLEANUP: peers/cli: stop using appctx->st2 for the dump state
2687 - CLEANUP: peers/cli: remove unneeded state STATE_INIT
2688 - CLEANUP: cli: initialize the whole appctx->ctx, not just the stats part
2689 - CLEANUP: promex: make the applet use its own context
2690 - CLEANUP: promex: stop using appctx->st2
2691 - CLEANUP: stats/cli: take the "show stat" context definition out of the appctx
2692 - CLEANUP: stats/cli: stop using appctx->st2
2693 - CLEANUP: hlua/cli: take the hlua_cli context definition out of the appctx
2694 - CLEANUP: ssl/cli: use a local context for "show cafile"
2695 - CLEANUP: ssl/cli: use a local context for "show crlfile"
2696 - CLEANUP: ssl/cli: use a local context for "show ssl cert"
2697 - CLEANUP: ssl/cli: use a local context for "commit ssl cert"
2698 - CLEANUP: ssl/cli: stop using appctx->st2 for "commit ssl cert"
2699 - CLEANUP: ssl/cli: use a local context for "set ssl cert"
2700 - CLEANUP: ssl/cli: use a local context for "set ssl cafile"
2701 - CLEANUP: ssl/cli: use a local context for "set ssl crlfile"
2702 - CLEANUP: ssl/cli: use a local context for "commit ssl {ca|crl}file"
2703 - CLEANUP: ssl/cli: stop using appctx->st2 for "commit ssl ca/crl"
2704 - CLEANUP: ssl/cli: stop using ctx.cli.i0/i1/p0 for "show tls-keys"
2705 - CLEANUP: ssl/cli: add a new "dump_entries" field to "show_keys_ref"
2706 - CLEANUP: ssl/cli: make "show tlskeys" not use appctx->st2 anymore
2707 - CLEANUP: ssl/cli: make "show ssl ocsp-response" not use cli.p0 anymore
2708 - CLEANUP: ssl/cli: make "{show|dump} ssl crtlist" use its own context
2709 - CLEANUP: ssl/cli: make "add ssl crtlist" use its own context
2710 - CLEANUP: ssl/cli: make "add ssl crtlist" not use st2 anymore
2711 - CLEANUP: dns: stop abusing the sink forwarder's context
2712 - CLEANUP: sink: use the generic context to store the forwarder's context
2713 - CLEANUP: activity/cli: make "show profiling" not use ctx.cli anymore
2714 - CLEANUP: debug/cli: make "debug dev fd" not use ctx.cli anymore
2715 - CLEANUP: debug/cli: make "debug dev memstats" not use ctx.cli anymore
2716 - CLEANUP: ring: pass the ring watch flags to ring_attach_cli(), not in ctx.cli
2717 - CLEANUP: ring/cli: use a locally-defined context instead of using ctx.cli
2718 - CLEANUP: resolvers/cli: make "show resolvers" use a locally-defined context
2719 - CLEANUP: resolvers/cli: remove the unneeded appctx->st2 from "show resolvers"
2720 - CLEANUP: cache/cli: make use of a locally defined context for "show cache"
2721 - CLEANUP: proxy/cli: make use of a locally defined context for "show servers"
2722 - CLEANUP: proxy/cli: get rid of appctx->st2 in "show servers"
2723 - CLEANUP: proxy/cli: make "show backend" only use the generic context
2724 - CLEANUP: cli: make "show fd" use its own context
2725 - CLEANUP: cli: make "show env" use its own context
2726 - CLEANUP: cli: simplify the "show cli sockets" I/O handler
2727 - CLEANUP: cli: make "show cli sockets" use its own context
2728 - CLEANUP: httpclient/cli: use a locally-defined context instead of ctx.cli
2729 - CLEANUP: httpclient: do not use the appctx.ctx anymore
2730 - CLEANUP: peers: do not use appctx.ctx anymore
2731 - CLEANUP: spoe: do not use appctx.ctx anymore
2732 - BUILD: applet: mark the CLI's generic variables as deprecated
2733 - BUILD: applet: mark the appctx's st2 variable as deprecated
2734 - CLEANUP: cache: take the context out of appctx.ctx
2735 - MEDIUM: lua: move the cosocket storage outside of appctx.ctx
2736 - MINOR: lua: move the tcp service storage outside of appctx.ctx
2737 - MINOR: lua: move the http service context out of appctx.ctx
2738 - CLEANUP: cli: move the status print context into its own context
2739 - CLEANUP: stats: rename the stats state values an mark the old ones deprecated
2740 - DOC: internal: document the new cleaner approach to the appctx
2741 - MINOR: tcp: socket translate TCP_KEEPIDLE for macOs equivalent
2742 - DOC: fix typo "ant" for "and" in INSTALL
2743 - CI: dynamically determine actual version of h2spec
2744
Willy Tarreau026fef92022-04-30 14:17:51 +020027452022/04/30 : 2.6-dev8
2746 - BUG/MINOR: quic: fix use-after-free with trace on ACK consume
2747 - BUG/MINOR: rules: Forbid captures in defaults section if used by a backend
2748 - BUG/MEDIUM: rules: Be able to use captures defined in defaults section
2749 - BUG/MINOR: rules: Fix check_capture() function to use the right rule arguments
2750 - BUG/MINOR: http-act: make release_http_redir() more robust
2751 - BUG/MINOR: sample: add missing use_backend/use-server contexts in smp_resolve_args
2752 - MINOR: sample: don't needlessly call c_none() in sample_fetch_as_type()
2753 - MINOR: sample: make the bool type cast to bin
2754 - MEDIUM: backend: add new "balance hash <expr>" algorithm
2755 - MINOR: init: add global setting "fd-hard-limit" to bound system limits
2756 - BUILD: pollers: use an initcall to register the pollers
2757 - BUILD: xprt: use an initcall to register the transport layers
2758 - BUILD: thread: use initcall instead of a constructor
2759 - BUILD: http: remove the two unused constructors in rules and ana
2760 - CLEANUP: compression: move the default setting of maxzlibmem to defaults
2761 - MINOR: tree-wide: always consider EWOULDBLOCK in addition to EAGAIN
2762 - BUG/MINOR: connection: "connection:close" header added despite 'close-spread-time'
2763 - MINOR: fd: add functions to set O_NONBLOCK and FD_CLOEXEC
2764 - CLEANUP: tree-wide: use fd_set_nonblock() and fd_set_cloexec()
2765 - CLEANUP: tree-wide: remove 25 occurrences of unneeded fcntl.h
2766 - REGTESTS: fix the race conditions in be2dec.vtc ad field.vtc
2767 - REGTESTS: webstats: remove unused stats socket in /tmp
2768 - MEDIUM: httpclient: disable SSL when the ca-file couldn't be loaded
2769 - BUG/MINOR: httpclient/lua: error when the httpclient_start() fails
2770 - BUG/MINOR: ssl: free the cafile entries on deinit
2771 - BUG/MINOR: ssl: memory leak when trying to load a directory with ca-file
2772 - MEDIUM: httpclient: re-enable the verify by default
2773 - BUG/MEDIUM: ssl/cli: fix yielding in show_cafile_detail
2774 - BUILD: compiler: properly distinguish weak and global symbols
2775 - MINOR: connection: Add way to disable active connection closing during soft-stop
2776 - BUG/MEDIUM: http-ana: Fix memleak in redirect rules with ignore-empty option
2777 - CLEANUP: Destroy `http_err_chunks` members during deinit
2778 - BUG/MINOR: resolvers: Fix memory leak in resolvers_deinit()
2779 - MINOR: Call deinit_and_exit(0) for `haproxy -vv`
2780 - BUILD: fd: disguise the fd_set_nonblock/cloexec result
2781 - BUG/MINOR: pools: make sure to also destroy shared pools in pool_destroy_all()
2782 - MINOR: ssl: add a new global option "tune.ssl.hard-maxrecord"
2783 - CLEANUP: errors: also call deinit_errors_buffers() on deinit()
2784 - CLEANUP: chunks: release trash also in deinit
2785 - CLEANUP: deinit: release the pre-check callbacks
2786 - CLEANUP: deinit: release the config postparsers
2787 - CLEANUP: listeners/deinit: release accept queue tasklets on deinit
2788 - CLEANUP: connections/deinit: destroy the idle_conns tasks
2789 - BUG/MINOR: mux-quic: fix build in release mode
2790 - MINOR: mux-quic: adjust comment on emission function
2791 - MINOR: mux-quic: remove unused bogus qcc_get_stream()
2792 - BUG/MINOR: mux-quic: fix leak if cs alloc failure
2793 - MINOR: mux-quic: count local flow-control stream limit on reception
2794 - BUG/MINOR: h3: fix incomplete POST requests
2795 - BUG/MEDIUM: h3: fix use-after-free on mux Rx buffer wrapping
2796 - MINOR: mux-quic: partially copy Rx frame if almost full buf
2797 - MINOR: h3: change frame demuxing API
2798 - MINOR: mux-quic: add a app-layer context in qcs
2799 - MINOR: h3: implement h3 stream context
2800 - MINOR: h3: support DATA demux if buffer full
2801 - MINOR: quic: decode as much STREAM as possible
2802 - MINOR: quic: Improve qc_prep_pkts() flexibility
2803 - MINOR: quic: Prepare quic_frame struct duplication
2804 - MINOR: quic: Do not retransmit frames from coalesced packets
2805 - MINOR: quic: Add traces about TX frame memory releasing
2806 - MINOR: quic: process_timer() rework
2807 - MEDIUM: quic: New functions for probing rework
2808 - MEDIUM: quic: Retransmission functions rework
2809 - MEDIUM: quic: qc_requeue_nacked_pkt_tx_frms() rework
2810 - MINOR: quic: old data distinction for qc_send_app_pkt()
2811 - MINOR: quic: Mark packets as probing with old data
2812 - MEDIUM: quic: Mark copies of acknowledged frames as acknowledged
2813 - MEDIUM: quic: Enable the new datagram probing process
2814 - MINOR: quic: Do not send ACK frames when probing
2815 - BUG/MINOR: quic: Wrong returned status by qc_build_frms()
2816 - BUG/MINOR: quic: Avoid sending useless PADDING frame
2817 - BUG/MINOR: quic: Traces fix about remaining frames upon packet build failure
2818 - MINOR: quic: Wake up the mux to probe with new data
2819 - BUG/MEDIUM: quic: Possible crash on STREAM frame loss
2820 - BUG/MINOR: quic: Missing Initial packet length check
2821 - CLEANUP: quic: Rely on the packet length set by qc_lstnr_pkt_rcv()
2822 - MINOR: quic: Drop 0-RTT packets if not allowed
2823 - BUG/MINOR: httpclient/ssl: use the correct verify constant
2824 - BUG/MEDIUM: conn-stream: Don't erase endpoint flags on reset
2825 - BUG/MEDIUM: httpclient: Fix loop consuming HTX blocks from the response channel
2826 - BUG/MINOR: httpclient: Count metadata in size to transfer via htx_xfer_blks()
2827 - MINOR: httpclient: Don't use co_set_data() to decrement output
2828 - BUG/MINOR: conn_stream: do not confirm a connection from the frontend path
2829 - MEDIUM: quic: do not ACK packet with STREAM if MUX not present
2830 - MEDIUM: quic: do not ack packet with invalid STREAM
2831 - MINOR: quic: Drop 0-RTT packets without secrets
2832 - CLEANUP: quic: Remaining fprintf() debug trace
2833 - MINOR: quic: moving code for QUIC loss detection
2834 - BUG/MINOR: quic: Missing time threshold multiplifier for loss delay computation
2835 - CI: github actions: update LibreSSL to 3.5.2
2836 - SCRIPTS: announce-release: add URL of dev packages
2837
Willy Tarreau3e69fcc2022-04-23 04:38:36 +020028382022/04/23 : 2.6-dev7
2839 - BUILD: calltrace: fix wrong include when building with TRACE=1
2840 - MINOR: ssl: Use DH parameters defined in RFC7919 instead of hard coded ones
2841 - MEDIUM: ssl: Disable DHE ciphers by default
2842 - BUILD: ssl: Fix compilation with OpenSSL 1.0.2
2843 - MINOR: mux-quic: split xfer and STREAM frames build
2844 - REORG: quic: use a dedicated module for qc_stream_desc
2845 - MINOR: quic-stream: use distinct tree nodes for quic stream and qcs
2846 - MINOR: quic-stream: add qc field
2847 - MEDIUM: quic: implement multi-buffered Tx streams
2848 - MINOR: quic-stream: refactor ack management
2849 - MINOR: quic: limit total stream buffers per connection
2850 - MINOR: mux-quic: implement immediate send retry
2851 - MINOR: cfg-quic: define tune.quic.conn-buf-limit
2852 - MINOR: ssl: Add 'show ssl providers' cli command and providers list in -vv option
2853 - REGTESTS: ssl: Update error messages that changed with OpenSSLv3.1.0-dev
2854 - BUG/MEDIUM: quic: Possible crash with released mux
2855 - BUG/MINOR: mux-quic: unsubscribe on release
2856 - BUG/MINOR: mux-quic: handle null timeout
2857 - BUG/MEDIUM: logs: fix http-client's log srv initialization
2858 - BUG/MINOR: mux-quic: remove dead code in qcs_xfer_data()
2859 - DEV: stream: Fix conn-streams dump in full stream message
2860 - CLEANUP: conn-stream: Rename cs_conn_close() and cs_conn_drain_and_close()
2861 - CLEANUP: conn-stream: Rename cs_applet_release()
2862 - MINOR: conn-stream: Rely on endpoint shutdown flags to shutdown an applet
2863 - BUG/MINOR: cache: Disable cache if applet creation fails
2864 - BUG/MINOR: backend: Don't allow to change backend applet
2865 - BUG/MEDIUM: conn-stream: Set back CS to RDY state when the appctx is created
2866 - MINOR: stream: Don't needlessly detach server endpoint on early client abort
2867 - MINOR: conn-stream: Make cs_detach_* private and use cs_destroy() from outside
2868 - MINOR: init: add the pre-check callback
2869 - MEDIUM: httpclient: change the init sequence
2870 - MEDIUM: httpclient/ssl: verify required
2871 - MINOR: httpclient/mworker: disable in the master process
2872 - MEDIUM: httpclient/ssl: verify is configurable and disabled by default
2873 - BUG/MAJOR: connection: Never remove connection from idle lists outside the lock
2874 - BUG/MEDIUM: mux-quic: fix stalled POST requets
2875 - BUG/MINOR: mux-quic: fix POST with abortonclose
2876 - MINOR: task: add a new task_instant_wakeup() function
2877 - MEDIUM: queue: use tasklet_instant_wakeup() to wake tasks
2878 - DOC: remove my name from the config doc
2879
Willy Tarreaua8b10652022-04-16 12:15:47 +020028802022/04/16 : 2.6-dev6
2881 - CLEANUP: connection: reduce the with of the mux dump output
2882 - CI: Update to actions/checkout@v3
2883 - CI: Update to actions/cache@v3
2884 - DOC: adjust QUIC instruction in INSTALL
2885 - BUG/MINOR: stats: define the description' background color in dark color scheme
2886 - BUILD: ssl: add USE_ENGINE and disable the openssl engine by default
2887 - BUILD: makefile: pass USE_ENGINE to cflags
2888 - BUILD: xprt-quic: replace ERR_func_error_string() with ERR_peek_error_func()
2889 - DOC: install: document the fact that SSL engines are not enabled by default
2890 - CI: github actions: disable -Wno-deprecated
2891 - BUILD: makefile: silence unbearable OpenSSL deprecation warnings
2892 - MINOR: sock: check configured limits at the sock layer, not the listener's
2893 - MINOR: connection: add a new flag CO_FL_FDLESS on fd-less connections
2894 - MINOR: connection: add conn_fd() to retrieve the FD only when it exists
2895 - MINOR: stream: only dump connections' FDs when they are valid
2896 - MINOR: connection: use conn_fd() when displaying connection errors
2897 - MINOR: connection: skip FD-based syscalls for FD-less connections
2898 - MEDIUM: connection: panic when calling FD-specific functions on FD-less conns
2899 - MINOR: mux-quic: properly set the flags and name fields
2900 - MINOR: connection: rearrange conn_get_src/dst to be a bit more extensible
2901 - MINOR: protocol: add get_src() and get_dst() at the protocol level
2902 - MINOR: quic-sock: provide a pair of get_src/get_dst functions
2903 - MEDIUM: ssl: improve retrieval of ssl_sock_ctx and SSL detection
2904 - MEDIUM: ssl: stop using conn->xprt_ctx to access the ssl_sock_ctx
2905 - MEDIUM: xprt-quic: implement get_ssl_sock_ctx()
2906 - MEDIUM: quic: move conn->qc into conn->handle
2907 - BUILD: ssl: fix build warning with previous changes to ssl_sock_ctx
2908 - BUILD: ssl: add an unchecked version of __conn_get_ssl_sock_ctx()
2909 - MINOR: ssl: refine the error testing for fc_err and fc_err_str
2910 - BUG/MINOR: sock: do not double-close the accepted socket on the error path
2911 - CI: cirrus: switch to FreeBSD-13.0
2912 - MINOR: log: add '~' to frontend when the transport layer provides SSL
2913 - BUILD/DEBUG: lru: fix printf format in debug code
2914 - BUILD: peers: adjust some printf format to silence cppcheck
2915 - BUILD/DEBUG: hpack-tbl: fix format string in standalone debug code
2916 - BUILD/DEBUG: hpack: use unsigned int in printf format in debug code
2917 - BUILD: halog: fix some incorrect signs in printf formats for integers
2918 - BUG/MINOR: h3: fix build with DEBUG_H3
2919 - BUG/MINOR: mux-h2: do not send GOAWAY if SETTINGS were not sent
2920 - BUG/MINOR: cache: do not display expired entries in "show cache"
2921 - BUG/MINOR: mux-h1: Don't release unallocated CS on error path
2922 - MINOR: applet: Make .init callback more generic
2923 - MINOR: conn-stream: Add flags to set the type of the endpoint
2924 - MEDIUM: applet: Set the appctx owner during allocation
2925 - MAJOR: conn-stream: Invert conn-stream endpoint and its context
2926 - REORG: Initialize the conn-stream by hand in cs_init()
2927 - MEDIUM: conn-stream: Add an endpoint structure in the conn-stream
2928 - MINOR: conn-stream: Move some CS flags to the endpoint
2929 - MEDIUM: conn-stream: Be able to pass endpoint to create a conn-stream
2930 - MEDIUM: conn-stream: Pre-allocate endpoint to create CS from muxes and applets
2931 - REORG: applet: Uninline appctx_new function
2932 - MAJOR: conn-stream: Share endpoint struct between the CS and the mux/applet
2933 - MEDIUM: conn-stream: Move remaning flags from CS to endpoint
2934 - MINOR: mux-pt: Rely on the endpoint instead of the conn-stream when possible
2935 - MINOR: conn-stream: Add ISBACK conn-stream flag
2936 - MINOR: conn-stream: Add header file with util functions related to conn-streams
2937 - MEDIUM: tree-wide: Use CS util functions instead of SI ones
2938 - MINOR: stream-int/txn: Move buffer for L7 retries in the HTTP transaction
2939 - CLEANUP: http-ana: Remove http_alloc_txn() function
2940 - MINOR: stream-int/stream: Move conn_retries counter in the stream
2941 - MINOR: stream: Simplify retries counter calculation
2942 - MEDIUM: stream-int/conn-stream: Move src/dst addresses in the conn-stream
2943 - MINOR: stream-int/conn-stream: Move half-close timeout in the conn-stream
2944 - MEDIUM: stream-int/stream: Use connect expiration instead of SI expiration
2945 - MINOR: stream-int/conn-stream: Report error to the CS instead of the SI
2946 - MEDIUM: conn-stream: Use endpoint error instead of conn-stream error
2947 - MINOR: channel: Use conn-streams as channel producer and consumer
2948 - MINOR: stream-int: Remove SI_FL_KILL_CON to rely on conn-stream endpoint only
2949 - MINOR: mux-h2/mux-fcgi: Fully rely on CS_EP_KILL_CONN
2950 - MINOR: stream-int: Remove SI_FL_NOLINGER/NOHALF to rely on CS flags instead
2951 - MINOR: stream-int: Remove SI_FL_DONT_WAKE to rely on CS flags instead
2952 - MINOR: stream-int: Remove SI_FL_INDEP_STR to rely on CS flags instead
2953 - MINOR: stream-int: Remove SI_FL_SRC_ADDR to rely on stream flags instead
2954 - CLEANUP: stream-int: Remove unused SI_FL_CLEAN_ABRT flag
2955 - MINOR: stream: Only save previous connection state for the server side
2956 - MEDIUM: stream-int: Move SI err_type in the stream
2957 - MEDIUM: stream-int/conn-stream: Move stream-interface state in the conn-stream
2958 - MINOR: stream-int/stream: Move si_retnclose() in the stream scope
2959 - MINOR: stream-int/backend: Move si_connect() in the backend scope
2960 - MINOR: stream-int/conn-stream: Move si_conn_ready() in the conn-stream scope
2961 - MINOR: conn-stream/connection: Move SHR/SHW modes in the connection scope
2962 - MEDIUM: conn-stream: Be prepared to fail to attach a cs to a mux
2963 - MEDIUM: stream-int/conn-stream: Handle I/O subscriptions in the conn-stream
2964 - MINOR: conn-stream: Rename CS functions dedicated to connections
2965 - MINOR: stream-int/conn-stream: Move si_shut* and si_chk* in conn-stream scope
2966 - MEDIUM: stream-int/conn-stream: Move si_ops in the conn-stream scope
2967 - MINOR: applet: Use the CS to register and release applets instead of SI
2968 - MINOR: connection: unconst mux's get_fist_cs() callback function
2969 - MINOR: stream-int/connection: Move conn_si_send_proxy() in the connection scope
2970 - REORG: stream-int: Export si_cs_recv(), si_cs_send() and si_cs_process()
2971 - REORG: stream-int: Move si_is_conn_error() in the header file
2972 - REORG: conn-stream: Move cs_shut* and cs_chk* in cs_utils
2973 - REORG: conn-stream: Move cs_app_ops in conn_stream.c
2974 - MINOR: stream-int-conn-stream: Move si_update_* in conn-stream scope
2975 - MINOR: stream-int/stream: Move si_update_both in stream scope
2976 - MEDIUM: conn-stream/applet: Add a data callback for applets
2977 - MINOR: stream-int/conn-stream: Move stream_int_read0() in the conn-stream scope
2978 - MINOR: stream-int/conn-stream: Move stream_int_notify() in the conn-stream scope
2979 - MINOR: stream-int/conn-stream: Move si_cs_io_cb() in the conn-stream scope
2980 - MINOR: stream-int/conn-stream: Move si_sync_recv/send() in conn-stream scope
2981 - MINOR: conn-stream: Move si_conn_cb in the conn-stream scope
2982 - MINOR: stream-int/conn-stream Move si_is_conn_error() in the conn-stream scope
2983 - MINOR: stream-int/conn-stream: Move si_alloc_ibuf() in the conn-stream scope
2984 - CLEANUP: stream-int: Remove unused SI functions
2985 - MEDIUM: stream-int/conn-stream: Move blocking flags from SI to CS
2986 - MEDIUM: stream-int/conn-stream: Move I/O functions to conn-stream
2987 - REORG: stream-int/conn-stream: Move remaining functions to conn-stream
2988 - MINOR: stream: Use conn-stream to report server error
2989 - MINOR: http-ana: Use CS to perform L7 retries
2990 - MEDIUM: stream: Don't use the stream-int anymore in process_stream()
2991 - MINOR: conn-stream: Remove the stream-interface from the conn-stream
2992 - DEV: flags: No longer dump SI flags
2993 - CLEANUP: tree-wide: Remove any ref to stream-interfaces
2994 - CLEANUP: conn-stream: Don't export internal functions
2995 - DOC: conn-stream: Add comments on functions of the new CS api
2996 - MEDIUM: check: Use a new conn-stream for each health-check run
2997 - CLEANUP: muxes: Remove MX_FL_CLEAN_ABRT flag
2998 - MINOR: conn-stream: Use a dedicated function to conditionally remove a CS
2999 - CLEANUP: conn-stream: rename cs_register_applet() to cs_applet_create()
3000 - MINOR: muxes: Improve show_fd callbacks to dump endpoint flags
3001 - MINOR: mux-h1: Rely on the endpoint instead of the conn-stream when possible
3002 - BUG/MINOR: quic: Avoid starting the mux if no ALPN sent by the client
3003 - BUILD: debug: mark the __start_mem_stats/__stop_mem_stats symbols as weak
3004 - BUILD: initcall: mark the __start_i_* symbols as weak, not global
3005 - BUG/MINOR: mux-h2: do not use timeout http-keep-alive on backend side
3006 - BUG/MINOR: mux-h2: use timeout http-request as a fallback for http-keep-alive
3007 - MINOR: muxes: Don't expect to have a mux without connection in destroy callback
3008 - MINOR: muxes: Don't handle proto upgrade for muxes not supporting it
3009 - MINOR: muxes: Don't expect to call release function with no mux defined
3010 - MINOR: conn-stream: Use unsafe functions to get conn/appctx in cs_detach_endp
3011 - BUG/MEDIUM: mux-h1: Don't request more room on partial trailers
3012 - BUILD: http-client: Avoid dead code when compiled without SSL support
3013 - BUG/MINOR: mux-quic: prevent a crash in session_free on mux.destroy
3014 - BUG/MINOR: quic-sock: do not double free session on conn init failure
3015 - BUG/MINOR: quic: fix return value for error in start
3016 - MINOR: quic: emit CONNECTION_CLOSE on app init error
3017 - BUILD: sched: workaround crazy and dangerous warning in Clang 14
3018 - BUILD: compiler: use a more portable set of asm(".weak") statements
3019 - BUG/MEDIUM: stream: do not abort connection setup too early
3020 - CLEANUP: extcheck: do not needlessly preset the server's address/port
3021 - MINOR: extcheck: fill in the server's UNIX socket address when known
3022 - BUG/MEDIUM: connection: Don't crush context pointer location if it is a CS
3023 - BUG/MEDIUM: quic: properly clean frames on stream free
3024 - BUG/MEDIUM: fcgi-app: Use http_msg flags to know if C-L header can be added
3025 - BUG/MEDIUM: compression: Don't forget to update htx_sl and http_msg flags
3026 - MINOR: tcp_sample: clarifying samples support per os, for further expansion.
3027 - MINOR: tcp_sample: extend support for get_tcp_info to macOs.
3028 - SCRIPTS: announce-release: update the doc's URL
3029 - DOC: lua: update a few doc URLs
3030 - SCRIPTS: announce-release: add shortened links to pending issues
3031
Willy Tarreaud3b4cd12022-04-09 11:31:40 +020030322022/04/09 : 2.6-dev5
3033 - DOC: reflect H2 timeout changes
3034 - BUG/MEDIUM: mux-fcgi: Properly handle return value of headers/trailers parsing
3035 - BUG/MEDIUM: mux-h1: Properly detect full buffer cases during message parsing
3036 - BUG/MINOR: log: Initialize the list element when allocating a new log server
3037 - BUG/MINOR: samples: add missing context names for sample fetch functions
3038 - MINOR: management: add some basic keyword dump infrastructure
3039 - MINOR: config: add a function to dump all known config keywords
3040 - MINOR: filters: extend flt_dump_kws() to dump to stdout
3041 - MINOR: services: extend list_services() to dump to stdout
3042 - MINOR: cli: add a new keyword dump function
3043 - MINOR: acl: add a function to dump the list of known ACL keywords
3044 - MINOR: samples: add a function to list register sample fetch keywords
3045 - MINOR: sample: list registered sample converter functions
3046 - MINOR: tools: add strordered() to check whether strings are ordered
3047 - MINOR: action: add a function to dump the list of actions for a ruleset
3048 - MINOR: config: alphanumerically sort config keywords output
3049 - MINOR: sample: alphanumerically sort sample & conv keyword dumps
3050 - MINOR: acl: alphanumerically sort the ACL dump
3051 - MINOR: cli: alphanumerically sort the dump of supported commands
3052 - MINOR: filters: alphabetically sort the list of filter names
3053 - MINOR: services: alphabetically sort service names
3054 - MEDIUM: httpclient/lua: be stricter with httpclient parameters
3055 - MINOR: ssl: split the cert commit io handler
3056 - MINOR: ssl: move the cert_exts and the CERT_TYPE enum
3057 - MINOR: ssl: simplify the certificate extensions array
3058 - MINOR: ssl: export ckch_inst_rebuild()
3059 - MINOR: ssl: add "crt" in the cert_exts array
3060 - MINOR: ssl/lua: CertCache.set() allows to update an SSL certificate file
3061 - BUILD: ssl/lua: CacheCert needs OpenSSL
3062 - DOC: lua: CertCache class documentation
3063 - BUG/MEDIUM: quic: do not use qcs from quic_stream on ACK parsing
3064 - MINOR: mux-quic: return qcs instance from qcc_get_qcs
3065 - MINOR: mux-quic: reorganize qcs free
3066 - MINOR: mux-quic: define release app-ops
3067 - BUG/MINOR: h3: release resources on close
3068 - BUG/MINOR: mux-quic: ensure to free all qcs on MUX release
3069 - CLEANUP: quic: complete comment on qcs_try_to_consume
3070 - MINOR: quic: implement stream descriptor for transport layer
3071 - MEDIUM: quic: move transport fields from qcs to qc_conn_stream
3072 - MEDIUM: mux-quic: remove qcs tree node
3073 - BUG/MINOR: cli/stream: fix "shutdown session" to iterate over all threads
3074 - DOC: management: add missing dot in 9.4.1
3075 - BUG/MAJOR: mux_pt: always report the connection error to the conn_stream
3076 - DOC: remove double blanks in configuration.txt
3077 - CI: github actions: update OpenSSL to 3.0.2
3078 - BUG/MEDIUM: quic: Possible crash in ha_quic_set_encryption_secrets()
3079 - CLEANUP: quic: Remove all atomic operations on quic_conn struct
3080 - CLEANUP: quic: Remove all atomic operations on packet number spaces
3081 - MEDIUM: quic: Send ACK frames asap
3082 - BUG/MINOR: quic: Missing probing packets when coalescing
3083 - BUG/MINOR: quic: Discard Initial packet number space only one time
3084 - MINOR: quic: Do not display any timer value from process_timer()
3085 - BUG/MINOR: quic: Do not probe from an already probing packet number space
3086 - BUG/MINOR: quic: Non duplicated frames upon fast retransmission
3087 - BUG/MINOR: quic: Too much prepared retransmissions due to anti-amplification
3088 - MINOR: quic: Useless call to SSL_CTX_set_default_verify_paths()
3089 - MINOR: quic: Add traces about list of frames
3090 - BUG/MINOR: h3: Missing wait event struct field initialization
3091 - BUG/MINOR: quic: QUIC TLS secrets memory leak
3092 - BUG/MINOR: quic: Missing ACK range deallocations
3093 - BUG/MINOR: quic: Missing TX packet deallocations
3094 - CLEANUP: hpack: be careful about integer promotion from uint8_t
3095 - OPTIM: hpack: read 32 bits at once when possible.
3096 - MEDIUM: ssl: allow loading of a directory with the ca-file directive
3097 - BUG/MINOR: ssl: continue upon error when opening a directory w/ ca-file
3098 - MINOR: ssl: ca-file @system-ca loads the system trusted CA
3099 - DOC: configuration: add the ca-file changes
3100 - MINOR: sample: converter: Add add_item convertor
3101 - BUG/MINOR: ssl: handle X509_get_default_cert_dir() returning NULL
3102 - BUG/MINOR: ssl/cli: Remove empty lines from CLI output
3103 - MINOR: httpclient: enable request buffering
3104 - MEDIUM: httpclient: enable l7-retry
3105 - BUG/MINOR: httpclient: end callback in applet release
3106 - MINOR: quic: Add draining connection state.
3107 - MINOR: quic: Add closing connection state
3108 - BUG/MEDIUM: quic: ensure quic-conn survives to the MUX
3109 - CLEANUP: quic: use static qualifer on quic_close
3110 - CLEANUP: mux-quic: remove unused QC_CF_CC_RECV
3111 - BUG/MINOR: fix memleak on quic-conn streams cleaning
3112 - MINOR: mux-quic: factorize conn-stream attach
3113 - MINOR: mux-quic: adjust timeout to accelerate closing
3114 - MINOR: mux-quic: define is_active app-ops
3115 - MINOR: mux-quic: centralize send operations in qc_send
3116 - MEDIUM: mux-quic: report CO_FL_ERROR on send
3117 - MEDIUM: mux-quic: report errors on conn-streams
3118 - MEDIUM: quic: report closing state for the MUX
3119 - BUG/MINOR: fcgi-app: Don't add C-L header on response to HEAD requests
3120 - BUG/MEDIUM: stats: Be sure to never set EOM flag on an empty HTX message
3121 - BUG/MEDIUM: hlua: Don't set EOM flag on an empty HTX message in HTTP applet
3122 - BUG/MEDIUM: promex: Be sure to never set EOM flag on an empty HTX message
3123 - BUG/MEDIUM: mux-h1: Set outgoing message to DONE when payload length is reached
3124 - BUG/MINOR: http_client: Don't add input data on an empty request buffer
3125 - BUG/MEDIUM: http-conv: Fix url_enc() to not crush const samples
3126 - BUG/MEDIUM: http-act: Don't replace URI if path is not found or invalid
3127 - CLEANUP: mux-quic: remove uneeded TODO in qc_detach
3128 - BUG/MEDIUM: mux-quic: properly release conn-stream on detach
3129 - BUG/MINOR: quic: set the source not the destination address on accept()
3130 - BUG/MEDIUM: quic: Possible crash from quic_free_arngs()
3131 - MINOR: quic_tls: Add reusable cipher contexts to QUIC TLS contexts
3132 - MINOR: quic_tls: Stop hardcoding cipher IV lengths
3133 - CLEANUP: quic: Do not set any cipher/group from ssl_quic_initial_ctx()
3134 - MINOR: quic: Add short packet key phase bit values to traces
3135 - MINOR: quic_tls: Make key update use of reusable cipher contexts
3136 - BUG/MINOR: opentracing: setting the return value in function flt_ot_var_set()
3137 - BUG/BUILD: opentracing: fixed OT_DEFINE variable setting
3138 - EXAMPLES: opentracing: refined shell scripts for testing filter performance
3139 - DOC: opentracing: corrected comments in function descriptions
3140 - CLEANUP: opentracing: removed unused function flt_ot_var_unset()
3141 - CLEANUP: opentracing: removed unused function flt_ot_var_get()
3142 - Revert "MINOR: opentracing: change the scope of the variable 'ot.uuid' from 'sess' to 'txn'"
3143 - MINOR: opentracing: only takes the variables lock on shared entries
3144 - CLEANUP: opentracing: added flt_ot_smp_init() function
3145 - CLEANUP: opentracing: added variable to store variable length
3146 - MINOR: opentracing: improved normalization of context variable names
3147 - DEBUG: opentracing: show return values of all functions in the debug output
3148 - CLEANUP: opentracing: added FLT_OT_PARSE_INVALID_enum enum
3149 - DEBUG: opentracing: display the contents of the err variable after setting
3150 - MAJOR: opentracing: reenable usage of vars to transmit opentracing context
3151 - Revert "BUILD: opentracing: display warning in case of using OT_USE_VARS at compile time"
3152 - MEDIUM: global: Add a "close-spread-time" option to spread soft-stop on time window
3153
Willy Tarreau0541c2b2022-03-26 08:31:33 +010031542022/03/26 : 2.6-dev4
3155 - BUG/MEDIUM: httpclient: don't consume data before it was analyzed
3156 - CLEANUP: htx: remove unused co_htx_remove_blk()
3157 - BUG/MINOR: httpclient: consume partly the blocks when necessary
3158 - BUG/MINOR: httpclient: remove the UNUSED block when parsing headers
3159 - BUG/MEDIUM: httpclient: must manipulate head, not first
3160 - REGTESTS: fix the race conditions in be2hex.vtc
3161 - BUG/MEDIUM: quic: Blocked STREAM when retransmitted
3162 - BUG/MAJOR: quic: Possible crash with full congestion control window
3163 - BUG/MINOR: httpclient/lua: stuck when closing without data
3164 - BUG/MEDIUM: applet: Don't call .release callback function twice
3165 - BUG/MEDIUM: cli/debug: Properly get the stream-int in all debug I/O handlers
3166 - BUG/MEDIUM: sink: Properly get the stream-int in appctx callback functions
3167 - DEV: udp: switch parser to getopt() instead of positional arguments
3168 - DEV: udp: add support for random packet corruption
3169 - MINOR: server: export server_parse_sni_expr() function
3170 - BUG/MINOR: httpclient: send the SNI using the host header
3171 - BUILD: httpclient: fix build without SSL
3172 - BUG/MINOR: server/ssl: free the SNI sample expression
3173 - BUG/MINOR: logs: fix logsrv leaks on clean exit
3174 - MINOR: actions: add new function free_act_rule() to free a single rule
3175 - BUG/MINOR: tcp-rules: completely free incorrect TCP rules on error
3176 - BUG/MINOR: http-rules: completely free incorrect TCP rules on error
3177 - BUG/MINOR: httpclient: only check co_data() instead of HTTP_MSG_DATA
3178 - BUG/MINOR: httpclient: process the response when received before the end of the request
3179 - BUG/MINOR: httpclient: CF_SHUTW_NOW should be tested with channel_is_empty()
3180 - CI: github actions: switch to LibreSSL-3.5.1
3181 - BUG/MEDIUM: mux-h1: only turn CO_FL_ERROR to CS_FL_ERROR with empty ibuf
3182 - BUG/MEDIUM: stream-int: do not rely on the connection error once established
3183 - BUG/MEDIUM: trace: avoid race condition when retrieving session from conn->owner
3184 - MEDIUM: mux-h2: slightly relax timeout management rules
3185 - BUG/MEDIUM: mux-h2: make use of http-request and keep-alive timeouts
3186 - BUG/MINOR: rules: Initialize the list element when allocating a new rule
3187 - BUG/MINOR: http-rules: Don't free new rule on allocation failure
3188 - DEV: coccinelle: Fix incorrect replacement in ist.cocci
3189 - CLEANUP: Reapply ist.cocci with `--include-headers-for-types --recursive-includes`
3190 - DEV: coccinelle: Add a new pattern to ist.cocci
3191 - CLEANUP: Reapply ist.cocci
3192 - REGTESTS: Do not use REQUIRE_VERSION for HAProxy 2.5+
3193 - MINOR: quic: Code factorization (TX buffer reuse)
3194 - CLEANUP: quic: "largest_acked_pn" pktns struc member moving
3195 - MEDIUM: quic: Limit the number of ACK ranges
3196 - MEDIUM: quic: Rework of the TX packets memory handling
3197 - BUG/MINOR: quic: Possible crash in parse_retry_token()
3198 - BUG/MINOR: quic: Possible leak in quic_build_post_handshake_frames()
3199 - BUG/MINOR: quic: Unsent frame because of qc_build_frms()
3200 - BUG/MINOR: mux-quic: Access to empty frame list from qc_send_frames()
3201 - BUG/MINOR: mux-quic: Missing I/O handler events initialization
3202 - BUG/MINOR: quic: Missing TX packet initializations
3203 - BUG/MINOR: quic: 1RTT packets ignored after mux was released
3204 - BUG/MINOR: quic: Incorrect peer address validation
3205 - BUG/MINOR: quic: Non initialized variable in quic_build_post_handshake_frames()
3206 - BUG/MINOR: quic: Wrong TX packet related counters handling
3207 - MEDIUM: mqtt: support mqtt_is_valid and mqtt_field_value converters for MQTTv3.1
3208 - DOC: config: Explictly add supported MQTT versions
3209 - MINOR: quic: Add traces about stream TX buffer consumption
3210 - MINOR: quic: Add traces in qc_set_timer() (scheduling)
3211 - CLEANUP: mux-quic: change comment style to not mess with git conflict
3212 - CLEANUP: mux-quic: adjust comment for coding-style
3213 - MINOR: mux-quic: complete trace when stream is not found
3214 - MINOR: mux-quic: add comments for send functions
3215 - MINOR: mux-quic: use shorter name for flow-control fields
3216 - MEDIUM: mux-quic: respect peer bidirectional stream data limit
3217 - MEDIUM: mux-quic: respect peer connection data limit
3218 - MINOR: mux-quic: support MAX_STREAM_DATA frame parsing
3219 - MINOR: mux-quic: support MAX_DATA frame parsing
3220 - BUILD: stream-int: avoid a build warning when DEBUG is empty
3221 - BUG/MINOR: quic: Wrong buffer length passed to generate_retry_token()
3222 - BUG/MINOR: tools: fix url2sa return value with IPv4
3223 - MINOR: mux-quic: convert fin on push-frame as boolean
3224 - BUILD: quic: add missing includes
3225 - REORG: quic: use a dedicated quic_loss.c
3226 - MINOR: mux-quic: declare the qmux trace module
3227 - MINOR: mux-quic: replace printfs by traces
3228 - MINOR: mux-quic: add trace event for frame sending
3229 - MINOR: mux-quic: add trace event for qcs_push_frame
3230 - MINOR: mux-quic: activate qmux traces on stdout via macro
3231 - BUILD: qpack: fix unused value when not using DEBUG_HPACK
3232 - CLEANUP: qpack: suppress by default stdout traces
3233 - CLEANUP: h3: suppress by default stdout traces
3234 - BUG/MINOR: tools: url2sa reads too far when no port nor path
3235
Willy Tarreaubc8b7a12022-03-11 18:09:24 +010032362022/03/11 : 2.6-dev3
3237 - DEBUG: rename WARN_ON_ONCE() to CHECK_IF()
3238 - DEBUG: improve BUG_ON output message accuracy
3239 - DEBUG: implement 4 levels of choices between warn and crash.
3240 - DEBUG: add two new macros to enable debugging in hot paths
3241 - DEBUG: buf: replace some sensitive BUG_ON() with BUG_ON_HOT()
3242 - DEBUG: buf: add BUG_ON_HOT() to most buffer management functions
3243 - MINOR: channel: don't use co_set_data() to decrement output
3244 - DEBUG: channel: add consistency checks using BUG_ON_HOT() in some key functions
3245 - MINOR: conn-stream: Improve API to have safe/unsafe accessors
3246 - MEDIUM: tree-wide: Use unsafe conn-stream API when it is relevant
3247 - CLEANUP: stream-int: Make si_cs_send() function static
3248 - REORG: stream-int: Uninline si_sync_recv() and make si_cs_recv() private
3249 - BUG/MEDIUM: mux-fcgi: Don't rely on SI src/dst addresses for FCGI health-checks
3250 - BUG/MEDIUM: htx: Fix a possible null derefs in htx_xfer_blks()
3251 - REGTESTS: fix the race conditions in normalize_uri.vtc
3252 - DEBUG: stream-int: Fix BUG_ON used to test appctx in si_applet_ops callbacks
3253 - BUILD: debug: fix build warning on older compilers around DEBUG_STRICT_ACTION
3254 - CLEANUP: connection: Indicate unreachability to the compiler in conn_recv_proxy
3255 - MINOR: connection: Transform safety check in PROXYv2 parsing into BUG_ON()
3256 - DOC: install: it's DEBUG_CFLAGS, not DEBUG, which is set to -g
3257 - DOC: install: describe the DEP variable
3258 - DOC: install: describe how to choose options used in the DEBUG variable
3259 - MINOR: queue: Replace if() + abort() with BUG_ON()
3260 - CLEANUP: adjust indentation in bidir STREAM handling function
3261 - MINOR: quic: simplify copy of STREAM frames to RX buffer
3262 - MINOR: quic: handle partially received buffered stream frame
3263 - MINOR: mux-quic: define flag for last received frame
3264 - BUG/MINOR: quic: support FIN on Rx-buffered STREAM frames
3265 - MEDIUM: quic: rearchitecture Rx path for bidirectional STREAM frames
3266 - REGTESTS: fix the race conditions in secure_memcmp.vtc
3267 - CLEANUP: stream: Remove useless tests on conn-stream in stream_dump()
3268 - BUILD: ssl: another build warning on LIBRESSL_VERSION_NUMBER
3269 - MINOR: quic: Ensure PTO timer is not set in the past
3270 - MINOR: quic: Post handshake I/O callback switching
3271 - MINOR: quic: Drop the packets of discarded packet number spaces
3272 - CLEANUP: quic: Useless tests in qc_try_rm_hp()
3273 - CLEANUP: quic: Indentation fix in qc_prep_pkts()
3274 - MINOR: quic: Assemble QUIC TLS flags at the same level
3275 - BUILD: conn_stream: avoid null-deref warnings on gcc 6
3276 - BUILD: connection: do not declare register_mux_proto() inline
3277 - BUILD: http_rules: do not declare http_*_keywords_registre() inline
3278 - BUILD: trace: do not declare trace_registre_source() inline
3279 - BUILD: tcpcheck: do not declare tcp_check_keywords_register() inline
3280 - DEBUG: reduce the footprint of BUG_ON() calls
3281 - BUG/MEDIUM: httpclient/lua: infinite appctx loop with POST
3282 - BUG/MINOR: pool: always align pool_heads to 64 bytes
3283 - DEV: udp: add a tiny UDP proxy for testing
3284 - DEV: udp: implement pseudo-random reordering/loss
3285 - DEV: udp: add an optional argument to set the prng seed
3286 - BUG/MINOR: quic: fix segfault on CC if mux uninitialized
3287 - BUG/MEDIUM: pools: fix ha_free() on area in the process of being freed
3288 - CLEANUP: tree-wide: remove a few rare non-ASCII chars
3289 - CI: coverity: simplify debugging options
3290 - CLEANUP: quic: complete ABORT_NOW with a TODO comment
3291 - MINOR: quic: qc_prep_app_pkts() implementation
3292 - MINOR: quic: Send short packet from a frame list
3293 - MINOR: quic: Make qc_build_frms() build ack-eliciting frames from a list
3294 - MINOR: quic: Export qc_send_app_pkts()
3295 - MINOR: mux-quic: refactor transport parameters init
3296 - MINOR: mux-quic: complete functions to detect stream type
3297 - MINOR: mux-quic: define new unions for flow-control fields
3298 - MEDIUM: mux-quic: use direct send transport API for STREAMs
3299 - MINOR: mux-quic: retry send opportunistically for remaining frames
3300 - MEDIUM: mux-quic: implement MAX_STREAMS emission for bidir streams
3301 - BUILD: fix kFreeBSD build.
3302 - MINOR: quic: Retry on qc_build_pkt() failures
3303 - BUG/MINOR: quic: Missing recovery start timer reset
3304 - CLEANUP: quic: Remove QUIC path manipulations out of the congestion controller
3305 - MINOR: quic: Add a "slow start" callback to congestion controller
3306 - MINOR: quic: Persistent congestion detection outside of controllers
3307 - CLEANUP: quic: Remove useless definitions from quic_cc_event struct
3308 - BUG/MINOR: quic: Confusion betwen "in_flight" and "prep_in_flight" in quic_path_prep_data()
3309 - MINOR: quic: More precise window update calculation
3310 - CLEANUP: quic: Remove window redundant variable from NewReno algorithm state struct
3311 - MINOR: quic: Add quic_max_int_by_size() function
3312 - BUG/MAJOR: quic: Wrong quic_max_available_room() returned value
3313 - MINOR: pools: add a new global option "no-memory-trimming"
3314 - BUG/MINOR: add missing modes in proxy_mode_str()
3315 - BUG/MINOR: cli: shows correct mode in "show sess"
3316 - BUG/MEDIUM: quic: do not drop packet on duplicate stream/decoding error
3317 - MINOR: stats: Add dark mode support for socket rows
3318 - BUILD: fix recent build breakage of freebsd caused by kFreeBSD build fix
3319 - BUG/MINOR: httpclient: Set conn-stream/channel EOI flags at the end of request
3320 - BUG/MINOR: hlua: Set conn-stream/channel EOI flags at the end of request
3321 - BUG/MINOR: stats: Set conn-stream/channel EOI flags at the end of request
3322 - BUG/MINOR: cache: Set conn-stream/channel EOI flags at the end of request
3323 - BUG/MINOR: promex: Set conn-stream/channel EOI flags at the end of request
3324 - BUG/MEDIUM: stream: Use the front analyzers for new listener-less streams
3325 - DEBUG: cache: Update underlying buffer when loading HTX message in cache applet
3326 - BUG/MEDIUM: mcli: Properly handle errors and timeouts during reponse processing
3327 - DEBUG: stream: Add the missing descriptions for stream trace events
3328 - DEBUG: stream: Fix stream trace message to print response buffer state
3329 - MINOR: proxy: Store monitor_uri as a `struct ist`
3330 - MINOR: proxy: Store fwdfor_hdr_name as a `struct ist`
3331 - MINOR: proxy: Store orgto_hdr_name as a `struct ist`
3332 - MEDIUM: proxy: Store server_id_hdr_name as a `struct ist`
3333 - CLEANUP: fcgi: Replace memcpy() on ist by istcat()
3334 - CLEANUP: fcgi: Use `istadv()` in `fcgi_strm_send_params`
3335 - BUG/MAJOR: mux-pt: Always destroy the backend connection on detach
3336 - DOC: sample fetch methods: move distcc_* to the right locations
3337 - MINOR: rules: record the last http/tcp rule that gave a final verdict
3338 - MINOR: stream: add "last_rule_file" and "last_rule_line" samples
3339 - BUG/MINOR: session: fix theoretical risk of memleak in session_accept_fd()
3340 - MINOR: quic: Add max_idle_timeout advertisement handling
3341 - MEDIUM: quic: Remove the QUIC connection reference counter
3342 - BUG/MINOR: quic: ACK_REQUIRED and ACK_RECEIVED flag collision
3343 - BUG/MINOR: quic: Missing check when setting the anti-amplification limit as reached
3344 - MINOR: quic: Add a function to compute the current PTO
3345 - MEDIUM: quic: Implement the idle timeout feature
3346 - BUG/MEDIUM: quic: qc_prep_app_pkts() retries on qc_build_pkt() failures
3347 - CLEANUP: quic: Comments fix for qc_prep_(app)pkts() functions
3348 - MINOR: mux-quic: prevent push frame for unidir streams
3349 - MINOR: mux-quic: improve opportunistic retry sending for STREAM frames
3350 - MINOR: quic: implement sending confirmation
3351 - MEDIUM: mux-quic: improve bidir STREAM frames sending
3352 - MEDIUM: check: do not auto configure SSL/PROXY for dynamic servers
3353 - REGTESTS: server: test SSL/PROXY with checks for dynamic servers
3354 - MEDIUM: server: remove experimental-mode for dynamic servers
3355 - BUG/MINOR: buffer: fix debugging condition in b_peek_varint()
3356
Willy Tarreau3b1d1902022-02-25 17:12:11 +010033572022/02/25 : 2.6-dev2
3358 - DOC: management: rework the Master CLI section
3359 - DOC: management: add expert and experimental mode in 9.4.1
3360 - CLEANUP: cleanup a commentary in pcli_parse_request()
3361 - BUG/MINOR: mworker/cli: don't display help on master applet
3362 - MINOR: mworker/cli: mcli-debug-mode enables every command
3363 - MINOR: mworker/cli: add flags in the prompt
3364 - BUG/MINOR: httpclient: Revisit HC request and response buffers allocation
3365 - BUG/MEDIUM: httpclient: Xfer the request when the stream is created
3366 - MINOR: httpclient: Don't limit data transfer to 1024 bytes
3367 - BUILD: ssl: adjust guard for X509_get_X509_PUBKEY(x)
3368 - REGTESTS: ssl: skip show_ssl_ocspresponse.vtc when BoringSSL is used
3369 - MINOR: quic: Do not modify a marked as consumed datagram
3370 - MINOR: quic: Wrong datagram buffer passed to quic_lstnr_dgram_dispatch()
3371 - MINOR: quic: Remove a useless test in quic_get_dgram_dcid()
3372 - BUG/MINOR: ssl: Remove empty lines from "show ssl ocsp-response <id>" output
3373 - CLEANUP: ssl: Remove unused ssl_sock_create_cert function
3374 - MINOR: ssl: Use high level OpenSSL APIs in sha2 converter
3375 - MINOR: ssl: Remove EC_KEY related calls when preparing SSL context
3376 - REGTESTS: ssl: Add test for "curves" and "ecdhe" SSL options
3377 - MINOR: ssl: Remove EC_KEY related calls when creating a certificate
3378 - REGTESTS: ssl: Add test for "generate-certificates" SSL option
3379 - MINOR: ssl: Remove call to SSL_CTX_set_tlsext_ticket_key_cb with OpenSSLv3
3380 - MINOR: ssl: Remove call to HMAC_Init_ex with OpenSSLv3
3381 - MINOR: h3: hardcode the stream id of control stream
3382 - MINOR: mux-quic: remove quic_transport_params_update
3383 - MINOR: quic: rename local tid variable
3384 - MINOR: quic: remove unused xprt rcv_buf operation
3385 - MINOR: quic: take out xprt snd_buf operation
3386 - CI: enable QUIC for Coverity scan
3387 - BUG/MINOR: mworker: does not erase the pidfile upon reload
3388 - MINOR: ssl: Remove call to ERR_func_error_string with OpenSSLv3
3389 - MINOR: ssl: Remove call to ERR_load_SSL_strings with OpenSSLv3
3390 - REGTESTS: ssl: Add tests for DH related options
3391 - MINOR: ssl: Create HASSL_DH wrapper structure
3392 - MINOR: ssl: Add ssl_sock_get_dh_from_bio helper function
3393 - MINOR: ssl: Factorize ssl_get_tmp_dh and append a cbk to its name
3394 - MINOR: ssl: Add ssl_sock_set_tmp_dh helper function
3395 - MINOR: ssl: Add ssl_sock_set_tmp_dh_from_pkey helper function
3396 - MINOR: ssl: Add ssl_new_dh_fromdata helper function
3397 - MINOR: ssl: Build local DH of right size when needed
3398 - MINOR: ssl: Set default dh size to 2048
3399 - MEDIUM: ssl: Replace all DH objects by EVP_PKEY on OpenSSLv3 (via HASSL_DH type)
3400 - MINOR: ssl: Remove calls to SSL_CTX_set_tmp_dh_callback on OpenSSLv3
3401 - MINOR: quic: Remove an RX buffer useless lock
3402 - MINOR: quic: Variable used before being checked in ha_quic_add_handshake_data()
3403 - MINOR: quic: EINTR error ignored
3404 - MINOR: quic: Potential overflow expression in qc_parse_frm()
3405 - MINOR: quic: Possible overflow in qpack_get_varint()
3406 - CLEANUP: h3: Unreachable target in h3_uqs_init()
3407 - MINOR: quic: Possible memleak in qc_new_conn()
3408 - MINOR: quic: Useless statement in quic_crypto_data_cpy()
3409 - BUG/MEDIUM: pools: ensure items are always large enough for the pool_cache_item
3410 - BUG/MINOR: pools: always flush pools about to be destroyed
3411 - CLEANUP: pools: don't needlessly set a call mark during refilling of caches
3412 - DEBUG: pools: add extra sanity checks when picking objects from a local cache
3413 - DEBUG: pools: let's add reverse mapping from cache heads to thread and pool
3414 - DEBUG: pools: replace the link pointer with the caller's address on pool_free()
3415 - BUG/MAJOR: sched: prevent rare concurrent wakeup of multi-threaded tasks
3416 - MINOR: quic: use a global dghlrs for each thread
3417 - BUG/MEDIUM: quic: fix crash on CC if mux not present
3418 - MINOR: qpack: fix typo in trace
3419 - BUG/MINOR: quic: fix FIN stream signaling
3420 - BUG/MINOR: h3: fix the header length for QPACK decoding
3421 - MINOR: h3: remove transfer-encoding header
3422 - MINOR: h3: add documentation on h3_decode_qcs
3423 - MINOR: h3: set properly HTX EOM/BODYLESS on HEADERS parsing
3424 - MINOR: mux-quic: implement rcv_buf
3425 - MINOR: mux-quic: set EOS on rcv_buf
3426 - MINOR: h3: set CS_FL_NOT_FIRST
3427 - MINOR: h3: report frames bigger than rx buffer
3428 - MINOR: h3: extract HEADERS parsing in a dedicated function
3429 - MINOR: h3: implement DATA parsing
3430 - MINOR: quic: Wrong smoothed rtt initialization
3431 - MINOR: quic: Wrong loss delay computation
3432 - MINOR: quic: Code never reached in qc_ssl_sess_init()
3433 - MINOR: quic: ha_quic_set_encryption_secrets without server specific code
3434 - MINOR: quic: Avoid warning about NULL pointer dereferences
3435 - MINOR: quic: Useless test in quic_lstnr_dghdlr()
3436 - MINOR: quic: Non checked returned value for cs_new() in hq_interop_decode_qcs()
3437 - MINOR: h3: Dead code in h3_uqs_init()
3438 - MINOR: quic: Non checked returned value for cs_new() in h3_decode_qcs()
3439 - MINOR: quic: Possible frame parsers array overrun
3440 - MINOR: quic: Do not retransmit too much packets.
3441 - MINOR: quic: Move quic_rxbuf_pool pool out of xprt part
3442 - MINOR: h3: report error on HEADERS/DATA parsing
3443 - BUG/MINOR: jwt: Double free in deinit function
3444 - BUG/MINOR: jwt: Missing pkey free during cleanup
3445 - BUG/MINOR: jwt: Memory leak if same key is used in multiple jwt_verify calls
3446 - BUG/MINOR: httpclient/cli: display junk characters in vsn
3447 - MINOR: h3: remove unused return value on decode_qcs
3448 - BUG/MAJOR: http/htx: prevent unbounded loop in http_manage_server_side_cookies
3449 - BUG/MAJOR: spoe: properly detach all agents when releasing the applet
3450 - REGTESTS: server: close an occasional race on dynamic_server_ssl.vtc
3451 - REGTESTS: peers: leave a bit more time to peers to synchronize
3452 - BUG/MEDIUM: h2/hpack: fix emission of HPACK DTSU after settings change
3453 - BUG/MINOR: mux-h2: update the session's idle delay before creating the stream
3454 - BUG/MINOR: httpclient: reinit flags in httpclient_start()
3455 - BUG/MINOR: mailers: negotiate SMTP, not ESMTP
3456 - MINOR: httpclient: sets an alternative destination
3457 - MINOR: httpclient/lua: add 'dst' optionnal field
3458 - BUG/MINOR: ssl: Add missing return value check in ssl_ocsp_response_print
3459 - BUG/MINOR: ssl: Fix leak in "show ssl ocsp-response" CLI command
3460 - BUG/MINOR: ssl: Missing return value check in ssl_ocsp_response_print
3461 - CLEANUP: httpclient/cli: fix indentation alignment of the help message
3462 - BUG/MINOR: tools: url2sa reads ipv4 too far
3463 - BUG/MEDIUM: httpclient: limit transfers to the maximum available room
3464 - DEBUG: buffer: check in __b_put_blk() whether the buffer room is respected
3465 - MINOR: mux-quic: fix a possible null dereference in qc_timeout_task
3466 - BUG/MEDIUM: htx: Be sure to have a buffer to perform a raw copy of a message
3467 - BUG/MEDIUM: mux-h1: Don't wake h1s if mux is blocked on lack of output buffer
3468 - BUG/MAJOR: mux-h2: Be sure to always report HTX parsing error to the app layer
3469 - DEBUG: stream-int: Check CS_FL_WANT_ROOM is not set with an empty input buffer
3470 - MINOR: quic: do not modify offset node if quic_rx_strm_frm in tree
3471 - MINOR: h3: fix compiler warning variable set but not used
3472 - MINOR: mux-quic: fix uninitialized return on qc_send
3473 - MINOR: quic: fix handling of out-of-order received STREAM frames
3474 - MINOR: pools: mark most static pool configuration variables as read-mostly
3475 - CLEANUP: pools: remove the now unused pool_is_crowded()
3476 - REGTESTS: fix the race conditions in 40be_2srv_odd_health_checks
3477 - BUG/MEDIUM: stream: Abort processing if response buffer allocation fails
3478 - MINOR: httpclient/lua: ability to set a server timeout
3479 - BUG/MINOR: httpclient/lua: missing pop for new timeout parameter
3480 - DOC: httpclient/lua: fix the type of the dst parameter
3481 - CLEANUP: httpclient: initialize the client in stage INIT not REGISTER
3482 - CLEANUP: muxes: do not use a dynamic trash in list_mux_protos()
3483 - CLEANUP: vars: move the per-process variables initialization to vars.c
3484 - CLEANUP: init: remove the ifdef on HAPROXY_MEMMAX
3485 - MINOR: pools: disable redundant poisonning on pool_free()
3486 - MINOR: pools: introduce a new pool_debugging global variable
3487 - MINOR: pools: switch the fail-alloc test to runtime only
3488 - MINOR: pools: switch DEBUG_DONT_SHARE_POOLS to runtime
3489 - MINOR: pools: add a new debugging flag POOL_DBG_COLD_FIRST
3490 - MINOR: pools: add a new debugging flag POOL_DBG_INTEGRITY
3491 - MINOR: pools: make the global pools a runtime option.
3492 - MEDIUM: pools: replace CONFIG_HAP_POOLS with a runtime "NO_CACHE" flag.
3493 - MINOR: pools: store the allocated size for each pool
3494 - MINOR: pools: get rid of POOL_EXTRA
3495 - MINOR: pools: replace DEBUG_POOL_TRACING with runtime POOL_DBG_CALLER
3496 - MINOR: pools: replace DEBUG_MEMORY_POOLS with runtime POOL_DBG_TAG
3497 - MINOR: pools: add a debugging flag for memory poisonning option
3498 - MEDIUM: initcall: move STG_REGISTER earlier
3499 - MEDIUM: init: split the early initialization in its own function
3500 - MINOR: init: extract args parsing to their own function
3501 - MEDIUM: init: handle arguments earlier
3502 - MINOR: pools: delegate parsing of command line option -dM to a new function
3503 - MINOR: pools: support setting debugging options using -dM
3504 - BUILD: makefile: enable both DEBUG_STRICT and DEBUG_MEMORY_POOLS by default
3505 - CI: github: enable pool debugging by default
3506 - DOC: Fix usage/examples of deprecated ACLs
3507 - DOC: internal: update the pools API to mention boot-time settings
3508 - DOC: design: add design thoughts for later simplification of the pools
3509 - DOC: design: commit the temporary design notes on thread groups
3510 - MINOR: stream-int: Handle appctx case first when releasing the endpoint
3511 - MINOR: connection: Be prepared to handle conn-stream with no connection
3512 - MINOR: stream: Handle appctx case first when creating a new stream
3513 - MINOR: connection: Add a function to detach a conn-stream from the connection
3514 - MINOR: stream-int: Add function to reset a SI endpoint
3515 - MINOR: stream-int: Add function to attach a connection to a SI
3516 - MINOR: stream-int: Be able to allocate a CS without connection
3517 - MEDIUM: stream: No longer release backend conn-stream on connection retry
3518 - MEDIUM: stream: Allocate backend CS when the stream is created
3519 - REORG: conn_stream: move conn-stream stuff in dedicated files
3520 - MEDIUM: conn-stream: No longer access connection field directly
3521 - MEDIUM: conn-stream: Be prepared to use an appctx as conn-stream endpoint
3522 - MAJOR: conn_stream/stream-int: move the appctx to the conn-stream
3523 - MEDIUM: applet: Set the conn-stream as appctx owner instead of the stream-int
3524 - MEDIUM: conn_stream: Add a pointer to the app object into the conn-stream
3525 - MINOR: stream: Add pointer to front/back conn-streams into stream struct
3526 - MINOR: stream: Slightly rework stream_new to separate CS/SI initialization
3527 - MINOR: stream-int: Always access the stream-int via the conn-stream
3528 - MINOR: backend: Always access the stream-int via the conn-stream
3529 - MINOR: stream: Always access the stream-int via the conn-stream
3530 - MINOR: http-ana: Always access the stream-int via the conn-stream
3531 - MINOR: cli: Always access the stream-int via the conn-stream
3532 - MINOR: log: Always access the stream-int via the conn-stream
3533 - MINOR: frontend: Always access the stream-int via the conn-stream
3534 - MINOR: proxy: Always access the stream-int via the conn-stream
3535 - MINOR: peers: Always access the stream-int via the conn-stream
3536 - MINOR: debug: Always access the stream-int via the conn-stream
3537 - MINOR: hlua: Always access the stream-int via the conn-stream
3538 - MINOR: cache: Always access the stream-int via the conn-stream
3539 - MINOR: dns: Always access the stream-int via the conn-stream
3540 - MINOR: http-act: Always access the stream-int via the conn-stream
3541 - MINOR: httpclient: Always access the stream-int via the conn-stream
3542 - MINOR: tcp-act: Always access the stream-int via the conn-stream
3543 - MINOR: sink: Always access the stream-int via the conn-stream
3544 - MINOR: conn-stream: Rename cs_detach() to cs_detach_endp()
3545 - CLEANUP: conn-stream: Don't export conn-stream pool
3546 - MAJOR: stream/conn_stream: Move the stream-interface into the conn-stream
3547 - CLEANUP: stream-int: rename si_reset() to si_init()
3548 - MINOR: conn-stream: Release a CS when both app and endp are detached
3549 - MINOR: stream: Don't destroy conn-streams but detach app and endp
3550 - MAJOR: check: Use a persistent conn-stream for health-checks
3551 - CLEANUP: conn-stream: Remove cs_destroy()
3552 - CLEANUP: backend: Don't export connect_server anymore
3553 - BUG/MINOR: h3/hq_interop: Fix CS and stream creation
3554 - BUILD: tree-wide: Avoid warnings about undefined entities retrieved from a CS
3555 - BUG/MINOR: proxy: preset the error message pointer to NULL in parse_new_proxy()
3556 - BUG/MEDIUM: quic: fix received ACK stream calculation
3557 - BUILD: stream: fix build warning with older compilers
3558 - BUG/MINOR: debug: fix get_tainted() to properly read an atomic value
3559 - DEBUG: move the tainted stuff to bug.h for easier inclusion
3560 - DEBUG: cleanup back trace generation
3561 - DEBUG: cleanup BUG_ON() configuration
3562 - DEBUG: mark ABORT_NOW() as unreachable
3563 - DBEUG: add a new WARN_ON() macro
3564 - DEBUG: make the _BUG_ON() macro return the condition
3565 - DEBUG: add a new WARN_ON_ONCE() macro
3566 - DEBUG: report BUG_ON() and WARN_ON() in the tainted flags
3567 - MINOR: quic: adjust buffer handling for STREAM transmission
3568 - MINOR: quic: liberate the TX stream buffer after ACK processing
3569 - MINOR: quic: add a TODO for a memleak frame on ACK consume
3570
Willy Tarreau2454d6e2022-02-01 18:06:59 +010035712022/02/01 : 2.6-dev1
3572 - BUG/MINOR: cache: Fix loop on cache entries in "show cache"
3573 - BUG/MINOR: httpclient: allow to replace the host header
3574 - BUG/MINOR: lua: don't expose internal proxies
3575 - MEDIUM: mworker: seamless reload use the internal sockpairs
3576 - BUG/MINOR: lua: remove loop initial declarations
3577 - BUG/MINOR: mworker: does not add the -sf in wait mode
3578 - BUG/MEDIUM: mworker: FD leak of the eventpoll in wait mode
3579 - MINOR: quic: do not reject PADDING followed by other frames
3580 - REORG: quic: add comment on rare thread concurrence during CID alloc
3581 - CLEANUP: quic: add comments on CID code
3582 - MEDIUM: quic: handle CIDs to rattach received packets to connection
3583 - MINOR: qpack: support litteral field line with non-huff name
3584 - MINOR: quic: activate QUIC traces at compilation
3585 - MINOR: quic: use more verbose QUIC traces set at compile-time
3586 - MEDIUM: pool: refactor malloc_trim/glibc and jemalloc api addition detections.
3587 - MEDIUM: pool: support purging jemalloc arenas in trim_all_pools()
3588 - BUG/MINOR: mworker: deinit of thread poller was called when not initialized
3589 - BUILD: pools: only detect link-time jemalloc on ELF platforms
3590 - CI: github actions: add the output of $CC -dM -E-
3591 - BUG/MEDIUM: cli: Properly set stream analyzers to process one command at a time
3592 - BUILD: evports: remove a leftover from the dead_fd cleanup
3593 - MINOR: quic: Set "no_application_protocol" alert
3594 - MINOR: quic: More accurate immediately close.
3595 - MINOR: quic: Immediately close if no transport parameters extension found
3596 - MINOR: quic: Rename qc_prep_hdshk_pkts() to qc_prep_pkts()
3597 - MINOR: quic: Possible crash when inspecting the xprt context
3598 - MINOR: quic: Dynamically allocate the secrete keys
3599 - MINOR: quic: Add a function to derive the key update secrets
3600 - MINOR: quic: Add structures to maintain key phase information
3601 - MINOR: quic: Optional header protection key for quic_tls_derive_keys()
3602 - MINOR: quic: Add quic_tls_key_update() function for Key Update
3603 - MINOR: quic: Enable the Key Update process
3604 - MINOR: quic: Delete the ODCIDs asap
3605 - BUG/MINOR: vars: Fix the set-var and unset-var converters
3606 - MEDIUM: pool: Following up on previous pool trimming update.
3607 - BUG/MEDIUM: mux-h1: Fix splicing by properly detecting end of message
3608 - BUG/MINOR: mux-h1: Fix splicing for messages with unknown length
3609 - MINOR: mux-h1: Improve H1 traces by adding info about http parsers
3610 - MINOR: mux-h1: register a stats module
3611 - MINOR: mux-h1: add counters instance to h1c
3612 - MINOR: mux-h1: count open connections/streams on stats
3613 - MINOR: mux-h1: add stat for total count of connections/streams
3614 - MINOR: mux-h1: add stat for total amount of bytes received and sent
3615 - REGTESTS: h1: Add a script to validate H1 splicing support
3616 - BUG/MINOR: server: Don't rely on last default-server to init server SSL context
3617 - BUG/MEDIUM: resolvers: Detach query item on response error
3618 - MEDIUM: resolvers: No longer store query items in a list into the response
3619 - BUG/MAJOR: segfault using multiple log forward sections.
3620 - BUG/MEDIUM: h1: Properly reset h1m flags when headers parsing is restarted
3621 - BUG/MINOR: resolvers: Don't overwrite the error for invalid query domain name
3622 - BUILD: bug: Fix error when compiling with -DDEBUG_STRICT_NOCRASH
3623 - BUG/MEDIUM: sample: Fix memory leak in sample_conv_jwt_member_query
3624 - DOC: spoe: Clarify use of the event directive in spoe-message section
3625 - DOC: config: Specify %Ta is only available in HTTP mode
3626 - BUILD: tree-wide: avoid warnings caused by redundant checks of obj_types
3627 - IMPORT: slz: use the correct CRC32 instruction when running in 32-bit mode
3628 - MINOR: quic: fix segfault on CONNECTION_CLOSE parsing
3629 - MINOR: h3: add BUG_ON on control receive function
3630 - MEDIUM: xprt-quic: finalize app layer initialization after ALPN nego
3631 - MINOR: h3: remove duplicated FIN flag position
3632 - MAJOR: mux-quic: implement a simplified mux version
3633 - MEDIUM: mux-quic: implement release mux operation
3634 - MEDIUM: quic: detect the stream FIN
3635 - MINOR: mux-quic: implement subscribe on stream
3636 - MEDIUM: mux-quic: subscribe on xprt if remaining data after send
3637 - MEDIUM: mux-quic: wake up xprt on data transferred
3638 - MEDIUM: mux-quic: handle when sending buffer is full
3639 - MINOR: quic: RX buffer full due to wrong CRYPTO data handling
3640 - MINOR: quic: Race issue when consuming RX packets buffer
3641 - MINOR: quic: QUIC encryption level RX packets race issue
3642 - MINOR: quic: Delete remaining RX handshake packets
3643 - MINOR: quic: Remove QUIC TX packet length evaluation function
3644 - MINOR: hq-interop: fix tx buffering
3645 - MINOR: mux-quic: remove uneeded code to check fin on TX
3646 - MINOR: quic: add HTX EOM on request end
3647 - BUILD: mux-quic: fix compilation with DEBUG_MEM_STATS
3648 - MINOR: http-rules: Add capture action to http-after-response ruleset
3649 - BUG/MINOR: cli/server: Don't crash when a server is added with a custom id
3650 - MINOR: mux-quic: do not release qcs if there is remaining data to send
3651 - MINOR: quic: notify the mux on CONNECTION_CLOSE
3652 - BUG/MINOR: mux-quic: properly initialize flow control
3653 - MINOR: quic: Compilation fix for quic_rx_packet_refinc()
3654 - MINOR: h3: fix possible invalid dereference on htx parsing
3655 - DOC: config: retry-on list is space-delimited
3656 - DOC: config: fix error-log-format example
3657 - BUG/MEDIUM: mworker/cli: crash when trying to access an old PID in prompt mode
3658 - MINOR: hq-interop: refix tx buffering
3659 - REGTESTS: ssl: use X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY for cert check
3660 - MINOR: cli: "show version" displays the current process version
3661 - CLEANUP: cfgparse: modify preprocessor guards around numa detection code
3662 - MEDIUM: cfgparse: numa detect topology on FreeBSD.
3663 - BUILD: ssl: unbreak the build with newer libressl
3664 - MINOR: vars: Move UPDATEONLY flag test to vars_set_ifexist
3665 - MINOR: vars: Set variable type to ANY upon creation
3666 - MINOR: vars: Delay variable content freeing in var_set function
3667 - MINOR: vars: Parse optional conditions passed to the set-var converter
3668 - MINOR: vars: Parse optional conditions passed to the set-var actions
3669 - MEDIUM: vars: Enable optional conditions to set-var converter and actions
3670 - DOC: vars: Add documentation about the set-var conditions
3671 - REGTESTS: vars: Add new test for conditional set-var
3672 - MINOR: quic: Attach timer task to thread for the connection.
3673 - CLEANUP: quic_frame: Remove a useless suffix to STOP_SENDING
3674 - MINOR: quic: Add traces for STOP_SENDING frame and modify others
3675 - CLEANUP: quic: Remove cdata_len from quic_tx_packet struct
3676 - MINOR: quic: Enable TLS 0-RTT if needed
3677 - MINOR: quic: No TX secret at EARLY_DATA encryption level
3678 - MINOR: quic: Add quic_set_app_ops() function
3679 - MINOR: ssl_sock: Set the QUIC application from ssl_sock_advertise_alpn_protos.
3680 - MINOR: quic: Make xprt support 0-RTT.
3681 - MINOR: qpack: Missing check for truncated QPACK fields
3682 - CLEANUP: quic: Comment fix for qc_strm_cpy()
3683 - MINOR: hq_interop: Stop BUG_ON() truncated streams
3684 - MINOR: quic: Do not mix packet number space and connection flags
3685 - CLEANUP: quic: Shorten a litte bit the traces in lstnr_rcv_pkt()
3686 - MINOR: mux-quic: fix trace on stream creation
3687 - CLEANUP: quic: fix spelling mistake in a trace
3688 - CLEANUP: quic: rename quic_conn conn to qc in quic_conn_free
3689 - MINOR: quic: add missing lock on cid tree
3690 - MINOR: quic: rename constant for haproxy CIDs length
3691 - MINOR: quic: refactor concat DCID with address for Initial packets
3692 - MINOR: quic: compare coalesced packets by DCID
3693 - MINOR: quic: refactor DCID lookup
3694 - MINOR: quic: simplify the removal from ODCID tree
3695 - REGTESTS: vars: Remove useless ssl tunes from conditional set-var test
3696 - MINOR: ssl: Remove empty lines from "show ssl ocsp-response" output
3697 - MINOR: quic: Increase the RX buffer for each connection
3698 - MINOR: quic: Add a function to list remaining RX packets by encryption level
3699 - MINOR: quic: Stop emptying the RX buffer asap.
3700 - MINOR: quic: Do not expect to receive only one O-RTT packet
3701 - MINOR: quic: Do not forget STREAM frames received in disorder
3702 - MINOR: quic: Wrong packet refcount handling in qc_pkt_insert()
3703 - DOC: fix misspelled keyword "resolve_retries" in resolvers
3704 - CLEANUP: quic: rename quic_conn instances to qc
3705 - REORG: quic: move mux function outside of xprt
3706 - MINOR: quic: add reference to quic_conn in ssl context
3707 - MINOR: quic: add const qualifier for traces function
3708 - MINOR: trace: add quic_conn argument definition
3709 - MINOR: quic: use quic_conn as argument to traces
3710 - MINOR: quic: add quic_conn instance in traces for qc_new_conn
3711 - MINOR: quic: Add stream IDs to qcs_push_frame() traces
3712 - MINOR: quic: unchecked qc_retrieve_conn_from_cid() returned value
3713 - MINOR: quic: Wrong dropped packet skipping
3714 - MINOR: quic: Handle the cases of overlapping STREAM frames
3715 - MINOR: quic: xprt traces fixes
3716 - MINOR: quic: Drop asap Retry or Version Negotiation packets
3717 - MINOR: pools: work around possibly slow malloc_trim() during gc
3718 - DEBUG: ssl: make sure we never change a servername on established connections
3719 - MINOR: quic: Add traces for RX frames (flow control related)
3720 - MINOR: quic: Add CONNECTION_CLOSE phrase to trace
3721 - REORG: quic: remove qc_ prefix on functions which not used it directly
3722 - BUG/MINOR: quic: upgrade rdlock to wrlock for ODCID removal
3723 - MINOR: quic: remove unnecessary call to free_quic_conn_cids()
3724 - MINOR: quic: store ssl_sock_ctx reference into quic_conn
3725 - MINOR: quic: remove unnecessary if in qc_pkt_may_rm_hp()
3726 - MINOR: quic: replace usage of ssl_sock_ctx by quic_conn
3727 - MINOR: quic: delete timer task on quic_close()
3728 - MEDIUM: quic: implement refcount for quic_conn
3729 - BUG/MINOR: quic: fix potential null dereference
3730 - BUG/MINOR: quic: fix potential use of uninit pointer
3731 - BUG/MEDIUM: backend: fix possible sockaddr leak on redispatch
3732 - BUG/MEDIUM: peers: properly skip conn_cur from incoming messages
3733 - CI: Github Actions: do not show VTest failures if build failed
3734 - BUILD: opentracing: display warning in case of using OT_USE_VARS at compile time
3735 - MINOR: compat: detect support for dl_iterate_phdr()
3736 - MINOR: debug: add ability to dump loaded shared libraries
3737 - MINOR: debug: add support for -dL to dump library names at boot
3738 - BUG/MEDIUM: ssl: initialize correctly ssl w/ default-server
3739 - REGTESTS: ssl: fix ssl_default_server.vtc
3740 - BUG/MINOR: ssl: free the fields in srv->ssl_ctx
3741 - BUG/MEDIUM: ssl: free the ckch instance linked to a server
3742 - REGTESTS: ssl: update of a crt with server deletion
3743 - BUILD/MINOR: cpuset FreeBSD 14 build fix.
3744 - MINOR: pools: always evict oldest objects first in pool_evict_from_local_cache()
3745 - DOC: pool: document the purpose of various structures in the code
3746 - CLEANUP: pools: do not use the extra pointer to link shared elements
3747 - CLEANUP: pools: get rid of the POOL_LINK macro
3748 - MINOR: pool: allocate from the shared cache through the local caches
3749 - CLEANUP: pools: group list updates in pool_get_from_cache()
3750 - MINOR: pool: rely on pool_free_nocache() in pool_put_to_shared_cache()
3751 - MINOR: pool: make pool_is_crowded() always true when no shared pools are used
3752 - MINOR: pool: check for pool's fullness outside of pool_put_to_shared_cache()
3753 - MINOR: pool: introduce pool_item to represent shared pool items
3754 - MINOR: pool: add a function to estimate how many may be released at once
3755 - MEDIUM: pool: compute the number of evictable entries once per pool
3756 - MINOR: pools: prepare pool_item to support chained clusters
3757 - MINOR: pools: pass the objects count to pool_put_to_shared_cache()
3758 - MEDIUM: pools: centralize cache eviction in a common function
3759 - MEDIUM: pools: start to batch eviction from local caches
3760 - MEDIUM: pools: release cached objects in batches
3761 - OPTIM: pools: reduce local pool cache size to 512kB
3762 - CLEANUP: assorted typo fixes in the code and comments This is 29th iteration of typo fixes
3763 - CI: github actions: update OpenSSL to 3.0.1
3764 - BUILD/MINOR: tools: solaris build fix on dladdr.
3765 - BUG/MINOR: cli: fix _getsocks with musl libc
3766 - BUG/MEDIUM: http-ana: Preserve response's FLT_END analyser on L7 retry
3767 - MINOR: quic: Wrong traces after rework
3768 - MINOR: quic: Add trace about in flight bytes by packet number space
3769 - MINOR: quic: Wrong first packet number space computation
3770 - MINOR: quic: Wrong packet number space computation for PTO
3771 - MINOR: quic: Wrong loss time computation in qc_packet_loss_lookup()
3772 - MINOR: quic: Wrong ack_delay compution before calling quic_loss_srtt_update()
3773 - MINOR: quic: Remove nb_pto_dgrams quic_conn struct member
3774 - MINOR: quic: Wrong packet number space trace in qc_prep_pkts()
3775 - MINOR: quic: Useless test in qc_prep_pkts()
3776 - MINOR: quic: qc_prep_pkts() code moving
3777 - MINOR: quic: Speeding up Handshake Completion
3778 - MINOR: quic: Probe Initial packet number space more often
3779 - MINOR: quic: Probe several packet number space upon timer expiration
3780 - MINOR: quic: Comment fix.
3781 - MINOR: quic: Improve qc_prep_pkts() flexibility
3782 - MINOR: quic: Do not drop secret key but drop the CRYPTO data
3783 - MINOR: quic: Prepare Handshake packets asap after completed handshake
3784 - MINOR: quic: Flag asap the connection having reached the anti-amplification limit
3785 - MINOR: quic: PTO timer too often reset
3786 - MINOR: quic: Re-arm the PTO timer upon datagram receipt
3787 - MINOR: proxy: add option idle-close-on-response
3788 - MINOR: cpuset: switch to sched_setaffinity for FreeBSD 14 and above.
3789 - CI: refactor spelling check
3790 - CLEANUP: assorted typo fixes in the code and comments
3791 - BUILD: makefile: add -Wno-atomic-alignment to work around clang abusive warning
3792 - MINOR: quic: Only one CRYPTO frame by encryption level
3793 - MINOR: quic: Missing retransmission from qc_prep_fast_retrans()
3794 - MINOR: quic: Non-optimal use of a TX buffer
3795 - BUG/MEDIUM: mworker: don't use _getsocks in wait mode
3796 - BUG/MINOR: ssl: Store client SNI in SSL context in case of ClientHello error
3797 - BUG/MAJOR: mux-h1: Don't decrement .curr_len for unsent data
3798 - DOC: internals: document the pools architecture and API
3799 - CI: github actions: clean default step conditions
3800 - BUILD: cpuset: fix build issue on macos introduced by previous change
3801 - MINOR: quic: Remaining TRACEs with connection as firt arg
3802 - MINOR: quic: Reset ->conn quic_conn struct member when calling qc_release()
3803 - MINOR: quic: Flag the connection as being attached to a listener
3804 - MINOR: quic: Wrong CRYPTO frame concatenation
3805 - MINOR: quid: Add traces quic_close() and quic_conn_io_cb()
3806 - REGTESTS: ssl: Fix ssl_errors regtest with OpenSSL 1.0.2
3807 - MINOR: quic: Do not dereference ->conn quic_conn struct member
3808 - MINOR: quic: fix return of quic_dgram_read
3809 - MINOR: quic: add config parse source file
3810 - MINOR: quic: implement Retry TLS AEAD tag generation
3811 - MEDIUM: quic: implement Initial token parsing
3812 - MINOR: quic: define retry_source_connection_id TP
3813 - MEDIUM: quic: implement Retry emission
3814 - MINOR: quic: free xprt tasklet on its thread
3815 - BUG/MEDIUM: connection: properly leave stopping list on error
3816 - MINOR: pools: enable pools with DEBUG_FAIL_ALLOC as well
3817 - MINOR: quic: As server, skip 0-RTT packet number space
3818 - MINOR: quic: Do not wakeup the I/O handler before the mux is started
3819 - BUG/MEDIUM: htx: Adjust length to add DATA block in an empty HTX buffer
3820 - CI: github actions: use cache for OpenTracing
3821 - BUG/MINOR: httpclient: don't send an empty body
3822 - BUG/MINOR: httpclient: set default Accept and User-Agent headers
3823 - BUG/MINOR: httpclient/lua: don't pop the lua stack when getting headers
3824 - BUILD/MINOR: fix solaris build with clang.
3825 - BUG/MEDIUM: server: avoid changing healthcheck ctx with set server ssl
3826 - CI: refactor OpenTracing build script
3827 - DOC: management: mark "set server ssl" as deprecated
3828 - MEDIUM: cli: yield between each pipelined command
3829 - MINOR: channel: add new function co_getdelim() to support multiple delimiters
3830 - BUG/MINOR: cli: avoid O(bufsize) parsing cost on pipelined commands
3831 - MEDIUM: h2/hpack: emit a Dynamic Table Size Update after settings change
3832 - MINOR: quic: Retransmit the TX frames in the same order
3833 - MINOR: quic: Remove the packet number space TX MT_LIST
3834 - MINOR: quic: Splice the frames which could not be added to packets
3835 - MINOR: quic: Add the number of TX bytes to traces
3836 - CLEANUP: quic: Replace <nb_pto_dgrams> by <probe>
3837 - MINOR: quic: Send two ack-eliciting packets when probing packet number spaces
3838 - MINOR: quic: Probe regardless of the congestion control
3839 - MINOR: quic: Speeding up handshake completion
3840 - MINOR: quic: Release RX Initial packets asap
3841 - MINOR: quic: Release asap TX frames to be transmitted
3842 - MINOR: quic: Probe even if coalescing
3843 - BUG/MEDIUM: cli: Never wait for more data on client shutdown
3844 - BUG/MEDIUM: mcli: do not try to parse empty buffers
3845 - BUG/MEDIUM: mcli: always realign wrapping buffers before parsing them
3846 - BUG/MINOR: stream: make the call_rate only count the no-progress calls
3847 - MINOR: quic: do not use quic_conn after dropping it
3848 - MINOR: quic: adjust quic_conn refcount decrement
3849 - MINOR: quic: fix race-condition on xprt tasklet free
3850 - MINOR: quic: free SSL context on quic_conn free
3851 - MINOR: quic: Add QUIC_FT_RETIRE_CONNECTION_ID parsing case
3852 - MINOR: quic: Wrong packet number space selection
3853 - DEBUG: pools: add new build option DEBUG_POOL_INTEGRITY
3854 - MINOR: quic: add missing include in quic_sock
3855 - MINOR: quic: fix indentation in qc_send_ppkts
3856 - MINOR: quic: remove dereferencement of connection when possible
3857 - MINOR: quic: set listener accept cb on parsing
3858 - MEDIUM: quic/ssl: add new ex data for quic_conn
3859 - MINOR: quic: initialize ssl_sock_ctx alongside the quic_conn
3860 - MINOR: ssl: fix build in release mode
3861 - MINOR: pools: partially uninline pool_free()
3862 - MINOR: pools: partially uninline pool_alloc()
3863 - MINOR: pools: prepare POOL_EXTRA to be split into multiple extra fields
3864 - MINOR: pools: extend pool_cache API to pass a pointer to a caller
3865 - DEBUG: pools: add new build option DEBUG_POOL_TRACING
3866 - DEBUG: cli: add a new "debug dev fd" expert command
3867 - MINOR: fd: register the write side of the poller pipe as well
3868 - CI: github actions: use cache for SSL libs
3869 - BUILD: debug/cli: condition test of O_ASYNC to its existence
3870 - BUILD: pools: fix build error on DEBUG_POOL_TRACING
3871 - MINOR: quic: refactor header protection removal
3872 - MINOR: quic: handle app data according to mux/connection layer status
3873 - MINOR: quic: refactor app-ops initialization
3874 - MINOR: receiver: define a flag for local accept
3875 - MEDIUM: quic: flag listener for local accept
3876 - MINOR: quic: do not manage connection in xprt snd_buf
3877 - MINOR: quic: remove wait handshake/L6 flags on init connection
3878 - MINOR: listener: add flags field
3879 - MINOR: quic: define QUIC flag on listener
3880 - MINOR: quic: create accept queue for QUIC connections
3881 - MINOR: listener: define per-thr struct
3882 - MAJOR: quic: implement accept queue
3883 - CLEANUP: mworker: simplify mworker_free_child()
3884 - BUILD/DEBUG: lru: update the standalone code to support the revision
3885 - DEBUG: lru: use a xorshift generator in the testing code
3886 - BUG/MAJOR: compiler: relax alignment constraints on certain structures
3887 - BUG/MEDIUM: fd: always align fdtab[] to 64 bytes
3888 - MINOR: quic: No DCID length for datagram context
3889 - MINOR: quic: Comment fix about the token found in Initial packets
3890 - MINOR: quic: Get rid of a struct buffer in quic_lstnr_dgram_read()
3891 - MINOR: quic: Remove the QUIC haproxy server packet parser
3892 - MINOR: quic: Add new defintion about DCIDs offsets
3893 - MINOR: quic: Add a list to QUIC sock I/O handler RX buffer
3894 - MINOR: quic: Allocate QUIC datagrams from sock I/O handler
3895 - MINOR: proto_quic: Allocate datagram handlers
3896 - MINOR: quic: Pass CID as a buffer to quic_get_cid_tid()
3897 - MINOR: quic: Convert quic_dgram_read() into a task
3898 - CLEANUP: quic: Remove useless definition
3899 - MINOR: proto_quic: Wrong allocations for TX rings and RX bufs
3900 - MINOR: quic: Do not consume the RX buffer on QUIC sock i/o handler side
3901 - MINOR: quic: Do not reset a full RX buffer
3902 - MINOR: quic: Attach all the CIDs to the same connection
3903 - MINOR: quic: Make usage of by datagram handler trees
3904 - MEDIUM: da: new optional data file download scheduler service.
3905 - MEDIUM: da: update doc and build for new scheduler mode service.
3906 - MEDIUM: da: update module to handle schedule mode.
3907 - MINOR: quic: Drop Initial packets with wrong ODCID
3908 - MINOR: quic: Wrong RX buffer tail handling when no more contiguous data
3909 - MINOR: quic: Iterate over all received datagrams
3910 - MINOR: quic: refactor quic CID association with threads
3911 - BUG/MEDIUM: resolvers: Really ignore trailing dot in domain names
3912 - DEV: flags: Add missing flags
3913 - BUG/MINOR: sink: Use the right field in appctx context in release callback
3914 - MINOR: sock: move the unused socket cleaning code into its own function
3915 - BUG/MEDIUM: mworker: close unused transferred FDs on load failure
3916 - BUILD: atomic: make the old HA_ATOMIC_LOAD() support const pointers
3917 - BUILD: cpuset: do not use const on the source of CPU_AND/CPU_ASSIGN
3918 - BUILD: checks: fix inlining issue on set_srv_agent_[addr,port}
3919 - BUILD: vars: avoid overlapping field initialization
3920 - BUILD: server-state: avoid using not-so-portable isblank()
3921 - BUILD: mux_fcgi: avoid aliasing of a const struct in traces
3922 - BUILD: tree-wide: mark a few numeric constants as explicitly long long
3923 - BUILD: tools: fix warning about incorrect cast with dladdr1()
3924 - BUILD: task: use list_to_mt_list() instead of casting list to mt_list
3925 - BUILD: mworker: include tools.h for platforms without unsetenv()
3926 - BUG/MINOR: mworker: fix a FD leak of a sockpair upon a failed reload
3927 - MINOR: mworker: set the master side of ipc_fd in the worker to -1
3928 - MINOR: mworker: allocate and initialize a mworker_proc
3929 - CI: Consistently use actions/checkout@v2
3930 - REGTESTS: Remove REQUIRE_VERSION=1.8 from all tests
3931 - MINOR: mworker: sets used or closed worker FDs to -1
3932 - MINOR: quic: Try to accept 0-RTT connections
3933 - MINOR: quic: Do not try to treat 0-RTT packets without started mux
3934 - MINOR: quic: Do not try to accept a connection more than one time
3935 - MINOR: quic: Initialize the connection timer asap
3936 - MINOR: quic: Do not use connection struct xprt_ctx too soon
3937 - Revert "MINOR: mworker: sets used or closed worker FDs to -1"
3938 - BUILD: makefile: avoid testing all -Wno-* options when not needed
3939 - BUILD: makefile: validate support for extra warnings by batches
3940 - BUILD: makefile: only compute alternative options if required
3941 - DEBUG: fd: make sure we never try to insert/delete an impossible FD number
3942 - MINOR: mux-quic: add comment
3943 - MINOR: mux-quic: properly initialize qcc flags
3944 - MINOR: mux-quic: do not consider CONNECTION_CLOSE for the moment
3945 - MINOR: mux-quic: create a timeout task
3946 - MEDIUM: mux-quic: delay the closing with the timeout
3947 - MINOR: mux-quic: release idle conns on process stopping
3948 - MINOR: listener: replace the listener's spinlock with an rwlock
3949 - BUG/MEDIUM: listener: read-lock the listener during accept()
3950 - MINOR: mworker/cli: set expert/experimental mode from the CLI
3951
Willy Tarreau73dec762021-11-23 15:50:11 +010039522021/11/23 : 2.6-dev0
3953 - MINOR: version: it's development again
3954
Willy Tarreauf2e08332021-11-23 15:40:21 +010039552021/11/23 : 2.5.0
3956 - BUILD: SSL: add quictls build to scripts/build-ssl.sh
3957 - BUILD: SSL: add QUICTLS to build matrix
3958 - CLEANUP: sock: Wrap `accept4_broken = 1` into additional parenthesis
3959 - BUILD: cli: clear a maybe-unused warning on some older compilers
3960 - BUG/MEDIUM: cli: make sure we can report a warning from a bind keyword
3961 - BUG/MINOR: ssl: make SSL counters atomic
3962 - CLEANUP: assorted typo fixes in the code and comments
3963 - BUG/MINOR: ssl: free correctly the sni in the backend SSL cache
3964 - MINOR: version: mention that it's stable now
3965
Willy Tarreaua99cdfb2021-11-19 19:30:04 +010039662021/11/19 : 2.5-dev15
3967 - BUG/MINOR: stick-table/cli: Check for invalid ipv6 key
3968 - CLEANUP: peers: Remove useless test on peer variable in peer_trace()
3969 - DOC: log: Add comments to specify when session's listener is defined or not
3970 - BUG/MEDIUM: mux-h1: Handle delayed silent shut in h1_process() to release H1C
3971 - REGTESTS: ssl_crt-list_filters: feature cmd incorrectly set
3972 - DOC: internals: document the list API
3973 - BUG/MINOR: h3: ignore unknown frame types
3974 - MINOR: quic: redirect app_ops snd_buf through mux
3975 - MEDIUM: quic: inspect ALPN to install app_ops
3976 - MINOR: quic: support hq-interop
3977 - MEDIUM: quic: send version negotiation packet on unknown version
3978 - BUG/MEDIUM: mworker: cleanup the listeners when reexecuting
3979 - DOC: internals: document the scheduler API
3980 - BUG/MINOR: quic: fix version negotiation packet generation
3981 - CLEANUP: ssl: fix wrong #else commentary
3982 - MINOR: config: support default values for environment variables
3983 - SCRIPTS: run-regtests: reduce the number of processes needed to check options
3984 - SCRIPT: run-regtests: avoid several calls to grep to test for features
3985 - SCRIPT: run-regtests: avoid calling awk to compute the version
3986 - REGTEST: set retries count to zero for all tests that expect at 503
3987 - REGTESTS: make tcp-check_min-recv fail fast
3988 - REGTESTS: extend the default I/O timeouts and make them overridable
3989 - BUG/MEDIUM: ssl: backend TLS resumption with sni and TLSv1.3
3990 - BUG/MEDIUM: ssl: abort with the correct SSL error when SNI not found
3991 - REGTESTS: ssl: test the TLS resumption
3992 - BUILD: makefile: stop opening sub-shells for each and every command
3993 - BUILD: makefile: reorder objects by build time
3994 - BUG/MEDIUM: mux-h2: always process a pending shut read
3995 - MINOR: quic_sock: missing CO_FL_ADDR_TO_SET flag
3996 - MINOR: quic: Possible wrong connection identification
3997 - MINOR: quic: Correctly pad UDP datagrams
3998 - MINOR: quic: Support transport parameters draft TLS extension
3999 - MINOR: quic: Anti-amplification implementation
4000 - MINOR: quic: Wrong Initial packet connection initialization
4001 - MINOR: quic: Wrong ACK range building
4002 - MINOR: quic: Update some QUIC protocol errors
4003 - MINOR: quic: Send CONNECTION_CLOSE frame upon TLS alert
4004 - MINOR: quic: Wrong largest acked packet number parsing
4005 - MINOR: quic: Add minimalistic support for stream flow control frames
4006 - MINOR: quic: Wrong value for version negotiation packet 'Unused' field
4007 - MINOR: quic: Support draft-29 QUIC version
4008 - BUG/MINOR: quic: fix segfault on trace for version negotiation
4009 - BUG/MINOR: hq-interop: fix potential NULL dereference
4010 - BUILD: quic: fix potential NULL dereference on xprt_quic
4011 - DOC: lua: documentation about the httpclient API
4012 - BUG/MEDIUM: cache/cli: make "show cache" thread-safe
4013 - BUG/MEDIUM: shctx: leave the block allocator when enough blocks are found
4014 - BUG/MINOR: shctx: do not look for available blocks when the first one is enough
4015 - MINOR: shctx: add a few BUG_ON() for consistency checks
4016
Willy Tarreaud83f6e62021-11-14 16:04:57 +010040172021/11/14 : 2.5-dev14
4018 - DEV: coccinelle: Remove unused `expression e`
4019 - DEV: coccinelle: Add rule to use `istend()` where possible
4020 - CLEANUP: Apply ist.cocci
4021 - CLEANUP: Re-apply xalloc_size.cocci
4022 - CLEANUP: halog: make the default usage message fit in small screens
4023 - MINOR: h3/qpack: fix gcc11 warnings
4024 - MINOR: mux-quic: fix gcc11 warning
4025 - MINOR: h3: fix potential NULL dereference
4026 - MINOR: quic: Fix potential null pointer dereference
4027 - CLEANUP: halog: remove unused strl2ui()
4028 - OPTIM: halog: improve field parser speed for modern compilers
4029 - OPTIM: halog: skip fields 64 bits at a time when supported
4030 - DEV: coccinelle: Add rule to use `isttrim()` where possible
4031 - CLEANUP: Apply ist.cocci
4032 - DEV: coccinelle: Add rule to use `chunk_istcat()` instead of `chunk_memcat()`
4033 - DEV: coccinelle: Add rule to use `chunk_istcat()` instead of `chunk_strncat()`
4034 - CLEANUP: Apply ist.cocci
4035 - CLEANUP: chunk: Remove duplicated chunk_Xcat implementation
4036 - CLEANUP: chunk: remove misleading chunk_strncat() function
4037 - BUG/MINOR: cache: properly ignore unparsable max-age in quotes
4038 - Revert "DEV: coccinelle: Add rule to use `chunk_istcat()` instead of `chunk_strncat()`"
4039 - DOC: stats: fix location of the text representation
4040 - DOC: internals: document the IST API
4041 - BUG/MINOR: httpclient/lua: rcv freeze when no request payload
4042 - BUG/MEDIUM: httpclient: channel_add_input() must use htx->data
4043 - MINOR: promex: backend aggregated server check status
4044 - DOC: config: Fix typo in ssl_fc_unique_id description
4045 - BUG/MINOR: http-ana: Apply stop to the current section for http-response rules
4046 - Revert "BUG/MINOR: http-ana: Don't eval front after-response rules if stopped on back"
4047 - DOC: config: Be more explicit in "allow" actions description
4048 - DOC: lua: Be explicit with the Reply object limits
4049 - MINOR: mux-h1: Slightly Improve H1 traces
4050 - BUG/MEDIUM: conn-stream: Don't reset CS flags on close
4051 - CLEANUP: mworker: remove any relative PID reference
4052 - MEDIUM: mworker: reexec in waitpid mode after successful loading
4053 - MINOR: mworker: clarify starting/failure messages
4054 - MINOR: mworker: only increment the number of reload in wait mode
4055 - MINOR: mworker: implement a reload failure counter
4056 - MINOR: mworker: ReloadFailed shown depending on failedreload
4057 - MINOR: mworker: change the way we set PROC_O_LEAVING
4058 - BUG/MINOR: mworker: doesn't launch the program postparser
4059 - DOC: management: edit the "show proc" example to show the current output
4060 - BUG/MEDIUM: httpclient/cli: free of unallocated hc->req.uri
4061 - REGTESTS: httpclient/lua: add greater body values
4062 - BUG/MINOR: mux-h2: Fix H2_CF_DEM_SHORT_READ value
4063 - BUG/MINOR: pools: don't mark ourselves as harmless in DEBUG_UAF mode
4064 - BUG/MEDIUM: connection: make cs_shutr/cs_shutw//cs_close() idempotent
4065 - BUILD: makefile: simplify detection of libatomic
4066
Willy Tarreau08d32202021-11-06 09:25:57 +010040672021/11/06 : 2.5-dev13
4068 - SCRIPTS: git-show-backports: re-enable file-based filtering
4069 - MINOR: jwt: Make invalid static JWT algorithms an error in `jwt_verify` converter
4070 - MINOR: mux-h2: add trace on extended connect usage
4071 - BUG/MEDIUM: mux-h2: reject upgrade if no RFC8441 support
4072 - MINOR: stream/mux: implement websocket stream flag
4073 - MINOR: connection: implement function to update ALPN
4074 - MINOR: connection: add alternative mux_ops param for conn_install_mux_be
4075 - MEDIUM: server/backend: implement websocket protocol selection
4076 - MINOR: server: add ws keyword
4077 - BUG/MINOR: resolvers: fix sent messages were counted twice
4078 - BUG/MINOR: resolvers: throw log message if trash not large enough for query
4079 - MINOR: resolvers/dns: split dns and resolver counters in dns_counter struct
4080 - MEDIUM: resolvers: rename dns extra counters to resolvers extra counters
4081 - BUG/MINOR: jwt: Fix jwt_parse_alg incorrectly returning JWS_ALG_NONE
4082 - DOC: add QUIC instruction in INSTALL
4083 - CLEANUP: halog: Remove dead stores
4084 - DEV: coccinelle: Add ha_free.cocci
4085 - CLEANUP: Apply ha_free.cocci
4086 - DEV: coccinelle: Add rule to use `istnext()` where possible
4087 - CLEANUP: Apply ist.cocci
4088 - REGTESTS: Use `feature cmd` for 2.5+ tests (2)
4089 - DOC: internals: move some API definitions to an "api" subdirectory
4090 - MINOR: quic: Allocate listener RX buffers
4091 - CLEANUP: quic: Remove useless code
4092 - MINOR: quic: Enhance the listener RX buffering part
4093 - MINOR: quic: Remove a useless lock for CRYPTO frames
4094 - MINOR: quic: Use QUIC_LOCK QUIC specific lock label.
4095 - MINOR: backend: Get client dst address to set the server's one only if needful
4096 - MINOR: compression: Warn for 'compression offload' in defaults sections
4097 - MEDIUM: connection: rename fc_conn_err and bc_conn_err to fc_err and bc_err
4098 - DOC: configuration: move the default log formats to their own section
4099 - MINOR: ssl: make the ssl_fc_sni() sample-fetch function always available
4100 - MEDIUM: log: add the client's SNI to the default HTTPS log format
4101 - DOC: config: add an example of reasonably complete error-log-format
4102 - DOC: config: move error-log-format before custom log format
4103
Willy Tarreau35dc13f2021-11-02 18:05:41 +010041042021/11/02 : 2.5-dev12
4105 - MINOR: httpclient: support payload within a buffer
4106 - MINOR: httpclient/lua: support more HTTP methods
4107 - MINOR: httpclient/lua: return an error when it can't generate the request
4108 - CLEANUP: lua: Remove any ambiguities about lua txn execution context flags
4109 - BUG/MEDIUM: lua: fix invalid return types in hlua_http_msg_get_body
4110 - CLEANUP: connection: No longer export make_proxy_line_v1/v2 functions
4111 - CLEANUP: tools: Use const address for get_net_port() and get_host_port()
4112 - CLEANUP: lua: Use a const address to retrieve info about a connection
4113 - MINOR: connection: Add function to get src/dst without updating the connection
4114 - MINOR: session: Add src and dst addresses to the session
4115 - MINOR: stream-int: Add src and dst addresses to the stream-interface
4116 - MINOR: frontend: Rely on client src and dst addresses at stream level
4117 - MINOR: log: Rely on client addresses at the appropriate level to log messages
4118 - MINOR: session: Rely on client source address at session level to log error
4119 - MINOR: http-ana: Rely on addresses at stream level to set xff and xot headers
4120 - MINOR: http-fetch: Rely on addresses at stream level in HTTP sample fetches
4121 - MINOR: mux-fcgi: Rely on client addresses at stream level to set default params
4122 - MEDIUM: tcp-sample: Rely on addresses at the appropriate level in tcp samples
4123 - MEDIUM: connection: Rely on addresses at stream level to make proxy line
4124 - MEDIUM: backend: Rely on addresses at stream level to init server connection
4125 - MEDIUM: connection: Assign session addresses when PROXY line is received
4126 - MEDIUM: connection: Assign session addresses when NetScaler CIP proto is parsed
4127 - MEDIUM: tcp-act: Set addresses at the apprioriate level in set-(src/dst) actions
4128 - MINOR: tcp-act: Add set-src/set-src-port for "tcp-request content" rules
4129 - DOC: config: Fix alphabetical order of fc_* samples
4130 - MINOR: tcp-sample: Add samples to get original info about client connection
4131 - REGTESTS: Add script to test client src/dst manipulation at different levels
4132 - MINOR: stream: Use backend stream-interface dst address instead of target_addr
4133 - BUILD: log: Fix compilation without SSL support
4134 - DEBUG: protocol: yell loudly during registration of invalid sock_domain
4135 - MINOR: protocols: add a new protocol type selector
4136 - MINOR: protocols: make use of the protocol type to select the protocol
4137 - MINOR: protocols: replace protocol_by_family() with protocol_lookup()
4138 - MINOR: halog: Add -qry parameter allowing to preserve the query string in -uX
4139 - CLEANUP: jwt: Remove the use of a trash buffer in jwt_jwsverify_hmac()
4140 - CLEANUP: jwt: Remove the use of a trash buffer in jwt_jwsverify_rsa_ecdsa()
4141 - DEV: coccinelle: Add realloc_leak.cocci
4142 - CLEANUP: hlua: Remove obsolete branch in `hlua_alloc()`
4143 - BUILD: atomic: prefer __atomic_compare_exchange_n() for __ha_cas_dw()
4144 - BUILD: atomic: fix build on mac/arm64
4145 - MINOR: atomic: remove the memcpy() call and dependency on string.h
4146 - MINOR: httpclient: request streaming with a callback
4147 - MINOR: httpclient/lua: handle the streaming into the lua applet
4148 - REGTESTS: lua: test httpclient with body streaming
4149 - DOC: halog: Move the `-qry` parameter into the correct section in help text
4150 - MINOR: halog: Rename -qry to -query
4151 - CLEANUP: halog: Use consistent indentation in help()
4152 - BUG/MINOR: halog: Add missing newlines in die() messages
4153 - MINOR: halog: Add support for extracting captures using -hdr
4154 - DOC: Typo fixed "it" should be "is"
4155 - BUG/MINOR: mux-h1: Save shutdown mode if the shutdown is delayed
4156 - BUG/MEDIUM: mux-h1: Perform a connection shutdown when the h1c is released
4157 - BUG/MEDIUM: resolvers: Don't recursively perform requester unlink
4158 - BUG/MEDIUM: http-ana: Drain request data waiting the tarpit timeout expiration
4159 - BUG/MINOR: http: Authorization value can have multiple spaces after the scheme
4160 - BUG/MINOR: http: http_auth_bearer fetch does not work on custom header name
4161 - BUG/MINOR: httpclient/lua: misplaced luaL_buffinit()
4162 - BUILD/MINOR: cpuset freebsd build fix
4163 - BUG/MINOR: httpclient: use a placeholder value for Host header
4164 - BUG/MEDIUM: stream-int: Block reads if channel cannot receive more data
4165 - BUG/MEDIUM: resolvers: Track api calls with a counter to free resolutions
4166 - MINOR: stream: Improve dump of bogus streams
4167 - DOC/peers: some grammar fixes for peers 2.1 spec
4168 - MEDIUM: vars: make the var() sample fetch function really return type ANY
4169 - MINOR: vars: add "set-var" for "tcp-request connection" rules.
4170
Willy Tarreaub4d0cd02021-10-22 19:40:44 +020041712021/10/22 : 2.5-dev11
4172 - DEV: coccinelle: Add strcmp.cocci
4173 - CLEANUP: Apply strcmp.cocci
4174 - CI: Add `permissions` to GitHub Actions
4175 - CI: Clean up formatting in GitHub Action definitions
4176 - MINOR: add ::1 to predefined LOCALHOST acl
4177 - CLEANUP: assorted typo fixes in the code and comments
4178 - CLEANUP: Consistently `unsigned int` for bitfields
4179 - MEDIUM: resolvers: lower-case labels when converting from/to DNS names
4180 - MEDIUM: resolvers: replace bogus resolv_hostname_cmp() with memcmp()
4181 - MINOR: jwt: Empty the certificate tree during deinit
4182 - MINOR: jwt: jwt_verify returns negative values in case of error
4183 - MINOR: jwt: Do not rely on enum order anymore
4184 - BUG/MEDIUM: stream: Keep FLT_END analyzers if a stream detects a channel error
4185 - MINOR: httpclient/cli: access should be only done from expert mode
4186 - DOC: management: doc about the CLI httpclient
4187 - BUG/MEDIUM: tcpcheck: Properly catch early HTTP parsing errors
4188 - BUG/MAJOR: dns: tcp session can remain attached to a list after a free
4189 - BUG/MAJOR: dns: attempt to lock globaly for msg waiter list instead of use barrier
4190 - CLEANUP: dns: always detach the appctx from the dns session on release
4191 - DEBUG: dns: add a few more BUG_ON at sensitive places
4192 - BUG/MAJOR: resolvers: add other missing references during resolution removal
4193 - CLEANUP: resolvers: do not export resolv_purge_resolution_answer_records()
4194 - BUILD: resolvers: avoid a possible warning on null-deref
4195 - BUG/MEDIUM: resolvers: always check a valid item in query_list
4196 - CLEANUP: always initialize the answer_list
4197 - CLEANUP: resolvers: simplify resolv_link_resolution() regarding requesters
4198 - CLEANUP: resolvers: replace all LIST_DELETE with LIST_DEL_INIT
4199 - MEDIUM: resolvers: use a kill list to preserve the list consistency
4200 - MEDIUM: resolvers: remove the last occurrences of the "safe" argument
4201 - BUG/MEDIUM: checks: fix the starting thread for external checks
4202 - MEDIUM: resolvers: replace the answer_list with a (flat) tree
4203 - MEDIUM: resolvers: hash the records before inserting them into the tree
4204 - BUG/MAJOR: buf: fix varint API post- vs pre- increment
4205 - OPTIM: resolvers: move the eb32 node before the data in the answer_item
4206 - MINOR: list: add new macro LIST_INLIST_ATOMIC()
4207 - OPTIM: dns: use an atomic check for the list membership
4208 - BUG/MINOR: task: do not set TASK_F_USR1 for no reason
4209 - BUG/MINOR: mux-h2: do not prevent from sending a final GOAWAY frame
4210 - MINOR: connection: add a new CO_FL_WANT_DRAIN flag to force drain on close
4211 - MINOR: mux-h2: perform a full cycle shutdown+drain on close
4212 - CLEANUP: resolvers: get rid of single-iteration loop in resolv_get_ip_from_response()
4213 - MINOR: quic: Increase the size of handshake RX UDP datagrams
4214 - BUG/MEDIUM: lua: fix memory leaks with realloc() on non-glibc systems
4215 - MINOR: memprof: report the delta between alloc and free on realloc()
4216 - MINOR: memprof: add one pointer size to the size of allocations
4217 - BUILD: fix compilation on NetBSD
4218 - MINOR: backend: add traces for idle connections reuse
4219 - BUG/MINOR: backend: fix improper insert in avail tree for always reuse
4220 - MINOR: backend: improve perf with tcp proxies skipping idle conns
4221 - MINOR: connection: remove unneeded memset 0 for idle conns
4222
Willy Tarreauf2b1b4d2021-10-16 15:24:22 +020042232021/10/16 : 2.5-dev10
4224 - MINOR: initcall: Rename __GLOBL and __GLOBL1.
4225 - MINOR: rules: add a new function new_act_rule() to allocate act_rules
4226 - MINOR: rules: add a file name and line number to act_rules
4227 - MINOR: stream: report the current rule in "show sess all" when known
4228 - MINOR: stream: report the current filter in "show sess all" when known
4229 - CLEANUP: stream: Properly indent current_rule line in "show sess all"
4230 - BUG/MINOR: lua: Fix lua error handling in `hlua_config_prepend_path()`
4231 - CI: github: switch to OpenSSL 3.0.0
4232 - REGTESTS: ssl: Fix references to removed option in test description
4233 - MINOR: ssl: Add ssllib_name_startswith precondition
4234 - REGTESTS: ssl: Fix ssl_errors test for OpenSSL v3
4235 - REGTESTS: ssl: Reenable ssl_errors test for OpenSSL only
4236 - REGTESTS: ssl: Use mostly TLSv1.2 in ssl_errors test
4237 - MEDIUM: mux-quic: rationalize tx buffers between qcc/qcs
4238 - MEDIUM: h3: properly manage tx buffers for large data
4239 - MINOR: mux-quic: standardize h3 settings sending
4240 - CLEANUP: h3: remove dead code
4241 - MINOR: mux-quic: implement standard method to detect if qcc is dead
4242 - MEDIUM: mux-quic: defer stream shut if remaining tx data
4243 - MINOR: mux: remove last occurences of qcc ring buffer
4244 - MINOR: quic: handle CONNECTION_CLOSE frame
4245 - REGTESTS: ssl: re-enable set_ssl_cert_bundle.vtc
4246 - MINOR: ssl: add ssl_fc_is_resumed to "option httpslog"
4247 - MINOR: http: Add http_auth_bearer sample fetch
4248 - MINOR: jwt: Parse JWT alg field
4249 - MINOR: jwt: JWT tokenizing helper function
4250 - MINOR: jwt: Insert public certificates into dedicated JWT tree
4251 - MINOR: jwt: jwt_header_query and jwt_payload_query converters
4252 - MEDIUM: jwt: Add jwt_verify converter to verify JWT integrity
4253 - REGTESTS: jwt: Add tests for the jwt_verify converter
4254 - BUILD: jwt: fix declaration of EVP_KEY in jwt-h.h
4255 - MINOR: proto_tcp: use chunk_appendf() to ouput socket setup errors
4256 - MINOR: proto_tcp: also report the attempted MSS values in error message
4257 - MINOR: inet: report the faulty interface name in "bind" errors
4258 - MINOR: protocol: report the file and line number for binding/listening errors
4259 - MINOR: protocol: uniformize protocol errors
4260 - MINOR: resolvers: fix the resolv_str_to_dn_label() API about trailing zero
4261 - BUG/MEDIUM: resolver: make sure to always use the correct hostname length
4262 - BUG/MINOR: resolvers: do not reject host names of length 255 in SRV records
4263 - MINOR: resolvers: fix the resolv_dn_label_to_str() API about trailing zero
4264 - MEDIUM: listeners: split the thread mask between receiver and bind_conf
4265 - MINOR: listeners: add clone_listener() to duplicate listeners at boot time
4266 - MEDIUM: listener: add the "shards" bind keyword
4267 - BUG/MEDIUM: resolvers: use correct storage for the target address
4268 - MINOR: resolvers: merge address and target into a union "data"
4269 - BUG/MEDIUM: resolvers: fix truncated TLD consecutive to the API fix
4270 - BUG/MEDIUM: jwt: fix base64 decoding error detection
4271 - BUG/MINOR: jwt: use CRYPTO_memcmp() to compare HMACs
4272 - DOC: jwt: fix a typo in the jwt_verify() keyword description
4273 - BUG/MEDIUM: sample/jwt: fix another instance of base64 error detection
4274 - BUG/MINOR: http-ana: Don't eval front after-response rules if stopped on back
4275 - BUG/MINOR: sample: Fix 'fix_tag_value' sample when waiting for more data
4276 - DOC: config: Move 'tcp-response content' at the right place
4277 - BUG/MINOR: proxy: Use .disabled field as a bitfield as documented
4278 - MINOR: proxy: Introduce proxy flags to replace disabled bitfield
4279 - MINOR: sample/arg: Be able to resolve args found in defaults sections
4280 - MEDIUM: proxy: Warn about ambiguous use of named defaults sections
4281 - MINOR: proxy: Be able to reference the defaults section used by a proxy
4282 - MINOR: proxy: Add PR_FL_READY flag on fully configured and usable proxies
4283 - MINOR: config: Finish configuration for referenced default proxies
4284 - MINOR: config: No longer remove previous anonymous defaults section
4285 - MINOR: tcpcheck: Support 2-steps args resolution in defaults sections
4286 - MEDIUM: rules/acl: Parse TCP/HTTP rules and acls defined in defaults sections
4287 - MEDIUM: tcp-rules: Eval TCP rules defined in defaults sections
4288 - MEDIUM: http-ana: Eval HTTP rules defined in defaults sections
4289 - BUG/MEDIUM: sample: Cumulate frontend and backend sample validity flags
4290 - REGTESTS: Add scripts to test support of TCP/HTTP rules in defaults sections
4291 - DOC: config: Add documentation about TCP/HTTP rules in defaults section
4292 - DOC: config: Rework and uniformize how TCP/HTTP rules are documented
4293 - BUG/MINOR: proxy: Release ACLs and TCP/HTTP rules of default proxies
4294 - BUG/MEDIUM: cpuset: fix cpuset size for FreeBSD
4295 - BUG/MINOR: sample: fix backend direction flags consecutive to last fix
4296 - BUG/MINOR: listener: fix incorrect return on out-of-memory
4297 - BUG/MINOR: listener: add an error check for unallocatable trash
4298 - CLEANUP: listeners: remove unreachable code in clone_listener()
4299
Willy Tarreau4c67bd62021-10-08 18:22:24 +020043002021/10/08 : 2.5-dev9
4301 - head-truc
4302 - REGTESTS: lua: test the httpclient:get() feature
4303 - Revert "head-truc"
4304 - BUG/MEDIUM: httpclient: replace ist0 by istptr
4305 - MINOR: config: use a standard parser for the "nbthread" keyword
4306 - CLEANUP: init: remove useless test against MAX_THREADS in affinity loop
4307 - MEDIUM: init: de-uglify the per-thread affinity setting
4308 - MINOR: init: extract the setup and end of threads to their own functions
4309 - MINOR: log: Try to get the status code when MUX_EXIT_STATUS is retrieved
4310 - MINOR: mux-h1: Set error code if possible when MUX_EXIT_STATUS is returned
4311 - MINOR: mux-h1: Be able to set custom status code on parsing error
4312 - MEDIUM: mux-h1: Reject HTTP/1.0 GET/HEAD/DELETE requests with a payload
4313 - MEDIUM: h1: Force close mode for invalid uses of T-E header
4314 - BUG/MINOR: mux-h1/mux-fcgi: Sanitize TE header to only send "trailers"
4315 - MINOR: http: Add 422-Unprocessable-Content error message
4316 - MINOR: h1: Change T-E header parsing to fail if chunked encoding is found twice
4317 - BUG/MEDIUM: mux-h1/mux-fcgi: Reject messages with unknown transfer encoding
4318 - REGTESTS: Add script to validate T-E header parsing
4319 - REORG: pools: move default settings to defaults.h
4320 - DOC: peers: fix doc "enable" statement on "peers" sections
4321 - MINOR: Makefile: add MEMORY_POOLS to the list of DEBUG_xxx options
4322 - MINOR: ssl: Set connection error code in case of SSL read or write fatal failure
4323 - MINOR: ssl: Rename ssl_bc_hsk_err to ssl_bc_err
4324 - MINOR: ssl: Store the last SSL error code in case of read or write failure
4325 - REGTESTS: ssl: enable show_ssl_ocspresponse.vtc again
4326 - REGTESTS: ssl: enable ssl_crt-list_filters.vtc again
4327 - BUG/MEDIUM: lua: fix wakeup condition from sleep()
4328 - BUG/MAJOR: lua: use task_wakeup() to properly run a task once
4329 - MINOR: arg: Be able to forbid unresolved args when building an argument list
4330 - BUG/MINOR: tcpcheck: Don't use arg list for default proxies during parsing
4331 - BUG/MINOR: tcp-rules: Stop content rules eval on read error and end-of-input
4332 - MINOR: tasks: catch TICK_ETERNITY with BUG_ON() in __task_queue()
4333 - REGTESTS: ssl: show_ssl_ocspresponse w/ freebsd won't use base64
4334 - REGTESTS: ssl: wrong feature cmd in show_ssl_ocspresponse.vtc
4335 - CLEANUP: tasks: remove the long-unused work_lists
4336 - MINOR: task: provide 3 task_new_* wrappers to simplify the API
4337 - MINOR: time: uninline report_idle() and move it to task.c
4338 - REORG: sched: move idle time calculation from time.h to task.h
4339 - REORG: sched: move the stolen CPU time detection to sched_entering_poll()
4340 - BUG/MEDIUM: filters: Fix a typo when a filter is attached blocking the release
4341 - BUG/MEDIUM: http-ana: Clear request analyzers when applying redirect rule
4342 - MINOR: httpclient: destroy() must free the headers and the ists
4343 - MINOR: httpclient: set HTTPCLIENT_F_ENDED only in release
4344 - MINOR: httpclient: stop_and_destroy() ask the applet to autokill
4345 - MINOR: httpclient: test if started during stop_and_destroy()
4346 - MINOR: httpclient/lua: implement garbage collection
4347 - BUG/MEDIUM: httpclient/lua: crash because of b_xfer and get_trash_chunk()
4348 - MINOR: httpclient: destroy checks if a client was started but not stopped
4349 - BUG/MINOR: httpclient/lua: does not process headers when failed
4350 - MINOR: httpclient/lua: supports headers via named arguments
4351 - CLEANUP: server: always include the storage for SSL settings
4352 - CLEANUP: sample: rename sample_conv_var2smp() to *_sint
4353 - CLEANUP: sample: uninline sample_conv_var2smp_str()
4354 - MINOR: sample: provide a generic var-to-sample conversion function
4355 - BUG/MEDIUM: sample: properly verify that variables cast to sample
4356 - BUILD: action: add the relevant structures for function arguments
4357 - BUILD: extcheck: needs to include stream-t.h
4358 - BUILD: hlua: needs to include stream-t.h
4359 - BUILD: stats: define several missing structures in stats.h
4360 - BUILD: resolvers: define missing types in resolvers.h
4361 - BUILD: httpclient: include missing ssl_sock-t
4362 - BUILD: sample: include openssl-compat
4363 - BUILD: http_ana: need to include proxy-t to get redirect_rule
4364 - BUILD: http_rules: requires http_ana-t.h for REDIRECT_*
4365 - BUILD: vars: need to include xxhash
4366 - BUILD: peers: need to include eb{32/mb/pt}tree.h
4367 - BUILD: ssl_ckch: include ebpttree.h in ssl_ckch.c
4368 - BUILD: compiler: add the container_of() and container_of_safe() macros
4369 - BUILD: idleconns: include missing ebmbtree.h at several places
4370 - BUILD: connection: connection.h needs list.h and server.h
4371 - BUILD: tree-wide: add missing http_ana.h from many places
4372 - BUILD: cfgparse-ssl: add missing errors.h
4373 - BUILD: tcp_sample: include missing errors.h and session-t.h
4374 - BUILD: mworker: mworker-prog needs time.h for the 'now' variable
4375 - BUILD: tree-wide: add several missing activity.h
4376 - BUILD: compat: fix -Wundef on SO_REUSEADDR
4377 - CLEANUP: pools: pools-t.h doesn't need to include thread-t.h
4378 - REORG: pools: uninline the UAF allocator and force-inline the rest
4379 - REORG: thread: uninline the lock-debugging code
4380 - MINOR: thread/debug: replace nsec_now() with now_mono_time()
4381 - CLEANUP: remove some unneeded includes from applet-t.h
4382 - REORG: listener: move bind_conf_alloc() and listener_state_str() to listener.c
4383 - CLEANUP: listeners: do not include openssl-compat
4384 - CLEANUP: servers: do not include openssl-compat
4385 - REORG: ssl: move ssl_sock_is_ssl() to connection.h and rename it
4386 - CLEANUP: mux_fcgi: remove dependency on ssl_sock
4387 - CLEANUP: ssl/server: move ssl_sock_set_srv() to srv_set_ssl() in server.c
4388 - REORG: ssl-sock: move the sslconns/totalsslconns counters to global
4389 - REORG: sample: move the crypto samples to ssl_sample.c
4390 - REORG: sched: moved samp_time and idle_time to task.c as well
4391 - REORG: time/ticks: move now_ms and global_now_ms definitions to ticks.h
4392 - CLEANUP: tree-wide: remove unneeded include time.h in ~20 files
4393 - REORG: activity: uninline activity_count_runtime()
4394 - REORG: acitvity: uninline sched_activity_entry()
4395 - CLEANUP: stream: remove many unneeded includes from stream-t.h
4396 - CLEANUP: stick-table: no need to include socket nor in.h
4397 - MINOR: connection: use uint64_t for the hashes
4398 - REORG: connection: move the hash-related stuff to connection.c
4399 - REORG: connection: uninline conn_notify_mux() and conn_delete_from_tree()
4400 - REORG: server: uninline the idle conns management functions
4401 - REORG: ebtree: split structures into their own file ebtree-t.h
4402 - CLEANUP: tree-wide: only include ebtree-t from type files
4403 - REORG: connection: move the largest inlines from connection.h to connection.c
4404 - CLEANUP: connection: do not include http_ana!
4405 - CLEANUP: connection: remove unneeded tcpcheck-t.h and use only session-t.h
4406 - REORG: connection: uninline the rest of the alloc/free stuff
4407 - REORG: task: uninline the loop time measurement code
4408 - CLEANUP: time: move a few configurable defines to defaults.h
4409 - CLEANUP: fd: do not include time.h
4410 - REORG: fd: uninline compute_poll_timeout()
4411 - CLENAUP: wdt: use ha_tkill() instead of accessing pthread directly
4412 - REORG: thread: move the thread init/affinity/stop to thread.c
4413 - REORG: thread: move ha_get_pthread_id() to thread.c
4414 - MINOR: thread: use a dedicated static pthread_t array in thread.c
4415 - CLEANUP: thread: uninline ha_tkill/ha_tkillall/ha_cpu_relax()
4416 - DOC: configuration: add clarification on escaping in keyword arguments
4417 - BUG/MINOR: task: fix missing include with DEBUG_TASK
4418 - MINOR: pools: report the amount used by thread caches in "show pools"
4419 - MINOR: quic: Distinguish packet and SSL read enc. level in traces
4420 - MINOR: quic: Add a function to dump SSL stack errors
4421 - MINOR: quic: BUG_ON() SSL errors.
4422 - MINOR: quic: Fix SSL error issues (do not use ssl_bio_and_sess_init())
4423 - BUG/MEDIUM: mux-quic: reinsert all streams in by_id tree
4424 - BUG/MAJOR: xprt-quic: do not queue qc timer if not set
4425 - MINOR: mux-quic: release connection if no more bidir streams
4426 - BUG/MAJOR: quic: remove qc from receiver cids tree on free
4427 - BUG/MEDIUM: mux_h2: Handle others remaining read0 cases on partial frames
4428 - MINOR: qpack: do not encode invalid http status code
4429 - MINOR: qpack: support non-indexed http status code encoding
4430 - MINOR: qpack: fix memory leak on huffman decoding
4431 - CLEANUP: mux-quic: remove unused code
4432 - BUG/MINOR: quic: fix includes for compilation
4433 - BUILD: connection: avoid a build warning on FreeBSD with SO_USER_COOKIE
4434 - BUILD: init: avoid a build warning on FreeBSD with USE_PROCCTL
4435 - REORG: time: move time-keeping code and variables to clock.c
4436 - REORG: clock: move the updates of cpu/mono time to clock.c
4437 - MINOR: activity: get the run_time from the clock updates
4438 - CLEANUP: clock: stop exporting before_poll and after_poll
4439 - REORG: clock: move the clock_id initialization to clock.c
4440 - REORG: clock/wdt: move wdt timer initialization to clock.c
4441 - MINOR: clock: move the clock_ids to clock.c
4442 - MINOR: wdt: move wd_timer to wdt.c
4443 - CLEANUP: wdt: do not remap SI_TKILL to SI_LWP, test the values directly
4444 - REORG: thread/sched: move the task_per_thread stuff to thread_ctx
4445 - REORG: thread/clock: move the clock parts of thread_info to thread_ctx
4446 - REORG: thread/sched: move the thread_info flags to the thread_ctx
4447 - REORG: thread/sched: move the last dynamic thread_info to thread_ctx
4448 - MINOR: thread: make "ti" a const pointer and clean up thread_info a bit
4449 - MINOR: threads: introduce a minimalistic notion of thread-group
4450 - MINOR: global: add a new "thread-groups" directive
4451 - MINOR: global: add a new "thread-group" directive
4452 - MINOR: threads: make tg point to the current thread's group
4453 - MEDIUM: threads: automatically assign threads to groups
4454 - MINOR: threads: set the group ID and its bit in the thread group
4455 - MINOR: threads: set the tid, ltid and their bit in thread_cfg
4456 - MEDIUM: threads: replace ha_set_tid() with ha_set_thread()
4457 - MINOR: threads: add the current group ID in thread-local "tgid" variable
4458 - MINOR: debug: report the group and thread ID in the thread dumps
4459 - MEDIUM: listeners: support the definition of thread groups on bind lines
4460 - MINOR: threads: add a new function to resolve config groups and masks
4461 - MEDIUM: config: resolve relative threads on bind lines to absolute ones
4462 - MEDIUM: stick-table: never learn the "conn_cur" value from peers
4463
Willy Tarreau538f3e02021-09-24 15:52:17 +020044642021/09/24 : 2.5-dev8
4465 - BUILD: compiler: fixed a missing test on defined(__GNUC__)
4466 - BUILD: halog: fix a -Wundef warning on non-glibc systems
4467 - BUILD: threads: fix -Wundef for _POSIX_PRIORITY_SCHEDULING on libmusl
4468 - BUG/MINOR: compat: make sure __WORDSIZE is always defined
4469 - BUILD: sample: fix format warning on 32-bit archs in sample_conv_be2dec_check()
4470 - CLEANUP: pools: factor all malloc_trim() calls into trim_all_pools()
4471 - MINOR: pools: automatically disable malloc_trim() with external allocators
4472 - MINOR: pools: report it when malloc_trim() is enabled
4473 - DOC: Add .mailmap
4474 - CLEANUP: tree-wide: fix prototypes for functions taking no arguments.
4475 - CLEANUP: Remove prototype for non-existent thread_get_default_count()
4476 - CLEANUP: acl: Remove unused variable when releasing an acl expression
4477 - BUG/MAJOR: mux-h1: Don't eval input data if an error was reported
4478 - DOC: update Tim's address in .mailmap
4479 - MINOR: pools: use mallinfo2() when available instead of mallinfo()
4480 - BUG/MINOR: tcpcheck: Improve LDAP response parsing to fix LDAP check
4481 - DOC: management: certificate files must be sanitized before injection
4482 - BUG/MINOR: connection: prevent null deref on mux cleanup task allocation
4483 - BUILD: ist: prevent gcc11 maybe-uninitialized warning on istalloc
4484 - BUG/MINOR: cli/payload: do not search for args inside payload
4485 - BUILD: sockpair: do not set unused flag
4486 - BUILD: proto_uxst: do not set unused flag
4487 - BUILD: fd: remove unused variable totlen in fd_write_frag_line()
4488 - MINOR: applet: remove the thread mask from appctx_new()
4489 - REORG: threads: move ha_get_pthread_id() to tinfo.h
4490 - CLEANUP: Apply ist.cocci
4491 - DEV: coccinelle: Add ist.cocci
4492 - CLEANUP: Apply bug_on.cocci
4493 - DEV: coccinelle: Add xalloc_size.cocci
4494 - DEV: coccinelle: Add bug_on.cocci
4495 - CLEANUP: Apply xalloc_size.cocci
4496 - DEV: coccinelle: Add xalloc_cast.cocci
4497 - BUG/MINOR: flt-trace: fix an infinite loop when random-parsing is set
4498 - MINOR: httpclient: add the EOH when no headers where provided
4499 - CLEANUP: Include check.h in flt_spoe.c
4500 - CLEANUP: Remove unreachable `break` from parse_time_err()
4501 - BUG/MINOR: server: allow 'enable health' only if check configured
4502 - BUG/MINOR: server: alloc dynamic srv ssl ctx if proxy uses ssl chk rule
4503 - MINOR: server: enable more keywords for ssl checks for dynamic servers
4504 - MINOR: server: enable more check related keywords for dynamic servers
4505 - REORG: server: move slowstart init outside of checks
4506 - MINOR: server: enable slowstart for dynamic server
4507 - MEDIUM: listener: deprecate "process" in favor of "thread" on bind lines
4508 - BUG/MEDIUM: leastconn: fix rare possibility of divide by zero
4509 - BUG/MINOR: quic: Possible NULL pointer dereferencing when dumping streams.
4510 - MINOR: quic: Move transport parmaters to anynomous struct.
4511 - MINOR: mux_quic: Add QUIC mux layer.
4512 - MINOR: connection: Add callbacks definitions for QUIC.
4513 - MINOR: quic: Attach QUIC mux connection objet to QUIC connection.
4514 - MINOR: quic: Add a new definition to store STREAM frames.
4515 - MINOR: h3: Add HTTP/3 definitions.
4516 - MINOR: qpack: Add QPACK compression.
4517 - MINOR: quic_sock: Finalize the QUIC connections.
4518 - MINOR: quic: Disable the action of ->rcv_buf() xprt callback
4519 - MINOR: quic: Add callbacks for (un)scribing to QUIC xprt.
4520 - MINOR: quic: Variable-length integer encoding/decoding into/from buffer struct.
4521 - BUG/MINOR: quic: Wrong ->accept() error handling
4522 - MINOR: quic: Add a wrapper function to update transport parameters.
4523 - MINOR: quic: Update the streams transport parameters.
4524 - MINOR: quic: Avoid header collisions
4525 - MINOR: quic: Replace max_packet_size by max_udp_payload size.
4526 - MINOR: quic: Enable some quic, h3 and qpack modules compilation.
4527 - MINOR: quic: Move an SSL func call from QUIC I/O handler to the xprt init.
4528 - MINOR: quic: Initialize the session before starting the xprt.
4529 - BUG/MINOR: quic: Do not check the acception of a new conn from I/O handler.
4530 - MINOR: quic: QUIC conn initialization from I/O handler
4531 - MINOR: quic: Remove header protection for conn with context
4532 - MINOR: quic: Derive the initial secrets asap
4533 - MINOR: quic: Remove header protection also for Initial packets
4534 - BUG/MINOR: quic: Wrong memory free in quic_update_ack_ranges_list()
4535 - MINOR: quic: quic_update_ack_ranges_list() code factorization
4536 - MINOR: quic: Useless test in quic_update_ack_ranges_list()
4537 - MINOR: quic: Remove a useless variable in quic_update_ack_ranges_list()
4538 - BUG/MINOR: quic: Missing cases treatement when updating ACK ranges
4539 - CLEAUNUP: quic: Usage of a useless variable in qc_treat_rx_pkts()
4540 - BUG/MINOR: quic: Wrong RX packet reference counter usage
4541 - MINOR: quic: Do not stop the packet parsing too early in qc_treat_rx_packets()
4542 - MINOR: quic: Add a lock for RX packets
4543 - MINOR: quic: Move the connection state
4544 - MINOR: quic: Replace quic_conn_ctx struct by ssl_sock_ctx struct
4545 - MINOR: quic: Replace the RX list of packet by a thread safety one.
4546 - MINOR: quic: Replace the RX unprotected packet list by a thread safety one.
4547 - MINOR: quic: Add useful traces for I/O dgram handler
4548 - MINOR: quic: Do not wakeup the xprt task on ACK receipt
4549 - MINOR: quic: Connection allocations rework
4550 - MINOR: quic: Move conn_prepare() to ->accept_conn() callback
4551 - MINOR: quic: Make qc_lstnr_pkt_rcv() be thread safe.
4552 - MINOR: quic: Add a ring buffer implementation for QUIC
4553 - MINOR: quic: Prefer x25519 as ECDH preferred parametes.
4554 - MINOR: quic: Add the QUIC v1 initial salt.
4555 - BUG/MINOR: quic: Too much reduced computed space to build handshake packets
4556 - MINOR: net_helper: add functions for pointers
4557 - MINOR: quic: Add ring buffer definition (struct qring) for QUIC
4558 - MINOR: proto_quic: Allocate TX ring buffers for listeners
4559 - MINOR: quic: Initialize pointers to TX ring buffer list
4560 - MINOR: quic: Make use of TX ring buffers to send QUIC packets
4561 - MINOR: quic_tls: Make use of the QUIC V1 salt.
4562 - MINOR: quic: Remove old TX buffer implementation
4563 - MINOR: Add function for TX packets reference counting
4564 - MINOR: quic: Add TX packets at the very last time to their tree.
4565 - MINOR: quic: Unitialized mux context upon Client Hello message receipt.
4566 - MINOR: quic: Missing encryption level rx.crypto member initialization and lock.
4567 - MINOR: quic: Rename ->rx.rwlock of quic_enc_level struct to ->rx.pkts_rwlock
4568 - MINOR: quic: Make qc_treat_rx_pkts() be thread safe.
4569 - MINOR: quic: Make ->tx.frms quic_pktns struct member be thread safe
4570 - MINOR: quic: Replace quic_tx_frm struct by quic_frame struct
4571 - MINOR: quic: Add a mask for TX frame builders and their authorized packet types
4572 - MINOR: quic: Add a useful function to compute any frame length.
4573 - MINOR: quic: Add the QUIC connection state to traces
4574 - MINOR: quic: Store post handshake frame in ->pktns.tx.frms MT_LIST
4575 - MINOR: quic: Add the packet type to quic_tx_packet struct
4576 - MINOR: quic: Modify qc_do_build_hdshk_pkt() to accept any packet type
4577 - MINOR: quic: Atomically handle packet number space ->largest_acked_pn variable
4578 - MINOR: quic: Modify qc_build_cfrms() to support any frame
4579 - MINOR: quic: quic_conn_io_cb() task rework
4580 - MINOR: quic: Make qc_build_hdshk_pkt() atomically consume a packet number
4581 - MINOR: quic: qc_do_build_hdshk_pkt() does not need to pass a copy of CRYPTO frame
4582 - MINOR: quic: Remove Application level related functions
4583 - MINOR: quic: Rename functions which do not build only Handshake packets
4584 - MINOR: quic: Make circular buffer internal buffers be variable-sized.
4585 - MINOR: quic: Add a pool for TX ring buffer internal buffer
4586 - MINOR: quic: Make use of the last cbuf API when initializing TX ring buffers
4587 - MINOR: quic: Missing acks encoded size updates.
4588 - MINOR: quic: Evaluate the packet lengths in advance
4589 - MINOR: quic: Update the TLS extension for QUIC transport parameters
4590 - MINOR: quic: Fix handshake state debug strings
4591 - MINOR: quic: Atomically get/set the connection state
4592 - MINOR: quic: Missing QUIC encryption level for qc_build_pkt()
4593 - MINOR: quic: Coalesce Application level packets with Handshake packets.
4594 - MINOR: quic: Wrong flags handling for acks
4595 - MINOR: quic: Missing case when discarding HANDSHAKE secrets
4596 - MINOR: quic: Post handshake packet building improvements
4597 - MINOR: quic: Prepare Application level packet asap.
4598 - MINOR: h3: Send h3 settings asap
4599 - MINOR: quic: Wrong STREAM frame length computing
4600 - MINOR: quic: Wrong short packet minimum length
4601 - MINOR: quic: Prepare STREAM frames to fill QUIC packets
4602 - MINOR: h3: change default settings
4603 - MINOR: quic-enc: fix varint encoding
4604 - MINOR: qpack: fix wrong comment
4605 - MINOR: qpack: generate headers list on decoder
4606 - MINOR: h3: parse headers to htx
4607 - MINOR: h3: allocate stream on headers
4608 - MEDIUM: mux-quic: implement ring buffer on stream tx
4609 - MINOR: mux-quic: send SETTINGS on uni stream
4610 - MINOR: h3: define snd_buf callback and divert mux ops
4611 - MINOR: mux-quic: define FIN stream flag
4612 - MINOR: qpack: create qpack-enc module
4613 - MINOR: qpack: encode headers functions
4614 - MINOR: h3: encode htx headers to QPACK
4615 - MINOR: h3: send htx data
4616 - MINOR: h3/mux: detect fin on last h3 frame of the stream
4617 - MINOR: quic: Shorten some handshakes
4618 - MINOR: quic: Make QUIC-TLS support at least two initial salts
4619 - MINOR: quic: Attach the QUIC connection to a thread.
4620 - MINOR: quic: Missing active_connection_id_limit default value
4621 - MINOR: quic_sock: Do not flag QUIC connections as being set
4622 - MINOR: buf: Add b_force_xfer() function
4623 - MINOR: quic: Make use of buffer structs to handle STREAM frames
4624 - MINOR: mux_quic: move qc_process() code to qc_send()
4625 - MINOR: quic: Add a typedef for unsigned long long
4626 - MINOR: quic: Confusion between TX/RX for the frame builders
4627 - MINOR: quic: Wrong packet flags settings during frame building
4628 - MINOR: quic: Constantness fixes for frame builders/parsers.
4629 - MINOR: quic_tls: Client/serveur state reordering
4630 - MINOR: quic: Wrong packet loss detection due to wrong pktns order
4631 - MINOR: quic: Wrong packet number space selection in quic_loss_pktns()
4632 - MINOR: quic: Initial packet number spaced not discarded
4633 - MINOR: quic: Add useful trace about pktns discarding
4634 - MINOR: mux_quic: Export the mux related flags
4635 - MINOR: quic: Implement quic_conn_subscribe()
4636 - MINOR: quic: Wake up the mux upon ACK receipt
4637 - MINOR: quic: Stream FIN bit fix in qcs_push_frame()
4638 - MINOR: quic: Implement qc_process_mux()
4639 - MINOR: quic: Wake up the xprt from mux
4640 - CLEANUP: quic: Remove useless inline functions
4641 - MINOR: quic: RX packets memory leak
4642 - MINOR: quic: Possible endless loop in qc_treat_rx_pkts()
4643 - MINOR: quic: Crash upon too big packets receipt
4644 - MINOR: quic: define close handler
4645 - MEDIUM: quic: implement mux release/conn free
4646 - MINOR: quic: fix qcc subs initialization
4647 - BUG/MINOR: h1-htx: Fix a typo when request parser is reset
4648 - BUG/MEDIUM: mux-h1: Adjust conditions to ask more space in the channel buffer
4649 - BUG/MEDIUM: stream-int: Notify stream that the mux wants more room to xfer data
4650 - BUG/MEDIUM: stream: Stop waiting for more data if SI is blocked on RXBLK_ROOM
4651 - MINOR: stream-int: Set CO_RFL transient/persistent flags apart in si_cs_rcv()
4652 - MINOR: htx: Add an HTX flag to know when a message is fragmented
4653 - MINOR: htx: Add a function to know if the free space wraps
4654 - BUG/MEDIUM: stream-int: Defrag HTX message in si_cs_recv() if necessary
4655 - MINOR: stream-int: Notify mux when the buffer is not stuck when calling rcv_buf
4656 - BUG/MINOR: http-ana: increment internal_errors counter on response error
4657 - MINOR: stats: Enable dark mode on stat web page
4658 - CLEANUP: stats: Fix some alignment mistakes
4659 - MINOR: httpclient: httpclient_data() returns the available data
4660 - MINOR: httpclient: httpclient_ended() returns 1 if the client ended
4661 - MINOR: httpclient/lua: httpclient:get() API in lua
4662 - MINOR: httpclient/lua: implement the headers in the response object
4663 - BUG/MINOR: httpclient/lua: return an error on argument check
4664 - CLEANUP: slz: Mark `reset_refs` as static
4665
Willy Tarreau4b3a9fe2021-09-12 11:36:38 +020046662021/09/12 : 2.5-dev7
4667 - BUG/MINOR: config: reject configs using HTTP with bufsize >= 256 MB
4668 - CLEANUP: htx: remove comments about "must be < 256 MB"
4669 - BUG/MAJOR: htx: fix missing header name length check in htx_add_header/trailer
4670 - Revert "BUG/MINOR: stream-int: Don't block reads in si_update_rx() if chn may receive"
4671 - MINOR: proxy: add a global "grace" directive to postpone soft-stop
4672 - MINOR: vars: rename vars_init() to vars_init_head()
4673 - CLEANUP: vars: rename sample_clear_stream() to var_unset()
4674 - REORG: vars: remerge sample_store{,_stream}() into var_set()
4675 - MEDIUM: vars: make the ifexist variant of set-var only apply to the proc scope
4676 - MINOR: vars: add a VF_CREATEONLY flag for creation
4677 - MINOR: vars: support storing empty sample data with a variable
4678 - MINOR: vars: store flags into variables and add VF_PERMANENT
4679 - MEDIUM: vars: make var_clear() only reset VF_PERMANENT variables
4680 - MEDIUM: vars: pre-create parsed SCOPE_PROC variables as permanent ones
4681 - MINOR: vars: preset a random seed to hash variables names
4682 - MEDIUM: vars: replace the global name index with a hash
4683 - CLEANUP: vars: remove the now unused var_names array
4684 - MINOR: vars: centralize the lock/unlock into static inlines
4685 - OPTIM: vars: only takes the variables lock on shared entries
4686 - OPTIM: vars: remove internal bookkeeping for vars_global_size
4687 - OPTIM: vars: do not keep variables usage stats if no limit is set
4688 - BUILD: fix dragonfly build again on __read_mostly
4689 - CI: Github Actions: temporarily disable Opentracing
4690 - BUG/MEDIUM: mux-h1: Remove "Upgrade:" header for requests with payload
4691 - MINOR: htx: Skip headers with no value when adding a header list to a message
4692 - CLEANUP: mux-h1: Remove condition rejecting upgrade requests with payload
4693 - BUG/MEDIUM: stream-int: Don't block SI on a channel policy if EOI is reached
4694 - BUG/MEDIUM: http-ana: Reset channels analysers when returning an error
4695 - BUG/MINOR: filters: Set right FLT_END analyser depending on channel
4696 - CLEANUP: Add haproxy/xxhash.h to avoid modifying import/xxhash.h
4697 - CLEANUP: ebmbtree: Replace always-taken elseif by else
4698 - CLEANUP: Move XXH3 macro from haproxy/compat.h to haproxy/xxhash.h
4699 - BUILD: opentracing: exclude the use of haproxy variables for the OpenTracing context
4700 - BUG/MINOR: opentracing: enable the use of http headers without a set value
4701 - CLEANUP: opentracing: use the haproxy function to generate uuid
4702 - MINOR: opentracing: change the scope of the variable 'ot.uuid' from 'sess' to 'txn'
4703 - CI: Github Actions: re-enable Opentracing
4704 - CLEANUP: opentracing: simplify the condition on the empty header
4705 - BUG/MEDIUM lua: Add missing call to RESET_SAFE_LJMP in hlua_filter_new()
4706
Willy Tarreauf653e832021-09-03 15:19:56 +020047072021/09/03 : 2.5-dev6
4708 - BUG/MINOR threads: Use get_(local|gm)time instead of (local|gm)time
4709 - BUG/MINOR: tools: Fix loop condition in dump_text()
4710 - BUILD: ssl: next round of build warnings on LIBRESSL_VERSION_NUMBER
4711 - BUILD: ssl: fix two remaining occurrences of #if USE_OPENSSL
4712 - BUILD: tools: properly guard __GLIBC__ with defined()
4713 - BUILD: globally enable -Wundef
4714 - MINOR: log: Remove log-error-via-logformat option
4715 - MINOR: log: Add new "error-log-format" option
4716 - BUG/MAJOR: queue: better protect a pendconn being picked from the proxy
4717 - CLEANUP: Add missing include guard to signal.h
4718 - MINOR: ssl: Add new ssl_bc_hsk_err sample fetch
4719 - MINOR: connection: Add a connection error code sample fetch for backend side
4720 - REGTESTS: ssl: Add tests for bc_conn_err and ssl_bc_hsk_err sample fetches
4721 - MINOR: http-rules: add a new "ignore-empty" option to redirects.
4722 - CI: Github Actions: temporarily disable BoringSSL builds
4723 - BUG/MINOR: vars: fix set-var/unset-var exclusivity in the keyword parser
4724 - BUG/MINOR: vars: improve accuracy of the rules used to check expression validity
4725 - MINOR: sample: add missing ARGC_ entries
4726 - BUG/MINOR: vars: properly set the argument parsing context in the expression
4727 - DOC: configuration: remove wrong tcp-request examples in tcp-response
4728 - MEDIUM: vars: add a new "set-var-fmt" action
4729 - BUG/MEDIUM: vars: run over the correct list in release_store_rules()
4730 - BUG/MINOR: vars: truncate the variable name in error reports about scope.
4731 - BUG/MINOR: vars: do not talk about global section in CLI errors for set-var
4732 - CLEANUP: vars: name the temporary proxy "CFG" instead of "CLI" for global vars
4733 - MINOR: log: make log-format expressions completely usable outside of req/resp
4734 - MINOR: vars: add a "set-var-fmt" directive to the global section
4735 - MEDIUM: vars: also support format strings in CLI's "set var" command
4736 - CLEANUP: vars: factor out common code from vars_get_by_{desc,name}
4737 - MINOR: vars: make vars_get_by_* support an optional default value
4738 - MINOR: vars: make the vars() sample fetch function support a default value
4739 - BUILD: ot: add argument for default value to vars_get_by_name()
4740
Willy Tarreau446344c2021-08-28 13:46:11 +020047412021/08/28 : 2.5-dev5
4742 - MINOR: httpclient: initialize the proxy
4743 - MINOR: httpclient: implement a simple HTTP Client API
4744 - MINOR: httpclient/cli: implement a simple client over the CLI
4745 - MINOR: httpclient/cli: change the User-Agent to "HAProxy"
4746 - MEDIUM: ssl: Keep a reference to the client's certificate for use in logs
4747 - BUG/MEDIUM: h2: match absolute-path not path-absolute for :path
4748 - BUILD/MINOR: ssl: Fix compilation with OpenSSL 1.0.2
4749 - MINOR: server: check if srv is NULL in free_server()
4750 - MINOR: proxy: check if p is NULL in free_proxy()
4751 - BUG/MEDIUM: cfgparse: do not allocate IDs to automatic internal proxies
4752 - BUG/MINOR: http_client: make sure to preset the proxy's default settings
4753 - REGTESTS: http_upgrade: fix incorrect expectation on TCP->H1->H2
4754 - REGTESTS: abortonclose: after retries, 503 is expected, not close
4755 - REGTESTS: server: fix agent-check syntax and expectation
4756 - BUG/MINOR: httpclient: fix uninitialized sl variable
4757 - BUG/MINOR: httpclient/cli: change the appctx test in the callbacks
4758 - BUG/MINOR: httpclient: check if hdr_num is not 0
4759 - MINOR: httpclient: cleanup the include files
4760 - MINOR: hlua: take the global Lua lock inside a global function
4761 - MINOR: tools: add FreeBSD support to get_exec_path()
4762 - BUG/MINOR: systemd: ExecStartPre must use -Ws
4763 - MINOR: systemd: remove the ExecStartPre line in the unit file
4764 - MINOR: ssl: add an openssl version string parser
4765 - MINOR: cfgcond: implements openssl_version_atleast and openssl_version_before
4766 - CLEANUP: ssl: remove useless check on p in openssl_version_parser()
4767 - BUG/MINOR: stick-table: fix the sc-set-gpt* parser when using expressions
4768 - BUG/MINOR: httpclient: remove deinit of the httpclient
4769 - BUG/MEDIUM: base64: check output boundaries within base64{dec,urldec}
4770 - MINOR: httpclient: set verify none on the https server
4771 - MINOR: httpclient: add the server to the proxy
4772 - BUG/MINOR: httpclient: fix Host header
4773 - BUILD: httpclient: fix build without OpenSSL
4774 - CI: github-actions: remove obsolete options
4775 - CLEANUP: assorted typo fixes in the code and comments
4776 - MINOR: proc: setting the process to produce a core dump on FreeBSD.
4777 - BUILD: adopt script/build-ssl.sh for OpenSSL-3.0.0beta2
4778 - MINOR: server: return the next srv instance on free_server
4779 - BUG/MINOR: stats: use refcount to protect dynamic server on dump
4780 - MEDIUM: server: extend refcount for all servers
4781 - MINOR: server: define non purgeable server flag
4782 - MINOR: server: mark referenced servers as non purgeable
4783 - MINOR: server: mark servers referenced by LUA script as non purgeable
4784 - MEDIUM: server: allow to remove servers at runtime except non purgeable
4785 - BUG/MINOR: base64: base64urldec() ignores padding in output size check
4786 - REGTEST: add missing lua requirements on server removal test
4787 - REGTEST: fix haproxy required version for server removal test
4788 - BUG/MINOR: proxy: don't dump servers of internal proxies
4789 - REGTESTS: Use `feature cmd` for 2.5+ tests
4790 - REGTESTS: Remove REQUIRE_VERSION=1.5 from all tests
4791 - BUG/MINOR: resolvers: mark servers with name-resolution as non purgeable
4792 - MINOR: compiler: implement an ONLY_ONCE() macro
4793 - BUG/MINOR: lua: use strlcpy2() not strncpy() to copy sample keywords
4794 - MEDIUM: ssl: Capture more info from Client Hello
4795 - MINOR: sample: Expose SSL captures using new fetchers
4796 - MINOR: sample: Add be2dec converter
4797 - MINOR: sample: Add be2hex converter
4798 - MEDIUM: config: Deprecate tune.ssl.capture-cipherlist-size
4799 - BUG/MINOR: time: fix idle time computation for long sleeps
4800 - MINOR: time: add report_idle() to report process-wide idle time
4801 - BUG/MINOR: ebtree: remove dependency on incorrect macro for bits per long
4802 - BUILD: activity: use #ifdef not #if on USE_MEMORY_PROFILING
4803 - BUILD/MINOR: defaults: eliminate warning on MAXHOSTNAMELEN with -Wundef
4804 - BUILD/MINOR: ssl: avoid a build warning on LIBRESSL_VERSION with -Wundef
4805 - IMPORT: slz: silence a build warning with -Wundef
4806 - BUILD/MINOR: regex: avoid a build warning on USE_PCRE2 with -Wundef
4807
Willy Tarreau08d0f232021-08-17 14:08:55 +020048082021/08/17 : 2.5-dev4
4809 - MINOR: log: rename 'dontloglegacyconnerr' to 'log-error-via-logformat'
4810 - MINOR: doc: rename conn_status in `option httsplog`
4811 - MINOR: proxy: disabled takes a stopping and a disabled state
4812 - MINOR: stats: shows proxy in a stopped state
4813 - BUG/MINOR: server: fix race on error path of 'add server' CLI if track
4814 - CLEANUP: thread: fix fantaisist indentation of thread_harmless_till_end()
4815 - MINOR: threads: make thread_release() not wait for other ones to complete
4816 - MEDIUM: threads: add a stronger thread_isolate_full() call
4817 - MEDIUM: servers: make the server deletion code run under full thread isolation
4818 - BUG/MINOR: server: remove srv from px list on CLI 'add server' error
4819 - MINOR: activity/fd: remove the dead_fd counter
4820 - MAJOR: fd: get rid of the DWCAS when setting the running_mask
4821 - CLEANUP: fd: remove the now unused fd_set_running()
4822 - CLEANUP: fd: remove the now unneeded fd_mig_lock
4823 - BUG/MINOR: server: update last_change on maint->ready transitions too
4824 - MINOR: spoe: Add a pointer on the filter config in the spoe_agent structure
4825 - BUG/MEDIUM: spoe: Create a SPOE applet if necessary when the last one is released
4826 - BUG/MEDIUM: spoe: Fix policy to close applets when SPOE connections are queued
4827 - MINOR: server: unmark deprecated on enable health/agent cli
4828 - MEDIUM: task: implement tasklet kill
4829 - MINOR: server: initialize fields for dynamic server check
4830 - MINOR: check: allocate default check ruleset for every backends
4831 - MINOR: check: export check init functions
4832 - MINOR: check: do not increment global maxsock at runtime
4833 - MINOR: server: implement a refcount for dynamic servers
4834 - MEDIUM: check: implement check deletion for dynamic servers
4835 - MINOR: check: enable safe keywords for dynamic servers
4836 - MEDIUM: server: implement check for dynamic servers
4837 - MEDIUM: server: implement agent check for dynamic servers
4838 - REGTESTS: server: add dynamic check server test
4839 - MINOR: doc: specify ulimit-n usage for dynamic servers
4840 - REGTESTS: server: fix dynamic server with checks test
4841 - CI: travis-ci: temporarily disable arm64 builds
4842 - BUG/MINOR: check: test if server is not null in purge
4843 - MINOR: global: define MODE_STOPPING
4844 - BUG/MINOR: server: do not use refcount in free_server in stopping mode
4845 - ADMIN: dyncookie: implement a simple dynamic cookie calculator
4846 - BUG/MINOR: check: do not reset check flags on purge
4847 - BUG/MINOR: check: fix leak on add dynamic server with agent-check error
4848 - BUG/MEDIUM: check: fix leak on agent-check purge
4849 - BUG/MEDIUM: server: support both check/agent-check on a dynamic instance
4850 - BUG/MINOR: buffer: fix buffer_dump() formatting
4851 - MINOR: channel: remove an htx block from a channel
4852 - BUG/MINOR: tcpcheck: Properly detect pending HTTP data in output buffer
4853 - BUG/MINOR: stream: Don't release a stream if FLT_END is still registered
4854 - MINOR: lua: Add a flag on lua context to know the yield capability at run time
4855 - BUG/MINOR: lua: Yield in channel functions only if lua context can yield
4856 - BUG/MINOR: lua: Don't yield in channel.append() and channel.set()
4857 - MINOR: filters/lua: Release filters before the lua context
4858 - MINOR: lua: Add a function to get a reference on a table in the stack
4859 - MEDIUM: lua: Process buffer data using an offset and a length
4860 - MEDIUM: lua: Improve/revisit the lua api to manipulate channels
4861 - DOC: Improve the lua documentation
4862 - MEDIUM: filters/lua: Add support for dummy filters written in lua
4863 - MINOR: lua: Add a function to get a filter attached to a channel class
4864 - MINOR: lua: Add flags on the lua TXN to know the execution context
4865 - MEDIUM: filters/lua: Be prepared to filter TCP payloads
4866 - MEDIUM: filters/lua: Support declaration of some filter callback functions in lua
4867 - MEDIUM: filters/lua: Add HTTPMessage class to help HTTP filtering
4868 - MINOR: filters/lua: Add request and response HTTP messages in the lua TXN
4869 - MINOR: filters/lua: Support the HTTP filtering from filters written in lua
4870 - DOC: config: Fix 'http-response send-spoe-group' documentation
4871 - BUG/MINOR: lua: Properly check negative offset in Channel/HttpMessage functions
4872 - BUG/MINOR: lua: Properly catch alloc errors when parsing lua filter directives
4873 - BUG/MEDIUM: cfgcheck: verify existing log-forward listeners during config check
4874 - MINOR: cli: delare the CLI frontend as an internal proxy
4875 - MINOR: proxy: disable warnings for internal proxies
4876 - BUG/MINOR: filters: Always set FLT_END analyser when CF_FLT_ANALYZE flag is set
4877 - BUG/MINOR: lua/filters: Return right code when txn:done() is called
4878 - DOC: lua-api: Add documentation about lua filters
4879 - CI: Remove obsolete USE_SLZ=1 CI job
4880 - CLEANUP: assorted typo fixes in the code and comments
4881 - CI: github actions: relax OpenSSL-3.0.0 version comparision
4882 - BUILD: tools: get the absolute path of the current binary on NetBSD.
4883 - DOC: Minor typo fix - 'question mark' -> 'exclamation mark'
4884 - DOC/MINOR: fix typo in management document
4885 - MINOR: http: add a new function http_validate_scheme() to validate a scheme
4886 - BUG/MAJOR: h2: verify early that non-http/https schemes match the valid syntax
4887 - BUG/MAJOR: h2: verify that :path starts with a '/' before concatenating it
4888 - BUG/MAJOR: h2: enforce stricter syntax checks on the :method pseudo-header
4889 - BUG/MEDIUM: h2: give :authority precedence over Host
4890 - REGTESTS: add a test to prevent h2 desync attacks
4891
Willy Tarreau8441deb2021-08-01 18:19:51 +020048922021/08/01 : 2.5-dev3
4893 - BUG/MINOR: arg: free all args on make_arg_list()'s error path
4894 - BUG/MINOR: cfgcond: revisit the condition freeing mechanism to avoid a leak
4895 - MEDIUM: proxy: remove long-broken 'option http_proxy'
4896 - CLEANUP: http_ana: Remove now unused label from http_process_request()
4897 - MINOR: deinit: always deinit the init_mutex on failed initialization
4898 - BUG/MEDIUM: cfgcond: limit recursion level in the condition expression parser
4899 - BUG/MEDIUM: mworker: do not register an exit handler if exit is expected
4900 - BUG/MINOR: mworker: do not export HAPROXY_MWORKER_REEXEC across programs
4901 - BUILD/MINOR: memprof fix macOs build.
4902 - BUG/MEDIUM: ssl_sample: fix segfault for srv samples on invalid request
4903 - BUG/MINOR: stats: Add missing agent stats on servers
4904 - BUG/MINOR: check: fix the condition to validate a port-less server
4905 - BUILD: threads: fix pthread_mutex_unlock when !USE_THREAD
4906 - BUG/MINOR: resolvers: Use a null-terminated string to lookup in servers tree
4907 - MINOR: ssl: use __objt_* variant when retrieving counters
4908 - BUG/MINOR: systemd: must check the configuration using -Ws
4909 - BUG/MINOR: mux-h1: Obey dontlognull option for empty requests
4910 - BUG/MINOR: mux-h2: Obey dontlognull option during the preface
4911 - BUG/MINOR: mux-h1: Be sure to swap H1C to splice mode when rcv_pipe() is called
4912 - BUG/MEDIUM: mux-h2: Handle remaining read0 cases on partial frames
4913 - MINOR: proxy: rename PR_CAP_LUA to PR_CAP_INT
4914 - MINOR: mworker: the mworker CLI proxy is internal
4915 - MINOR: stats: don't output internal proxies (PR_CAP_INT)
4916 - CLEANUP: mworker: use the proxy helper functions in mworker_cli_proxy_create()
4917 - CLEANUP: mworker: PR_CAP already initialized with alloc_new_proxy()
4918 - BUG/MINOR: connection: Add missing error labels to conn_err_code_str
4919 - MINOR: connection: Add a connection error code sample fetch
4920 - MINOR: ssl: Enable error fetches in case of handshake error
4921 - MINOR: ssl: Add new ssl_fc_hsk_err sample fetch
4922 - MINOR: ssl: Define a default https log format
4923 - MEDIUM: connection: Add option to disable legacy error log
4924 - REGTESTS: ssl: Add tests for the connection and SSL error fetches
4925 - REGTESTS: ssl: ssl_errors.vtc does not work with old openssl version
4926 - BUG/MEDIUM: connection: close a rare race between idle conn close and takeover
4927 - BUG/MEDIUM: pollers: clear the sleeping bit after waking up, not before
4928 - BUG/MINOR: select: fix excess number of dead/skip reported
4929 - BUG/MINOR: poll: fix abnormally high skip_fd counter
4930 - BUG/MINOR: pollers: always program an update for migrated FDs
4931 - BUG/MINOR: fd: protect fd state harder against a concurrent takeover
4932 - DOC: internals: document the FD takeover process
4933 - MINOR: fd: update flags only once in fd_update_events()
4934 - MINOR: poll/epoll: move detection of RDHUP support earlier
4935 - REORG: fd: uninline fd_update_events()
4936 - MEDIUM: fd: rely more on fd_update_events() to detect changes
4937 - BUG/MINOR: freq_ctr: use stricter barriers between updates and readings
4938 - MEDIUM: atomic: simplify the atomic load/store/exchange operations
4939 - MEDIUM: atomic: relax the load/store barriers on x86_64
4940 - BUILD: opentracing: fixed build when using pkg-config utility
4941
Willy Tarreaubccc91d2021-07-17 12:35:11 +020049422021/07/17 : 2.5-dev2
4943 - BUILD/MEDIUM: tcp: set-mark support for OpenBSD
4944 - DOC: config: use CREATE USER for mysql-check
4945 - BUG/MINOR: stick-table: fix several printf sign errors dumping tables
4946 - BUG/MINOR: peers: fix data_type bit computation more than 32 data_types
4947 - MINOR: stick-table: make skttable_data_cast to use only std types
4948 - MEDIUM: stick-table: handle arrays of standard types into stick-tables
4949 - MEDIUM: peers: handle arrays of std types in peers protocol
4950 - DOC: stick-table: add missing documentation about gpt0 stored type
4951 - MEDIUM: stick-table: add the new array of gpt data_type
4952 - MEDIUM: stick-table: make the use of 'gpt' excluding the use of 'gpt0'
4953 - MEDIUM: stick-table: add the new arrays of gpc and gpc_rate
4954 - MEDIUM: stick-table: make the use of 'gpc' excluding the use of 'gpc0/1''
4955 - BUG/MEDIUM: sock: make sure to never miss early connection failures
4956 - BUG/MINOR: cli: fix server name output in "show fd"
4957 - Revert "MINOR: tcp-act: Add set-src/set-src-port for "tcp-request content" rules"
4958 - MEDIUM: stats: include disabled proxies that hold active sessions to stats
4959 - BUILD: stick-table: shut up invalid "uninitialized" warning in gcc 8.3
4960 - MINOR: http: implement http_get_scheme
4961 - MEDIUM: http: implement scheme-based normalization
4962 - MEDIUM: h1-htx: apply scheme-based normalization on h1 requests
4963 - MEDIUM: h2: apply scheme-based normalization on h2 requests
4964 - REGTESTS: add http scheme-based normalization test
4965 - BUILD: http_htx: fix ci compilation error with isdigit for Windows
4966 - MINOR: http: implement http uri parser
4967 - MINOR: http: use http uri parser for scheme
4968 - MINOR: http: use http uri parser for authority
4969 - REORG: http_ana: split conditions for monitor-uri in wait for request
4970 - MINOR: http: use http uri parser for path
4971 - BUG/MEDIUM: http_ana: fix crash for http_proxy mode during uri rewrite
4972 - MINOR: mux_h2: define config to disable h2 websocket support
4973 - CLEANUP: applet: remove unused thread_mask
4974 - BUG/MINOR: ssl: Default-server configuration ignored by server
4975 - BUILD: add detection of missing important CFLAGS
4976 - BUILD: lua: silence a build warning with TCC
4977 - MINOR: srv: extract tracking server config function
4978 - MINOR: srv: do not allow to track a dynamic server
4979 - MEDIUM: server: support track keyword for dynamic servers
4980 - REGTESTS: test track support for dynamic servers
4981 - MINOR: init: verify that there is a single word on "-cc"
4982 - MINOR: init: make -cc support environment variables expansion
4983 - MINOR: arg: add a free_args() function to free an args array
4984 - CLEANUP: config: use free_args() to release args array in cfg_eval_condition()
4985 - CLEANUP: hlua: use free_args() to release args arrays
4986 - REORG: config: move the condition preprocessing code to its own file
4987 - MINOR: cfgcond: start to split the condition parser to introduce terms
4988 - MEDIUM: cfgcond: report invalid trailing chars after expressions
4989 - MINOR: cfgcond: remerge all arguments into a single line
4990 - MINOR: cfgcond: support negating conditional expressions
4991 - MINOR: cfgcond: make the conditional term parser automatically allocate nodes
4992 - MINOR: cfgcond: insert an expression between the condition and the term
4993 - MINOR: cfgcond: support terms made of parenthesis around expressions
4994 - REGTEST: make check_condition.vtc fail as soon as possible
4995 - REGTESTS: add more complex check conditions to check_conditions.vtc
4996 - BUG/MEDIUM: init: restore behavior of command-line "-m" for memory limitation
4997
Willy Tarreau96a2f502021-06-30 16:16:14 +020049982021/06/30 : 2.5-dev1
4999 - CLEANUP: ssl: Move ssl_store related code to ssl_ckch.c
5000 - MINOR: ssl: Allow duplicated entries in the cafile_tree
5001 - MEDIUM: ssl: Chain ckch instances in ca-file entries
5002 - MINOR: ssl: Add reference to default ckch instance in bind_conf
5003 - MINOR: ssl: Add helper functions to create/delete cafile entries
5004 - MEDIUM: ssl: Add a way to load a ca-file content from memory
5005 - MINOR: ssl: Add helper function to add cafile entries
5006 - MINOR: ssl: Ckch instance rebuild and cleanup factorization in CLI handler
5007 - MEDIUM: ssl: Add "set+commit ssl ca-file" CLI commands
5008 - REGTESTS: ssl: Add new ca-file update tests
5009 - MINOR: ssl: Add "abort ssl ca-file" CLI command
5010 - MINOR: ssl: Add a cafile_entry type field
5011 - MINOR: ssl: Refactorize the "show certificate details" code
5012 - MEDIUM: ssl: Add "show ssl ca-file" CLI command
5013 - MEDIUM: ssl: Add "new ssl ca-file" CLI command
5014 - MINOR: ssl: Add "del ssl ca-file" CLI command
5015 - REGTESTS: ssl: Add "new/del ssl ca-file" tests
5016 - DOC: ssl: Add documentation about CA file hot update commands
5017 - DOC: internals: update the SSL architecture schema
5018 - MINOR: ssl: Chain instances in ca-file entries
5019 - MEDIUM: ssl: Add "set+commit ssl crl-file" CLI commands
5020 - MEDIUM: ssl: Add "new+del crl-file" CLI commands
5021 - MINOR: ssl: Add "abort ssl crl-file" CLI command
5022 - MEDIUM: ssl: Add "show ssl crl-file" CLI command
5023 - REGTESTS: ssl: Add "new/del ssl crl-file" tests
5024 - REGTESTS: ssl: Add "set/commit ssl crl-file" test
5025 - DOC: ssl: Add documentation about CRL file hot update commands
5026 - BUILD/MINOR: ssl: Fix compilation with SSL enabled
5027 - BUILD/MINOR: ssl: Fix compilation with OpenSSL 1.0.2
5028 - CI: introduce scripts/build-vtest.sh for installing VTest
5029 - CLEANUP: ssl: Fix coverity issues found in CA file hot update code
5030 - CI: github actions: add OpenTracing builds
5031 - BUG/MEDIUM: ebtree: Invalid read when looking for dup entry
5032 - BUG/MAJOR: server: prevent deadlock when using 'set maxconn server'
5033 - BUILD/MINOR: opentracing: fixed build when using clang
5034 - BUG/MEDIUM: filters: Exec pre/post analysers only one time per filter
5035 - BUG/MINOR: http-comp: Preserve HTTP_MSGF_COMPRESSIONG flag on the response
5036 - MINOR: map/acl: print the count of all the map/acl entries in "show map/acl"
5037 - CLEANUP: pattern: remove export of non-existent function pattern_delete()
5038 - MINOR: h1-htx: Update h1 parsing functions to return result as a size_t
5039 - MEDIUM: h1-htx: Adapt H1 data parsing to copy wrapping data in one call
5040 - MINOR: mux-h1/mux-fcgi: Don't needlessly loop on data parsing
5041 - MINOR: h1-htx: Move HTTP chunks parsing into a dedicated function
5042 - MEDIUM: h1-htx: Split function to parse a chunk and the loop on the buffer
5043 - MEDIUM: h1-htx: Add a function to parse contiguous small chunks
5044 - MINOR: h1-htx: Use a correlation table to speed-up small chunks parsing
5045 - MINOR: buf: Add function to realign a buffer with a specific head position
5046 - MINOR: muxes/h1-htx: Realign input buffer using b_slow_realign_ofs()
5047 - CLEANUP: mux-h1: Rename functions parsing input buf and filling output buf
5048 - Revert "MEDIUM: http-ana: Deal with L7 retries in HTTP analysers"
5049 - BUG/MINOR: http-ana: Send the right error if max retries is reached on L7 retry
5050 - BUG/MINOR: http-ana: Handle L7 retries on refused early data before K/A aborts
5051 - MINOR: http-ana: Perform L7 retries because of status codes in response analyser
5052 - MINOR: cfgparse: Fail when encountering extra arguments in macro
5053 - DOC: intro: Fix typo in starter guide
5054 - BUG/MINOR: server: Missing calloc return value check in srv_parse_source
5055 - BUG/MINOR: peers: Missing calloc return value check in peers_register_table
5056 - BUG/MINOR: ssl: Missing calloc return value check in ssl_init_single_engine
5057 - BUG/MINOR: http: Missing calloc return value check in parse_http_req_capture
5058 - BUG/MINOR: proxy: Missing calloc return value check in proxy_parse_declare
5059 - BUG/MINOR: proxy: Missing calloc return value check in proxy_defproxy_cpy
5060 - BUG/MINOR: http: Missing calloc return value check while parsing tcp-request/tcp-response
5061 - BUG/MINOR: http: Missing calloc return value check while parsing tcp-request rule
5062 - BUG/MINOR: compression: Missing calloc return value check in comp_append_type/algo
5063 - BUG/MINOR: worker: Missing calloc return value check in mworker_env_to_proc_list
5064 - BUG/MINOR: http: Missing calloc return value check while parsing redirect rule
5065 - BUG/MINOR: http: Missing calloc return value check in make_arg_list
5066 - BUG/MINOR: proxy: Missing calloc return value check in chash_init_server_tree
5067 - CLEANUP: http-ana: Remove useless if statement about L7 retries
5068 - BUG/MAJOR: stream-int: Release SI endpoint on server side ASAP on retry
5069 - MINOR: backend: Don't release SI endpoint anymore in connect_server()
5070 - BUG/MINOR: vars: Be sure to have a session to get checks variables
5071 - DOC/MINOR: move uuid in the configuration to the right alphabetical order
5072 - CLEANUP: mux-fcgi: Don't needlessly store result of data/trailers parsing
5073 - BUILD: fix compilation for OpenSSL-3.0.0-alpha17
5074 - MINOR: http-ana: Use -1 status for client aborts during queuing and connect
5075 - REGTESTS: Fix http_abortonclose.vtc to support -1 status for some client aborts
5076 - CLEANUP: backend: fix incorrect comments on locking conditions for lb functions
5077 - CLEANUP: reg-tests: Remove obsolete no-htx parameter for reg-tests
5078 - CI: github actions: add OpenSSL-3.0.0 builds
5079 - CI: github actions: -Wno-deprecated-declarations with OpenSSL 3.0.0
5080 - MINOR: errors: allow empty va_args for diag variadic macro
5081 - REORG: errors: split errors reporting function from log.c
5082 - CLEANUP: server: fix cosmetic of error message on sni parsing
5083 - MEDIUM: errors: implement user messages buffer
5084 - MINOR: log: do not discard stderr when starting is over
5085 - MEDIUM: errors: implement parsing context type
5086 - MINOR: errors: use user messages context in print_message
5087 - MINOR: log: display exec path on first warning
5088 - MINOR: errors: specify prefix "config" for parsing output
5089 - MINOR: log: define server user message format
5090 - REORG: server: use parsing ctx for server parsing
5091 - REORG: config: use parsing ctx for server config check
5092 - MINOR: server: use parsing ctx for server init addr
5093 - MINOR: server: use ha_alert in server parsing functions
5094 - DOC: use the req.ssl_sni in examples
5095 - CLEANUP: cfgparse: Remove duplication of `MAX_LINE_ARGS + 1`
5096 - CLEANUP: tools: Make errptr const in `parse_line()`
5097 - MINOR: haproxy: Add `-cc` argument
5098 - BUG: errors: remove printf positional args for user messages context
5099 - CI: Make matrix.py executable and add shebang
5100 - BUILD: make tune.ssl.keylog available again
5101 - BUG/MINOR: ssl: OCSP stapling does not work if expire too far in the future
5102 - Revert "BUG/MINOR: opentracing: initialization after establishing daemon mode"
5103 - BUG/MEDIUM: opentracing: initialization before establishing daemon and/or chroot mode
5104 - SCRIPTS: opentracing: enable parallel builds in build-ot.sh
5105 - BUG/MEDIUM: compression: Fix loop skipping unused blocks to get the next block
5106 - BUG/MEDIUM: compression: Properly get the next block to iterate on payload
5107 - BUG/MEDIUM: compression: Add a flag to know the filter is still processing data
5108 - MINOR: ssl: Keep the actual key length in the certificate_ocsp structure
5109 - MINOR: ssl: Add new "show ssl ocsp-response" CLI command
5110 - MINOR: ssl: Add the OCSP entry key when displaying the details of a certificate
5111 - MINOR: ssl: Add the "show ssl cert foo.pem.ocsp" CLI command
5112 - REGTESTS: ssl: Add "show ssl ocsp-response" test
5113 - BUG/MINOR: server: explicitly set "none" init-addr for dynamic servers
5114 - BUG/MINOR: pools: fix a possible memory leak in the lockless pool_flush()
5115 - BUG/MINOR: pools: make DEBUG_UAF always write to the to-be-freed location
5116 - MINOR: pools: do not maintain the lock during pool_flush()
5117 - MINOR: pools: call malloc_trim() under thread isolation
5118 - MEDIUM: pools: use a single pool_gc() function for locked and lockless
5119 - BUG/MAJOR: pools: fix possible race with free() in the lockless variant
5120 - CLEANUP: pools: remove now unused seq and pool_free_list
5121 - MEDIUM: pools: remove the locked pools implementation
5122 - BUILD: ssl: Fix compilation with BoringSSL
5123 - BUG/MEDIUM: errors: include missing obj_type file
5124 - REGTESTS: ssl: show_ssl_ocspresponce.vtc is broken with BoringSSL
5125 - BUG/MAJOR: htx: Fix htx_defrag() when an HTX block is expanded
5126 - BUG/MINOR: mux-fcgi: Expose SERVER_SOFTWARE parameter by default
5127 - BUG/MINOR: h1-htx: Fix a signess bug with char data type when parsing chunk size
5128 - CLEANUP: l7-retries: do not test the buffer before calling b_alloc()
5129 - BUG/MINOR: resolvers: answser item list was randomly purged or errors
5130 - MEDIUM: resolvers: add a ref on server to the used A/AAAA answer item
5131 - MEDIUM: resolvers: add a ref between servers and srv request or used SRV record
5132 - BUG/MINOR: server-state: load SRV resolution only if params match the config
5133 - MINOR: config: remove support for deprecated option "tune.chksize"
5134 - MINOR: config: completely remove support for "no option http-use-htx"
5135 - MINOR: log: remove the long-deprecated early log-format tags
5136 - MINOR: http: remove the long deprecated "set-cookie()" sample fetch function
5137 - MINOR: config: reject long-deprecated "option forceclose"
5138 - MINOR: config: remove deprecated option "http-tunnel"
5139 - MEDIUM: proxy: remove the deprecated "grace" keyword
5140 - MAJOR: config: remove parsing of the global "nbproc" directive
5141 - BUILD: init: remove initialization of multi-process thread mappings
5142 - BUILD: log: remove unused fmt_directive()
5143 - REGTESTS: Remove REQUIRE_VERSION=1.6 from all tests
5144 - REGTESTS: Remove REQUIRE_VERSION=1.7 from all tests
5145 - CI: github actions: enable alpine/musl builds
5146 - BUG/MAJOR: resolvers: segfault using server template without SRV RECORDs
5147 - DOC: lua: Add a warning about buffers modification in HTTP
5148 - MINOR: ssl: Use OpenSSL's ASN1_TIME convertor when available
5149 - BUG/MINOR: stick-table: insert srv in used_name tree even with fixed id
5150 - BUG/MEDIUM: server: extend thread-isolate over much of CLI 'add server'
5151 - BUG/MEDIUM: server: clear dynamic srv on delete from proxy id/name trees
5152 - BUG/MEDIUM: server: do not forget to generate the dynamic servers ids
5153 - BUG/MINOR: server: do not keep an invalid dynamic server in px ids tree
5154 - BUG/MEDIUM: server: do not auto insert a dynamic server in px addr_node
5155 - BUG/MEDIUM: shctx: use at least thread-based locking on USE_PRIVATE_CACHE
5156 - BUG/MINOR: ssl: use atomic ops to update global shctx stats
5157 - BUG/MINOR: mworker: fix typo in chroot error message
5158 - CLEANUP: global: remove unused definition of stopping_task[]
5159 - MEDIUM: init: remove the loop over processes during init
5160 - MINOR: mworker: remove the initialization loop over processes
5161 - CLEANUP: global: remove the nbproc field from the global structure
5162 - CLEANUP: global: remove pid_bit and all_proc_mask
5163 - MEDIUM: global: remove dead code from nbproc/bind_proc removal
5164 - MEDIUM: config: simplify cpu-map handling
5165 - MEDIUM: cpu-set: make the proc a single bit field and not an array
5166 - CLEANUP: global: remove unused definition of MAX_PROCS
5167 - MEDIUM: global: remove the relative_pid from global and mworker
5168 - DOC: update references to process numbers in cpu-map and bind-process
5169 - MEDIUM: config: warn about "bind-process" deprecation
5170 - CLEANUP: shctx: remove the different inter-process locking techniques
5171 - BUG/MAJOR: queue: set SF_ASSIGNED when setting strm->target on dequeue
5172 - MINOR: backend: only skip LB when there are actual connections
5173 - BUG/MINOR: mux-h1: do not skip the error response on bad requests
5174 - MINOR: connection: add helper conn_append_debug_info()
5175 - MINOR: mux-h2/trace: report a few connection-level info during h2_init()
5176 - CLEANUP: mux-h2/traces: better align user messages
5177 - BUG/MINOR: stats: make "show stat typed desc" work again
5178 - MINOR: mux-h2: obey http-ignore-probes during the preface
5179 - BUG/MINOR: mux-h2/traces: bring back the lost "rcvd H2 REQ" trace
5180 - BUG/MINOR: mux-h2/traces: bring back the lost "sent H2 REQ/RES" traces
5181 - CLEANUP: assorted typo fixes in the code and comments
5182 - CI: Replace the requirement for 'sudo' with a call to 'ulimit -n'
5183 - REGTESTS: Replace REQUIRE_VERSION=2.5 with 'haproxy -cc'
5184 - REGTESTS: Replace REQUIRE_OPTIONS with 'haproxy -cc' for 2.5+ tests
5185 - REGTESTS: Replace REQUIRE_BINARIES with 'command -v'
5186 - REGTESTS: Remove support for REQUIRE_BINARIES
5187 - CI: ssl: enable parallel builds for OpenSSL on Linux
5188 - CI: ssl: do not needlessly build the OpenSSL docs
5189 - CI: ssl: keep the old method for ancient OpenSSL versions
5190 - CLEANUP: server: a separate function for initializing the per_thr field
5191 - BUG/MINOR: server: Forbid to set fqdn on the CLI if SRV resolution is enabled
5192 - BUG/MEDIUM: server/cli: Fix ABBA deadlock when fqdn is set from the CLI
5193 - MINOR: resolvers: Clean server in a dedicated function when removing a SRV item
5194 - MINOR: resolvers: Remove server from named_servers tree when removing a SRV item
5195 - BUG/MEDIUM: resolvers: Add a task on servers to check SRV resolution status
5196 - BUG/MINOR: backend: restore the SF_SRV_REUSED flag original purpose
5197 - BUG/MINOR: backend: do not set sni on connection reuse
5198 - BUG/MINOR: resolvers: Use resolver's lock in resolv_srvrq_expire_task()
5199 - BUG/MINOR: server/cli: Fix locking in function processing "set server" command
5200 - BUG/MINOR: cache: Correctly handle existing-but-empty 'accept-encoding' header
5201 - MINOR: ssl: fix typo in usage for 'new ssl ca-file'
5202 - MINOR: ssl: always initialize random generator
5203 - MINOR: ssl: check allocation in ssl_sock_init_srv
5204 - MINOR: ssl: check allocation in parse ciphers/ciphersuites/verifyhost
5205 - MINOR: ssl: check allocation in parse npn/sni
5206 - MINOR: server: disable CLI 'set server ssl' for dynamic servers
5207 - MINOR: ssl: render file-access optional on server crt loading
5208 - MINOR: ssl: split parse functions for alpn/check-alpn
5209 - MINOR: ssl: support ca-file arg for dynamic servers
5210 - MINOR: ssl: support crt arg for dynamic servers
5211 - MINOR: ssl: support crl arg for dynamic servers
5212 - MINOR: ssl: enable a series of ssl keywords for dynamic servers
5213 - MINOR: ssl: support ssl keyword for dynamic servers
5214 - REGTESTS: server: test ssl support for dynamic servers
5215 - MINOR: queue: update the stream's pend_pos before queuing it
5216 - CLEANUP: Prevent channel-t.h from being detected as C++ by GitHub
5217 - BUG/MAJOR: server: fix deadlock when changing maxconn via agent-check
5218 - REGTESTS: fix maxconn update with agent-check
5219 - MEDIUM: queue: make pendconn_process_next_strm() only return the pendconn
5220 - MINOR: queue: update proxy->served once out of the loop
5221 - MEDIUM: queue: refine the locking in process_srv_queue()
5222 - MINOR: lb/api: remove the locked argument from take_conn/drop_conn
5223 - MINOR: queue: create a new structure type "queue"
5224 - MINOR: proxy: replace the pendconns-related stuff with a struct queue
5225 - MINOR: server: replace the pendconns-related stuff with a struct queue
5226 - MEDIUM: queue: use a dedicated lock for the queues
5227 - MEDIUM: queue: simplify again the process_srv_queue() API
5228 - MINOR: queue: factor out the proxy/server queuing code
5229 - MINOR: queue: use atomic-ops to update the queue's index
5230 - MEDIUM: queue: determine in process_srv_queue() if the proxy is usable
5231 - MEDIUM: queue: move the queue lock manipulation to pendconn_process_next_strm()
5232 - MEDIUM: queue: unlock as soon as possible
5233 - MINOR: queue: make pendconn_first() take the lock by itself
5234 - CLEANUP: backend: remove impossible case of round-robin + consistent hash
5235 - MINOR: tcp-act: Add set-src/set-src-port for "tcp-request content" rules
5236 - DOC: config: Add missing actions in "tcp-request session" documentation
5237 - CLEANUP: dns: Remove a forgotten debug message
5238 - DOC: Replace issue templates by issue forms
5239 - Revert "MINOR: queue: make pendconn_first() take the lock by itself"
5240 - Revert "MEDIUM: queue: unlock as soon as possible"
5241 - Revert "MEDIUM: queue: move the queue lock manipulation to pendconn_process_next_strm()"
5242 - Revert "MEDIUM: queue: determine in process_srv_queue() if the proxy is usable"
5243 - Revert "MINOR: queue: use atomic-ops to update the queue's index"
5244 - Revert "MINOR: queue: factor out the proxy/server queuing code"
5245 - Revert "MEDIUM: queue: simplify again the process_srv_queue() API"
5246 - Revert "MEDIUM: queue: use a dedicated lock for the queues"
5247 - Revert "MEDIUM: queue: refine the locking in process_srv_queue()"
5248 - Revert "MINOR: queue: update proxy->served once out of the loop"
5249 - Revert "MEDIUM: queue: make pendconn_process_next_strm() only return the pendconn"
5250 - MEDIUM: queue: update px->served and lb's take_conn once per loop
5251 - MEDIUM: queue: use a dedicated lock for the queues (v2)
5252 - MEDIUM: queue: simplify again the process_srv_queue() API (v2)
5253 - MEDIUM: queue: determine in process_srv_queue() if the proxy is usable (v2)
5254 - MINOR: queue: factor out the proxy/server queuing code (v2)
5255 - MINOR: queue: use atomic-ops to update the queue's index (v2)
5256 - MEDIUM: queue: take the proxy lock only during the px queue accesses
5257 - MEDIUM: queue: use a trylock on the server's queue
5258 - MINOR: queue: add queue_init() to initialize a queue
5259 - MINOR: queue: add a pointer to the server and the proxy in the queue
5260 - MINOR: queue: store a pointer to the queue into the pendconn
5261 - MINOR: queue: remove the px/srv fields from pendconn
5262 - MINOR: queue: simplify pendconn_unlink() regarding srv vs px
5263 - BUG: backend: stop looking for queued connections once there's no more
5264 - BUG/MINOR: queue/debug: use the correct lock labels on the queue lock
5265 - BUG/MINOR: resolvers: Always attach server on matching record on resolution
5266 - BUG/MINOR: resolvers: Reset server IP when no ip is found in the response
5267 - MINOR: resolvers: Reset server IP on error in resolv_get_ip_from_response()
5268 - BUG/MINOR: checks: return correct error code for srv_parse_agent_check
5269 - BUILD: Makefile: fix linkage for Haiku.
5270 - BUG/MINOR: tcpcheck: Fix numbering of implicit HTTP send/expect rules
5271 - MINOR: http-act/tcp-act: Add "set-log-level" for tcp content rules
5272 - MINOR: http-act/tcp-act: Add "set-nice" for tcp content rules
5273 - MINOR: http-act/tcp-act: Add "set-mark" and "set-tos" for tcp content rules
5274 - CLEANUP: tcp-act: Sort action lists
5275 - BUILD/MEDIUM: tcp: set-mark setting support for FreeBSD.
5276 - BUILD: tcp-act: avoid warning when set-mark / set-tos are not supported
5277 - BUG/MINOR: mqtt: Fix parser for string with more than 127 characters
5278 - BUG/MINOR: mqtt: Support empty client ID in CONNECT message
5279 - BUG/MEDIUM: resolvers: Make 1st server of a template take part to SRV resolution
5280 - CLEANUP: peers: re-write intdecode function comment.
5281
Willy Tarreau1f973062021-05-14 09:36:37 +020052822021/05/14 : 2.5-dev0
5283 - MINOR: version: it's development again
5284
Willy Tarreau6cbbecf2021-05-14 09:03:30 +020052852021/05/14 : 2.4.0
5286 - BUG/MINOR: http_fetch: fix possible uninit sockaddr in fetch_url_ip/port
5287 - CLEANUP: cli/activity: Remove double spacing in set profiling command
5288 - CI: Build VTest with clang
5289 - CI: extend spellchecker whitelist, add "ists" as well
5290 - CLEANUP: assorted typo fixes in the code and comments
5291 - BUG/MINOR: memprof: properly account for differences for realloc()
5292 - MINOR: memprof: also report the method used by each call
5293 - MINOR: memprof: also report the totals and delta alloc-free
5294 - CLEANUP: pattern: remove the unused and dangerous pat_ref_reload()
5295 - BUG/MINOR: http_act: Fix normalizer names in error messages
5296 - MINOR: uri_normalizer: Add `fragment-strip` normalizer
5297 - MINOR: uri_normalizer: Add `fragment-encode` normalizer
5298 - IMPORT: slz: use the generic function for the last bytes of the crc32
5299 - IMPORT: slz: do not produce the crc32_fast table when CRC is natively supported
5300 - BUILD/MINOR: opentracing: fixed compilation with filter enabled
5301 - BUILD: makefile: add a few popular ARMv8 CPU targets
5302 - BUG/MEDIUM: stick_table: fix crash when using tcp smp_fetch_src
5303 - REGTESTS: stick-table: add src_conn_rate test
5304 - CLEANUP: stick-table: remove a leftover of an old keyword declaration
5305 - BUG/MINOR: stats: fix lastchk metric that got accidently lost
5306 - EXAMPLES: add a "basic-config-edge" example config
5307 - EXAMPLES: add a trivial config for quick testing
5308 - DOC: management: Correct example reload command in the document
5309 - Revert "CI: Build VTest with clang"
5310 - MINOR: activity/cli: optionally support sorting by address on "show profiling"
5311 - DEBUG: ssl: export ssl_sock_close() to see its symbol resolved in profiling
5312 - BUG/MINOR: lua/vars: prevent get_var() from allocating a new name
5313 - DOC: config: Fix configuration example for mqtt
5314 - BUG/MAJOR: config: properly initialize cpu_map.thread[] up to MAX_THREADS
5315 - BUILD: config: avoid a build warning on numa_detect_topology() without threads
5316 - DOC: update min requirements in INSTALL
5317 - IMPORT: slz: use inttypes.h instead of stdint.h
5318 - BUILD: sample: use strtoll() instead of atoll()
5319 - MINOR: version: mention that it's LTS now.
5320
Willy Tarreau46b93af2021-05-10 07:50:26 +020053212021/05/10 : 2.4-dev19
5322 - BUG/MINOR: hlua: Don't rely on top of the stack when using Lua buffers
5323 - BUG/MEDIUM: cli: prevent memory leak on write errors
5324 - BUG/MINOR: ssl/cli: fix a lock leak when no memory available
5325 - MINOR: debug: add a new "debug dev sym" command in expert mode
5326 - MINOR: pools/debug: slightly relax DEBUG_DONT_SHARE_POOLS
5327 - CI: Github Actions: switch to LibreSSL-3.3.3
5328 - MINOR: srv: close all idle connections on shutdown
5329 - MINOR: connection: move session_list member in a union
5330 - MEDIUM: mux_h1: release idling frontend conns on soft-stop
5331 - MEDIUM: connection: close front idling connection on soft-stop
5332 - MINOR: tools: add functions to retrieve the address of a symbol
5333 - CLEANUP: activity: mark the profiling and task_profiling_mask __read_mostly
5334 - MINOR: activity: add a "memory" entry to "profiling"
5335 - MINOR: activity: declare the storage for memory usage statistics
5336 - MEDIUM: activity: collect memory allocator statistics with USE_MEMORY_PROFILING
5337 - MINOR: activity: clean up the show profiling io_handler a little bit
5338 - MINOR: activity: make "show profiling" support a few arguments
5339 - MINOR: activity: make "show profiling" also dump the memoery usage
5340 - MINOR: activity: add the profiling.memory global setting
5341 - BUILD: makefile: add new option USE_MEMORY_PROFILING
5342 - MINOR: channel: Rely on HTX version if appropriate in channel_may_recv()
5343 - BUG/MINOR: stream-int: Don't block reads in si_update_rx() if chn may receive
5344 - MINOR: conn-stream: Force mux to wait for read events if abortonclose is set
5345 - MEDIUM: mux-h1: Don't block reads when waiting for the other side
5346 - BUG/MEDIUM: mux-h1: Properly report client close if abortonclose option is set
5347 - REGTESTS: Add script to test abortonclose option
5348 - MINOR: mux-h1: clean up conditions to enabled and disabled splicing
5349 - MINOR: mux-h1: Subscribe for sends if output buffer is not empty in h1_snd_pipe
5350 - MINOR: mux-h1: Always subscribe for reads when splicing is disabled
5351 - MEDIUM: mux-h1: Wake H1 stream when both sides a synchronized
5352 - CLEANUP: mux-h1: rename WAIT_INPUT/WAIT_OUTPUT flags
5353 - MINOR: mux-h1: Manage processing blocking flags on the H1 stream
5354 - BUG/MINOR: stream: Decrement server current session counter on L7 retry
5355 - BUG/MINOR: config: fix uninitialized initial state in ".if" block evaluator
5356 - BUG/MINOR: config: add a missing "ELIF_TAKE" test for ".elif" condition evaluator
5357 - BUG/MINOR: config: .if/.elif should also accept negative integers
5358 - MINOR: config: centralize the ".if"/".elif" condition parser and evaluator
5359 - MINOR: config: keep up-to-date current file/line/section in the global struct
5360 - MINOR: config: support some pseudo-variables for file/line/section
5361 - BUILD: activity: do not include malloc.h
5362 - MINOR: arg: improve the error message on missing closing parenthesis
5363 - MINOR: global: export the build features string list
5364 - MINOR: global: add version comparison functions
5365 - MINOR: config: improve .if condition error reporting
5366 - MINOR: config: make cfg_eval_condition() support predicates with arguments
5367 - MINOR: config: add predicate "defined()" to conditional expression blocks
5368 - MINOR: config: add predicates "streq()" and "strneq()" to conditional expressions
5369 - MINOR: config: add predicate "feature" to detect certain built-in features
5370 - MINOR: config: add predicates "version_atleast" and "version_before" to cond blocks
5371 - BUG/MINOR: activity: use the new pointer to calculate the new size in realloc()
5372 - BUG/MINOR: stream: properly clear the previous error mask on L7 retries
5373 - MEDIUM: log: slightly refine the output format of alerts/warnings/etc
5374 - MINOR: config: add a new message directive: .diag
5375 - CLEANUP: cli/tree-wide: properly re-align the CLI commands' help messages
5376 - BUG/MINOR: stream: Reset stream final state and si error type on L7 retry
5377 - BUG/MINOR: checks: Handle synchronous connect when a tcpcheck is started
5378 - BUG/MINOR: checks: Reschedule check on observe mode only if fastinter is set
5379 - MINOR: global: define tainted flag
5380 - MINOR: cfgparse: add a new field flags in cfg_keyword
5381 - MINOR: cfgparse: implement experimental config keywords
5382 - MINOR: action: replace match_pfx by a keyword flags field
5383 - MINOR: action: implement experimental actions
5384 - MINOR: cli: set tainted when using CLI expert/experimental mode
5385 - MINOR: stats: report tainted on show info
5386 - MINOR: http_act: mark normalize-uri as experimental
5387 - BUILD: fix usage of ha_alert without format string
5388 - MINOR: proxy: define PR_CAP_LB
5389 - BUG/MINOR: server: do not report diag for peer servers with null weight
5390 - DOC: ssl: Extra files loading now works for backends too
5391 - ADDONS: make addons/ discoverable by git via .gitignore
5392 - DOC: ssl: Add information about crl-file option
5393 - MINOR: sample: improve error reporting on missing arg to strcmp() converter
5394 - DOC: management: mention that some fields may be emitted as floats
5395 - MINOR: tools: implement trimming of floating point numbers
5396 - MINOR: tools: add a float-to-ascii conversion function
5397 - MINOR: freq_ctr: add new functions to report float measurements
5398 - MINOR: stats: avoid excessive padding of float values with trailing zeroes
5399 - MINOR: stats: add the HTML conversion for float types
5400 - MINOR: stats: pass the appctx flags to stats_fill_info()
5401 - MINOR: stats: support an optional "float" option to "show info"
5402 - MINOR: stats: use tv_remain() to precisely compute the uptime
5403 - MINOR: stats: report uptime and start time as floats with subsecond resolution
5404 - MINOR: stats: make "show info" able to report rates as floats when asked
5405 - MINOR: config: mark tune.fd.edge-triggered as experimental
5406 - REORG: vars: move the "proc" scope variables out of the global struct
5407 - REORG: threads: move all_thread_mask() to thread.h
5408 - BUILD: wdt: include signal-t.h
5409 - BUILD: auth: include missing list.h
5410 - REORG: mworker: move proc_self from global to mworker
5411 - BUILD: ssl: ssl_utils requires chunk.h
5412 - BUILD: config: cfgparse-ssl.c needs tools.h
5413 - BUILD: wurfl: wurfl.c needs tools.h
5414 - BUILD: spoe: flt_spoe.c needs tools.h
5415 - BUILD: promex: service-prometheus.c needs tools.h
5416 - BUILD: resolvers: include tools.h
5417 - BUILD: config: include tools.h in cfgparse-listen.c
5418 - BUILD: htx: include tools.h in http_htx.c
5419 - BUILD: proxy: include tools.h in proxy.c
5420 - BUILD: session: include tools.h in session.c
5421 - BUILD: cache: include tools.h in cache.c
5422 - BUILD: sink: include tools.h in sink.c
5423 - BUILD: connection: include tools.h in connection.c
5424 - BUILD: server-state: include tools.h from server_state.c
5425 - BUILD: dns: include tools.h in dns.c
5426 - BUILD: payload: include tools.h in payload.c
5427 - BUILD: vars: include tools.h in vars.c
5428 - BUILD: compression: include tools.h in compression.c
5429 - BUILD: mworker: include tools.h from mworker.c
5430 - BUILD: queue: include tools.h from queue.c
5431 - BUILD: udp: include tools.h from proto_udp.c
5432 - BUILD: stick-table: include freq_ctr.h from stick_table.h
5433 - BUILD: server: include tools.h from server.c
5434 - BUILD: server: include missing proxy.h in server.c
5435 - BUILD: sink: include proxy.h in sink.c
5436 - BUILD: mworker: include proxy.h in mworker.c
5437 - BUILD: filters: include proxy.h in filters.c
5438 - BUILD: fcgi-app: include proxy.h in fcgi-app.c
5439 - BUILD: connection: move list_mux_proto() to connection.c
5440 - REORG: stick-table: uninline stktable_alloc_data_type()
5441 - REORG: stick-table: move composite address functions to stick_table.h
5442 - REORG: config: uninline warnifnotcap() and failifnotcap()
5443 - BUILD: task: remove unused includes from task.c
5444 - MINOR: task: stop including stream.h from task.c
5445 - BUILD: connection: stop including listener-t.h
5446 - BUILD: hlua: include proxy.h from hlua.c
5447 - BUILD: mux-h1: include proxy.h from mux-h1.c
5448 - BUILD: mux-fcgi: include proxy.h from mux-fcgi.c
5449 - BUILD: listener: include proxy.h from listener.c
5450 - BUILD: http-rules: include proxy.h from http_rules.c
5451 - BUILD: thread: include log.h from thread.c
5452 - BUILD: comp: include proxy.h from flt_http_comp.c
5453 - BUILD: fd: include log.h from fd.c
5454 - BUILD: config: do not include proxy.h nor errors.h anymore in cfgparse.h
5455 - BUILD: makefile: reorder object files by build time
5456 - DOC: Fix a few grammar/spelling issues and casing of HAProxy
5457 - REGTESTS: run-regtests: match both "HAProxy" and "HA-Proxy" in the version
5458 - MINOR: version: report "HAProxy" not "HA-Proxy" in the version output
5459 - DOC: remove last occurrences of "HA-Proxy" syntax
5460 - DOC: peers: fix the protocol tag name in the doc
5461 - ADMIN: netsnmp: report "HAProxy" and not "Haproxy" in output descriptions
5462 - MEDIUM: mailers: use "HAProxy" nor "HAproxy" in the subject of messages
5463 - DOC: fix a few remainig cases of "Haproxy" and "HAproxy" in doc and comments
5464 - MINOR: tools/rnd: compute the result outside of the CAS loop
5465 - BUILD: http_fetch: address a few aliasing warnings with older compilers
5466 - BUILD: ssl: define HAVE_CRYPTO_memcmp() based on the library version
5467 - BUILD: errors: include stdarg in errors.h
5468 - REGTESTS: disable inter-thread idle connection sharing on sensitive tests
5469 - MINOR: cli: make "help" support a command in argument
5470 - MINOR: cli: sort the output of the "help" keywords
5471 - CLEANUP: cli/mworker: properly align the help messages
5472 - BUILD: memprof: make the old caller pointer a const in get_prof_bin()
5473 - BUILD: compat: include malloc_np.h for USE_MEMORY_PROFILING on FreeBSD
5474 - CI: Github Actions: enable USE_QUIC=1 for BoringSSL builds
5475 - BUG/MEDIUM: quic: fix null deref on error path in qc_conn_init()
5476 - BUILD: cli: appease a null-deref warning in cli_gen_usage_msg()
5477
Willy Tarreau080347f2021-05-01 08:25:15 +020054782021/05/01 : 2.4-dev18
5479 - DOC: Fix indentation for `path-strip-dot` normalizer
5480 - DOC: Fix RFC reference for the percent-to-uppercase normalizer
5481 - DOC: Add RFC references for the path-strip-dot(dot)? normalizers
5482 - MINOR: uri_normalizer: Add a `percent-decode-unreserved` normalizer
5483 - BUG/MINOR: mux-fcgi: Don't send normalized uri to FCGI application
5484 - REORG: htx: Inline htx functions to add HTX blocks in a message
5485 - CLEANUP: assorted typo fixes in the code and comments
5486 - DOC: general: fix white spaces for HTML converter
5487 - BUG/MINOR: ssl: ssl_sock_prepare_ssl_ctx does not return an error code
5488 - BUG/MINOR: cpuset: move include guard at the very beginning
5489 - BUG/MAJOR: fix build on musl with cpu_set_t support
5490 - BUG/MEDIUM: cpuset: fix build on MacOS
5491 - BUG/MINOR: htx: Preserve HTX flags when draining data from an HTX message
5492 - MEDIUM: htx: Refactor htx_xfer_blks() to not rely on hdrs_bytes field
5493 - CLEANUP: htx: Remove unsued hdrs_bytes field from the HTX start-line
5494 - BUG/MINOR: mux-h2: Don't encroach on the reserve when decoding headers
5495 - MEDIUM: http-ana: handle read error on server side if waiting for response
5496 - MINOR: htx: Limit length of headers name/value when a HTX message is dumped
5497 - BUG/MINOR: applet: Notify the other side if data were consumed by an applet
5498 - BUG/MINOR: hlua: Don't consume headers when starting an HTTP lua service
5499 - BUG/MEDIUM: mux-h2: Handle EOM flag when sending a DATA frame with zero-copy
5500 - CLEANUP: channel: No longer notify the producer in co_skip()/co_htx_skip()
5501 - DOC: general: fix example in set-timeout
5502 - CLEANUP: cfgparse: de-uglify early file error handling in readcfgfile()
5503 - MINOR: config: add a new "default-path" global directive
5504 - BUG/MEDIUM: peers: initialize resync timer to get an initial full resync
5505 - BUG/MEDIUM: peers: register last acked value as origin receiving a resync req
5506 - BUG/MEDIUM: peers: stop considering ack messages teaching a full resync
5507 - BUG/MEDIUM: peers: reset starting point if peers appears longly disconnected
5508 - BUG/MEDIUM: peers: reset commitupdate value in new conns
5509 - BUG/MEDIUM: peers: re-work updates lookup during the sync on the fly
5510 - BUG/MEDIUM: peers: reset tables stage flags stages on new conns
5511 - MINOR: peers: add informative flags about resync process for debugging
5512 - BUG/MEDIUM: time: fix updating of global_now upon clock drift
5513 - CLEANUP: freq_ctr: make arguments of freq_ctr_total() const
5514 - CLEANUP: hlua: rename hlua_appctx* appctx to luactx
5515 - MINOR: server: fix doc/trace on lb algo for dynamic server creation
5516 - REGTESTS: server: fix cli_add_server due to previous trace update
5517 - REGTESTS: add minimal CLI "add map" tests
5518 - DOC: management: move "set var" to the proper place
5519 - CLEANUP: map: slightly reorder the add map function
5520 - MINOR: map: get rid of map_add_key_value()
5521 - MINOR: map: show the current and next pattern version in "show map"
5522 - MINOR: map/acl: add the possibility to specify the version in "show map/acl"
5523 - MINOR: pattern: support purging arbitrary ranges of generations
5524 - MINOR: map/acl: add the possibility to specify the version in "clear map/acl"
5525 - MINOR: map/acl: add the "prepare map/acl" CLI command
5526 - MINOR: map/acl: add the "commit map/acl" CLI command
5527 - MINOR: map/acl: make "add map/acl" support an optional version number
5528 - CLEANUP: map/cli: properly align the map/acl help
5529 - BUILD: compiler: do not use already defined __read_mostly on dragonfly
5530
Willy Tarreaubfd19d62021-04-23 19:11:10 +020055312021/04/23 : 2.4-dev17
5532 - MINOIR: mux-pt/trace: Register a new trace source with its events
5533 - BUG/MINOR: mux-pt: Fix a possible UAF because of traces in mux_pt_io_cb
5534 - CI: travis: Drastically clean up .travis.yml
5535 - CLEANUP: pattern: make all pattern tables read-only
5536 - MINOR: trace: replace the trace() inline function with an equivalent macro
5537 - MINOR: initcall: uniformize the section names between MacOS and other unixes
5538 - CLEANUP: initcall: rename HA_SECTION to HA_INIT_SECTION
5539 - MINOR: compiler: add macros to declare section names
5540 - CLEANUP: initcall: rely on HA_SECTION_* instead of defining its own
5541 - MINOR: global: declare a read_mostly section
5542 - MINOR: fd: move a few read-mostly variables to their own section
5543 - MINOR: epoll: move epoll_fd to read_mostly
5544 - MINOR: kqueue: move kqueue_fd to read_mostly
5545 - MINOR: pool: move pool declarations to read_mostly
5546 - MINOR: threads: mark all_threads_mask as read_mostly
5547 - MINOR: server: move idle_conn_task to read_mostly
5548 - MINOR: protocol: move __protocol_by_family to read_mostly
5549 - MINOR: pattern: make the pat_lru_seed read_mostly
5550 - MINOR: trace: make trace sources read_mostly
5551 - MINOR: freq_ctr: add a generic function to report the total value
5552 - MEDIUM: freq_ctr: make read_freq_ctr_period() use freq_ctr_total()
5553 - MEDIUM: freq_ctr: reimplement freq_ctr_remain_period() from freq_ctr_total()
5554 - MINOR: freq_ctr: add the missing next_event_delay_period()
5555 - MINOR: freq_ctr: unify freq_ctr and freq_ctr_period into freq_ctr
5556 - MEDIUM: freq_ctr: replace the per-second counters with the generic ones
5557 - MINOR: freq_ctr: add cpu_relax in the rotation loop of update_freq_ctr_period()
5558 - MINOR: freq_ctr: simplify and improve the update function
5559 - CLEANUP: time: remove the now unused ms_left_scaled
5560 - MINOR: time: move the time initialization out of tv_update_date()
5561 - MINOR: time: remove useless variable copies in tv_update_date()
5562 - MINOR: time: change the global timeval and the the global tick at once
5563 - MEDIUM: time: make the clock offset global and no per-thread
5564 - MINOR: atomic: reimplement the relaxed version of x86 BTS/BTR
5565 - MINOR: trace: Add the checks as a possible trace source
5566 - MINOIR: checks/trace: Register a new trace source with its events
5567 - MINOR: hlua: Add function to release a lua function
5568 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a task
5569 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a converter
5570 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a fetch
5571 - BUG/MINOR: hlua: Fix memory leaks on error path when parsing a lua action
5572 - BUG/MINOR: hlua: Fix memory leaks on error path when registering an action
5573 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a service
5574 - BUG/MINOR: hlua: Fix memory leaks on error path when registering a cli keyword
5575 - BUG/MINOR: cfgparse/proxy: Fix some leaks during proxy section parsing
5576 - BUG/MINOR: listener: Handle allocation error when allocating a new bind_conf
5577 - BUG/MINOR: cfgparse/proxy: Hande allocation errors during proxy section parsing
5578 - MINOR: cfgparse/proxy: Group alloc error handling during proxy section parsing
5579 - DOC: internals: update the SSL architecture schema
5580 - BUG/MEDIUM: sample: Fix adjusting size in field converter
5581 - MINOR: sample: add ub64dec and ub64enc converters
5582 - CLEANUP: sample: align samples list in sample.c
5583 - MINOR: ist: Add `istclear(struct ist*)`
5584 - CI: cirrus: install "pcre" package
5585 - MINOR: opentracing: correct calculation of the number of arguments in the args[]
5586 - MINOR: opentracing: transfer of context names without prefix
5587 - MINOR: sample: converter: Add mjson library.
5588 - MINOR: sample: converter: Add json_query converter
5589 - CI: travis-ci: enable weekly graviton2 builds
5590 - DOC: ssl: Certificate hot update only works on fronted certificates
5591 - DOC: ssl: Certificate hot update works on server certificates
5592 - BUG/MEDIUM: threads: Ignore current thread to end its harmless period
5593 - MINOR: threads: Only consider running threads to end a thread harmeless period
5594 - BUG/MINOR: checks: Set missing id to the dummy checks frontend
5595 - MINOR: logs: Add support of checks as session origin to format lf strings
5596 - BUG/MINOR: connection: Fix fc_http_major and bc_http_major for TCP connections
5597 - MINOR: connection: Make bc_http_major compatible with tcp-checks
5598 - BUG/MINOR: ssl-samples: Fix ssl_bc_* samples when called from a health-check
5599 - BUG/MINOR: http-fetch: Make method smp safe if headers were already forwarded
5600 - MINOR: tcp_samples: Add samples to get src/dst info of the backend connection
5601 - MINOR: tcp_samples: Be able to call bc_src/bc_dst from the health-checks
5602 - BUG/MINOR: http_htx: Remove BUG_ON() from http_get_stline() function
5603 - BUG/MINOR: logs: Report the true number of retries if there was no connection
5604 - BUILD: makefile: Redirect stderr to /dev/null when probing options
5605 - MINOR: uri_normalizer: Add uri_normalizer module
5606 - MINOR: uri_normalizer: Add `enum uri_normalizer_err`
5607 - MINOR: uri_normalizer: Add `http-request normalize-uri`
5608 - MINOR: uri_normalizer: Add a `merge-slashes` normalizer to http-request normalize-uri
5609 - MINOR: uri_normalizer: Add a `dotdot` normalizer to http-request normalize-uri
5610 - MINOR: uri_normalizer: Add support for supressing leading `../` for dotdot normalizer
5611 - MINOR: uri_normalizer: Add a `sort-query` normalizer
5612 - MINOR: uri_normalizer: Add a `percent-upper` normalizer
5613 - MEDIUM: http_act: Rename uri-normalizers
5614 - DOC: Add introduction to http-request normalize-uri
5615 - DOC: Note that URI normalization is experimental
5616 - BUG/MINOR: pools: maintain consistent ->allocated count on alloc failures
5617 - BUG/MINOR: pools/buffers: make sure to always reserve the required buffers
5618 - MINOR: pools: drop the unused static history of artificially failed allocs
5619 - CLEANUP: pools: remove unused arguments to pool_evict_from_cache()
5620 - MEDIUM: pools: move the cache into the pool header
5621 - MINOR: pool: remove the size field from pool_cache_head
5622 - MINOR: pools: rename CONFIG_HAP_LOCAL_POOLS to CONFIG_HAP_POOLS
5623 - MINOR: pools: enable the fault injector in all allocation modes
5624 - MINOR: pools: make the basic pool_refill_alloc()/pool_free() update needed_avg
5625 - MEDIUM: pools: unify pool_refill_alloc() across all models
5626 - CLEANUP: pools: re-merge pool_refill_alloc() and __pool_refill_alloc()
5627 - MINOR: pools: call pool_alloc_nocache() out of the pool's lock
5628 - CLEANUP: pools: move the lock to the only __pool_get_first() that needs it
5629 - CLEANUP: pools: rename __pool_get_first() to pool_get_from_shared_cache()
5630 - CLEANUP: pools: rename pool_*_{from,to}_cache() to *_local_cache()
5631 - CLEANUP: pools: rename __pool_free() to pool_put_to_shared_cache()
5632 - MINOR: tools: add statistical_prng_range() to get a random number over a range
5633 - MINOR: pools: use cheaper randoms for fault injections
5634 - MINOR: pools: move the fault injector to __pool_alloc()
5635 - MINOR: pools: split the OS-based allocator in two
5636 - MINOR: pools: always use atomic ops to maintain counters
5637 - MINOR: pools: move pool_free_area() out of the lock in the locked version
5638 - MINOR: pools: factor the release code into pool_put_to_os()
5639 - MEDIUM: pools: make CONFIG_HAP_POOLS control both local and shared pools
5640 - MINOR: pools: create unified pool_{get_from,put_to}_cache()
5641 - MINOR: pools: evict excess objects using pool_evict_from_local_cache()
5642 - MEDIUM: pools: make pool_put_to_cache() always call pool_put_to_local_cache()
5643 - CLEANUP: pools: make the local cache allocator fall back to the shared cache
5644 - CLEANUP: pools: merge pool_{get_from,put_to}_local_caches with generic ones
5645 - CLEANUP: pools: uninline pool_put_to_cache()
5646 - CLEANUP: pools: declare dummy pool functions to remove some ifdefs
5647 - BUILD: pools: fix build with DEBUG_FAIL_ALLOC
5648 - BUG/MINOR: server: make srv_alloc_lb() allocate lb_nodes for consistent hash
5649 - CONTRIB: mod_defender: import the minimal number of includes
5650 - CONTRIB: mod_defender: make the code build with the embedded includes
5651 - CONTRIB: modsecurity: import the minimal number of includes
5652 - CONTRIB: modsecurity: make the code build with the embedded includes
5653 - CLEANUP: sample: Improve local variables in sample_conv_json_query
5654 - CLEANUP: sample: Explicitly handle all possible enum values from mjson
5655 - CLEANUP: sample: Use explicit return for successful `json_query`s
5656 - CLEANUP: lists/tree-wide: rename some list operations to avoid some confusion
5657 - CONTRIB: move spoa_example out of the tree
5658 - BUG/MINOR: server: free srv.lb_nodes in free_server
5659 - BUG/MINOR: logs: free logsrv.conf.file on exit
5660 - BUG/MEDIUM: server: ensure thread-safety of server runtime creation
5661 - MINOR: server: add log on dynamic server creation
5662 - MINOR: server: implement delete server cli command
5663 - CONTRIB: move spoa_server out of the tree
5664 - CONTRIB: move modsecurity out of the tree
5665 - BUG/MINOR: server: fix potential null gcc error in delete server
5666 - BUG/MAJOR: mux-h2: Properly detect too large frames when decoding headers
5667 - BUG/MEDIUM: mux-h2: Fix dfl calculation when merging CONTINUATION frames
5668 - BUG/MINOR: uri_normalizer: Use delim parameter when building the sorted query in uri_normalizer_query_sort
5669 - CLEANUP: uri_normalizer: Remove trailing whitespace
5670 - MINOR: uri_normalizer: Add a `strip-dot` normalizer
5671 - CONTRIB: move mod_defender out of the tree
5672 - CLEANUP: contrib: remove the last references to the now dead contrib/ directory
5673 - BUG/MEDIUM: config: fix cpu-map notation with both process and threads
5674 - MINOR: config: add a diag for invalid cpu-map statement
5675 - BUG/MINOR: mworker/init: don't reset nb_oldpids in non-mworker cases
5676 - BUG/MINOR: mworker: don't use oldpids[] anymore for reload
5677 - BUILD: makefile: fix the "make clean" target on strict bourne shells
5678 - IMPORT: slz: import slz into the tree
5679 - BUILD: compression: switch SLZ from out-of-tree to in-tree
5680 - CI: github: do not build libslz any more
5681 - CLEANUP: compression: remove calls to SLZ init functions
5682 - BUG/MEDIUM: mux-h2: Properly handle shutdowns when received with data
5683 - MINOR: cpuset: define a platform-independent cpuset type
5684 - MINOR: cfgparse: use hap_cpuset for parse_cpu_set
5685 - MEDIUM: config: use platform independent type hap_cpuset for cpu-map
5686 - MINOR: thread: implement the detection of forced cpu affinity
5687 - MINOR: cfgparse: support the comma separator on parse_cpu_set
5688 - MEDIUM: cfgparse: detect numa and set affinity if needed
5689 - MINOR: global: add option to disable numa detection
5690 - BUG/MINOR: haproxy: fix compilation on macOS
5691 - BUG/MINOR: cpuset: fix compilation on platform without cpu affinity
5692 - MINOR: time: avoid unneeded updates to now_offset
5693 - MINOR: time: avoid overwriting the same values of global_now
5694 - CLEANUP: time: use __tv_to_ms() in tv_update_date() instead of open-coding
5695 - MINOR: time: avoid u64 needlessly expensive computations for the 32-bit now_ms
5696 - BUG/MINOR: peers: remove useless table check if initial resync is finished
5697 - BUG/MEDIUM: peers: re-work connection to new process during reload.
5698 - BUG/MEDIUM: peers: re-work refcnt on table to protect against flush
5699 - BUG/MEDIUM: config: fix missing initialization in numa_detect_topology()
5700
Willy Tarreau86512dd2021-04-09 17:10:39 +020057012021/04/09 : 2.4-dev16
5702 - CLEANUP: dev/flags: remove useless test in the stdin number parser
5703 - MINOR: No longer rely on deprecated sample fetches for predefined ACLs
5704 - MINOR: acl: Add HTTP_2.0 predefined macro
5705 - BUG/MINOR: hlua: Detect end of request when reading data for an HTTP applet
5706 - BUG/MINOR: tools: fix parsing "us" unit for timers
5707 - MINOR: server/bind: add support of new prefixes for addresses.
5708 - MINOR: log: register config file and line number on log servers.
5709 - MEDIUM: log: support tcp or stream addresses on log lines.
5710 - BUG/MEDIUM: log: fix config parse error logging on stdout/stderr or any raw fd
5711 - CLEANUP: fd: remove FD_POLL_DATA and FD_POLL_STICKY
5712 - MEDIUM: fd: prepare FD_POLL_* to move to bits 8-15
5713 - MEDIUM: fd: merge fdtab[].ev and state for FD_EV_* and FD_POLL_* into state
5714 - MINOR: fd: move .linger_risk into fdtab[].state
5715 - MINOR: fd: move .cloned into fdtab[].state
5716 - MINOR: fd: move .initialized into fdtab[].state
5717 - MINOR: fd: move .et_possible into fdtab[].state
5718 - MINOR: fd: move .exported into fdtab[].state
5719 - MINOR: fd: implement an exclusive syscall bit to remove the ugly "log" lock
5720 - MINOR: cli/show-fd: slightly reorganize the FD status flags
5721 - MINOR: atomic/arm64: detect and use builtins for the double-word CAS
5722 - CLEANUP: atomic: add an explicit _FETCH variant for add/sub/and/or
5723 - CLEANUP: atomic: make all standard add/or/and/sub operations return void
5724 - CLEANUP: atomic: add a fetch-and-xxx variant for common operations
5725 - CLEANUP: atomic: add HA_ATOMIC_INC/DEC for unit increments
5726 - CLEANUP: atomic/tree-wide: replace single increments/decrements with inc/dec
5727 - CLEANUP: atomic: use the __atomic variant of BTS/BTR on modern compilers
5728 - MINOR: atomic: implement native BTS/BTR for x86
5729 - MINOR: ist: Add `istappend(struct ist, char)`
5730 - MINOR: ist: Add `istshift(struct ist*)`
5731 - MINOR: ist: Add `istsplit(struct ist*, char)`
5732 - BUG/MAJOR: fd: switch temp values to uint in fd_stop_both()
5733 - MINOR: opentracing: register config file and line number on log servers
5734 - MEDIUM: resolvers: add support of tcp address on nameserver line.
5735 - MINOR: ist: Rename istappend() to __istappend()
5736 - CLEANUP: htx: Make http_get_stline take a `const struct`
5737 - CLEANUP: ist: Remove unused `count` argument from `ist2str*`
5738 - CLEANUP: Remove useless malloc() casts
5739
Willy Tarreau59fa1d12021-04-02 19:16:32 +020057402021/04/02 : 2.4-dev15
5741 - BUG/MINOR: payload: Wait for more data if buffer is empty in payload/payload_lv
5742 - BUG/MINOR: stats: Apply proper styles in HTML status page.
5743 - BUG/MEDIUM: time: make sure to always initialize the global tick
5744 - BUG/MINOR: tcp: fix silent-drop workaround for IPv6
5745 - BUILD: tcp: use IPPROTO_IPV6 instead of SOL_IPV6 on FreeBSD/MacOS
5746 - CLEANUP: socket: replace SOL_IP/IPV6/TCP with IPPROTO_IP/IPV6/TCP
5747 - BUG/MINOR: http_fetch: make hdr_ip() resistant to empty fields
5748 - BUG/MINOR: mux-h2: Don't emit log twice if an error occurred on the preface
5749 - MINOR: stream: Don't trigger errors on destructive HTTP upgrades
5750 - MINOR: frontend: Create HTTP txn for HTX streams
5751 - MINOR: stream: Be sure to set HTTP analysers when creating an HTX stream
5752 - BUG/MINOR: stream: Properly handle TCP>H1>H2 upgrades in http_wait_for_request
5753 - BUG/MINOR: config: Add warning for http-after-response rules in TCP mode
5754 - MINOR: muxes: Add a flag to notify a mux does not support any upgrade
5755 - MINOR: mux-h1: Don't perform implicit HTTP/2 upgrade if not supported by mux
5756 - MINOR: mux-pt: Don't perform implicit HTTP upgrade if not supported by mux
5757 - MEDIUM: mux-h1: Expose h1 in the list of supported mux protocols
5758 - MEDIUM: mux-pt: Expose passthrough in the list of supported mux protocols
5759 - MINOR: muxes: Show muxes flags when the mux list is displayed
5760 - DOC: config: Improve documentation about proto/check-proto keywords
5761 - MINOR: stream: Use stream type instead of proxy mode when appropriate
5762 - MINOR: filters/http-ana: Decide to filter HTTP headers in HTTP analysers
5763 - MINOR: http-ana: Simplify creation/destruction of HTTP transactions
5764 - MINOR: stream: Handle stream HTTP upgrade in a dedicated function
5765 - MEDIUM: Add tcp-request switch-mode action to perform HTTP upgrade
5766 - MINOR: config/proxy: Don't warn for HTTP rules in TCP if 'switch-mode http' set
5767 - MINOR: config/proxy: Warn if a TCP proxy without backend is upgradable to HTTP
5768 - DOC: config: Add documentation about TCP to HTTP upgrades
5769 - REGTESTS: Add script to tests TCP to HTTP upgrades
5770 - BUG/MINOR: payload/htx: Ingore L6 sample fetches for HTX streams/checks
5771 - MINOR: htx: Make internal.strm.is_htx an internal sample fetch
5772 - MINOR: action: Use a generic function to check validity of an action rule list
5773 - MINOR: payload/config: Warn if a L6 sample fetch is used from an HTTP proxy
5774 - MEDIUM: http-rules: Add wait-for-body action on request and response side
5775 - REGTESTS: Add script to tests the wait-for-body HTTP action
5776 - BUG/MINOR: http-fetch: Fix test on message state to capture the version
5777 - CLEANUP: vars: always pre-initialize smp in vars_parse_cli_get_var()
5778 - MINOR: global: define diagnostic mode of execution
5779 - MINOR: cfgparse: diag for multiple nbthread statements
5780 - MINOR: server: diag for 0 weight server
5781 - MINOR: diag: create cfgdiag module
5782 - MINOR: diag: diag if servers use the same cookie value
5783 - MINOR: config: diag if global section after non-global
5784 - TESTS: slightly reorganize the code in the tests/ directory
5785 - TESTS: move tests/*.cfg to tests/config
5786 - REGTESTS: ssl: "set ssl cert" and multi-certificates bundle
5787 - REGTESTS: ssl: mark set_ssl_cert_bundle.vtc as broken
5788 - CONTRIB: halog: fix issue with array of type char
5789 - CONTRIB: tcploop: add a shutr command
5790 - CONTRIB: debug: add the show-fd-to-flags script
5791 - CONTRIB: debug: split poll from flags
5792 - CONTRIB: move some dev-specific tools to dev/
5793 - BUILD: makefile: always build the flags utility
5794 - DEV: flags: replace the unneeded makefile with a README
5795 - BUILD: makefile: integrate the hpack tools
5796 - CONTRIB: merge ip6range with iprange
5797 - CONTRIB: move some admin-related sub-projects to admin/
5798 - CONTRIB: move halog to admin/
5799 - ADMIN: halog: automatically enable USE_MEMCHR on the right glibc version
5800 - BUILD: makefile: build halog with the correct flags
5801 - BUILD: makefile: add a "USE_PROMEX" variable to ease building prometheus-exporter
5802 - CONTRIB: move prometheus-exporter to addons/promex
5803 - DOC: add a few words about USE_* and the addons directory
5804 - CONTRIB: move 51Degrees to addons/51degrees
5805 - CONTRIB: move src/da.c and contrib/deviceatlas to addons/deviceatlas
5806 - CONTRIB: move src/wurfl.c and contrib/wurfl to addons/wurfl
5807 - CONTRIB: move contrib/opentracing to addons/ot
5808 - BUG/MINOR: opentracing: initialization after establishing daemon mode
5809 - DOC: clarify that compression works for HTTP/2
5810
Willy Tarreauaf6d88b2021-03-27 09:42:09 +010058112021/03/27 : 2.4-dev14
5812 - MEDIUM: quic: Fix build.
5813 - MEDIUM: quic: Fix build.
5814 - CI: codespell: whitelist "Dragan Dosen"
5815 - CLEANUP: assorted typo fixes in the code and comments
5816 - CI: github actions: update LibreSSL to 3.2.5
5817 - REGTESTS: revert workaround for a crash with recent libressl on http-reuse sni
5818 - CLEANUP: mark defproxy as const on parse tune.fail-alloc
5819 - REGTESTS: remove unneeded experimental-mode in cli add server test
5820 - REGTESTS: wait for proper return of enable server in cli add server test
5821 - MINOR: compression: use pool_alloc(), not pool_alloc_dirty()
5822 - MINOR: spoe: use pool_alloc(), not pool_alloc_dirty()
5823 - MINOR: fcgi-app: use pool_alloc(), not pool_alloc_dirty()
5824 - MINOR: cache: use pool_alloc(), not pool_alloc_dirty()
5825 - MINOR: ssl: use pool_alloc(), not pool_alloc_dirty()
5826 - MINOR: opentracing: use pool_alloc(), not pool_alloc_dirty()
5827 - MINOR: dynbuf: make b_alloc() always check if the buffer is allocated
5828 - CLEANUP: compression: do not test for buffer before calling b_alloc()
5829 - CLEANUP: l7-retries: do not test the buffer before calling b_alloc()
5830 - MINOR: channel: simplify the channel's buffer allocation
5831 - MEDIUM: dynbuf: remove last usages of b_alloc_margin()
5832 - CLEANUP: dynbuf: remove b_alloc_margin()
5833 - CLEANUP: dynbuf: remove the unused b_alloc_fast() function
5834 - CLEANUP: pools: remove the unused pool_get_first() function
5835 - MINOR: pools: make the pool allocator support a few flags
5836 - MINOR: pools: add pool_zalloc() to return a zeroed area
5837 - CLEANUP: connection: use pool_zalloc() in conn_alloc_hash_node()
5838 - CLEANUP: filters: use pool_zalloc() in flt_stream_add_filter()
5839 - CLEANUP: spoe: use pool_zalloc() instead of pool_alloc+memset
5840 - CLEANUP: frontend: use pool_zalloc() in frontend_accept()
5841 - CLEANUP: mailers: use pool_zalloc() in enqueue_one_email_alert()
5842 - CLEANUP: resolvers: use pool_zalloc() in resolv_link_resolution()
5843 - CLEANUP: ssl: use pool_zalloc() in ssl_init_keylog()
5844 - CLEANUP: tcpcheck: use pool_zalloc() instead of pool_alloc+memset
5845 - CLEANUP: quic: use pool_zalloc() instead of pool_alloc+memset
5846 - MINOR: time: also provide a global, monotonic global_now_ms timer
5847 - BUG/MEDIUM: freq_ctr/threads: use the global_now_ms variable
5848 - MINOR: tools: introduce new option PA_O_DEFAULT_DGRAM on str2sa_range.
5849 - BUILD: tools: fix build error with new PA_O_DEFAULT_DGRAM
5850 - BUG/MINOR: ssl: Prevent disk access when using "add ssl crt-list"
5851 - CLEANUP: ssl: remove unused definitions
5852 - BUILD: ssl: guard ecdh functions with SSL_CTX_set_tmp_ecdh macro
5853 - MINOR: lua: Slightly improve function dumping the lua traceback
5854 - BUG/MEDIUM: debug/lua: Use internal hlua function to dump the lua traceback
5855 - BUG/MEDIUM: lua: Always init the lua stack before referencing the context
5856 - MINOR: fd: make fd_clr_running() return the remaining running mask
5857 - MINOR: fd: remove the unneeded running bit from fd_insert()
5858 - BUG/MEDIUM: fd: do not wait on FD removal in fd_delete()
5859 - CLEANUP: fd: remove unused fd_set_running_excl()
5860 - CLEANUP: fd: slightly simplify up _fd_delete_orphan()
5861 - BUG/MEDIUM: fd: Take the fd_mig_lock when closing if no DWCAS is available.
5862 - BUG/MEDIUM: release lock on idle conn killing on reached pool high count
5863 - BUG/MEDIUM: thread: Fix a deadlock if an isolated thread is marked as harmless
5864 - MINOR: tools: make url2ipv4 return the exact number of bytes parsed
5865 - BUG/MINOR: http_fetch: make hdr_ip() reject trailing characters
5866 - BUG/MEDIUM: mux-h1: make h1_shutw_conn() idempotent
5867 - BUG/MINOR: ssl: Fix update of default certificate
5868 - BUG/MINOR: ssl: Prevent removal of crt-list line if the instance is a default one
5869 - BUILD: ssl: introduce fine guard for ssl random extraction functions
5870 - REORG: global: move initcall register code in a dedicated file
5871 - REORG: global: move free acl/action in their related source files
5872 - REORG: split proxy allocation functions
5873 - MINOR: proxy: implement a free_proxy function
5874 - MINOR: proxy: define cap PR_CAP_LUA
5875 - MINOR: lua: properly allocate the lua Socket proxy
5876 - MINOR: lua: properly allocate the lua Socket servers
5877 - MINOR: vars: make get_vars() allow the session to be null
5878 - MINOR: vars: make the var() sample fetch keyword depend on nothing
5879 - CLEANUP: sample: remove duplicate "stopping" sample fetch keyword
5880 - MINOR: sample: make smp_resolve_args() return an allocate error message
5881 - MINOR: sample: add a new SMP_SRC_CONST sample capability
5882 - MINOR: sample: mark the truly constant sample fetch keywords as such
5883 - MINOR: sample: add a new CFG_PARSER context for samples
5884 - MINOR: action: add a new ACT_F_CFG_PARSER origin designation
5885 - MEDIUM: vars: add support for a "set-var" global directive
5886 - REGTESTS: add a basic reg-test for some "set-var" commands
5887 - MINOR: sample: add a new CLI_PARSER context for samples
5888 - MINOR: action: add a new ACT_F_CLI_PARSER origin designation
5889 - MINOR: vars/cli: add a "get var" CLI command to retrieve global variables
5890 - MEDIUM: cli: add a new experimental "set var" command
5891 - MINOR: compat: add short aliases for a few very commonly used types
5892 - BUILD: ssl: use EVP_CIPH_GCM_MODE macro instead of HA_OPENSSL_VERSION
5893 - MEDIUM: backend: use a trylock to grab a connection on high FD counts as well
5894
Willy Tarreau09cc6692021-03-19 17:16:18 +010058952021/03/19 : 2.4-dev13
5896 - BUG/MEDIUM: cli: fix "help" crashing since recent spelling fixes
5897 - BUG/MINOR: cfgparse: use the GLOBAL not LISTEN keywords list for spell checking
5898 - MINOR: tools: improve word fingerprinting by counting presence
5899 - MINOR: tools: do not sum squares of differences for word fingerprints
5900 - MINOR: cli: improve fuzzy matching to work on all remaining words at once
5901 - MINOR: cli: sort the suggestions by order of relevance
5902 - MINOR: cli: limit spelling suggestions to 5
5903 - MINOR: cfgparse/proxy: also support spelling fixes on options
5904 - BUG/MINOR: resolvers: Add missing case-insensitive comparisons of DNS hostnames
5905 - MINOR: time: export the global_now variable
5906 - BUG/MINOR: freq_ctr/threads: make use of the last updated global time
5907 - MINOR: freq_ctr/threads: relax when failing to update a sliding window value
5908 - MINOR/BUG: mworker/cli: do not use the unix_bind prefix for the master CLI socket
5909 - MINOR: mworker/cli: alert the user if we enabled a master CLI but not the master-worker mode
5910 - MINOR: cli: implement experimental-mode
5911 - REORG: server: add a free server function
5912 - MINOR: cfgparse: always alloc idle conns task
5913 - REORG: server: move keywords in srv_kws
5914 - MINOR: server: remove fastinter from mistyped kw list
5915 - REORG: server: split parse_server
5916 - REORG: server: move alert traces in parse_server
5917 - REORG: server: rename internal functions from parse_server
5918 - REORG: server: attach servers in parse_server
5919 - REORG: server: use flags for parse_server
5920 - MINOR: server: prepare parsing for dynamic servers
5921 - MINOR: stats: export function to allocate extra proxy counters
5922 - MEDIUM: server: implement 'add server' cli command
5923 - REGTESTS: implement test for 'add server' cli
5924 - MINOR: server: enable standard options for dynamic servers
5925 - MINOR: server: support keyword proto in 'add server' cli
5926 - BUG/MINOR: protocol: add missing support of dgram unix socket.
5927 - CLEANUP: Fix a typo in fix_is_valid description
5928 - MINOR: raw_sock: Add a close method.
5929 - MEDIUM: connections: Introduce a new XPRT method, start().
5930 - MEDIUM: connections: Implement a start() method for xprt_handshake.
5931 - MEDIUM: connections: Implement a start() method in ssl_sock.
5932 - MINOR: muxes: garbage collect the reset() method.
5933 - CLEANUP: tcp-rules: Fix a typo in error messages about expect-netscaler-cip
5934 - MEDIUM: lua: Use a per-thread counter to track some non-reentrant parts of lua
5935 - BUG/MEDIUM: debug/lua: Don't dump the lua stack if not dumpable
5936
Willy Tarreauacdd47d2021-03-13 11:48:28 +010059372021/03/13 : 2.4-dev12
5938 - CLEANUP: connection: Use `VAR_ARRAY` in `struct tlv` definition
5939 - CLEANUP: connection: Remove useless test for NULL before calling `pool_free()`
5940 - CLEANUP: connection: Use istptr / istlen for proxy_unique_id
5941 - MINOR: connection: Use a `struct ist` to store proxy_authority
5942 - CLEANUP: connection: Consistently use `struct ist` to process all TLV types
5943 - BUILD: task: fix build at -O0 with threads disabled
5944 - BUILD: bug: refine HA_LINK_ERROR() to only be used on gcc and derivatives
5945 - CLEANUP: config: make the cfg_keyword parsers take a const for the defproxy
5946 - BUILD: connection: do not use VAR_ARRAY in struct tlv
5947 - BUG/MEDIUM: session: NULL dereference possible when accessing the listener
5948 - MINOR: build: force CC to set a return code when probing options
5949 - CLEANUP: stream: rename a few remaining occurrences of "stream *sess"
5950 - BUG/MEDIUM: resolvers: handle huge responses over tcp servers.
5951 - CLEANUP: config: also address the cfg_keyword API change in the compression code
5952 - BUG/MEDIUM: ssl: properly remove the TASK_HEAVY flag at end of handshake
5953 - BUG/MINOR: sample: Rename SenderComID/TargetComID to SenderCompID/TargetCompID
5954 - MINOR: task: give the scheduler a bit more flexibility in the runqueue size
5955 - OPTIM: task: automatically adjust the default runqueue-depth to the threads
5956 - BUG/MINOR: connection: Missing QUIC initialization
5957 - BUG/MEDIUM: stick-tables: fix ref counter in table entry using multiple http tracksc.
5958 - BUILD: atomic/arm64: force the register pairs to use in __ha_cas_dw()
5959 - BUG/MEDIUM: filters: Set CF_FL_ANALYZE on channels when filters are attached
5960 - BUG/MINOR: tcpcheck: Update .health threshold of agent inside an agent-check
5961 - BUG/MINOR: proxy/session: Be sure to have a listener to increment its counters
5962 - BUG/MINOR: tcpcheck: Fix double free on error path when parsing tcp/http-check
5963 - BUG/MINOR: server-state: properly handle the case where the base is not set
5964 - BUG/MINOR: server-state: use the argument, not the global state
5965 - CLEANUP: tcp-rules: add missing actions in the tcp-request error message
5966 - CLEANUP: vars: make the error message clearer on missing arguments for set-var
5967 - CLEANUP: http-rules: remove the unexpected comma before the list of action keywords
5968 - CLEANUP: actions: the keyword must always be const from the rule
5969 - MINOR: tools: add simple word fingerprinting to find similar-looking words
5970 - MINOR: cfgparse: add cfg_find_best_match() to suggest an existing word
5971 - MINOR: cfgparse: suggest correct spelling for unknown words in proxy sections
5972 - MINOR: cfgparse: suggest correct spelling for unknown words in global section
5973 - MINOR: cfgparse/server: try to fix spelling mistakes on server lines
5974 - MINOR: cfgparse/bind: suggest correct spelling for unknown bind keywords
5975 - MINOR: actions: add a function to suggest an action ressembling a given word
5976 - MINOR: http-rules: suggest approaching action names on mismatch
5977 - MINOR: tcp-rules: suggest approaching action names on mismatch
5978 - BUG/MINOR: cfgparse/server: increment the extra keyword counter one at a time
5979 - Revert "BUG/MINOR: resolvers: Only renew TTL for SRV records with an additional record"
5980 - BUG/MINOR: resolvers: Consider server to have no IP on DNS resolution error
5981 - BUG/MINOR: resolvers: Reset server address on DNS error only on status change
5982 - BUG/MINOR: resolvers: Unlink DNS resolution to set RMAINT on SRV resolution
5983 - BUG/MEDIUM: resolvers: Don't set an address-less server as UP
5984 - BUG/MEDIUM: resolvers: Fix the loop looking for an existing ADD item
5985 - MINOR: resolvers: new function find_srvrq_answer_record()
5986 - BUG/MINOR; resolvers: Ignore DNS resolution for expired SRV item
5987 - BUG/MEDIUM: resolvers: Trigger a DNS resolution if an ADD item is obsolete
5988 - MINOR: resolvers: Use a function to remove answers attached to a resolution
5989 - MINOR: resolvers: Purge answer items when a SRV resolution triggers an error
5990 - MINOR: resolvers: Add function to change the srv status based on SRV resolution
5991 - MINOR: resolvers: Directly call srvrq_update_srv_state() when possible
5992 - BUG/MEDIUM: resolvers: Don't release resolution from a requester callbacks
5993 - BUG/MEDIUM: resolvers: Skip DNS resolution at startup if SRV resolution is set
5994 - MINOR: resolvers: Use milliseconds for cached items in resolver responses
5995 - MINOR: resolvers: Don't try to match immediatly renewed ADD items
5996 - CLEANUP: resolvers: Use ha_free() in srvrq_resolution_error_cb()
5997 - CLEANUP: resolvers: Perform unsafe loop on requester list when possible
5998 - BUG/MINOR: cli: make sure "help", "prompt", "quit" are enabled at master level
5999 - CLEANUP: cli: fix misleading comment and better indent the access level flags
6000 - MINOR: cli: set the ACCESS_MASTER* bits on the master bind_conf
6001 - MINOR: cli: test the appctx level for master access instead of comparing pointers
6002 - MINOR: cli: print the error message in the parser function itself
6003 - MINOR: cli: filter the list of commands to the matching part
6004 - MEDIUM: cli: apply spelling fixes for known commands before listing them
6005 - MINOR: tools: add the ability to update a word fingerprint
6006 - MINOR: cli: apply the fuzzy matching on the whole command instead of words
6007 - CLEANUP: cli: rename MAX_STATS_ARGS to MAX_CLI_ARGS
6008 - CLEANUP: cli: rename the last few "stats_" to "cli_"
6009 - CLEANUP: task: make sure tasklet handlers always indicate their statuses
6010 - CLEANUP: assorted typo fixes in the code and comments
6011
Willy Tarreau7bbc6c92021-03-05 21:24:23 +010060122021/03/05 : 2.4-dev11
6013 - CI: codespell: skip Makefile for spell check
6014 - CLEANUP: assorted typo fixes in the code and comments
6015 - BUG/MINOR: tcp-act: Don't forget to set the original port for IPv4 set-dst rule
6016 - BUG/MINOR: connection: Use the client's dst family for adressless servers
6017 - BUG/MEDIUM: spoe: Kill applets if there are pending connections and nbthread > 1
6018 - CLEANUP: Use ist2(const void*, size_t) whenever possible
6019 - CLEANUP: Use IST_NULL whenever possible
6020 - BUILD: proxy: Missing header inclusion for quic_transport_params_init()
6021 - BUILD: quic: Implicit conversion between SSL related enums.
6022 - DOC: spoe: Add a note about fragmentation support in HAProxy
6023 - MINOR: contrib: add support for heartbeat control messages.
6024 - MINOR: contrib: Enhance peers dissector heuristic.
6025 - BUG/MINOR: mux-h2: Fix typo in scheme adjustment
6026 - CLEANUP: Reapply the ist2() replacement patch
6027 - CLEANUP: Use istadv(const struct ist, const size_t) whenever possible
6028 - CLEANUP: Use isttest(const struct ist) whenever possible
6029 - Revert "CI: Pin VTest to a known good commit"
6030 - CLEANUP: backend: fix a wrong comment
6031 - BUG/MINOR: backend: free allocated bind_addr if reuse conn
6032 - MINOR: backend: handle reuse for conns with no server as target
6033 - REGTESTS: test http-reuse if no server target
6034 - BUG/MINOR: hlua: Don't strip last non-LWS char in hlua_pushstrippedstring()
6035 - BUG/MINOR: server-state: Don't load server-state file for disabled backends
6036 - CLEANUP: dns: Use DISGUISE() on a never-failing ring_attach() call
6037 - CLEANUP: dns: Remove useless test on ns->dgram in dns_connect_nameserver()
6038 - DOC: fix originalto except clause on destination address
6039 - CLEANUP: Use the ist() macro whenever possible
6040 - CLEANUP: Replace for loop with only a condition by while
6041 - REORG: atomic: reimplement pl_cpu_relax() from atomic-ops.h
6042 - BUG/MINOR: mt-list: always perform a cpu_relax call on failure
6043 - MINOR: atomic: add armv8.1-a atomics variant for cas-dw
6044 - MINOR: atomic: implement a more efficient arm64 __ha_cas_dw() using pairs
6045 - BUG/MINOR: ssl: don't truncate the file descriptor to 16 bits in debug mode
6046 - MEDIUM: pools: add CONFIG_HAP_NO_GLOBAL_POOLS and CONFIG_HAP_GLOBAL_POOLS
6047 - MINOR: pools: double the local pool cache size to 1 MB
6048 - MINOR: stream: use ABORT_NOW() and not abort() in stream_dump_and_crash()
6049 - CLEANUP: stream: explain why we queue the stream at the head of the server list
6050 - MEDIUM: backend: use a trylock when trying to grab an idle connection
6051 - REORG: tools: promote the debug PRNG to more general use as a statistical one
6052 - OPTIM: lb-random: use a cheaper PRNG to pick a server
6053 - MINOR: task: stop abusing the nice field to detect a tasklet
6054 - MINOR: task: move the nice field to the struct task only
6055 - MEDIUM: task: extend the state field to 32 bits
6056 - MINOR: task: add an application specific flag to the state: TASK_F_USR1
6057 - MEDIUM: muxes: mark idle conns tasklets with TASK_F_USR1
6058 - MINOR: xprt: add new xprt_set_idle and xprt_set_used methods
6059 - MEDIUM: ssl: implement xprt_set_used and xprt_set_idle to relax context checks
6060 - MINOR: server: don't read curr_used_conns multiple times
6061 - CLEANUP: global: reorder some fields to respect cache lines
6062 - CLEANUP: sockpair: silence a coverity check about fcntl()
6063 - CLEANUP: lua: set a dummy file name and line number on the dummy servers
6064 - MINOR: server: add a global list of all known servers
6065 - MINOR: cfgparse: finish to set up servers outside of the proxy setup loop
6066 - MINOR: server: allocate a per-thread struct for the per-thread connections stuff
6067 - MINOR: server: move actconns to the per-thread structure
6068 - CLEANUP: server: reorder some fields in the server struct to respect cache lines
6069 - MINOR: backend: add a BUG_ON if conn mux NULL in connect_server
6070 - BUG/MINOR: backend: fix condition for reuse on mode HTTP
6071 - BUILD: Fix build when using clang without optimizing.
6072 - CLEANUP: assorted typo fixes in the code and comments
6073
Willy Tarreau8ab65c22021-02-26 22:49:10 +010060742021/02/26 : 2.4-dev10
6075 - BUILD: SSL: introduce fine guard for RAND_keep_random_devices_open
6076 - MINOR: Configure the `cpp` userdiff driver for *.[ch] in .gitattributes
6077 - BUG/MINOR: ssl/cli: potential null pointer dereference in "set ssl cert"
6078 - BUG/MINOR: sample: secure convs that accept base64 string and var name as args
6079 - BUG/MEDIUM: vars: make functions vars_get_by_{name,desc} thread-safe
6080 - CLEANUP: vars: make smp_fetch_var() to reuse vars_get_by_desc()
6081 - DOC: muxes: add a diagram of the exchanges between muxes and outer world
6082 - BUG/MEDIUM: proxy: use thread-safe stream killing on hard-stop
6083 - BUG/MEDIUM: cli/shutdown sessions: make it thread-safe
6084 - BUG/MINOR: proxy: wake up all threads when sending the hard-stop signal
6085 - MINOR: stream: add an "epoch" to figure which streams appeared when
6086 - MINOR: cli/streams: make "show sess" dump all streams till the new epoch
6087 - MINOR: streams: use one list per stream instead of a global one
6088 - MEDIUM: streams: do not use the streams lock anymore
6089 - BUILD: dns: avoid a build warning when threads are disabled (dss unused)
6090 - MEDIUM: task: remove the tasks_run_queue counter and have one per thread
6091 - MINOR: tasks: do not maintain the rqueue_size counter anymore
6092 - CLEANUP: tasks: use a less confusing name for task_list_size
6093 - CLEANUP: task: move the tree root detection from __task_wakeup() to task_wakeup()
6094 - MINOR: task: limit the remote thread wakeup to the global runqueue only
6095 - MINOR: task: move the allocated tasks counter to the per-thread struct
6096 - CLEANUP: task: split the large tasklet_wakeup_on() function in two
6097 - BUG/MINOR: fd: properly wait for !running_mask in fd_set_running_excl()
6098 - BUG/MINOR: resolvers: Fix condition to release received ARs if not assigned
6099 - BUG/MINOR: resolvers: Only renew TTL for SRV records with an additional record
6100 - BUG/MINOR: resolvers: new callback to properly handle SRV record errors
6101 - BUG/MEDIUM: resolvers: Reset server address and port for obselete SRV records
6102 - BUG/MEDIUM: resolvers: Reset address for unresolved servers
6103 - DOC: Update the module list in MAINTAINERS file
6104 - MINOR: htx: Add function to reserve the max possible size for an HTX DATA block
6105 - DOC: Update the HTX API documentation
6106 - DOC: Update the filters guide
6107 - BUG/MEDIUM: contrib/prometheus-exporter: fix segfault in listener name dump
6108 - MINOR: task: split the counts of local and global tasks picked
6109 - MINOR: task: do not use __task_unlink_rq() from process_runnable_tasks()
6110 - MINOR: task: don't decrement then increment the local run queue
6111 - CLEANUP: task: re-merge __task_unlink_rq() with task_unlink_rq()
6112 - MINOR: task: make grq_total atomic to move it outside of the grq_lock
6113 - MINOR: tasks: also compute the tasklet latency when DEBUG_TASK is set
6114 - MINOR: task: make tasklet wakeup latency measurements more accurate
6115 - MINOR: server: Be more strict on the server-state line parsing
6116 - MINOR: server: Only fill one array when parsing a server-state line
6117 - MEDIUM: server: Refactor apply_server_state() to make it more readable
6118 - CLEANUP: server: Rename state_line node to node instead of name_name
6119 - CLEANUP: server: Rename state_line structure into server_state_line
6120 - CLEANUP: server: Use a local eb-tree to store lines of the global server-state file
6121 - MINOR: server: Be more strict when reading the version of a server-state file
6122 - MEDIUM: server: Store parsed params of a server-state line in the tree
6123 - MINOR: server: Remove cached line from global server-state tree when found
6124 - MINOR: server: Move loading state of servers in a dedicated function
6125 - MEDIUM: server: Use a tree to store local server-state lines
6126 - MINOR: server: Parse and store server-state lines in a dedicated function
6127 - MEDIUM: server: Don't load server-state file if a line is corrupted
6128 - REORG: server: Export and rename some functions updating server info
6129 - REORG: server-state: Move functions to deal with server-state in its own file
6130 - MINOR: server-state: Don't load server-state file for serverless proxies
6131 - CLEANUP: muxes: Remove useless if condition in show_fd function
6132 - BUG/MINOR: stats: fix compare of no-maint url suffix
6133 - MINOR: task: limit the number of subsequent heavy tasks with flag TASK_HEAVY
6134 - MINOR: ssl: mark the SSL handshake tasklet as heavy
6135 - CLEANUP: server: rename srv_cleanup_{idle,toremove}_connections()
6136 - BUG/MINOR: ssl: potential null pointer dereference in ckchs_dup()
6137 - MINOR: task: add one extra tasklet class: TL_HEAVY
6138 - MINOR: task: place the heavy elements in TL_HEAVY
6139 - MINOR: task: only limit TL_HEAVY tasks but not others
6140 - BUG/MINOR: http-ana: Only consider dst address to process originalto option
6141 - MINOR: tools: Add net_addr structure describing a network addess
6142 - MINOR: tools: Add function to compare an address to a network address
6143 - MEDIUM: http-ana: Add IPv6 support for forwardfor and orignialto options
6144 - CLEANUP: hlua: Use net_addr structure internally to parse and compare addresses
6145 - REGTESTS: Add script to test except param for fowardedfor/originalto options
6146 - DOC: scheduler: add a diagram showing the different queues and their usages
6147 - CLEANUP: tree-wide: replace free(x);x=NULL with ha_free(&x)
6148 - CLEANUP: config: replace a few free() with ha_free()
6149 - CLEANUP: vars: always zero the pointers after a free()
6150 - CLEANUP: ssl: remove a useless "if" before freeing an error message
6151 - CLEANUP: ssl: make ssl_sock_free_srv_ctx() zero the pointers after free
6152 - CLEANUP: ssl: use realloc() instead of free()+malloc()
6153
Willy Tarreau31dd3932021-02-20 13:30:31 +010061542021/02/20 : 2.4-dev9
6155 - BUG/MINOR: server: Remove RMAINT from admin state when loading server state
6156 - CLEANUP: check: fix get_check_status_info declaration
6157 - CLEANUP: contrib/prometheus-exporter: align for with srv status case
6158 - MEDIUM: stats: allow to select one field in `stats_fill_li_stats`
6159 - MINOR: stats: add helper to get status string
6160 - MEDIUM: contrib/prometheus-exporter: add listen stats
6161 - BUG/MINOR: dns: add test on result getting value from buffer into ring.
6162 - BUG/MINOR: dns: dns_connect_server must return -1 unsupported nameserver's type
6163 - BUG/MINOR: dns: missing test writing in output channel in session handler
6164 - BUG/MINOR: dns: fix ring attach control on dns_session_new
6165 - BUG/MEDIUM: dns: fix multiple double close on fd in dns.c
6166 - BUG/MAJOR: connection: prevent double free if conn selected for removal
6167 - BUG/MINOR: session: atomically increment the tracked sessions counter
6168 - REGTESTS: fix http_reuse_conn_hash proxy test
6169 - BUG/MINOR: backend: do not call smp_make_safe for sni conn hash
6170 - MINOR: connection: remove pointers for prehash in conn_hash_params
6171 - BUG/MINOR: checks: properly handle wrapping time in __health_adjust()
6172 - BUG/MEDIUM: checks: don't needlessly take the server lock in health_adjust()
6173 - DEBUG: thread: add 5 extra lock labels for statistics and debugging
6174 - OPTIM: server: switch the actconn list to an mt-list
6175 - Revert "MINOR: threads: change lock_t to an unsigned int"
6176 - MINOR: lb/api: let callers of take_conn/drop_conn tell if they have the lock
6177 - OPTIM: lb-first: do not take the server lock on take_conn/drop_conn
6178 - OPTIM: lb-leastconn: do not take the server lock on take_conn/drop_conn
6179 - OPTIM: lb-leastconn: do not unlink the server if it did not change
6180 - MINOR: tasks: add DEBUG_TASK to report caller info in a task
6181 - MINOR: tasks/debug: add some extra controls of use-after-free in DEBUG_TASK
6182 - BUG/MINOR: sample: Always consider zero size string samples as unsafe
6183 - MINOR: cli: add missing agent commands for set server
6184 - BUILD/MEDIUM: da Adding pcre2 support.
6185 - BUILD: ssl: introduce fine guard for OpenSSL specific SCTL functions
6186 - REGTESTS: reorder reuse conn proxy protocol test
6187 - DOC: explain the relation between pool-low-conn and tune.idle-pool.shared
6188 - MINOR: tasks: refine the default run queue depth
6189 - MINOR: listener: refine the default MAX_ACCEPT from 64 to 4
6190 - MINOR: mux_h2: do not try to remove front conn from idle trees
6191 - REGTESTS: workaround for a crash with recent libressl on http-reuse sni
6192 - BUG/MEDIUM: lists: Avoid an infinite loop in MT_LIST_TRY_ADDQ().
6193 - MINOR: connection: allocate dynamically hash node for backend conns
6194 - DOC: DeviceAtlas documentation typo fix.
6195 - BUG/MEDIUM: spoe: Resolve the sink if a SPOE logs in a ring buffer
6196 - BUG/MINOR: http-rules: Always replace the response status on a return action
6197 - BUG/MINOR: server: Init params before parsing a new server-state line
6198 - BUG/MINOR: server: Be sure to cut the last parsed field of a server-state line
6199 - MEDIUM: server: Don't introduce a new server-state file version
6200 - DOC: contrib/prometheus-exporter: remove htx reference
6201 - REGTESTS: contrib/prometheus-exporter: test NaN values
6202 - REGTESTS: contrib/prometheus-exporter: test well known labels
6203 - CI: github actions: switch to stable LibreSSL release
6204 - BUG/MINOR: server: Fix test on number of fields allowed in a server-state line
6205 - MINOR: dynbuf: make the buffer wait queue per thread
6206 - MINOR: dynbuf: use regular lists instead of mt_lists for buffer_wait
6207 - MINOR: dynbuf: pass offer_buffers() the number of buffers instead of a threshold
6208 - MINOR: sched: have one runqueue ticks counter per thread
6209
Willy Tarreaudc626ec2021-02-13 10:17:27 +010062102021/02/13 : 2.4-dev8
6211 - BUILD: ssl: fix typo in HAVE_SSL_CTX_ADD_SERVER_CUSTOM_EXT macro
6212 - BUILD: ssl: guard SSL_CTX_add_server_custom_ext with special macro
6213 - BUG/MINOR: mux-h1: Don't emit extra CRLF for empty chunked messages
6214 - MINOR: contrib/prometheus-exporter: use stats desc when possible followup
6215 - MEDIUM: contrib/prometheus-exporter: export base stick table stats
6216 - CLEANUP: assorted typo fixes in the code and comments
6217 - CLEANUP: check: fix some typo in comments
6218 - CLEANUP: tools: typo in `strl2irc` mention
6219 - BUILD: ssl: guard SSL_CTX_set_msg_callback with SSL_CTRL_SET_MSG_CALLBACK macro
6220 - MEDIUM: ssl: add a rwlock for SSL server session cache
6221 - BUG/MINOR: intops: fix mul32hi()'s off-by-one
6222 - BUG/MINOR: freq_ctr: fix a wrong delay calculation in next_event_delay()
6223 - MINOR: stick-tables/counters: add http_fail_cnt and http_fail_rate data types
6224 - MINOR: ssl: add SSL_SERVER_LOCK label in threads.h
6225 - BUG/MINOR: mux-h1: Don't increment HTTP error counter for 408/500/501 errors
6226 - BUG/MINOR: http-ana: Don't increment HTTP error counter on internal errors
6227 - BUG/MEDIUM: mux-h1: Always set CS_FL_EOI for response in MSG_DONE state
6228 - BUG/MINOR: mux-h1: Fix data skipping for bodyless responses
6229 - BUG/MINOR: mux-h1: Don't blindly skip EOT block for non-chunked messages
6230 - BUG/MEDIUM: mux-h2: Add EOT block when EOM flag is set on an empty HTX message
6231 - MINOR: mux-h1: Be sure EOM flag is set when processing end of outgoing message
6232 - REGTESTS: Add a script to test payload skipping for bodyless HTTP responses
6233 - BUG/MINOR: server: re-align state file fields number
6234 - CLEANUP: muxes: Remove useless calls to b_realign_if_empty()
6235 - BUG/MINOR: tools: Fix a memory leak on error path in parse_dotted_uints()
6236 - CLEANUP: remove unused variable assigned found by Coverity
6237 - CLEANUP: queue: Remove useless tests on p or pp in pendconn_process_next_strm()
6238 - BUG/MINOR: backend: hold correctly lock when killing idle conn
6239 - MEDIUM: connection: protect idle conn lists with locks
6240 - MEDIUM: connection: replace idle conn lists by eb trees
6241 - MINOR: backend: search conn in idle/safe trees after available
6242 - MINOR: backend: search conn in idle tree after safe on always reuse
6243 - MINOR: connection: prepare hash calcul for server conns
6244 - MINOR: connection: use the srv pointer for the srv conn hash
6245 - MINOR: backend: compare conn hash for session conn reuse
6246 - MINOR: connection: use sni as parameter for srv conn hash
6247 - MINOR: reg-tests: test http-reuse with sni
6248 - MINOR: backend: rewrite alloc of stream target address
6249 - MINOR: connection: use dst addr as parameter for srv conn hash
6250 - MINOR: reg-test: test http-reuse with specific dst addr
6251 - MINOR: backend: rewrite alloc of connection src address
6252 - MINOR: connection: use src addr as parameter for srv conn hash
6253 - MINOR: connection: use proxy protocol as parameter for srv conn hash
6254 - MINOR: reg-tests: test http-reuse with proxy protocol
6255 - MINOR: doc: update http reuse for new eligilible connections
6256 - BUG/MINOR: backend: fix compilation without ssl
6257 - REGTESTS: adjust http_reuse_conn_hash requirements
6258 - REGTESTS: deactivate a failed test on CI in http_reuse_conn_hash
6259 - REGTESTS: fix sni used in http_reuse_conn_hash for libressl 3.3.0
6260 - CI: cirrus: update FreeBSD image to 12.2
6261 - MEDIUM: cli: add check-addr command
6262 - MEDIUM: cli: add agent-port command
6263 - MEDIUM: server: add server-states version 2
6264 - MEDIUM: server: support {check,agent}_addr, agent_port in server state
6265 - MINOR: server: enhance error precision when applying server state
6266 - BUG/MINOR: server: Fix server-state-file-name directive
6267 - CLEANUP: deinit: release global and per-proxy server-state variables on deinit
6268 - BUG/MEDIUM: config: don't pick unset values from last defaults section
6269 - BUG/MINOR: stats: revert the change on ST_CONVDONE
6270 - BUG/MINOR: cfgparse: do not mention "addr:port" as supported on proxy lines
6271 - BUG/MINOR: http-htx: defpx must be a const in proxy_dup_default_conf_errors()
6272 - BUG/MINOR: tcpheck: the source list must be a const in dup_tcpcheck_var()
6273 - BUILD: proxy: add missing compression-t.h to proxy-t.h
6274 - REORG: move init_default_instance() to proxy.c and pass it the defproxy pointer
6275 - REORG: proxy: centralize the proxy allocation code into alloc_new_proxy()
6276 - MEDIUM: proxy: only take defaults when a default proxy is passed.
6277 - MINOR: proxy: move the defproxy freeing code to proxy.c
6278 - MINOR: proxy: always properly reset the just freed default instance pointers
6279 - BUG/MINOR: extcheck: proxy_parse_extcheck() must take a const for the defproxy
6280 - BUG/MINOR: tcpcheck: proxy_parse_*check*() must take a const for the defproxy
6281 - BUG/MINOR: server: parse_server() must take a const for the defproxy
6282 - MINOR: cfgparse: move defproxy to cfgparse-listen as a static
6283 - MINOR: proxy: add a new capability PR_CAP_DEF
6284 - MINOR: cfgparse: check PR_CAP_DEF instead of comparing poiner against defproxy
6285 - MINOR: cfgparse: use a pointer to the current default proxy
6286 - MINOR: proxy: also store the name for a defaults section
6287 - MINOR: proxy: support storing defaults sections into their own tree
6288 - MEDIUM: proxy: store the default proxies in a tree by name
6289 - MEDIUM: cfgparse: allow a proxy to designate the defaults section to use
6290 - MINOR: http: add baseq sample fetch
6291 - CLEANUP: tcpcheck: Remove a useless test on port variable
6292 - BUG/MINOR: server: Don't call fopen() with server-state filepath set to NULL
6293 - CLEANUP: server: Remove useless "filepath" variable in apply_server_state()
6294 - MINOR: peers/cli: do not dump the peers dictionaries by default on "show peers"
6295 - MINOR: cfgparse: implement a simple if/elif/else/endif macro block handler
6296 - DOC: tune: explain the origin of block size for ssl.cachesize
6297 - MINOR: tcp: add support for defer-accept on FreeBSD.
6298 - MINOR: ring: adds new ring_init function.
6299 - CLEANUP: channel: fix comment in ci_putblk.
6300 - BUG/MINOR: dns: add missing sent counter and parent id to dns counters.
6301 - BUG/MINOR: resolvers: fix attribute packed struct for dns
6302 - MINOR: resolvers: renames some resolvers internal types and removes dns prefix
6303 - MINOR: resolvers: renames type dns_resolvers to resolvers.
6304 - MINOR: resolvers: renames some resolvers specific types to not use dns prefix
6305 - MINOR: resolvers: renames some dns prefixed types using resolv prefix.
6306 - MINOR: resolvers: renames resolvers DNS_RESP_* errcodes RSLV_RESP_*
6307 - MINOR: resolvers: renames resolvers DNS_UPD_* returncodes to RSLV_UPD_*
6308 - MINOR: resolvers: rework prototype suffixes to split resolving and dns.
6309 - MEDIUM: resolvers: move resolvers section parsing from cfgparse.c to dns.c
6310 - MINOR: resolvers: replace nameserver's resolver ref by generic parent pointer
6311 - MINOR: resolvers: rework dns stats prototype because specific to resolvers
6312 - MEDIUM: resolvers: split resolving and dns message exchange layers.
6313 - MEDIUM: resolvers/dns: split dns.c into dns.c and resolvers.c
6314 - MEDIUM: dns: adds code to support pipelined DNS requests over TCP.
6315 - MEDIUM: resolvers: add supports of TCP nameservers in resolvers.
6316
Willy Tarreau5d46fbd2021-02-05 15:17:33 +010063172021/02/05 : 2.4-dev7
6318 - BUG/MINOR: stats: Continue to fill frontend stats on unimplemented metric
6319 - BUILD: ssl: guard Client Hello callbacks with HAVE_SSL_CLIENT_HELLO_CB macro instead of openssl version
6320 - BUG/MINOR: stats: Init the metric variable when frontend stats are filled
6321 - MINOR: contrib/prometheus-exporter: better output of Not-a-Number
6322 - CLEANUP: stats: improve field selection for frontend http fields
6323 - CLEANUP: assorted typo fixes in the code and comments
6324 - DOC: Improve documentation of the various hdr() fetches
6325 - MEDIUM: stats: allow to select one field in `stats_fill_be_stats`
6326 - MINOR: contrib/prometheus-exporter: use fill_be_stats for backend dump
6327 - MEDIUM: stats: allow to select one field in `stats_fill_sv_stats`
6328 - MINOR: contrib/prometheus-exporter: use fill_sv_stats for server dump
6329 - MINOR: abort() on my_unreachable() when DEBUG_USE_ABORT is set.
6330 - BUG/MEDIUM: filters/htx: Fix data forwarding when payload length is unknown
6331 - BUG/MINOR: config: fix leak on proxy.conn_src.bind_hdr_name
6332 - MINOR: reg-tests: add http-reuse test
6333 - CLEANUP: srv: fix comment for pool-max-conn
6334 - CLEANUP: backend: remove an obsolete comment on conn_backend_get
6335 - REORG: backend: simplify conn_backend_get
6336 - MINOR: ssl: Server ssl context prepare function refactoring
6337 - MINOR: ssl: Certificate chain loading refactorization
6338 - MEDIUM: ssl: Load client certificates in a ckch for backend servers
6339 - MEDIUM: ssl: Enable backend certificate hot update
6340 - MINOR: ssl: Remove client_crt member of the server's ssl context
6341 - CLEANUP: ssl/cli: rework free in cli_io_handler_commit_cert()
6342 - CLEANUP: ssl: remove SSL_CTX function parameter
6343 - CLEANUP: ssl: make load_srv_{ckchs,cert} match their bind counterpart
6344 - BUILD: Include stdlib.h in compiler.h if DEBUG_USE_ABORT is set
6345 - CI: Fix DEBUG_STRICT definition for Coverity
6346 - BUG/MINOR: stats: Remove a break preventing ST_F_QCUR to be set for servers
6347 - BUG/MINOR: stats: Add a break after filling ST_F_MODE field for servers
6348 - CLEANUP: ssl: remove dead code in ckch_inst_new_load_srv_store()
6349 - BUG/MINOR: ssl: init tmp chunk correctly in ssl_sock_load_sctl_from_file()
6350 - BUG/MEDIUM: session: only retrieve ready idle conn from session
6351 - BUG/MEDIUM: backend: never reuse a connection for tcp mode
6352 - REGTESTS: set_ssl_server_cert.vtc: remove the abort command
6353 - REGTESTS: set_ssl_server_cert.vtc: check the Sha1 Fingerprint
6354 - REGTESTS: set_ssl_server_cert.vtc: check the sha1 from the server
6355 - MEDIUM: stream-int: Take care of EOS if the SI wake callback function
6356 - MINOR: mux-h1: Try to wake up data layer first before calling its wake callback
6357 - MINOR: mux-h1: Wake up H1C after its creation if input buffer is not empty
6358 - MEDIUM: mux-h1: Add ST_READY state for the H1 connections
6359 - MINOR: stream: Add a function to validate TCP to H1 upgrades
6360 - MEDIUM: http-ana: Do nothing in wait-for-request analyzer if not htx
6361 - BUG/MEDIUM: stream: Don't immediatly ack the TCP to H1 upgrades
6362 - BUG/MAJOR: mux-h1: Properly handle TCP to H1 upgrades
6363 - MINOR: htx/http-ana: Save info about Upgrade option in the Connection header
6364 - MEDIUM: http-ana: Refuse invalid 101-switching-protocols responses
6365 - BUG/MINOR: h2/mux-h2: Reject 101 responses with a PROTOCOL_ERROR h2s error
6366 - MINOR: mux-h1/mux-fcgi: Don't set TUNNEL mode if payload length is unknown
6367 - MINOR: mux-h1: Split H1C_F_WAIT_OPPOSITE flag to separate input/output sides
6368 - MINOR: mux-h2: Add 2 flags to help to properly handle tunnel mode
6369 - MEDIUM: mux-h2: Block client data on server side waiting tunnel establishment
6370 - MEDIUM: mux-h2: Close streams when processing data for an aborted tunnel
6371 - MEDIUM: mux-h1: Properly handle tunnel establishments and aborts
6372 - BUG/MAJOR: mux-h1/mux-h2/htx: Fix HTTP tunnel management at the mux level
6373 - MINOR: htx: Rename HTX_FL_EOI flag into HTX_FL_EOM
6374 - REGTESTS: Don't run http_msg_full_on_eom script on the 2.4 anymore
6375 - MINOR: htx: Add a function to know if a block is the only one in a message
6376 - MAJOR: htx: Remove the EOM block type and use HTX_FL_EOM instead
6377 - MINOR: mux-h1: Add a flag on H1 streams with a response known to be bodyless
6378 - MEDIUM: mux-h1: Don't emit any payload for bodyless responses
6379 - MINOR: mux-h1: Don't emit C-L and T-E headers for 204 and 1xx responses
6380 - MINOR: mux-h1: Don't add Connection close/keep-alive header for 1xx messages
6381 - MINOR: h2/mux-h2: Add flags to notify the response is known to have no body
6382 - MEDIUM: mux-h2: Don't emit DATA frame for bodyless responses
6383 - MEDIUM: http-ana: Deal with L7 retries in HTTP analysers
6384 - MINOR: h1: reject websocket handshake if missing key
6385 - MEDIUM: h1: generate WebSocket key on response if needed
6386 - MINOR: mux_h2: define H2_SF_EXT_CONNECT_SENT stream flag
6387 - MEDIUM: h2: parse Extended CONNECT reponse to htx
6388 - MEDIUM: mux_h2: generate Extended CONNECT from htx upgrade
6389 - MEDIUM: h1: add a WebSocket key on handshake if needed
6390 - MEDIUM: mux_h2: generate Extended CONNECT response
6391 - MEDIUM: h2: parse Extended CONNECT request to htx
6392 - MEDIUM: h2: send connect protocol h2 settings
6393 - MINOR: vtc: add test for h1/h2 protocol upgrade translation
6394 - MINOR: vtc: add websocket test
6395 - REGTESTS: Fix required versions for several scripts
6396 - REGTEST: Don't use the websocket to validate http-check
6397 - MINOR: mux-h1/trace: add traces at level ERROR for all kind of errors
6398 - MINOR: mux-fcgi/trace: add traces at level ERROR for all kind of errors
6399 - MINOR: h1: Raise the chunk size limit up to (2^52 - 1)
6400 - BUG/MEDIUM: listener: do not accept connections faster than we can process them
6401 - REGTESTS: set_ssl_server_cert.vtc: set as broken
6402 - Revert "BUG/MEDIUM: listener: do not accept connections faster than we can process them"
6403 - BUG/MINOR: backend: check available list allocation for reuse
6404 - CI: Fix the coverity builds
6405 - DOC: management: fix "show resolvers" alphabetical ordering
6406 - MINOR: tools: add print_time_short() to print a condensed duration value
6407 - MINOR: activity: make profiling more manageable
6408 - MINOR: activity: declare a new structure to collect per-function activity
6409 - MEDIUM: tasks/activity: collect per-task statistics when profiling is enabled
6410 - MINOR: activity: also report collected tasks stats in "show profiling"
6411 - MINOR: activity: flush scheduler stats on "set profiling tasks on"
6412 - MINOR: activity: add a new "show tasks" command to list currently active tasks
6413 - MINOR: listener: export accept_queue_process
6414 - MINOR: session: export session_expire_embryonic()
6415 - MINOR: muxes: export the timeout and shutr task handlers
6416 - MINOR: checks: export a few functions that appear often in trace dumps
6417 - MINOR: peers: export process_peer_sync() to improve traces
6418 - MINOR: stick-tables: export process_table_expire()
6419 - MINOR: mux-h1: Remove first useless test on count in h1_process_output()
6420 - BUG/MINOR: stick-table: Always call smp_fetch_src() with a valid arg list
6421 - MINOR: http-fetch: Don't check if argument list is set in sample fetches
6422 - MINOR: http-conv: Don't check if argument list is set in sample converters
6423 - MINOR: sample: Don't check if argument list is set in sample fetches
6424 - MINOR: ssl-sample: Don't check if argument list is set in sample fetches
6425 - MINOR: mux-h2: Don't tests the start-line when sending HEADERS frame
6426 - MINOR: mux-h2: Slightly improve request HEADERS frames sending
6427 - MINOR: contrib/prometheus-exporter: declare states for objects
6428 - MAJOR: contrib/prometheus-exporter: move ftd/bkd/srv states to labels
6429 - MEDIUM: contrib/prometheus-exporter: Use dynamic labels instead of static ones
6430 - MINOR: listener: export manage_global_listener_queue()
6431 - BUG/MINOR: activity: take care of late wakeups in "show tasks"
6432 - REGTESTS: set_ssl_server_cert.vtc: remove SSL caching and set as working
6433 - REGTESTS: set_ssl_server_cert: cleanup the SSL caching option
6434 - MINOR: checks: Add function to get the result code corresponding to a status
6435 - MAJOR: contrib/prometheus-exporter: move health check status to labels
6436 - MINOR: contrib/prometheus-exporter: improve service status description field
6437 - MINOR: stats: improve pending connections description
6438 - MINOR: stats: improve max stats descriptions
6439 - MINOR: contrib/prometheus-exporter: use stats desc when possible
6440 - MINOR: contrib/prometheus-exporter: add uweight field
6441 - MINOR: contrib/prometheus-exporter: add recv logs_logs_total field
6442 - CLEANUP: contrib/prometheus-exporter: remove unused includes
6443 - CLEANUP: contrib/prometheus-exporter: align and reorder fields
6444 - CLEANUP: contrib/prometheus-exporter: remove description in README
6445 - DOC: contrib/prometheus-exporter: Add missing metrics in README
6446 - BUG/MINOR: contrib/prometheus-exporter: Add missing label for ST_F_HRSP_1XX
6447 - BUG/MINOR: contrib/prometheus-exporter: Restart labels dump at the right pos
6448 - BUG/MEDIUM: ssl/cli: abort ssl cert is freeing the old store
6449 - BUG/MEDIUM: ssl: check a connection's status before computing a handshake
6450 - BUG/MINOR: mux_h2: fix incorrect stat titles
6451 - MINOR: ssl/cli: flush the server session cache upon 'commit ssl cert'
6452 - BUG/MINOR: cli: fix set server addr/port coherency with health checks
6453 - MINOR: server: Don't set the check port during the update from a state file
6454 - MINOR: dns: Don't set the check port during a server dns resolution
6455 - MEDIUM: check: remove checkport checkaddr flag
6456 - MEDIUM: server: adding support for check_port in server state
6457 - BUG/MINOR: check: consitent way to set agentaddr
6458 - MEDIUM: check: align agentaddr and agentport behaviour
6459 - DOC: server: Add missing params in comment of the server state line parsing
6460 - BUG/MINOR: xxhash: make sure armv6 uses memcpy()
6461 - REGTESTS: mark http-check-send.vtc as 2.4-only
6462 - REGTESTS: mark sample_fetches/hashes.vtc as 2.4-only
6463 - BUG/MINOR: ssl: do not try to use early data if not configured
6464 - REGTESTS: unbreak http-check-send.vtc
6465 - MINOR: cli/show_fd: report local and report ports when known
6466 - BUILD: Makefile: move REGTESTST_TYPE default setting
6467 - BUG/MEDIUM: mux-h2: handle remaining read0 cases
6468 - CLEANUP: http-htx: Set buffer area to NULL instead of malloc(0)
6469 - BUG/MINOR: sock: Unclosed fd in case of connection allocation failure
6470 - BUG/MEDIUM: mux-h2: do not quit the demux loop before setting END_REACHED
6471
Willy Tarreau24c41d52021-01-22 16:19:46 +010064722021/01/22 : 2.4-dev6
6473 - MINOR: converter: adding support for url_enc
6474 - BUILD: SSL: guard TLS13 ciphersuites with HAVE_SSL_CTX_SET_CIPHERSUITES
6475 - BUILD: ssl: guard EVP_PKEY_get_default_digest_nid with ASN1_PKEY_CTRL_DEFAULT_MD_NID
6476 - BUILD: ssl: guard openssl specific with SSL_READ_EARLY_DATA_SUCCESS
6477 - BUILD: Makefile: exclude broken tests by default
6478 - CLEANUP: cfgparse: replace "realloc" with "my_realloc2" to fix to memory leak on error
6479 - BUG/MINOR: hlua: Fix memory leak in hlua_alloc
6480 - MINOR: contrib/prometheus-exporter: export build_info
6481 - DOC: fix some spelling issues over multiple files
6482 - CLEANUP: Fix spelling errors in comments
6483 - SCRIPTS: announce-release: fix typo in help message
6484 - CI: github: add a few more words to the codespell ignore list
6485 - DOC: Add maintainers for the Prometheus exporter
6486 - BUG/MINOR: sample: fix concat() converter's corruption with non-string variables
6487 - BUG/MINOR: server: Memory leak of proxy.used_server_addr during deinit
6488 - CLEANUP: sample: remove uneeded check in json validation
6489 - MINOR: reg-tests: add a way to add service dependency
6490 - BUG/MINOR: sample: check alloc_trash_chunk return value in concat()
6491 - BUG/MINOR: reg-tests: fix service dependency script
6492 - MINOR: reg-tests: add base prometheus test
6493 - Revert "BUG/MINOR: dns: SRV records ignores duplicated AR records"
6494 - BUG/MINOR: sample: Memory leak of sample_expr structure in case of error
6495 - BUG/MINOR: check: Don't perform any check on servers defined in a frontend
6496 - BUG/MINOR: init: enforce strict-limits when using master-worker
6497 - MINOR: contrib/prometheus-exporter: avoid connection close header
6498 - MINOR: contrib/prometheus-exporter: use fill_info for process dump
6499 - BUG/MINOR: init: Use a dynamic buffer to set HAPROXY_CFGFILES env variable
6500 - MINOR: config: Add failifnotcap() to emit an alert on proxy capabilities
6501 - MINOR: server: Forbid server definitions in frontend sections
6502 - BUG/MINOR: threads: Fixes the number of possible cpus report for Mac.
6503 - CLEANUP: pattern: rename pat_ref_commit() to pat_ref_commit_elt()
6504 - MINOR: pattern: add the missing generation ID manipulation functions
6505 - MINOR: peers: Add traces for peer control messages.
6506 - BUG/MINOR: dns: SRV records ignores duplicated AR records (v2)
6507 - BUILD: peers: fix build warning about unused variable
6508 - BUG/MEDIUM: stats: add missing INF_BUILD_INFO definition
6509 - MINOR: cache: Do not store responses with an unknown encoding
6510 - BUG/MINOR: peers: Possible appctx pointer dereference.
6511 - MINOR: build: discard echoing in help target
6512 - MINOR: cache: Remove the `hash` part of the accept-encoding secondary key
6513 - CLEANUP: cache: Use proper data types in secondary_key_cmp()
6514 - CLEANUP: Rename accept_encoding_hash_cmp to accept_encoding_bitmap_cmp
6515 - BUG/MINOR: peers: Wrong "new_conn" value for "show peers" CLI command.
6516 - MINOR: contrib: Make the wireshark peers dissector compile for more distribs.
6517 - BUG/MINOR: mux_h2: missing space between "st" and ".flg" in the "show fd" helper
6518 - CLEANUP: tools: make resolve_sym_name() take a const pointer
6519 - CLEANUP: cli: make "show fd" use a const connection to access other fields
6520 - MINOR: cli: make "show fd" also report the xprt and xprt_ctx
6521 - MINOR: xprt: add a new show_fd() helper to complete some "show fd" dumps.
6522 - MINOR: ssl: provide a "show fd" helper to report important SSL information
6523 - MINOR: xprt/mux: export all *_io_cb functions so that "show fd" resolves them
6524 - MINOR: mux-h2: make the "show fd" helper also decode the h2s subscriber when known
6525 - MINOR: mux-h1: make the "show fd" helper also decode the h1s subscriber when known
6526 - MINOR: mux-fcgi: make the "show fd" helper also decode the fstrm subscriber when known
6527 - CI: Pin VTest to a known good commit
6528 - MINOR: cli: give the show_fd helpers the ability to report a suspicious entry
6529 - MINOR: cli/show_fd: report some easily detectable suspicious states
6530 - MINOR: ssl/show_fd: report some FDs as suspicious when possible
6531 - MINOR: mux-h2/show_fd: report as suspicious an entry with too many calls
6532 - MINOR: mux-h1/show_fd: report as suspicious an entry with too many calls
6533 - BUG/MINOR: mworker: define _GNU_SOURCE for strsignal()
6534 - BUG/MEDIUM: tcpcheck: Don't destroy connection in the wake callback context
6535 - BUG/MEDIUM: mux-h2: Xfer rxbuf to the upper layer when creating a front stream
6536 - MINOR: http: Add HTTP 501-not-implemented error message
6537 - MINOR: muxes: Add exit status for errors about not implemented features
6538 - MINOR: mux-h1: Be prepared to return 501-not-implemented error during parsing
6539 - MEDIUM: mux-h1: Return a 501-not-implemented for upgrade requests with a body
6540 - DOC: Remove space after comma in converter signature
6541 - DOC: Rename '<var name>' to '<var>' in converter signature
6542 - MINOR: stats: duplicate 3 fields in bytes in info
6543 - MINOR: stats: add new start time field
6544 - MINOR: contrib/prometheus-exporter: merge info description from stats
6545 - MEDIUM: stats: allow to select one field in `stats_fill_fe_stats`
6546 - MINOR: contrib/prometheus-exporter: use fill_fe_stats for frontend dump
6547 - MINOR: contrib/prometheus-exporter: Don't needlessly set empty label for metrics
6548 - MINOR: contrib/prometheus-exporter: Split the PROMEX_FL_STATS_METRIC flag
6549 - MINOR: contrib/prometheus-exporter: Add promex_metric struct defining a metric
6550 - MEDIUM: contrib/prometheus-exporter: Rework matrices defining Promex metrics
6551 - BUG/MINOR: stream: Don't update counters when TCP to H2 upgrades are performed
6552 - BUG/MEDIUM: mux-h2: fix read0 handling on partial frames
6553 - MINOR: debug: always export the my_backtrace function
6554 - MINOR: debug: extract the backtrace dumping code to its own function
6555 - MINOR: debug: create ha_backtrace_to_stderr() to dump an instant backtrace
6556 - MEDIUM: debug: now always print a backtrace on CRASH_NOW() and friends
6557 - MINOR: debug: let ha_dump_backtrace() dump a bit further for some callers
6558 - BUILD: debug: fix build warning by consuming the write() result
6559 - MINOR: lua: remove unused variable
6560 - BUILD/MINOR: lua: define _GNU_SOURCE for LLONG_MAX
6561
Willy Tarreau421ed392021-01-06 17:41:32 +010065622021/01/06 : 2.4-dev5
6563 - BUG/MEDIUM: mux_h2: Add missing braces in h2_snd_buf()around trace+wakeup
6564 - BUILD: hpack: hpack-tbl-t.h uses VAR_ARRAY but does not include compiler.h
6565 - MINOR: time: increase the minimum wakeup interval to 60s
6566 - MINOR: check: do not ignore a connection header for http-check send
6567 - REGTESTS: complete http-check test
6568 - CI: travis-ci: drop coverity scan builds
6569 - MINOR: atomic: don't use ; to separate instruction on aarch64.
6570 - IMPORT: xxhash: update to v0.8.0 that introduces stable XXH3 variant
6571 - MEDIUM: xxhash: use the XXH3 functions to generate 64-bit hashes
6572 - MEDIUM: xxhash: use the XXH_INLINE_ALL macro to inline all functions
6573 - CLEANUP: xxhash: remove the unused src/xxhash.c
6574 - MINOR: sample: add the xxh3 converter
6575 - REGTESTS: add tests for the xxh3 converter
6576 - MINOR: protocol: Create proto_quic QUIC protocol layer.
6577 - MINOR: connection: Attach a "quic_conn" struct to "connection" struct.
6578 - MINOR: quic: Redefine control layer callbacks which are QUIC specific.
6579 - MINOR: ssl_sock: Initialize BIO and SSL objects outside of ssl_sock_init()
6580 - MINOR: connection: Add a new xprt to connection.
6581 - MINOR: ssl: Export definitions required by QUIC.
6582 - MINOR: cfgparse: Do not modify the QUIC xprt when parsing "ssl".
6583 - MINOR: tools: Add support for QUIC addresses parsing.
6584 - MINOR: quic: Add definitions for QUIC protocol.
6585 - MINOR: quic: Import C source code files for QUIC protocol.
6586 - MINOR: listener: Add QUIC info to listeners and receivers.
6587 - MINOR: server: Add QUIC definitions to servers.
6588 - MINOR: ssl: SSL CTX initialization modifications for QUIC.
6589 - MINOR: ssl: QUIC transport parameters parsing.
6590 - MINOR: quic: QUIC socket management finalization.
6591 - MINOR: cfgparse: QUIC default server transport parameters init.
6592 - MINOR: quic: Enable the compilation of QUIC modules.
6593 - MAJOR: quic: Make usage of ebtrees to store QUIC ACK ranges.
6594 - MINOR: quic: Attempt to make trace more readable
6595 - MINOR: quic: Make usage of the congestion control window.
6596 - MINOR: quic: Flag RX packet as ack-eliciting from the generic parser.
6597 - MINOR: quic: Code reordering to help in reviewing/modifying.
6598 - MINOR: quic: Add traces to congestion avoidance NewReno callback.
6599 - MINOR: quic: Display the SSL alert in ->ssl_send_alert() callback.
6600 - MINOR: quic: Update the initial salt to that of draft-29.
6601 - MINOR: quic: Add traces for in flght ack-eliciting packet counter.
6602 - MINOR: quic: make a packet build fails when qc_build_frm() fails.
6603 - MINOR: quic: Add traces for quic_packet_encrypt().
6604 - MINOR: cache: Refactoring of secondary_key building functions
6605 - MINOR: cache: Avoid storing responses whose secondary key was not correctly calculated
6606 - BUG/MINOR: cache: Manage multiple headers in accept-encoding normalization
6607 - MINOR: cache: Add specific secondary key comparison mechanism
6608 - MINOR: http: Add helper functions to trim spaces and tabs
6609 - MEDIUM: cache: Manage a subset of encodings in accept-encoding normalizer
6610 - REGTESTS: cache: Simplify vary.vtc file
6611 - REGTESTS: cache: Add a specific test for the accept-encoding normalizer
6612 - MINOR: cache: Remove redundant test in http_action_req_cache_use
6613 - MINOR: cache: Replace the "process-vary" option's expected values
6614 - CI: GitHub Actions: enable daily Coverity scan
6615 - BUG/MEDIUM: cache: Fix hash collision in `accept-encoding` handling for `Vary`
6616 - MEDIUM: stick-tables: Add srvkey option to stick-table
6617 - REGTESTS: add test for stickiness using "srvkey addr"
6618 - BUILD: Makefile: disable -Warray-bounds until it's fixed in gcc 11
6619 - BUG/MINOR: sink: Return an allocation failure in __sink_new if strdup() fails
6620 - BUG/MINOR: lua: Fix memory leak error cases in hlua_config_prepend_path
6621 - MINOR: lua: Use consistent error message 'memory allocation failed'
6622 - CLEANUP: Compare the return value of `XXXcmp()` functions with zero
6623 - CLEANUP: Apply the coccinelle patch for `XXXcmp()` on include/
6624 - CLEANUP: Apply the coccinelle patch for `XXXcmp()` on contrib/
6625 - MINOR: qpack: Add static header table definitions for QPACK.
6626 - CLEANUP: qpack: Wrong comment about the draft for QPACK static header table.
6627 - CLEANUP: quic: Remove useless QUIC event trace definitions.
6628 - BUG/MINOR: quic: Possible CRYPTO frame building errors.
6629 - MINOR: quic: Pass quic_conn struct to frame parsers.
6630 - BUG/MINOR: quic: Wrong STREAM frames parsing.
6631 - MINOR: quic: Drop packets with STREAM frames with wrong direction.
6632 - CLEANUP: ssl: Remove useless loop in tlskeys_list_get_next()
6633 - CLEANUP: ssl: Remove useless local variable in tlskeys_list_get_next()
6634 - MINOR: ssl: make tlskeys_list_get_next() take a list element
6635 - Revert "BUILD: Makefile: disable -Warray-bounds until it's fixed in gcc 11"
6636 - BUG/MINOR: cfgparse: Fail if the strdup() for `rule->be.name` for `use_backend` fails
6637 - CLEANUP: mworker: remove duplicate pointer tests in cfg_parse_program()
6638 - CLEANUP: Reduce scope of `header_name` in http_action_store_cache()
6639 - CLEANUP: Reduce scope of `hdr_age` in http_action_store_cache()
6640 - CLEANUP: spoe: fix typo on `var_check_arg` comment
6641 - BUG/MINOR: tcpcheck: Report a L7OK if the last evaluated rule is a send rule
6642 - CI: github actions: build several popular "contrib" tools
6643 - DOC: Improve the message printed when running `make` w/o `TARGET`
6644 - BUG/MEDIUM: server: srv_set_addr_desc() crashes when a server has no address
6645 - REGTESTS: add unresolvable servers to srvkey-addr
6646 - BUG/MINOR: stats: Make stat_l variable used to dump a stat line thread local
6647 - BUG/MINOR: quic: NULL pointer dereferences when building post handshake frames.
6648 - SCRIPTS: improve announce-release to support different tag and versions
6649 - SCRIPTS: make announce release support preparing announces before tag exists
6650 - CLEANUP: assorted typo fixes in the code and comments
6651 - BUG/MINOR: srv: do not init address if backend is disabled
6652 - BUG/MINOR: srv: do not cleanup idle conns if pool max is null
6653 - CLEANUP: assorted typo fixes in the code and comments
6654 - CLEANUP: few extra typo and fixes over last one ("ot" -> "to")
6655
Willy Tarreau4d711762020-12-21 11:54:56 +010066562020/12/21 : 2.4-dev4
6657 - BUG/MEDIUM: lb-leastconn: Reposition a server using the right eweight
6658 - BUG/MEDIUM: mux-h1: Fix a deadlock when a 408 error is pending for a client
6659 - BUG/MEDIUM: ssl/crt-list: bad behavior with "commit ssl cert"
6660 - BUG/MAJOR: cache: Crash because of disabled entry not removed from the tree
6661 - BUILD: SSL: fine guard for SSL_CTX_add_server_custom_ext call
6662 - MEDIUM: cache: Add a secondary entry counter and insertion limitation
6663 - MEDIUM: cache: Avoid going over duplicates lists too often
6664 - MINOR: cache: Add a max-secondary-entries cache option
6665 - CI: cirrus: drop CentOS 6 builds
6666 - BUILD: Makefile: have "make clean" destroy .o/.a/.s in contrib subdirs as well
6667 - MINOR: vars: replace static functions with global ones
6668 - MINOR: opentracing: add ARGC_OT enum
6669 - CONTRIB: opentracing: add the OpenTracing filter
6670 - DOC: opentracing: add the OpenTracing filter section
6671 - REGTESTS: make use of HAPROXY_ARGS and pass -dM by default
6672 - BUG/MINOR: http: Establish a tunnel for all 2xx responses to a CONNECT
6673 - BUG/MINOR: mux-h1: Don't set CS_FL_EOI too early for protocol upgrade requests
6674 - BUG/MEDIUM: http-ana: Never for sending data in TUNNEL mode
6675 - CLEANUP: mux-h2: Rename h2s_frt_make_resp_data() to be generic
6676 - CLEANUP: mux-h2: Rename h2c_frt_handle_data() to be generic
6677 - BUG/MEDIUM: mux-h1: Handle h1_process() failures on a pipelined request
6678 - CLEANUP: debug: mark the RNG's seed as unsigned
6679 - CONTRIB: halog: fix build issue caused by %L printf format
6680 - CONTRIB: halog: mark the has_zero* functions unused
6681 - CONTRIB: halog: fix signed/unsigned build warnings on counts and timestamps
6682 - CONTRIB: debug: address "poll" utility build on non-linux platforms
6683 - BUILD: plock: remove dead code that causes a warning in gcc 11
6684 - BUILD: ssl: fine guard for SSL_CTX_get0_privatekey call
6685 - BUG/MINOR: dns: SRV records ignores duplicated AR records
6686 - DOC: fix "smp_size" vs "sample_size" in "log" directive arguments
6687 - CLEANUP: assorted typo fixes in the code and comments
6688 - DOC: assorted typo fixes in the documentation
6689 - CI: codespell: whitelist "te" and "nd" words
6690
Willy Tarreaua786c412020-12-11 17:22:51 +010066912020/12/11 : 2.4-dev3
6692 - MINOR: log: Logging HTTP path only with %HPO
6693 - BUG/MINOR: mux-h2/stats: make stream/connection proto errors more accurate
6694 - MINOR: traces: add a new level "error" below the "user" level
6695 - MINOR: mux-h2/trace: add traces at level ERROR for protocol errors
6696 - BUG/MINOR: mux-h2/stats: not all GOAWAY frames are errors
6697 - BUG/MINOR: lua: missing "\n" in error message
6698 - BUG/MINOR: lua: lua-load doesn't check its parameters
6699 - BUG/MINOR: lua: Post init register function are not executed beyond the first one
6700 - BUG/MINOR: lua: Some lua init operation are processed unsafe
6701 - MINOR: actions: Export actions lookup functions
6702 - MINOR: actions: add a function returning a service pointer from its name
6703 - MINOR: cli: add a function to look up a CLI service description
6704 - BUG/MINOR: lua: warn when registering action, conv, sf, cli or applet multiple times
6705 - MINOR: cache: Improve accept_encoding_normalizer
6706 - MINOR: cache: Add entry to the tree as soon as possible
6707 - BUG/MINOR: trace: Wrong displayed trace level
6708 - BUG/MAJOR: ring: tcp forward on ring can break the reader counter.
6709 - MINOR: lua: simplify hlua_alloc() to only rely on realloc()
6710 - MEDIUM: lua-thread: use atomics for memory accounting
6711 - MINOR: lua-thread: remove struct hlua from function hlua_prepend_path()
6712 - MEDIUM: lua-thread: make hlua_post_init() no longer use the runtime execution function
6713 - MINOR: lua-thread: hlua_ctx_renew() is never called with main gL lua state
6714 - MINOR: lua-thread: Use NULL context for main lua state
6715 - MINOR: lua-thread: Stop usage of struct hlua for the global lua state
6716 - MINOR: lua-thread: Replace embedded struct hlua_function by a pointer
6717 - MINOR: lua-thread: Split hlua_init() function in two parts
6718 - MINOR: lua-thread: make hlua_ctx_init() get L from its caller
6719 - MINOR: lua-thread: Split hlua_load function in two parts
6720 - MINOR: lua-thread: Split hlua_post_init() function in two parts
6721 - MINOR: lua-thread: Add the "thread" core variable
6722 - MEDIUM: lua-thread: No longer use locked context in initialization parts
6723 - MEDIUM: lua-thread: Apply lock only if the parent state is the main thread
6724 - MINOR: lua-thread: Replace global gL var with an array of states
6725 - MINOR: lua-thread: Replace "struct hlua_function" allocation by dedicated function
6726 - MINOR: lua-thread: Replace state_from by state_id
6727 - MINOR: lua-thread: Store each function reference and init reference in array
6728 - MEDIUM: lua-thread: Add the lua-load-per-thread directive
6729 - MINOR: lua-thread: Add verbosity in errors
6730 - REGTESTS: add a test for the threaded Lua code
6731 - BUILD/MINOR: haproxy DragonFlyBSD affinity build update.
6732 - DOC/MINOR: Fix formatting in Management Guide
6733 - MINOR: cache: Do not store stale entry
6734 - MINOR: cache: Add extra "cache-control" value checks
6735 - MEDIUM: cache: Remove cache entry in case of POST on the same resource
6736 - MINOR: cache: Consider invalid Age values as stale
6737 - BUG/MEDIUM: lua-thread: some parts must be initialized once
6738 - BUG/MINOR: lua-thread: close all states on deinit
6739 - BUG/MINOR: listener: use sockaddr_in6 for IPv6
6740 - BUG/MINOR: mux-h1: Handle keep-alive timeout for idle frontend connections
6741 - MINOR: session: Add the idle duration field into the session
6742 - MINOR: mux-h1: Update session idle duration when data are received
6743 - MINOR: mux-h1: Reset session dates and durations info when the CS is detached
6744 - MINOR: logs: Use session idle duration when no stream is provided
6745 - MINOR: stream: Always get idle duration from the session
6746 - MINOR: stream: Don't retrieve anymore timing info from the mux csinfo
6747 - MINOR: mux-h1: Don't provide anymore timing info using cs_info structure
6748 - MINOR: muxes: Remove get_cs_info callback function now useless
6749 - MINOR: stream: Pass an optional input buffer when a stream is created
6750 - MINOR: mux-h1: Add a flag to disable reads to wait opposite side
6751 - MEDIUM: mux-h1: Use a h1c flag to block reads when splicing is in-progress
6752 - MINOR: mux-h1: Introduce H1C_F_IS_BACK flag on the H1 connection
6753 - MINOR: mux-h1: Separate parsing and formatting errors at H1 stream level
6754 - MINOR: mux-h1: Split front/back h1 stream creation in 2 functions
6755 - MINOR: mux-h1: Add a rxbuf into the H1 stream
6756 - MINOR: mux-h1: Don't set CS flags in internal parsing functions
6757 - MINOR: mux-h1: Add embryonic and attached states on the H1 connection
6758 - MINOR: mux-h1: rework the h1_timeout_task() function
6759 - MINOR: mux-h1: Reset more H1C flags when a H1 stream is destroyed
6760 - MINOR: mux-h1: Disable reads if an error was reported on the H1 stream
6761 - MINOR: mux-h1: Rework how shutdowns are handled
6762 - MINOR: mux-h1: Rework h1_refresh_timeout to be easier to read
6763 - MINOR: mux-h1: Process next request for IDLE connection only
6764 - MINOR: mux-h1: Add a idle expiration date on the H1 connection
6765 - MINOR: stick-tables: Add functions to update some values of a tracked counter
6766 - MINOR: session: Add functions to increase http values of tracked counters
6767 - MINOR: mux: Add a ctl parameter to get the exit status of the multiplexers
6768 - MINOR: logs: Get the multiplexer exist status when no stream is provided
6769 - MINOR: mux-h1: Add functions to send HTTP errors from the mux
6770 - MAJOR: mux-h1: Create the client stream as later as possible
6771 - DOC: config: Add notes about errors emitted by H1 mux
6772 - CLEANUP: mux-h1: Rename H1C_F_CS_* flags and reorder H1C flags
6773 - MINOR: http-ana: Remove useless update of t_idle duration of the stream
6774 - CLEANUP: htx: Remove HTX_FL_UPGRADE unsued flag
6775 - MEDIUM: http-ana: Don't process partial or empty request anymore
6776 - CLEANUP: http-ana: Remove TX_WAIT_NEXT_RQ unsued flag
6777 - CLEANUP: connection: Remove CS_FL_READ_PARTIAL flag
6778 - REGTESTS: Fix proxy_protocol_tlv_validation
6779 - MINOR: http-ana: Properly set message flags from the start-line flags
6780 - MINOR: h1-htx/http-ana: Set BODYLESS flag on message in TUNNEL state
6781 - MINOR: protocol: add a ->set_port() helper to address families
6782 - MINOR: listener: automatically set the port when creating listeners
6783 - MINOR: listener: now use a generic add_listener() function
6784 - MEDIUM: ssl: fatal error with bundle + openssl < 1.1.1
6785 - BUG/MEDIUM: stream: Xfer the input buffer to a fully created stream
6786 - BUG/MINOR: stream: Don't use input buffer after the ownership xfer
6787 - MINOR: protocol: remove the redundant ->sock_domain field
6788 - MINOR: protocol: export protocol definitions
6789 - CLEANUP: protocol: group protocol struct members by usage
6790 - MINOR: protocol: add a set of ctrl_init/ctrl_close methods for setup/teardown
6791 - MINOR: connection: use the control layer's init/close
6792 - MINOR: udp: export udp_suspend_receiver() and udp_resume_receiver()
6793 - BUG/MAJOR: spoa/python: Fixing return None
6794 - DOC: spoa/python: Fixing typo in IP related error messages
6795 - DOC: spoa/python: Rephrasing memory related error messages
6796 - DOC: spoa/python: Fixing typos in comments
6797 - BUG/MINOR: spoa/python: Cleanup references for failed Module Addobject operations
6798 - BUG/MINOR: spoa/python: Cleanup ipaddress objects if initialization fails
6799 - BUG/MEDIUM: spoa/python: Fixing PyObject_Call positional arguments
6800 - BUG/MEDIUM: spoa/python: Fixing references to None
6801 - DOC: email change of the DeviceAtlas maintainer
6802 - MINOR: cache: Dump secondary entries in "show cache"
6803 - CLEANUP: connection: use fd_stop_both() instead of conn_stop_polling()
6804 - MINOR: stream-int: don't touch polling anymore on shutdown
6805 - MINOR: connection: implement cs_drain_and_close()
6806 - MINOR: mux-pt: take care of CS_SHR_DRAIN in shutr()
6807 - MINOR: checks: use cs_drain_and_close() instead of draining the connection
6808 - MINOR: checks: don't call conn_cond_update_polling() anymore
6809 - CLEANUP: connection: open-code conn_cond_update_polling() and update the comment
6810 - CLEANUP: connection: remove the unused conn_{stop,cond_update}_polling()
6811 - BUG/MINOR: http-check: Use right condition to consider HTX message as full
6812 - BUG/MINOR: tcpcheck: Don't rearm the check timeout on each read
6813 - MINOR: tcpcheck: Only wait for more payload data on HTTP expect rules
6814 - BUG/MINOR: tools: make parse_time_err() more strict on the timer validity
6815 - BUG/MINOR: tools: Reject size format not starting by a digit
6816 - MINOR: action: define enum for timeout type of the set-timeout rule
6817 - MINOR: stream: prepare the hot refresh of timeouts
6818 - MEDIUM: stream: support a dynamic server timeout
6819 - MEDIUM: stream: support a dynamic tunnel timeout
6820 - MEDIUM: http_act: define set-timeout server/tunnel action
6821 - MINOR: frontend: add client timeout sample fetch
6822 - MINOR: backend: add timeout sample fetches
6823 - MINOR: stream: add sample fetches
6824 - MINOR: stream: add timeout sample fetches
6825 - REGTESTS: add regtest for http-request set-timeout
6826 - CLEANUP: remove the unused fd_stop_send() in conn_xprt_shutw{,_hard}()
6827 - CLEANUP: connection: remove the unneeded fd_stop_{recv,send} on read0/shutw
6828 - MINOR: connection: remove sock-specific code from conn_sock_send()
6829 - REORG: connection: move the socket iocb (conn_fd_handler) to sock.c
6830 - MINOR: protocol: add a ->drain() function at the connection control layer
6831 - MINOR: connection: make conn_sock_drain() use the control layer's ->drain()
6832 - MINOR: protocol: add a pair of check_events/ignore_events functions at the ctrl layer
6833 - MEDIUM: connection: make use of the control layer check_events/ignore_events
6834
Willy Tarreauc94431b2020-12-01 08:15:26 +010068352020/12/01 : 2.4-dev2
6836 - BUILD: Make DEBUG part of .build_opts
6837 - BUILD: Show the value of DEBUG= in haproxy -vv
6838 - CI: Set DEBUG=-DDEBUG_STRICT=1 in GitHub Actions
6839 - MINOR: stream: Add level 7 retries on http error 401, 403
6840 - CLEANUP: remove unused function "ssl_sock_is_ckch_valid"
6841 - BUILD: SSL: add BoringSSL guarding to "RAND_keep_random_devices_open"
6842 - BUILD: SSL: do not "update" BoringSSL version equivalent anymore
6843 - BUG/MEDIUM: http_act: Restore init of log-format list
6844 - DOC: better describes how to configure a fallback crt
6845 - BUG/MAJOR: filters: Always keep all offsets up to date during data filtering
6846 - MINOR: cache: Prepare helper functions for Vary support
6847 - MEDIUM: cache: Add the Vary header support
6848 - MINOR: cache: Add a process-vary option that can enable/disable Vary processing
6849 - BUG/CRITICAL: cache: Fix trivial crash by sending accept-encoding header
6850 - BUG/MAJOR: peers: fix partial message decoding
6851 - DOC: cache: Add new caching limitation information
6852 - DOC: cache: Add information about Vary support
6853 - DOC: better document the config file format and escaping/quoting rules
6854 - DOC: Clarify %HP description in log-format
6855 - CI: github actions: update LibreSSL to 3.3.0
6856 - CI: github actions: enable 51degrees feature
6857 - MINOR: fd/threads: silence a build warning with threads disabled
6858 - BUG/MINOR: tcpcheck: Don't forget to reset tcp-check flags on new kind of check
6859 - MINOR: tcpcheck: Don't handle anymore in-progress send rules in tcpcheck_main
6860 - BUG/MAJOR: tcpcheck: Allocate input and output buffers from the buffer pool
6861 - MINOR: tcpcheck: Don't handle anymore in-progress connect rules in tcpcheck_main
6862 - MINOR: config: Deprecate and ignore tune.chksize global option
6863 - MINOR: config: Add a warning if tune.chksize is used
6864 - REORG: tcpcheck: Move check option parsing functions based on tcp-check
6865 - MINOR: check: Always increment check health counter on CONPASS
6866 - MINOR: tcpcheck: Add support of L7OKC on expect rules error-status argument
6867 - DOC: config: Make disable-on-404 option clearer on transition conditions
6868 - DOC: config: Move req.hdrs and req.hdrs_bin in L7 samples fetches section
6869 - BUG/MINOR: http-fetch: Fix smp_fetch_body() when called from a health-check
6870 - MINOR: plock: use an ARMv8 instruction barrier for the pause instruction
6871 - MINOR: debug: add "debug dev sched" to stress the scheduler.
6872 - MINOR: debug: add a trivial PRNG for scheduler stress-tests
6873 - BUG/MEDIUM: lists: Lock the element while we check if it is in a list.
6874 - MINOR: task: remove tasklet_insert_into_tasklet_list()
6875 - MINOR: task: perform atomic counter increments only once per wakeup
6876 - MINOR: task: remove __tasklet_remove_from_tasklet_list()
6877 - BUG/MEDIUM: task: close a possible data race condition on a tasklet's list link
6878 - BUG/MEDIUM: local log format regression.
6879
Willy Tarreau1a38ffc2020-11-21 16:00:40 +010068802020/11/21 : 2.4-dev1
6881 - MINOR: ist: Add istend() function to return a pointer to the end of the string
6882 - MINOR: sample: Add converters to parse FIX messages
6883 - REGTEST: converter: Add a regtest for fix converters
6884 - MINOR: sample: Add converts to parses MQTT messages
6885 - REGTEST: converter: Add a regtest for MQTT converters
6886 - MINOR: compat: automatically include malloc.h on glibc
6887 - MEDIUM: pools: call malloc_trim() from pool_gc()
6888 - MEDIUM: pattern: call malloc_trim() on pat_ref_reload()
6889 - MINOR: pattern: move the update revision to the pat_ref, not the expression
6890 - CLEANUP: pattern: delete the back refs at once during pat_ref_reload()
6891 - MINOR: pattern: new sflag PAT_SF_REGFREE indicates regex_free() is needed
6892 - MINOR: pattern: make the delete and prune functions more generic
6893 - MEDIUM: pattern: link all final elements from the reference
6894 - MEDIUM: pattern: change the pat_del_* functions to delete from the references
6895 - MINOR: pattern: remerge the list and tree deletion functions
6896 - MINOR: pattern: perform a single call to pat_delete_gen() under the expression
6897 - CLEANUP: acl: don't reference the generic pattern deletion function anymore
6898 - CLEANUP: pattern: remove pat_delete_fcts[] and pattern_head->delete()
6899 - MINOR: pattern: introduce pat_ref_delete_by_ptr() to delete a valid reference
6900 - MINOR: pattern: store a generation number in the reference patterns
6901 - MEDIUM: pattern: only match patterns that match the current generation
6902 - MINOR: pattern: add pat_ref_commit() to commit a previously inserted element
6903 - MINOR: pattern: implement pat_ref_load() to load a pattern at a given generation
6904 - MINOR: pattern: add pat_ref_purge_older() to purge old entries
6905 - MEDIUM: pattern: make pat_ref_prune() rely on pat_ref_purge_older()
6906 - MINOR: pattern: during reload, delete elements frem the ref, not the expression
6907 - MINOR: pattern: prepare removal of a pattern from the list head
6908 - MEDIUM: pattern: turn the pattern chaining to single-linked list
6909 - CLEANUP: cfgparse: remove duplicate registration for transparent build options
6910 - BUG/MINOR: ssl: don't report 1024 bits DH param load error when it's higher
6911 - MINOR: http-htx: Add understandable errors for the errorfiles parsing
6912 - MINOR: ssl: instantiate stats module
6913 - MINOR: ssl: count client hello for stats
6914 - MINOR: ssl: add counters for ssl sessions
6915 - DOC: config: Fix a typo on ssl_c_chain_der
6916 - MINOR: server: remove idle lock in srv_cleanup_connections
6917 - BUILD: ssl: silence build warning on uninitialised counters
6918 - BUILD: http-htx: fix build warning regarding long type in printf
6919 - REGTEST: ssl: test wildcard and multi-type + exclusions
6920 - BUG/MEDIUM: ssl/crt-list: correctly insert crt-list line if crt already loaded
6921 - CI: Expand use of GitHub Actions for CI
6922 - REGTEST: ssl: mark reg-tests/ssl/ssl_crt-list_filters.vtc as broken
6923 - BUG/MINOR: pattern: a sample marked as const could be written
6924 - BUG/MINOR: lua: set buffer size during map lookups
6925 - MEDIUM: cache: Change caching conditions
6926 - BUG/MINOR: stats: free dynamically stats fields/lines on shutdown
6927 - BUG/MEDIUM: stats: prevent crash if counters not alloc with dummy one
6928 - MINOR: peers: Add traces to peer_treat_updatemsg().
6929 - BUG/MINOR: peers: Do not ignore a protocol error for dictionary entries.
6930 - BUG/MINOR: peers: Missing TX cache entries reset.
6931 - BUG/MEDIUM: peers: fix decoding of multi-byte length in stick-table messages
6932 - BUG/MINOR: http-fetch: Extract cookie value even when no cookie name
6933 - BUG/MINOR: http-fetch: Fix calls w/o parentheses of the cookie sample fetches
6934 - BUG/MEDIUM: check: reuse srv proto only if using same mode
6935 - MINOR: check: report error on incompatible proto
6936 - MINOR: check: report error on incompatible connect proto
6937 - BUG/MINOR: http-htx: Handle warnings when parsing http-error and http-errors
6938 - BUG/MAJOR: spoe: Be sure to remove all references on a released spoe applet
6939 - MINOR: spoe: Don't close connection in sync mode on processing timeout
6940 - BUG/MINOR: tcpcheck: Don't warn on unused rules if check option is after
6941 - MINOR: init: Fix the prototype for per-thread free callbacks
6942 - MINOR: config/mux-h2: Return ERR_ flags from init_h2() instead of a status
6943 - CLEANUP: config: Return ERR_NONE from config callbacks instead of 0
6944 - MINOR: cfgparse: tighten the scope of newnameserver variable, free it on error.
6945 - REGTEST: make ssl_client_samples and ssl_server_samples require to 2.2
6946 - REGTESTS: Add sample_fetches/cook.vtc
6947 - BUG/MEDIUM: filters: Forward all filtered data at the end of http filtering
6948 - BUG/MINOR: http-ana: Don't wait for the body of CONNECT requests
6949 - CLEANUP: flt-trace: Remove unused random-parsing option
6950 - MINOR: flt-trace: Add an option to inhibits trace messages
6951 - MINOR: flt-trace: Use a bitfield for the trace options
6952 - REGTESTS: Add a script to test the random forwarding with several filters
6953 - REGTESTS: mark the abns test as broken again
6954 - REGTESTS: converter: add url_dec test
6955 - CI: Stop hijacking the hosts file
6956 - CI: Make the h2spec workflow more consistent with the VTest workflow
6957 - CI: travis-ci: remove amd64, osx builds
6958 - CI: travis-ci: arm64 are not allowed to fail anymore
6959 - DOC: add missing 3.10 in the summary
6960 - MINOR: ssl: remove client hello counters
6961 - MEDIUM: stats: add counters for failed handshake
6962 - MINOR: ssl: create common ssl_ctx init
6963 - MEDIUM: cli/ssl: configure ssl on server at runtime
6964 - REGTEST: server/cli_set_ssl.vtc requires OpenSSL
6965 - DOC: coding-style: update a few rules about pointers
6966 - BUG/MINOR: ssl: segv on startup when AKID but no keyid
6967 - BUILD: ssl: use SSL_MODE_ASYNC macro instead of OPENSSL_VERSION
6968 - BUG/MEDIUM: http-ana: Don't eval http-after-response ruleset on empty messages
6969 - BUG/MEDIUM: ssl/crt-list: bundle support broken in crt-list
6970 - BUG/MEDIUM: ssl: error when no certificate are found
6971 - BUG/MINOR: ssl/crt-list: load bundle in crt-list only if activated
6972 - BUG/MEDIUM: ssl/crt-list: fix error when no file found
6973 - CI: Github Actions: enable prometheus exporter
6974 - CI: Github Actions: remove LibreSSL-3.0.2 builds
6975 - CI: Github Actions: enable BoringSSL builds
6976 - CI: travis-ci: remove builds migrated to GH actions
6977 - BUILD: makefile: enable crypt(3) for OpenBSD
6978 - CI: Github Action: run "apt-get update" before packages restore
6979 - BUILD: SSL: guard TLS13 ciphersuites with HAVE_SSL_CTX_SET_CIPHERSUITES
6980 - CI: Pass the github.event_name to matrix.py
6981 - CI: Clean up Windows CI
6982 - DOC: clarify how to create a fallback crt
6983 - CLEANUP: connection: do not use conn->owner when the session is known
6984 - BUG/MAJOR: connection: reset conn->owner when detaching from session list
6985 - REGTESTS: mark proxy_protocol_random_fail as broken
6986 - BUG/MINOR: http_htx: Fix searching headers by substring
6987 - MINOR: http_act: Add -m flag for del-header name matching method
6988
Willy Tarreau1db55792020-11-05 17:20:35 +010069892020/11/05 : 2.4-dev0
6990 - MINOR: version: it's development again.
6991 - DOC: mention in INSTALL that it's development again
6992
Willy Tarreau1c0a7222020-11-05 17:04:53 +010069932020/11/05 : 2.3.0
6994 - CLEANUP: pattern: remove unused entry "tree" in pattern.val
6995 - BUILD: ssl: use SSL_CTRL_GET_RAW_CIPHERLIST instead of OpenSSL versions
6996 - BUG/MEDIUM: filters: Don't try to init filters for disabled proxies
6997 - BUG/MINOR: proxy/server: Skip per-proxy/server post-check for disabled proxies
6998 - BUG/MINOR: checks: Report a socket error before any connection attempt
6999 - BUG/MINOR: server: Set server without addr but with dns in RMAINT on startup
7000 - MINOR: server: Copy configuration file and line for server templates
7001 - BUG/MEDIUM: mux-pt: Release the tasklet during an HTTP upgrade
7002 - BUILD: ssl: use HAVE_OPENSSL_KEYLOG instead of OpenSSL versions
7003 - MINOR: debug: don't count free(NULL) in memstats
7004 - BUG/MINOR: filters: Skip disabled proxies during startup only
7005 - MINOR: mux_h2: capitalize frame type in stats
7006 - MINOR: mux_h2: add stat for total count of connections/streams
7007 - MINOR: stats: do not display empty stat module title on html
7008 - BUG/MEDIUM: stick-table: limit the time spent purging old entries
7009 - BUG/MEDIUM: listener: only enable a listening listener if needed
7010 - BUG/MEDIUM: listener: never suspend inherited sockets
7011 - BUG/MEDIUM: listener: make the master also keep workers' inherited FDs
7012 - MINOR: fd: add fd_want_recv_safe()
7013 - MEDIUM: listeners: make use of fd_want_recv_safe() to enable early receivers
7014 - REGTESTS: mark abns_socket as working now
7015 - CLEANUP: mux-h2: Remove the h1 parser state from the h2 stream
7016 - MINOR: sock: add a check against cross worker<->master socket activities
7017 - CI: github actions: limit OpenSSL no-deprecated builds to "default,bug,devel" reg-tests
7018 - BUG/MEDIUM: server: make it possible to kill last idle connections
7019 - MINOR: mworker/cli: the master CLI use its own applet
7020 - MINOR: ssl: define SSL_CTX_set1_curves_list to itself on BoringSSL
7021 - BUILD: ssl: use feature macros for detecting ec curves manipulation support
7022 - DOC: Add dns as an available domain to show stat
7023 - BUILD: makefile: usual reorder of objects for faster builds
7024 - DOC: update INSTALL to mention that TCC is supported
7025 - DOC: mention in INSTALL that haproxy 2.3 is a stable version
7026 - MINOR: version: mention that it's stable now
7027
Willy Tarreaubd703e52020-10-31 13:17:06 +010070282020/10/31 : 2.3-dev9
7029 - CLEANUP: http_ana: remove unused assignation of `att_beg`
7030 - BUG/MEDIUM: ssl: OCSP must work with BoringSSL
7031 - BUG/MINOR: log: fix memory leak on logsrv parse error
7032 - BUG/MINOR: log: fix risk of null deref on error path
7033 - BUILD: ssl: more elegant OpenSSL early data support check
7034 - CI: github actions: update h2spec to 2.6.0
7035 - BUG/MINOR: cache: Check the return value of http_replace_res_status
7036 - MINOR: cache: Store the "Last-Modified" date in the cache_entry
7037 - MINOR: cache: Process the If-Modified-Since header in conditional requests
7038 - MINOR: cache: Create res.cache_hit and res.cache_name sample fetches
7039 - MINOR: mux-h2: register a stats module
7040 - MINOR: mux-h2: add counters instance to h2c
7041 - MINOR: mux-h2: add stats for received frame types
7042 - MINOR: mux-h2: report detected error on stats
7043 - MINOR: mux-h2: count open connections/streams on stats
7044 - BUG/MINOR: server: fix srv downtime calcul on starting
7045 - BUG/MINOR: server: fix down_time report for stats
7046 - BUG/MINOR: lua: initialize sample before using it
7047 - MINOR: cache: Add Expires header value parsing
7048 - MINOR: ist: Add a case insensitive istmatch function
7049 - BUG/MINOR: cache: Manage multiple values in cache-control header value
7050 - BUG/MINOR: cache: Inverted variables in http_calc_maxage function
7051 - MINOR: pattern: make pat_ref_append() return the newly added element
7052 - MINOR: pattern: make pat_ref_add() rely on pat_ref_append()
7053 - MINOR: pattern: export pat_ref_push()
7054 - CLEANUP: pattern: use calloc() rather than malloc for structures
7055 - CLEANUP: pattern: fix spelling/grammatical/copy-paste in comments
7056
Willy Tarreaufb1b9e32020-10-24 13:14:31 +020070572020/10/24 : 2.3-dev8
7058 - MINOR: backend: replace the lbprm lock with an rwlock
7059 - MINOR: lb/map: use seek lock and read locks where appropriate
7060 - MINOR: lb/leastconn: only take a read lock in fwlc_get_next_server()
7061 - MINOR: lb/first: use a read lock in fas_get_next_server()
7062 - MINOR: lb/chash: use a read lock in chash_get_server_hash()
7063 - BUG/MINOR: disable dynamic OCSP load with BoringSSL
7064 - BUILD: ssl: make BoringSSL use its own version numbers
7065 - CLEANUP: threads: don't register an initcall when not debugging
7066 - MINOR: threads: change lock_t to an unsigned int
7067 - CLEANUP: tree-wide: reorder a few structures to plug some holes around locks
7068 - CLEANUP: task: remove the unused and mishandled global_rqueue_size
7069 - BUG/MEDIUM: connection: Never cleanup server lists when freeing private conns
7070 - MEDIUM: config: report that "nbproc" is deprecated
7071 - BUG/MINOR: listener: close before free in `listener_accept`
7072 - MINOR: ssl: 'ssl-load-extra-del-ext' removes the certificate extension
7073 - BUG/MINOR: queue: properly report redistributed connections
7074 - CONTRIB: tcploop: remove unused local variables in tcp_pause()
7075 - BUILD: makefile: add entries to build common debugging tools
7076 - BUG/MEDIUM: server: support changing the slowstart value from state-file
7077 - MINOR: http: Add `enum etag_type http_get_etag_type(const struct ist)`
7078 - MINOR: http: Add etag comparison function
7079 - MEDIUM: cache: Store the ETag information in the cache_entry
7080 - MEDIUM: cache: Add support for 'If-None-Match' request header
7081 - REGTEST: cache: Add if-none-match test case
7082 - CLEANUP: compression: Make use of http_get_etag_type()
7083 - BUG/MINOR: http-ana: Don't send payload for internal responses to HEAD requests
7084 - BUG/MAJOR: mux-h2: Don't try to send data if we know it is no longer possible
7085 - MINOR: threads/debug: only report used lock stats
7086 - MINOR: threads/debug: only report lock stats for used operations
7087 - MINOR: proxy; replace the spinlock with an rwlock
7088 - MINOR: server: read-lock the cookie during srv_set_dyncookie()
7089 - MINOR: proxy/cli: only take a read lock in "show errors"
7090 - OPTIM: queue: don't call pendconn_unlink() when the pendconn is not queued
7091 - MINOR: queue: split __pendconn_unlink() in per-srv and per-prx
7092 - MINOR: queue: reduce the locked area in pendconn_add()
7093 - OPTIM: queue: make the nbpend counters atomic
7094 - OPTIM: queue: decrement the nbpend and totpend counters outside of the lock
7095 - MINOR: leastconn: take the queue length into account when queuing servers
7096 - MEDIUM: fwlc: re-enable per-server queuing up to maxqueue
7097 - Revert "OPTIM: queue: don't call pendconn_unlink() when the pendconn is not queued"
7098 - MINOR: stats: support the "up" output modifier for "show stat"
7099 - MINOR: stats: also support a "no-maint" show stat modifier
7100 - MINOR: stats: indicate the number of servers in a backend's status
7101 - MEDIUM: ssl: ssl-load-extra-del-ext work only with .crt
7102 - REGTEST: ssl: test "set ssl cert" with separate key / crt
7103 - DOC: management: apply the "show stat" modifiers to "show stat", not "show info"
7104 - MINOR: stats: report server's user-configured weight next to effective weight
7105 - CI: travis-ci: switch to Ubuntu 20.04
7106 - CONTRIB: release-estimator: Add release estimating tool
7107 - BUG/MEDIUM: queue: fix unsafe proxy pointer when counting nbpend
7108 - BUG/MINOR: extcheck: add missing checks on extchk_setenv()
7109
Willy Tarreau9d58c9b2020-10-17 10:31:50 +020071102020/10/17 : 2.3-dev7
7111 - CI: travis-ci: replace not defined SSL_LIB, SSL_INC for BotringSSL builds
7112 - BUG/MINOR: init: only keep rlim_fd_cur if max is unlimited
7113 - BUG/MINOR: mux-h2: do not stop outgoing connections on stopping
7114 - MINOR: fd: report an error message when failing initial allocations
7115 - MINOR: proto-tcp: make use of connect(AF_UNSPEC) for the pause
7116 - MINOR: sock: add sock_accept_conn() to test a listening socket
7117 - MINOR: protocol: make proto_tcp & proto_uxst report listening sockets
7118 - MINOR: sockpair: implement the .rx_listening function
7119 - CLEANUP: tcp: make use of sock_accept_conn() where relevant
7120 - CLEANUP: unix: make use of sock_accept_conn() where relevant
7121 - BUG/MINOR: listener: detect and handle shared sockets stopped in other processes
7122 - CONTRIB: tcploop: implement a disconnect operation 'D'
7123 - CLEANUP: protocol: intitialize all of the sockaddr when disconnecting
7124 - BUG/MEDIUM: deinit: check fdtab before fdtab[fd].owner
7125 - BUG/MINOR: connection: fix loop iter on connection takeover
7126 - BUG/MEDIUM: connection: fix srv idle count on conn takeover
7127 - MINOR: connection: improve list api usage
7128 - MINOR: mux/connection: add a new mux flag for HOL risk
7129 - MINOR: connection: don't check priv flag on free
7130 - MEDIUM: backend: add new conn to session if mux marked as HOL blocking
7131 - MEDIUM: backend: add reused conn to sess if mux marked as HOL blocking
7132 - MEDIUM: h2: remove conn from session on detach
7133 - MEDIUM: fcgi: remove conn from session on detach
7134 - DOC: Describe reuse safe for HOL handling
7135 - MEDIUM: proxy: remove obsolete "mode health"
7136 - MEDIUM: proxy: remove obsolete "monitor-net"
7137 - CLEANUP: protocol: remove the ->drain() function
7138 - CLEANUP: fd: finally get rid of fd_done_recv()
7139 - MINOR: connection: make sockaddr_alloc() take the address to be copied
7140 - MEDIUM: listener: allocate the connection before queuing a new connection
7141 - MINOR: session: simplify error path in session_accept_fd()
7142 - MINOR: connection: add new error codes for accept_conn()
7143 - MINOR: sock: rename sock_accept_conn() to sock_accepting_conn()
7144 - MINOR: protocol: add a new function accept_conn()
7145 - MINOR: sock: implement sock_accept_conn() to accept a connection
7146 - MINOR: sockpair: implement sockpair_accept_conn() to accept a connection
7147 - MEDIUM: listener: use protocol->accept_conn() to accept a connection
7148 - MEDIUM: listener: remove the second pass of fd manipulation at the end
7149 - MINOR: protocol: add a default I/O callback and put it into the receiver
7150 - MINOR: log: set the UDP receiver's I/O handler in the receiver
7151 - MINOR: protocol: register the receiver's I/O handler and not the protocol's
7152 - CLEANUP: protocol: remove the now unused <handler> field of proto_fam->bind()
7153 - DOC: improve the documentation for "option nolinger"
7154 - BUG/MEDIUM: proxy: properly stop backends
7155 - BUG/MEDIUM: task: bound the number of tasks picked from the wait queue at once
7156 - MINOR: threads: augment rwlock debugging stats to report seek lock stats
7157 - MINOR: threads: add the transitions to/from the seek state
7158 - MEDIUM: task: use an upgradable seek lock when scanning the wait queue
7159 - BUILD: listener: avoir a build warning when threads are disabled
7160 - BUG/MINOR: peers: Possible unexpected peer seesion reset after collisions.
7161 - MINOR: ssl: add volatile flags to ssl samples
7162 - MEDIUM: backend: reuse connection if using a static sni
7163 - BUG/MEDIUM: spoe: Unset variable instead of set it if no data provided
7164 - BUG/MEDIUM: mux-h1: Get the session from the H1S when capturing bad messages
7165 - BUG/MEDIUM: lb: Always lock the server when calling server_{take,drop}_conn
7166 - DOC: fix typo in MAX_SESS_STKCTR
7167
Willy Tarreaub7ffe192020-10-10 10:45:13 +020071682020/10/10 : 2.3-dev6
7169 - REGTESTS: use "command" instead of "which" for better POSIX compatibility
7170 - BUILD: makefile: Update feature flags for OpenBSD
7171 - DOC: agent-check: fix typo in "fail" word expected reply
7172 - DOC: crt: advise to move away from cert bundle
7173 - BUG/MINOR: ssl/crt-list: exit on warning out of crtlist_parse_line()
7174 - REGTEST: fix host part in balance-uri-path-only.vtc
7175 - REGTEST: make ssl_client_samples and ssl_server_samples requiret to 2.3
7176 - REGTEST: the iif converter test requires 2.3
7177 - REGTEST: make agent-check.vtc require 1.8
7178 - REGTEST: make abns_socket.vtc require 1.8
7179 - REGTEST: make map_regm_with_backref require 1.7
7180 - BUILD: makefile: Update feature flags for FreeBSD
7181 - OPTIM: backend/random: never queue on the server, always on the backend
7182 - OPTIM: backend: skip LB when we know the backend is full
7183 - BUILD: makefile: Fix building with closefrom() support enabled
7184 - BUILD: makefile: add an EXTRAVERSION variable to ease local naming
7185 - MINOR: tools: support for word expansion of environment in parse_line
7186 - BUILD: tools: fix minor build issue on isspace()
7187 - BUILD: makefile: Enable closefrom() support on Solaris
7188 - CLEANUP: ssl: Use structured format for error line report during crt-list parsing
7189 - MINOR: ssl: Add error if a crt-list might be truncated
7190 - MINOR: ssl: remove uneeded check in crtlist_parse_file
7191 - BUG/MINOR: Fix several leaks of 'log_tag' in init().
7192 - DOC: tcp-rules: Refresh details about L7 matching for tcp-request content rules
7193 - MEDIUM: tcp-rules: Warn if a track-sc* content rule doesn't depend on content
7194 - BUG/MINOR: tcpcheck: Set socks4 and send-proxy flags before the connect call
7195 - DOC: ssl: new "cert bundle" behavior
7196 - BUG/MEDIUM: queue: make pendconn_cond_unlink() really thread-safe
7197 - CLEANUP: ssl: "bundle" is not an OpenSSL wording
7198 - MINOR: counters: fix a typo in comment
7199 - BUG/MINOR: stats: fix validity of the json schema
7200 - REORG: stats: export some functions
7201 - MINOR: stats: add stats size as a parameter for csv/json dump
7202 - MINOR: stats: hide px/sv/li fields in applet struct
7203 - REORG: stats: extract proxy json dump
7204 - REORG: stats: extract proxies dump loop in a function
7205 - MINOR: hlua: Display debug messages on stderr only in debug mode
7206 - MINOR: stats: define the concept of domain for statistics
7207 - MINOR: stats: define additional flag px cap on domain
7208 - MEDIUM: stats: add delimiter for static proxy stats on csv
7209 - MEDIUM: stats: define an API to register stat modules
7210 - MEDIUM: stats: add abstract type to store counters
7211 - MEDIUM: stats: integrate static proxies stats in new stats
7212 - MINOR: stats: support clear counters for dynamic stats
7213 - MINOR: stats: display extra proxy stats on the html page
7214 - MINOR: stats: add config "stats show modules"
7215 - MINOR: dns/stats: integrate dns counters in stats
7216 - MINOR: stats: remove for loop declaration
7217 - DOC: ssl: fix typo about ocsp files
7218 - BUG/MINOR: peers: Inconsistency when dumping peer status codes.
7219 - DOC: update INSTALL with supported OpenBSD / FreeBSD versions
7220 - BUG/MINOR: proto_tcp: Report warning messages when listeners are bound
7221 - CLEANUP: cache: Fix leak of cconf->c.name during config check
7222 - CLEANUP: ssl: Release cached SSL sessions on deinit
7223 - BUG/MINOR: mux-h1: Be sure to only set CO_RFL_READ_ONCE for the first read
7224 - BUG/MINOR: mux-h1: Always set the session on frontend h1 stream
7225 - MINOR: mux-h1: Don't wakeup the H1C when output buffer become available
7226 - CLEANUP: sock-unix: Remove an unreachable goto clause
7227 - BUG/MINOR: proxy: inc req counter on new syslog messages.
7228 - BUG/MEDIUM: log: old processes with log foward section don't die on soft stop.
7229 - MINOR: stats: inc req counter on listeners.
7230 - MINOR: channel: new getword and getchar functions on channel.
7231 - MEDIUM: log: syslog TCP support on log forward section.
7232 - BUG/MINOR: proxy/log: frontend/backend and log forward names must differ
7233 - DOC: re-work log forward bind statement documentation.
7234 - DOC: fix a confusing typo on a regsub example
7235 - BUILD: Add a DragonFlyBSD target
7236 - BUG/MINOR: makefile: fix a tiny typo in the target list
7237 - BUILD: makefile: Update feature flags for NetBSD
7238 - CI: travis-ci: help Coverity to detect BUG_ON() as a real stop
7239 - DOC: Add missing stats fields in the management doc
7240 - BUG/MEDIUM: mux-fcgi: Don't handle pending read0 too early on streams
7241 - BUG/MEDIUM: mux-h2: Don't handle pending read0 too early on streams
7242 - DOC: Fix typos in configuration.txt
7243 - BUG/MINOR: http: Fix content-length of the default 500 error
7244 - BUG/MINOR: http-htx: Expect no body for 204/304 internal HTTP responses
7245 - REGTESTS: mark abns_socket as broken
7246 - MEDIUM: fd: always wake up one thread when enabling a foreing FD
7247 - MEDIUM: listeners: don't bounce listeners management between queues
7248 - MEDIUM: init: stop disabled proxies after initializing fdtab
7249 - MEDIUM: listeners: make unbind_listener() converge if needed
7250 - MEDIUM: deinit: close all receivers/listeners before scanning proxies
7251 - MEDIUM: listeners: remove the now unused ZOMBIE state
7252 - MINOR: listeners: do not uselessly try to close zombie listeners in soft_stop()
7253 - CLEANUP: proxy: remove the first_to_listen hack in zombify_proxy()
7254 - MINOR: listeners: introduce listener_set_state()
7255 - MINOR: proxy: maintain per-state counters of listeners
7256 - MEDIUM: proxy: remove the unused PR_STFULL state
7257 - MEDIUM: proxy: remove the PR_STERROR state
7258 - MEDIUM: proxy: remove state PR_STPAUSED
7259 - MINOR: startup: don't rely on PR_STNEW to check for listeners
7260 - CLEANUP: peers: don't use the PR_ST* states to mark enabled/disabled
7261 - MEDIUM: proxy: replace proxy->state with proxy->disabled
7262 - MEDIUM: proxy: remove start_proxies()
7263 - MEDIUM: proxy: merge zombify_proxy() with stop_proxy()
7264 - MINOR: listeners: check the current listener state in pause_listener()
7265 - MINOR: listeners: check the current listener earlier state in resume_listener()
7266 - MEDIUM: listener/proxy: make the listeners notify about proxy pause/resume
7267 - MINOR: protocol: introduce protocol_{pause,resume}_all()
7268 - MAJOR: signals: use protocol_pause_all() and protocol_resume_all()
7269 - CLEANUP: proxy: remove the now unused pause_proxies() and resume_proxies()
7270 - MEDIUM: proto_tcp: make the pause() more robust in multi-process
7271 - BUG/MEDIUM: listeners: correctly report pause() errors
7272 - MINOR: listeners: move fd_stop_recv() to the receiver's socket code
7273 - CLEANUP: protocol: remove the ->disable_all method
7274 - CLEANUP: listeners: remove unused disable_listener and disable_all_listeners
7275 - MINOR: listeners: export enable_listener()
7276 - MINOR: protocol: directly call enable_listener() from protocol_enable_all()
7277 - CLEANUP: protocol: remove the ->enable_all method
7278 - CLEANUP: listeners: remove the now unused enable_all_listeners()
7279 - MINOR: protocol: rename the ->listeners field to ->receivers
7280 - MINOR: protocol: replace ->pause(listener) with ->rx_suspend(receiver)
7281 - MINOR: protocol: implement an ->rx_resume() method
7282 - MINOR: listener: use the protocol's ->rx_resume() method when available
7283 - MINOR: sock: provide a set of generic enable/disable functions
7284 - MINOR: protocol: add a new pair of rx_enable/rx_disable methods
7285 - MINOR: protocol: add a new pair of enable/disable methods for listeners
7286 - MEDIUM: listeners: now use the listener's ->enable/disable
7287 - MINOR: listeners: split delete_listener() in two versions
7288 - MINOR: listeners: count unstoppable jobs on creation, not deletion
7289 - MINOR: listeners: add a new stop_listener() function
7290 - MEDIUM: proxy: make stop_proxy() now use stop_listener()
7291 - MEDIUM: proxy: add mode PR_MODE_PEERS to flag peers frontends
7292 - MEDIUM: proxy: centralize proxy status update and reporting
7293 - MINOR: protocol: add protocol_stop_now() to instant-stop listeners
7294 - MEDIUM: proxy: make soft_stop() stop most listeners using protocol_stop_now()
7295 - MEDIUM: udp: implement udp_suspend() and udp_resume()
7296 - MINOR: listener: add a few BUG_ON() statements to detect inconsistencies
7297 - MEDIUM: listeners: always close master vs worker listeners
7298 - BROKEN/MEDIUM: listeners: rework the unbind logic to make it idempotent
7299 - MEDIUM: listener: let do_unbind_listener() decide whether to close or not
7300 - CLEANUP: listeners: remove the do_close argument to unbind_listener()
7301 - MINOR: listeners: move the LI_O_MWORKER flag to the receiver
7302 - MEDIUM: receivers: add an rx_unbind() method in the protocols
7303 - MINOR: listeners: split do_unbind_listener() in two
7304 - MEDIUM: listeners: implement protocol level ->suspend/resume() calls
7305 - MEDIUM: config: mark "grace" as deprecated
7306 - MEDIUM: config: remove the deprecated and dangerous global "debug" directive
7307 - BUG/MINOR: proxy: respect the proper format string in sig_pause/sig_listen
7308 - MINOR: peers: heartbeat, collisions and handshake information for "show peers" command.
7309 - BUILD: makefile: Enable getaddrinfo() on OS/X
7310
Christopher Faulet05f01882020-09-25 18:40:47 +020073112020/09/25 : 2.3-dev5
7312 - DOC: Fix typo in iif() example
7313 - CLEANUP: Update .gitignore
7314 - BUILD: introduce possibility to define ABORT_NOW() conditionally
7315 - CI: travis-ci: help Coverity to recognize abort()
7316 - BUG/MINOR: Fix type passed of sizeof() for calloc()
7317 - CLEANUP: Do not use a fixed type for 'sizeof' in 'calloc'
7318 - CLEANUP: tree-wide: use VAR_ARRAY instead of [0] in various definitions
7319 - BUILD: connection: fix build on clang after the VAR_ARRAY cleanup
7320 - BUG/MINOR: ssl: verifyhost is case sensitive
7321 - BUILD: makefile: change default value of CC from gcc to cc
7322 - CI: travis-ci: split asan step out of running tests
7323 - BUG/MINOR: server: report correct error message for invalid port on "socks4"
7324 - BUG/MEDIUM: ssl: Don't call ssl_sock_io_cb() directly.
7325 - BUG/MINOR: ssl/crt-list: crt-list could end without a \n
7326 - BUG/MINOR: log-forward: fail on unknown keywords
7327 - MEDIUM: log-forward: use "dgram-bind" instead of "bind" for the listener
7328 - BUG/MEDIUM: log-forward: always quit on parsing errors
7329 - MEDIUM: ssl: remove bundle support in crt-list and directories
7330 - MEDIUM: ssl/cli: remove support for multi certificates bundle
7331 - MINOR: ssl: crtlist_dup_ssl_conf() duplicates a ssl_bind_conf
7332 - MINOR: ssl: crtlist_entry_dup() duplicates a crtlist_entry
7333 - MEDIUM: ssl: emulates the multi-cert bundles in the crtlist
7334 - MEDIUM: ssl: emulate multi-cert bundles loading in standard loading
7335 - CLEANUP: ssl: remove test on "multi" variable in ckch functions
7336 - CLEANUP: ssl/cli: remove test on 'multi' variable in CLI functions
7337 - CLEANUP: ssl: remove utility functions for bundle
7338 - DOC: explain bundle emulation in configuration.txt
7339 - BUILD: fix build with openssl < 1.0.2 since bundle removal
7340 - BUG/MINOR: log: gracefully handle the "udp@" address format for log servers
7341 - BUG/MINOR: dns: gracefully handle the "udp@" address format for nameservers
7342 - MINOR: listener: create a new struct "settings" in bind_conf
7343 - MINOR: listener: move bind_proc and bind_thread to struct settings
7344 - MINOR: listener: move the interface to the struct settings
7345 - MINOR: listener: move the network namespace to the struct settings
7346 - REORG: listener: create a new struct receiver
7347 - REORG: listener: move the listening address to a struct receiver
7348 - REORG: listener: move the receiving FD to struct receiver
7349 - REORG: listener: move the listener's proto to the receiver
7350 - MINOR: listener: make sock_find_compatible_fd() check the socket type
7351 - REORG: listener: move the receiver part to a new file
7352 - MINOR: receiver: link the receiver to its settings
7353 - MINOR: receiver: link the receiver to its owner
7354 - MINOR: listener: prefer to retrieve the socket's settings via the receiver
7355 - MINOR: receiver: add a receiver-specific flag to indicate the socket is bound
7356 - MINOR: listener: move the INHERITED flag down to the receiver
7357 - MINOR: receiver: move the FOREIGN and V6ONLY options from listener to settings
7358 - MINOR: sock: make sock_find_compatible_fd() only take a receiver
7359 - MINOR: protocol: rename the ->bind field to ->listen
7360 - MINOR: protocol: add a new ->bind() entry to bind the receiver
7361 - MEDIUM: sock_inet: implement sock_inet_bind_receiver()
7362 - MEDIUM: tcp: make use of sock_inet_bind_receiver()
7363 - MEDIUM: udp: make use of sock_inet_bind_receiver()
7364 - MEDIUM: sock_unix: implement sock_unix_bind_receiver()
7365 - MEDIUM: uxst: make use of sock_unix_bind_receiver()
7366 - MEDIUM: sockpair: implement sockpair_bind_receiver()
7367 - MEDIUM: proto_sockpair: make use of sockpair_bind_receiver()
7368 - MEDIUM: protocol: explicitly start the receiver before the listener
7369 - MEDIUM: protocol: do not call proto->bind() anymore from bind_listener()
7370 - MINOR: protocol: add a new proto_fam structure for protocol families
7371 - MINOR: protocol: retrieve the family-specific fields from the family
7372 - CLEANUP: protocol: remove family-specific fields from struct protocol
7373 - MINOR: protocol: add a real family for existing FDs
7374 - CLEANUP: tools: make str2sa_range() less awful for fd@ and sockpair@
7375 - MINOR: tools: make str2sa_range() take more options than just resolve
7376 - MINOR: tools: add several PA_O_PORT_* flags in str2sa_range() callers
7377 - MEDIUM: tools: make str2sa_range() validate callers' port specifications
7378 - MEDIUM: config: remove all checks for missing/invalid ports/ranges
7379 - MINOR: tools: add several PA_O_* flags in str2sa_range() callers
7380 - MINOR: listener: remove the inherited arg to create_listener()
7381 - MINOR: tools: make str2sa_range() optionally return the fd
7382 - MINOR: log: detect LOG_TARGET_FD from the fd and not from the syntax
7383 - MEDIUM: tools: make str2sa_range() resolve pre-bound listeners
7384 - MINOR: config: do not test an inherited socket again
7385 - MEDIUM: tools: make str2sa_range() check for the sockpair's FD usability
7386 - MINOR: tools: start to distinguish stream and dgram in str2sa_range()
7387 - MEDIUM: tools: make str2sa_range() only report AF_CUST_UDP on listeners
7388 - MINOR: tools: remove the central test for "udp" in str2sa_range()
7389 - MINOR: cfgparse: add str2receiver() to parse dgram receivers
7390 - MINOR: log-forward: use str2receiver() to parse the dgram-bind address
7391 - MEDIUM: config: make str2listener() not accept datagram sockets anymore
7392 - MINOR: listener: pass the chosen protocol to create_listeners()
7393 - MINOR: tools: make str2sa_range() directly return the protocol
7394 - MEDIUM: tools: make str2sa_range() check that the protocol has ->connect()
7395 - MINOR: protocol: add the control layer type in the protocol struct
7396 - MEDIUM: protocol: store the socket and control type in the protocol array
7397 - MEDIUM: tools: make str2sa_range() use protocol_lookup()
7398 - MEDIUM: proto_udp: replace last AF_CUST_UDP* with AF_INET*
7399 - MINOR: tools: drop listener detection hack from str2sa_range()
7400 - BUILD: sock_unix: add missing errno.h
7401 - MINOR: sock_inet: report the errno string in binding errors
7402 - MINOR: sock_unix: report the errno string in binding errors
7403 - BUILD: sock_inet: include errno.h
7404 - MINOR: h2/trace: also display the remaining frame length in traces
7405 - BUG/MINOR: h2/trace: do not display "stream error" after a frame ACK
7406 - BUG/MEDIUM: h2: report frame bits only for handled types
7407 - BUG/MINOR: http-fetch: Don't set the sample type during the htx prefetch
7408 - BUG/MINOR: Fix memory leaks cfg_parse_peers
7409 - BUG/MINOR: config: Fix memory leak on config parse listen
7410 - MINOR: backend: make the "whole" option of balance uri take only one bit
7411 - MINOR: backend: add a new "path-only" option to "balance uri"
7412 - REGTESTS: add a few load balancing tests
7413 - BUG/MEDIUM: listeners: do not pause foreign listeners
7414 - BUG/MINOR: listeners: properly close listener FDs
7415 - BUILD: trace: include tools.h
7416
Willy Tarreau253c4dc2020-09-11 17:05:59 +020074172020/09/11 : 2.3-dev4
7418 - MINOR: hlua: Add error message relative to the Channel manipulation and HTTP mode
7419 - BUG/MEDIUM: ssl: crt-list negative filters don't work
7420 - DOC: overhauling github issue templates
7421 - MEDIUM: cfgparse: Emit hard error on truncated lines
7422 - DOC: cache: Use '<name>' instead of '<id>' in error message
7423 - MINOR: cache: Reject duplicate cache names
7424 - REGTEST: remove stray leading spaces in converteers_ref_cnt_never_dec.vtc
7425 - MINOR: stats: prevent favicon.ico requests for stats page
7426 - BUILD: tools: include auxv a bit later
7427 - BUILD: task: work around a bogus warning in gcc 4.7/4.8 at -O1
7428 - MEDIUM: ssl: Support certificate chaining for certificate generation
7429 - MINOR: ssl: Support SAN extension for certificate generation
7430 - MINOR: tcp: don't try to set/clear v6only on inherited sockets
7431 - BUG/MINOR: reload: detect the OS's v6only status before choosing an old socket
7432 - MINOR: reload: determine the foreing binding status from the socket
7433 - MEDIUM: reload: stop passing listener options along with FDs
7434 - BUG/MEDIUM: ssl: fix ssl_bind_conf double free w/ wildcards
7435 - MEDIUM: fd: replace usages of fd_remove() with fd_stop_both()
7436 - CLEANUP: fd: remove fd_remove() and rename fd_dodelete() to fd_delete()
7437 - MINOR: fd: add a new "exported" flag and use it for all regular listeners
7438 - MEDIUM: reload: pass all exportable FDs, not just listeners
7439 - DOC: add description of pidfile in master-worker mode
7440 - BUG/MINOR: reload: do not fail when no socket is sent
7441 - REORG: tcp: move TCP actions from proto_tcp.c to tcp_act.c
7442 - CLEANUP: tcp: stop exporting smp_fetch_src()
7443 - REORG: tcp: move TCP sample fetches from proto_tcp.c to tcp_sample.c
7444 - REORG: tcp: move TCP bind/server keywords from proto_tcp.c to cfgparse-tcp.c
7445 - REORG: unix: move UNIX bind/server keywords from proto_uxst.c to cfgparse-unix.c
7446 - REORG: sock: start to move some generic socket code to sock.c
7447 - MINOR: sock: introduce sock_inet and sock_unix
7448 - MINOR: tcp/udp/unix: make use of proto->addrcmp() to compare addresses
7449 - MINOR: sock_inet: implement sock_inet_get_dst()
7450 - REORG: inet: replace tcp_is_foreign() with sock_inet_is_foreign()
7451 - REORG: sock_inet: move v6only_default from proto_tcp.c to sock_inet.c
7452 - REORG: sock_inet: move default_tcp_maxseg from proto_tcp.c
7453 - REORG: listener: move xfer_sock_list to sock.{c,h}.
7454 - MINOR: sock: add interface and namespace length to xfer_sock_list
7455 - MINOR: sock: implement sock_find_compatible_fd()
7456 - MINOR: sock_inet: move the IPv4/v6 transparent mode code to sock_inet
7457 - REORG: sock: move get_old_sockets() from haproxy.c
7458 - MINOR: sock: do not use LI_O_* in xfer_sock_list anymore
7459 - MINOR: sock: distinguish dgram from stream types when retrieving old sockets
7460 - BUILD: sock_unix: fix build issue with isdigit()
7461 - BUG/MEDIUM: http-ana: Don't wait to send 1xx responses received from servers
7462 - MINOR: http-htx: Add an option to eval query-string when the path is replaced
7463 - BUG/MINOR: http-rules: Replace path and query-string in "replace-path" action
7464 - MINOR: http-htx: Handle an optional reason when replacing the response status
7465 - MINOR: contrib/spoa-server: allow MAX_FRAME_SIZE override
7466 - BUG/MAJOR: contrib/spoa-server: Fix unhandled python call leading to memory leak
7467 - BUG/MINOR: contrib/spoa-server: Ensure ip address references are freed
7468 - BUG/MINOR: contrib/spoa-server: Do not free reference to NULL
7469 - BUG/MINOR: contrib/spoa-server: Updating references to free in case of failure
7470 - BUG/MEDIUM: contrib/spoa-server: Fix ipv4_address used instead of ipv6_address
7471 - CLEANUP: http: silence a cppcheck warning in get_http_auth()
7472 - REGTEST: increase some short timeouts to make tests more reliable
7473 - BUG/MINOR: threads: work around a libgcc_s issue with chrooting
7474 - BUILD: thread: limit the libgcc_s workaround to glibc only
7475 - MINOR: protocol: do not call proto->bind_all() anymore
7476 - MINOR: protocol: do not call proto->unbind_all() anymore
7477 - CLEANUP: protocol: remove all ->bind_all() and ->unbind_all() functions
7478 - MAJOR: init: start all listeners via protocols and not via proxies anymore
7479 - BUG/MINOR: startup: haproxy -s cause 100% cpu
7480 - Revert "BUG/MINOR: http-rules: Replace path and query-string in "replace-path" action"
7481 - BUG/MEDIUM: doc: Fix replace-path action description
7482 - MINOR: http-rules: Add set-pathq and replace-pathq actions
7483 - MINOR: http-fetch: Add pathq sample fetch
7484 - REGTEST: Add a test for request path manipulations, with and without the QS
7485 - MINOR: Commit .gitattributes
7486 - CLEANUP: Update .gitignore
7487 - BUG/MEDIUM: dns: Don't store additional records in a linked-list
7488 - BUG/MEDIUM: dns: Be sure to renew IP address for already known servers
7489 - MINOR: server: Improve log message sent when server address is updated
7490 - DOC: ssl-load-extra-files only applies to certificates on bind lines
7491 - BUG/MINOR: auth: report valid crypto(3) support depending on build options
7492 - BUG/MEDIUM: mux-h1: always apply the timeout on half-closed connections
7493 - BUILD: threads: better workaround for late loading of libgcc_s
7494 - BUILD: compiler: reserve the gcc version checks to the gcc compiler
7495 - BUILD: compiler: workaround a glibc madness around __attribute__()
7496 - BUILD: intops: on x86_64, the bswap instruction is called bswapq
7497 - BUILD: trace: always have an argument before variadic args in macros
7498 - BUILD: traces: don't pass an empty argument for missing ones
7499 - BUG/MINOR: haproxy: Free uri_auth->scope during deinit
7500 - CLEANUP: Free old_argv on deinit
7501 - CLEANUP: haproxy: Free post_proxy_check_list in deinit()
7502 - CLEANUP: haproxy: Free per_thread_*_list in deinit()
7503 - CLEANUP: haproxy: Free post_check_list in deinit()
7504 - BUG/MEDIUM: pattern: Renew the pattern expression revision when it is pruned
7505 - REORG: tools: move PARSE_OPT_* from tools.h to tools-t.h
7506 - MINOR: sample: Add iif(<true>,<false>) converter
7507
Willy Tarreauf104b532020-08-14 18:54:05 +020075082020/08/14 : 2.3-dev3
7509 - SCRIPTS: git-show-backports: make -m most only show the left branch
7510 - SCRIPTS: git-show-backports: emit the shell command to backport a commit
7511 - BUILD: Makefile: require SSL_LIB, SSL_INC to be explicitly set
7512 - CI: travis-ci: specify SLZ_LIB, SLZ_INC for travis builds
7513 - BUG/MEDIUM: mux-h1: Refresh H1 connection timeout after a synchronous send
7514 - CLEANUP: dns: typo in reported error message
7515 - BUG/MAJOR: dns: disabled servers through SRV records never recover
7516 - BUG/MINOR: spoa-server: fix size_t format printing
7517 - DOC: spoa-server: fix false friends `actually`
7518 - BUG/MINOR: ssl: fix memory leak at OCSP loading
7519 - BUG/MEDIUM: ssl: memory leak of ocsp data at SSL_CTX_free()
7520 - BUG/MEDIUM: map/lua: Return an error if a map is loaded during runtime
7521 - MINOR: arg: Add an argument type to keep a reference on opaque data
7522 - BUG/MINOR: converters: Store the sink in an arg pointer for debug() converter
7523 - BUG/MINOR: lua: Duplicate map name to load it when a new Map object is created
7524 - BUG/MINOR: arg: Fix leaks during arguments validation for fetches/converters
7525 - BUG/MINOR: lua: Check argument type to convert it to IPv4/IPv6 arg validation
7526 - BUG/MINOR: lua: Check argument type to convert it to IP mask in arg validation
7527 - MINOR: hlua: Don't needlessly copy lua strings in trash during args validation
7528 - BUG/MINOR: lua: Duplicate lua strings in sample fetches/converters arg array
7529 - MEDIUM: lua: Don't filter exported fetches and converters
7530 - MINOR: lua: Add support for userlist as fetches and converters arguments
7531 - MINOR: lua: Add support for regex as fetches and converters arguments
7532 - MINOR: arg: Use chunk_destroy() to release string arguments
7533 - BUG/MINOR: snapshots: leak of snapshots on deinit()
7534 - CLEANUP: ssl: ssl_sock_crt2der semicolon and spaces
7535 - MINOR: ssl: add ssl_{c,s}_chain_der fetch methods
7536 - CLEANUP: fix all duplicated semicolons
7537 - BUG/MEDIUM: ssl: fix the ssl-skip-self-issued-ca option
7538 - BUG/MINOR: ssl: ssl-skip-self-issued-ca requires >= 1.0.2
7539 - BUG/MINOR: stats: use strncmp() instead of memcmp() on health states
7540 - BUILD: makefile: don't disable -Wstringop-overflow anymore
7541 - BUG/MINOR: ssl: double free w/ smp_fetch_ssl_x_chain_der()
7542 - BUG/MEDIUM: htx: smp_prefetch_htx() must always validate the direction
7543 - BUG/MEDIUM: ssl: never generates the chain from the verify store
7544 - OPTIM: regex: PCRE2 use JIT match when JIT optimisation occured.
7545 - BUG/MEDIUM: ssl: does not look for all SNIs before chosing a certificate
7546 - CLEANUP: ssl: remove poorly readable nested ternary
7547
Willy Tarreau3f3cc8c2020-07-31 14:48:32 +020075482020/07/31 : 2.3-dev2
7549 - DOC: ssl: req_ssl_sni needs implicit TLS
7550 - BUG/MEDIUM: arg: empty args list must be dropped
7551 - BUG/MEDIUM: resolve: fix init resolving for ring and peers section.
7552 - BUG/MAJOR: tasks: don't requeue global tasks into the local queue
7553 - MINOR: tasks/debug: make the thread affinity BUG_ON check a bit stricter
7554 - MINOR: tasks/debug: add a few BUG_ON() to detect use of wrong timer queue
7555 - MINOR: tasks/debug: add a BUG_ON() check to detect requeued task on free
7556 - BUG/MAJOR: dns: Make the do-resolve action thread-safe
7557 - BUG/MEDIUM: dns: Release answer items when a DNS resolution is freed
7558 - MEDIUM: htx: Add a flag on a HTX message when no more data are expected
7559 - BUG/MEDIUM: stream-int: Don't set MSG_MORE flag if no more data are expected
7560 - BUG/MEDIUM: http-ana: Only set CF_EXPECT_MORE flag on data filtering
7561 - CLEANUP: dns: remove 45 "return" statements from dns_validate_dns_response()
7562 - BUG/MINOR: htx: add two missing HTX_FL_EOI and remove an unexpected one
7563 - BUG/MINOR: mux-fcgi: Don't url-decode the QUERY_STRING parameter anymore
7564 - BUILD: tools: fix build with static only toolchains
7565 - DOC: Use gender neutral language
7566 - BUG/MINOR: debug: Don't dump the lua stack if it is not initialized
7567 - BUG/MAJOR: dns: fix null pointer dereference in snr_update_srv_status
7568 - BUG/MAJOR: dns: don't treat Authority records as an error
7569 - CI : travis-ci : prepare for using stock OpenSSL
7570 - CI: travis-ci : switch to stock openssl when openssl-1.1.1 is used
7571 - MEDIUM: lua: Add support for the Lua 5.4
7572 - BUG/MEDIUM: dns: Don't yield in do-resolve action on a final evaluation
7573 - BUG/MINOR: lua: Abort execution of actions that yield on a final evaluation
7574 - MINOR: tcp-rules: Return an internal error if an action yields on a final eval
7575 - BUG/MINOR: tcp-rules: Preserve the right filter analyser on content eval abort
7576 - BUG/MINOR: tcp-rules: Set the inspect-delay when a tcp-response action yields
7577 - MEDIUM: tcp-rules: Use a dedicated expiration date for tcp ruleset
7578 - MEDIUM: lua: Set the analyse expiration date with smaller wake_time only
7579 - BUG/MEDIUM: connection: Be sure to always install a mux for sync connect
7580 - MINOR: connection: Preinstall the mux for non-ssl connect
7581 - MINOR: stream-int: Be sure to have a mux to do sends and receives
7582 - BUG/MINOR: lua: Fix a possible null pointer deref on lua ctx
7583 - SCRIPTS: announce-release: add the link to the wiki in the announce messages
7584 - CI: travis-ci: use better name for Coverity scan job
7585 - CI: travis-ci: use proper linking flags for SLZ build
7586 - BUG/MEDIUM: backend: always attach the transport before installing the mux
7587 - BUG/MEDIUM: tcp-checks: always attach the transport before installing the mux
7588 - MINOR: connection: avoid a useless recvfrom() on outgoing connections
7589 - MINOR: mux-h1: do not even try to receive if the connection is not fully set up
7590 - MINOR: mux-h1: do not try to receive on backend before sending a request
7591 - CLEANUP: assorted typo fixes in the code and comments
7592 - BUG/MEDIUM: ssl: check OCSP calloc in ssl_sock_load_ocsp()
7593
Willy Tarreaue732cbd2020-07-17 15:13:19 +020075942020/07/17 : 2.3-dev1
7595 - MINOR: config: make strict limits enabled by default
7596 - BUG/MINOR: acl: Fix freeing of expr->smp in prune_acl_expr
7597 - BUG/MINOR: sample: Fix freeing of conv_exprs in release_sample_expr
7598 - BUG/MINOR: haproxy: Free proxy->format_unique_id during deinit
7599 - BUG/MINOR: haproxy: Add missing free of server->(hostname|resolvers_id)
7600 - BUG/MINOR: haproxy: Free proxy->unique_id_header during deinit
7601 - BUG/MINOR: haproxy: Free srule->file during deinit
7602 - BUG/MINOR: haproxy: Free srule->expr during deinit
7603 - BUG/MINOR: sample: Free str.area in smp_check_const_bool
7604 - BUG/MINOR: sample: Free str.area in smp_check_const_meth
7605 - CLEANUP: haproxy: Free proxy_deinit_list in deinit()
7606 - CLEANUP: haproxy: Free post_deinit_list in deinit()
7607 - CLEANUP: haproxy: Free server_deinit_list in deinit()
7608 - CLEANUP: haproxy: Free post_server_check_list in deinit()
7609 - CLEANUP: Add static void vars_deinit()
7610 - CLEANUP: Add static void hlua_deinit()
7611 - CLEANUP: contrib/prometheus-exporter: typo fixes for ssl reuse metric
7612 - BUG/MEDIUM: lists: add missing store barrier on MT_LIST_BEHEAD()
7613 - BUG/MEDIUM: lists: add missing store barrier in MT_LIST_ADD/MT_LIST_ADDQ
7614 - MINOR: tcp: Support TCP keepalive parameters customization
7615 - BUILD: tcp: condition TCP keepalive settings to platforms providing them
7616 - MINOR: lists: rename some MT_LIST operations to clarify them
7617 - MINOR: buffer: use MT_LIST_ADDQ() for buffer_wait lists additions
7618 - MINOR: connection: use MT_LIST_ADDQ() to add connections to idle lists
7619 - MINOR: tasks: use MT_LIST_ADDQ() when killing tasks.
7620 - CONTRIB: da: fix memory leak in dummy function da_atlas_open()
7621 - CI: travis-ci: speed up osx build by running brew scripted, switch to latest osx image
7622 - BUG/MEDIUM: mux-h2: Don't add private connections in available connection list
7623 - BUG/MEDIUM: mux-fcgi: Don't add private connections in available connection list
7624 - MINOR: connection: Set the SNI on server connections before installing the mux
7625 - MINOR: connection: Set new connection as private on reuse never
7626 - MINOR: connection: Add a wrapper to mark a connection as private
7627 - MEDIUM: connection: Add private connections synchronously in session server list
7628 - MINOR: connection: Use a dedicated function to look for a session's connection
7629 - MINOR: connection: Set the conncetion target during its initialisation
7630 - MINOR: session: Take care to decrement idle_conns counter in session_unown_conn
7631 - MINOR: server: Factorize code to deal with reuse of server idle connections
7632 - MINOR: server: Factorize code to deal with connections removed from an idle list
7633 - CLEANUP: connection: remove unused field idle_time from the connection struct
7634 - BUG/MEDIUM: mux-h1: Continue to process request when switching in tunnel mode
7635 - MINOR: raw_sock: Report the number of bytes emitted using the splicing
7636 - MINOR: contrib/prometheus-exporter: Add missing global and per-server metrics
7637 - MINOR: backend: Add sample fetches to get the server's weight
7638 - BUG/MINOR: mux-fcgi: Handle empty STDERR record
7639 - BUG/MINOR: mux-fcgi: Set conn state to RECORD_P when skipping the record padding
7640 - BUG/MINOR: mux-fcgi: Set flags on the right stream field for empty FCGI_STDOUT
7641 - BUG/MINOR: backend: fix potential null deref on srv_conn
7642 - BUG/MEDIUM: log: issue mixing sampled to not sampled log servers.
7643 - MEDIUM: udp: adds minimal proto udp support for message listeners.
7644 - MEDIUM: log/sink: re-work and merge of build message API.
7645 - MINOR: log: adds syslog udp message handler and parsing.
7646 - MEDIUM: log: adds log forwarding section.
7647 - MINOR: log: adds counters on received syslog messages.
7648 - BUG/MEDIUM: fcgi-app: fix memory leak in fcgi_flt_http_headers
7649 - BUG/MEDIUM: server: resolve state file handle leak on reload
7650 - BUG/MEDIUM: server: fix possibly uninitialized state file on close
7651 - BUG/MEDIUM: channel: Be aware of SHUTW_NOW flag when output data are peeked
7652 - BUILD: config: address build warning on raspbian+rpi4
7653 - BUG/MAJOR: tasks: make sure to always lock the shared wait queue if needed
7654 - BUILD: config: fix again bugs gcc warnings on calloc
7655
Willy Tarreau33205c22020-07-07 16:35:28 +020076562020/07/07 : 2.3-dev0
Willy Tarreau848dbdf2020-07-07 16:39:18 +02007657 - [RELEASE] Released version 2.3-dev0
7658 - MINOR: version: back to development, update status message
7659
76602020/07/07 : 2.3-dev0
Willy Tarreau33205c22020-07-07 16:35:28 +02007661 - exact copy of 2.2.0
7662
Willy Tarreau3a00c912020-07-07 16:33:14 +020076632020/07/07 : 2.2.0
7664 - BUILD: mux-h2: fix typo breaking build when using DEBUG_LOCK
7665 - CLEANUP: makefile: update the outdated list of DEBUG_xxx options
7666 - BUILD: tools: make resolve_sym_name() return a const
7667 - CLEANUP: auth: fix useless self-include of auth-t.h
7668 - BUILD: tree-wide: cast arguments to tolower/toupper to unsigned char
7669 - CLEANUP: assorted typo fixes in the code and comments
7670 - WIP/MINOR: ssl: add sample fetches for keylog in frontend
7671 - DOC: fix tune.ssl.keylog sample fetches array
7672 - BUG/MINOR: ssl: check conn in keylog sample fetch
7673 - DOC: configuration: various typo fixes
7674 - MINOR: log: Remove unused case statement during the log-format string parsing
7675 - BUG/MINOR: mux-h1: Fix the splicing in TUNNEL mode
7676 - BUG/MINOR: mux-h1: Don't read data from a pipe if the mux is unable to receive
7677 - BUG/MINOR: mux-h1: Disable splicing only if input data was processed
7678 - BUG/MEDIUM: mux-h1: Disable splicing for the conn-stream if read0 is received
7679 - MINOR: mux-h1: Improve traces about the splicing
7680 - BUG/MINOR: backend: Remove CO_FL_SESS_IDLE if a client remains on the last server
7681 - BUG/MEDIUM: connection: Don't consider new private connections as available
7682 - BUG/MINOR: connection: See new connection as available only on reuse always
7683 - DOC: configuration: remove obsolete mentions of H2 being converted to HTTP/1.x
7684 - CLEANUP: ssl: remove unrelevant comment in smp_fetch_ssl_x_keylog()
7685 - DOC: update INSTALL with new compiler versions
7686 - DOC: minor update to coding style file
7687 - MINOR: version: mention that it's an LTS release now
7688
Willy Tarreau62f11a52020-07-04 07:10:24 +020076892020/07/04 : 2.2-dev12
7690 - BUG/MINOR: mux_h2: don't lose the leaving trace in h2_io_cb()
7691 - MINOR: cli: make "show sess" stop at the last known session
7692 - CLEANUP: buffers: remove unused buffer_wq_lock lock
7693 - BUG/MEDIUM: buffers: always allocate from the local cache first
7694 - MINOR: connection: align toremove_{lock,connections} and cleanup into idle_conns
7695 - CONTRIB: debug: add missing flags SI_FL_L7_RETRY & SI_FL_D_L7_RETRY
7696 - BUG/MEDIUM: connections: Don't increase curr_used_conns for shared connections.
7697 - BUG/MEDIUM: checks: Increment the server's curr_used_conns
7698 - REORG: buffer: rename buffer.c to dynbuf.c
7699 - REORG: includes: create tinfo.h for the thread_info struct
7700 - CLEANUP: pool: only include the type files from types
7701 - MINOR: pools: move the LRU cache heads to thread_info
7702 - BUG/MINOR: debug: fix "show fd" null-deref when built with DEBUG_FD
7703 - MINOR: stats: add 3 new output values for the per-server idle conn state
7704 - MINOR: activity: add per-thread statistics on FD takeover
7705 - BUG/MINOR: server: start cleaning idle connections from various points
7706 - MEDIUM: server: improve estimate of the need for idle connections
7707 - MINOR: stats: add the estimated need of concurrent connections per server
7708 - BUG/MINOR: threads: Don't forget to init each thread toremove_lock.
7709 - BUG/MEDIUM: lists: Lock the element while we check if it is in a list.
7710 - Revert "BUG/MEDIUM: lists: Lock the element while we check if it is in a list."
7711 - BUG/MINOR: haproxy: don't wake already stopping threads on exit
7712 - BUG/MINOR: server: always count one idle slot for current thread
7713 - MEDIUM: server: use the two thresholds for the connection release algorithm
7714 - BUG/MINOR: http-rules: Fix ACLs parsing for http deny rules
7715 - BUG/MINOR: sched: properly cover for a rare MT_LIST_ADDQ() race
7716 - MINOR: mux-h1: avoid taking the toremove_lock in on dying tasks
7717 - MINOR: mux-h2: avoid taking the toremove_lock in on dying tasks
7718 - MINOR: mux-fcgi: avoid taking the toremove_lock in on dying tasks
7719 - MINOR: pools: increase MAX_BASE_POOLS to 64
7720 - DOC: ssl: add "allow-0rtt" and "ciphersuites" in crt-list
7721 - BUG/MEDIUM: pattern: Add a trailing \0 to match strings only if possible
7722 - BUG/MEDIUM: log-format: fix possible endless loop in parse_logformat_string()
7723 - BUG/MINOR: proxy: fix dump_server_state()'s misuse of the trash
7724 - BUG/MINOR: proxy: always initialize the trash in show servers state
7725 - MINOR: cli/proxy: add a new "show servers conn" command
7726 - MINOR: server: skip servers with no idle conns earlier
7727 - BUG/MINOR: server: fix the connection release logic regarding nearly full conditions
7728 - MEDIUM: server: add a new pool-low-conn server setting
7729 - BUG/MEDIUM: backend: always search in the safe list after failing on the idle one
7730 - MINOR: backend: don't always takeover from the same threads
7731 - MINOR: sched: make sched->task_list_size atomic
7732 - MEDIUM: sched: create a new TASK_KILLED task flag
7733 - MEDIUM: sched: implement task_kill() to kill a task
7734 - MEDIUM: mux-h1: use task_kill() during h1_takeover() instead of task_wakeup()
7735 - MEDIUM: mux-h2: use task_kill() during h2_takeover() instead of task_wakeup()
7736 - MEDIUM: mux-fcgi: use task_kill() during fcgi_takeover() instead of task_wakeup()
7737 - MINOR: list: Add MT_LIST_DEL_SAFE_NOINIT() and MT_LIST_ADDQ_NOCHECK()
7738 - CLEANUP: connections: rename the toremove_lock to takeover_lock
7739 - MEDIUM: connections: Don't use a lock when moving connections to remove.
7740 - DOC: configuration: add missing index entries for tune.pool-{low,high}-fd-ratio
7741 - DOC: configuration: fix alphabetical ordering for tune.pool-{high,low}-fd-ratio
7742 - MINOR: config: add a new tune.idle-pool.shared global setting.
7743 - MINOR: 51d: silence a warning about null pointer dereference
7744 - MINOR: debug: add a new "debug dev memstats" command
7745 - MINOR: log-format: allow to preserve spacing in log format strings
7746 - BUILD: debug: avoid build warnings with DEBUG_MEM_STATS
7747 - BUG/MAJOR: sched: make sure task_kill() always queues the task
7748 - BUG/MEDIUM: muxes: Make sure nobody stole the connection before using it.
7749 - BUG/MEDIUM: cli/proxy: don't try to dump idle connection state if there's none
7750 - BUILD: haproxy: fix build error when RLIMIT_AS is not set
7751 - BUG/MAJOR: sched: make it work also when not building with DEBUG_STRICT
7752 - MINOR: log: add time second fraction field to rfc5424 log timestamp.
7753 - BUG/MINOR: log: missing timezone on iso dates.
7754 - BUG/MEDIUM: server: don't kill all idle conns when there are not enough
7755 - MINOR: sched: split tasklet_wakeup() into tasklet_wakeup_on()
7756 - BUG/MEDIUM: connections: Set the tid for the old tasklet on takeover.
7757 - BUG/MEDIUM: connections: Let the xprt layer know a takeover happened.
7758 - BUG/MINOR: http_act: don't check capture id in backend (2)
7759 - BUILD: makefile: disable threads by default on OpenBSD
7760 - BUILD: peers: fix build warning with gcc 4.2.1
7761 - CI: cirrus-ci: exclude slow reg-tests
7762
Willy Tarreau4462af82020-06-26 22:01:04 +020077632020/06/26 : 2.2-dev11
7764 - REGTEST: Add a simple script to tests errorfile directives in proxy sections
7765 - BUG/MEDIUM: fcgi-app: Resolve the sink if a fcgi-app logs in a ring buffer
7766 - BUG/MINOR: spoe: correction of setting bits for analyzer
7767 - BUG/MINOR: cfgparse: Support configurations without newline at EOF
7768 - MINOR: cfgparse: Warn on truncated lines / files
7769 - BUG/MINOR: http_ana: clarify connection pointer check on L7 retry
7770 - MINOR: debug: add a new DEBUG_FD build option
7771 - BUG/MINOR: tasks: make sure never to exceed max_processed
7772 - MINOR: task: add a new pointer to current tasklet queue
7773 - BUG/MEDIUM: task: be careful not to run too many tasks at TL_URGENT
7774 - BUG/MINOR: cfgparse: Fix argument reference in PARSE_ERR_TOOMANY message
7775 - BUG/MINOR: cfgparse: Fix calculation of position for PARSE_ERR_TOOMANY message
7776 - BUG/MEDIUM: ssl: fix ssl_bind_conf double free
7777 - MINOR: ssl: free bind_conf_node in crtlist_free()
7778 - MINOR: ssl: free the crtlist and the ckch during the deinit()
7779 - BUG/MINOR: ssl: fix build with ckch_deinit() and crtlist_deinit()
7780 - BUG/MINOR: ssl/cli: certs added from the CLI can't be deleted
7781 - MINOR: ssl: move the ckch/crtlist deinit to ssl_sock.c
7782 - MEDIUM: tasks: apply a fair CPU distribution between tasklet classes
7783 - MINOR: tasks: make current_queue an index instead of a pointer
7784 - MINOR: tasks: add a mask of the queues with active tasklets
7785 - MINOR: tasks: pass the queue index to run_task_from_list()
7786 - MINOR: tasks: make run_tasks_from_lists() scan the queues itself
7787 - MEDIUM: tasks: add a tune.sched.low-latency option
7788 - BUG/MEDIUM: ssl/cli: 'commit ssl cert' crashes when no private key
7789 - BUG/MINOR: cfgparse: don't increment linenum on incomplete lines
7790 - MINOR: tools: make parse_line() always terminate the args list
7791 - BUG/MINOR: cfgparse: report extraneous args *after* the string is allocated
7792 - MINOR: cfgparse: sanitize the output a little bit
7793 - MINOR: cli/ssl: handle trailing slashes in crt-list commands
7794 - MINOR: ssl: add the ssl_s_* sample fetches for server side certificate
7795 - BUG/MEDIUM: http-ana: Don't loop trying to generate a malformed 500 response
7796 - BUG/MINOR: stream-int: Don't wait to send truncated HTTP messages
7797 - BUG/MINOR: http-ana: Set CF_EOI on response channel for generated responses
7798 - BUG/MINOR: http-ana: Don't wait to send 1xx responses generated by HAProxy
7799 - MINOR: spoe: Don't systematically create new applets if processing rate is low
7800 - DOC: fix some typos in the ssl_s_{s|i}_dn documentation
7801 - BUILD: fix ssl_sample.c when building against BoringSSL
7802 - CI: travis-ci: switch BoringSSL builds to ninja
7803 - CI: extend spellchecker whitelist
7804 - DOC: assorted typo fixes in the documentation
7805 - CLEANUP: assorted typo fixes in the code and comments
7806 - MINOR: http: Add support for http 413 status
7807 - REGTEST: ssl: tests the ssl_f_* sample fetches
7808 - REGTEST: ssl: add some ssl_c_* sample fetches test
7809 - DOC: ssl: update the documentation of "commit ssl cert"
7810 - BUG/MINOR: cfgparse: correctly deal with empty lines
7811 - BUG/MEDIUM: fetch: Fix hdr_ip misparsing IPv4 addresses due to missing NUL
7812
Willy Tarreaudc0936c2020-06-19 21:43:26 +020078132020/06/19 : 2.2-dev10
7814 - BUILD: include: add sys/types before netinet/tcp.h
7815 - BUG/MEDIUM: log: don't hold the log lock during writev() on a file descriptor
7816 - BUILD: Remove nowarn for warnings that do not trigger
7817 - BUG/MEDIUM: pattern: fix thread safety of pattern matching
7818 - BUILD: Re-enable -Wimplicit-fallthrough
7819 - BUG/MINOR: ssl: fix ssl-{min,max}-ver with openssl < 1.1.0
7820 - BUILD: thread: add parenthesis around values of locking macros
7821 - BUILD: proto_uxst: shut up yet another gcc's absurd warning
7822 - BUG/MEDIUM: checks: Fix off-by-one in allocation of SMTP greeting cmd
7823 - CI: travis-ci: use "-O1" for clang builds
7824 - MINOR: haproxy: Add void deinit_and_exit(int)
7825 - MINOR: haproxy: Make use of deinit_and_exit() for clean exits
7826 - BUG/MINOR: haproxy: Free rule->arg.vars.expr during deinit_act_rules
7827 - BUILD: compression: make gcc 10 happy with free_zlib()
7828 - BUILD: atomic: add string.h for memcpy() on ARM64
7829 - BUG/MINOR: http: make smp_fetch_body() report that the contents may change
7830 - BUG/MINOR: tcp-rules: tcp-response must check the buffer's fullness
7831 - BUILD: haproxy: mark deinit_and_exit() as noreturn
7832 - BUG/MAJOR: vars: Fix bogus free() during deinit() for http-request rules
7833 - BUG/MEDIUM: ebtree: use a byte-per-byte memcmp() to compare memory blocks
7834 - MINOR: tools: add a new configurable line parse, parse_line()
7835 - BUG/MEDIUM: cfgparse: use parse_line() to expand/unquote/unescape config lines
7836 - BUG/MEDIUM: cfgparse: stop after a reasonable amount of fatal error
7837 - MINOR: http: do not close connections anymore after internal responses
7838 - BUG/MINOR: cfgparse: Add missing fatal++ in PARSE_ERR_HEX case
7839 - BUG/MINOR: spoe: add missing key length check before checking key names
7840 - MINOR: version: put the compiler version output into version.c not haproxy.c
7841 - MINOR: compiler: always define __has_feature()
7842 - MINOR: version: report the presence of the compiler's address sanitizer
7843 - BUILD: Fix build by including haproxy/global.h
7844 - BUG/MAJOR: connection: always disable ready events once reported
7845 - CLEANUP: activity: remove unused counter fd_lock
7846 - DOC: fd: make it clear that some fields ordering must absolutely be respected
7847 - MINOR: activity: report the number of times poll() reports I/O
7848 - MINOR: activity: rename confusing poll_* fields in the output
7849 - MINOR: fd: Fix a typo in a coment.
7850 - BUG/MEDIUM: fd: Don't fd_stop_recv() a fd we don't own.
7851 - BUG/MEDIUM: fd: Call fd_stop_recv() when we just got a fd.
7852 - MINOR: activity: group the per-loop counters at the top
7853 - MINOR: activity: rename the "stream" field to "stream_calls"
7854 - MEDIUM: fd: refine the fd_takeover() migration lock
7855 - MINOR: fd: slightly optimize the fd_takeover double-CAS loop
7856 - MINOR: fd: factorize the fd_takeover() exit path to make it safer
7857 - MINOR: peers: do not use localpeer as an array anymore
7858 - MEDIUM: peers: add the "localpeer" global option
7859 - MEDIUM: fd: add experimental support for edge-triggered polling
7860 - CONTRIB: debug: add the missing flags CO_FL_SAFE_LIST and CO_FL_IDLE_LIST
7861 - MINOR: haproxy: process signals before runnable tasks
7862 - MEDIUM: tasks: clean up the front side of the wait queue in wake_expired_tasks()
7863 - MEDIUM: tasks: also process late wakeups in process_runnable_tasks()
7864 - BUG/MINOR: cli: allow space escaping on the CLI
7865 - BUG/MINOR: mworker/cli: fix the escaping in the master CLI
7866 - BUG/MINOR: mworker/cli: fix semicolon escaping in master CLI
7867 - REGTEST: http-rules: test spaces in ACLs
7868 - REGTEST: http-rules: test spaces in ACLs with master CLI
7869 - BUG/MAJOR: init: properly compute the default global.maxpipes value
7870 - MEDIUM: map: make the "clear map" operation yield
7871 - BUG/MEDIUM: stream-int: fix loss of CO_SFL_MSG_MORE flag in forwarding
7872 - MINOR: mux_h1: Set H1_F_CO_MSG_MORE if we know we have more to send.
7873 - BUG/MINOR: systemd: Wait for network to be online
7874 - DOC: configuration: Unindent non-code sentences in the protobuf example
7875 - DOC: configuration: http-check send was missing from matrix
7876
Willy Tarreau1385c882020-06-11 10:22:10 +020078772020/06/11 : 2.2-dev9
7878 - BUG/MINOR: http-htx: Don't forget to release the http reply in release function
7879 - BUG/MINOR: http-htx: Fix a leak on error path during http reply parsing
7880 - MINOR: checks: Remove dead code from process_chk_conn()
7881 - REGTESTS: checks: Fix tls_health_checks when IPv6 addresses are used
7882 - REGTESTS: Add missing OPENSSL to REQUIRE_OPTIONS for lua/txn_get_priv
7883 - MINOR: lua: Use vars_unset_by_name_ifexist()
7884 - CLEANUP: vars: Remove void vars_unset_by_name(const char*, size_t, struct sample*)
7885 - MINOR: vars: Make vars_(un|)set_by_name(_ifexist|) return a success value
7886 - MINOR: lua: Make `set_var()` and `unset_var()` return success
7887 - MEDIUM: lua: Add `ifexist` parameter to `set_var`
7888 - MEDIUM: ring: new section ring to declare custom ring buffers.
7889 - REGTESTS: Add missing OPENSSL to REQUIRE_OPTIONS for compression/lua_validation
7890 - REGTESTS: Require the version 2.2 to execute lua/set_var
7891 - BUG/MEDIUM: checks: Refresh the conn-stream and the connection after a connect
7892 - MINOR: checks: Remove useless tests on the connection and conn-stream
7893 - BUG/MEDIUM: contrib/spoa: do not register python3.8 if --embed fail
7894 - BUG/MEDIUM: connection: Ignore PP2 unique ID for stream-less connections
7895 - BUG/MINOR: connection: Always get the stream when available to send PP2 line
7896 - BUG/MEDIUM: backend: set the connection owner to the session when using alpn.
7897 - MINOR: pools: compute an estimate of each pool's average needed objects
7898 - MEDIUM: pools: directly free objects when pools are too much crowded
7899 - REGTEST: Add connection/proxy_protocol_send_unique_id_alpn
7900 - MINOR: http-ana: Make the function http_reply_to_htx() public
7901 - MINOR: http-ana: Use proxy's error replies to emit 401/407 responses
7902 - MINOR: http-rules: Use an action function to eval http-request auth rules
7903 - CLEANUP: http: Remove unused HTTP message templates
7904 - BUG/MEDIUM: checks: Don't blindly subscribe for receive if waiting for connect
7905 - MINOR: checks: I/O callback function only rely on the data layer wake callback
7906 - BUG/MINOR: lua: Add missing string length for lua sticktable lookup
7907 - BUG/MEDIUM: logs: fix trailing zeros on log message.
7908 - CI: cirrus-ci: skip reg-tests/connection/proxy_protocol_send_unique_id_alpn.vtc on CentOS 6
7909 - BUG/MINOR: nameservers: fix error handling in parsing of resolv.conf
7910 - BUG/MEDIUM: checks: Don't add a tcpcheck ruleset twice in the shared tree
7911 - MEDIUM: ssl: use TLSv1.2 as the minimum default on bind lines
7912 - CLEANUP: pools: use the regular lock for the flush operation on lockless pools
7913 - SCRIPTS: publish-release: pass -n to gzip to remove timestamp
7914 - MINOR: ring: re-work ring attach generic API.
7915 - BUG/MINOR: error on unknown statement in ring section.
7916 - MEDIUM: ring: add server statement to forward messages from a ring
7917 - MEDIUM: ring: add new srv statement to support octet counting forward
7918 - MINOR: ssl: set ssl-min-ver in ambiguous configurations
7919 - CLEANUP: ssl: remove comment from dump_crtlist_sslconf()
7920 - BUILD: sink: address build warning on 32-bit architectures
7921 - BUG/MINOR: peers: fix internal/network key type mapping.
7922 - CLEANUP: regex: remove outdated support for regex actions
7923 - Revert "MINOR: ssl: rework add cert chain to CTX to be libssl independent"
7924 - MINOR: mux-h1/proxy: Add a proxy option to disable clear h2 upgrade
7925 - BUG/MEDIUM: lua: Reset analyse expiration timeout before executing a lua action
7926 - DOC: add a line about comments in crt-list
7927 - BUG/MEDIUM: hlua: Lock pattern references to perform set/add/del operations
7928 - BUG/MINOR: checks: Fix test on http-check rulesets during config validity check
7929 - BUG/MEDIUM: contrib/prometheus-exporter: Properly set flags to dump metrics
7930 - BUG/MEDIUM: mworker: fix the copy of options in copy_argv()
7931 - BUG/MINOR: init: -x can have a parameter starting with a dash
7932 - BUG/MINOR: init: -S can have a parameter starting with a dash
7933 - BUG/MEDIUM: mworker: fix the reload with an -- option
7934 - BUG/MINOR: ssl: fix a trash buffer leak in some error cases
7935 - BUG/MINOR: mworker: fix a memleak when execvp() failed
7936 - MINOR: sample: Add secure_memcmp converter
7937 - REORG: ebtree: move the C files from ebtree/ to src/
7938 - REORG: ebtree: move the include files from ebtree to include/import/
7939 - REORG: ebtree: clean up remains of the ebtree/ directory
7940 - REORG: include: create new file haproxy/api-t.h
7941 - REORG: include: create new file haproxy/api.h
7942 - REORG: include: update all files to use haproxy/api.h or api-t.h if needed
7943 - CLEANUP: include: remove common/config.h
7944 - CLEANUP: include: remove unused template.h
7945 - REORG: include: move MIN/MAX from tools.h to compat.h
7946 - REORG: include: move SWAP/MID_RANGE/MAX_RANGE from tools.h to standard.h
7947 - CLEANUP: include: remove unused common/tools.h
7948 - REORG: include: move the base files from common/ to haproxy/
7949 - REORG: include: move version.h to haproxy/
7950 - REORG: include: move base64.h, errors.h and hash.h from common to to haproxy/
7951 - REORG: include: move openssl-compat.h from common/ to haproxy/
7952 - REORG: include: move ist.h from common/ to import/
7953 - REORG: include: move the BUG_ON() code to haproxy/bug.h
7954 - REORG: include: move debug.h from common/ to haproxy/
7955 - CLEANUP: debug: drop unused function p_malloc()
7956 - REORG: include: split buf.h into haproxy/buf-t.h and haproxy/buf.h
7957 - REORG: include: move istbuf.h to haproxy/
7958 - REORG: include: split mini-clist into haproxy/list and list-t.h
7959 - REORG: threads: extract atomic ops from hathreads.h
7960 - CLEANUP: threads: remove a few needless includes of hathreads.h
7961 - REORG: include: split hathreads into haproxy/thread.h and haproxy/thread-t.h
7962 - CLEANUP: thread: rename __decl_hathreads() to __decl_thread()
7963 - REORG: include: move time.h from common/ to haproxy/
7964 - REORG: include: move integer manipulation functions from standard.h to intops.h
7965 - CLEANUP: include: remove excessive includes of common/standard.h
7966 - REORG: include: move freq_ctr to haproxy/
7967 - CLEANUP: pool: include freq_ctr.h and remove locally duplicated functions
7968 - REORG: memory: move the pool type definitions to haproxy/pool-t.h
7969 - REORG: memory: move the OS-level allocator to haproxy/pool-os.h
7970 - MINOR: memory: don't let __pool_get_first() pick from the cache
7971 - MEDIUM: memory: don't let pool_put_to_cache() free the objects itself
7972 - MINOR: memory: move pool-specific path of the locked pool_free() to __pool_free()
7973 - MEDIUM: memory: make local pools independent on lockless pools
7974 - REORG: include: move common/memory.h to haproxy/pool.h
7975 - REORG: include: move common/chunk.h to haproxy/chunk.h
7976 - REORG: include: move activity to haproxy/
7977 - REORG: include: move common/buffer.h to haproxy/dynbuf{,-t}.h
7978 - REORG: include: move common/net_helper.h to haproxy/net_helper.h
7979 - REORG: include: move common/namespace.h to haproxy/namespace{,-t}.h
7980 - REORG: include: split common/regex.h into haproxy/regex{,-t}.h
7981 - REORG: include: split common/xref.h into haproxy/xref{,-t}.h
7982 - REORG: include: move common/ticks.h to haproxy/ticks.h
7983 - REORG: include: split common/http.h into haproxy/http{,-t}.h
7984 - REORG: include: split common/http-hdr.h into haproxy/http-hdr{,-t}.h
7985 - REORG: include: move common/h1.h to haproxy/h1.h
7986 - REORG: include: split common/htx.h into haproxy/htx{,-t}.h
7987 - REORG: include: move hpack*.h to haproxy/ and split hpack-tbl
7988 - REORG: include: move common/h2.h to haproxy/h2.h
7989 - REORG: include: move common/fcgi.h to haproxy/
7990 - REORG: include: move protocol.h to haproxy/protocol{,-t}.h
7991 - REORG: tools: split common/standard.h into haproxy/tools{,-t}.h
7992 - REORG: include: move dict.h to hparoxy/dict{,-t}.h
7993 - REORG: include: move shctx to haproxy/shctx{,-t}.h
7994 - REORG: include: move port_range.h to haproxy/port_range{,-t}.h
7995 - REORG: include: move fd.h to haproxy/fd{,-t}.h
7996 - REORG: include: move ring to haproxy/ring{,-t}.h
7997 - REORG: include: move sink.h to haproxy/sink{,-t}.h
7998 - REORG: include: move pipe.h to haproxy/pipe{,-t}.h
7999 - CLEANUP: include: remove empty raw_sock.h
8000 - REORG: include: move proto_udp.h to haproxy/proto_udp{,-t}.h
8001 - REORG: include: move proto/proto_sockpair.h to haproxy/proto_sockpair.h
8002 - REORG: include: move compression.h to haproxy/compression{,-t}.h
8003 - REORG: include: move h1_htx.h to haproxy/h1_htx.h
8004 - REORG: include: move http_htx.h to haproxy/http_htx{,-t}.h
8005 - REORG: include: move hlua.h to haproxy/hlua{,-t}.h
8006 - REORG: include: move hlua_fcn.h to haproxy/hlua_fcn.h
8007 - REORG: include: move action.h to haproxy/action{,-t}.h
8008 - REORG: include: move arg.h to haproxy/arg{,-t}.h
8009 - REORG: include: move auth.h to haproxy/auth{,-t}.h
8010 - REORG: include: move dns.h to haproxy/dns{,-t}.h
8011 - REORG: include: move flt_http_comp.h to haproxy/
8012 - REORG: include: move counters.h to haproxy/counters-t.h
8013 - REORG: include: split mailers.h into haproxy/mailers{,-t}.h
8014 - REORG: include: move capture.h to haproxy/capture{,-t}.h
8015 - REORG: include: move frontend.h to haproxy/frontend.h
8016 - REORG: include: move obj_type.h to haproxy/obj_type{,-t}.h
8017 - REORG: include: move http_rules.h to haproxy/http_rules.h
8018 - CLEANUP: include: remove unused mux_pt.h
8019 - REORG: include: move mworker.h to haproxy/mworker{,-t}.h
8020 - REORG: include: move ssl_utils.h to haproxy/ssl_utils.h
8021 - REORG: include: move ssl_ckch.h to haproxy/ssl_ckch{,-t}.h
8022 - REORG: move ssl_crtlist.h to haproxy/ssl_crtlist{,-t}.h
8023 - REORG: include: move lb_chash.h to haproxy/lb_chash{,-t}.h
8024 - REORG: include: move lb_fas.h to haproxy/lb_fas{,-t}.h
8025 - REORG: include: move lb_fwlc.h to haproxy/lb_fwlc{,-t}.h
8026 - REORG: include: move lb_fwrr.h to haproxy/lb_fwrr{,-t}.h
8027 - REORG: include: move listener.h to haproxy/listener{,-t}.h
8028 - REORG: include: move pattern.h to haproxy/pattern{,-t}.h
8029 - REORG: include: move map to haproxy/map{,-t}.h
8030 - REORG: include: move payload.h to haproxy/payload.h
8031 - REORG: include: move sample.h to haproxy/sample{,-t}.h
8032 - REORG: include: move protocol_buffers.h to haproxy/protobuf{,-t}.h
8033 - REORG: include: move vars.h to haproxy/vars{,-t}.h
8034 - REORG: include: split global.h into haproxy/global{,-t}.h
8035 - REORG: include: move task.h to haproxy/task{,-t}.h
8036 - REORG: include: move proto_tcp.h to haproxy/proto_tcp.h
8037 - REORG: include: move signal.h to haproxy/signal{,-t}.h
8038 - REORG: include: move tcp_rules.h to haproxy/tcp_rules.h
8039 - REORG: include: move connection.h to haproxy/connection{,-t}.h
8040 - REORG: include: move checks.h to haproxy/check{,-t}.h
8041 - REORG: include: move http_fetch.h to haproxy/http_fetch.h
8042 - REORG: include: move peers.h to haproxy/peers{,-t}.h
8043 - REORG: include: move stick_table.h to haproxy/stick_table{,-t}.h
8044 - REORG: include: move session.h to haproxy/session{,-t}.h
8045 - REORG: include: move trace.h to haproxy/trace{,-t}.h
8046 - REORG: include: move acl.h to haproxy/acl.h{,-t}.h
8047 - REORG: include: split common/uri_auth.h into haproxy/uri_auth{,-t}.h
8048 - REORG: move applet.h to haproxy/applet{,-t}.h
8049 - REORG: include: move stats.h to haproxy/stats{,-t}.h
8050 - REORG: include: move cli.h to haproxy/cli{,-t}.h
8051 - REORG: include: move lb_map.h to haproxy/lb_map{,-t}.h
8052 - REORG: include: move ssl_sock.h to haproxy/ssl_sock{,-t}.h
8053 - REORG: include: move stream_interface.h to haproxy/stream_interface{,-t}.h
8054 - REORG: include: move channel.h to haproxy/channel{,-t}.h
8055 - REORG: include: move http_ana.h to haproxy/http_ana{,-t}.h
8056 - REORG: include: move filters.h to haproxy/filters{,-t}.h
8057 - REORG: include: move fcgi-app.h to haproxy/fcgi-app{,-t}.h
8058 - REORG: include: move log.h to haproxy/log{,-t}.h
8059 - REORG: include: move proxy.h to haproxy/proxy{,-t}.h
8060 - REORG: include: move spoe.h to haproxy/spoe{,-t}.h
8061 - REORG: include: move backend.h to haproxy/backend{,-t}.h
8062 - REORG: include: move queue.h to haproxy/queue{,-t}.h
8063 - REORG: include: move server.h to haproxy/server{,-t}.h
8064 - REORG: include: move stream.h to haproxy/stream{,-t}.h
8065 - REORG: include: move cfgparse.h to haproxy/cfgparse.h
8066 - CLEANUP: hpack: export debug functions and move inlines to .h
8067 - REORG: check: move the e-mail alerting code to mailers.c
8068 - REORG: check: move tcpchecks away from check.c
8069 - REORG: check: move email_alert* from proxy-t.h to mailers-t.h
8070 - REORG: check: extract the external checks from check.{c,h}
8071 - CLEANUP: include: don't include stddef.h directly
8072 - CLEANUP: include: don't include proxy-t.h in global-t.h
8073 - CLEANUP: include: move sample_data out of sample-t.h
8074 - REORG: include: move the error reporting functions to from log.h to errors.h
8075 - BUILD: reorder objects in the Makefile for faster builds
8076 - CLEANUP: compiler: add a THREAD_ALIGNED macro and use it where appropriate
8077 - CLEANUP: include: make atomic.h part of the base API
8078 - REORG: include: move MAX_THREADS to defaults.h
8079 - REORG: include: move THREAD_LOCAL and __decl_thread() to compiler.h
8080 - CLEANUP: include: tree-wide alphabetical sort of include files
8081 - REORG: include: make list-t.h part of the base API
8082 - REORG: dgram: rename proto_udp to dgram
8083
Willy Tarreau73b943b2020-05-22 16:19:04 +020080842020/05/22 : 2.2-dev8
8085 - MINOR: checks: Improve report of unexpected errors for expect rules
8086 - MEDIUM: checks: Add matching on log-format string for expect rules
8087 - DOC: Fix req.body and co documentation to be accurate
8088 - MEDIUM: checks: Remove dedicated sample fetches and use response ones instead
8089 - CLEANUP: checks: sort and rename tcpcheck_expect_type types
8090 - MINOR: checks: Use dedicated actions to send log-format strings in send rules
8091 - MINOR: checks: Simplify matching on HTTP headers in HTTP expect rules
8092 - MINOR: checks/sample: Remove unnecessary tests on the sample session
8093 - REGTEST: checks: Adapt SSL error message reported when connection is rejected
8094 - MINOR: mworker: replace ha_alert by ha_warning when exiting successfuly
8095 - MINOR: checks: Support log-format string to set the URI for HTTP send rules
8096 - MINOR: checks: Support log-format string to set the body for HTTP send rules
8097 - DOC: Be more explicit about configurable check ok/error/timeout status
8098 - MINOR: checks: Make matching on HTTP headers for expect rules less obscure
8099 - BUG/MEDIUM: lua: Fix dumping of stick table entries for STD_T_DICT
8100 - BUG/MINOR: config: Make use_backend and use-server post-parsing less obscur
8101 - REGTESTS: make the http-check-send test require version 2.2
8102 - BUG/MINOR: http-ana: fix NTLM response parsing again
8103 - BUG/MEDIUM: http_ana: make the detection of NTLM variants safer
8104 - BUG/MINOR: cfgparse: Abort parsing the current line if an invalid \x sequence is encountered
8105 - MINOR: cfgparse: Improve error message for invalid \x sequences
8106 - CI: travis-ci: enable arm64 builds again
8107 - MEDIUM: ssl: increase default-dh-param to 2048
8108 - CI: travis-ci: skip pcre2 on arm64 build
8109 - CI: travis-ci: extend the build time for SSL to 60 minutes
8110 - CLEANUP: config: drop unused setting CONFIG_HAP_MEM_OPTIM
8111 - CLEANUP: config: drop unused setting CONFIG_HAP_INLINE_FD_SET
8112 - CLENAUP: config: move CONFIG_HAP_LOCKLESS_POOLS out of config.h
8113 - CLEANUP: remove THREAD_LOCAL from config.h
8114 - CI: travis-ci: upgrade LibreSSL versions
8115 - DOC: assorted typo fixes in the documentation
8116 - CI: extend spellchecker whitelist
8117 - CLEANUP: assorted typo fixes in the code and comments
8118 - MAJOR: contrib: porting spoa_server to support python3
8119 - BUG/MEDIUM: checks: Subscribe to I/O events on an unfinished connect
8120 - BUG/MINOR: checks: Don't subscribe to I/O events if it is already done
8121 - BUG/MINOR: checks: Rely on next I/O oriented rule when waiting for a connection
8122 - MINOR: checks: Don't try to send outgoing data if waiting to be able to send
8123 - MINOR: sample: Move aes_gcm_dec implementation into sample.c
8124 - MINOR: sample: Add digest and hmac converters
8125 - BUG/MEDIUM: checks: Subscribe to I/O events only if a mux was installed
8126 - BUG/MINOR: sample/ssl: Fix digest converter for openssl < 1.1.0
8127 - BUG/MINOR: pools: use %u not %d to report pool stats in "show pools"
8128 - BUG/MINOR: pollers: remove uneeded free in global init
8129 - CLEANUP: select: enhance readability in init
8130 - BUG/MINOR: soft-stop: always wake up waiting threads on stopping
8131 - MINOR: soft-stop: let the first stopper only signal other threads
8132 - BUILD: select: only declare existing local labels to appease clang
8133 - BUG/MEDIUM: streams: Remove SF_ADDR_SET if we're retrying due to L7 retry.
8134 - BUG/MEDIUM: stream: Only allow L7 retries when using HTTP.
8135 - DOC: retry-on can only be used with mode http
8136 - MEDIUM: ssl: allow to register callbacks for SSL/TLS protocol messages
8137 - MEDIUM: ssl: split ssl_sock_msgcbk() and use a new callback mechanism
8138 - MINOR: ssl: add a new function ssl_sock_get_ssl_object()
8139 - MEDIUM: ssl: use ssl_sock_get_ssl_object() in fetchers where appropriate
8140 - REORG: ssl: move macros and structure definitions to ssl_sock.h
8141 - CLEANUP: ssl: remove the shsess_* macros
8142 - REORG: move the crt-list structures in their own .h
8143 - REORG: ssl: move the ckch structures to types/ssl_ckch.h
8144 - CLEANUP: ssl: add ckch prototypes in proto/ssl_ckch.h
8145 - REORG: ssl: move crtlist functions to src/ssl_crtlist.c
8146 - CLEANUP: ssl: avoid circular dependencies in ssl_crtlist.h
8147 - REORG: ssl: move the ckch_store related functions to src/ssl_ckch.c
8148 - REORG: ssl: move ckch_inst functions to src/ssl_ckch.c
8149 - REORG: ssl: move the crt-list CLI functions in src/ssl_crtlist.c
8150 - REORG: ssl: move the CLI 'cert' functions to src/ssl_ckch.c
8151 - REORG: ssl: move ssl configuration to cfgparse-ssl.c
8152 - MINOR: ssl: remove static keyword in some SSL utility functions
8153 - REORG: ssl: move ssl_sock_ctx and fix cross-dependencies issues
8154 - REORG: ssl: move sample fetches to src/ssl_sample.c
8155 - REORG: ssl: move utility functions to src/ssl_utils.c
8156 - DOC: ssl: update MAINTAINERS file
8157 - CI: travis-ci: switch arm64 builds to use openssl from distro
8158 - MINOR: stats: Prepare for more accurate moving averages
8159 - MINOR: stats: Expose native cum_req metric for a server
8160 - MEDIUM: stats: Enable more accurate moving average calculation for stats
8161 - BUILD: ssl: include buffer common headers for ssl_sock_ctx
8162 - BUILD: ssl: include errno.h in ssl_crtlist.c
8163 - CLEANUP: acl: remove unused assignment
8164 - DOC/MINOR: halog: Add long help info for ic flag
8165 - BUILD: ssl: fix build without OPENSSL_NO_ENGINE
8166 - DOC: SPOE is no longer experimental
8167 - BUG/MINOR: cache: Don't needlessly test "cache" keyword in parse_cache_flt()
8168 - MINOR: config: Don't dump keywords if argument is NULL
8169 - MEDIUM: checks: Make post-41 the default mode for mysql checks
8170 - BUG/MINOR: logs: prevent double line returns in some events.
8171 - MEDIUM: sink: build header in sink_write for log formats
8172 - MEDIUM: logs: buffer targets now rely on new sink_write
8173 - MEDIUM: sink: add global statement to create a new ring (sink buffer)
8174 - MEDIUM: hpack: use a pool for the hpack table
8175 - BUG/MAJOR: mux-fcgi: Stop sending loop if FCGI stream is blocked for any reason
8176 - BUG/MEDIUM: ring: write-lock the ring while attaching/detaching
8177 - MINOR: applet: adopt the wait list entry from the CLI
8178 - MINOR: ring: make the applet code not depend on the CLI
8179 - Revert "MEDIUM: sink: add global statement to create a new ring (sink buffer)"
8180 - CI: travis-ci: fix libslz download URL
8181 - MINOR: ssl: split config and runtime variable for ssl-{min,max}-ver
8182 - CLEANUP: http_ana: Remove unused TXN flags
8183 - BUG/MINOR: http-rules: Mark http return rules as final
8184 - MINOR: http-htx: Add http_reply type based on what is used for http return rules
8185 - CLEANUP: http-htx: Rename http_error structure into http_error_msg
8186 - MINOR: http-rules: Use http_reply structure for http return rules
8187 - MINOR: http-htx: Use a dedicated function to release http_reply objects
8188 - MINOR: http-htx: Use a dedicated function to parse http reply arguments
8189 - MINOR: http-htx: Use a dedicated function to check http reply validity
8190 - MINOR: http-ana: Use a dedicated function to send a response from an http reply
8191 - MEDIUM: http-rules: Rely on http reply for http deny/tarpit rules
8192 - MINOR: http-htx: Store default error messages in a global http reply array
8193 - MINOR: http-htx: Store messages of an http-errors section in a http reply array
8194 - MINOR: http-htx: Store errorloc/errorfile messages in http replies
8195 - MINOR: proxy: Add references on http replies for proxy error messages
8196 - MINOR: http-htx: Use http reply from the http-errors section
8197 - MINOR: http-ana: Use a TXN flag to prevent after-response ruleset evaluation
8198 - MEDIUM: http-ana: Use http replies for HTTP error messages
8199 - CLEANUP: http-htx: Remove unused storage of error messages in buffers
8200 - MINOR: htx: Add a function to copy a buffer in an HTX message
8201 - CLEANUP: channel: Remove channel_htx_copy_msg() function
8202 - MINOR: http-ana: Add a function to write an http reply in an HTX message
8203 - MINOR: http-htx/proxy: Add http-error directive using http return syntax
8204 - DOC: Fix "errorfile" description in the configuration manual
8205 - BUG/MINOR: checks: Respect check-ssl param when a port or an addr is specified
8206 - BUILD: hpack: make sure the hpack table can still be built standalone
8207 - CONTRIB: hpack: make use of the simplified standalone HPACK API
8208 - MINOR: connection: add pp2-never-send-local to support old PP2 behavior
8209
Willy Tarreaufc0b8f32020-05-05 21:49:10 +020082102020/05/05 : 2.2-dev7
8211 - MINOR: version: Show uname output in display_version()
8212 - CI: run weekly OpenSSL "no-deprecated" builds
8213 - CLEANUP: log: fix comment of parse_logformat_string()
8214 - DOC: Improve documentation on http-request set-src
8215 - MINOR: ssl/cli: disallow SSL options for directory in 'add ssl crt-list'
8216 - MINOR: ssl/cli: restrain certificate path when inserting into a directory
8217 - MINOR: ssl: add ssl-skip-self-issued-ca global option
8218 - BUG/MINOR: ssl: default settings for ssl server options are not used
8219 - MINOR: config: add a global directive to set default SSL curves
8220 - BUG/MEDIUM: http-ana: Handle NTLM messages correctly.
8221 - DOC: internals: update the SSL architecture schema
8222 - BUG/MINOR: tools: fix the i386 version of the div64_32 function
8223 - BUG/MINOR: mux-fcgi/trace: fix wrong set of trace flags in fcgi_strm_add_eom()
8224 - BUG/MINOR: http: make url_decode() optionally convert '+' to SP
8225 - DOC: option logasap does not depend on mode
8226 - MEDIUM: memory: make pool_gc() run under thread isolation
8227 - MINOR: contrib: make the peers wireshark dissector a plugin
8228 - BUG/MINOR: http-ana: Throw a 500 error if after-response ruleset fails on errors
8229 - BUG/MINOR: check: Update server address and port to execute an external check
8230 - MINOR: mini-clist: Add functions to iterate backward on a list
8231 - MINOR: checks: Add a way to send custom headers and payload during http chekcs
8232 - MINOR: server: respect warning and alert semantic
8233 - BUG/MINOR: checks: Respect the no-check-ssl option
8234 - BUG/MEDIUM: server/checks: Init server check during config validity check
8235 - CLEANUP: checks: Don't export anymore init_check and srv_check_healthcheck_port
8236 - BUG/MINOR: checks: chained expect will not properly wait for enough data
8237 - BUG/MINOR: checks: Forbid tcp-check lines in default section as documented
8238 - MINOR: checks: Use an enum to describe the tcp-check rule type
8239 - MINOR: checks: Simplify connection flag parsing in tcp-check connect
8240 - MEDIUM: checks: rewind to the first inverse expect rule of a chain on new data
8241 - MINOR: checks: simplify tcp expect config parser
8242 - MINOR: checks: add min-recv tcp-check expect option
8243 - MINOR: checks: add linger option to tcp connect
8244 - MINOR: checks: define a tcp expect type
8245 - MEDIUM: checks: rewrite tcp-check expect block
8246 - MINOR: checks: Stop xform buffers to null-terminated string for tcp-check rules
8247 - MINOR: checks: add rbinary expect match type
8248 - MINOR: checks: Simplify functions to get step id and comment
8249 - MEDIUM: checks: capture groups in expect regexes
8250 - MINOR: checks: Don't use a static tcp rule list head
8251 - MEDIUM: checks: Use a non-comment rule iterator to get next rule
8252 - MEDIUM: proxy/checks: Register a keyword to parse tcp-check rules
8253 - MINOR: checks: Set the tcp-check rule index during parsing
8254 - MINOR: checks: define tcp-check send type
8255 - MINOR: checks: define a tcp-check connect type
8256 - MEDIUM: checks: Add implicit tcp-check connect rule
8257 - MAJOR: checks: Refactor and simplify the tcp-check loop
8258 - MEDIUM: checks: Associate a session to each tcp-check healthcheck
8259 - MINOR: checks/vars: Add a check scope for variables
8260 - MEDIUM: checks: Parse custom action rules in tcp-checks
8261 - MINOR: checks: Add support to set-var and unset-var rules in tcp-checks
8262 - MINOR: checks: Add the sni option for tcp-check connect rules
8263 - MINOR: checks: Add the via-socks4 option for tcp-check connect rules
8264 - MINOR: checks: Add the alpn option for tcp-check connect rules
8265 - MINOR: ssl: Export a generic function to parse an alpn string
8266 - MINOR: checks: Add the default option for tcp-check connect rules
8267 - MINOR: checks: Add the addr option for tcp-check connect rule
8268 - MEDIUM: checks: Support expression to set the port
8269 - MEDIUM: checks: Support log-format strings for tcp-check send rules
8270 - MINOR: log: Don't depends on a stream to process samples in log-format string
8271 - MINOR: log: Don't systematically set LW_REQ when a sample expr is added
8272 - MEDIUM: checks: Add a shared list of tcp-check rules
8273 - MINOR: sample: add htonl converter
8274 - MINOR: sample: add cut_crlf converter
8275 - MINOR: sample: add ltrim converter
8276 - MINOR: sample: add rtrim converter
8277 - MINOR: checks: Use a name for the healthcheck status enum
8278 - MINOR: checks: Add option to tcp-check expect rules to customize error status
8279 - MINOR: checks: Merge tcp-check comment rules with the others at config parsing
8280 - MINOR: checks: Add a sample fetch to extract a block from the input check buffer
8281 - MEDIUM: checks: Add on-error/on-success option on tcp-check expect rules
8282 - MEDIUM: checks: Add status-code sample expression on tcp-check expect rules
8283 - MINOR: checks: Relax the default option for tcp-check connect rules
8284 - MEDIUM: checks: Add a list of vars to set before executing a tpc-check ruleset
8285 - MINOR: checks: Export the tcpcheck_eval_ret enum
8286 - MINOR: checks: Use dedicated function to handle onsuccess/onerror messages
8287 - MINOR: checks: Support custom functions to eval a tcp-check expect rules
8288 - MEDIUM: checks: Implement redis check using tcp-check rules
8289 - MEDIUM: checks: Implement ssl-hello check using tcp-check rules
8290 - MEDIUM: checks: Implement smtp check using tcp-check rules
8291 - MEDIUM: checks: Implement postgres check using tcp-check rules
8292 - MEDIUM: checks: Implement MySQL check using tcp-check rules
8293 - MEDIUM: checks: Implement LDAP check using tcp-check rules
8294 - MEDIUM: checks: Implement SPOP check using tcp-check rules
8295 - MINOR: server/checks: Move parsing of agent keywords in checks.c
8296 - MINOR: server/checks: Move parsing of server check keywords in checks.c
8297 - MEDIUM: checks: Implement agent check using tcp-check rules
8298 - REGTEST: Adapt regtests about checks to recent changes
8299 - MINOR: Produce tcp-check info message for pure tcp-check rules only
8300 - MINOR: checks: Add an option to set success status of tcp-check expect rules
8301 - MINOR: checks: Improve log message of tcp-checks on success
8302 - MINOR: proxy/checks: Move parsing of httpchk option in checks.c
8303 - MINOR: proxy/checks: Move parsing of tcp-check option in checks.c
8304 - MINOR: proxy/checks: Register a keyword to parse http-check rules
8305 - MINOR: proxy/checks: Move parsing of external-check option in checks.c
8306 - MINOR: proxy/checks: Register a keyword to parse external-check rules
8307 - MEDIUM: checks: Use a shared ruleset to store tcp-check rules
8308 - MINOR: checks: Use an indirect string to represent the expect matching string
8309 - MINOR: checks: Introduce flags to configure in tcp-check expect rules
8310 - MINOR: standard: Add my_memspn and my_memcspn
8311 - MINOR: checks: Add a reverse non-comment rule iterator to get last rule
8312 - MAJOR: checks: Implement HTTP check using tcp-check rules
8313 - MINOR: checks: Make resume conditions more explicit in tcpcheck_main()
8314 - MINOR: connection: Add macros to know if a conn or a cs uses an HTX mux
8315 - MEDIUM: checks: Refactor how data are received in tcpcheck_main()
8316 - MINOR: checks/obj_type: Add a new object type for checks
8317 - BUG/MINOR: obj_type: Handle stream object in obj_base_ptr() function
8318 - MINOR: checks: Use the check as origin when a session is created
8319 - MINOR: checks: Add a mux proto to health-check and tcp-check connect rule
8320 - MINOR: connection: Add a function to install a mux for a health-check
8321 - MAJOR: checks: Use the best mux depending on the protocol for health checks
8322 - MEDIUM: checks: Implement default TCP check using tcp-check rules
8323 - MINOR: checks: Remove unused code about pure TCP checks
8324 - CLEANUP: checks: Reorg checks.c file to be more readable
8325 - REGTEST: Fix reg-tests about health-checks to adapt them to recent changes
8326 - MINOR: ist: Add a function to retrieve the ist pointer
8327 - MINOR: checks: Use ist API as far as possible
8328 - BUG/MEDIUM: checks: Be sure to subscribe for sends if outgoing data remains
8329 - MINOR: checks: Use a tree instead of a list to store tcp-check rulesets
8330 - BUG/MINOR: checks: Send the right amount of outgoing data for HTTP checks
8331 - REGTEST: Add scripts to test based tcp-check health-checks
8332 - Revert "MEDIUM: checks: capture groups in expect regexes"
8333 - DOC: Add documentation about comments for tcp-check and http-check directives
8334 - DOC: Fix the tcp-check and http-check directives layout
8335 - BUG/MEDIUM: checks: Use the mux protocol specified on the server line
8336 - MINOR: checks: Support mux protocol definition for tcp and http health checks
8337 - BUG/MINOR: mux-fcgi: Be sure to have a connection as session's origin to use it
8338 - MINOR: checks: Support list of status codes on http-check expect rules
8339 - BUG/MEDIUM: checks: Unsubscribe to mux events when a conn-stream is destroyed
8340 - REGTEST: Add a script to validate agent checks
8341 - BUG/MINOR: server: Fix server_finalize_init() to avoid unused variable
8342 - BUG/MEDIUM: checks: unsubscribe for events on the old conn-stream on connect
8343 - BUG/MINOR: checks: Only use ssl_sock_is_ssl() if compiled with SSL support
8344 - BUG/MINOR: checks/server: use_ssl member must be signed
8345 - BUG/MEDIUM: sessions: Always pass the mux context as argument to destroy a mux
8346 - BUG/MEDIUM: checks: Destroy the conn-stream before the session
8347 - BUG/MINOR: checks: Fix PostgreSQL regex on the authentication packet
8348 - CI: cirrus-ci: remove reg-tests/checks/tcp-check-ssl.vtc on CentOS 6
8349 - MINOR: checks: Support HTTP/2 version (without '.0') for http-check send rules
8350 - MINOR: checks: Use ver keyword to specify the HTTP version for http checks
8351 - BUG/MINOR: checks: Remove wrong variable redeclaration
8352 - BUG/MINOR: checks: Properly handle truncated mysql server messages
8353 - CLEANUP: checks: Remove unused code when ldap server message is parsed
8354 - MINOR: checks: Make the use of the check's server more explicit on connect
8355 - BUG/MINOR: checks: Avoid incompatible cast when a binary string is parsed
8356 - BUG/MINOR: checks: Remove bad call to free() when an expect rule is parsed
8357 - BUG/MINOR: checks: Don't lose warning on proxy capability
8358 - MINOR: log: Add "Tu" timer
8359 - BUG/MINOR: checks: Set the output buffer length before calling parse_binary()
8360 - BUG/MEDIUM: mux-h1: make sure we always have a timeout on front connections
8361 - REGTEST: ssl: test the client certificate authentication
8362 - DOC: give a more accurate description of what check does
8363 - BUG/MEDIUM: capture: capture-req/capture-res converters crash without a stream
8364 - BUG/MEDIUM: capture: capture.{req,res}.* crash without a stream
8365 - BUG/MEDIUM: http: the "http_first_req" sample fetch could crash without a steeam
8366 - BUG/MEDIUM: http: the "unique-id" sample fetch could crash without a steeam
8367 - CLEANUP: http: add a few comments on certain functions' assumptions about streams
8368 - BUG/MEDIUM: sample: make the CPU and latency sample fetches check for a stream
8369 - MINOR: http-htx: Export functions to update message authority and host
8370 - MINOR: checks: Don't support multiple host header for http-check send rule
8371 - MINOR: checks: Skip some headers for http-check send rules
8372 - MINOR: checks: Keep the Host header and the request uri synchronized
8373 - CLEANUP: checks: Fix checks includes
8374 - DOC: Fix send rules in the http-check connect example
8375 - DOC: Add more info about request formatting in http-check send description
8376 - REGTEST: http-rules: Require PCRE or PCRE2 option to run map_redirect script
8377 - REGTEST: ssl: remove curl from the "add ssl crt-list" test
8378 - REGTEST: ssl: improve the "set ssl cert" test
8379 - CLEANUP: ssl: silence a build warning when threads are disabled
8380 - BUG/MEDIUM: listener: mark the thread as not stuck inside the loop
8381 - MINOR: threads: export the POSIX thread ID in panic dumps
8382 - BUG/MINOR: debug: properly use long long instead of long for the thread ID
8383 - BUG/MEDIUM: shctx: really check the lock's value while waiting
8384 - BUG/MEDIUM: shctx: bound the number of loops that can happen around the lock
8385 - MINOR: stream: report the list of active filters on stream crashes
8386 - BUG/MEDIUM: mux-fcgi: Return from detach if server don't keep the connection
8387 - BUG/MEDIUM: mux_fcgi: Free the FCGI connection at the end of fcgi_release()
8388 - BUG/MEDIUM: mux-fcgi: Fix wrong test on FCGI_CF_KEEP_CONN in fcgi_detach()
8389 - BUG/MEDIUM: connections: force connections cleanup on server changes
8390 - BUG/MEDIUM: h1: Don't compare host and authority if only h1 headers are parsed
8391 - BUG/MEDIUM: ssl: fix the id length check within smp_fetch_ssl_fc_session_id()
8392 - CLEANUP: connections: align function declaration
8393 - BUG/MINOR: sample: Set the correct type when a binary is converted to a string
8394 - MEDIUM: checks/http-fetch: Support htx prefetch from a check for HTTP samples
8395 - DOC: Document the log-format parameter for tcp-check send/send-binary rules
8396 - MINOR: checks: Add support of payload-based sample fetches
8397 - MINOR: checks: Add support of be_id, be_name, srv_id and srv_name sample fetches
8398 - MINOR: checks: Add support of server side ssl sample fetches
8399 - MINOR: checks: Add support of HTTP response sample fetches
8400 - MINOR: http-htx: Support different methods to look for header names
8401 - MINOR: checks: Set by default expect rule status to UNKNOWN during parsing
8402 - BUG/MINOR: checks: Support multiple HTTP expect rules
8403 - REGTEST: checks: Fix sync condition for agent-check
8404 - MEDIUM: checks: Support matching on headers for http-check expect rules
8405 - MINOR: lua: allow changing port with set_addr
8406 - BUG/MINOR: da: Fix HTX message prefetch
8407 - BUG/MINOR: wurfl: Fix HTX message prefetch
8408 - BUG/MINOR: 51d: Fix HTX message prefetch
8409 - MINOR: ist: add istadv() function
8410 - MINOR: ist: add istissame() function
8411 - MINOR: istbuf: add ist2buf() function
8412 - BUG/MINOR: threads: fix multiple use of argument inside HA_ATOMIC_CAS()
8413 - BUG/MINOR: threads: fix multiple use of argument inside HA_ATOMIC_UPDATE_{MIN,MAX}()
8414 - DOC: update intro.txt for 2.2
8415 - DOC: intro: add a contacts section
8416
Willy Tarreaud0089302020-04-17 14:19:38 +020084172020/04/17 : 2.2-dev6
8418 - BUG/MINOR: ssl: memory leak when find_chain is NULL
8419 - CLEANUP: ssl: rename ssl_get_issuer_chain to ssl_get0_issuer_chain
8420 - MINOR: ssl: rework add cert chain to CTX to be libssl independent
8421 - BUG/MINOR: peers: init bind_proc to 1 if it wasn't initialized
8422 - BUG/MINOR: peers: avoid an infinite loop with peers_fe is NULL
8423 - BUG/MINOR: peers: Use after free of "peers" section.
8424 - CI: github actions: add weekly h2spec test
8425 - BUG/MEDIUM: mux_h1: Process a new request if we already received it.
8426 - MINOR: build: Fix build in mux_h1
8427 - CLEANUP: remove obsolete comments
8428 - BUG/MEDIUM: dns: improper parsing of aditional records
8429 - MINOR: ssl: skip self issued CA in cert chain for ssl_ctx
8430 - MINOR: listener: add so_name sample fetch
8431 - MEDIUM: stream: support use-server rules with dynamic names
8432 - MINOR: servers: Add a counter for the number of currently used connections.
8433 - MEDIUM: connections: Revamp the way idle connections are killed
8434 - MINOR: cli: add a general purpose pointer in the CLI struct
8435 - MINOR: ssl: add a list of bind_conf in struct crtlist
8436 - REORG: ssl: move SETCERT enum to ssl_sock.h
8437 - BUG/MINOR: ssl: ckch_inst wrongly inserted in crtlist_entry
8438 - REORG: ssl: move some functions above crtlist_load_cert_dir()
8439 - MINOR: ssl: use crtlist_free() upon error in directory loading
8440 - MINOR: ssl: add a list of crtlist_entry in ckch_store
8441 - MINOR: ssl: store a ptr to crtlist in crtlist_entry
8442 - MINOR: ssl/cli: update pointer to store in 'commit ssl cert'
8443 - MEDIUM: ssl/cli: 'add ssl crt-list' command
8444 - REGTEST: ssl/cli: test the 'add ssl crt-list' command
8445 - BUG/MINOR: ssl: entry->ckch_inst not initialized
8446 - REGTEST: ssl/cli: change test type to devel
8447 - REGTEST: make the PROXY TLV validation depend on version 2.2
8448 - CLEANUP: assorted typo fixes in the code and comments
8449 - BUG/MINOR: stats: Fix color of draining servers on stats page
8450 - DOC: internals: Fix spelling errors in filters.txt
8451 - MINOR: connections: Don't mark conn flags 0x00000001 and 0x00000002 as unused.
8452 - REGTEST: make the unique-id test depend on version 2.0
8453 - BUG/MEDIUM: dns: Consider the fact that dns answers are case-insensitive
8454 - MINOR: ssl: split the line parsing of the crt-list
8455 - MINOR: ssl/cli: support filters and options in add ssl crt-list
8456 - MINOR: ssl: add a comment above the ssl_bind_conf keywords
8457 - REGTEST: ssl/cli: tests options and filters w/ add ssl crt-list
8458 - REGTEST: ssl: pollute the crt-list file
8459 - BUG/CRITICAL: hpack: never index a header into the headroom after wrapping
8460 - BUG/MINOR: protocol_buffer: Wrong maximum shifting.
8461 - CLEANUP: src/fd.c: mask setsockopt with DISGUISE
8462 - BUG/MINOR: ssl/cli: initialize fcount int crtlist_entry
8463 - REGTEST: ssl/cli: add other cases of 'add ssl crt-list'
8464 - CLEANUP: assorted typo fixes in the code and comments
8465 - DOC: management: add the new crt-list CLI commands
8466 - BUG/MINOR: ssl/cli: fix spaces in 'show ssl crt-list'
8467 - MINOR: ssl/cli: 'del ssl crt-list' delete an entry
8468 - MINOR: ssl/cli: replace dump/show ssl crt-list by '-n' option
8469 - CI: use better SSL library definition
8470 - CI: travis-ci: enable DEBUG_STRICT=1 for CI builds
8471 - CI: travis-ci: upgrade openssl to 1.1.1f
8472 - MINOR: ssl: improve the errors when a crt can't be open
8473 - CI: cirrus-ci: rename openssl package after it is renamed in FreeBSD
8474 - CI: adopt openssl download script to download all versions
8475 - BUG/MINOR: ssl/cli: lock the ckch structures during crt-list delete
8476 - MINOR: ssl/cli: improve error for bundle in add/del ssl crt-list
8477 - MINOR: ssl/cli: 'del ssl cert' deletes a certificate
8478 - BUG/MINOR: ssl: trailing slashes in directory names wrongly cached
8479 - BUG/MINOR: ssl/cli: memory leak in 'set ssl cert'
8480 - CLEANUP: ssl: use the refcount for the SSL_CTX'
8481 - CLEANUP: ssl/cli: use the list of filters in the crtlist_entry
8482 - BUG/MINOR: ssl: memleak of the struct cert_key_and_chain
8483 - CLEANUP: ssl: remove a commentary in struct ckch_inst
8484 - MINOR: ssl: initialize all list in ckch_inst_new()
8485 - MINOR: ssl: free instances and SNIs with ckch_inst_free()
8486 - MINOR: ssl: replace ckchs_free() by ckch_store_free()
8487 - BUG/MEDIUM: ssl/cli: trying to access to free'd memory
8488 - MINOR: ssl: ckch_store_new() alloc and init a ckch_store
8489 - MINOR: ssl: crtlist_new() alloc and initialize a struct crtlist
8490 - REORG: ssl: move some free/new functions
8491 - MINOR: ssl: crtlist_entry_{new, free}
8492 - BUG/MINOR: ssl: ssl_conf always set to NULL on crt-list parsing
8493 - MINOR: ssl: don't alloc ssl_conf if no option found
8494 - BUG/MINOR: connection: always send address-less LOCAL PROXY connections
8495 - BUG/MINOR: peers: Incomplete peers sections should be validated.
8496 - MINOR: init: report in "haproxy -c" whether there were warnings or not
8497 - MINOR: init: add -dW and "zero-warning" to reject configs with warnings
8498 - MINOR: init: report the compiler version in haproxy -vv
8499 - CLEANUP: assorted typo fixes in the code and comments
8500 - MINOR: init: report the haproxy version and executable path once on errors
8501 - DOC: Make how "option redispatch" works more explicit
8502 - BUILD: Makefile: add linux-musl to TARGET
8503 - CLEANUP: assorted typo fixes in the code and comments
8504 - CLEANUP: http: Fixed small typo in parse_http_return
8505 - DOC: hashing: update link to hashing functions
8506
Willy Tarreau3328f182020-03-23 09:43:45 +010085072020/03/23 : 2.2-dev5
8508 - CLEANUP: ssl: is_default is a bit in ckch_inst
8509 - BUG/MINOR: ssl/cli: sni_ctx' mustn't always be used as filters
8510 - DOC: ssl: clarify security implications of TLS tickets
8511 - CLEANUP: remove support for Linux i686 vsyscalls
8512 - CLEANUP: drop support for USE_MY_ACCEPT4
8513 - CLEANUP: remove support for USE_MY_EPOLL
8514 - CLEANUP: remove support for USE_MY_SPLICE
8515 - CLEANUP: remove the now unused common/syscall.h
8516 - BUILD: make dladdr1 depend on glibc version and not __USE_GNU
8517 - BUILD: wdt: only test for SI_TKILL when compiled with thread support
8518 - BUILD: Makefile: the compiler-specific flags should all be in SPEC_CFLAGS
8519 - CLEANUP: ssl: separate the directory loading in a new function
8520 - BUG/MINOR: buffers: MT_LIST_DEL_SAFE() expects the temporary pointer.
8521 - BUG/MEDIUM: mt_lists: Make sure we set the deleted element to NULL;
8522 - MINOR: init: move the maxsock calculation code to compute_ideal_maxsock()
8523 - MEDIUM: init: always try to push the FD limit when maxconn is set from -m
8524 - BUG/MAJOR: list: fix invalid element address calculation
8525 - BUILD: stream-int: fix a few includes dependencies
8526 - MINOR: mt_lists: Appease gcc.
8527 - MINOR: lists: Implement function to convert list => mt_list and mt_list => list
8528 - MINOR: servers: Kill priv_conns.
8529 - MINOR: lists: fix indentation.
8530 - BUG/MEDIUM: random: align the state on 2*64 bits for ARM64
8531 - BUG/MEDIUM: connections: Don't assume the connection has a valid session.
8532 - BUG/MEDIUM: pools: Always update free_list in pool_gc().
8533 - BUG/MINOR: haproxy: always initialize sleeping_thread_mask
8534 - BUG/MINOR: listener/mq: do not dispatch connections to remote threads when stopping
8535 - BUG/MINOR: haproxy/threads: try to make all threads leave together
8536 - Revert "BUILD: travis-ci: enable s390x builds"
8537 - BUILD: travis-ci: enable regular s390x builds
8538 - DOC: proxy_protocol: Reserve TLV type 0x05 as PP2_TYPE_UNIQUE_ID
8539 - MINOR: proxy_protocol: Ingest PP2_TYPE_UNIQUE_ID on incoming connections
8540 - MEDIUM: proxy_protocol: Support sending unique IDs using PPv2
8541 - CLEANUP: connection: Add blank line after declarations in PP handling
8542 - CLEANUP: assorted typo fixes in the code and comments
8543 - CI: add spellcheck github action
8544 - DOC: correct typo in alert message about rspirep
8545 - CI: travis: switch linux builds to clang-9
8546 - MINOR: debug: add a new DISGUISE() macro to pass a value as identity
8547 - MINOR: debug: consume the write() result in BUG_ON() to silence a warning
8548 - MINOR: use DISGUISE() everywhere we deliberately want to ignore a result
8549 - BUILD: pools: silence build warnings with DEBUG_MEMORY_POOLS and DEBUG_UAF
8550 - CLEANUP: connection: Stop directly setting an ist's .ptr
8551 - CI: travis: revert to clang-7 for BoringSSL tests
8552 - BUILD: on ARM, must be linked to libatomic.
8553 - BUILD: makefile: fix regex syntax in ARM platform detection
8554 - BUG/MEDIUM: peers: resync ended with RESYNC_PARTIAL in wrong cases.
8555 - REORG: ssl: move ssl_sock_load_cert()
8556 - MINOR: ssl: pass ckch_inst to ssl_sock_load_ckchs()
8557 - MEDIUM: ssl: allow crt-list caching
8558 - MINOR: ssl: directories are loaded like crt-list
8559 - BUG/MINOR: ssl: can't open directories anymore
8560 - BUG/MEDIUM: spoe: dup agent's engine_id string from trash.area
8561 - MINOR: fd: Use a separate lock for logs instead of abusing the fd lock.
8562 - MINOR: mux_pt: Don't try to remove the connection from the idle list.
8563 - MINOR: ssl/cli: show/dump ssl crt-list
8564 - BUG/MINOR: ssl/cli: free the trash chunk in dump_crtlist
8565 - MEDIUM: fd: Introduce a running mask, and use it instead of the spinlock.
8566 - BUG/MINOR: ssl: memory leak in crtlist_parse_file()
8567 - MINOR: tasks: Provide the tasklet to the callback.
8568 - BUG/MINOR: ssl: memleak of struct crtlist_entry
8569 - BUG/MINOR: pattern: Do not pass len = 0 to calloc()
8570 - BUILD: makefile: fix expression again to detect ARM platform
8571 - CI: travis: re-enable ASAN on clang
8572 - CI: travis: proper group output redirection together with travis_wait
8573 - DOC: assorted typo fixes in the documentation
8574 - MINOR: wdt: Move the definitions of WDTSIG and DEBUGSIG into types/signal.h.
8575 - BUG/MEDIUM: wdt: Don't ignore WDTSIG and DEBUGSIG in __signal_process_queue().
8576 - MINOR: memory: Change the flush_lock to a spinlock, and don't get it in alloc.
8577 - MINOR: ssl/cli: 'new ssl cert' command
8578 - MINOR: ssl/cli: show certificate status in 'show ssl cert'
8579 - MEDIUM: sessions: Don't be responsible for connections anymore.
8580 - MEDIUM: servers: Split the connections into idle, safe, and available.
8581 - MINOR: fd: Implement fd_takeover().
8582 - MINOR: connections: Add a new mux method, "takeover".
8583 - MINOR: connections: Make the "list" element a struct mt_list instead of list.
8584 - MINOR: connections: Add a flag to know if we're in the safe or idle list.
8585 - MEDIUM: connections: Attempt to get idle connections from other threads.
8586 - MEDIUM: mux_h1: Implement the takeover() method.
8587 - MEDIUM: mux_h2: Implement the takeover() method.
8588 - MEDIUM: mux_fcgi: Implement the takeover() method.
8589 - MEDIUM: connections: Kill connections even if we are reusing one.
8590 - BUG/MEDIUM: connections: Don't forget to decrement idle connection counters.
8591 - BUG/MINOR: ssl: Do not free garbage pointers on memory allocation failure
8592 - BUG/MINOR: ssl: Correctly add the 1 for the sentinel to the number of elements
8593 - BUG/MINOR: ssl: crtlist_dup_filters() must return NULL with fcount == 0
8594 - BUG/MEDIUM: build: Fix compilation by spelling decl correctly.
8595 - BUILD/MEDIUM: fd: Declare fd_mig_lock as extern.
8596 - CI: run travis-ci builds on push only, skip pull requests
8597 - CI: temporarily disable unstable travis arm64 builds
8598 - BUG/MINOR: ssl/cli: free BIO upon error in 'show ssl cert'
8599 - BUG/MINOR: connections: Make sure we free the connection on failure.
8600 - BUG/MINOR: ssl/cli: fix a potential NULL dereference
8601 - BUG/MEDIUM: h1: Make sure we subscribe before going into idle list.
8602 - BUG/MINOR: connections: Set idle_time before adding to idle list.
8603 - MINOR: muxes: Note that we can't usee a connection when added to the srv idle.
8604 - REGTEST: increase timeouts on the seamless-reload test
8605 - BUG/MINOR: haproxy/threads: close a possible race in soft-stop detection
8606 - CLEANUP: haproxy/threads: don't check global_tasks_mask twice
8607
Willy Tarreau5a753bd2020-03-09 14:57:20 +010086082020/03/09 : 2.2-dev4
8609 - MEDIUM: buffer: remove the buffer_wq lock
8610 - MINOR: ssl: move find certificate chain code to its own function
8611 - MINOR: ssl: resolve issuers chain later
8612 - MINOR: ssl: resolve ocsp_issuer later
8613 - MINOR: ssl/cli: "show ssl cert" command should print the "Chain Filename:"
8614 - BUG/MINOR: h2: reject again empty :path pseudo-headers
8615 - MINOR: wdt: always clear sigev_value to make valgrind happy
8616 - MINOR: epoll: always initialize all of epoll_event to please valgrind
8617 - BUG/MINOR: sample: Make sure to return stable IDs in the unique-id fetch
8618 - BUG/MEDIUM: ssl: chain must be initialized with sk_X509_new_null()
8619 - BUILD: cirrus-ci: suppress OS version check when installing packages
8620 - BUG/MINOR: http_ana: make sure redirect flags don't have overlapping bits
8621 - CLEANUP: fd: remove the FD_EV_STATUS aggregate
8622 - CLEANUP: fd: remove some unneeded definitions of FD_EV_* flags
8623 - MINOR: fd: merge the read and write error bits into RW error
8624 - BUG/MINOR: dns: ignore trailing dot
8625 - MINOR: contrib/prometheus-exporter: Add the last heathcheck duration metric
8626 - BUG/MINOR: http-htx: Do case-insensive comparisons on Host header name
8627 - MINOR: mux-h1: Remove useless case-insensitive comparisons
8628 - MINOR: rawsock: always mark the FD not ready when we're certain it happens
8629 - MEDIUM: connection: make the subscribe() call able to wakeup if ready
8630 - MEDIUM: connection: don't stop receiving events in the FD handler
8631 - MEDIUM: mux-h1: do not blindly wake up the tasklet at end of request anymore
8632 - BUG/MINOR: arg: don't reject missing optional args
8633 - MINOR: tools: make sure to correctly check the returned 'ms' in date2std_log
8634 - MINOR: debug: report the task handler's pointer relative to main
8635 - BUG/MEDIUM: debug: make the debug_handler check for the thread in threads_to_dump
8636 - MINOR: haproxy: export main to ease access from debugger
8637 - MINOR: haproxy: export run_poll_loop
8638 - MINOR: task: export run_tasks_from_list
8639 - BUILD: tools: remove obsolete and conflicting trace() from standard.c
8640 - MINOR: tools: add new function dump_addr_and_bytes()
8641 - MINOR: tools: add resolve_sym_name() to resolve function pointers
8642 - MINOR: debug: use resolve_sym_name() to dump task handlers
8643 - MINOR: cli: make "show fd" rely on resolve_sym_name()
8644 - MEDIUM: debug: add support for dumping backtraces of stuck threads
8645 - MINOR: debug: call backtrace() once upon startup
8646 - MINOR: ssl: add "ca-verify-file" directive
8647 - BUG/MINOR: wdt: do not return an error when the watchdog couldn't be enabled
8648 - BUILD: Makefile: include librt before libpthread
8649 - MEDIUM: wdt: fall back to CLOCK_REALTIME if CLOCK_THREAD_CPUTIME is not available
8650 - MINOR: wdt: do not depend on USE_THREAD
8651 - MINOR: debug: report the number of entries in the backtrace
8652 - MINOR: debug: improve backtrace() on aarch64 and possibly other systems
8653 - MINOR: debug: use our own backtrace function on clang+x86_64
8654 - MINOR: debug: dump the whole trace if we can't spot the starting point
8655 - BUILD: tools: unbreak resolve_sym_name() on non-GNU platforms
8656 - BUILD: tools: rely on __ELF__ not USE_DL to enable use of dladdr()
8657 - CLEANUP: contrib/spoa_example: Fix several typos
8658 - BUILD: makefile: do not modify the build options during make reg-tests
8659 - BUG/MEDIUM: connection: stop polling for sending when the event is ready
8660 - MEDIUM: stream-int: make sure to try to immediately validate the connection
8661 - MINOR: tcp/uxst/sockpair: only ask for I/O when really waiting for a connect()
8662 - MEDIUM: connection: only call ->wake() for connect() without I/O
8663 - OPTIM: connection: disable receiving on disabled events when the run queue is too high
8664 - OPTIM: mux-h1: subscribe rather than waking up at a few other places
8665 - REGTEST: Add unique-id reg-test
8666 - MINOR: stream: Add stream_generate_unique_id function
8667 - MINOR: stream: Use stream_generate_unique_id
8668 - BUG/MINOR: connection/debug: do not enforce !event_type on subscribe() anymore
8669 - MINOR: ssl/cli: support crt-list filters
8670 - MINOR: ssl: reach a ckch_store from a sni_ctx
8671 - DOC: fix incorrect indentation of http_auth_*
8672 - BUG/MINOR: ssl-sock: do not return an uninitialized pointer in ckch_inst_sni_ctx_to_sni_filters
8673 - MINOR: debug: add CLI command "debug dev write" to write an arbitrary size
8674 - MINOR: ist: Add `IST_NULL` macro
8675 - MINOR: ist: Add `int isttest(const struct ist)`
8676 - MINOR: ist: Add `struct ist istalloc(size_t)` and `void istfree(struct ist*)`
8677 - CLEANUP: Use `isttest()` and `istfree()`
8678 - MINOR: ist: Add `struct ist istdup(const struct ist)`
8679 - MINOR: proxy: Make `header_unique_id` a `struct ist`
8680 - MEDIUM: stream: Make the `unique_id` member of `struct stream` a `struct ist`
8681 - OPTIM: startup: fast unique_id allocation for acl.
8682 - DOC: configuration.txt: fix various typos
8683 - DOC: assorted typo fixes in the documentation and Makefile
8684 - BUG/MINOR: init: make the automatic maxconn consider the max of soft/hard limits
8685 - BUG/MAJOR: proxy_protocol: Properly validate TLV lengths
8686 - CLEANUP: proxy_protocol: Use `size_t` when parsing TLVs
8687 - MINOR: buf: Add function to insert a string at an absolute offset in a buffer
8688 - MINOR: htx: Add a function to return a block at a specific offset
8689 - MINOR: htx: Use htx_find_offset() to truncate an HTX message
8690 - MINOR: flt_trace: Use htx_find_offset() to get the available payload length
8691 - BUG/MINOR: filters: Use filter offset to decude the amount of forwarded data
8692 - BUG/MINOR: filters: Forward everything if no data filters are called
8693 - BUG/MEDIUM: cache/filters: Fix loop on HTX blocks caching the response payload
8694 - BUG/MEDIUM: compression/filters: Fix loop on HTX blocks compressing the payload
8695 - BUG/MINOR: http-ana: Reset request analysers on a response side error
8696 - BUG/MINOR: lua: Abort when txn:done() is called from a Lua action
8697 - BUG/MINOR: lua: Ignore the reserve to know if a channel is full or not
8698 - MINOR: lua: Add function to know if a channel is a response one
8699 - MINOR: lua: Stop using the lua txn in hlua_http_get_headers()
8700 - MINOR: lua: Stop using the lua txn in hlua_http_rep_hdr()
8701 - MINOR: lua: Stop using lua txn in hlua_http_del_hdr() and hlua_http_add_hdr()
8702 - MINOR: lua: Remove the flag HLUA_TXN_HTTP_RDY
8703 - MINOR: lua: Rename hlua_action_wake_time() to hlua_set_wake_time()
8704 - BUG/MINOR: lua: Init the lua wake_time value before calling a lua function
8705 - BUG/MINOR: http-rules: Return ACT_RET_ABRT to abort a transaction
8706 - BUG/MINOR: http-rules: Preserve FLT_END analyzers on reject action
8707 - BUG/MINOR: http-rules: Fix a typo in the reject action function
8708 - MINOR: cache/filters: Initialize the cache filter when stream is created
8709 - MINOR: compression/filters: Initialize the comp filter when stream is created
8710 - BUG/MINOR: rules: Preserve FLT_END analyzers on silent-drop action
8711 - BUG/MINOR: rules: Return ACT_RET_ABRT when a silent-drop action is executed
8712 - BUG/MINOR: rules: Increment be_counters if backend is assigned for a silent-drop
8713 - BUG/MINOR: http-rules: Abort transaction when a redirect is applied on response
8714 - BUILD: buffer: types/{ring.h,checks.h} should include buf.h, not buffer.h
8715 - BUILD: ssl: include mini-clist.h
8716 - BUILD: global: must not include common/standard.h but only types/freq_ctr.h
8717 - BUILD: freq_ctr: proto/freq_ctr needs to include common/standard.h
8718 - BUILD: listener: types/listener.h must not include standard.h
8719 - BUG/MEDIUM: random: initialize the random pool a bit better
8720 - BUG/MEDIUM: random: implement per-thread and per-process random sequences
8721 - Revert "BUG/MEDIUM: random: implement per-thread and per-process random sequences"
8722 - BUILD: cirrus-ci: get rid of unstable freebsd images
8723 - MINOR: tools: add 64-bit rotate operators
8724 - BUG/MEDIUM: random: implement a thread-safe and process-safe PRNG
8725 - MINOR: backend: use a single call to ha_random32() for the random LB algo
8726 - BUG/MINOR: checks/threads: use ha_random() and not rand()
8727 - MINOR: sample: make all bits random on the rand() sample fetch
8728 - MINOR: tools: add a generic function to generate UUIDs
8729 - DOC: fix typo about no-tls-tickets
8730 - DOC: improve description of no-tls-tickets
8731 - DOC: assorted typo fixes in the documentation
8732 - CLEANUP: remove unused code in 'my_ffsl/my_flsl' functions
8733
Willy Tarreau32bf97f2020-02-25 18:14:02 +010087342020/02/25 : 2.2-dev3
8735 - SCRIPTS: announce-release: place the send command in the mail's header
8736 - SCRIPTS: announce-release: allow the user to force to overwrite old files
8737 - SCRIPTS: backport: fix the master branch detection
8738 - BUG/MINOR: http-act: Set stream error flag before returning an error
8739 - BUG/MINOR: http-act: Fix bugs on error path during parsing of return actions
8740 - BUG/MEDIUM: ssl/cli: 'commit ssl cert' wrong SSL_CTX init
8741 - BUG/MEDIUM: tcp-rules: Fix track-sc* actions for L4/L5 TCP rules
8742 - DOC: schematic of the SSL certificates architecture
8743 - BUG/MAJOR: mux-h2: don't wake streams after connection was destroyed
8744 - BUG/MINOR: unix: better catch situations where the unix socket path length is close to the limit
8745 - BUILD: cirrus-ci: switch to "snap" images to unify openssl naming
8746 - BUILD: cirrus-ci: workaround "pkg install" bug
8747 - BUILD: cirrus-ci: add ERR=1 to freebsd builds
8748 - BUG/MINOR: connection: correctly retry I/O on signals
8749 - CLEANUP: mini-clist: simplify nested do { while(1) {} } while (0)
8750 - BUILD: http_act: cast file sizes when reporting file size error
8751 - BUG/MEDIUM: listener: only consider running threads when resuming listeners
8752 - BUG/MINOR: listener: enforce all_threads_mask on bind_thread on init
8753 - BUG/MINOR: tcp: avoid closing fd when socket failed in tcp_bind_listener
8754 - MINOR: build: add aix72-gcc build TARGET and power{8,9} CPUs
8755 - BUILD: travis-ci: no more allowed failures for openssl-1.0.2
8756 - BUILD: travis-ci: harden builds, add ERR=1 (warning ought to be errors)
8757 - BUILD: scripts/build-ssl.sh: use "uname" instead of ${TRAVIS_OS_NAME}
8758 - BUG/MINOR: tcp: don't try to set defaultmss when value is negative
8759 - SCRIPTS: make announce-release executable again
8760 - BUG/MINOR: namespace: avoid closing fd when socket failed in my_socketat
8761 - BUG/MEDIUM: muxes: Use the right argument when calling the destroy method.
8762 - BUG/MINOR: mux-fcgi: Forbid special characters when matching PATH_INFO param
8763 - CLEANUP: ssl: remove unused functions in openssl-compat.h
8764 - MINOR: mux-fcgi: Make the capture of the path-info optional in pathinfo regex
8765 - MINOR: tools: add is_idchar() to tell if a char may belong to an identifier
8766 - MINOR: chunk: implement chunk_strncpy() to copy partial strings
8767 - MINOR: sample/acl: use is_idchar() to locate the fetch/conv name
8768 - MEDIUM: arg: make make_arg_list() stop after its own arguments
8769 - MEDIUM: arg: copy parsed arguments into the trash instead of allocating them
8770 - MEDIUM: arg: make make_arg_list() support quotes in arguments
8771 - MINOR: sample: make sample_parse_expr() able to return an end pointer
8772 - MEDIUM: log-format: make the LF parser aware of sample expressions' end
8773 - BUG/MINOR: arg: report an error if an argument is larger than bufsize
8774 - SCRIPTS: announce-release: use mutt -H instead of -i to include the draft
8775 - BUILD: enable ERR=1 in github cygwin builds
8776 - BUG/MINOR: arg: fix again incorrect argument length check
8777 - MINOR: sample: regsub now supports backreferences
8778 - BUG/MINOR: tools: also accept '+' as a valid character in an identifier
8779 - MINOR: http-htx: Add a function to retrieve the headers size of an HTX message
8780 - MINOR: filters: Forward data only if the last filter forwards something
8781 - BUG/MINOR: filters: Count HTTP headers as filtered data but don't forward them
8782 - BUG/MINOR: http-htx: Don't return error if authority is updated without changes
8783 - BUG/MINOR: stream: Don't incr frontend cum_req counter when stream is closed
8784 - BUG/MINOR: sample: exit regsub() in case of trash allocation error
8785 - MINOR: ssl: add "issuers-chain-path" directive.
8786 - REGTESTS: use "command -v" instead of "which"
8787 - BUG/MINOR: http-ana: Matching on monitor-uri should be case-sensitive
8788 - MINOR: http-ana: Match on the path if the monitor-uri starts by a /
8789 - BUG/MINOR: ssl: Stop passing dynamic strings as format arguments
8790 - BUG/MAJOR: http-ana: Always abort the request when a tarpit is triggered
8791 - BUG/MINOR: mux: do not call conn_xprt_stop_recv() on buffer shortage
8792 - MINOR: checks: do not call conn_xprt_stop_send() anymore
8793 - CLEANUP: epoll: place the struct epoll_event in the stack
8794 - MEDIUM: connection: remove the intermediary polling state from the connection
8795 - MINOR: raw_sock: directly call fd_stop_send() and not conn_xprt_stop_send()
8796 - MINOR: tcp/uxst/sockpair: use fd_want_send() instead of conn_xprt_want_send()
8797 - MINOR: connection: remove the last calls to conn_xprt_{want,stop}_*
8798 - CLEANUP: connection: remove the definitions of conn_xprt_{stop,want}_{send,recv}
8799 - MINOR: connection: introduce a new receive flag: CO_RFL_READ_ONCE
8800 - MINOR: mux-h1: pass CO_RFL_READ_ONCE to the lower layers when relevant
8801 - MINOR: ist: add an iststop() function
8802 - BUG/MINOR: http: http-request replace-path duplicates the query string
8803 - CLEANUP: sample: use iststop instead of a for loop
8804 - BUG/MEDIUM: shctx: make sure to keep all blocks aligned
8805 - MINOR: compiler: move CPU capabilities definition from config.h and complete them
8806 - BUG/MEDIUM: ebtree: don't set attribute packed without unaligned access support
8807 - CLEANUP: http/h1: rely on HA_UNALIGNED_LE instead of checking for CPU families
8808 - BUILD: fix recent build failure on unaligned archs
8809 - MINOR: ssl: load the key from a dedicated file
8810 - BUG/MINOR: ssl: load .key in a directory only after PEM
8811 - MINOR: compiler: drop special cases of likely/unlikely for older compilers
8812 - CLEANUP: conn: Do not pass a pointer to likely
8813 - CLEANUP: net_helper: Do not negate the result of unlikely
8814 - BUILD: remove obsolete support for -mregparm / USE_REGPARM
8815 - CLEANUP: cfgparse: Fix type of second calloc() parameter
8816 - BUILD: ssl: only pass unsigned chars to isspace()
8817 - BUILD: general: always pass unsigned chars to is* functions
8818 - BUG/MINOR: sample: fix the json converter's endian-sensitivity
8819 - BUG/MEDIUM: ssl: fix several bad pointer aliases in a few sample fetch functions
8820 - CLEANUP: fd: use a union in fd_rm_from_fd_list() to shut aliasing warnings
8821 - CLEANUP: cache: use read_u32/write_u32 to access the cache entry's hash
8822 - CLEANUP: stick-tables: use read_u32() to display a node's key
8823 - CLEANUP: sample: use read_u64() in ipmask() to apply an IPv6 mask
8824 - MINOR: pattern: fix all remaining strict aliasing issues
8825 - CLEANUP: lua: fix aliasing issues in the address matching code
8826 - CLEANUP: connection: use read_u32() instead of a cast in the netscaler parser
8827 - BUILD: makefile: re-enable strict aliasing
8828 - BUG/MINOR: connection: make sure to correctly tag local PROXY connections
8829 - MINOR: compiler: add new alignment macros
8830 - BUILD: ebtree: improve architecture-specific alignment
8831 - MINOR: config: mark global.debug as deprecated
8832 - BUILD: travis-ci: enable s390x builds
8833 - MINOR: ssl/cli: 'show ssl cert' displays the chain
8834 - MINOR: ssl/cli: 'show ssl cert'displays the issuer in the chain
8835 - MINOR: ssl/cli: reorder 'show ssl cert' output
8836 - CLEANUP: ssl: move issuer_chain tree and definition
8837 - DOC: proxy-protocol: clarify IPv6 address representation in the spec
8838
Willy Tarreau4c47d912020-02-07 04:12:19 +010088392020/02/07 : 2.2-dev2
8840 - BUILD: CI: temporarily mark openssl-1.0.2 as allowed failure
8841 - MEDIUM: cli: Allow multiple filter entries for "show table"
8842 - BUG/MEDIUM: netscaler: Don't forget to allocate storage for conn->src/dst.
8843 - BUG/MINOR: ssl: ssl_sock_load_pem_into_ckch is not consistent
8844 - BUILD: stick-table: fix build errors introduced by last stick-table change
8845 - BUG/MINOR: cli: Missing arg offset for filter data values.
8846 - MEDIUM: streams: Always create a conn_stream in connect_server().
8847 - MEDIUM: connections: Get ride of the xprt_done callback.
8848 - CLEANUP: changelog: remove the duplicate entry for 2.2-dev1
8849 - BUILD: CI: move cygwin builds to Github Actions
8850 - MINOR: cli: Report location of errors or any extra data for "show table"
8851 - BUG/MINOR: ssl/cli: free the previous ckch content once a PEM is loaded
8852 - CLEANUP: backend: remove useless test for inexistent connection
8853 - CLEANUP: backend: shut another false null-deref in back_handle_st_con()
8854 - CLEANUP: stats: shut up a wrong null-deref warning from gcc 9.2
8855 - BUG/MINOR: ssl: increment issuer refcount if in chain
8856 - BUG/MINOR: ssl: memory leak w/ the ocsp_issuer
8857 - BUG/MINOR: ssl: typo in previous patch
8858 - BUG/MEDIUM: connections: Set CO_FL_CONNECTED in conn_complete_session().
8859 - BUG/MINOR: ssl/cli: ocsp_issuer must be set w/ "set ssl cert"
8860 - MEDIUM: connection: remove CO_FL_CONNECTED and only rely on CO_FL_WAIT_*
8861 - BUG/MEDIUM: 0rtt: Only consider the SSL handshake.
8862 - MINOR: stream-int: always report received shutdowns
8863 - MINOR: connection: remove CO_FL_SSL_WAIT_HS from CO_FL_HANDSHAKE
8864 - MEDIUM: connection: use CO_FL_WAIT_XPRT more consistently than L4/L6/HANDSHAKE
8865 - MINOR: connection: remove checks for CO_FL_HANDSHAKE before I/O
8866 - MINOR: connection: do not check for CO_FL_SOCK_RD_SH too early
8867 - MINOR: connection: don't check for CO_FL_SOCK_WR_SH too early in handshakes
8868 - MINOR: raw-sock: always check for CO_FL_SOCK_WR_SH before sending
8869 - MINOR: connection: remove some unneeded checks for CO_FL_SOCK_WR_SH
8870 - BUG/MINOR: stktable: report the current proxy name in error messages
8871 - BUG/MEDIUM: mux-h2: make sure we don't emit TE headers with anything but "trailers"
8872 - MINOR: lua: Add hlua_prepend_path function
8873 - MINOR: lua: Add lua-prepend-path configuration option
8874 - MINOR: lua: Add HLUA_PREPEND_C?PATH build option
8875 - BUILD: cfgparse: silence a bogus gcc warning on 32-bit machines
8876 - BUG/MINOR: http-ana: Increment the backend counters on the backend
8877 - BUG/MINOR: stream: Be sure to have a listener to increment its counters
8878 - BUG/MEDIUM: streams: Move the conn_stream allocation outside #IF USE_OPENSSL.
8879 - REGTESTS: make the set_ssl_cert test require version 2.2
8880 - BUG/MINOR: ssl: Possible memleak when allowing the 0RTT data buffer.
8881 - MINOR: ssl: Remove dead code.
8882 - BUG/MEDIUM: ssl: Don't forget to free ctx->ssl on failure.
8883 - BUG/MEDIUM: stream: Don't install the mux in back_handle_st_con().
8884 - MEDIUM: streams: Don't close the connection in back_handle_st_con().
8885 - MEDIUM: streams: Don't close the connection in back_handle_st_rdy().
8886 - BUILD: CI: disable slow regtests on Travis
8887 - BUG/MINOR: tcpchecks: fix the connect() flags regarding delayed ack
8888 - BUG/MINOR: http-rules: Always init log-format expr for common HTTP actions
8889 - BUG/MINOR: connection: fix ip6 dst_port copy in make_proxy_line_v2
8890 - BUG/MINOR: dns: allow 63 char in hostname
8891 - MINOR: proxy: clarify number of connections log when stopping
8892 - DOC: word converter ignores delimiters at the start or end of input string
8893 - MEDIUM: raw-sock: remove obsolete calls to fd_{cant,cond,done}_{send,recv}
8894 - BUG/MINOR: ssl/cli: fix unused variable with openssl < 1.0.2
8895 - MEDIUM: pipe/thread: reduce the locking overhead
8896 - MEDIUM: pipe/thread: maintain a per-thread local cache of recently used pipes
8897 - BUG/MEDIUM: pipe/thread: fix atomicity of pipe counters
8898 - MINOR: tasks: move the list walking code to its own function
8899 - MEDIUM: tasks: implement 3 different tasklet classes with their own queues
8900 - MEDIUM: tasks: automatically requeue into the bulk queue an already running tasklet
8901 - OPTIM: task: refine task classes default CPU bandwidth ratios
8902 - BUG/MEDIUM: connections: Don't forget to unlock when killing a connection.
8903 - MINOR: task: permanently flag tasklets waking themselves up
8904 - MINOR: task: make sched->current also reflect tasklets
8905 - MINOR: task: detect self-wakeups on tl==sched->current instead of TASK_RUNNING
8906 - OPTIM: task: readjust CPU bandwidth distribution since last update
8907 - MINOR: task: don't set TASK_RUNNING on tasklets
8908 - BUG/MEDIUM: memory_pool: Update the seq number in pool_flush().
8909 - MINOR: memory: Only init the pool spinlock once.
8910 - BUG/MEDIUM: memory: Add a rwlock before freeing memory.
8911 - BUG/MAJOR: memory: Don't forget to unlock the rwlock if the pool is empty.
8912 - MINOR: ssl: ssl-load-extra-files configure loading of files
8913 - SCRIPTS: add a new "backport" script to simplify long series of backports
8914 - BUG/MINOR: ssl: we may only ignore the first 64 errors
8915 - SCRIPTS: use /usr/bin/env bash instead of /bin/bash for scripts
8916 - BUG/MINOR: ssl: clear the SSL errors on DH loading failure
8917 - CLEANUP: hpack: remove a redundant test in the decoder
8918 - CLEANUP: peers: Remove unused static function `free_dcache`
8919 - CLEANUP: peers: Remove unused static function `free_dcache_tx`
8920 - CONTRIB: debug: add missing flags SF_HTX and SF_MUX
8921 - CONTRIB: debug: add the possibility to decode the value as certain types only
8922 - CONTRIB: debug: support reporting multiple values at once
8923 - BUG/MINOR: http-act: Use the good message to test strict rewritting mode
8924 - MINOR: global: Set default tune.maxrewrite value during global structure init
8925 - MINOR: http-rules: Set SF_ERR_PRXCOND termination flag when a header rewrite fails
8926 - MINOR: http-htx: Emit a warning if an error file runs over the buffer's reserve
8927 - MINOR: htx: Add a function to append an HTX message to another one
8928 - MINOR: htx/channel: Add a function to copy an HTX message in a channel's buffer
8929 - BUG/MINOR: http-ana: Don't overwrite outgoing data when an error is reported
8930 - MINOR: dns: Dynamically allocate dns options to reduce the act_rule size
8931 - MINOR: dns: Add function to release memory allocated for a do-resolve rule
8932 - BUG/MINOR: http-ana: Reset HTX first index when HAPRoxy sends a response
8933 - BUG/MINOR: http-ana: Set HTX_FL_PROXY_RESP flag if a server perform a redirect
8934 - MINOR: http-rules: Add a flag on redirect rules to know the rule direction
8935 - MINOR: http-rules: Handle the rule direction when a redirect is evaluated
8936 - MINOR: http-ana: Rely on http_reply_and_close() to handle server error
8937 - MINOR: http-ana: Add a function for forward internal responses
8938 - MINOR: http-ana/http-rules: Use dedicated function to forward internal responses
8939 - MEDIUM: http: Add a ruleset evaluated on all responses just before forwarding
8940 - MEDIUM: http-rules: Add the return action to HTTP rules
8941 - MEDIUM: http-rules: Support extra headers for HTTP return actions
8942 - CLEANUP: lua: Remove consistency check for sample fetches and actions
8943 - BUG/MINOR: http-ana: Increment failed_resp counters on invalid response
8944 - MINOR: lua: Get the action return code on the stack when an action finishes
8945 - MINOR: lua: Create the global 'act' object to register all action return codes
8946 - MINOR: lua: Add act:wake_time() function to set a timeout when an action yields
8947 - MEDIUM: lua: Add ability for actions to intercept HTTP messages
8948 - REGTESTS: Add reg tests for the HTTP return action
8949 - REGTESTS: Add a reg test for http-after-response rulesets
8950 - BUILD: lua: silence a warning on systems where longjmp is not marked as noreturn
8951 - MINOR: acl: Warn when an ACL is named 'or'
8952 - CONTRIB: debug: also support reading values from stdin
8953 - SCRIPTS: backport: use short revs and resolve the initial commit
8954 - BUG/MINOR: acl: Fix type of log message when an acl is named 'or'
8955
Willy Tarreau71f95fa2020-01-22 10:34:58 +010089562020/01/22 : 2.2-dev1
8957 - DOC: this is development again
8958 - MINOR: version: this is development again, update the status
8959 - SCRIPTS: update create-release to fix the changelog on new branches
8960 - CLEANUP: ssl: Clean up error handling
8961 - BUG/MINOR: contrib/prometheus-exporter: decode parameter and value only
8962 - BUG/MINOR: h1: Don't test the host header during response parsing
8963 - BUILD/MINOR: trace: fix use of long type in a few printf format strings
8964 - DOC: Clarify behavior of server maxconn in HTTP mode
8965 - MINOR: ssl: deduplicate ca-file
8966 - MINOR: ssl: compute ca-list from deduplicate ca-file
8967 - MINOR: ssl: deduplicate crl-file
8968 - CLEANUP: dns: resolution can never be null
8969 - BUG/MINOR: http-htx: Don't make http_find_header() fail if the value is empty
8970 - DOC: ssl/cli: set/commit/abort ssl cert
8971 - BUG/MINOR: ssl: fix SSL_CTX_set1_chain compatibility for openssl < 1.0.2
8972 - BUG/MINOR: fcgi-app: Make the directive pass-header case insensitive
8973 - BUG/MINOR: stats: Fix HTML output for the frontends heading
8974 - BUG/MINOR: ssl: fix X509 compatibility for openssl < 1.1.0
8975 - DOC: clarify matching strings on binary fetches
8976 - DOC: Fix ordered list in summary
8977 - DOC: move the "group" keyword at the right place
8978 - MEDIUM: init: prevent process and thread creation at runtime
8979 - BUG/MINOR: ssl/cli: 'ssl cert' cmd only usable w/ admin rights
8980 - BUG/MEDIUM: stream-int: don't subscribed for recv when we're trying to flush data
8981 - BUG/MINOR: stream-int: avoid calling rcv_buf() when splicing is still possible
8982 - BUG/MINOR: ssl/cli: don't overwrite the filters variable
8983 - BUG/MEDIUM: listener/thread: fix a race when pausing a listener
8984 - BUG/MINOR: ssl: certificate choice can be unexpected with openssl >= 1.1.1
8985 - BUG/MEDIUM: mux-h1: Never reuse H1 connection if a shutw is pending
8986 - BUG/MINOR: mux-h1: Don't rely on CO_FL_SOCK_RD_SH to set H1C_F_CS_SHUTDOWN
8987 - BUG/MINOR: mux-h1: Fix conditions to know whether or not we may receive data
8988 - BUG/MEDIUM: tasks: Make sure we switch wait queues in task_set_affinity().
8989 - BUG/MEDIUM: checks: Make sure we set the task affinity just before connecting.
8990 - MINOR: debug: replace popen() with pipe+fork() in "debug dev exec"
8991 - MEDIUM: init: set NO_NEW_PRIVS by default when supported
8992 - BUG/MINOR: mux-h1: Be sure to set CS_FL_WANT_ROOM when EOM can't be added
8993 - BUG/MEDIUM: mux-fcgi: Handle cases where the HTX EOM block cannot be inserted
8994 - BUG/MINOR: proxy: make soft_stop() also close FDs in LI_PAUSED state
8995 - BUG/MINOR: listener/threads: always use atomic ops to clear the FD events
8996 - BUG/MINOR: listener: also clear the error flag on a paused listener
8997 - BUG/MEDIUM: listener/threads: fix a remaining race in the listener's accept()
8998 - MINOR: listener: make the wait paths cleaner and more reliable
8999 - MINOR: listener: split dequeue_all_listener() in two
9000 - REORG: listener: move the global listener queue code to listener.c
9001 - DOC: document the listener state transitions
9002 - BUG/MEDIUM: kqueue: Make sure we report read events even when no data.
9003 - BUG/MAJOR: dns: add minimalist error processing on the Rx path
9004 - BUG/MEDIUM: proto_udp/threads: recv() and send() must not be exclusive.
9005 - DOC: listeners: add a few missing transitions
9006 - BUG/MINOR: tasks: only requeue a task if it was already in the queue
9007 - MINOR: tasks: split wake_expired_tasks() in two parts to avoid useless wakeups
9008 - DOC: proxies: HAProxy only supports 3 connection modes
9009 - DOC: remove references to the outdated architecture.txt
9010 - BUG/MINOR: log: fix minor resource leaks on logformat error path
9011 - BUG/MINOR: mworker: properly pass SIGTTOU/SIGTTIN to workers
9012 - BUG/MINOR: listener: do not immediately resume on transient error
9013 - BUG/MINOR: server: make "agent-addr" work on default-server line
9014 - BUG/MINOR: listener: fix off-by-one in state name check
9015 - BUILD/MINOR: unix sockets: silence an absurd gcc warning about strncpy()
9016 - MEDIUM: h1-htx: Add HTX EOM block when the message is in H1_MSG_DONE state
9017 - MINOR: http-htx: Add some htx sample fetches for debugging purpose
9018 - REGTEST: Add an HTX reg-test to check an edge case
9019 - DOC: clarify the fact that replace-uri works on a full URI
9020 - BUG/MINOR: sample: fix the closing bracket and LF in the debug converter
9021 - BUG/MINOR: sample: always check converters' arguments
9022 - MINOR: sample: Validate the number of bits for the sha2 converter
9023 - BUG/MEDIUM: ssl: Don't set the max early data we can receive too early.
9024 - MINOR: ssl/cli: 'show ssl cert' give information on the certificates
9025 - BUG/MINOR: ssl/cli: fix build for openssl < 1.0.2
9026 - MINOR: debug: support logging to various sinks
9027 - MINOR: http: add a new "replace-path" action
9028 - REGTEST: ssl: test the "set ssl cert" CLI command
9029 - REGTEST: run-regtests: implement #REQUIRE_BINARIES
9030 - MINOR: task: only check TASK_WOKEN_ANY to decide to requeue a task
9031 - BUG/MAJOR: task: add a new TASK_SHARED_WQ flag to fix foreing requeuing
9032 - BUG/MEDIUM: ssl: Revamp the way early data are handled.
9033 - MINOR: fd/threads: make _GET_NEXT()/_GET_PREV() use the volatile attribute
9034 - BUG/MEDIUM: fd/threads: fix a concurrency issue between add and rm on the same fd
9035 - REGTEST: make the "set ssl cert" require version 2.1
9036 - BUG/MINOR: ssl: openssl-compat: Fix getm_ defines
9037 - BUG/MEDIUM: state-file: do not allocate a full buffer for each server entry
9038 - BUG/MINOR: state-file: do not store duplicates in the global tree
9039 - BUG/MINOR: state-file: do not leak memory on parse errors
9040 - BUG/MAJOR: mux-h1: Don't pretend the input channel's buffer is full if empty
9041 - BUG/MEDIUM: stream: Be sure to never assign a TCP backend to an HTX stream
9042 - BUILD: ssl: improve SSL_CTX_set_ecdh_auto compatibility
9043 - BUILD: travis-ci: link with ssl libraries using rpath instead of LD_LIBRARY_PATH/DYLD_LIBRARY_PATH
9044 - BUILD: travis-ci: reenable address sanitizer for clang builds
9045 - BUG/MINOR: checks: refine which errno values are really errors.
9046 - BUG/MINOR: connection: only wake send/recv callbacks if the FD is active
9047 - CLEANUP: connection: conn->xprt is never NULL
9048 - MINOR: pollers: add a new flag to indicate pollers reporting ERR & HUP
9049 - MEDIUM: tcp: make tcp_connect_probe() consider ERR/HUP
9050 - REORG: connection: move tcp_connect_probe() to conn_fd_check()
9051 - MINOR: connection: check for connection validation earlier
9052 - MINOR: connection: remove the double test on xprt_done_cb()
9053 - CLEANUP: connection: merge CO_FL_NOTIFY_DATA and CO_FL_NOTIFY_DONE
9054 - MINOR: poller: do not call the IO handler if the FD is not active
9055 - OPTIM: epoll: always poll for recv if neither active nor ready
9056 - OPTIM: polling: do not create update entries for FD removal
9057 - BUG/MEDIUM: checks: Only attempt to do handshakes if the connection is ready.
9058 - BUG/MEDIUM: connections: Hold the lock when wanting to kill a connection.
9059 - BUILD: CI: modernize cirrus-ci
9060 - MINOR: config: disable busy polling on old processes
9061 - MINOR: ssl: Remove unused variable "need_out".
9062 - BUG/MINOR: h1: Report the right error position when a header value is invalid
9063 - BUG/MINOR: proxy: Fix input data copy when an error is captured
9064 - BUG/MEDIUM: http-ana: Truncate the response when a redirect rule is applied
9065 - BUG/MINOR: channel: inject output data at the end of output
9066 - BUG/MEDIUM: session: do not report a failure when rejecting a session
9067 - MEDIUM: dns: implement synchronous send
9068 - MINOR: raw_sock: make sure to disable polling once everything is sent
9069 - MINOR: http: Add 410 to http-request deny
9070 - MINOR: http: Add 404 to http-request deny
9071 - CLEANUP: mux-h2: remove unused goto "out_free_h2s"
9072 - BUILD: cirrus-ci: choose proper openssl package name
9073 - BUG/MAJOR: listener: do not schedule a task-less proxy
9074 - CLEANUP: server: remove unused err section in server_finalize_init
9075 - REGTEST: set_ssl_cert.vtc: replace "echo" with "printf"
9076 - BUG/MINOR: stream-int: Don't trigger L7 retry if max retries is already reached
9077 - BUG/MEDIUM: tasks: Use the MT macros in tasklet_free().
9078 - BUG/MINOR: mux-h2: use a safe list_for_each_entry in h2_send()
9079 - BUG/MEDIUM: mux-h2: fix missing test on sending_list in previous patch
9080 - CLEANUP: ssl: remove opendir call in ssl_sock_load_cert
9081 - MEDIUM: lua: don't call the GC as often when dealing with outgoing connections
9082 - BUG/MEDIUM: mux-h2: don't stop sending when crossing a buffer boundary
9083 - BUG/MINOR: cli/mworker: can't start haproxy with 2 programs
9084 - REGTEST: mcli/mcli_start_progs: start 2 programs
9085 - BUG/MEDIUM: mworker: remain in mworker mode during reload
9086 - DOC: clarify crt-base usage
9087 - CLEANUP: compression: remove unused deinit_comp_ctx section
9088 - BUG/MEDIUM: mux_h1: Don't call h1_send if we subscribed().
9089 - BUG/MEDIUM: raw_sock: Make sur the fd and conn are sync.
9090 - CLEANUP: proxy: simplify proxy_parse_rate_limit proxy checks
9091 - BUG/MAJOR: hashes: fix the signedness of the hash inputs
9092 - REGTEST: add sample_fetches/hashes.vtc to validate hashes
9093 - BUG/MEDIUM: cli: _getsocks must send the peers sockets
9094 - CLEANUP: cli: deduplicate the code in _getsocks
9095 - BUG/MINOR: stream: don't mistake match rules for store-request rules
9096 - BUG/MEDIUM: connection: add a mux flag to indicate splice usability
9097 - BUG/MINOR: pattern: handle errors from fgets when trying to load patterns
9098 - MINOR: connection: move the CO_FL_WAIT_ROOM cleanup to the reader only
9099 - MINOR: stream-int: remove dependency on CO_FL_WAIT_ROOM for rcv_buf()
9100 - MEDIUM: connection: get rid of CO_FL_CURR_* flags
9101 - BUILD: pattern: include errno.h
9102 - MEDIUM: mux-h2: do not try to stop sending streams on blocked mux
9103 - MEDIUM: mux-fcgi: do not try to stop sending streams on blocked mux
9104 - MEDIUM: mux-h2: do not make an h2s subscribe to itself on deferred shut
9105 - MEDIUM: mux-fcgi: do not make an fstrm subscribe to itself on deferred shut
9106 - REORG: stream/backend: move backend-specific stuff to backend.c
9107 - MEDIUM: backend: move the connection finalization step to back_handle_st_con()
9108 - MEDIUM: connection: merge the send_wait and recv_wait entries
9109 - MEDIUM: xprt: merge recv_wait and send_wait in xprt_handshake
9110 - MEDIUM: ssl: merge recv_wait and send_wait in ssl_sock
9111 - MEDIUM: mux-h1: merge recv_wait and send_wait
9112 - MEDIUM: mux-h2: merge recv_wait and send_wait event notifications
9113 - MEDIUM: mux-fcgi: merge recv_wait and send_wait event notifications
9114 - MINOR: connection: make the last arg of subscribe() a struct wait_event*
9115 - MINOR: ssl: Add support for returning the dn samples from ssl_(c|f)_(i|s)_dn in LDAP v3 (RFC2253) format.
9116 - DOC: Fix copy and paste mistake in http-response replace-value doc
9117 - BUG/MINOR: cache: Fix leak of cache name in error path
9118 - BUG/MINOR: dns: Make dns_query_id_seed unsigned
9119 - BUG/MINOR: 51d: Fix bug when HTX is enabled
9120 - MINOR: http-htx: Move htx sample fetches in the scope "internal"
9121 - MINOR: http-htx: Rename 'internal.htx_blk.val' to 'internal.htx_blk.data'
9122 - MINOR: http-htx: Make 'internal.htx_blk_data' return a binary string
9123 - DOC: Add a section to document the internal sample fetches
9124 - MINOR: mux-h1: Inherit send flags from the upper layer
9125 - MINOR: contrib/prometheus-exporter: Add heathcheck status/code in server metrics
9126 - BUG/MINOR: http-ana/filters: Wait end of the http_end callback for all filters
9127 - BUG/MINOR: http-rules: Remove buggy deinit functions for HTTP rules
9128 - BUG/MINOR: stick-table: Use MAX_SESS_STKCTR as the max track ID during parsing
9129 - MEDIUM: http-rules: Register an action keyword for all http rules
9130 - MINOR: tcp-rules: Always set from which ruleset a rule comes from
9131 - MINOR: actions: Use ACT_RET_CONT code to ignore an error from a custom action
9132 - MINOR: tcp-rules: Kill connections when custom actions return ACT_RET_ERR
9133 - MINOR: http-rules: Return an error when custom actions return ACT_RET_ERR
9134 - MINOR: counters: Add a counter to report internal processing errors
9135 - MEDIUM: http-ana: Properly handle internal processing errors
9136 - MINOR: http-rules: Add a rule result to report internal error
9137 - MINOR: http-rules: Handle internal errors during HTTP rules evaluation
9138 - MINOR: http-rules: Add more return codes to let custom actions act as normal ones
9139 - MINOR: tcp-rules: Handle denied/aborted/invalid connections from TCP rules
9140 - MINOR: http-rules: Handle denied/aborted/invalid connections from HTTP rules
9141 - MINOR: stats: Report internal errors in the proxies/listeners/servers stats
9142 - MINOR: contrib/prometheus-exporter: Export internal errors per proxy/server
9143 - MINOR: counters: Remove failed_secu counter and use denied_resp instead
9144 - MINOR: counters: Review conditions to increment counters from analysers
9145 - MINOR: http-ana: Add a txn flag to support soft/strict message rewrites
9146 - MINOR: http-rules: Handle all message rewrites the same way
9147 - MINOR: http-rules: Add a rule to enable or disable the strict rewriting mode
9148 - MEDIUM: http-rules: Enable the strict rewriting mode by default
9149 - REGTEST: Fix format of set-uri HTTP request rule in h1or2_to_h1c.vtc
9150 - MINOR: actions: Add a function pointer to release args used by actions
9151 - MINOR: actions: Regroup some info about HTTP rules in the same struct
9152 - MINOR: http-rules/tcp-rules: Call the defined action function first if defined
9153 - MINOR: actions: Rename the act_flag enum into act_opt
9154 - MINOR: actions: Add flags to configure the action behaviour
9155 - MINOR: actions: Use an integer to set the action type
9156 - MINOR: http-rules: Use a specific action type for some custom HTTP actions
9157 - MINOR: http-rules: Make replace-header and replace-value custom actions
9158 - MINOR: http-rules: Make set-header and add-header custom actions
9159 - MINOR: http-rules: Make set/del-map and add/del-acl custom actions
9160 - MINOR: http-rules: Group all processing of early-hint rule in its case clause
9161 - MEDIUM: http-rules: Make early-hint custom actions
9162 - MINOR: http-rule/tcp-rules: Make track-sc* custom actions
9163 - MINOR: tcp-rules: Make tcp-request capture a custom action
9164 - MINOR: http-rules: Add release functions for existing HTTP actions
9165 - BUG/MINOR: http-rules: Fix memory releases on error path during action parsing
9166 - MINOR: tcp-rules: Add release functions for existing TCP actions
9167 - BUG/MINOR: tcp-rules: Fix memory releases on error path during action parsing
9168 - MINOR: http-htx: Add functions to read a raw error file and convert it in HTX
9169 - MINOR: http-htx: Add functions to create HTX redirect message
9170 - MINOR: config: Use dedicated function to parse proxy's errorfiles
9171 - MINOR: config: Use dedicated function to parse proxy's errorloc
9172 - MEDIUM: http-htx/proxy: Use a global and centralized storage for HTTP error messages
9173 - MINOR: proxy: Register keywords to parse errorfile and errorloc directives
9174 - MINOR: http-htx: Add a new section to create groups of custom HTTP errors
9175 - MEDIUM: proxy: Add a directive to reference an http-errors section in a proxy
9176 - MINOR: http-rules: Update txn flags and status when a deny rule is executed
9177 - MINOR: http-rules: Support an optional status on deny rules for http reponses
9178 - MINOR: http-rules: Use same function to parse request and response deny actions
9179 - MINOR: http-ana: Add an error message in the txn and send it when defined
9180 - MEDIUM: http-rules: Support an optional error message in http deny rules
9181 - REGTEST: Add a strict rewriting mode reg test
9182 - REGEST: Add reg tests about error files
9183 - MINOR: ssl: accept 'verify' bind option with 'set ssl cert'
9184 - BUG/MINOR: ssl: ssl_sock_load_ocsp_response_from_file memory leak
9185 - BUG/MINOR: ssl: ssl_sock_load_issuer_file_into_ckch memory leak
9186 - BUG/MINOR: ssl: ssl_sock_load_sctl_from_file memory leak
9187 - BUG/MINOR: http_htx: Fix some leaks on error path when error files are loaded
9188 - CLEANUP: http-ana: Remove useless test on txn when the error message is retrieved
9189 - BUILD: CI: introduce ARM64 builds
9190 - BUILD: ssl: more elegant anti-replay feature presence check
9191 - MINOR: proxy/http-ana: Add support of extra attributes for the cookie directive
9192 - MEDIUM: dns: use Additional records from SRV responses
9193 - CLEANUP: Consistently `unsigned int` for bitfields
9194 - CLEANUP: pattern: remove the pat_time definition
9195 - BUG/MINOR: http_act: don't check capture id in backend
9196 - BUG/MINOR: ssl: fix build on development versions of openssl-1.1.x
9197
Willy Tarreau2e077f82019-11-25 20:36:16 +010091982019/11/25 : 2.2-dev0
9199 - exact copy of 2.1.0
9200
Willy Tarreaue54b43a2019-11-25 19:47:40 +010092012019/11/25 : 2.1.0
9202 - BUG/MINOR: init: fix set-dumpable when using uid/gid
9203 - MINOR: init: avoid code duplication while setting identify
9204 - BUG/MINOR: ssl: ssl_pkey_info_index ex_data can store a dereferenced pointer
9205 - BUG/MINOR: ssl: fix crt-list neg filter for openssl < 1.1.1
9206 - MINOR: peers: Alway show the table info for disconnected peers.
9207 - MINOR: peers: Add TX/RX heartbeat counters.
9208 - MINOR: peers: Add debugging information to "show peers".
9209 - BUG/MINOR: peers: Wrong null "server_name" data field handling.
9210 - MINOR: ssl/cli: 'abort ssl cert' deletes an on-going transaction
9211 - BUG/MEDIUM: mworker: don't fill the -sf argument with -1 during the reexec
9212 - BUG/MINOR: peers: "peer alive" flag not reset when deconnecting.
9213 - BUILD/MINOR: ssl: fix compiler warning about useless statement
9214 - BUG/MEDIUM: stream-int: Don't loose events on the CS when an EOS is reported
9215 - MINOR: contrib/prometheus-exporter: filter exported metrics by scope
9216 - MINOR: contrib/prometheus-exporter: Add a param to ignore servers in maintenance
9217 - BUILD: debug: Avoid warnings in dev mode with -02 because of some BUG_ON tests
9218 - BUG/MINOR: mux-h1: Fix tunnel mode detection on the response path
9219 - BUG/MINOR: http-ana: Properly catch aborts during the payload forwarding
9220 - DOC: Update http-buffer-request description to remove the part about chunks
9221 - BUG/MINOR: stream-int: Fix si_cs_recv() return value
9222 - DOC: internal: document the init calls
9223 - MEDIUM: dns: Add resolve-opts "ignore-weight"
9224 - MINOR: ssl: ssl_sock_prepare_ctx() return an error code
9225 - MEDIUM: ssl/cli: apply SSL configuration on SSL_CTX during commit
9226 - MINOR: ssl/cli: display warning during 'commit ssl cert'
9227 - MINOR: version: report the version status in "haproxy -v"
9228 - MINOR: version: emit the link to the known bugs in output of "haproxy -v"
9229 - DOC: Add documentation about the use-service action
9230 - MINOR: ssl: fix possible null dereference in error handling
9231 - BUG/MINOR: ssl: fix curve setup with LibreSSL
9232 - BUG/MINOR: ssl: Stop passing dynamic strings as format arguments
9233 - CLEANUP: ssl: check if a transaction exists once before setting it
9234 - BUG/MINOR: cli: fix out of bounds in -S parser
9235 - MINOR: ist: add ist_find_ctl()
9236 - BUG/MAJOR: h2: reject header values containing invalid chars
9237 - BUG/MAJOR: h2: make header field name filtering stronger
9238 - BUG/MAJOR: mux-h2: don't try to decode a response HEADERS frame in idle state
9239 - MINOR: h2: add a function to report H2 error codes as strings
9240 - MINOR: mux-h2/trace: report the connection and/or stream error code
9241 - SCRIPTS: create-release: show the correct origin name in suggested commands
9242 - SCRIPTS: git-show-backports: add "-s" to proposed cherry-pick commands
9243 - BUG/MEDIUM: trace: fix a typo causing an incorrect startup error
9244 - BUILD: reorder the objects in the makefile
9245 - DOC: mention in INSTALL haproxy 2.1 is a stable stable version
9246 - MINOR: version: indicate that this version is stable
9247
Willy Tarreau84681322019-11-15 18:49:37 +010092482019/11/15 : 2.1-dev5
9249 - BUG/MEDIUM: ssl/cli: don't alloc path when cert not found
9250 - BUG/MINOR: ssl/cli: unable to update a certificate without bundle extension
9251 - BUG/MINOR: ssl/cli: fix an error when a file is not found
9252 - MINOR: ssl/cli: replace the default_ctx during 'commit ssl cert'
9253 - DOC: fix date and http_date keywords syntax
9254 - MINOR: peers: Add "log" directive to "peers" section.
9255 - BUG/MEDIUM: mux-h1: Disable splicing for chunked messages
9256 - BUG/MEDIUM: stream: Be sure to support splicing at the mux level to enable it
9257 - MINOR: flt_trace: Rename macros to print trace messages
9258 - MINOR: trace: Add a set of macros to trace events if HA is compiled with debug
9259 - MEDIUM: stream/trace: Register a new trace source with its events
9260 - MINOR: doc: http-reuse connection pool fix
9261 - BUG/MEDIUM: stream: Be sure to release allocated captures for TCP streams
9262 - MINOR: http-ana: Remove the unused function http_reset_txn()
9263 - BUG/MINOR: action: do-resolve now use cached response
9264 - BUG: dns: timeout resolve not applied for valid resolutions
9265 - DOC: management: fix typo on "cache_lookups" stats output
9266 - BUG/MINOR: stream: init variables when the list is empty
9267 - BUG/MEDIUM: tasks: Make tasklet_remove_from_tasklet_list() no matter the tasklet.
9268 - BUG/MINOR: queue/threads: make the queue unlinking atomic
9269 - BUG/MEDIUM: Make sure we leave the session list in session_free().
9270 - CLEANUP: session: slightly simplify idle connection cleanup logic
9271 - MINOR: memory: also poison the area on freeing
9272 - CLEANUP: cli: use srv_shutdown_streams() instead of open-coding it
9273 - CLEANUP: stats: use srv_shutdown_streams() instead of open-coding it
9274 - BUG/MEDIUM: listeners: always pause a listener on out-of-resource condition
9275 - BUILD: contrib/da: remove an "unused" warning
9276 - BUG/MEDIUM: filters: Don't call TCP callbacks for HTX streams
9277 - MEDIUM: filters: Adapt filters API to allow again TCP filtering on HTX streams
9278 - MINOR: freq_ctr: Make the sliding window sums thread-safe
9279 - MINOR: stream: Remove the lock on the proxy to update time stats
9280 - MINOR: counters: Add fields to store the max observed for {q,c,d,t}_time
9281 - MINOR: stats: Report max times in addition of the averages for sessions
9282 - MINOR: contrib/prometheus-exporter: Report metrics about max times for sessions
9283 - BUG/MINOR: contrib/prometheus-exporter: Rename some metrics
9284 - MINOR: contrib/prometheus-exporter: report the number of idle conns per server
9285 - DOC: Add missing stats fields in the management manual
9286 - BUG/MINOR: mux-h1: Properly catch parsing errors on payload and trailers
9287 - BUG/MINOR: mux-h1: Don't set CS_FL_EOS on a read0 when receiving data to pipe
9288 - MINOR: mux-h1: Set EOI on the conn-stream when EOS is reported in TUNNEL state
9289 - MINOR: sink: Set the default max length for a message to BUFSIZE
9290 - MINOR: ring: make the parse function automatically set the handler/release
9291 - BUG/MINOR: log: make "show startup-log" use a ring buffer instead
9292 - MINOR: stick-table: allow sc-set-gpt0 to set value from an expression
9293
Willy Tarreau1753cb52019-11-03 15:43:10 +010092942019/11/03 : 2.1-dev4
9295 - BUG/MINOR: cli: don't call the kw->io_release if kw->parse failed
9296 - BUG/MINOR: mux-h2: Don't pretend mux buffers aren't full anymore if nothing sent
9297 - BUG/MAJOR: stream-int: Don't receive data from mux until SI_ST_EST is reached
9298 - DOC: remove obsolete section about header manipulation
9299 - BUG/MINOR: ssl/cli: cleanup on cli_parse_set_cert error
9300 - MINOR: ssl/cli: rework the 'set ssl cert' IO handler
9301 - BUILD: CI: comment out cygwin build, upgrade various ssl libraries
9302 - DOC: Improve documentation of http-re(quest|sponse) replace-(header|value|uri)
9303 - BUILD/MINOR: tools: shut up the format truncation warning in get_gmt_offset()
9304 - BUG/MINOR: spoe: fix off-by-one length in UUID format string
9305 - BUILD/MINOR: ssl: shut up a build warning about format truncation
9306 - BUILD: do not disable -Wformat-truncation anymore
9307 - MINOR: chunk: add chunk_istcat() to concatenate an ist after a chunk
9308 - Revert "MINOR: istbuf: add b_fromist() to make a buffer from an ist"
9309 - MINOR: mux: Add a new method to get informations about a mux.
9310 - BUG/MEDIUM: stream_interface: Only use SI_ST_RDY when the mux is ready.
9311 - BUG/MEDIUM: servers: Only set SF_SRV_REUSED if the connection if fully ready.
9312 - MINOR: doc: fix busy-polling performance reference
9313 - MINOR: config: allow no set-dumpable config option
9314 - MINOR: init: always fail when setrlimit fails
9315 - MINOR: ssl/cli: rework 'set ssl cert' as 'set/commit'
9316 - CLEANUP: ssl/cli: remove leftovers of bundle/certs (it < 2)
9317 - REGTEST: vtest can now enable mcli with its own flag
9318 - BUG/MINOR: config: Update cookie domain warn to RFC6265
9319 - MINOR: sample: add us/ms support to date/http_date
9320 - BUG/MINOR: ssl/cli: check trash allocation in cli_io_handler_commit_cert()
9321 - BUG/MEDIUM: mux-h2: report no available stream on a connection having errors
9322 - BUG/MEDIUM: mux-h2: immediately remove a failed connection from the idle list
9323 - BUG/MEDIUM: mux-h2: immediately report connection errors on streams
9324 - BUG/MINOR: stats: properly check the path and not the whole URI
9325 - BUG/MINOR: ssl: segfault in cli_parse_set_cert with old openssl/boringssl
9326 - BUG/MINOR: ssl: ckch->chain must be initialized
9327 - BUG/MINOR: ssl: double free on error for ckch->{key,cert}
9328 - MINOR: ssl: BoringSSL ocsp_response does not need issuer
9329 - BUG/MEDIUM: ssl/cli: fix dot research in cli_parse_set_cert
9330 - MINOR: backend: Add srv_name sample fetche
9331 - DOC: Add GitHub issue config.yml
9332
Willy Tarreauc70df532019-10-25 15:48:53 +020093332019/10/25 : 2.1-dev3
9334 - MINOR: mux-h2/trace: missing conn pointer in demux full message
9335 - MINOR: mux-h2: add a per-connection list of blocked streams
9336 - BUILD: ebtree: make eb_is_empty() and eb_is_dup() take a const
9337 - BUG/MEDIUM: mux-h2: do not enforce timeout on long connections
9338 - BUG/MEDIUM: tasks: Don't forget to decrement tasks_run_queue.
9339 - BUG/MINOR: peers: crash on reload without local peer.
9340 - BUG/MINOR: mux-h2/trace: Fix traces on h2c initialization
9341 - MINOR: h1-htx: Update h1_copy_msg_data() to ease the traces in the mux-h1
9342 - MINOR: htx: Adapt htx_dump() to be used from traces
9343 - MINOR: mux-h1/trace: register a new trace source with its events
9344 - MINOR: proxy: Store http-send-name-header in lower case
9345 - MINOR: http: Remove headers matching the name of http-send-name-header option
9346 - BUG/MINOR: mux-h1: Adjust header case when the server name is add to a request
9347 - BUG/MINOR: mux-h1: Adjust header case when chunked encoding is add to a message
9348 - MINOR: mux-h1: Try to wakeup the stream on output buffer allocation
9349 - MINOR: fcgi: Add function to get the string representation of a record type
9350 - MINOR: mux-fcgi/trace: Register a new trace source with its events
9351 - BUG/MEDIUM: cache: make sure not to cache requests with absolute-uri
9352 - DOC: clarify some points around http-send-name-header's behavior
9353 - MEDIUM: mux-h2: support emitting CONTINUATION frames after HEADERS
9354 - BUG/MINOR: mux-h1/mux-fcgi/trace: Fix position of the 4th arg in some traces
9355 - DOC: fix typo in Prometheus exporter doc
9356 - MINOR: h2: clarify the rules for how to convert an H2 request to HTX
9357 - MINOR: htx: Add 2 flags on the start-line to have more info about the uri
9358 - MINOR: http: Add a function to get the authority into a URI
9359 - MINOR: h1-htx: Set the flag HTX_SL_F_HAS_AUTHORITY during the request parsing
9360 - MEDIUM: http-htx: Keep the Host header and the request start-line synchronized
9361 - MINOR: h1-htx: Only use the path of a normalized URI to format a request line
9362 - MEDIUM: h2: make the request parser rebuild a complete URI
9363 - MINOR: h2: report in the HTX flags when the request has an authority
9364 - MEDIUM: mux-h2: do not map Host to :authority on output
9365 - MEDIUM: h2: use the normalized URI encoding for absolute form requests
9366 - MINOR: stats: mention in the help message support for "json" and "typed"
9367 - MINOR: stats: get rid of the ST_CONVDONE flag
9368 - MINOR: stats: replace the ST_* uri_auth flags with STAT_*
9369 - MINOR: stats: always merge the uri_auth flags into the appctx flags
9370 - MINOR: stats: set the appctx flags when initializing the applet only
9371 - MINOR: stats: get rid of the STAT_SHOWADMIN flag
9372 - MINOR: stats: make stats_dump_fields_json() directly take flags
9373 - MINOR: stats: uniformize the calling convention of the dump functions
9374 - MINOR: stats: support the "desc" output format modifier for info and stat
9375 - MINOR: stats: prepare to add a description with each stat/info field
9376 - MINOR: stats: make "show stat" and "show info"
9377 - MINOR: stats: fill all the descriptions for "show info" and "show stat"
9378 - BUG/MEDIUM: applet: always check a fast running applet's activity before killing
9379 - BUILD: stats: fix missing '=' sign in array declaration
9380 - MINOR: lists: add new macro LIST_SPLICE_END_DETACHED
9381 - MINOR: list: add new macro MT_LIST_BEHEAD
9382 - MEDIUM: task: Split the tasklet list into two lists.
9383 - MINOR: h2: Document traps to be avoided on multithread.
9384 - MINOR: lists: Try to use local variables instead of macro arguments.
9385 - MINOR: lists: Fix alignement of \ when relevant.
9386 - MINOR: mux-h2: also support emitting CONTINUATION on trailers
9387 - MINOR: ssl: crt-list do ckchn_lookup
9388 - REORG: ssl: rename ckch_node to ckch_store
9389 - REORG: ssl: move structures to ssl_sock.h
9390 - MINOR: ssl: initialize the sni_keytypes_map as EB_ROOT
9391 - MINOR: ssl: initialize explicitly the sni_ctx trees
9392 - BUG/MINOR: ssl: abort on sni allocation failure
9393 - BUG/MINOR: ssl: free the sni_keytype nodes
9394 - BUG/MINOR: ssl: abort on sni_keytypes allocation failure
9395 - MEDIUM: ssl: introduce the ckch instance structure
9396 - MEDIUM: ssl: split ssl_sock_add_cert_sni()
9397 - MINOR: ssl: ssl_sock_load_ckchn() can properly fail
9398 - MINOR: ssl: ssl_sock_load_multi_ckchs() can properly fail
9399 - MEDIUM: ssl: ssl_sock_load_ckchs() alloc a ckch_inst
9400 - MINOR: ssl: ssl_sock_load_crt_file_into_ckch() is filling from a BIO
9401 - MEDIUM: ssl/cli: 'set ssl cert' updates a certificate from the CLI
9402 - MINOR: ssl: load the sctl in/from the ckch
9403 - MINOR: ssl: load the ocsp in/from the ckch
9404 - BUG/MEDIUM: ssl: NULL dereference in ssl_sock_load_cert_sni()
9405 - BUG/MINOR: ssl: fix build without SSL
9406 - BUG/MINOR: ssl: fix build without multi-cert bundles
9407 - BUILD: ssl: wrong #ifdef for SSL engines code
9408 - BUG/MINOR: ssl: fix OCSP build with BoringSSL
9409 - BUG/MEDIUM: htx: Catch chunk_memcat() failures when HTX data are formatted to h1
9410 - BUG/MINOR: chunk: Fix tests on the chunk size in functions copying data
9411 - BUG/MINOR: mux-h1: Mark the output buffer as full when the xfer is interrupted
9412 - MINOR: mux-h1: Xfer as much payload data as possible during output processing
9413 - CLEANUP: h1-htx: Move htx-to-h1 formatting functions from htx.c to h1_htx.c
9414 - BUG/MINOR: mux-h1: Capture ignored parsing errors
9415 - MINOR: h1: Reject requests with different occurrences of the header host
9416 - MINOR: h1: Reject requests if the authority does not match the header host
9417 - REGTESTS: Send valid URIs in peers reg-tests and fix HA config to avoid warnings
9418 - REGTESTS: Adapt proxy_protocol_random_fail.vtc to match normalized URI too
9419 - BUG/MINOR: WURFL: fix send_log() function arguments
9420 - BUG/MINOR: ssl: fix error messages for OCSP loading
9421 - BUG/MINOR: ssl: can't load ocsp files
9422 - MINOR: version: make the version strings variables, not constants
9423 - BUG/MINOR: http-htx: Properly set htx flags on error files to support keep-alive
9424 - MINOR: htx: Add a flag on HTX to known when a response was generated by HAProxy
9425 - MINOR: mux-h1: Force close mode for proxy responses with an unfinished request
9426 - BUILD: travis-ci: limit build to branches "master" and "next"
9427 - BUILD/MEDIUM: threads: rename thread_info struct to ha_thread_info
9428 - BUILD/SMALL: threads: enable threads on osx
9429 - BUILD/MEDIUM: threads: enable cpu_affinity on osx
9430 - MINOR: istbuf: add b_fromist() to make a buffer from an ist
9431 - BUG/MINOR: cache: also cache absolute URIs
9432 - BUG/MINOR: mworker/ssl: close openssl FDs unconditionally
9433 - BUG/MINOR: tcp: Don't alter counters returned by tcp info fetchers
9434 - BUG/MEDIUM: lists: Handle 1-element-lists in MT_LIST_BEHEAD().
9435 - BUG/MEDIUM: mux_pt: Make sure we don't have a conn_stream before freeing.
9436 - BUG/MEDIUM: tasklet: properly compute the sleeping threads mask in tasklet_wakeup()
9437 - BUG/MAJOR: idle conns: schedule the cleanup task on the correct threads
9438 - BUG/MEDIUM: task: make tasklets either local or shared but not both at once
9439 - Revert e8826ded5fea3593d89da2be5c2d81c522070995.
9440 - BUG/MEDIUM: mux_pt: Don't destroy the connection if we have a stream attached.
9441 - BUG/MEDIUM: mux_pt: Only call the wake emthod if nobody subscribed to receive.
9442 - REGTEST: mcli/mcli_show_info: launch a 'show info' on the master CLI
9443 - CLEANUP: ssl: make ssl_sock_load_cert*() return real error codes
9444 - CLEANUP: ssl: make ssl_sock_load_ckchs() return a set of ERR_*
9445 - CLEANUP: ssl: make cli_parse_set_cert handle errcode and warnings.
9446 - CLEANUP: ssl: make ckch_inst_new_load_(multi_)store handle errcode/warn
9447 - CLEANUP: ssl: make ssl_sock_put_ckch_into_ctx handle errcode/warn
9448 - CLEANUP: ssl: make ssl_sock_load_dh_params handle errcode/warn
9449 - CLEANUP: bind: handle warning label on bind keywords parsing.
9450 - BUG/MEDIUM: ssl: 'tune.ssl.default-dh-param' value ignored with openssl > 1.1.1
9451 - BUG/MINOR: mworker/cli: reload fail with inherited FD
9452 - BUG/MINOR: ssl: Fix fd leak on error path when a TLS ticket keys file is parsed
9453 - BUG/MINOR: stick-table: Never exceed (MAX_SESS_STKCTR-1) when fetching a stkctr
9454 - BUG/MINOR: cache: alloc shctx after check config
9455 - BUG/MINOR: sample: Make the `field` converter compatible with `-m found`
9456 - BUG/MINOR: server: check return value of fopen() in apply_server_state()
9457 - REGTESTS: make seamless-reload depend on 1.9 and above
9458 - REGTESTS: server/cli_set_fqdn requires version 1.8 minimum
9459 - BUG/MINOR: dns: allow srv record weight set to 0
9460 - BUG/MINOR: ssl: fix memcpy overlap without consequences.
9461 - BUG/MINOR: stick-table: fix an incorrect 32 to 64 bit key conversion
9462 - BUG/MEDIUM: pattern: make the pattern LRU cache thread-local and lockless
9463 - BUG/MINOR: mux-h2: do not emit logs on backend connections
9464 - CLEANUP: ssl: remove old TODO commentary
9465 - CLEANUP: ssl: fix SNI/CKCH lock labels
9466 - MINOR: ssl: OCSP functions can load from file or buffer
9467 - MINOR: ssl: load sctl from buf OR from a file
9468 - MINOR: ssl: load issuer from file or from buffer
9469 - MINOR: ssl: split ssl_sock_load_crt_file_into_ckch()
9470 - BUG/MINOR: ssl/cli: fix looking up for a bundle
9471 - MINOR: ssl/cli: update ocsp/issuer/sctl file from the CLI
9472 - MINOR: ssl: update ssl_sock_free_cert_key_and_chain_contents
9473 - MINOR: ssl: copy a ckch from src to dst
9474 - MINOR: ssl: new functions duplicate and free a ckch_store
9475 - MINOR: ssl/cli: assignate a new ckch_store
9476 - MEDIUM: cli/ssl: handle the creation of SSL_CTX in an IO handler
9477 - BUG/MINOR: ssl/cli: fix build of SCTL and OCSP
9478 - BUG/MINOR: ssl/cli: out of bounds when built without ocsp/sctl
9479 - BUG/MINOR: ssl: fix build with openssl < 1.1.0
9480 - BUG/MINOR: ssl: fix build of X509_chain_up_ref() w/ libreSSL
9481 - MINOR: tcp: avoid confusion in time parsing init
9482 - MINOR: debug: add a new "debug dev stream" command
9483 - MINOR: cli/debug: validate addresses using may_access() in "debug dev stream"
9484 - REORG: move CLI access level definitions to cli.h
9485 - MINOR: cli: add an expert mode to hide dangerous commands
9486 - MINOR: debug: make most debug CLI commands accessible in expert mode
9487 - MINOR: stats/debug: maintain a counter of debug commands issued
9488 - BUG/MEDIUM: debug: address a possible null pointer dereference in "debug dev stream"
9489
Willy Tarreaucb8f03f2019-10-01 18:13:09 +020094902019/10/01 : 2.1-dev2
9491 - DOC: management: document reuse and connect counters in the CSV format
9492 - DOC: management: document cache_hits and cache_lookups in the CSV format
9493 - BUG/MINOR: dns: remove irrelevant dependency on a client connection
9494 - MINOR: applet: make appctx use their own pool
9495 - BUG/MEDIUM: checks: Don't attempt to receive data if we already subscribed.
9496 - BUG/MEDIUM: http/htx: unbreak option http_proxy
9497 - BUG/MINOR: backend: do not try to install a mux when the connection failed
9498 - MINOR: mux-h2: Don't adjust anymore the amount of data sent in h2_snd_buf()
9499 - BUG/MINOR: http_fetch: Fix http_auth/http_auth_group when called from TCP rules
9500 - BUG/MINOR: http_htx: Initialize HTX error messages for TCP proxies
9501 - BUG/MINOR: cache/htx: Make maxage calculation HTX aware
9502 - BUG/MINOR: hlua: Make the function txn:done() HTX aware
9503 - MINOR: proto_htx: Directly call htx_check_response_for_cacheability()
9504 - MINOR: proto_htx: Rely on the HTX function to apply a redirect rules
9505 - MINOR: proto_htx: Add the function htx_return_srv_error()
9506 - MINOR: backend/htx: Don't rewind output data to set the sni on a srv connection
9507 - MINOR: proto_htx: Don't stop forwarding when there is a post-connect processing
9508 - DOC: htx: Update comments in HTX files
9509 - CLEANUP: htx: Remove the unsued function htx_add_blk_type_size()
9510 - MINOR: htx: Deduce the number of used blocks from tail and head values
9511 - MINOR: htx: Use an array of char to store HTX blocks
9512 - MINOR: htx: Slightly update htx_dump() to report better messages
9513 - DOC: htx: Add internal documentation about the HTX
9514 - MAJOR: http: Deprecate and ignore the option "http-use-htx"
9515 - MEDIUM: mux-h2: Remove support of the legacy HTTP mode
9516 - CLEANUP: h2: Remove functions converting h2 requests to raw HTTP/1.1 ones
9517 - MINOR: connection: Remove the multiplexer protocol PROTO_MODE_HTX
9518 - MINOR: stream: Rely on HTX analyzers instead of legacy HTTP ones
9519 - MEDIUM: http_fetch: Remove code relying on HTTP legacy mode
9520 - MINOR: config: Remove tests on the option 'http-use-htx'
9521 - MINOR: stream: Remove tests on the option 'http-use-htx' in stream_new()
9522 - MINOR: proxy: Remove tests on the option 'http-use-htx' during H1 upgrade
9523 - MINOR: hlua: Remove tests on the option 'http-use-htx' to reject TCP applets
9524 - MINOR: cache: Remove tests on the option 'http-use-htx'
9525 - MINOR: contrib/prometheus-exporter: Remove tests on the option 'http-use-htx'
9526 - CLEANUP: proxy: Remove the flag PR_O2_USE_HTX
9527 - MINOR: proxy: Don't adjust connection mode of HTTP proxies anymore
9528 - MEDIUM: backend: Remove code relying on the HTTP legacy mode
9529 - MEDIUM: hlua: Remove code relying on the legacy HTTP mode
9530 - MINOR: http_act: Remove code relying on the legacy HTTP mode
9531 - MEDIUM: cache: Remove code relying on the legacy HTTP mode
9532 - MEDIUM: compression: Remove code relying on the legacy HTTP mode
9533 - MINOR: flt_trace: Remove code relying on the legacy HTTP mode
9534 - MINOR: stats: Remove code relying on the legacy HTTP mode
9535 - MAJOR: filters: Remove code relying on the legacy HTTP mode
9536 - MINOR: stream: Remove code relying on the legacy HTTP mode
9537 - MAJOR: http: Remove the HTTP legacy code
9538 - MINOR: hlua: Remove useless test on TX_CON_WANT_* flags
9539 - MINOR: proto_http: Remove unused http txn flags
9540 - MINOR: proto_http: Remove the unused flag HTTP_MSGF_WAIT_CONN
9541 - CLEANUP: proto_http: Group remaining flags of the HTTP transaction
9542 - CLEANUP: channel: Remove the unused flag CF_WAKE_CONNECT
9543 - CLEANUP: proto_http: Remove unecessary includes and comments
9544 - CLEANUP: proto_http: Move remaining code from proto_http.c to proto_htx.c
9545 - REORG: proto_htx: Move HTX analyzers & co to http_ana.{c,h} files
9546 - BUG/MINOR: debug: Remove flags CO_FL_SOCK_WR_ENA/CO_FL_SOCK_RD_ENA
9547 - MINOR: proxy: Remove support of the option 'http-tunnel'
9548 - DOC: config: Update as a result of the legacy HTTP removal
9549 - MEDIUM: config: Remove parsing of req* and rsp* directives
9550 - MINOR: proxy: Remove the unused list of block rules
9551 - MINOR: proxy/http_ana: Remove unused req_exp/rsp_exp and req_add/rsp_add lists
9552 - DOC: config: Remove unsupported req* and rsp* keywords
9553 - MINOR: global: Preset tune.max_http_hdr to its default value
9554 - MINOR: http: Don't store raw HTTP errors in chunks anymore
9555 - BUG/MINOR: session: Emit an HTTP error if accept fails only for H1 connection
9556 - BUG/MINOR: session: Send a default HTTP error if accept fails for a H1 socket
9557 - CLEANUP: mux-h2: Remove unused flags H2_SF_CHNK_*
9558 - BUG/MINOR: checks: do not exit tcp-checks from the middle of the loop
9559 - MINOR: config: Warn only if the option http-use-htx is used with "no" prefix
9560 - BUG/MEDIUM: mux-h1: Trim excess server data at the end of a transaction
9561 - MINOR: connection: add conn_get_src() and conn_get_dst()
9562 - MINOR: frontend: switch to conn_get_{src,dst}() for logging and debugging
9563 - MINOR: backend: switch to conn_get_{src,dst}() for port and address mapping
9564 - MINOR: ssl: switch to conn_get_dst() to retrieve the destination address
9565 - MINOR: tcp: replace various calls to conn_get_{from,to}_addr with conn_get_{src,dst}
9566 - MINOR: stream-int: use conn_get_{src,dst} in conn_si_send_proxy()
9567 - MINOR: stream/cli: use conn_get_{src,dst} in "show sess" and "show peers" output
9568 - MINOR: log: use conn_get_{dst,src}() to retrieve the cli/frt/bck/srv/ addresses
9569 - MINOR: http/htx: use conn_get_dst() to retrieve the destination address
9570 - MINOR: lua: use conn_get_{src,dst} to retrieve connection addresses
9571 - MINOR: http: check the source address via conn_get_src() in sample fetch functions
9572 - CLEANUP: connection: remove the now unused conn_get_{from,to}_addr()
9573 - MINOR: connection: add new src and dst fields
9574 - MINOR: connection: use conn->{src,dst} instead of &conn->addr.{from,to}
9575 - MINOR: ssl-sock: use conn->dst instead of &conn->addr.to
9576 - MINOR: lua: switch to conn->dst for a connection's target address
9577 - MINOR: peers: use conn->dst for the peer's target address
9578 - MINOR: htx: switch from conn->addr.{from,to} to conn->{src,dst}
9579 - MINOR: stream: switch from conn->addr.{from,to} to conn->{src,dst}
9580 - MINOR: proxy: switch to conn->src in error snapshots
9581 - MINOR: session: use conn->src instead of conn->addr.from
9582 - MINOR: tcp: replace conn->addr.{from,to} with conn->{src,dst}
9583 - MINOR: unix: use conn->dst for the target address in ->connect()
9584 - MINOR: sockpair: use conn->dst for the target address in ->connect()
9585 - MINOR: log: use conn->{src,dst} instead of conn->addr.{from,to}
9586 - MINOR: checks: replace conn->addr.to with conn->dst
9587 - MINOR: frontend: switch from conn->addr.{from,to} to conn->{src,dst}
9588 - MINOR: http: convert conn->addr.from to conn->src in sample fetches
9589 - MEDIUM: backend: turn all conn->addr.{from,to} to conn->{src,dst}
9590 - MINOR: connection: create a new pool for struct sockaddr_storage
9591 - MEDIUM: connection: make sure all address producers allocate their address
9592 - MAJOR: connection: remove the addr field
9593 - MINOR: connection: don't use clear_addr() anymore, just release the address
9594 - MINOR: stream: add a new target_addr entry in the stream structure
9595 - MAJOR: stream: store the target address into s->target_addr
9596 - MINOR: peers: now remove the remote connection setup code
9597 - MEDIUM: lua: do not allocate the remote connection anymore
9598 - MEDIUM: backend: always release any existing prior connection in connect_server()
9599 - MEDIUM: backend: remove impossible cases from connect_server()
9600 - BUG/MINOR: mux-h1: Close server connection if input data remains in h1_detach()
9601 - BUG/MEDIUM: tcp-checks: do not dereference inexisting conn_stream
9602 - BUG/MINOR: http_ana: Be sure to have an allocated buffer to generate an error
9603 - BUG/MINOR: http_htx: Support empty errorfiles
9604 - BUG/CRITICAL: http_ana: Fix parsing of malformed cookies which start by a delimiter
9605 - BUG/MEDIUM: protocols: add a global lock for the init/deinit stuff
9606 - BUG/MINOR: proxy: always lock stop_proxy()
9607 - MEDIUM: mux-h1: Add the support of headers adjustment for bogus HTTP/1 apps
9608 - BUILD: threads: add the definition of PROTO_LOCK
9609 - BUG/MEDIUM: lb-chash: Fix the realloc() when the number of nodes is increased
9610 - BUG/MEDIUM: streams: Don't switch the SI to SI_ST_DIS if we have data to send.
9611 - BUG/MINOR: log: make sure writev() is not interrupted on a file output
9612 - DOC: improve the wording in CONTRIBUTING about how to document a bug fix
9613 - MEDIUM: h1: Don't try to subscribe if we managed to read data.
9614 - MEDIUM: h1: Don't wake the H1 tasklet if we got the whole request.
9615 - REGTESTS: checks: exclude freebsd target for tcp-check_multiple_ports.vtc
9616 - BUG/MINOR: hlua/htx: Reset channels analyzers when txn:done() is called
9617 - BUG/MEDIUM: hlua: Check the calling direction in lua functions of the HTTP class
9618 - MINOR: hlua: Don't set request analyzers on response channel for lua actions
9619 - MINOR: hlua: Add a flag on the lua txn to know in which context it can be used
9620 - BUG/MINOR: hlua: Only execute functions of HTTP class if the txn is HTTP ready
9621 - BUG/MINOR: htx: Fix free space addresses calculation during a block expansion
9622 - MINOR: ssl: merge ssl_sock_load_cert_file() and ssl_sock_load_cert_chain_file()
9623 - MEDIUM: ssl: use cert_key_and_chain struct in ssl_sock_load_cert_file()
9624 - MEDIUM: ssl: split the loading of the certificates
9625 - MEDIUM: ssl: lookup and store in a ckch_node tree
9626 - MEDIUM: ssl: load DH param in struct cert_key_and_chain
9627 - BUG/MAJOR: queue/threads: avoid an AB/BA locking issue in process_srv_queue()
9628 - MINOR: ssl: use STACK_OF for chain certs
9629 - MINOR: ssl: add extra chain compatibility
9630 - MINOR: ssl: check private key consistency in loading
9631 - MINOR: ssl: do not look at DHparam with OPENSSL_NO_DH
9632 - CLEANUP: ssl: ssl_sock_load_crt_file_into_ckch
9633 - MINOR: ssl: clean ret variable in ssl_sock_load_ckchn
9634 - MAJOR: fd: Get rid of the fd cache.
9635 - MEDIUM: pollers: Remember the state for read and write for each threads.
9636 - MEDIUM: mux-h2: don't try to read more than needed
9637 - BUG/BUILD: ssl: fix build with openssl < 1.0.2
9638 - BUG/MEDIUM: ssl: does not try to free a DH in a ckch
9639 - BUG/MINOR: debug: fix a small race in the thread dumping code
9640 - MINOR: wdt: also consider that waiting in the thread dumper is normal
9641 - REGTESTS: checks: make 4be_1srv_health_checks more reliable
9642 - BUILD: ssl: BoringSSL add EVP_PKEY_base_id
9643 - BUG/MEDIUM: ssl: don't free the ckch in multi-cert bundle
9644 - BUG/MINOR: ssl: fix ressource leaks on error
9645 - BUG/MEDIUM: lb-chash: Ensure the tree integrity when server weight is increased
9646 - BUG/MAJOR: http/sample: use a static buffer for raw -> htx conversion
9647 - BUG/MINOR: stream-int: make sure to always release empty buffers after sending
9648 - BUG/MEDIUM: ssl: open the right path for multi-cert bundle
9649 - BUG/MINOR: stream-int: also update analysers timeouts on activity
9650 - BUG/MEDIUM: mux-h2: unbreak receipt of large DATA frames
9651 - BUG/MEDIUM: mux-h2: split the stream's and connection's window sizes
9652 - BUG/MEDIUM: proxy: Make sure to destroy the stream on upgrade from TCP to H2
9653 - DOC: Add 'Question.md' issue template, discouraging asking questions
9654 - BUG/MEDIUM: fd: Always reset the polled_mask bits in fd_dodelete().
9655 - BUG/MEDIUM: pollers: Clear the poll_send bits as well.
9656 - BUILD: travis-ci: enable daily Coverity scan
9657 - BUG/MINOR: mux-h2: don't refrain from sending an RST_STREAM after another one
9658 - BUG/MINOR: mux-h2: use CANCEL, not STREAM_CLOSED in h2c_frt_handle_data()
9659 - BUG/MINOR: mux-h2: do not send REFUSED_STREAM on aborted uploads
9660 - BUG/MEDIUM: mux-h2: do not recheck a frame type after a state transition
9661 - BUG/MINOR: mux-h2: always send stream window update before connection's
9662 - BUG/MINOR: mux-h2: always reset rcvd_s when switching to a new frame
9663 - BUG/MEDIUM: checks: make sure to close nicely when we're the last to speak
9664 - BUG/MEDIUM: stick-table: Wrong stick-table backends parsing.
9665 - CLEANUP: mux-h2: move the demuxed frame check code in its own function
9666 - MINOR: cache: add method to cache hash
9667 - MINOR: cache: allow caching of OPTIONS request
9668 - BUG/MINOR: ssl: fix 0-RTT for BoringSSL
9669 - MINOR: ssl: ssl_fc_has_early should work for BoringSSL
9670 - BUG/MINOR: pools: don't mark the thread harmless if already isolated
9671 - BUG/MINOR: buffers/threads: always clear a buffer's head before releasing it
9672 - CLEANUP: buffer: replace b_drop() with b_free()
9673 - CLEANUP: task: move the cpu_time field to the task-only part
9674 - MINOR: cli: add two new states to print messages on the CLI
9675 - MINOR: cli: add cli_msg(), cli_err(), cli_dynmsg(), cli_dynerr()
9676 - CLEANUP: cli: replace all occurrences of manual handling of return messages
9677 - BUG/MEDIUM: proxy: Don't forget the SF_HTX flag when upgrading TCP=>H1+HTX.
9678 - BUG/MEDIUM: proxy: Don't use cs_destroy() when freeing the conn_stream.
9679 - BUG/MINOR: lua: fix setting netfilter mark
9680 - BUG/MINOR: Fix prometheus '# TYPE' and '# HELP' headers
9681 - BUG/MEDIUM: lua: Fix test on the direction to set the channel exp timeout
9682 - BUG/MINOR: stats: Wait the body before processing POST requests
9683 - MINOR: fd: make sure to mark the thread as not stuck in fd_update_events()
9684 - BUG/MEDIUM: mux_pt: Don't call unsubscribe if we did not subscribe.
9685 - BUILD: travis-ci: trigger non-mainstream configurations only on daily builds.
9686 - MINOR: debug: indicate the applet name when the task is task_run_applet()
9687 - MINOR: tools: add append_prefixed_str()
9688 - MINOR: lua: export applet and task handlers
9689 - MEDIUM: debug: make the thread dump code show Lua backtraces
9690 - BUG/MEDIUM: h1: Always try to receive more in h1_rcv_buf().
9691 - MINOR: list: add LIST_SPLICE() to merge one list into another
9692 - MINOR: tools: add a DEFNULL() macro to use NULL for empty args
9693 - REORG: trace: rename trace.c to calltrace.c and mention it's not thread-safe
9694 - MINOR: sink: create definitions a minimal code for event sinks
9695 - MINOR: sink: add a support for file descriptors
9696 - MINOR: trace: start to create a new trace subsystem
9697 - MINOR: trace: add allocation of buffer-sized trace buffers
9698 - MINOR: trace/cli: register the "trace" CLI keyword to list the sources
9699 - MINOR: trace/cli: parse the "level" argument to configure the trace verbosity
9700 - MINOR: trace/cli: add "show trace" to report trace state and statistics
9701 - MINOR: trace: implement a very basic trace() function
9702 - MINOR: trace: add the file name and line number in the prefix
9703 - MINOR: trace: make trace() now also take a level in argument
9704 - MINOR: trace: implement a call to a decode function
9705 - MINOR: trace: add per-level macros to produce traces
9706 - MINOR: trace: add a definition of typed arguments to trace()
9707 - MINOR: trace: make sure to always stop the locking when stopping or pausing
9708 - MINOR: trace: add the possibility to lock on some arguments
9709 - MINOR: trace: parse the "lock" argument to trace
9710 - MINOR: trace: retrieve useful pointers and enforce lock-on
9711 - DOC: management: document the "trace" and "show trace" commands
9712 - BUILD: trace: make the lockon_ptr const to silence a warning without threads
9713 - BUG/MEDIUM: mux-h1: do not truncate trailing 0CRLF on buffer boundary
9714 - BUG/MEDIUM: mux-h1: do not report errors on transfers ending on buffer full
9715 - DOC: fixed typo in management.txt
9716 - BUG/MINOR: mworker: disable SIGPROF on re-exec
9717 - BUG/MEDIUM: listener/threads: fix an AB/BA locking issue in delete_listener()
9718 - BUG/MEDIUM: url32 does not take the path part into account in the returned hash.
9719 - MINOR: backend: Add srv_queue converter
9720 - MINOR: sink: set the fd-type sinks to non-blocking
9721 - MINOR: tools: add a function varint_bytes() to report the size of a varint
9722 - MINOR: buffer: add functions to read/write varints from/to buffers
9723 - MINOR: fd: add fd_write_frag_line() to send a fragmented line to an fd
9724 - MINOR: sink: now call the generic fd write function
9725 - MINOR: ring: add a new mechanism for retrieving/storing ring data in buffers
9726 - MINOR: ring: add a ring_write() function
9727 - MINOR: ring: add a generic CLI io_handler to dump a ring buffer
9728 - MINOR: sink: add support for ring buffers
9729 - MINOR: sink: implement "show events" to show supported sinks and dump the rings
9730 - MINOR: sink: now report the number of dropped events on output
9731 - MINOR: trace: support a default callback for the source
9732 - MINOR: trace: extend the source location to 13 chars
9733 - MINOR: trace: show thread number and source name in the trace
9734 - MINOR: trace: change the TRACE() calling convention to put the args and cb last
9735 - MINOR: connection: add the fc_pp_authority fetch -- authority TLV, from PROXYv2
9736 - MINOR: tools: add a generic struct "name_desc" for name-description pairs
9737 - MINOR: trace: replace struct trace_lockon_args with struct name_desc
9738 - MINOR: trace: change the "payload" level to "data" and move it
9739 - MINOR: trace: prepend the function name for developer level traces
9740 - MINOR: trace: also report the trace level in the output
9741 - MINOR: trace: change the detail_level to per-source verbosity
9742 - MINOR: mux-h2/trace: register a new trace source with its events
9743 - MINOR: mux-h2/trace: add the default decoding callback
9744 - MEDIUM: mux-h2/trace: add lots of traces all over the code
9745 - MINOR: mux-h2: add functions to convert an h2c/h2s state to a string
9746 - MINOR: mux-h2/trace: add a new verbosity level "clean"
9747 - MINOR: mux-h2/trace: only decode the start-line at verbosity other than "minimal"
9748 - MINOR: mux-h2/trace: always report the h2c/h2s state and flags
9749 - MINOR: mux-h2/trace: report h2s->id before h2c->dsi for the stream ID
9750 - CLEANUP: mux-h2/trace: reformat the "received" messages for better alignment
9751 - CLEANUP: mux-h2/trace: lower-case event names
9752 - MINOR: trace: extend default event names to 12 chars
9753 - BUG/MINOR: ring: fix the way watchers are counted
9754 - MINOR: cli: extend the CLI context with a list and two offsets
9755 - MINOR: mux-h2/trace: report the connection pointer and state before FRAME_H
9756 - MEDIUM: ring: implement a wait mode for watchers
9757 - BUG/MEDIUM: mux-h2/trace: do not dereference h2c->conn after failed idle
9758 - BUG/MEDIUM: mux-h2/trace: fix missing braces added with traces
9759 - BUG/MINOR: ring: b_peek_varint() returns a uint64_t, not a size_t
9760 - CLEANUP: fd: remove leftovers of the fdcache
9761 - MINOR: fd: add a new "initialized" bit in the fdtab struct
9762 - MINOR: fd/log/sink: make the non-blocking initialization depend on the initialized bit
9763 - MEDIUM: log: use the new generic fd_write_frag_line() function
9764 - MINOR: log: add a target type instead of hacking the address family
9765 - MEDIUM: log: add support for logging to a ring buffer
9766 - MINOR: send-proxy-v2: sends authority TLV according to TLV received
9767 - MINOR: build: add linux-glibc-legacy build TARGET
9768 - BUG/MEDIUM: peers: local peer socket not bound.
9769 - BUILD: connection: silence gcc warning with extra parentheses
9770 - BUG/MINOR: http-ana: Reset response flags when 1xx messages are handled
9771 - BUG/MINOR: h1: Properly reset h1m when parsing is restarted
9772 - BUG/MINOR: mux-h1: Fix size evaluation of HTX messages after headers parsing
9773 - BUG/MINOR: mux-h1: Don't stop anymore input processing when the max is reached
9774 - BUG/MINOR: mux-h1: Be sure to update the count before adding EOM after trailers
9775 - BUG/MEDIUM: cache: Properly copy headers splitted on several shctx blocks
9776 - BUG/MEDIUM: cache: Don't cache objects if the size of headers is too big
9777 - BUG/MINOR: mux-h1: Fix a possible null pointer dereference in h1_subscribe()
9778 - MEDIUM: fd: remove the FD_EV_POLLED status bit
9779 - MEDIUM: fd: simplify the fd_*_{recv,send} functions using BTS/BTR
9780 - MINOR: fd: make updt_fd_polling() a normal function
9781 - CONTRIB: debug: add new program "poll" to test poll() events
9782 - BUG/MINOR: checks: stop polling for write when we have nothing left to send
9783 - BUG/MINOR: checks: start sending the request right after connect()
9784 - BUG/MINOR: checks: make __event_chk_srv_r() report success before closing
9785 - BUG/MINOR: checks: do not uselessly poll for reads before the connection is up
9786 - BUG/MINOR: mux-h1: Fix a UAF in cfg_h1_headers_case_adjust_postparser()
9787 - BUILD: CI: add basic CentOS 6 cirrus build
9788 - MINOR: contrib/prometheus-exporter: Report DRAIN/MAINT/NOLB status for servers
9789 - BUG/MINOR: lb/leastconn: ignore the server weights for empty servers
9790 - BUG/MAJOR: ssl: ssl_sock was not fully initialized.
9791 - MEDIUM: fd: mark the FD as ready when it's inserted
9792 - MINOR: fd: add two new calls fd_cond_{recv,send}()
9793 - MEDIUM: connection: enable reading only once the connection is confirmed
9794 - MINOR: fd: add two flags ERR and SHUT to describe FD states
9795 - MEDIUM: fd: do not use the FD_POLL_* flags in the pollers anymore
9796 - BUG/MEDIUM: connection: don't keep more idle connections than ever needed
9797 - MINOR: stats: report the number of idle connections for each server
9798 - BUILD: CI: skip reg-tests/connection/proxy_protocol_random_fail.vtc on CentOS 6
9799 - BUILD/MINOR: auth: enabling for osx
9800 - BUG/MINOR: listener: Fix a possible null pointer dereference
9801 - BUG/MINOR: ssl: always check for ssl connection before getting its XPRT context
9802 - MINOR: stats: Add JSON export from the stats page
9803 - BUG/MINOR: filters: Properly set the HTTP status code on analysis error
9804 - MINOR: sample: Add UUID-fetch
9805 - CLEANUP: mux-h2: Remove unused flag H2_SF_DATA_CHNK
9806 - BUG/MINOR: acl: Fix memory leaks when an ACL expression is parsed
9807 - BUG/MINOR: backend: Fix a possible null pointer dereference
9808 - BUG/MINOR: Missing stat_field_names (since f21d17bb)
9809 - BUG/MEDIUM: stick-table: Properly handle "show table" with a data type argument
9810 - BUILD: CI: temporarily disable ASAN
9811 - MINOR: htx: Add a flag on HTX message to report processing errors
9812 - MINOR: mux-h1: Report a processing error during output processing
9813 - MINOR: http-ana: Handle HTX errors first during message analysis
9814 - MINOR: http-ana: Remove err_state field from http_msg
9815 - MINOR: config: Support per-proxy and per-server deinit functions callbacks
9816 - MINOR: config: Support per-proxy and per-server post-check functions callbacks
9817 - MINOR: http_fetch: Add sample fetches to get auth method/user/pass
9818 - MINOR: istbuf: Add the function b_isteqi()
9819 - MINOR: log: Provide a function to emit a log for an application
9820 - MINOR: http: Add function to parse value of the header Status
9821 - MEDIUM: mux-h1/h1-htx: move HTX convertion of H1 messages in dedicated file
9822 - MINOR: h1-htx: Use the same function to copy message payload in all cases
9823 - MINOR: muxes/htx: Ignore pseudo header during message formatting
9824 - MINOR: fcgi: Add code related to FCGI protocol
9825 - MEDIUM: fcgi-app: Add FCGI application and filter
9826 - MEDIUM: mux-fcgi: Add the FCGI multiplexer
9827 - MINOR: doc: Add documentation about the FastCGI support
9828 - BUG/MINOR: build: Fix compilation of mux_fcgi.c when compiled without SSL
9829 - BUILD: CI: install golang-1.13 when building BoringSSL
9830 - BUG/MINOR: mux-h2: Be sure to have a connection to unsubcribe
9831 - BUG/MINOR: mux-fcgi: Be sure to have a connection to unsubcribe
9832 - CLEANUP: fcgi-app: Remove useless test on fcgi_conf pointer
9833 - BUG/MINOR: mux-fcgi: Don't compare the filter name in its parsing callback
9834 - BUG/MAJOR: mux-h2: Handle HEADERS frames received after a RST_STREAM frame
9835 - BUG/MEDIUM: check/threads: make external checks run exclusively on thread 1
9836 - MEDIUM: list: Separate "locked" list from regular list.
9837 - MINOR: mt_lists: Add new macroes.
9838 - MEDIUM: servers: Use LIST_DEL_INIT() instead of LIST_DEL().
9839 - MINOR: mt_lists: Do nothing in MT_LIST_ADD/MT_LIST_ADDQ if already in list.
9840 - MINOR: mt_lists: Give MT_LIST_ADD, MT_LIST_ADDQ and MT_LIST_DEL a return value.
9841 - MEDIUM: tasklets: Make the tasklet list a struct mt_list.
9842 - TESTS: Add a stress-test for mt_lists.
9843 - BUILD: travis-ci: add PCRE2, SLZ build
9844 - BUG/MINOR: build: fix event ports (Solaris)
9845 - BUG/MEDIUM: namespace: fix fd leak in master-worker mode
9846 - OPTIM: listeners: use tasklets for the multi-queue rings
9847 - BUILD: makefile: work around yet another GCC fantasy (-Wstring-plus-int)
9848 - BUG/MINOR: stream-int: Process connection/CS errors first in si_cs_send()
9849 - BUG/MEDIUM: stream-int: Process connection/CS errors during synchronous sends
9850 - BUG/MEDIUM: checks: make sure the connection is ready before trying to recv
9851 - CLEANUP: task: remove impossible test
9852 - CLEANUP: task: cache the task_per_thread pointer
9853 - MINOR: task: split the tasklet vs task code in process_runnable_tasks()
9854 - MINOR: task: introduce a thread-local "sched" variable for local scheduler stuff
9855 - CLEANUP: mux-fcgi: Remove the unused function fcgi_strm_id()
9856 - BUG/MINOR: mux-fcgi: Use a literal string as format in app_log()
9857 - BUG/MEDIUM: tasklets: Make sure we're waking the target thread if it sleeps.
9858 - MINOR: h2/trace: indicate 'F' or 'B' to locate the side of an h2c in traces
9859 - MINOR: h2/trace: report the frame type when known
9860 - BUG/MINOR: mux-h2: do not wake up blocked streams before the mux is ready
9861 - BUG/MEDIUM: namespace: close open namespaces during soft shutdown
9862 - MINOR: time: add timeofday_as_iso_us() to return instant time as ISO
9863 - MINOR: sink: finally implement support for SINK_FMT_{TIMED,ISO}
9864 - MINOR: sink: change ring buffer "buf0"'s format to "timed"
9865 - BUG/MEDIUM: mux-h2: don't reject valid frames on closed streams
9866 - BUG/MINOR: mux-fcgi: silence a gcc warning about null dereference
9867 - BUG/MINOR: mux-h2: Fix missing braces because of traces in h2_detach()
9868 - BUG/MINOR: mux-h2: Use the dummy error when decoding headers for a closed stream
9869 - BUG/MAJOR: mux_h2: Don't consume more payload than received for skipped frames
9870 - BUG/MINOR: mux-h1: Do h2 upgrade only on the first request
9871 - BUG/MEDIUM: spoe: Use a different engine-id per process
9872 - MINOR: spoe: Improve generation of the engine-id
9873 - MINOR: spoe: Support the async mode with several threads
9874 - MINOR: http: Add server name header from HTTP multiplexers
9875 - CLEANUP: http-ana: Remove the unused function http_send_name_header()
9876 - MINOR: stats: Add the support of float fields in stats
9877 - BUG/MINOR: contrib/prometheus-exporter: Return the time averages in seconds
9878 - DOC: Fix documentation about the cli command to get resolver stats
9879 - BUG/MEDIUM: fcgi: fix missing list tail in sample fetch registration
9880 - BUG/MINOR: stats: Add a missing break in a switch statement
9881 - BUG/MINOR: lua: Properly initialize the buffer's fields for string samples in hlua_lua2(smp|arg)
9882 - CLEANUP: lua: Get rid of obsolete (size_t *) cast in hlua_lua2(smp|arg)
9883 - BUG/MEDIUM: lua: Store stick tables into the sample's `t` field
9884 - CLEANUP: proxy: Remove `proxy_tbl_by_name`
9885 - BUILD: ssl: fix a warning when built with openssl < 1.0.2
9886 - DOC: replace utf-8 quotes by ascii ones
9887 - BUG/MEDIUM: fd: HUP is an error only when write is active
9888 - BUG/MINOR: action: do-resolve does not yield on requests with body
9889 - Revert "MINOR: cache: allow caching of OPTIONS request"
9890
Willy Tarreaudb514072019-07-16 19:15:28 +020098912019/07/16 : 2.1-dev1
9892 - BUG/MEDIUM: h2/htx: Update data length of the HTX when the cookie list is built
9893 - DOC: this is a development branch again.
9894 - MEDIUM: Make 'block' directive fatal
9895 - MEDIUM: Make 'redispatch' directive fatal
9896 - MEDIUM: Make '(cli|con|srv)timeout' directive fatal
9897 - MEDIUM: Remove 'option independant-streams'
9898 - MINOR: sample: Add sha2([<bits>]) converter
9899 - MEDIUM: server: server-state global file stored in a tree
9900 - BUG/MINOR: lua/htx: Make txn.req_req_* and txn.res_rep_* HTX aware
9901 - BUG/MINOR: mux-h1: Add the header connection in lower case in outgoing messages
9902 - BUG/MEDIUM: compression: Set Vary: Accept-Encoding for compressed responses
9903 - MINOR: htx: Add the function htx_change_blk_value_len()
9904 - BUG/MEDIUM: htx: Fully update HTX message when the block value is changed
9905 - BUG/MEDIUM: mux-h2: Reset padlen when several frames are demux
9906 - BUG/MEDIUM: mux-h2: Remove the padding length when a DATA frame size is checked
9907 - BUG/MEDIUM: lb_fwlc: Don't test the server's lb_tree from outside the lock
9908 - BUG/MAJOR: sample: Wrong stick-table name parsing in "if/unless" ACL condition.
9909 - BUILD: mworker: silence two printf format warnings around getpid()
9910 - BUILD: makefile: use :space: instead of digits to count commits
9911 - BUILD: makefile: adjust the sed expression of "make help" for solaris
9912 - BUILD: makefile: do not rely on shell substitutions to determine git version
9913 - BUG/MINOR: mworker-prog: Fix segmentation fault during cfgparse
9914 - BUG/MINOR: spoe: Fix memory leak if failing to allocate memory
9915 - BUG/MEDIUM: mworker: don't call the thread and fdtab deinit
9916 - BUG/MEDIUM: stream_interface: Don't add SI_FL_ERR the state is < SI_ST_CON.
9917 - BUG/MEDIUM: connections: Always add the xprt handshake if needed.
9918 - BUG/MEDIUM: ssl: Don't do anything in ssl_subscribe if we have no ctx.
9919 - BUG/MEDIUM: mworker/cli: command pipelining doesn't work anymore
9920 - BUG/MINOR: htx: Save hdrs_bytes when the HTX start-line is replaced
9921 - BUG/MAJOR: mux-h1: Don't crush trash chunk area when outgoing message is formatted
9922 - BUG/MINOR: memory: Set objects size for pools in the per-thread cache
9923 - BUG/MINOR: log: Detect missing sampling ranges in config
9924 - BUG/MEDIUM: proto_htx: Don't add EOM on 1xx informational messages
9925 - BUG/MEDIUM: mux-h1: Use buf_room_for_htx_data() to detect too large messages
9926 - BUG/MINOR: mux-h1: Make format errors during output formatting fatal
9927 - BUG/MEDIUM: ssl: Don't attempt to set alpn if we're not using SSL.
9928 - BUG/MEDIUM: mux-h1: Always release H1C if a shutdown for writes was reported
9929 - BUG/MINOR: mworker/cli: don't output a \n before the response
9930 - BUG/MEDIUM: checks: unblock signals in external checks
9931 - BUG/MINOR: mux-h1: Skip trailers for non-chunked outgoing messages
9932 - BUG/MINOR: mux-h1: Don't return the empty chunk on HEAD responses
9933 - BUG/MEDIUM: connections: Always call shutdown, with no linger.
9934 - BUG/MEDIUM: checks: Make sure the tasklet won't run if the connection is closed.
9935 - BUG/MINOR: contrib/prometheus-exporter: Don't use channel_htx_recv_max()
9936 - BUG/MINOR: hlua: Don't use channel_htx_recv_max()
9937 - BUG/MEDIUM: channel/htx: Use the total HTX size in channel_htx_recv_limit()
9938 - BUG/MINOR: hlua/htx: Respect the reserve when HTX data are sent
9939 - BUG/MINOR: contrib/prometheus-exporter: Respect the reserve when data are sent
9940 - BUG/MEDIUM: connections: Make sure we're unsubscribe before upgrading the mux.
9941 - BUG/MEDIUM: servers: Authorize tfo in default-server.
9942 - BUG/MEDIUM: sessions: Don't keep an extra idle connection in sessions.
9943 - MINOR: server: Add "no-tfo" option.
9944 - BUG/MINOR: contrib/prometheus-exporter: Don't try to add empty data blocks
9945 - MINOR: action: Add the return code ACT_RET_DONE for actions
9946 - BUG/MEDIUM: http/applet: Finish request processing when a service is registered
9947 - BUG/MEDIUM: lb_fas: Don't test the server's lb_tree from outside the lock
9948 - BUG/MEDIUM: mux-h1: Handle TUNNEL state when outgoing messages are formatted
9949 - BUG/MINOR: mux-h1: Don't process input or ouput if an error occurred
9950 - MINOR: stream-int: Factorize processing done after sending data in si_cs_send()
9951 - BUG/MEDIUM: stream-int: Don't rely on CF_WRITE_PARTIAL to unblock opposite si
9952 - DOC: contrib: spoa_server Add some hints for building spoa_server
9953 - DOC: Fix typo in intro.txt
9954 - BUG/MEDIUM: servers: Don't forget to set srv_cs to NULL if we can't reuse it.
9955 - BUG/MINOR: ssl: revert empty handshake detection in OpenSSL <= 1.0.2
9956 - MINOR: pools: release the pool's lock during the malloc/free calls
9957 - MINOR: pools: always pre-initialize allocated memory outside of the lock
9958 - MINOR: pools: make the thread harmless during the mmap/munmap syscalls
9959 - BUG/MEDIUM: fd/threads: fix excessive CPU usage on multi-thread accept
9960 - BUG/MINOR: server: Be really able to keep "pool-max-conn" idle connections
9961 - BUG/MEDIUM: checks: Don't attempt to read if we destroyed the connection.
9962 - BUG/MEDIUM: da: cast the chunk to string.
9963 - DOC: Fix typos and grammer in configuration.txt
9964 - CLEANUP: proto_tcp: Remove useless header inclusions.
9965 - BUG/MEDIUM: servers: Fix a race condition with idle connections.
9966 - MINOR: task: introduce work lists
9967 - BUG/MAJOR: listener: fix thread safety in resume_listener()
9968 - BUG/MEDIUM: mux-h1: Don't release h1 connection if there is still data to send
9969 - BUG/MINOR: mux-h1: Correctly report Ti timer when HTX and keepalives are used
9970 - BUG/MEDIUM: streams: Don't give up if we couldn't send the request.
9971 - BUG/MEDIUM: streams: Don't redispatch with L7 retries if redispatch isn't set.
9972 - BUG/MINOR: mux-pt: do not pretend there's more data after a read0
9973 - BUG/MEDIUM: tcp-check: unbreak multiple connect rules again
9974 - MEDIUM: mworker-prog: Add user/group options to program section
9975 - REGTESTS: checks: tcp-check connect to multiple ports
9976 - BUG/MEDIUM: threads: cpu-map designating a single thread/process are ignored
9977
Willy Tarreau9dc6b972019-06-16 21:49:47 +020099782019/06/16 : 2.1-dev0
9979 - exact copy of 2.0.0
9980
Willy Tarreauba236302019-06-16 20:00:26 +020099812019/06/16 : 2.0.0
9982 - MINOR: fd: Don't use atomic operations when it's not needed.
9983 - DOC: mworker-prog: documentation for the program section
9984 - MINOR: http: add a new "http-request replace-uri" action
9985 - BUG/MINOR: 51d/htx: The _51d_fetch method, and the methods it calls are now HTX aware.
9986 - MINOR: 51d: Added dummy libraries for the 51Degrees module for testing.
9987 - MINOR: mworker: change formatting in uptime field of "show proc"
9988 - MINOR: mworker: add the HAProxy version in "show proc"
9989 - MINOR: doc: Remove -Ds option in man page
9990 - MINOR: doc: add master-worker in the man page
9991 - MINOR: doc: mention HAPROXY_LOCALPEER in the man
9992 - BUILD: Silence gcc warning about unused return value
9993 - CLEANUP: 51d: move the 51d dummy lib to contrib/51d/src to match the real lib
9994 - BUILD: travis-ci: add 51Degree device detection, update openssl to 1.1.1c
9995 - MINOR: doc: update the manpage and usage message about -S
9996 - BUILD/MINOR: 51d: Updated build registration output to indicate thatif the library is a dummy one or not.
9997 - BUG/MEDIUM: h1: Don't wait for handshake if we had an error.
9998 - BUG/MEDIUM: h1: Wait for the connection if the handshake didn't complete.
9999 - BUG/MINOR: task: prevent schedulable tasks from starving under high I/O activity
10000 - BUG/MINOR: fl_trace/htx: Be sure to always forward trailers and EOM
10001 - BUG/MINOR: channel/htx: Call channel_htx_full() from channel_full()
10002 - BUG/MINOR: http: Use the global value to limit the number of parsed headers
10003 - BUG/MINOR: htx: Detect when tail_addr meet end_addr to maximize free rooms
10004 - BUG/MEDIUM: htx: Don't change position of the first block during HTX analysis
10005 - CLEANUP: channel: Remove channel_htx_fwd_payload() and channel_htx_fwd_all()
10006 - BUG/MEDIUM: proto_htx: Introduce the state ENDING during forwarding
10007 - MINOR: htx: Add 3 flags on the start-line to deal with the request schemes
10008 - MINOR: h2: Set flags about the request's scheme on the start-line
10009 - MINOR: mux-h1: Set flags about the request's scheme on the start-line
10010 - MINOR: mux-h2: Forward clients scheme to servers checking start-line flags
10011 - MEDIUM: server: server-state only rely on server name
10012 - CLEANUP: connection: rename the wait_event.task field to .tasklet
10013 - CLEANUP: tasks: rename task_remove_from_tasklet_list() to tasklet_remove_*
10014 - BUG/MEDIUM: connections: Don't call shutdown() if we want to disable linger.
10015 - DOC: add some environment variables in section 2.3
10016 - BUILD: makefile: clarify the "help" output and list options
10017 - BUG/MINOR: mux-h1: Wake busy mux for I/O when message is fully sent
10018 - BUG: tasks: fix bug introduced by latest scheduler cleanup
10019 - BUG/MEDIUM: mux-h2: fix early close with option abortonclose
10020 - BUG/MEDIUM: connections: Don't use ALPN to pick mux when in mode TCP.
10021 - BUG/MEDIUM: connections: Don't try to send early data if we have no mux.
10022 - BUG/MEDIUM: mux-h2: properly account for the appended data in HTX
10023 - BUILD: makefile: further clarify the "help" output and list targets
10024 - BUILD: makefile: rename "linux2628" to "linux-glibc" and remove older targets
10025 - BUILD: travis-ci: switch to linux-glibc instead of linux2628
10026 - DOC: update few references to the linux* targets and change them to linux-glibc
10027 - BUILD: makefile: detect and reject recently removed linux targets
10028 - BUILD: makefile: enable linux namespaces by default on linux
10029 - BUILD: makefile: enable TFO on linux platforms
10030 - BUILD: makefile: enable getaddrinfo on the linux-glibc target
10031 - DOC: small updates to the CONTRIBUTING file
10032 - BUG/MEDIUM: ssl: Make sure we initiate the handshake after using early data.
10033 - CLEANUP: removed obsolete examples an move a few to better places
10034 - DOC: Fix typos in CONTRIBUTING
10035 - DOC: update the outdated ROADMAP file
10036 - DOC: create a BRANCHES file to explain the life cycle
10037 - DOC: mention in INSTALL haproxy 2.0 is a long-term supported stable version
10038 - BUILD: travis-ci: TFO and GETADDRINFO are now enabled by default
10039 - BUILD: makefile: make the obsolete target detection compatible with make-3.80
10040 - BUILD: tools: work around an internal compiler bug in gcc-3.4
10041 - BUILD: pattern: work around an internal compiler bug in gcc-3.4
10042 - BUILD: makefile: enable USE_RT on Solaris
10043 - BUILD: makefile: do not use echo -n
10044 - DOC: mention a few common build errors in the INSTALL file
10045
Willy Tarreauca3551f2019-06-11 19:28:00 +0200100462019/06/11 : 2.0-dev7
10047 - BUG/MEDIUM: mux-h2: make sure the connection timeout is always set
10048 - MINOR: tools: add new bitmap manipulation functions
10049 - MINOR: logs: use the new bitmap functions instead of fd_sets for encoding maps
10050 - MINOR: chunks: Make sure trash_size is only set once.
10051 - Revert "MINOR: chunks: Make sure trash_size is only set once."
10052 - MINOR: threads: serialize threads initialization
10053 - MINOR peers: data structure simplifications for server names dictionary cache.
10054 - DOC: peers: Update for dictionary cache entries for peers protocol.
10055 - MINOR: dict: Store the length of the dictionary entries.
10056 - MINOR: peers: A bit of optimization when encoding cached server names.
10057 - MINOR: peers: Optimization for dictionary cache lookup.
10058 - MEDIUM: tools: improve time format error detection
10059 - BUG/MEDIUM: H1: When upgrading, make sure we don't free the buffer too early.
10060 - BUG/MEDIUM: stream_interface: Make sure we call si_cs_process() if CS_FL_EOI.
10061 - MINOR: threads: avoid clearing harmless twice in thread_release()
10062 - MEDIUM: threads: add thread_sync_release() to synchronize steps
10063 - BUG/MEDIUM: init/threads: prevent initialized threads from starting before others
10064 - OPTIM/MINOR: init/threads: only call protocol_enable_all() on first thread
10065 - BUG/MINOR: dict: race condition fix when inserting dictionary entries.
10066 - MEDIUM: init/threads: don't use spinlocks during the init phase
10067 - BUG/MINOR: cache/htx: Fix the counting of data already sent by the cache applet
10068 - BUG/MEDIUM: compression/htx: Fix the adding of the last data block
10069 - MINOR: flt_trace: Don't scrash the original offset during the random forwarding
10070 - MAJOR: htx: Rework how free rooms are tracked in an HTX message
10071 - MINOR: htx: Add the function htx_move_blk_before()
10072 - Revert "BUG/MEDIUM: H1: When upgrading, make sure we don't free the buffer too early."
10073 - BUG/MINOR: http-rules: mention "deny_status" for "deny" in the error message
10074 - MINOR: http: turn default error files to HTTP/1.1
10075 - BUG/MEDIUM: h1: Don't try to subscribe if we had a connection error.
10076 - BUG/MEDIUM: h1: Don't consider we're connected if the handshake isn't done.
10077 - MINOR: contrib/spoa_server: Upgrade SPOP to 2.0
10078 - BUG/MEDIUM: contrib/spoa_server: Set FIN flag on agent frames
10079 - MINOR: contrib/spoa_server: Add random IP score
10080 - DOC/MINOR: contrib/spoa_server: Fix typo in README
10081
Willy Tarreaub57f1092019-06-07 06:12:59 +0200100822019/06/07 : 2.0-dev6
10083 - BUG/MEDIUM: connection: fix multiple handshake polling issues
10084 - MINOR: connection: also stop receiving after a SOCKS4 response
10085 - MINOR: mux-h1: don't try to recv() before the connection is ready
10086 - BUG/MEDIUM: mux-h1: only check input data for the current stream, not next one
10087 - MEDIUM: mux-h1: don't use CS_FL_REOS anymore
10088 - CLEANUP: connection: remove the now unused CS_FL_REOS flag
10089 - CONTRIB: debug: add 4 missing connection/conn_stream flags
10090 - MEDIUM: stream: make a full process_stream() loop when completing I/O on exit
10091 - MINOR: server: increase the default pool-purge-delay to 5 seconds
10092 - BUILD: tools: do not use the weak attribute for trace() on obsolete linkers
10093 - BUG/MEDIUM: vars: make sure the scope is always valid when accessing vars
10094 - BUG/MEDIUM: vars: make the tcp/http unset-var() action support conditions
10095 - BUILD: task: fix a build warning when threads are disabled
10096 - CLEANUP: peers: Remove tabs characters.
10097 - CLEANUP: peers: Replace hard-coded values by macros.
10098 - BUG/MINOR: peers: Wrong stick-table update message building.
10099 - MINOR: dict: Add dictionary new data structure.
10100 - MINOR: peers: Add a LRU cache implementation for dictionaries.
10101 - MINOR: stick-table: Add "server_name" new data type.
10102 - MINOR: cfgparse: Space allocation for "server_name" stick-table data type.
10103 - MINOR: proxy: Add a "server by name" tree to proxy.
10104 - MINOR: server: Add a dictionary for server names.
10105 - MINOR: stream: Stickiness server lookup by name.
10106 - MINOR: peers: Make peers protocol support new "server_name" data type.
10107 - MINOR: stick-table: Make the CLI stick-table handler support dictionary entry data type.
10108 - REGTEST: Add a basic server by name stickiness reg test.
10109 - MINOR: peers: Add dictionary cache information to "show peers" CLI command.
10110 - MINOR: peers: Replace hard-coded for peer protocol 64-bits value encoding by macros.
10111 - MINOR: peers: Replace hard-coded values for peer protocol messaging by macros.
10112 - CLEANUP: ssl: remove unneeded defined(OPENSSL_IS_BORINGSSL)
10113 - BUILD: travis-ci improvements
10114 - MINOR: SSL: add client/server random sample fetches
10115 - BUG/MINOR: channel/htx: Don't alter channel during forward for empty HTX message
10116 - BUG/MINOR: contrib/prometheus-exporter: Add HTX data block in one time
10117 - BUG/MINOR: mux-h1: errflag must be set on H1S and not H1M during output processing
10118 - MEDIUM: mux-h1: refactor output processing
10119 - MINOR: mux-h1: Add the flag HAVE_O_CONN on h1s
10120 - MINOR: mux-h1: Add h1_eval_htx_hdrs_size() to estimate size of the HTX headers
10121 - MINOR: mux-h1: Don't count the EOM in the estimated size of headers
10122 - MEDIUM: cache/htx: Always store info about HTX blocks in the cache
10123 - MEDIUM: htx: Add the parsing of trailers of chunked messages
10124 - MINOR: htx: Don't use end-of-data blocks anymore
10125 - BUG/MINOR: mux-h1: Don't send more data than expected
10126 - BUG/MINOR: flt_trace/htx: Only apply the random forwarding on the message body.
10127 - BUG/MINOR: peers: Wrong "server_name" decoding.
10128 - BUG/MEDIUM: servers: Don't attempt to destroy idle connections if disabled.
10129 - MEDIUM: checks: Make sure we unsubscribe before calling cs_destroy().
10130 - MEDIUM: connections: Wake the upper layer even if sending/receiving is disabled.
10131 - MEDIUM: ssl: Handle subscribe by itself.
10132 - MINOR: ssl: Make ssl_sock_handshake() static.
10133 - MINOR: connections: Add a new xprt method, remove_xprt.
10134 - MINOR: connections: Add a new xprt method, add_xprt().
10135 - MEDIUM: connections: Introduce a handshake pseudo-XPRT.
10136 - MEDIUM: connections: Remove CONN_FL_SOCK*
10137 - BUG/MEDIUM: ssl: Don't forget to initialize ctx->send_recv and ctx->recv_wait.
10138 - BUG/MINOR: peers: Wrong server name parsing.
10139 - MINOR: server: really increase the pool-purge-delay default to 5 seconds
10140 - BUG/MINOR: stream: don't emit a send-name-header in conn error or disconnect states
10141 - MINOR: stream-int: use bit fields to match multiple stream-int states at once
10142 - MEDIUM: stream-int: remove dangerous interval checks for stream-int states
10143 - MEDIUM: stream-int: introduce a new state SI_ST_RDY
10144 - MAJOR: stream-int: switch from SI_ST_CON to SI_ST_RDY on I/O
10145 - MEDIUM: stream-int: make idle-conns switch to ST_RDY
10146 - MEDIUM: stream: re-arrange the connection setup status reporting
10147 - MINOR: stream-int: split si_update() into si_update_rx() and si_update_tx()
10148 - MINOR: stream-int: make si_sync_send() from the send code of si_update_both()
10149 - MEDIUM: stream: rearrange the events to remove the loop
10150 - MEDIUM: stream: only loop on flags relevant to the analysers
10151 - MEDIUM: stream: don't abusively loop back on changes on CF_SHUT*_NOW
10152 - BUILD: stream-int: avoid a build warning in dev mode in si_state_bit()
10153 - BUILD: peers: fix a build warning about an incorrect intiialization
10154 - BUG/MINOR: time: make sure only one thread sets global_now at boot
10155 - BUG/MEDIUM: tcp: Make sure we keep the polling consistent in tcp_probe_connect.
10156
Willy Tarreauabc874e2019-06-02 12:06:08 +0200101572019/06/02 : 2.0-dev5
10158 - BUILD: watchdog: use si_value.sival_int, not si_int for the timer's value
10159 - BUILD: signals: FreeBSD has SI_LWP instead of SI_TKILL
10160 - BUILD: watchdog: condition it to USE_RT
10161 - MINOR: raw_sock: report global traffic statistics
10162 - MINOR: stats: report the global output bit rate in human readable form
10163 - BUG/MINOR: proto-htx: Try to keep connections alive on redirect
10164 - BUG/MEDIUM: spoe: Don't use the SPOE applet after releasing it
10165 - BUG/MINOR: lua: Set right direction and flags on new HTTP objects
10166 - BUG/MINOR: mux-h2: Count EOM in bytes sent when a HEADERS frame is formatted
10167 - BUG/MINOR: mux-h1: Report EOI instead EOS on parsing error or H2 upgrade
10168 - BUG/MEDIUM: proto-htx: Not forward too much data when 1xx reponses are handled
10169 - BUG/MINOR: htx: Remove a forgotten while loop in htx_defrag()
10170 - DOC: fix typos
10171 - BUG/MINOR: ssl_sock: Fix memory leak when disabling compression
10172 - OPTIM: freq-ctr: don't take the date lock for most updates
10173 - MEDIUM: mux-h2: avoid doing expensive buffer realigns when not absolutely needed
10174 - CLEANUP: debug: remove the TRACE() macro
10175 - MINOR: buffer: introduce b_make() to make a buffer from its parameters
10176 - MINOR: buffer: add a new buffer ring API to manipulate rings of buffers
10177 - MEDIUM: mux-h2: replace all occurrences of mbuf with a buffer ring
10178 - MEDIUM: mux-h2: make the conditions to send based on mbuf, not just its tail
10179 - MINOR: mux-h2: introduce h2_release_mbuf() to release all buffers in the mbuf ring
10180 - MEDIUM: mux-h2: make the send() function iterate over all mux buffers
10181 - CLEANUP: mux-h2: consistently use a local variable for the mbuf
10182 - MINOR: mux-h2: report the mbuf's head and tail in "show fd"
10183 - MAJOR: mux-h2: switch to next mux buffer on buffer full condition.
10184 - BUILD: connections: shut up gcc about impossible out-of-bounds warning
10185 - BUILD: ssl: fix latest LibreSSL reg-test error
10186 - MINOR: cli/activity: remove "fd_del" and "fd_skip" from show activity
10187 - MINOR: cli/activity: add 3 general purpose counters in development mode
10188 - BUG/MAJOR: lb/threads: make sure the avoided server is not full on second pass
10189 - BUG/MEDIUM: queue: fix the tree walk in pendconn_redistribute.
10190 - BUG/MEDIUM: threads: fix double-word CAS on non-optimized 32-bit platforms
10191 - MEDIUM: config: now alert when two servers have the same name
10192 - MINOR: htx: Remove the macro IS_HTX_SMP() and always use IS_HTX_STRM() instead
10193 - MINOR: htx: Move the macro IS_HTX_STRM() in proto/stream.h
10194 - MINOR: htx: Store the head position instead of the wrap one
10195 - MINOR: htx: Store start-line block's position instead of address of its payload
10196 - MINOR: htx: Add functions to get the first block of an HTX message
10197 - MINOR: mux-h2/htx: Get the start-line from the head when HEADERS frame is built
10198 - MINOR: htx: Replace the function http_find_stline() by http_get_stline()
10199 - CLEANUP: htx: Remove unused function htx_get_stline()
10200 - MINOR: http/htx: Use sl_pos directly to replace the start-line
10201 - MEDIUM: http/htx: Perform analysis relatively to the first block
10202 - MINOR: channel/htx: Call channel_htx_recv_max() from channel_recv_max()
10203 - MINOR: htx: Add function htx_get_max_blksz()
10204 - BUG/MINOR: htx: Change htx_xfer_blk() to also count metadata
10205 - MEDIUM: mux-h1: Use the count value received from the SI in h1_rcv_buf()
10206 - MINOR: mux-h2: Use the count value received from the SI in h2_rcv_buf()
10207 - MINOR: stream-int: Don't use the flag CO_RFL_KEEP_RSV anymore in si_cs_recv()
10208 - MINOR: connection: Remove the unused flag CO_RFL_KEEP_RSV
10209 - MINOR: mux-h2/htx: Support zero-copy when possible in h2_rcv_buf()
10210 - MINOR: htx: Add a field to set the memory used by headers in the HTX start-line
10211 - MINOR: h2/htx: Set hdrs_bytes on the SL when an HTX message is produced
10212 - MINOR: mux-h1: Set hdrs_bytes on the SL when an HTX message is produced
10213 - MINOR: htx: Be sure to xfer all headers in one time in htx_xfer_blks()
10214 - MEDIUM: htx: 1xx messages are now part of the final reponses
10215 - MINOR: channel/htx: Add function to forward headers of an HTX message
10216 - MINOR: filters/htx: Use channel_htx_fwd_headers() after headers filtering
10217 - MINOR: proto-htx: Use channel_htx_fwd_headers() to forward 1xx responses
10218 - MEDIUM: htx: Store the first block position instead of the start-line one
10219 - MINOR: stats/htx: don't use the first block position but the head one
10220 - MINOR: channel/htx: Add functions to forward a part or all HTX payload
10221 - MINOR: proto-htx: Use channel_htx_fwd_all() when unfiltered body are forwarded
10222 - MEDIUM: filters/htx: Filter body relatively to the first block
10223 - MINOR: htx: Optimize htx_drain() when all data are drained
10224 - MINOR: htx: don't rely on htx_find_blk() anymore in the function htx_truncate()
10225 - MINOR: htx: remove the unused function htx_find_blk()
10226 - MINOR: htx: Remove support of pseudo headers because it is unused
10227 - BUG/MEDIUM: http: fix "http-request reject" when not final
10228 - MINOR: ssl: Make sure the underlying xprt's init method doesn't fail.
10229 - MINOR: ssl: Don't forget to call the close method of the underlying xprt.
10230 - MINOR: htx: rename htx_append_blk_value() to htx_add_data_atonce()
10231 - MINOR: htx: make htx_add_data() return the transmitted byte count
10232 - MEDIUM: htx: make htx_add_data() never defragment the buffer
10233 - MINOR: activity: write totals on the "show activity" output
10234 - MINOR: activity: report totals and average separately
10235 - MEDIUM: poller: separate the wait time from the wake events
10236 - MINOR: activity: report the number of failed pool/buffer allocations
10237 - MEDIUM: buffers: relax the buffer lock a little bit
10238 - MINOR: task: turn the WQ lock to an RW_LOCK
10239 - MEDIUM: task: don't grab the WR lock just to check the WQ
10240 - BUG/MEDIUM: mux-h1: Don't skip the TCP splicing when there is no more data to read
10241 - MEDIUM: sessions: Introduce session flags.
10242 - BUG/MEDIUM: h2: Don't forget to set h2s->cs to NULL after having free'd cs.
10243 - BUG/MEDIUM: mux-h2: fix the conditions to end the h2_send() loop
10244 - BUG/MEDIUM: mux-h2: don't refrain from offering oneself a used buffer
10245 - BUG/MEDIUM: connection: Use the session to get the origin address if needed.
10246 - MEDIUM: tasks: Get rid of active_tasks_mask.
10247 - MEDIUM: connection: Upstream SOCKS4 proxy support
10248 - BUILD: contrib/prometheus: fix build breakage caused by move of idle_pct
10249 - BUG/MINOR: deinit/threads: make hard-stop-after perform a clean exit
10250
Willy Tarreau56740692019-05-22 20:48:33 +0200102512019/05/22 : 2.0-dev4
10252 - BUILD: enable freebsd builds on cirrus-ci
10253 - BUG/MINOR: http_fetch: Rely on the smp direction for "cookie()" and "hdr()"
10254 - MEDIUM: Make 'option forceclose' actually warn
10255 - MEDIUM: Make 'resolution_pool_size' directive fatal
10256 - DOC: management: place "show activity" at the right place
10257 - MINOR: cli/activity: show the dumping thread ID starting at 1
10258 - MINOR: task: export global_task_mask
10259 - MINOR: cli/debug: add a thread dump function
10260 - BUG/MEDIUM: streams: Don't use CF_EOI to decide if the request is complete.
10261 - BUG/MEDIUM: streams: Try to L7 retry before aborting the connection.
10262 - BUG/MINOR: debug: make ha_task_dump() always check the task before dumping it
10263 - BUG/MINOR: debug: make ha_task_dump() actually dump the requested task
10264 - MINOR: debug: make ha_thread_dump() and ha_task_dump() take a buffer
10265 - BUG/MINOR: debug: don't check the call date on tasklets
10266 - MINOR: thread: implement ha_thread_relax()
10267 - MINOR: task: put barriers after each write to curr_task
10268 - MINOR: task: always reset curr_task when freeing a task or tasklet
10269 - MINOR: stream: detach the stream from its own task on stream_free()
10270 - MEDIUM: debug/threads: implement an advanced thread dump system
10271 - REGTEST: extend the check duration on tls_health_checks and mark it slow
10272 - DOC: fix "successful" typo
10273 - MINOR: init: setenv HAPROXY_CFGFILES
10274 - MINOR: threads/init: synchronize the threads startup
10275 - MEDIUM: init/mworker: make the pipe register function a regular initcall
10276 - CLEANUP: memory: make the fault injection code use the OTHER_LOCK label
10277 - CLEANUP: threads: remove the now unused START_LOCK label
10278 - MINOR: init/threads: make the global threads an array of structs
10279 - MINOR: threads: add each thread's clockid into the global thread_info
10280 - CLEANUP: stream: remove an obsolete debugging test
10281 - MINOR: tools: add dump_hex()
10282 - MINOR: debug: implement ha_panic()
10283 - MINOR: debug/cli: add some debugging commands for developers
10284 - MINOR: tools: provide a may_access() function and make dump_hex() use it
10285 - MINOR: debug: make ha_panic() report threads starting at 1
10286 - REORG: compat: move some integer limit definitions from standard.h to compat.h
10287 - REORG: threads: move the struct thread_info from global.h to hathreads.h
10288 - MINOR: compat: make sure to always define clockid_t
10289 - MINOR: threads: always place the clockid in the struct thread_info
10290 - MINOR: threads: add a thread-local thread_info pointer "ti"
10291 - MINOR: time: move the cpu, mono, and idle time to thread_info
10292 - MINOR: time: add a function to retrieve another thread's cputime
10293 - MINOR: debug: report each thread's cpu usage in "show thread"
10294 - BUILD: threads: only assign the clock_id when supported
10295 - BUILD: makefile: use USE_OBSOLETE_LINKER for solaris
10296 - BUILD: makefile: remove -fomit-frame-pointer optimisation (solaris)
10297 - MAJOR: polling: add event ports support (Solaris)
10298 - BUG/MEDIUM: streams: Don't switch from SI_ST_CON to SI_ST_DIS on read0.
10299 - CLEANUP: time: refine the test on _POSIX_TIMERS
10300 - MINOR: compat: define a new empty type empty_t for non-implemented fields
10301 - CLEANUP: time: switch clockid_t to empty_t when not available
10302 - BUG/MINOR: mworker: Fix memory leak of mworker_proc members
10303 - CLEANUP: objtype: make obj_type() and obj_type_name() take consts
10304 - MINOR: debug: switch to SIGURG for thread dumps
10305 - CLEANUP: threads: really move thread_info to hathreads.c
10306 - MINOR: threads: make threads_{harmless|want_rdv}_mask constant 0 without threads
10307 - CLEANUP: debug: always report harmless/want_rdv even without threads
10308 - MINOR: threads: implement ha_tkill() and ha_tkillall()
10309 - CLEANUP: debug: make use of ha_tkill() and remove ifdefs
10310 - MINOR: stream: introduce a stream_dump() function and use it in stream_dump_and_crash()
10311 - MINOR: debug: dump streams when an applet, iocb or stream is known
10312 - MINOR: threads: add a "stuck" flag to the thread_info struct
10313 - MINOR: threads: add a timer_t per thread in thread_info
10314 - MAJOR: watchdog: implement a thread lockup detection mechanism
10315 - MINOR: stream: remove the cpu time detection from process_stream()
10316 - MINOR: connection: report the mux names in "haproxy -vv"
10317 - CLEANUP: mux-h1: use "H1" and not "h1" as the mux's name
10318 - BUG/MEDIUM: WURFL: segfault in wurfl-get() with missing info.
10319 - MINOR: WURFL: call header_retireve_callback() in dummy library
10320 - MINOR: WURFL: fixed Engine load failed error when wurfl-information-list contains wurfl_root_id
10321 - MINOR: WURFL: shows log messages during module initialization
10322 - MINOR: WURFL: removes heading wurfl-information-separator from wurfl-get-all() and wurfl-get() results
10323 - MINOR: WURFL: wurfl_get() and wurfl_get_all() now return an empty string if device detection fails
10324 - MEDIUM: WURFL: HTX awareness.
10325 - MINOR: WURFL: module version bump to 2.0
10326 - MINOR: WURFL: do not emit warnings when not configured
10327 - CONTRIB: wurfl: address 3 build issues in the wurfl dummy library
10328 - BUG/MEDIUM: init/threads: provide per-thread alloc/free function callbacks
10329 - BUILD: travis: add sanitizers to travis-ci builds
10330 - BUILD: time: remove the test on _POSIX_C_SOURCE
10331 - CLEANUP: build: rename some build macros to use the USE_* ones
10332 - CLEANUP: raw_sock: remove support for very old linux splice bug workaround
10333 - BUG/MEDIUM: dns: make the port numbers unsigned
10334 - MEDIUM: config: deprecate the antique req* and rsp* commands
10335
Willy Tarreaua257a9b2019-05-15 16:51:48 +0200103362019/05/15 : 2.0-dev3
10337 - BUG/MINOR: peers: Really close the sessions with no heartbeat.
10338 - CLEANUP: peers: remove useless annoying tabulations.
10339 - CLEANUP: peers: replace timeout constants by macros.
10340 - REGTEST: Enable again reg tests with HEAD HTTP method usage.
10341 - DOC: The option httplog is no longer valid in a backend.
10342 - DOC: peers: Peers protocol documentation update.
10343 - REGTEST: remove unexpected "nbthread" statement from Lua test cases
10344 - BUILD: Makefile: remove 11-years old workarounds for deprecated options
10345 - BUILD: remove 10-years old error message for obsolete option USE_TCPSPLICE
10346 - BUILD: Makefile: remove outdated support for dlmalloc
10347 - BUILD: Makefile: consider a variable's origin and not its value for the options list
10348 - BUILD: Makefile: also report disabled options in the BUILD_OPTIONS variable
10349 - BUILD: Makefile: shorten default settings declaration
10350 - BUILD: Makefile: clean up the target declarations
10351 - BUILD: report the whole feature set with their status in haproxy -vv
10352 - BUILD: pass all "USE_*" variables as -DUSE_* to the compiler
10353 - REGTEST: script: make the script use the new features list
10354 - REGTEST: script: remove platform-specific assigments of OPTIONS
10355 - BUG/MINOR: peers: Missing initializations after peer session shutdown.
10356 - BUG/MINOR: contrib/prometheus-exporter: Fix applet accordingly to recent changes
10357 - BUILD/MINOR: listener: Silent a few signedness warnings.
10358 - BUG/MINOR: mux-h1: Only skip invalid C-L headers on output
10359 - BUG/MEDIUM: mworker: don't free the wrong child when not found
10360 - BUG/MEDIUM: checks: Don't bother subscribing if we have a connection error.
10361 - BUG/MAJOR: checks: segfault during tcpcheck_main
10362 - BUILD: makefile: work around an old bug in GNU make-3.80
10363 - BUILD: makefile: work around another bug in make 3.80
10364 - BUILD: http: properly mark some struct as extern
10365 - BUILD: chunk: properly declare pool_head_trash as extern
10366 - BUILD: cache: avoid a build warning with some compilers/linkers
10367 - MINOR: tools: make memvprintf() never pass a NULL target to vsnprintf()
10368 - MINOR: tools: add an unsetenv() implementation
10369 - BUILD: re-implement an initcall variant without using executable sections
10370 - BUILD: use inttypes.h instead of stdint.h
10371 - BUILD: connection: fix naming of ip_v field
10372 - BUILD: makefile: fix build of IPv6 header on aix51
10373 - BUILD: makefile: add _LINUX_SOURCE_COMPAT to build on AIX-51
10374 - BUILD: define unsetenv on AIX 5.1
10375 - BUILD: Makefile: disable shared cache on AIX 5.1
10376 - MINOR: ssl: Add aes_gcm_dec converter
10377 - REORG: mworker: move serializing functions to mworker.c
10378 - REORG: mworker: move signals functions to mworker.c
10379 - REORG: mworker: move IPC functions to mworker.c
10380 - REORG: mworker: move signal handlers and related functions
10381 - REORG: mworker: move mworker_cleanlisteners to mworker.c
10382 - MINOR: mworker: calloc mworker_proc structures
10383 - MINOR: mworker: don't use children variable anymore
10384 - MINOR: cli: export cli_parse_default() definition in cli.h
10385 - REORG: mworker/cli: move CLI functions to mworker.c
10386 - MEDIUM: mworker-prog: implement program for master-worker
10387 - MINOR: mworker/cli: show programs in 'show proc'
10388 - BUG/MINOR: cli: correctly handle abns in 'show cli sockets'
10389 - MINOR: cli: start addresses by a prefix in 'show cli sockets'
10390 - MINOR: cli: export HAPROXY_CLI environment variable
10391 - BUG/MINOR: htx: Preserve empty HTX messages with an unprocessed parsing error
10392 - BUG/MINOR: proto_htx: Reset to_forward value when a message is set to DONE
10393 - REGTEST: http-capture/h00000: Relax a regex matching the log message
10394 - REGTEST: http-messaging/h00000: Fix the test when the HTX is enabled
10395 - REGTEST: http-rules/h00003: Use a different client for requests expecting a 301
10396 - REGTEST: log/b00000: Be sure the client always hits its timeout
10397 - REGTEST: lua/b00003: Relax the regex matching the log message
10398 - REGTEST: lua/b00003: Specify the HAProxy pid when the command ss is executed
10399 - BUG/MEDIUM: peers: fix a case where peer session is not cleanly reset on release.
10400 - BUG/MEDIUM: h2: Don't attempt to recv from h2_process_demux if we subscribed.
10401 - BUG/MEDIUM: htx: fix random premature abort of data transfers
10402 - BUG/MEDIUM: streams: Don't remove the SI_FL_ERR flag in si_update_both().
10403 - BUG/MEDIUM: streams: Store prev_state before calling si_update_both().
10404 - BUG/MEDIUM: stream: Don't clear the stream_interface flags in si_update_both.
10405 - MINOR: initcall: Don't forget to define the __start/stop_init_##stg symbols.
10406 - MINOR: threads: Implement thread_cpus_enabled() for FreeBSD.
10407 - BUG/MEDIUM: pattern: assign pattern IDs after checking the config validity
10408 - MINOR: skip get_gmtime where tm is unused
10409 - MINOR: ssl: Activate aes_gcm_dec converter for BoringSSL
10410 - BUG/MEDIUM: streams: Only re-run process_stream if we're in a connected state.
10411 - BUG/MEDIUM: stream_interface: Don't bother doing chk_rcv/snd if not connected.
10412 - BUG/MEDIUM: task/threads: address a fairness issue between local and global tasks
10413 - BUG/MINOR: tasks: make sure the first task to be queued keeps its nice value
10414 - BUG/MINOR: listener: renice the accept ring processing task
10415 - MINOR: cli/listener: report the number of accepts on "show activity"
10416 - MINOR: cli/activity: report the accept queue sizes in "show activity"
10417 - BUG/MEDIUM: spoe: Queue message only if no SPOE applet is attached to the stream
10418 - BUG/MEDIUM: spoe: Return an error if nothing is encoded for fragmented messages
10419 - BUG/MINOR: spoe: Be sure to set tv_request when each message fragment is encoded
10420 - BUG/MEDIUM: htx: Defrag if blocks position is changed and the payloads wrap
10421 - BUG/MEDIUM: htx: Don't crush blocks payload when append is done on a data block
10422 - MEDIUM: htx: Deprecate the option 'http-tunnel' and ignore it in HTX
10423 - MINOR: proto_htx: Don't adjust transaction mode anymore in HTX analyzers
10424 - BUG/MEDIUM: htx: Fix the process of HTTP CONNECT with h2 connections
10425 - MINOR: mux-h1: Simplify handling of 1xx responses
10426 - MINOR: stats/htx: Don't add "Connection: close" header anymore in stats responses
10427 - MEDIUM: h1: Add an option to sanitize connection headers during parsing
10428 - MEDIUM: mux-h1: Simplify the connection mode management by sanitizing headers
10429 - MINOR: mux-h1: Don't release the conn_stream anymore when h1s is destroyed
10430 - BUG/MINOR: mux-h1: Handle the flag CS_FL_KILL_CONN during a shutdown read/write
10431 - MINOR: mux-h2: Add a mux_ops dedicated to the HTX mode
10432 - MINOR: muxes: Add a flag to specify a multiplexer uses the HTX
10433 - MINOR: stream: Set a flag when the stream uses the HTX
10434 - MINOR: http: update the macro IS_HTX_STRM() to check the stream flag SF_HTX
10435 - MINOR: http_fetch/htx: Use stream flags instead of px mode in smp_prefetch_htx
10436 - MINOR: filters/htx: Use stream flags instead of px mode to instanciate a filter
10437 - MINOR: muxes: Rely on conn_is_back() during init to handle front/back conn
10438 - MEDIUM: muxes: Add an optional input buffer during mux initialization
10439 - MINOR: muxes: Pass the context of the mux to destroy() instead of the connection
10440 - MEDIUM: muxes: Be prepared to don't own connection during the release
10441 - MEDIUM: connection: Add conn_upgrade_mux_fe() to handle mux upgrades
10442 - MEDIUM: htx: Allow the option http-use-htx to be used on TCP proxies too
10443 - MAJOR: proxy/htx: Handle mux upgrades from TCP to HTTP in HTX mode
10444 - MAJOR: muxes/htx: Handle inplicit upgrades from h1 to h2
10445 - MAJOR: htx: Enable the HTX mode by default for all proxies
10446 - REGTEST: Use HTX by default and add '--no-htx' option to disable it
10447 - BUG/MEDIUM: muxes: Don't dereference mux context if null in release functions
10448 - CLEANUP: task: do not export rq_next anymore
10449 - MEDIUM: tasks: improve fairness between the local and global queues
10450 - MEDIUM: tasks: only base the nice offset on the run queue depth
10451 - MINOR: tasks: restore the lower latency scheduling when niced tasks are present
10452 - BUG/MEDIUM: map: Fix memory leak in the map converter
10453 - BUG/MINOR: ssl: Fix 48 byte TLS ticket key rotation
10454 - BUILD: task/thread: fix single-threaded build of task.c
10455 - BUILD: cli/threads: fix build in single-threaded mode
10456 - BUG/MEDIUM: muxes: Make sure we unsubcribed when destroying mux ctx.
10457 - BUG/MEDIUM: h2: Make sure we're not already in the send_list in h2_subscribe().
10458 - BUG/MEDIUM: h2: Revamp the way send subscriptions works.
10459 - MINOR: connections: Remove the SUB_CALL_UNSUBSCRIBE flag.
10460 - BUG/MEDIUM: Threads: Only use the gcc >= 4.7 builtins when using gcc >= 4.7.
10461 - BUILD: address a few cases of "static <type> inline foo()"
10462 - BUILD: do not specify "const" on functions returning structs or scalars
10463 - BUILD: htx: fix a used uninitialized warning on is_cookie2
10464 - MINOR: peers: Add a new command to the CLI for peers.
10465 - DOC: update for "show peers" CLI command.
10466 - BUG/MAJOR: lb/threads: fix insufficient locking on round-robin LB
10467 - MEDIUM: mworker: store the leaving state of a process
10468 - MEDIUM: mworker-prog: implements 'option start-on-reload'
10469 - CLEANUP: mworker: remove the type field in mworker_proc
10470 - MEDIUM: mworker/cli: export the HAPROXY_MASTER_CLI variable
10471 - MINOR: cli: don't add a semicolon at the end of HAPROXY_CLI
10472 - MINOR: mworker: export HAPROXY_MWORKER=1 when running in mworker mode
10473 - MINOR: init: add a "set-dumpable" global directive to enable core dumps
10474 - BUG/MINOR: listener/mq: correctly scan all bound threads under low load
10475 - BUG/MINOR: mworker: mworker_kill should apply on every children
10476 - BUG/MINOR: mworker: don't exit with an ambiguous value
10477 - BUG/MINOR: mworker: ensure that we still quits with SIGINT
10478 - REGTESTS: exclude tests that require ssl, pcre if no such feature is enabled
10479 - BUG/MINOR: mux-h1: Process input even if the input buffer is empty
10480 - BUG/MINOR: mux-h1: Don't switch the parser in busy mode if other side has done
10481 - BUG/MEDIUM: mux-h1: Notify the stream waiting for TCP splicing if ibuf is empty
10482 - BUG/MEDIUM: mux-h1: Enable TCP splicing to exchange data only
10483 - MINOR: mux-h1: Handle read0 during TCP splicing
10484 - BUG/MEDIUM: htx: Don't return the start-line if the HTX message is empty
10485 - BUG/MAJOR: http_fetch: Get the channel depending on the keyword used
10486 - BUG/MINOR: http_fetch/htx: Allow permissive sample prefetch for the HTX
10487 - BUG/MINOR: http_fetch/htx: Use HTX versions if the proxy enables the HTX mode
10488 - BUG/MEDIUM: tasks: Make sure we set TASK_QUEUED before adding a task to the rq.
10489 - BUG/MEDIUM: tasks: Make sure we modify global_tasks_mask with the rq_lock.
10490 - MINOR: tasks: Don't consider we can wake task with tasklet_wakeup().
10491 - MEDIUM: tasks: No longer use rq.node.leaf_p as a lock.
10492 - MINOR: tasks: Don't set the TASK_RUNNING flag when adding in the tasklet list.
10493 - BUG/MEDIUM: applets: Don't use task_in_rq().
10494 - BUG/MAJOR: task: make sure never to delete a queued task
10495 - MINOR: task/thread: factor out a wake-up condition
10496 - CLEANUP: task: remain consistent when using the task's handler
10497 - MEDIUM: tasks: Merge task_delete() and task_free() into task_destroy().
10498 - MEDIUM: tasks: Don't account a destroyed task as a runned task.
10499 - BUG/MINOR: contrib/prometheus-exporter: Fix a typo in the run-queue metric type
10500 - MINOR: contrib/prometheus-exporter: Remove usless rate metrics
10501 - MINOR: contrib/prometheus-exporter: Rename some metrics to be more usable
10502 - MINOR: contrib/prometheus-exporter: Follow best practices about metrics type
10503 - BUG/MINOR: mworker: disable busy polling in the master process
10504 - MEDIUM: tasks: Use __ha_barrier_store after modifying global_tasks_mask.
10505 - MEDIUM: ssl: Give ssl_sock its own context.
10506 - MEDIUM: connections: Move some fields from struct connection to ssl_sock_ctx.
10507 - MEDIUM: ssl: provide its own subscribe/unsubscribe function.
10508 - MEDIUM: connections: Provide a xprt_ctx for each xprt method.
10509 - MEDIUM: ssl: provide our own BIO.
10510 - BUILD/medium: ssl: Fix build with OpenSSL < 1.1.0
10511 - MINOR: peers: adds counters on show peers about tasks calls.
10512 - MEDIUM: enable travis-ci builds
10513 - MINOR: fd: Add a counter of used fds.
10514 - MEDIUM: connections: Add a way to control the number of idling connections.
10515 - BUG/MEDIUM: maps: only try to parse the default value when it's present
10516 - BUG/MINOR: acl: properly detect pattern type SMP_T_ADDR
10517 - REGTEST: Missing REQUIRE_VERSION declarations.
10518 - MINOR: proto_tcp: tcp-request content: enable set-dst and set-dst-var
10519 - BUG/MEDIUM: h1: Don't parse chunks CRLF if not enough data are available
10520 - BUG/MEDIUM: thread/http: Add missing locks in set-map and add-acl HTTP rules
10521 - BUG/MEDIUM: stream: Don't request a server connection if a shutw was scheduled
10522 - BUG/MINOR: 51d: Get the request channel to call CHECK_HTTP_MESSAGE_FIRST()
10523 - BUG/MINOR: da: Get the request channel to call CHECK_HTTP_MESSAGE_FIRST()
10524 - MINOR: gcc: Fix a silly gcc warning in connect_server()
10525 - MINOR: ssl/cli: async fd io-handlers printable on show fd
10526 - Revert "CLEANUP: wurfl: remove dead, broken and unmaintained code"
10527 - BUILD: add USE_WURFL to the list of known build options
10528 - MINOR: wurfl: indicate in haproxy -vv the wurfl version in use
10529 - BUILD: wurfl: build fix for 1.9/2.0 code base
10530 - CLEANUP: wurfl: removed deprecated methods
10531 - DOC: wurfl: added point of contact in MAINTAINERS file
10532 - MINOR: wurfl: enabled multithreading mode
10533 - MINOR: contrib: dummy wurfl library
10534 - MINOR: dns: dns_requester structures are now in a memory pool
10535 - MINOR: dns: move callback affection in dns_link_resolution()
10536 - MINOR: obj_type: new object type for struct stream
10537 - MINOR: action: new '(http-request|tcp-request content) do-resolve' action
10538 - MINOR: log: Extract some code to send syslog messages.
10539 - REGTEST: replace LEVEL option by a more human readable one.
10540 - REGTEST: rename the reg test files.
10541 - REGTEST: adapt some reg tests after renaming.
10542 - REGTEST: make the "run-regtests" script search for tests in reg-tests by default
10543 - BUG/MAJOR: stream: Missing DNS context initializations.
10544 - BUG/MEDIUM: stream: Fix the way early aborts on the client side are handled
10545 - BUG/MINOR: spoe: Don't systematically wakeup SPOE stream in the applet handler
10546 - BUG/MEDIUM: ssl: Return -1 on recv/send if we got EAGAIN.
10547 - BUG/MAJOR: lb/threads: fix AB/BA locking issue in round-robin LB
10548 - BUG/MAJOR: muxes: Use the HTX mode to find the best mux for HTTP proxies only
10549 - BUG/MINOR: htx: Exclude TCP proxies when the HTX mode is handled during startup
10550 - CLEANUP: task: report calls as unsigned in show sess
10551 - MINOR: tasks/activity: report the context switch and task wakeup rates
10552 - MINOR: stream: measure and report a stream's call rate in "show sess"
10553 - MINOR: applet: measure and report an appctx's call rate in "show sess"
10554 - BUILD: extend Travis CI config to support more platforms
10555 - REGTEST: exclude osx and generic targets for 40be_2srv_odd_health_checks
10556 - REGTEST: relax the IPv6 address format checks in converters_ipmask_concat_strcmp_field_word
10557 - REGTEST: exclude OSX and generic targets from abns_socket.vtc
10558 - BUILD: travis: remove the "allow_failures" entry
10559 - BUG/MINOR: activity: always initialize the profiling variable
10560 - MINOR: activity: make the profiling status per thread and not global
10561 - MINOR: activity: enable automatic profiling turn on/off
10562 - CLEANUP: standard: use proper const to addr_to_str() and port_to_str()
10563 - BUG/MINOR: proto_http: properly reset the stream's call rate on keep-alive
10564 - MINOR: connection: make the debugging helper functions safer
10565 - MINOR: stream/debug: make a stream dump and crash function
10566 - MEDIUM: appctx/debug: force a crash if an appctx spins over itself forever
10567 - MEDIUM: stream/debug: force a crash if a stream spins over itself forever
10568 - MEDIUM: streams: measure processing time and abort when detecting bugs
10569 - BUILD/MEDIUM: contrib: Dummy DeviceAtlas API.
10570 - MEDIUM: da: HTX mode support.
10571 - BUG/MEDIUM: mux-h2: properly deal with too large headers frames
10572 - BUG/MINOR: http: Call stream_inc_be_http_req_ctr() only one time per request
10573 - BUG/MEDIUM: spoe: arg len encoded in previous frag frame but len changed
10574 - MINOR: spoe: Use the sample context to pass frag_ctx info during encoding
10575 - DOC: contrib/modsecurity: Typos and fix the reject example
10576 - BUG/MEDIUM: contrib/modsecurity: If host header is NULL, don't try to strdup it
10577 - MINOR: log: Add "sample" new keyword to "log" lines.
10578 - MINOR: log: Enable the log sampling and load-balancing feature.
10579 - DOC: log: Document the sampling and load-balancing logging feature.
10580 - REGTEST: Add a new reg test for log load-balancing feature.
10581 - BUG/MAJOR: map/acl: real fix segfault during show map/acl on CLI
10582 - REGTEST: Make this reg test be Linux specific.
10583 - CLEANUP: task: move the task_per_thread definition to task.h
10584 - MINOR: activity: report context switch counts instead of rates
10585 - MINOR: threads: Implement HA_ATOMIC_LOAD().
10586 - BUG/MEDIUM: port_range: Make the ring buffer lock-free.
10587 - BUG/MEDIUM: listener: Fix how unlimited number of consecutive accepts is handled
10588 - MINOR: config: Test validity of tune.maxaccept during the config parsing
10589 - CLEANUP: config: Don't alter listener->maxaccept when nbproc is set to 1
10590 - BUG/MEDIUM: servers: fix typo "src" instead of "srv"
10591 - BUG/MEDIUM: ssl: Don't pretend we can retry a recv/send if we got a shutr/w.
10592 - BUG/MINOR: haproxy: fix rule->file memory leak
10593 - BUG/MINOR: log: properly free memory on logformat parse error and deinit()
10594 - BUG/MINOR: checks: free memory allocated for tasklets
10595 - BUG/MEDIUM: pattern: fix memory leak in regex pattern functions
10596 - BUG/MEDIUM: channels: Don't forget to reset output in channel_erase().
10597 - BUG/MEDIUM: connections: Make sure we remove CO_FL_SESS_IDLE on disown.
10598 - MINOR: threads: flatten the per-thread cpu-map
10599 - MINOR: init/threads: remove the useless tids[] array
10600 - MINOR: init/threads: make the threads array global
10601 - BUG/MEDIUM: ssl: Use the early_data API the right way.
10602 - BUG/MEDIUM: streams: Don't add CF_WRITE_ERROR if early data were rejected.
10603 - MEDIUM: streams: Add the ability to retry a request on L7 failure.
10604 - MEDIUM: streams: Add a way to replay failed 0rtt requests.
10605 - MEDIUM: streams: Add a new keyword for retry-on, "junk-response"
10606 - BUG/MINOR: stream: also increment the retry stats counter on L7 retries
10607 - BUG/MEDIUM: checks: make sure the warmup task takes the server lock
10608 - BUG/MINOR: logs/threads: properly split the log area upon startup
10609 - BUILD: extend travis-ci matrix
10610 - CLEANUP: Remove appsession documentation
10611 - DOC: Fix typo in keyword matrix
10612 - BUILD: remove "build_libressl" duplicate declaration
10613 - BUILD: travis-ci: get back to osx without openssl support
10614 - BUILD: enable several LibreSSL hacks, including
10615 - BUILD: temporarily mark LibreSSL builds as allowed to fail
10616 - BUILD: travis: TMPDIR replacement.
10617 - BUG/MEDIUM: ssl: Don't attempt to use early data with libressl.
10618 - MINOR: doc: Document allow-0rtt on the server line.
10619 - MINOR: doc: Document the interaction of allow-0rtt and retry-on 0rtt-rejected.
10620 - MEDIUM: proto: Change the prototype of the connect() method.
10621 - MEDIUM: tcp: add the "tfo" option to support TCP fastopen on the server
10622 - MINOR: config: Extract the code of "stick-table" line parsing.
10623 - BUILD/MINOR: stick-table: Compilation fix.
10624 - MEDIUM: stick-table: Stop handling stick-tables as proxies.
10625 - MINOR: stick-tables: Add peers process binding computing.
10626 - MINOR: stick-table: Add prefixes to stick-table names.
10627 - MINOR: peers: Do not emit global stick-table names.
10628 - DOC: Update for "table" lines in "peers" section.
10629 - REGTEST: Add reg tests for "table" lines in "peers" sections.
10630 - MEDIUM: regex: modify regex_comp() to atomically allocate/free the my_regex struct
10631 - REGTEST: make the tls_health_checks test much faster
10632 - REGTEST: make the "table in peers" test require v2.0
10633 - BUG/MINOR: mux-h2: rely on trailers output not input to turn them to empty data
10634 - BUG/MEDIUM: h2/htx: always fail on too large trailers
10635 - MEDIUM: mux-h2: discard contents that are to be sent after a shutdown
10636 - BUG/MEDIUM: mux-h2/htx: never wait for EOM when processing trailers
10637 - BUG/MEDIUM: h2/htx: never leave a trailers block alone with no EOM block
10638 - REGTEST: Flag some slow reg tests.
10639 - REGTEST: Reg tests file renaming.
10640 - REGTEST: Wrong renaming for one reg test.
10641 - REGTEST: Wrong assumption in IP:port logging test.
10642 - BUG/MINOR: mworker/ssl: close OpenSSL FDs on reload
10643 - MINOR: systemd: Use the variables from /etc/default/haproxy
10644 - MINOR: systemd: Make use of master socket in systemd unit
10645 - MINOR: systemd: support /etc/sysconfig/ for redhat based distrib
10646 - BUG/MEDIUM: stick-table: fix regression caused by a change in proxy struct
10647 - BUG/MEDIUM: tasks: fix possible segfault on task_destroy()
10648 - CLEANUP: task: remove unneeded tests before task_destroy()
10649 - MINOR: mworker: support a configurable maximum number of reloads
10650 - BUG/MINOR: mux-h2: fix the condition to close a cs-less h2s on the backend
10651 - BUG/MEDIUM: spoe: Be sure the sample is found before setting its context
10652 - BUG/MINOR: mux-h1: Fix the parsing of trailers
10653 - BUG/MINOR: htx: Never transfer more than expected in htx_xfer_blks()
10654 - MINOR: htx: Split on DATA blocks only when blocks are moved to an HTX message
10655 - MINOR: htx: Don't try to append a trailer block with the previous one
10656 - MINOR: htx: Remove support for unused OOB HTX blocks
10657 - BUILD: travis-ci bugfixes and improvements
10658 - BUG/MEDIUM: servers: Don't use the same srv flag for cookie-set and TFO.
10659 - BUG/MEDIUM: h2: Make sure we set send_list to NULL in h2_detach().
10660 - BUILD: ssl: fix again a libressl build failure after the openssl FD leak fix
10661 - CLEANUP: ssl-sock: use HA_OPENSSL_VERSION_NUMBER instead of OPENSSL_VERSION_NUMBER
10662 - BUILD: ssl: make libressl use its own version numbers
10663 - CLEANUP: ssl: remove 57 occurrences of useless tests on LIBRESSL_VERSION_NUMBER
10664 - MINOR: ssl: enable aes_gcm_dec on LibreSSL
10665 - BUILD: ssl: fix libressl build again after aes-gcm-enc
10666 - REORG: ssl: move openssl-compat from proto to common
10667 - REORG: ssl: move some OpenSSL defines from ssl_sock to openssl-compat
10668 - CLEANUP: ssl: never include openssl/*.h outside of openssl-compat.h anymore
10669 - CLEANUP: ssl: make inclusion of openssl headers safe
10670 - BUILD: add BoringSSL to travis-ci build matrix
10671 - BUILD: threads: Add __ha_cas_dw fallback for single threaded builds
10672 - BUG/MINOR: stream: Attach the read side on the response as soon as possible
10673 - BUG/MEDIUM: http: Use pointer to the begining of input to parse message headers
10674 - BUG/MEDIUM: h2: Don't check send_wait to know if we're in the send_list.
10675 - BUG/MEDIUM: streams: Make sur SI_FL_L7_RETRY is set before attempting a retry.
10676 - MEDIUM: streams: Add a new http action, disable-l7-retry.
10677 - MINOR: streams: Introduce a new retry-on keyword, all-retryable-errors.
10678 - BUG/MINOR: vars: Fix memory leak in vars_check_arg
10679 - BUILD: travis-ci: make TMPDIR global variable in travis-ci
10680 - CLEANUP: ssl: move the SSL_OP_* and SSL_MODE_* definitions to openssl-compat
10681 - CLEANUP: ssl: remove ifdef around SSL_CTX_get_extra_chain_certs()
10682 - CLEANUP: ssl: move all BIO_* definitions to openssl-compat
10683 - BUILD: threads: fix again the __ha_cas_dw() definition
10684 - BUG/MAJOR: mux-h2: do not add a stream twice to the send list
10685 - Revert "BUG/MINOR: vars: Fix memory leak in vars_check_arg"
10686 - BUG/MINOR: peers: Fix memory leak in cfg_parse_peers
10687 - BUG/MINOR: htx: make sure to always initialize the HTTP method when parsing a buffer
10688 - REGTEST: fix tls_health_checks random failures on MacOS in Travis-CI
10689 - MINOR: spoe: Set the argument chunk size to 0 when SPOE variables are checked
10690 - BUG/MINOR: vars: Fix memory leak in vars_check_arg
10691 - BUG/MAJOR: ssl: segfault upon an heartbeat request
10692 - MINOR: spoa-server: Clone the v1.7 spoa-example project
10693 - MINOR: spoa-server: move some definition from spoa_server.c to spoa_server.h
10694 - MINOR: spoa-server: Externalise debug functions
10695 - MINOR: spoe-server: rename "worker" functions
10696 - MINOR: spoa-server: Replace the thread init system by processes
10697 - MINOR: spoa-server: With debug mode, start only one process
10698 - MINOR: spoa-server: Allow registering external processes
10699 - MINOR: spoa-server: Allow registering message processors
10700 - MINOR: spoa-server: Load files
10701 - MINOR: spoa-server: Prepare responses
10702 - MINOR: spoa-server: Execute registered callbacks
10703 - MINOR: spoa-server: Add Lua processing
10704 - MINOR: spoa-server: Add python
10705 - MINOR/DOC: spoe-server: Add documentation
10706 - BUG/MEDIUM: connections: Don't forget to set xprt_ctx to NULL on close.
10707 - MINOR: lists: add LIST_ADDED() to check if an element belongs to a list
10708 - CLEANUP: mux-h2: use LIST_ADDED() instead of LIST_ISEMPTY() where relevant
10709 - MINOR: mux-h2: add two H2S flags to report the need for shutr/shutw
10710 - CLEANUP: mux-h2: simply use h2s->flags instead of ret in h2_deferred_shut()
10711 - CLEANUP: connection: remove the handle field from the wait_event struct
10712 - BUG/MINOR: log: Wrong log format initialization.
10713 - BUG/MINOR: mux-h2: make the do_shut{r,w} functions more robust against retries
10714 - BUG/MINOR: mworker: use after free when the PID not assigned
10715 - MINOR: mux-h2: remove useless test on stream ID vs last in wake function
10716 - MINOR: mux-h2: make h2_wake_some_streams() not depend on the CS flags
10717 - MINOR: mux-h2: make h2s_wake_one_stream() the only function to deal with CS
10718 - MINOR: mux-h2: make h2s_wake_one_stream() not depend on temporary CS flags
10719 - BUG/MINOR: mux-h2: make sure to honor KILL_CONN in do_shut{r,w}
10720 - CLEANUP: mux-h2: don't test for impossible CS_FL_REOS conditions
10721 - MINOR: mux-h2: add macros to check multiple stream states at once
10722 - MINOR: mux-h2: stop relying on CS_FL_REOS
10723 - BUG/MEDIUM: mux-h2: Set EOI on the conn_stream during h2_rcv_buf()
10724 - BUILD: debug: make gcc not complain on the ABORT_NOW() macro
10725 - MINOR: debug: add a new BUG_ON macro
10726 - MINOR: h2: Use BUG_ON() to enforce rules in subscribe/unsubscribe.
10727 - MINOR: h1: Use BUG_ON() to enforce rules in subscribe/unsubscribe.
10728 - MINOR: connections: Use BUG_ON() to enforce rules in subscribe/unsubscribe.
10729 - BUILD: ist: turn the lower/upper case tables to literal on obsolete linkers
10730
Willy Tarreau6e893b92019-03-26 05:40:51 +0100107312019/03/26 : 2.0-dev2
10732 - CLEANUP: http: Remove unreachable code in parse_http_req_capture
10733 - CLEANUP: stream: Remove bogus loop in conn_si_send_proxy
10734 - MINOR: lists: Implement locked variations.
10735 - MEDIUM: servers: Used a locked list for idle_orphan_conns.
10736 - MEDIUM: servers: Reorganize the way idle connections are cleaned.
10737 - BUG/MEDIUM: lists: Properly handle the case we're removing the first elt.
10738 - MINOR: cfgparse: Add a cast to make gcc happier.
10739 - BUG/MEDIUM: standard: Wrong reallocation size.
10740 - BUG/MINOR: listener: keep accept rate counters accurate under saturation
10741 - DOC: fix alphabetic ordering for "tune.fail-alloc" setting
10742 - MAJOR: config: disable support for nbproc and nbthread in parallel
10743 - MEDIUM: listener: keep a single thread-mask and warn on "process" misuse
10744 - MAJOR: listener: do not hold the listener lock in listener_accept()
10745 - MINOR: listener: maintain a per-thread count of the number of connections on a listener
10746 - MINOR: tools: implement functions to look up the nth bit set in a mask
10747 - MINOR: listener: pre-compute some thread counts per bind_conf
10748 - MINOR: listener: implement multi-queue accept for threads
10749 - MAJOR: listener: use the multi-queue for multi-thread listeners
10750 - MINOR: activity: add accept queue counters for pushed and overflows
10751 - MINOR: config: add global tune.listener.multi-queue setting
10752 - MAJOR: threads: enable one thread per CPU by default
10753 - DOC: update management.txt to reflect that threads are used by default
10754 - BUG/MINOR: config: don't over-count the global maxsock value
10755 - BUG/MEDIUM: list: fix the rollback on addq in the locked liss
10756 - BUG/MEDIUM: list: fix LIST_POP_LOCKED's removal of the last pointer
10757 - BUG/MEDIUM: list: add missing store barriers when updating elements and head
10758 - MINOR: list: make the delete and pop operations idempotent
10759 - MINOR: server: remove a few unneeded LIST_INIT calls after LIST_DEL_LOCKED
10760 - BUG/MEDIUM: listener: use a self-locked list for the dequeue lists
10761 - BUG/MEDIUM: listener: make sure the listener never accepts too many conns
10762 - BUG/MEDIUM: list: correct fix for LIST_POP_LOCKED's removal of last element
10763 - MINOR: listener: introduce listener_backlog() to report the backlog value
10764 - MINOR: listener: do not needlessly set l->maxconn
10765 - MINOR: proxy: do not change the listeners' maxconn when updating the frontend's
10766 - MEDIUM: config: don't enforce a low frontend maxconn value anymore
10767 - MINOR: peers: Add a message for heartbeat.
10768 - MINOR: global: keep a copy of the initial rlim_fd_cur and rlim_fd_max values
10769 - BUG/MINOR: init: never lower rlim_fd_max
10770 - BUG/MINOR: checks: make external-checks restore the original rlim_fd_cur/max
10771 - BUG/MINOR: mworker: be careful to restore the original rlim_fd_cur/max on reload
10772 - MINOR: init: make the maxpipe computation more accurate
10773 - MINOR: init: move some maxsock updates earlier
10774 - MEDIUM: init: make the global maxconn default to what rlim_fd_cur permits
10775 - REGTEST: fix a spurious "nbthread 4" in the connection test
10776 - DOC: update the text related to the global maxconn value
10777 - BUG/MAJOR: mux-h2: fix race condition between close on both ends
10778 - MINOR: sample: Replace "req.ungrpc" smp fetch by a "ungrpc" converter.
10779 - BUG/MEDIUM: list: fix again LIST_ADDQ_LOCKED
10780 - MINOR: htx: unconditionally handle parsing errors in requests or responses
10781 - MINOR: mux-h2: always pass HTX_FL_PARSING_ERROR between h2s and buf on RX
10782 - BUG/MEDIUM: h2/htx: verify that :path doesn't contain invalid chars
10783 - MINOR: sample: Code factorization "ungrpc" converter.
10784 - MINOR: sample: Rework gRPC converter code.
10785 - CLEANUP: wurfl: remove dead, broken and unmaintained code
10786 - MINOR: config: relax the range checks on cpu-map
10787 - BUG/MINOR: ssl: fix warning about ssl-min/max-ver support
10788 - MINOR: sample: Extract some protocol buffers specific code.
10789 - DOC: Remove tabs and fixed punctuation.
10790 - MINOR: sample: Add a protocol buffers specific converter.
10791 - REGTEST: Peers reg tests.
10792 - REGTEST: Enable reg tests with HEAD HTTP method usage.
10793 - MINOR: lists: add a LIST_DEL_INIT() macro
10794 - MINOR: task: use LIST_DEL_INIT() to remove a task from the queue
10795 - MINOR: listener: improve incoming traffic distribution
10796 - MINOR: tools: implement my_flsl()
10797 - MEDIUM: listener: change the LB algorithm again to use two round robins instead
10798 - CLEANUP: listener: remove old thread bit mapping
10799 - MINOR: listener: move thr_idx from the bind_conf to the listener
10800 - BUG/MEDIUM: logs: Only attempt to free startup_logs once.
10801 - BUG/MAJOR: config: Wrong maxconn adjustment.
10802 - BUG/MEDIUM: 51d: fix possible segfault on deinit_51degrees()
10803 - OPTIM: task: limit the impact of memory barriers in taks_remove_from_task_list()
10804 - MINOR: fd: Remove debugging code.
10805 - BUG/MEDIUM: listeners: Don't call fd_stop_recv() if fd_updt is NULL.
10806 - MINOR: threads: Implement __ha_barrier_atomic*.
10807 - MEDIUM: threads: Use __ATOMIC_SEQ_CST when using the newer atomic API.
10808 - MINOR: threads: Add macros to do atomic operation with no memory barrier.
10809 - MEDIUM: various: Use __ha_barrier_atomic* when relevant.
10810 - MEDIUM: applets: Use the new _HA_ATOMIC_* macros.
10811 - MEDIUM: xref: Use the new _HA_ATOMIC_* macros.
10812 - MEDIUM: fd: Use the new _HA_ATOMIC_* macros.
10813 - MEDIUM: freq_ctr: Use the new _HA_ATOMIC_* macros.
10814 - MEDIUM: proxy: Use the new _HA_ATOMIC_* macros.
10815 - MEDIUM: server: Use the new _HA_ATOMIC_* macros.
10816 - MEDIUM: task: Use the new _HA_ATOMIC_* macros.
10817 - MEDIUM: activity: Use the new _HA_ATOMIC_* macros.
10818 - MEDIUM: backend: Use the new _HA_ATOMIC_* macros.
10819 - MEDIUM: cache: Use the new _HA_ATOMIC_* macros.
10820 - MEDIUM: checks: Use the new _HA_ATOMIC_* macros.
10821 - MEDIUM: pollers: Use the new _HA_ATOMIC_* macros.
10822 - MEDIUM: compression: Use the new _HA_ATOMIC_* macros.
10823 - MEDIUM: spoe: Use the new _HA_ATOMIC_* macros.
10824 - MEDIUM: threads: Use the new _HA_ATOMIC_* macros.
10825 - MEDIUM: http: Use the new _HA_ATOMIC_* macros.
10826 - MEDIUM: lb/threads: Use the new _HA_ATOMIC_* macros.
10827 - MEDIUM: listeners: Use the new _HA_ATOMIC_* macros.
10828 - MEDIUM: logs: Use the new _HA_ATOMIC_* macros.
10829 - MEDIUM: memory: Use the new _HA_ATOMIC_* macros.
10830 - MEDIUM: peers: Use the new _HA_ATOMIC_* macros.
10831 - MEDIUM: proto_tcp: Use the new _HA_ATOMIC_* macros.
10832 - MEDIUM: queues: Use the new _HA_ATOMIC_* macros.
10833 - MEDIUM: sessions: Use the new _HA_ATOMIC_* macros.
10834 - MEDIUM: ssl: Use the new _HA_ATOMIC_* macros.
10835 - MEDIUM: stream: Use the new _HA_ATOMIC_* macros.
10836 - MEDIUM: tcp_rules: Use the new _HA_ATOMIC_* macros.
10837 - MEDIUM: time: Use the new _HA_ATOMIC_* macros.
10838 - MEDIUM: vars: Use the new _HA_ATOMIC_* macros.
10839 - MINOR: config: remove obsolete use of DEFAULT_MAXCONN at various places
10840 - MINOR: config: continue to rely on DEFAULT_MAXCONN to set the minimum maxconn
10841 - BUG/MEDIUM: list: fix incorrect pointer unlocking in LIST_DEL_LOCKED()
10842 - BUG/MEDIUM: listener: make sure we don't pick stopped threads
10843 - MEDIUM: list: Remove useless barriers.
10844 - MEDIUM: list: Use _HA_ATOMIC_*
10845 - MEDIUM: connections: Use _HA_ATOMIC_*
10846 - BUG/MAJOR: tasks: Use the TASK_GLOBAL flag to know if we're in the global rq.
10847 - BUG/MEDIUM: threads/fd: do not forget to take into account epoll_fd/pipes
10848 - BUG/MEDIUM: init/threads: consider epoll_fd/pipes for automatic maxconn calculation
10849 - BUG/MEDIUM: tasks: Make sure we wake sleeping threads if needed.
10850 - BUG/MINOR: mux-h1: Don't report an error on EOS if no message was received
10851 - BUG/MINOR: stats/htx: Call channel_add_input() when response headers are sent
10852 - BUG/MINOR: lua/htx: Use channel_add_input() when response data are added
10853 - BUG/MINOR: lua/htx: Don't forget to call htx_to_buf() when appropriate
10854 - MINOR: stats: Add the status code STAT_STATUS_IVAL to handle invalid requests
10855 - MINOR: stats: Move stuff about the stats status codes in stats files
10856 - BUG/MINOR: stats: Be more strict on what is a valid request to the stats applet
10857 - Revert "REGTEST: Enable reg tests with HEAD HTTP method usage."
10858 - BUILD: listener: shut up a build warning when threads are disabled
10859 - BUILD: Makefile: allow the reg-tests target to be verbose
10860 - BUILD: Makefile: resolve LEVEL before calling run-regtests
10861 - BUG/MAJOR: spoe: Fix initialization of thread-dependent fields
10862 - BUG/MAJOR: stats: Fix how huge POST data are read from the channel
10863 - BUG/MINOR: http/counters: fix missing increment of fe->srv_aborts
10864 - BUG/MEDIUM: mux-h2: Always wakeup streams with no id to avoid frozen streams
10865 - MINOR: mux-h2: Set REFUSED_STREAM error to reset a stream if no data was never sent
10866 - MINOR: muxes: Report the Last read with a dedicated flag
10867 - MINOR: proto-http/proto-htx: Make error handling clearer during data forwarding
10868 - BUILD: tools: fix a build warning on some 32-bit archs
10869 - MINOR: init: report the list of optionally available services
10870 - MEDIUM: proto_htx: Switch to infinite forwarding if there is no data filter
10871 - BUG/MINOR: cache: Fully consume large requests in the cache applet
10872 - BUG/MINOR: stats: Fully consume large requests in the stats applet
10873 - BUG/MEDIUM: lua: Fully consume large requests when an HTTP applet ends
10874 - MINOR: proto_http: Add function to handle the header "Expect: 100-continue"
10875 - MINOR: proto_htx: Add function to handle the header "Expect: 100-continue"
10876 - MINOR: stats/cache: Handle the header Expect when applets are registered
10877 - MINOR: http/applets: Handle all applets intercepting HTTP requests the same way
10878 - CLEANUP: cache: don't export http_cache_applet anymore
10879 - MINOR: lua: Don't handle the header Expect in lua HTTP applets anymore
10880 - BUG/MINOR: doc: Be accurate on the behavior on pool-purge-delay.
10881 - Revert "MEDIUM: proto_htx: Switch to infinite forwarding if there is no data filter"
10882 - BUG/MEDIUM: mux-h2: Make sure we destroyed the h2s once shutr/shutw is done.
10883 - BUG/MEDIUM: mux-h2: Don't bother keeping the h2s if detaching and nothing to send.
10884 - BUG/MEDIUM: mux-h2: Use the right list in h2_stop_senders().
10885 - MINOR: mux-h2: copy small data blocks more often and reduce the number of pauses
10886 - CLEANUP: mux-h2: add some comments to help understand the code
10887 - BUG/MEDIUM: ssl: ability to set TLS 1.3 ciphers using ssl-default-server-ciphersuites
10888 - BUG/MINOR: log: properly format IPv6 address when LOG_OPT_HEXA modifier is used.
10889 - BUG/MEDIUM: h2: Try to be fair when sending data.
10890 - BUG/MINOR: proto-http: Don't forward request body anymore on error
10891 - MINOR: mux-h2: Remove useless test on ES flag in h2_frt_transfer_data()
10892 - MINOR: connection: and new flag to mark end of input (EOI)
10893 - MINOR: channel: Report EOI on the input channel if it was reached in the mux
10894 - MEDIUM: mux-h2: Don't mix the end of the message with the end of stream
10895 - MINOR: mux-h1: Set CS_FL_EOI the end of the message is reached
10896 - BUG/MEDIUM: http/htx: Fix handling of the option abortonclose
10897 - CLEANUP: muxes/stream-int: Remove flags CS_FL_READ_NULL and SI_FL_READ_NULL
10898 - MEDIUM: proto_htx: Reintroduce the infinite forwarding on data
10899 - BUG/MEDIUM: h2: only destroy the h2s if h2s->cs is NULL.
10900 - BUG/MEDIUM: h2: Use the new sending_list in h2s_notify_send().
10901 - BUG/MEDIUM: h2: Follow the same logic in h2_deferred_shut than in h2_snd_buf.
10902 - BUG/MEDIUM: h2: Remove the tasklet from the task list if unsubscribing.
10903 - BUG/MEDIUM: task/h2: add an idempotent task removal fucntion
10904 - CLEANUP: task: only perform a LIST_DEL() when the list is not empty
10905 - BUG/MEDIUM: mux-h2: make sure to always notify streams of EOS condition
10906 - CONTRIB: debug: report the CS and CF's EOI flags
10907 - MINOR: channel: don't unset CF_SHUTR_NOW after shutting down.
10908
Willy Tarreau6c1b6672019-02-26 16:43:49 +0100109092019/02/26 : 2.0-dev1
10910 - MINOR: mux-h2: only increase the connection window with the first update
10911 - REGTESTS: remove the expected window updates from H2 handshakes
10912 - BUG/MINOR: mux-h2: make empty HEADERS frame return a connection error
10913 - BUG/MEDIUM: mux-h2: mark that we have too many CS once we have more than the max
10914 - MEDIUM: mux-h2: remove padlen during headers phase
10915 - MINOR: h2: add a bit-based frame type representation
10916 - MINOR: mux-h2: remove useless check for empty frame length in h2s_decode_headers()
10917 - MEDIUM: mux-h2: decode HEADERS frames before allocating the stream
10918 - MINOR: mux-h2: make h2c_send_rst_stream() use the dummy stream's error code
10919 - MINOR: mux-h2: add a new dummy stream for the REFUSED_STREAM error code
10920 - MINOR: mux-h2: fail stream creation more cleanly using RST_STREAM
10921 - MINOR: buffers: add a new b_move() function
10922 - MINOR: mux-h2: make h2_peek_frame_hdr() support an offset
10923 - MEDIUM: mux-h2: handle decoding of CONTINUATION frames
10924 - CLEANUP: mux-h2: remove misleading comments about CONTINUATION
10925 - BUG/MEDIUM: servers: Don't try to reuse connection if we switched server.
10926 - BUG/MEDIUM: tasks: Decrement tasks_run_queue in tasklet_free().
10927 - BUG/MINOR: htx: send the proper authenticate header when using http-request auth
10928 - BUG/MEDIUM: mux_h2: Don't add to the idle list if we're full.
10929 - BUG/MEDIUM: servers: Fail if we fail to allocate a conn_stream.
10930 - BUG/MAJOR: servers: Use the list api correctly to avoid crashes.
10931 - BUG/MAJOR: servers: Correctly use LIST_ELEM().
10932 - BUG/MAJOR: sessions: Use an unlimited number of servers for the conn list.
10933 - BUG/MEDIUM: servers: Flag the stream_interface on handshake error.
10934 - MEDIUM: servers: Be smarter when switching connections.
10935 - MEDIUM: sessions: Keep track of which connections are idle.
10936 - MINOR: payload: add sample fetch for TLS ALPN
10937 - BUG/MEDIUM: log: don't mark log FDs as non-blocking on terminals
10938 - MINOR: channel: Add the function channel_add_input
10939 - MINOR: stats/htx: Call channel_add_input instead of updating channel state by hand
10940 - BUG/MEDIUM: cache: Be sure to end the forwarding when XFER length is unknown
10941 - BUG/MAJOR: htx: Return the good block address after a defrag
10942 - MINOR: lb: allow redispatch when using consistent hash
10943 - CLEANUP: mux-h2: fix end-of-stream flag name when processing headers
10944 - BUG/MEDIUM: mux-h2: always restart reading if data are available
10945 - BUG/MINOR: mux-h2: set the stream-full flag when leaving h2c_decode_headers()
10946 - BUG/MINOR: mux-h2: don't check the CS count in h2c_bck_handle_headers()
10947 - BUG/MINOR: mux-h2: mark end-of-stream after processing response HEADERS, not before
10948 - BUG/MINOR: mux-h2: only update rxbuf's length for H1 headers
10949 - BUG/MEDIUM: mux-h1: use per-direction flags to indicate transitions
10950 - BUG/MEDIUM: mux-h1: make HTX chunking consistent with H2
10951 - BUG/MAJOR: stream-int: Update the stream expiration date in stream_int_notify()
10952 - BUG/MEDIUM: proto-htx: Set SI_FL_NOHALF on server side when request is done
10953 - BUG/MEDIUM: mux-h1: Add a task to handle connection timeouts
10954 - MINOR: mux-h2: make h2c_decode_headers() return a status, not a count
10955 - MINOR: mux-h2: add a new dummy stream : h2_error_stream
10956 - MEDIUM: mux-h2: make h2c_decode_headers() support recoverable errors
10957 - BUG/MINOR: mux-h2: detect when the HTX EOM block cannot be added after headers
10958 - MINOR: mux-h2: remove a misleading and impossible test
10959 - CLEANUP: mux-h2: clean the stream error path on HEADERS frame processing
10960 - MINOR: mux-h2: check for too many streams only for idle streams
10961 - MINOR: mux-h2: set H2_SF_HEADERS_RCVD when a HEADERS frame was decoded
10962 - BUG/MEDIUM: mux-h2: decode trailers in HEADERS frames
10963 - MINOR: h2: add h2_make_h1_trailers to turn H2 headers to H1 trailers
10964 - MEDIUM: mux-h2: pass trailers to H1 (legacy mode)
10965 - MINOR: htx: add a new function to add a block without filling it
10966 - MINOR: h2: add h2_make_htx_trailers to turn H2 headers to HTX trailers
10967 - MEDIUM: mux-h2: pass trailers to HTX
10968 - MINOR: mux-h1: parse the content-length header on output and set H1_MF_CLEN
10969 - BUG/MEDIUM: mux-h1: don't enforce chunked encoding on requests
10970 - MINOR: mux-h2: make HTX_BLK_EOM processing idempotent
10971 - MINOR: h1: make the H1 headers block parser able to parse headers only
10972 - MEDIUM: mux-h2: emit HEADERS frames when facing HTX trailers blocks
10973 - MINOR: stream/htx: Add info about the HTX structs in "show sess all" command
10974 - MINOR: stream: Add the subscription events of SIs in "show sess all" command
10975 - MINOR: mux-h1: Add the subscription events in "show fd" command
10976 - BUG/MEDIUM: h1: Get the h1m state when restarting the headers parsing
10977 - BUG/MINOR: cache/htx: Be sure to count partial trailers
10978 - BUG/MEDIUM: h1: In h1_init(), wake the tasklet instead of calling h1_recv().
10979 - BUG/MEDIUM: server: Defer the mux init until after xprt has been initialized.
10980 - MINOR: connections: Remove a stall comment.
10981 - BUG/MEDIUM: cli: make "show sess" really thread-safe
10982 - BUILD: add a new file "version.c" to carry version updates
10983 - MINOR: stream/htx: add the HTX flags output in "show sess all"
10984 - MINOR: stream/cli: fix the location of the waiting flag in "show sess all"
10985 - MINOR: stream/cli: report more info about the HTTP messages on "show sess all"
10986 - BUG/MINOR: lua: bad args are returned for Lua actions
10987 - BUG/MEDIUM: lua: dead lock when Lua tasks are trigerred
10988 - MINOR: htx: Add an helper function to get the max space usable for a block
10989 - MINOR: channel/htx: Add HTX version for some helper functions
10990 - BUG/MEDIUM: cache/htx: Respect the reserve when cached objects are served
10991 - BUG/MINOR: stats/htx: Respect the reserve when the stats page is dumped
10992 - DOC: regtest: make it clearer what the purpose of the "broken" series is
10993 - REGTEST: mailers: add new test for 'mailers' section
10994 - REGTEST: Add a reg test for health-checks over SSL/TLS.
10995 - BUG/MINOR: mux-h1: Close connection on shutr only when shutw was really done
10996 - MEDIUM: mux-h1: Clarify how shutr/shutw are handled
10997 - BUG/MINOR: compression: Disable it if another one is already in progress
10998 - BUG/MINOR: filters: Detect cache+compression config on legacy HTTP streams
10999 - BUG/MINOR: cache: Disable the cache if any compression filter precedes it
11000 - REGTEST: Add some informatoin to test results.
11001 - MINOR: htx: Add a function to truncate all blocks after a specific offset
11002 - MINOR: channel/htx: Add the HTX version of channel_truncate/erase
11003 - BUG/MINOR: proto_htx: Use HTX versions to truncate or erase a buffer
11004 - BUG/CRITICAL: mux-h2: re-check the frame length when PRIORITY is used
11005 - DOC: Fix typo in req.ssl_alpn example (commit 4afdd138424ab...)
11006 - DOC: http-request cache-use / http-response cache-store expects cache name
11007 - REGTEST: "capture (request|response)" regtest.
11008 - BUG/MINOR: lua/htx: Respect the reserve when data are send from an HTX applet
11009 - REGTEST: filters: add compression test
11010 - BUG/MEDIUM: init: Initialize idle_orphan_conns for first server in server-template
11011 - BUG/MEDIUM: ssl: Disable anti-replay protection and set max data with 0RTT.
11012 - DOC: Be a bit more explicit about allow-0rtt security implications.
11013 - MINOR: mux-h1: make the mux_h1_ops struct static
11014 - BUILD: makefile: add an EXTRA_OBJS variable to help build optional code
11015 - BUG/MEDIUM: connection: properly unregister the mux on failed initialization
11016 - BUG/MAJOR: cache: fix confusion between zero and uninitialized cache key
11017 - REGTESTS: test case for map_regm commit 271022150d
11018 - REGTESTS: Basic tests for concat,strcmp,word,field,ipmask converters
11019 - REGTESTS: Basic tests for using maps to redirect requests / select backend
11020 - DOC: REGTESTS README varnishtest -Dno-htx= define.
11021 - MINOR: spoe: Make the SPOE filter compatible with HTX proxies
11022 - MINOR: checks: Store the proxy in checks.
11023 - BUG/MEDIUM: checks: Avoid having an associated server for email checks.
11024 - REGTEST: Switch to vtest.
11025 - REGTEST: Adapt reg test doc files to vtest.
11026 - BUG/MEDIUM: h1: Make sure we destroy an inactive connectin that did shutw.
11027 - BUG/MINOR: base64: dec func ignores padding for output size checking
11028 - BUG/MEDIUM: ssl: missing allocation failure checks loading tls key file
11029 - MINOR: ssl: add support of aes256 bits ticket keys on file and cli.
11030 - BUG/MINOR: backend: don't use url_param_name as a hint for BE_LB_ALGO_PH
11031 - BUG/MINOR: backend: balance uri specific options were lost across defaults
11032 - BUG/MINOR: backend: BE_LB_LKUP_CHTREE is a value, not a bit
11033 - MINOR: backend: move url_param_name/len to lbprm.arg_str/len
11034 - MINOR: backend: make headers and RDP cookie also use arg_str/len
11035 - MINOR: backend: add new fields in lbprm to store more LB options
11036 - MINOR: backend: make the header hash use arg_opt1 for use_domain_only
11037 - MINOR: backend: remap the balance uri settings to lbprm.arg_opt{1,2,3}
11038 - MINOR: backend: move hash_balance_factor out of chash
11039 - MEDIUM: backend: move all LB algo parameters into an union
11040 - MINOR: backend: make the random algorithm support a number of draws
11041 - BUILD/MEDIUM: da: Necessary code changes for new buffer API.
11042 - BUG/MINOR: stick_table: Prevent conn_cur from underflowing
11043 - BUG: 51d: Changes to the buffer API in 1.9 were not applied to the 51Degrees code.
11044 - BUG/MEDIUM: stats: Get the right scope pointer depending on HTX is used or not
11045 - DOC: add a missing space in the documentation for bc_http_major
11046 - REGTEST: checks basic stats webpage functionality
11047 - BUG/MEDIUM: servers: Make assign_tproxy_address work when ALPN is set.
11048 - BUG/MEDIUM: connections: Add the CO_FL_CONNECTED flag if a send succeeded.
11049 - DOC: add github issue templates
11050 - MINOR: cfgparse: Extract some code to be re-used.
11051 - CLEANUP: cfgparse: Return asap from cfg_parse_peers().
11052 - CLEANUP: cfgparse: Code reindentation.
11053 - MINOR: cfgparse: Useless frontend initialization in "peers" sections.
11054 - MINOR: cfgparse: Rework peers frontend init.
11055 - MINOR: cfgparse: Simplication.
11056 - MINOR: cfgparse: Make "peer" lines be parsed as "server" lines.
11057 - MINOR: peers: Make outgoing connection to SSL/TLS peers work.
11058 - MINOR: cfgparse: SSL/TLS binding in "peers" sections.
11059 - DOC: peers: SSL/TLS documentation for "peers"
11060 - BUG/MINOR: startup: certain goto paths in init_pollers fail to free
11061 - BUG/MEDIUM: checks: fix recent regression on agent-check making it crash
11062 - BUG/MINOR: server: don't always trust srv_check_health when loading a server state
11063 - BUG/MINOR: check: Wake the check task if the check is finished in wake_srv_chk()
11064 - BUG/MEDIUM: ssl: Fix handling of TLS 1.3 KeyUpdate messages
11065 - DOC: mention the effect of nf_conntrack_tcp_loose on src/dst
11066 - BUG/MINOR: proto-htx: Return an error if all headers cannot be received at once
11067 - BUG/MEDIUM: mux-h2/htx: Respect the channel's reserve
11068 - BUG/MINOR: mux-h1: Apply the reserve on the channel's buffer only
11069 - BUG/MINOR: mux-h1: avoid copying output over itself in zero-copy
11070 - BUG/MAJOR: mux-h2: don't destroy the stream on failed allocation in h2_snd_buf()
11071 - BUG/MEDIUM: backend: also remove from idle list muxes that have no more room
11072 - BUG/MEDIUM: mux-h2: properly abort on trailers decoding errors
11073 - MINOR: h2: declare new sets of frame types
11074 - BUG/MINOR: mux-h2: CONTINUATION in closed state must always return GOAWAY
11075 - BUG/MINOR: mux-h2: headers-type frames in HREM are always a connection error
11076 - BUG/MINOR: mux-h2: make it possible to set the error code on an already closed stream
11077 - BUG/MINOR: hpack: return a compression error on invalid table size updates
11078 - MINOR: server: make sure pool-max-conn is >= -1
11079 - BUG/MINOR: stream: take care of synchronous errors when trying to send
11080 - CLEANUP: server: fix indentation mess on idle connections
11081 - BUG/MINOR: mux-h2: always check the stream ID limit in h2_avail_streams()
11082 - BUG/MINOR: mux-h2: refuse to allocate a stream with too high an ID
11083 - BUG/MEDIUM: backend: never try to attach to a mux having no more stream available
11084 - MINOR: server: add a max-reuse parameter
11085 - MINOR: mux-h2: always consider a server's max-reuse parameter
11086 - MEDIUM: stream-int: always mark pending outgoing SI_ST_CON
11087 - MINOR: stream: don't wait before retrying after a failed connection reuse
11088 - MEDIUM: h2: always parse and deduplicate the content-length header
11089 - BUG/MINOR: mux-h2: always compare content-length to the sum of DATA frames
11090 - CLEANUP: h2: Remove debug printf in mux_h2.c
11091 - MINOR: cfgparse: make the process/thread parser support a maximum value
11092 - MINOR: threads: make MAX_THREADS configurable at build time
11093 - DOC: nbthread is no longer experimental.
11094 - BUG/MINOR: listener: always fill the source address for accepted socketpairs
11095 - BUG/MINOR: mux-h2: do not report available outgoing streams after GOAWAY
11096 - BUG/MINOR: spoe: corrected fragmentation string size
11097 - BUG/MINOR: task: fix possibly missed event in inter-thread wakeups
11098 - BUG/MEDIUM: servers: Attempt to reuse an unfinished connection on retry.
11099 - BUG/MEDIUM: backend: always call si_detach_endpoint() on async connection failure
11100 - SCRIPTS: add the issue tracker URL to the announce script
11101 - MINOR: peers: Extract some code to be reused.
11102 - CLEANUP: peers: Indentation fixes.
11103 - MINOR: peers: send code factorization.
11104 - MINOR: peers: Add new functions to send code and reduce the I/O handler.
11105 - MEDIUM: peers: synchronizaiton code factorization to reduce the size of the I/O handler.
11106 - MINOR: peers: Move update receive code to reduce the size of the I/O handler.
11107 - MINOR: peers: Move ack, switch and definition receive code to reduce the size of the I/O handler.
11108 - MINOR: peers: Move high level receive code to reduce the size of I/O handler.
11109 - CLEANUP: peers: Be more generic.
11110 - MINOR: peers: move error handling to reduce the size of the I/O handler.
11111 - MINOR: peers: move messages treatment code to reduce the size of the I/O handler.
11112 - MINOR: peers: move send code to reduce the size of the I/O handler.
11113 - CLEANUP: peers: Remove useless statements.
11114 - MINOR: peers: move "hello" message treatment code to reduce the size of the I/O handler.
11115 - MINOR: peers: move peer initializations code to reduce the size of the I/O handler.
11116 - CLEANUP: peers: factor the error handling code in peer_treet_updatemsg()
11117 - CLEANUP: peers: factor error handling in peer_treat_definedmsg()
11118 - BUILD/MINOR: peers: shut up a build warning introduced during last cleanup
11119 - BUG/MEDIUM: mux-h2: only close connection on request frames on closed streams
11120 - CLEANUP: mux-h2: remove two useless but misleading assignments
11121 - BUG/MEDIUM: checks: Check that conn_install_mux succeeded.
11122 - BUG/MEDIUM: servers: Only destroy a conn_stream we just allocated.
11123 - BUG/MEDIUM: servers: Don't add an incomplete conn to the server idle list.
11124 - BUG/MEDIUM: checks: Don't try to set ALPN if connection failed.
11125 - BUG/MEDIUM: h2: In h2_send(), stop the loop if we failed to alloc a buf.
11126 - BUG/MEDIUM: peers: Handle mux creation failure.
11127 - BUG/MEDIUM: servers: Close the connection if we failed to install the mux.
11128 - BUG/MEDIUM: compression: Rewrite strong ETags
11129 - BUG/MINOR: deinit: tcp_rep.inspect_rules not deinit, add to deinit
11130 - CLEANUP: mux-h2: remove misleading leftover test on h2s' nullity
11131 - BUG/MEDIUM: mux-h2: wake up flow-controlled streams on initial window update
11132 - BUG/MEDIUM: mux-h2: fix two half-closed to closed transitions
11133 - BUG/MEDIUM: mux-h2: make sure never to send GOAWAY on too old streams
11134 - BUG/MEDIUM: mux-h2: do not abort HEADERS frame before decoding them
11135 - BUG/MINOR: mux-h2: make sure response HEADERS are not received in other states than OPEN and HLOC
11136 - MINOR: h2: add a generic frame checker
11137 - MEDIUM: mux-h2: check the frame validity before considering the stream state
11138 - CLEANUP: mux-h2: remove stream ID and frame length checks from the frame parsers
11139 - BUG/MINOR: mux-h2: make sure request trailers on aborted streams don't break the connection
11140 - DOC: compression: Update the reasons for disabled compression
11141 - BUG/MEDIUM: buffer: Make sure b_is_null handles buffers waiting for allocation.
11142 - DOC: htx: make it clear that htxbuf() and htx_from_buf() always return valid pointers
11143 - MINOR: htx: never check for null htx pointer in htx_is_{,not_}empty()
11144 - MINOR: mux-h2: consistently rely on the htx variable to detect the mode
11145 - BUG/MEDIUM: peers: Peer addresses parsing broken.
11146 - BUG/MEDIUM: mux-h1: Don't add "transfer-encoding" if message-body is forbidden
11147 - BUG/MEDIUM: connections: Don't forget to remove CO_FL_SESS_IDLE.
11148 - BUG/MINOR: stream: don't close the front connection when facing a backend error
11149 - BUG/MEDIUM: mux-h2: wait for the mux buffer to be empty before closing the connection
11150 - MINOR: stream-int: add a new flag to mention that we want the connection to be killed
11151 - MINOR: connstream: have a new flag CS_FL_KILL_CONN to kill a connection
11152 - BUG/MEDIUM: mux-h2: do not close the connection on aborted streams
11153 - BUG/MINOR: server: fix logic flaw in idle connection list management
11154 - MINOR: mux-h2: max-concurrent-streams should be unsigned
11155 - MINOR: mux-h2: make sure to only check concurrency limit on the frontend
11156 - MINOR: mux-h2: learn and store the peer's advertised MAX_CONCURRENT_STREAMS setting
11157 - BUG/MEDIUM: mux-h2: properly consider the peer's advertised max-concurrent-streams
11158 - MINOR: xref: Add missing barriers.
11159 - MINOR: muxes: Don't bother to LIST_DEL(&conn->list) before calling conn_free().
11160 - MINOR: debug: Add an option that causes random allocation failures.
11161 - BUG/MEDIUM: backend: always release the previous connection into its own target srv_list
11162 - BUG/MEDIUM: htx: check the HTX compatibility in dynamic use-backend rules
11163 - BUG/MINOR: tune.fail-alloc: Don't forget to initialize ret.
11164 - BUG/MINOR: backend: check srv_conn before dereferencing it
11165 - BUG/MEDIUM: mux-h2: always omit :scheme and :path for the CONNECT method
11166 - BUG/MEDIUM: mux-h2: always set :authority on request output
11167 - BUG/MEDIUM: stream: Don't forget to free s->unique_id in stream_free().
11168 - BUG/MINOR: threads: fix the process range of thread masks
11169 - BUG/MINOR: config: fix bind line thread mask validation
11170 - CLEANUP: threads: fix misleading comment about all_threads_mask
11171 - CLEANUP: threads: use nbits to calculate the thread mask
11172 - OPTIM: listener: optimize cache-line packing for struct listener
11173 - MINOR: tools: improve the popcount() operation
11174 - MINOR: config: keep an all_proc_mask like we have all_threads_mask
11175 - MINOR: global: add proc_mask() and thread_mask()
11176 - MINOR: config: simplify bind_proc processing using proc_mask()
11177 - MINOR: threads: make use of thread_mask() to simplify some thread calculations
11178 - BUG/MINOR: compression: properly report compression stats in HTX mode
11179 - BUG/MINOR: task: close a tiny race in the inter-thread wakeup
11180 - BUG/MAJOR: config: verify that targets of track-sc and stick rules are present
11181 - BUG/MAJOR: spoe: verify that backends used by SPOE cover all their callers' processes
11182 - BUG/MAJOR: htx/backend: Make all tests on HTTP messages compatible with HTX
11183 - BUG/MINOR: config: make sure to count the error on incorrect track-sc/stick rules
11184 - DOC: ssl: Clarify when pre TLSv1.3 cipher can be used
11185 - DOC: ssl: Stop documenting ciphers example to use
11186 - BUG/MINOR: spoe: do not assume agent->rt is valid on exit
11187 - BUG/MINOR: lua: initialize the correct idle conn lists for the SSL sockets
11188 - BUG/MEDIUM: spoe: initialization depending on nbthread must be done last
11189 - BUG/MEDIUM: server: initialize the idle conns list after parsing the config
11190 - BUG/MEDIUM: server: initialize the orphaned conns lists and tasks at the end
11191 - MINOR: config: make MAX_PROCS configurable at build time
11192 - BUG/MAJOR: spoe: Don't try to get agent config during SPOP healthcheck
11193 - BUG/MINOR: config: Reinforce validity check when a process number is parsed
11194 - BUG/MEDIUM: peers: check that p->srv actually exists before using p->srv->use_ssl
11195 - CONTRIB: contrib/prometheus-exporter: Add a Prometheus exporter for HAProxy
11196 - BUG/MINOR: mux-h1: verify the request's version before dropping connection: keep-alive
11197 - BUG: 51d: In Hash Trie, multi header matching was affected by the header names stored globaly.
11198 - MEDIUM: 51d: Enabled multi threaded operation in the 51Degrees module.
11199 - BUG/MAJOR: stream: avoid double free on unique_id
11200 - BUILD/MINOR: stream: avoid a build warning with threads disabled
11201 - BUILD/MINOR: tools: fix build warning in the date conversion functions
11202 - BUILD/MINOR: peers: remove an impossible null test in intencode()
11203 - BUILD/MINOR: htx: fix some potential null-deref warnings with http_find_stline
11204 - BUG/MEDIUM: peers: Missing peer initializations.
11205 - BUG/MEDIUM: http_fetch: fix the "base" and "base32" fetch methods in HTX mode
11206 - BUG/MEDIUM: proto_htx: Fix data size update if end of the cookie is removed
11207 - BUG/MEDIUM: http_fetch: fix "req.body_len" and "req.body_size" fetch methods in HTX mode
11208 - BUILD/MEDIUM: initcall: Fix build on MacOS.
11209 - BUG/MEDIUM: mux-h2/htx: Always set CS flags before exiting h2_rcv_buf()
11210 - MINOR: h2/htx: Set the flag HTX_SL_F_BODYLESS for messages without body
11211 - BUG/MINOR: mux-h1: Add "transfer-encoding" header on outgoing requests if needed
11212 - BUG/MINOR: mux-h2: Don't add ":status" pseudo-header on trailers
11213 - BUG/MINOR: proto-htx: Consider a XFER_LEN message as chunked by default
11214 - BUG/MEDIUM: h2/htx: Correctly handle interim responses when HTX is enabled
11215 - MINOR: mux-h2: Set HTX extra value when possible
11216 - BUG/MEDIUM: htx: count the amount of copied data towards the final count
11217 - MINOR: mux-h2: make the H2 MAX_FRAME_SIZE setting configurable
11218 - BUG/MEDIUM: mux-h2/htx: send an empty DATA frame on empty HTX trailers
11219 - BUG/MEDIUM: servers: Use atomic operations when handling curr_idle_conns.
11220 - BUG/MEDIUM: servers: Add a per-thread counter of idle connections.
11221 - MINOR: fd: add a new my_closefrom() function to close all FDs
11222 - MINOR: checks: use my_closefrom() to close all FDs
11223 - MINOR: fd: implement an optimised my_closefrom() function
11224 - BUG/MINOR: fd: make sure my_closefrom() doesn't miss some FDs
11225 - BUG/MAJOR: fd/threads, task/threads: ensure all spin locks are unlocked
11226 - BUG/MAJOR: listener: Make sure the listener exist before using it.
11227 - MINOR: fd: Use closefrom() as my_closefrom() if supported.
11228 - BUG/MEDIUM: mux-h1: Report the right amount of data xferred in h1_rcv_buf()
11229 - BUG/MINOR: channel: Set CF_WROTE_DATA when outgoing data are skipped
11230 - MINOR: htx: Add function to drain data from an HTX message
11231 - MINOR: channel/htx: Add function to skips output bytes from an HTX channel
11232 - BUG/MAJOR: cache/htx: Set the start-line offset when a cached object is served
11233 - BUG/MEDIUM: cache: Get objects from the cache only for GET and HEAD requests
11234 - BUG/MINOR: cache/htx: Return only the headers of cached objects to HEAD requests
11235 - BUG/MINOR: mux-h1: Always initilize h1m variable in h1_process_input()
11236 - BUG/MEDIUM: proto_htx: Fix functions applying regex filters on HTX messages
11237 - BUG/MEDIUM: h2: advertise to servers that we don't support push
11238 - MINOR: standard: Add a function to parse uints (dotted notation).
11239 - MINOR: arg: Add support for ARGT_PBUF_FNUM arg type.
11240 - MINOR: http_fetch: add "req.ungrpc" sample fetch for gRPC.
11241 - MINOR: sample: Add two sample converters for protocol buffers.
11242 - DOC: sample: Add gRPC related documentation.
11243
Willy Tarreaufba74ea2018-12-22 11:19:45 +0100112442018/12/22 : 2.0-dev0
11245 - BUG/MAJOR: connections: Close the connection before freeing it.
11246 - REGTEST: Require the option LUA to run lua tests
11247 - REGTEST: script: Process script arguments before everything else
11248 - REGTEST: script: Evaluate the varnishtest command to allow quoted parameters
11249 - REGTEST: script: Add the option --clean to remove previous log direcotries
11250 - REGTEST: script: Add the option --debug to show logs on standard ouput
11251 - REGTEST: script: Add the option --keep-logs to keep all log directories
11252 - REGTEST: script: Add the option --use-htx to enable the HTX in regtests
11253 - REGTEST: script: Print only errors in the results report
11254 - REGTEST: Add option to use HTX prefixed by the macro 'no-htx'
11255 - REGTEST: Make reg-tests target support argument.
11256 - REGTEST: Fix a typo about barrier type.
11257 - REGTEST: Be less Linux specific with a syslog regex.
11258 - REGTEST: Missing enclosing quotes for ${tmpdir} macro.
11259 - REGTEST: Exclude freebsd target for some reg tests.
11260 - BUG/MEDIUM: h2: Don't forget to quit the sending_list if SUB_CALL_UNSUBSCRIBE.
11261 - BUG/MEDIUM: mux-h2: Don't forget to quit the send list on error reports
11262 - BUG/MEDIUM: dns: Don't prevent reading the last byte of the payload in dns_validate_response()
11263 - BUG/MEDIUM: dns: overflowed dns name start position causing invalid dns error
11264 - BUG/MINOR: compression/htx: Don't compress responses with unknown body length
11265 - BUG/MINOR: compression/htx: Don't add the last block of data if it is empty
11266 - MEDIUM: mux_h1: Implement h1_show_fd.
11267 - REGTEST: script: Add support of alternatives in requited options list
11268 - REGTEST: Add a basic test for the compression
11269 - BUG/MEDIUM: mux-h2: don't needlessly wake up the demux on short frames
11270 - REGTEST: A basic test for "http-buffer-request"
11271 - BUG/MEDIUM: server: Also copy "check-sni" for server templates.
11272 - MINOR: ssl: Add ssl_sock_set_alpn().
11273 - MEDIUM: checks: Add check-alpn.
11274 - wip
11275
Willy Tarreau82230502018-12-19 19:13:17 +0100112762018/12/19 : 1.9.0
11277 - BUG/MEDIUM: compression: Use the right buffer pointers to compress input data
11278 - BUG/MINOR: mux_pt: Set CS_FL_WANT_ROOM when count is zero in rcv_buf() callback
11279 - BUG/MEDIUM: connection: Add a new CS_FL_ERR_PENDING flag to conn_streams.
11280 - CONTRIB: debug: teach the "flags" utility about new conn_stream flags
11281 - BUG/MEDIUM: stream-int: always clear CS_FL_WANT_ROOM before receiving
11282 - BUG/MEDIUM: mux-h2: also restart demuxing when data are pending in demux
11283 - BUG/MEDIUM: mux-h2: restart demuxing as soon as demux data are available
11284 - BUG/MEDIUM: h2: fix aggregated cookie length computation in HTX mode
11285 - MINOR: mux-h2: report more h2c, last h2s and cs information on "show fd"
11286 - CONTRIB: debug: report stream-int's flag SI_FL_CLEAN_ABRT
11287 - MINOR: cli/stream: add the conn_stream in "show sess" output
11288 - BUG/MINOR: mux-h2: don't report a fantom h2s in "show fd"
11289 - BUG/MINOR: cli/fd: don't isolate the thread for each individual fd
11290 - MINOR: objtype: report a few missing types in names and base pointers
11291 - BUG/MEDIUM: mux-h2: make sure to report synchronous errors after EOS
11292 - BUG/MEDIUM: mux-h2: report asynchronous errors in h2_wake_some_streams()
11293 - BUG/MEDIUM: mux-h2: make sure the demux also wakes streams up on errors
11294 - BUG/MINOR: mux-h1: report the correct frontend in error captures
11295 - BUG/MEDIUM: stream-int: also wake the stream up on end of transfer
11296 - MEDIUM: h2: properly check and deduplicate the content-length header in HTX
11297 - BUG/MEDIUM: stream: Forward the right amount of data before infinite forwarding
11298 - BUG/MINOR: proto_htx: Call the HTX version of the function managing client cookies
11299 - BUG/MEDIUM: lua/htx: Handle EOM in receive/get_line calls in HTTP applets
11300 - BUG/MINOR: lua: Return an error if a legacy HTTP applet doesn't send anything
11301 - MINOR: compression: Remove the thread_local variable buf_output
11302 - CLEANUP: connection: rename subscription events values and event field
11303 - CLEANUP: connection: rename conn->mux_ctx to conn->ctx
11304 - MINOR: connection: remove an unwelcome dependency on struct stream
11305 - CLEANUP: stream-int: consistently call the si/stream_int functions
11306 - BUG/MEDIUM: h1: Don't shutw/shutr the connection if we have keepalive.
11307 - BUG/MEDIUM: H2: Make sure htx is set even on empty frames.
11308 - BUG/MEDIUM: mux-h2: pass CS_FL_ERR_PENDING to h2_wake_some_streams()
11309 - MEDIUM: stream-int: always consider all CS errors on the send side
11310 - BUG/MEDIUM: h2: Make sure we don't set CS_FL_ERROR if there's still data.
11311 - CLEANUP: mux-h2: implement h2s_notify_{send,recv} to report events to subscribers
11312 - MINOR: mux-h2: add a new function h2s_alert() to call the data layer
11313 - BUG/MEDIUM: mux-h2: make use of h2s_alert() to report aborts
11314 - MINOR: connection: add cs_set_error() to set the error bits
11315 - CLEANUP: mux-h2: make use of cs_set_error()
11316 - BUG/MINOR: mux-h2: make sure we check the conn_stream in early data
11317 - BUG/MEDIUM: h2: Don't wait for flow control if the connection had a shutr.
11318 - MINOR: cli/show_fd: report that a connection is back or not
11319 - SCRIPTS: add the slack channel URL to the announce script
11320 - CLEANUP: remove my name and address from the copyright banner
11321 - DOC: mention in the readme that 1.9 is a stable version now
11322
Willy Tarreau2a7d6502018-12-16 22:35:06 +0100113232018/12/16 : 1.9-dev11
11324 - BUG/MEDIUM: connection: Don't use the provided conn_stream if it was tried.
11325 - REGTEST/MINOR: remove double body specification for server txresp
11326 - BUG/MEDIUM: connections: Remove error flags when retrying.
11327 - REGTEST/MINOR: skip seamless-reload test with abns socket on freebsd
11328 - REGTEST/MINOR: remove health-check that can make the test fail
11329 - DOC: clarify that check-sni needs an argument.
11330 - DOC: refer to check-sni in the documentation of sni
11331 - BUG/MEDIUM: mux-h2: fix encoding of non-GET/POST methods
11332 - BUG/MINOR: mux-h1: Fix conn_mode processing for headerless outgoing messages
11333 - BUG/MEDIUM: mux-h1: Add a BUSY mode to not loop on pipelinned requests
11334 - BUG/MEDIUM: mux-h1: Don't loop on the headers parsing if the read0 was received
11335 - BUG/MEDIUM: htx: Always do a defrag if a block value is replace by a bigger one
11336 - BUG/MEDIUM: mux-h2: Don't forget to set the CS_FL_EOS flag with htx.
11337 - BUG/MINOR: hpack: fix off-by-one in header name encoding length calculation
11338 - CLEANUP: hpack: no need to include chunk.h, only include buf.h
11339 - MINOR: hpack: simplify the len to bytes conversion
11340 - MINOR: hpack: use ist2bin() to copy header names in hpack_encode_header()
11341 - MINOR: hpack: optimize header encoding for short names
11342 - CONTRIB: hpack: add a compressed stream generator for the encoder
11343 - MEDIUM: hpack: make it possible to encode any static header name
11344 - MINOR: hpack: move the length computation and encoding functions to .h
11345 - MINOR: hpack: provide a function to encode a short indexed header
11346 - MINOR: hpack: provide a function to encode a long indexed header
11347 - MINOR: hpack: provide new functions to encode the ":status" header
11348 - MEDIUM: mux-h2: make use of standard HPACK encoding functions for the status
11349 - MINOR: hpack: provide a function to encode an HTTP method
11350 - MEDIUM: mux-h2: make use of hpack_encode_method() to encode the method
11351 - MINOR: hpack: provide a function to encode an HTTP scheme
11352 - MEDIUM: mux-h2: make use of hpack_encode_scheme() to encode the scheme
11353 - MINOR: hpack: provide a function to encode an HTTP path
11354 - MEDIUM: mux-h2: make use of hpack_encode_path() to encode the path
11355 - REGTEST: add the HTTP rules test involving HTX processing
11356 - REORG: connection: centralize the conn_set_{tos,mark,quickack} functions
11357 - MEDIUM: cli: rework the CLI proxy parser
11358 - MINOR: cli: parse prompt command in the CLI proxy
11359 - MINOR: cli: implements 'quit' in the CLI proxy
11360 - BUG/MINOR: cli: wait for payload data even without prompt
11361 - MEDIUM: cli: handle payload in CLI proxy
11362 - MINOR: cli: use pcli_flags for prompt activation
11363 - MINOR: compression: Rename the function check_legacy_http_comp_flt()
11364 - MINOR: cache/htx: Don't use the same cache on HTX and legacy HTTP proxies
11365 - MINOR: cache: Register the cache as a data filter only if response is cacheable
11366 - MEDIUM: cache/htx: Add the HTX support into the cache
11367 - MINOR: cache: Improve and simplify the cache configuration check
11368 - MINOR: filters: Export the name of known filters
11369 - MEDIUM: cache/compression: Add a way to safely combined compression and cache
11370 - MEDIUM: cache: Require an explicit filter declaration if other filters are used
11371 - REORG: htx: merge types+proto into common/htx.h
11372 - REORG: http: create http_msg.c to place there some legacy HTTP parts
11373 - REORG: h1: move legacy http functions to http_msg.c
11374 - REORG: h1: move the h1_state definition to proto_http
11375 - CLEANUP: h1: remove some occurrences of unneeded h1.h inclusions
11376 - REORG: h1: merge types+proto into common/h1.h
11377 - CLEANUP: stream: remove SF_TUNNEL, SF_INITIALIZED, SF_CONN_TAR
11378 - MEDIUM: mux-h1: implement true zero-copy of DATA blocks
11379 - MINOR: config: round up global.tune.bufsize to the next multiple of 2 void*
11380 - BUG/MINOR: mux-h2: refrain from muxing during the preface
11381 - BUG/MINOR: mux-h2: advertise a larger connection window size
11382 - DOC: master CLI documentation in management.txt
11383 - MINOR: mux-h2: avoid copying large blocks into full buffers
11384 - MEDIUM: mux-h2: implement true zero-copy send of large HTX DATA blocks
11385 - MINOR: mux-h2: force reads to be HTX-aligned in HTX mode
11386 - MINOR: cli: change 'show proc' output of old processes
11387 - BUG/MEDIUM: mux-h1: Fix the zero-copy on output for chunked messages
11388 - BUG: dns: Prevent stack-exhaustion via recursion loop in dns_read_name
11389 - BUG: dns: Prevent out-of-bounds read in dns_read_name()
11390 - BUG: dns: Prevent out-of-bounds read in dns_validate_dns_response()
11391 - BUG: dns: Fix out-of-bounds read via signedness error in dns_validate_dns_response()
11392 - BUG: dns: Fix off-by-one write in dns_validate_dns_response()
11393 - REGTEST: the cache regtest requires haproxy 1.9
11394 - MEDIUM: cli: store CLI level in the appctx
11395 - MEDIUM: cli: show and change CLI permissions
11396 - CLEANUP: cli: use dedicated define instead of appctx ones
11397 - MEDIUM: cli: handle CLI level from the master CLI
11398 - BUG/MEDIUM: cli: handle correctly prefix and payload
11399 - BUILD: Makefile: Implements the help target
11400 - REGTESTS: adjust the http-rules regtest to support window updates
11401 - BUG/MEDIUM: connections: Remove CS_FL_EOS | CS_FL_REOS on retry.
11402 - BUG/MEDIUM: stream_interface: Don't report read0 if we were not connected.
11403 - BUG/MEDIUM: connection: Just make sure we closed the fd on connection failure.
11404 - MEDIUM: mux: Add an optional "reset" method.
11405 - BUG/MEDIUM: mux-h1: Fix loop if server closes its connection with unparsed data
11406 - MINOR: mux-h1: Add helper functions to wake a stream from recv or send
11407 - BUG/MEDIUM: mux-h1: Wake the stream for send once the connection is established
11408 - BUG/MEDIUM: connections: Don't attempt to reuse an unusable connection.
11409 - MEDIUM: htx: Try to take a connection over if it has no owner.
11410 - REGTEST: Reg testing improvements.
11411 - REGTEST: Add a first test for health-checks.
11412 - REGTEST: Reg test for "check" health-check option.
11413 - REGTEST: level 1 health-check test 2.
11414 - REGTEST: Add miscellaneous reg tests for health-checks.
11415 - REGTEST: add a few HTTP messaging tests
11416 - MINOR: lb: make the leastconn algorithm more accurate
11417 - REGTEST: fix missing space in checks/s00001
11418 - REGTEST: http-messaging: add "option http-buffer-request" for H2 tests
11419 - BUG/MEDIUM: cache: fix random crash on filter parser's error path
11420 - MINOR: connection: realign empty buffers in muxes, not transport layers
11421 - MINOR: mux_h1/h2: simplify the zero-copy Rx alignment
11422 - MINOR: backend: count the number of connect and reuse per server and per backend
11423 - BUG/MINOR: stats: fix inversion of failed header rewrites and other statuses
11424 - MINOR: tools: increase the number of ITOA strings to 16
11425 - MINOR: cache: report the number of cache lookups and cache hits
11426 - MEDIUM: tasks: check the global task mask instead of the thread number
11427 - MINOR: mworker: set all_threads_mask and pid_bit to 1
11428 - BUG/MINOR: proto_htx: Fix htx_res_set_status to also set the reason
11429 - BUG/MINOR: stats: Parse post data for HTX streams
11430 - MINOR: payload/htx: Adapt smp_fetch_len to be HTX aware
11431 - MINOR: http_fecth: Implement body_len and body_size sample fetches for the HTX
11432 - MAJOR: lua: Forbid calls to Channel functions for LUA scripts in HTTP proxies
11433 - MEDIUM: lua/htx: Adapt functions of the HTTP to be compatible with HTX
11434 - MINOR: lua/htx: Adapt the functions get_in_length and is_full to be HTX aware
11435 - MAJOR: lua/htx: Adapt HTTP applets to support HTX messages
11436 - MINOR: lua: Remove useless check on the messages state in HTTP functions
11437 - BUG/MEDIUM: htx: When performing zero-copy, start from the right offset.
11438 - BUG/MINOR: mworker: don't use unitialized mworker_proc struct
11439 - MINOR: mworker/cli: indicate in the master prompt when a reload failed
11440 - MINOR: cli: implements 'reload' on master CLI
11441 - BUG/MEDIUM: log: Don't call sample_fetch_as_type if we don't have a stream.
11442 - BUG/MEDIUM: mux-h1: make sure we always have at least one HTX block to send
11443 - BUG/MAJOR: backend: only update server's counters when the server exists
11444 - MINOR: tools: preset the port of fd-based "sockets" to zero
11445 - BUG/MINOR: log: fix logging to both FD and IP
11446 - REGTEST: Add a reg test for HTTP cookies.
11447 - BUILD: ssl: Fix compilation without deprecated OpenSSL 1.1 APIs
11448 - BUILD: thread: properly report multi-thread support
11449 - BUG/MINOR: logs: leave startup-logs global and not per-thread
11450 - BUG/MEDIUM: threads: don't close the thread waker pipe if not init
11451 - BUG/MAJOR: compression/cache: Make it really works with these both filters
11452 - BUG/MEDIUM: h2: Don't forget to destroy the h2s after deferred shut.
11453 - MEDIUM: proxy: Set http-reuse safe as default.
11454 - MEDIUM: servers: Add a command to limit the number of idling connections.
11455 - MEDIUM: servers: Replace idle-timeout with pool-purge-delay.
11456 - MEDIUM: mux: Destroy the stream before trying to add the conn to the idle list.
11457 - MEDIUM: mux: provide the session to the init() and attach() method.
11458 - MEDIUM: sessions: Don't keep an infinite number of idling connections.
11459 - MEDIUM: servers: Be more agressive when adding H2 connection to idle lists.
11460 - MEDIUM: mux_h2: Always set CS_FL_NOT_FIRST for new conn_streams.
11461 - BUG/MEDIUM: htx/cache: use the correct class of error codes on abort
11462 - BUG/MINOR: cache: also consider CF_SHUTR to abort delivery
11463 - MINOR: pools: Cast to volatile int * instead of int *.
11464 - MINOR: debug: make the ABORT_NOW macro use a volatile int
11465 - BUG/MEDIUM: h2: Don't destroy the h2s if it still has a cs attached.
11466 - BUG/MEDIUM: mux-h1: don't try to process an empty input buffer
11467 - DOC: clarify the agent-check status line syntax
11468 - BUG/MAJOR: hpack: fix length check for short names encoding
11469 - DOC: split the README into README + INSTALL
11470
Willy Tarreau72e92272018-12-08 16:20:55 +0100114712018/12/08 : 1.9-dev10
11472 - MINOR: htx: Rename functions htx_*_to_str() to be H1 specific
11473 - BUG/MINOR: htx: Force HTTP/1.1 on H1 formatting when version is 1.1 or above
11474 - BUG/MINOR: fix ssl_fc_alpn and actually add ssl_bc_alpn
11475 - BUG/MEDIUM: mworker: stop proxies which have no listener in the master
11476 - BUG/MEDIUM: h1: Destroy a connection after detach if it has no owner.
11477 - BUG/MEDIUM: h2: Don't forget to wake the tasklet after shutr/shutw.
11478 - BUG/MINOR: flt_trace/compression: Use the right flag to add the HTX support
11479 - BUG/MEDIUM: stream_interface: Make REALLY sure we read all the data.
11480 - MEDIUM: mux-h1: Revamp the way subscriptions are handled.
11481 - BUG/MEDIUM: mux-h1: Always set CS_FL_RCV_MORE when data are received in h1_recv()
11482 - MINOR: mux-h1: Make sure to return 1 in h1_recv() when needed
11483 - BUG/MEDIUM: mux-h1: Release the mux H1 in h1_process() if there is no h1s
11484 - BUG/MINOR: proto_htx: Truncate the request when an error is detected
11485 - BUG/MEDIUM: h2: When sending in HTX, make sure the caller knows we sent all.
11486 - BUG/MEDIUM: mux-h2: properly update the window size in HTX mode
11487 - BUG/MEDIUM: mux-h2: make sure to always report HTX EOM when consumed by headers
11488 - BUG/MEDIUM: mux-h2: stop sending HTX once the mux is blocked
11489 - BUG/MEDIUM: mux-h2: don't send more HTX data than requested
11490 - MINOR: mux-h2: stop on non-DATA and non-EOM HTX blocks
11491 - BUG/MEDIUM: h1: Correctly report used data with no len.
11492 - MEDIUM: h1: Realign the ibuf before calling rcv_buf if needed.
11493 - BUG/MEDIUM: mux_pt: Always set CS_FL_RCV_MORE.
11494 - MINOR: htx: make htx_from_buf() adjust the size only on new buffers
11495 - MINOR: htx: add buf_room_for_htx_data() to help optimize buffer transfers
11496 - MEDIUM: mux-h1: make use of buf_room_for_htx_data() instead of b_room()
11497 - MEDIUM: mux-h1: attempt to zero-copy Rx DATA transfers
11498 - MEDIUM: mux-h1: avoid a double copy on the Tx path whenever possible
11499 - BUG/MEDIUM: stream-int: don't mark as blocked an empty buffer on Rx
11500 - BUG/MINOR: mux-h1: Check h1m flags to set the server conn_mode on request path
11501 - MEDIUM: htx: Rework conversion from a buffer to an htx structure
11502 - MEDIUM: channel/htx: Add functions for forward HTX data
11503 - MINOR: mux-h1: Don't adjust anymore the amount of data sent in h1_snd_buf()
11504 - CLEANUP: htx: Fix indentation here and there in HTX files
11505 - MINOR: mux-h1: Allow partial data consumption during outgoing data processing
11506 - BUG/MEDIUM: mux-h2: use the correct offset for the HTX start line
11507 - BUG/MEDIUM: mux-h2: stop sending using HTX on errors
11508 - MINOR: mux-h1: Drain obuf if the output is closed after sending data
11509 - BUG/MEDIUM: mworker: stop every tasks in the master
11510 - BUG/MEDIUM: htx: Set the right start-line offset after a defrag
11511 - BUG/MEDIUM: stream: Don't dereference s->txn when it is not there yet.
11512 - BUG/MEDIUM: connections: Reuse an already attached conn_stream.
11513 - MINOR: stream-int: add a new blocking condition on the remote connection
11514 - BUG/MEDIUM: stream-int: don't attempt to receive if the connection is not established
11515 - BUG/MEDIUM: lua: block on remote connection establishment
11516 - BUG/MEDIUM: mworker: fix several typos in mworker_cleantasks()
11517 - SCRIPTS/REGTEST: merge grep+sed into sed in run-regtests
11518 - BUG/MEDIUM: connections: Split CS_FL_RCV_MORE into 2 flags.
11519 - BUG/MEDIUM: h1: Don't free the connection if it's an outgoing connection.
11520 - BUG/MEDIUM: h1: Set CS_FL_REOS if we had a read0.
11521 - BUG/MEDIUM: mux-h1: Be sure to have a conn_stream to set CS_FL_REOS in h1_recv
11522 - REGTEST: Move LUA reg test 4 to level 1.
11523 - MINOR: ist: add functions to copy/uppercase/lowercase into a buffer or string
11524 - MEDIUM: ist: always turn header names to lower case
11525 - MINOR: h2: don't turn HTX header names to lower case anymore
11526 - MEDIUM: ist: use local conversion arrays to case conversion
11527 - MINOR: htx: switch to case sensitive search of lower case header names
11528 - MINOR: mux-h1: Set CS_FL_EOS when read0 is detected and no data are pending
11529 - BUG/MINOR: stream-int: Process read0 even if no data was received in si_cs_recv
11530 - REGTEST: fix the Lua test file name in test lua/h00002 :-)
11531 - REGTEST: add a basic test for HTTP rules manipulating headers
11532 - BUG/MEDIUM: sample: Don't treat SMP_T_METH as SMP_T_STR.
11533 - MINOR: sample: add bc_http_major
11534 - BUG/MEDIUM: htx: fix typo in htx_replace_stline() making it fail all the time
11535 - REGTEST: make the HTTP rules test compatible with HTTP/2 as well
11536 - BUG/MEDIUM: h2: Don't try to chunk data when using HTX.
11537 - MINOR: compiler: add a new macro ALREADY_CHECKED()
11538 - BUILD: h2: mark the start line already checked to avoid warnings
11539 - BUG/MINOR: mux-h1: Remove the connection header when it is useless
11540
Willy Tarreauda7e3be2018-12-02 19:31:37 +0100115412018/12/02 : 1.9-dev9
11542 - BUILD/MINOR: ssl: fix build with non-alpn/non-npn libssl
11543 - BUG/MINOR: mworker: Do not attempt to close(2) fd -1
11544 - BUILD: compression: fix build error with DEFAULT_MAXZLIBMEM
11545 - MINOR: compression: always create the compression pool
11546 - BUG/MEDIUM: mworker: fix FD leak upon reload
11547 - BUILD: htx: fix fprintf format inconsistency on 32-bit platforms
11548 - BUILD: buffers: buf.h requires unistd to get ssize_t on libmusl
11549 - MINOR: initcall: introduce a way to register init functions to call at boot
11550 - MINOR: init: process all initcalls in order at boot time
11551 - MEDIUM: init: convert all trivial registration calls to initcalls
11552 - MINOR: thread: provide a set of lock initialisers
11553 - MINOR: threads: add new macros to declare self-initializing locks
11554 - MEDIUM: init: use self-initializing spinlocks and rwlocks
11555 - MINOR: initcall: apply initcall to all register_build_opts() calls
11556 - MINOR: initcall: use initcalls for most post_{check,deinit} and per_thread*
11557 - MINOR: initcall: use initcalls for section parsers
11558 - MINOR: memory: add a callback function to create a pool
11559 - MEDIUM: init: use initcall for all fixed size pool creations
11560 - MEDIUM: memory: use pool_destroy_all() to destroy all pools on deinit()
11561 - MEDIUM: initcall: use initcalls for a few initialization functions
11562 - MEDIUM: memory: make the pool cache an array and not a thread_local
11563 - MINOR: ssl: free ctx when libssl doesn't support NPN
11564 - BUG/MINOR: proto_htx: only mark connections private if NTLM is detected
11565 - MINOR: h2: make struct h2_ops static
11566 - BUG/MEDIUM: mworker: avoid leak of client socket
11567 - REORG: mworker: declare master variable in global.h
11568 - BUG/MEDIUM: listeners: CLOEXEC flag is not correctly set
11569 - CLEANUP: http: Fix typo in init_http's comment
11570 - BUILD: Makefile: Disable -Wcast-function-type if it exists.
11571 - BUG/MEDIUM: h2: Don't bogusly error if the previous stream was closed.
11572 - REGTEST/MINOR: script: add run-regtests.sh script
11573 - REGTEST: Add a basic test for the cache.
11574 - BUG/MEDIUM: mux_pt: Don't forget to unsubscribe() on attach.
11575 - BUG/MINOR: ssl: ssl_sock_parse_clienthello ignores session id
11576 - BUG/MEDIUM: connections: Wake the stream once the mux is chosen.
11577 - BUG/MEDIUM: connections: Don't forget to detach the connection from the SI.
11578 - BUG/MEDIUM: stream_interface: Don't check if the handshake is done.
11579 - BUG/MEDIUM: stream_interface: Make sure we read all the data available.
11580 - BUG/MEDIUM: h2: Call h2_process() if there's an error on the connection.
11581 - REGTEST: Fix several issues.
11582 - REGTEST: lua: check socket functionality from a lua-task
11583 - BUG/MEDIUM: session: Remove the session from the session_list in session_free.
11584 - BUG/MEDIUM: streams: Don't assume we have a CS in sess_update_st_con_tcp.
11585 - BUG/MEDIUM: connections: Don't assume we have a mux in connect_server().
11586 - BUG/MEDIUM: connections: Remove the connection from the idle list before destroy.
11587 - BUG/MEDIUM: session: properly clean the outgoing connection before freeing.
11588 - BUG/MEDIUM: mux_pt: Don't try to send if handshake is not done.
11589 - MEDIUM: connections: Put H2 connections in the idle list if http-reuse always.
11590 - MEDIUM: h2: Destroy a connection with no stream if it has no owner.
11591 - MAJOR: sessions: Store multiple outgoing connections in the session.
11592 - MEDIUM: session: Steal owner-less connections on end of transaction.
11593 - MEDIUM: server: Be smarter about deciding to reuse the last server.
11594 - BUG/MEDIUM: Special-case http_proxy when dealing with outgoing connections.
11595 - BUG/MINOR: cfgparse: Fix transition between 2 sections with the same name
11596 - BUG/MINOR: http: Use out buffer instead of trash to display error snapshot
11597 - BUG/MINOR: htx: Fix block size calculation when a start-line is added/replaced
11598 - BUG/MINOR: mux-h1: Fix processing of "Connection: " header on outgoing messages
11599 - BUG/MEDIUM: mux-h1: Reset the H1 parser when an outgoing message is processed
11600 - BUG/MINOR: proto_htx: Send outgoing data to client to start response processing
11601 - BUG/MINOR: htx: Stop a header or a start line lookup on the first EOH or EOM
11602 - BUG/MINOR: connection: report mux modes when HTX is supported
11603 - MINOR: htx: add a function to cut the beginning of a DATA block
11604 - MEDIUM: conn_stream: Add a way to get mux's info on a CS from the upper layer
11605 - MINOR: mux-h1: Implement get_cs_info() callback
11606 - MINOR: stream: Rely on CS's info if it exists and fallback on session's ones
11607 - MINOR: proto_htx: Use conn_stream's info to set t_idle duration when possible
11608 - MINOR: mux-h1: Don't rely on the stream anymore in h1_set_srv_conn_mode()
11609 - MINOR: mux-h1: Write last chunk and trailers if not found in the HTX message
11610 - MINOR: mux-h1: Be prepare to fail when EOM is added during trailers parsing
11611 - MINOR: mux-h1: Subscribe to send in h1_snd_buf() when not all data have been sent
11612 - MINOR: mux-h1: Consume channel's data in a loop in h1_snd_buf()
11613 - MEDIUM: mux-h1: Add keep-alive outgoing connections in connections list
11614 - MINOR: htx: Add function to add an HTX block just before another one
11615 - MINOR: htx: Add function to iterate on an HTX message using HTX blocks
11616 - MINOR: htx: Add a function to find the HTX block corresponding to a data offset
11617 - MINOR: stats: Don't add end-of-data marker and trailers in the HTX response
11618 - MEDIUM: htx: Change htx_sl to be a struct instead of an union
11619 - MINOR: htx: Add the start-line offset for the HTX message in the HTX structure
11620 - MEDIUM: htx: Don't rely on h1_sl anymore except during H1 header parsing
11621 - MINOR: proto-htx: Use the start-line flags to set the HTTP messsage ones
11622 - MINOR: htx: Add BODYLESS flags on the HTX start-line and the HTTP message
11623 - MINOR: proto_htx: Use full HTX messages to send 100-Continue responses
11624 - MINOR: proto_htx: Use full HTX messages to send 103-Early-Hints responses
11625 - MINOR: proto_htx: Use full HTX messages to send 401 and 407 responses
11626 - MINOR: proto_htx: Send valid HTX message when redir mode is enabled on a server
11627 - MINOR: proto_htx: Send valid HTX message to send 30x responses
11628 - MEDIUM: proto_htx: Convert all HTTP error messages into HTX
11629 - MINOR: mux-h1: Process conn_mode on the EOH when no connection header is found
11630 - MINOR: mux-h1: Change client conn_mode on an explicit close for the response
11631 - MINOR: mux-h1: Capture bad H1 messages
11632 - MAJOR: filters: Adapt filters API to be compatible with the HTX represenation
11633 - MEDIUM: proto_htx/filters: Add data filtering during the forwarding
11634 - MINOR: flt_trace: Adapt to be compatible with the HTX representation
11635 - MEDIUM: compression: Adapt to be compatible with the HTX representation
11636 - MINOR: h2: implement H2->HTX request header frame transcoding
11637 - MEDIUM: mux-h2: register mux for both HTTP and HTX modes
11638 - MEDIUM: mux-h2: make h2_rcv_buf() support HTX transfers
11639 - MEDIUM: mux-h2: make h2_snd_buf() HTX-aware
11640 - MEDIUM: mux-h2: add basic H2->HTX transcoding support for headers
11641 - MEDIUM: mux-h2: implement emission of H2 headers frames from HTX blocks
11642 - MEDIUM: mux-h2: implement the emission of DATA frames from HTX DATA blocks
11643 - MEDIUM: mux-h2: support passing H2 DATA frames to HTX blocks
11644 - BUG/MINOR: cfgparse: Fix the call to post parser of the last sections parsed
11645 - BUG/MEDIUM: mux-h2: don't lose the first response header in HTX mode
11646 - BUG/MEDIUM: mux-h2: remove the HTX EOM block on H2 response headers
11647 - MINOR: listener: the mux_proto entry in the bind_conf is const
11648 - MINOR: connection: create conn_get_best_mux_entry()
11649 - MINOR: server: the mux_proto entry in the server is const
11650 - MINOR: config: make sure to associate the proper mux to bind and servers
11651 - MINOR: hpack: add ":path" to the list of common header fields
11652 - MINOR: h2: add new functions to produce an HTX message from an H2 response
11653 - MINOR: mux-h2: mention that the mux is compatible with both sides
11654 - MINOR: mux-h2: implement an outgoing stream allocator : h2c_bck_stream_new()
11655 - MEDIUM: mux-h2: start to create the outgoing mux
11656 - MEDIUM: mux-h2: implement encoding of H2 request on the backend side
11657 - MEDIUM: mux-h2: make h2_frt_decode_headers() direction-agnostic
11658 - MEDIUM: mux-h2: make h2_process_demux() capable of processing responses as well
11659 - MEDIUM: mux-h2: Implement h2_attach().
11660 - MEDIUM: mux-h2: Don't bother flagging outgoing connections as TOOMANY.
11661 - REGTEST: Fix LEVEL 4 script 0 of "connection" module.
11662 - MINOR: connection: Fix a comment.
11663 - MINOR: mux: add a "max_streams" method.
11664 - MEDIUM: servers: Add a way to keep idle connections alive.
11665 - CLEANUP: fix typos in the htx subsystem
11666 - CLEANUP: Fix typo in the chunk headers file
11667 - CLEANUP: Fix typos in the h1 subsystem
11668 - CLEANUP: Fix typos in the h2 subsystem
11669 - CLEANUP: Fix a typo in the mini-clist header
11670 - CLEANUP: Fix a typo in the proto_htx subsystem
11671 - CLEANUP: Fix typos in the proto_tcp subsystem
11672 - CLEANUP: Fix a typo in the signal subsystem
11673 - CLEANUP: Fix a typo in the session subsystem
11674 - CLEANUP: Fix a typo in the queue subsystem
11675 - CLEANUP: Fix typos in the shctx subsystem
11676 - CLEANUP: Fix typos in the socket pair protocol subsystem
11677 - CLEANUP: Fix typos in the map management functions
11678 - CLEANUP: Fix typo in the fwrr subsystem
11679 - CLEANUP: Fix typos in the cli subsystem
11680 - CLEANUP: Fix typo in the 51d subsystem
11681 - CLEANUP: Fix a typo in the base64 subsystem
11682 - CLEANUP: Fix a typo in the connection subsystem
11683 - CLEANUP: Fix a typo in the protocol header file
11684 - CLEANUP: Fix a typo in the checks header file
11685 - CLEANUP: Fix typos in the file descriptor subsystem
11686 - CLEANUP: Fix a typo in the listener subsystem
11687 - BUG/MINOR: lb-map: fix unprotected update to server's score
11688 - BUILD: threads: fix minor build warnings when threads are disabled
11689
Willy Tarreau0b936ad2018-11-25 09:16:46 +0100116902018/11/25 : 1.9-dev8
11691 - REORG: config: extract the global section parser into cfgparse-global
11692 - REORG: config: extract the proxy parser into cfgparse-listen.c
11693 - BUILD: update the list of supported targets and compilers in makefile and readme
11694 - BUILD: reorder the objects in the makefile
11695 - BUILD: Makefile: make "V=1" show some of the commands that are executed
11696 - BUILD: Makefile: add the quiet mode to a few more targets
11697 - BUILD: Makefile: add "$(Q)" to clean, tags and cscope targets
11698 - BUILD: Makefile: switch to quiet mode by default for CC/LD/AR
11699 - MINOR: cli: format `show proc` to be more readable
11700 - MINOR: cli: displays uptime in `show proc`
11701 - MINOR: cli: show master information in 'show proc'
11702 - BUG/MEDIUM: hpack: fix encoding of "accept-ranges" field
11703 - MAJOR: mux-h1: Remove the rxbuf and decode HTTP messages in channel's buffer
11704 - BUG/MINOR: mux-h1: Enable keep-alive on server side
11705 - BUG/MEDIUM: mux-h1: Fix freeze when the kernel splicing is used
11706 - BUG/MEDIUM: mux-h1: Don't set the flag CS_FL_RCV_MORE when nothing was parsed
11707 - BUG/MINOR: stats/htx: Remove channel's output when the request is eaten
11708 - BUG/MINOR: proto_htx: Fix request/response synchronisation on error
11709 - MINOR: stream-int: Notify caller when an error is reported after a rcv_pipe()
11710 - MINOR: stream-int: Notify caller when an error is reported after a rcv_buf()
11711 - BUG/MINOR: stream-int: Don't call snd_buf() if there are still data in the pipe
11712 - MINOR: stream-int: remove useless checks on CS and conn flags in si_cs_send()
11713 - BUG/MINOR: config: Be aware of the HTX during the check of mux protocols
11714 - BUG/MINOR: mux-htx: Fix bad test on h1c flags in h1_recv_allowed()
11715 - MEDIUM: mworker: wait mode use standard init code path
11716 - MINOR: log: introduce ha_notice()
11717 - MINOR: mworker: use ha_notice to announce a new worker
11718 - BUG/MEDIUM: http_fetch: Make sure name is initialized before http_find_header.
11719 - MINOR: cli: add mworker_accept_wrapper to 'show fd'
11720 - MEDIUM: signal: signal_unregister() removes every handlers
11721 - BUG/MEDIUM: mworker: unregister the signals of main()
11722 - MINOR: cli: add a few missing includes in proto/cli.h
11723 - REORG: time/activity: move activity measurements to activity.{c,h}
11724 - MINOR: activity: report the average loop time in "show activity"
11725 - MINOR: activity: add configuration and CLI support for "profiling.tasks"
11726 - MEDIUM: tasks: collect per-task CPU time and latency
11727 - MINOR: sample: add cpu_calls, cpu_ns_avg, cpu_ns_tot, lat_ns_avg, lat_ns_tot
11728 - MINOR: cli/activity: rename the stolen CPU time fields to mention milliseconds
11729 - BUG/MINOR: cli: Fix memory leak
11730 - BUG/MINOR: mworker: fix FD leak and memory leak in error path
11731 - MINOR: poller: move the call of tv_update_date() back to the pollers
11732 - MINOR: polling: add an option to support busy polling
11733 - MINOR: server: Add "alpn" and "npn" keywords.
11734 - MEDIUM: connection: Don't bother reactivating polling after connection retry.
11735 - MAJOR: connections: Defer mux creation for outgoing connection if alpn is set.
11736 - MEDIUM: ssl: Add ssl_bc_alpn and ssl_bc_npn sample fetches.
11737 - MINOR: servers: Free [idle|safe|priv]_conns on exit.
11738 - REGTEST: add the option to test only a specific set of files
11739 - REGTEST: add a test for connections to a "dispatch" address
11740 - BUG/MEDIUM: connections: Don't reset the conn flags in *connect_server().
11741 - MINOR: server: Only defined conn_complete_server if USE_OPENSSL is set.
11742 - BUG/MEDIUM: servers: Don't check if we have a conn_stream too soon.
11743 - BUG/MEDIUM: sessions: Set sess->origin to NULL if the origin was destroyed.
11744 - MEDIUM: servers: Store the connection in the SI until we have a mux.
11745 - BUG/MEDIUM: h2: wake the processing task up after demuxing
11746 - BUG/MEDIUM: h2: restart demuxing after releasing buffer space
11747
Willy Tarreau5c0e41b2018-11-18 22:33:00 +0100117482018/11/18 : 1.9-dev7
11749 - BUILD: cache: fix a build warning regarding too large an integer for the age
11750 - CLEANUP: fix typos in the comments of the Makefile
11751 - CLEANUP: fix a typo in a comment for the contrib/halog subsystem
11752 - CLEANUP: fix typos in comments for the contrib/modsecurity subsystem
11753 - CLEANUP: fix typos in comments for contrib/spoa_example
11754 - CLEANUP: fix typos in comments for contrib/wireshark-dissectors
11755 - DOC: Fix typos in README and CONTRIBUTING
11756 - MINOR: log: slightly improve error message syntax on log failure
11757 - DOC: logs: the format directive was missing from the second log part
11758 - MINOR: log: report the number of dropped logs in the stats
11759 - MEDIUM: log: add support for logging to existing file descriptors
11760 - MEDIUM: log: support a new "short" format
11761 - MEDIUM: log: add a new "raw" format
11762 - BUG/MEDIUM: stream-int: change the way buffer room is requested by a stream-int
11763 - BUG/MEDIUM: stream-int: convert some co_data() checks to channel_is_empty()
11764 - MINOR: namespaces: don't build namespace.c if disabled
11765 - BUILD/MEDIUM: threads/affinity: DragonFly build fix
11766 - MINOR: http: Add new "early-hint" http-request action.
11767 - MINOR: http: Make new "early-hint" http-request action really be parsed.
11768 - MINOR: http: Implement "early-hint" http request rules.
11769 - MINOR: doc: Add information about "early-hint" http-request action.
11770 - DOC: early-hints: fix truncated line.
11771 - MINOR: mworker: only close std{in,out,err} in daemon mode
11772 - BUG/MEDIUM: log: don't CLOEXEC the inherited FDs
11773 - BUG/MEDIUM: Make sure stksess is properly aligned.
11774 - BUG/MEDIUM: stream-int: make failed splice_in always subscribe to recv
11775 - BUG/MEDIUM: stream-int: clear CO_FL_WAIT_ROOM after splicing data in
11776 - BUG/MINOR: stream-int: make sure not to go through the rcv_buf path after splice()
11777 - CONTRIB: debug: fix build related to conn_stream flags change
11778 - REGTEST: fix scripts 1 and 3 to accept development version
11779 - BUG/MINOR: http_fetch: Remove the version part when capturing the request uri
11780 - MINOR: http: Regroup return statements of http_req_get_intercept_rule at the end
11781 - MINOR: http: Regroup return statements of http_res_get_intercept_rule at the end
11782 - BUG/MINOR: http: Be sure to sent fully formed HTTP 103 responses
11783 - MEDIUM: jobs: support unstoppable jobs for soft stop
11784 - MEDIUM: listeners: support unstoppable listener
11785 - MEDIUM: cli: worker socketpair is unstoppable
11786 - BUG/MINOR: stream-int: set SI_FL_WANT_PUT in sess_establish()
11787 - MINOR: stream: move the conn_stream specific calls to the stream-int
11788 - BUG/MINOR: config: Copy default error messages when parsing of a backend starts
11789 - CLEANUP: h2: minimum documentation for recent API changes
11790 - MINOR: mux: implement a get_first_cs() method
11791 - MINOR: stream-int: make conn_si_send_proxy() use cs_get_first()
11792 - MINOR: stream-int: relax the forwarding rules in stream_int_notify()
11793 - MINOR: stream-int: expand the flags to 32-bit
11794 - MINOR: stream-int: rename SI_FL_WAIT_ROOM to SI_FL_RXBLK_ROOM
11795 - MINOR: stream-int: introduce new SI_FL_RXBLK flags
11796 - MINOR: stream-int: add new functions si_{rx,tx}_{blocked,endp_ready}()
11797 - MINOR: stream-int: replace SI_FL_WANT_PUT with !SI_FL_RX_WAIT_EP
11798 - MINOR: stream-int: use si_rx_blocked()/si_tx_blocked() to check readiness
11799 - MEDIUM: stream-int: use si_rx_buff_{rdy,blk} to report buffer readiness
11800 - MINOR: stream-int: replace si_{want,stop}_put() with si_rx_endp_{more,done}()
11801 - MEDIUM: stream-int: update the endp polling status only at the end of si_cs_recv()
11802 - MINOR: stream-int: make si_sync_recv() simply check ENDP before si_cs_recv()
11803 - MINOR: stream-int: automatically mark applets as ready if they block on the channel
11804 - MEDIUM: stream-int: fix the si_cant_put() calls used for end point readiness
11805 - MEDIUM: stream-int: fix the si_cant_put() calls used for buffer readiness
11806 - MEDIUM: stream-int: use si_rx_shut_blk() to indicate the SI is closed
11807 - MEDIUM: stream-int: unconditionally call si_chk_rcv() in update and notify
11808 - MEDIUM: stream-int: make use of si_rx_chan_{rdy,blk} to control the stream-int from the channel
11809 - MINOR: stream-int: replace si_cant_put() with si_rx_room_{blk,rdy}()
11810 - MEDIUM: connections: Wait until the connection is established to try to recv.
11811 - MEDIUM: mux: Teach the mux_pt how to deal with idle connections.
11812 - MINOR: mux: Add a new "avail_streams" method.
11813 - MINOR: mux: Add a destroy() method.
11814 - MINOR: sessions: Start to store the outgoing connection in sessions.
11815 - MAJOR: connections: Detach connections from streams.
11816 - MINOR: conn_stream: Add a flag to notify the mux it should flush its buffers
11817 - MINOR: htx: Add proto_htx.c file
11818 - MINOR: conn_stream: Add a flag to notify the mux it must respect the reserve
11819 - MINOR: http: Add standalone functions to parse a start-line or a header
11820 - MINOR: http: Call http_send_name_header with the stream instead of the txn
11821 - MINOR: conn_stream: Add a flag to notify the SI some data were received
11822 - MINOR: http: Add macros to check if a stream uses the HTX representation
11823 - MEDIUM: proto_htx: Add HTX analyzers and use it when the mux H1 is used
11824 - MEDIUM: mux-h1: Add dummy mux to handle HTTP/1.1 connections
11825 - MEDIUM: mux-h1: Add parsing of incoming and ougoing HTTP messages
11826 - MAJOR: mux-h1/proto_htx: Handle keep-alive connections in the mux
11827 - MEDIUM: mux-h1: Add support of the kernel TCP splicing to forward data
11828 - MEDIUM: htx: Add API to deal with the internal representation of HTTP messages
11829 - MINOR: http_htx: Add functions to manipulate HTX messages in http_htx.c
11830 - MINOR: proto_htx: Add some functions to handle HTX messages
11831 - MAJOR: mux-h1/proto_htx: Switch mux-h1 and HTX analyzers on the HTX representation
11832 - MINOR: http_htx: Add functions to replace part of the start-line
11833 - MINOR: http_htx: Add functions to retrieve a specific occurrence of a header
11834 - MINOR: proto_htx: Rewrite htx_apply_redirect_rule to handle HTX messages
11835 - MINOR: proto_htx: Add the internal function htx_del_hdr_value
11836 - MINOR: proto_htx: Add the internal function htx_fmt_res_line
11837 - MINOR: proto_htx: Add functions htx_transform_header and htx_transform_header_str
11838 - MINOR: proto_htx: Add functions htx_req_replace_stline and htx_res_set_status
11839 - MINOR: proto_htx: Add function to build and send HTTP 103 responses
11840 - MINOR: proto_htx: Add functions htx_req_get_intercept_rule and htx_res_get_intercept_rule
11841 - MINOR: proto_htx: Add functions to apply req* and rsp* rules on HTX messages
11842 - MINOR: proto_htx: Add functions to manage cookies on HTX messages
11843 - MINOR: proto_htx: Add functions to check the cacheability of HTX messages
11844 - MINOR: proto_htx: Add functions htx_send_name_header
11845 - MINOR: proto_htx: Add functions htx_perform_server_redirect
11846 - MINOR: proto_htx: Add functions to handle the stats applet
11847 - MEDIUM: proto_htx: Adapt htx_process_req_common to handle HTX messages
11848 - MEDIUM: proto_htx: Adapt htx_process_request to handle HTX messages
11849 - MINOR: proto_htx: Adapt htx_process_tarpit to handle HTX messages
11850 - MEDIUM: proto_htx: Adapt htx_wait_for_request_body to handle HTX messages
11851 - MEDIUM: proto_htx: Adapt htx_process_res_common to handle HTX messages
11852 - MINOR: http_fetch: Add smp_prefetch_htx
11853 - MEDIUM: http_fetch: Adapt all fetches to handle HTX messages
11854 - MEDIUM: mux-h1: Wait for connection establishment before consuming channel's data
11855 - MINOR: stats/htx: Adapt the stats applet to handle HTX messages
11856 - MINOR: stream: Don't reset sov value with HTX messages
11857 - MEDIUM: mux-h1: Handle errors and timeouts in the stream
11858 - MINOR: filters/htx: Forbid filters when the HTX is enabled on a proxy
11859 - MINOR: lua/htx: Forbid lua usage when the HTX is enabled on a proxy
11860 - CLEANUP: Fix some typos in the haproxy subsystem
11861 - CLEANUP: Fix typos in the dns subsystem
11862 - CLEANUP: Fix typos in the pattern subsystem
11863 - CLEANUP: fix 2 typos in the xxhash subsystem
11864 - CLEANUP: fix a few typos in the comments of the server subsystem
11865 - CLEANUP: fix a misspell in tests/filltab25.c
11866 - CLEANUP: fix a typo found in the stream subsystem
11867 - CLEANUP: fix typos in comments in ebtree
11868 - CLEANUP: fix typos in reg-tests
11869 - CLEANUP: fix typos in the comments of the vars subsystem
11870 - CLEANUP: fix typos in the hlua_fcn subsystem
11871 - CLEANUP: fix typos in the proto_http subsystem
11872 - CLEANUP: fix typos in the proxy subsystem
11873 - CLEANUP: fix typos in the ssl_sock subsystem
11874 - DOC: Fix typos in different subsections of the documentation
11875 - DOC: fix a few typos in the documentation
11876 - MINOR: Fix an error message thrown when we run out of memory
11877 - MINOR: Fix typos in error messages in the proxy subsystem
11878 - MINOR: fix typos in the examples files
11879 - CLEANUP: Fix a typo in the stats subsystem
11880 - CLEANUP: Fix typos in the acl subsystem
11881 - CLEANUP: Fix typos in the cache subsystem
11882 - CLEANUP: Fix typos in the cfgparse subsystem
11883 - CLEANUP: Fix typos in the filters subsystem
11884 - CLEANUP: Fix typos in the http subsystem
11885 - CLEANUP: Fix typos in the log subsystem
11886 - CLEANUP: Fix typos in the peers subsystem
11887 - CLEANUP: Fix typos in the regex subsystem
11888 - CLEANUP: Fix typos in the sample subsystem
11889 - CLEANUP: Fix typos in the spoe subsystem
11890 - CLEANUP: Fix typos in the standard subsystem
11891 - CLEANUP: Fix typos in the stick_table subsystem
11892 - CLEANUP: Fix typos in the task subsystem
11893 - MINOR: Fix typo in error message in the standard subsystem
11894 - CLEANUP: fix typos in the comments of hlua
11895 - MINOR: Fix typo in the error 500 output of hlua
11896 - MINOR: Fix a typo in a warning message in the spoe subsystem
11897
Willy Tarreau96079492018-11-11 10:43:39 +0100118982018/11/11 : 1.9-dev6
11899 - BUG/MEDIUM: tools: fix direction of my_ffsl()
11900 - BUG/MINOR: cli: forward the whole command on master CLI
11901 - BUG/MEDIUM: auth/threads: use of crypt() is not thread-safe
11902 - MINOR: compat: automatically detect support for crypt_r()
11903 - MEDIUM: auth/threads: make use of crypt_r() on systems supporting it
11904 - DOC: split the http-request actions in their own section
11905 - DOC: split the http-response actions in their own section
11906 - BUG/MAJOR: stream-int: don't call si_cs_recv() in stream_int_chk_rcv_conn()
11907 - BUG/MINOR: tasks: make sure wakeup events are properly reported to subscribers
11908 - MINOR: stats: report the number of active jobs and listeners in "show info"
11909 - MINOR: stats: report the number of active peers in "show info"
11910 - MINOR: stats: report the number of currently connected peers
11911 - MINOR: cli: show the number of reload in 'show proc'
11912 - MINOR: cli: can't connect to the target CLI
11913 - MEDIUM: mworker: does not create the CLI proxy when no listener
11914 - MINOR: mworker: displays more information when leaving
11915 - MEDIUM: mworker: exit with the incriminated exit code
11916 - MINOR: mworker: displays a message when a worker is forked
11917 - MEDIUM: mworker: leave when the master die
11918 - CLEANUP: stream-int: retro-document si_cs_io_cb()
11919 - BUG/MEDIUM: mworker: does not abort() in mworker_pipe_register()
11920 - BUG/MEDIUM: stream-int: don't wake up for nothing during SI_ST_CON
11921 - BUG/MEDIUM: cli: crash when trying to access a worker
11922 - DOC: restore note about "independant" typo
11923 - MEDIUM: stream: implement stream_buf_available()
11924 - MEDIUM: appctx: check for allocation attempts in buffer allocation callbacks
11925 - MINOR: stream-int: rename si_applet_{want|stop|cant}_{get|put}
11926 - MINOR: stream-int: add si_done_{get,put} to indicate that we won't do it anymore
11927 - MINOR: stream-int: use si_cant_put() instead of setting SI_FL_WAIT_ROOM
11928 - MINOR: stream-int: make use of si_done_{get,put}() in shut{w,r}
11929 - MINOR: stream-int: make it clear that si_ops cannot be null
11930 - MEDIUM: stream-int: temporarily make si_chk_rcv() take care of SI_FL_WAIT_ROOM
11931 - MINOR: stream-int: factor the SI_ST_EST state test into si_chk_rcv()
11932 - MEDIUM: stream-int: make SI_FL_WANT_PUT reflect CF_DONT_READ
11933 - MEDIUM: stream-int: always call si_chk_rcv() when we make room in the buffer
11934 - MEDIUM: stream-int: make si_chk_rcv() check that SI_FL_WAIT_ROOM is cleared
11935 - MINOR: stream-int: replace si_update() with si_update_both()
11936 - MEDIUM: stream-int: make stream_int_update() aware of the lower layers
11937 - CLEANUP: stream-int: remove the now unused si->update() function
11938 - MEDIUM: stream-int: Rely only on SI_FL_WAIT_ROOM to stop data receipt
11939 - MEDIUM: stream-int: Try to read data even if channel's buffer seems to be full
11940 - BUG/MINOR: config: better detect the presence of the h2 pattern in npn/alpn
11941
Willy Tarreaubddf2922018-10-28 20:39:31 +0100119422018/10/28 : 1.9-dev5
11943 - BUILD: Makefile: add the new ERR variable to force -Werror
11944 - MINOR: freq_ctr: add swrate_add_scaled() to work with large samples
11945 - MINOR: stream_interface: Avoid calling si_cs_send/recv if not needed.
11946 - CLEANUP: http: Remove the unused function http_find_header
11947 - MINOR: h1: Export some functions parsing the value of some HTTP headers
11948 - BUG/MEDIUM: stream-int: don't set SI_FL_WAIT_ROOM on CF_READ_DONTWAIT
11949 - MINOR: proxy: add a new option "http-use-htx"
11950 - BUG/MEDIUM: pools: fix the minimum allocation size
11951 - MINOR: shctx: Shared objects block by block allocation.
11952 - MINOR: cache: Larger HTTP objects caching.
11953 - MINOR: shctx: Add a maximum object size parameter.
11954 - MINOR: cache: Add "max-object-size" option.
11955 - DOC: Update about the cache support for big objects.
11956 - BUG/MINOR: cache: Crashes with "total-max-size" > 2047(MB).
11957 - BUG/MINOR: cache: Wrong usage of shctx_init().
11958 - BUG/MINOR: ssl: Wrong usage of shctx_init().
11959 - MINOR: cache: Avoid usage of atoi() when parsing "max-object-size".
11960 - MINOR: shctx: Change max. object size type to unsigned int.
11961 - DOC: cache: Missing information about "total-max-size" and "max-object-size"
11962 - CLEANUP: tools: fix misleading comment above function LIM2A
11963 - MEDIUM: channel: merge back flags CF_WRITE_PARTIAL and CF_WRITE_EVENT
11964 - BUG/MINOR: only mark connections private if NTLM is detected
11965 - BUG/MINOR: only auto-prefer last server if lb-alg is non-deterministic
11966 - MINOR: stream: don't prune variables if the list is empty
11967 - MINOR: stream-int: add si_alloc_ibuf() to ease input buffer allocation
11968 - MEDIUM: stream-int: replace channel_alloc_buffer() with si_alloc_ibuf() everywhere
11969 - MEDIUM: stream: always call si_cs_recv() after a failed buffer allocation
11970 - MEDIUM: stream: don't try to send first in process_stream()
11971 - MEDIUM: stream-int: make si_update() synchronize flag changes before the I/O
11972 - MEDIUM: stream-int: call si_cs_process() in stream_int_update_conn
11973 - MINOR: stream-int: don't needlessly call tasklet_wakeup() in stream_int_chk_snd_conn()
11974 - MINOR: stream-int: make stream_int_notify() not wake the tasklet up
11975 - MINOR: stream-int: don't needlessly call si_cs_send() in si_cs_process()
11976 - MINOR: mworker: number of reload in the life of a worker
11977 - MEDIUM: mworker: each worker socketpair is a CLI listener
11978 - REORG: mworker: move struct mworker_proc to global.h
11979 - MINOR: server: export new_server() function
11980 - MEDIUM: mworker: move proc_list gen before proxies startup
11981 - MEDIUM: mworker: add proc_list in global.h
11982 - MEDIUM: mworker: proxy for the master CLI
11983 - MEDIUM: mworker: create CLI listeners from argv[]
11984 - MEDIUM: cli: disable some keywords in the master
11985 - MEDIUM: mworker: find the server ptr using a CLI prefix
11986 - MEDIUM: cli: 'show proc' displays processus
11987 - MEDIUM: cli: implement 'mode cli' proxy analyzers
11988 - MINOR: cli: displays sockpair@ in "show cli sockets"
11989 - MEDIUM: cli: enable "show cli sockets" for the master
11990 - MINOR: cli: put @master @<relative pid> @!<pid> in the help
11991 - MEDIUM: listeners: set O_CLOEXEC on the accepted FDs
11992 - MEDIUM: mworker: stop the master proxy in the workers
11993 - MEDIUM: channel: reorder the channel analyzers for the cli
11994 - MEDIUM: cli: write a prompt for the CLI proxy of the master
11995 - MINOR: cli: helper to write an response message and close
11996 - MINOR: cache: Add "Age" header.
11997 - REGTEST: make the IP+port logging test more reliable
11998 - BUG/MINOR: memory: make the thread-local cache allocator set the debugging link
11999 - BUG/MAJOR: http: http_txn_get_path() may deference an inexisting buffer
12000 - BUG/MINOR: backend: assign the wait list after the error check
12001
Willy Tarreau01fbe742018-10-21 20:28:30 +0200120022018/10/21 : 1.9-dev4
12003 - BUILD: Allow configuration of pcre-config path
12004 - DOC: clarify force-private-cache is an option
12005 - BUG/MINOR: connection: avoid null pointer dereference in send-proxy-v2
12006 - REORG: http: move the code to different files
12007 - REORG: http: move HTTP rules parsing to http_rules.c
12008 - CLEANUP: http: remove some leftovers from recent cleanups
12009 - BUILD: Makefile: add a "make opts" target to simply show the build options
12010 - BUILD: Makefile: speed up compiler options detection
12011 - BUG/MINOR: backend: check that the mux installed properly
12012 - BUG/MEDIUM: h2: check that the connection is still valid at the end of init()
12013 - BUG/MEDIUM: h2: make h2_stream_new() return an error on memory allocation failure
12014 - REGTEST/MINOR: compatibility: use unix@ instead of abns@ sockets
12015 - MINOR: ssl: cleanup old openssl API call
12016 - MINOR: ssl: generate-certificates for BoringSSL
12017 - BUG/MEDIUM: buffers: Make sure we don't wrap in ci_insert_line2/b_rep_blk.
12018 - MEDIUM: ssl: add support for ciphersuites option for TLSv1.3
12019 - CLEANUP: haproxy: Remove unused variable
12020 - CLEANUP: h1: Fix debug warnings for h1 headers
12021 - CLEANUP: stick-tables: Remove unneeded double (()) around conditional clause
12022 - MEDIUM: task: perform a single tree lookup per run queue batch
12023 - BUG/MEDIUM: Cur/CumSslConns counters not threadsafe.
12024 - BUG/MINOR: threads: move declaration of capabilities to config.h
12025 - OPTIM: tools: optimize my_ffsl() for x86_64
12026 - BUG/MINOR: h2: null-deref
12027 - BUG/MINOR: checks: queues null-deref
12028 - MINOR: connections: Introduce an unsubscribe method.
12029 - MEDIUM: connections: Change struct wait_list to wait_event.
12030 - BUG/MEDIUM: h2: Make sure we're not in the send list on flow control.
12031 - BUG/MEDIUM: mworker: segfault receiving SIGUSR1 followed by SIGTERM.
12032 - BUG/MEDIUM: stream: Make sure to unsubscribe before si_release_endpoint.
12033 - MINOR: http: Move comment about some HTTP macros in the right header file
12034 - MINOR: stats: Add missing include
12035 - MINOR: http: Export some functions and do cleanup to prepare HTTP refactoring
12036 - MEDIUM: http: Ignore http-pretend-keepalive option on frontend
12037 - MEDIUM: http: Ignore http-tunnel option on backend
12038 - MINOR: http: Use same flag for httpclose and forceclose options
12039 - MINOR: h1: Add EOH marker during headers parsing
12040 - MINOR: conn-stream: Add CL_FL_NOT_FIRST flag
12041 - MINOR: h1: Change the union h1_sl to use indirect strings to store infos
12042 - MINOR: h1: Add the flag H1_MF_NO_PHDR to not add pseudo-headers during parsing
12043 - MINOR: log: make sess_log() support sess=NULL
12044 - MINOR: chunk: add chunk_cpy() and chunk_cat()
12045 - MEDIUM: h2: stop relying on H2_SS_IDLE / H2_SS_CLOSED
12046 - CLEANUP: h2: rename h2c_snd_settings() to h2c_send_settings()
12047 - MINOR: h2: don't try to send data before preface
12048 - MINOR: h2: unify the mux init function
12049 - MINOR: h2: retrieve the front proxy from the caller instead of the session
12050 - MINOR: h2: split h2c_stream_new() into h2s_new() + h2c_frt_stream_new()
12051 - MINOR: h2: add a new flag to quickly distinguish front vs back connection
12052 - BUG/MEDIUM: mworker: don't poll on LI_O_INHERITED listeners
12053 - BUG/MEDIUM: stream: don't crash on out-of-memory
12054 - BUILD: compiler: add a new statement "__unreachable()"
12055 - BUILD: lua: silence some compiler warnings about potential null derefs
12056 - BUILD: ssl: fix null-deref warning in ssl_fc_cipherlist_str sample fetch
12057 - BUILD: ssl: fix another null-deref warning in ssl_sock_switchctx_cbk()
12058 - BUILD: stick-table: make sure not to fail on task_new() during initialization
12059 - BUILD: peers: check allocation error during peers_init_sync()
12060 - MINOR: tools: add a new function atleast2() to test masks for more than 1 bit
12061 - MINOR: config: use atleast2() instead of my_popcountl() where relevant
12062 - MEDIUM: fd/threads: only grab the fd's lock if the FD has more than one thread
12063 - MAJOR: tasks: create per-thread wait queues
12064 - OPTIM: tasks: group all tree roots per cache line
12065 - DOC: Fix a few typos
12066 - MINOR: pools: allocate most memory pools from an array
12067 - MINOR: pools: split pool_free() in the lockfree variant
12068 - MEDIUM: pools: implement a thread-local cache for pool entries
12069 - BUG/MEDIUM: threads: fix thread_release() at the end of the rendez-vous point
12070 - Revert "BUILD: lua: silence some compiler warnings about potential null derefs"
12071 - BUILD: lua: silence some compiler warnings about potential null derefs (#2)
12072 - MINOR: lua: all functions calling lua_yieldk() may return
12073 - BUILD: lua: silence some compiler warnings after WILL_LJMP
12074 - BUILD: Makefile: silence an option conflict warning with clang
12075 - MINOR: server: Use memcpy() instead of strncpy().
12076 - CLEANUP: state-file: make the path concatenation code a bit more consistent
12077 - MINOR: build: Disable -Wstringop-overflow.
12078 - MINOR: cfgparse: Write 130 as 128 as 0x82 and 0x80.
12079 - MINOR: peers: use defines instead of enums to appease clang.
12080 - DOC: fix reference to map files in MAINTAINERS
12081 - MINOR: fd: centralize poll timeout computation in compute_poll_timeout()
12082 - MINOR: poller: move time and date computation out of the pollers
12083 - BUILD: memory: fix pointer declaration for atomic CAS
12084 - BUILD: Makefile: add USE_RT to pass -lrt for clock_gettime() and friends
12085 - MINOR: time: add now_mono_time() and now_cpu_time()
12086 - MEDIUM: time: measure the time stolen by other threads
12087 - BUILD: memory: fix free_list pointer declaration again for atomic CAS
12088 - BUILD: compiler: rename __unreachable() to my_unreachable()
12089 - BUG/MEDIUM: pools: Fix the usage of mmap()) with DEBUG_UAF.
12090 - BUILD: memory: fix free_list pointer declaration again for atomic CAS
12091 - BUG/MEDIUM: h2: Close connection if no stream is left an GOAWAY was sent.
12092 - BUG/MEDIUM: connections: Remove subscription if going in idle mode.
12093 - BUG/MEDIUM: stream: Make sure polling is right on retry.
12094 - MINOR: h2: Make sure to return 1 in h2_recv() when needed.
12095 - MEDIUM: connections: Don't directly mess with the polling from the upper layers.
12096 - MINOR: streams: Call tasklet_free() after si_release_endpoint().
12097 - MINOR: connection: Add a SUB_CALL_UNSUBSCRIBE event.
12098 - MINOR: h2: Don't run tasks that are waiting to send if mux in full.
12099 - MINOR: ebtree: save 8 bytes in struct eb32sc_node
12100
Willy Tarreau27010f02018-09-29 20:17:33 +0200121012018/09/29 : 1.9-dev3
12102 - BUG/MINOR: h1: don't consider the status for each header
12103 - MINOR: h1: report in the h1m struct if the HTTP version is 1.1 or above
12104 - MINOR: h1: parse the Connection header field
12105 - DOC: Fix typos in lua documentation
12106 - MINOR: h1: Add H1_MF_XFER_LEN flag
12107 - MINOR: http: add http_hdr_del() to remove a header from a list
12108 - MINOR: h1: add headers to the list after controls, not before
12109 - MEDIUM: h1: better handle transfer-encoding vs content-length
12110 - MEDIUM: h1: deduplicate the content-length header
12111 - BUG/MEDIUM: patterns: fix possible double free when reloading a pattern list
12112 - BUG/MEDIUM: h1: Really skip all updates when incomplete messages are parsed
12113 - CLEANUP/CONTRIB: hpack: remove some h1 build warnings
12114 - BUG/MINOR: tools: fix set_net_port() / set_host_port() on IPv4
12115 - BUG/MINOR: cli: make sure the "getsock" command is only called on connections
12116 - MINOR: stktable: provide an unchecked version of stktable_data_ptr()
12117 - MINOR: stream-int: make si_appctx() never fail
12118 - BUILD: ssl_sock: remove build warnings on potential null-derefs
12119 - BUILD: stats: remove build warnings on potential null-derefs
12120 - BUILD: stream: address null-deref build warnings at -Wextra
12121 - BUILD: http: address a couple of null-deref warnings at -Wextra
12122 - BUILD: log: silent build warnings due to unchecked __objt_{server,applet}
12123 - BUILD: dns: fix null-deref build warning at -Wextra
12124 - BUILD: checks: silence a null-deref build warning at -Wextra
12125 - BUILD: connection: silence a couple of null-deref build warnings at -Wextra
12126 - BUILD: backend: fix 3 build warnings related to null-deref at -Wextra
12127 - BUILD: sockpair: silence a build warning at -Wextra
12128 - BUILD: build with -Wextra and sort out certain warnings
12129 - BUG/CRITICAL: hpack: fix improper sign check on the header index value
12130 - BUG/MEDIUM: http: Don't parse chunked body if there is no input data
12131 - DOC: Update configuration doc about the maximum number of stick counters.
12132 - BUG/MEDIUM: process_stream: Don't use si_cs_io_cb() in process_stream().
12133 - MINOR: h2/stream_interface: Reintroduce te wake() method.
12134 - BUG/MEDIUM: h2: Wake the task instead of calling h2_recv()/h2_process().
12135 - BUG/MEDIUM: process_stream(): Don't wake the task if no new data was received.
12136 - MEDIUM: lua: Add stick table support for Lua.
12137
Willy Tarreau253006d2018-09-12 18:59:48 +0200121382018/09/12 : 1.9-dev2
12139 - BUG/MINOR: buffers: Fix b_slow_realign when a buffer is realign without output
12140 - BUG/MEDIUM: threads: fix the no-thread case after the change to the sync point
12141 - BUG/MEDIUM: servers: check the queues once enabling a server
12142 - BUG/MEDIUM: queue: prevent a backup server from draining the proxy's connections
12143 - MEDIUM: mux: Remove const on the buffer in mux->snd_buf()
12144 - CLEANUP: backend: Move mux install to call it at only one place
12145 - MINOR: conn_stream: add an tx buffer to the conn_stream
12146 - MINOR: conn_stream: add cs_send() as a default snd_buf() function
12147 - MINOR: backend: Try to find the best mux for outgoing connections
12148 - MEDIUM: backend: don't rely on mux_pt_ops in connect_server()
12149 - MINOR: mux: Add info about the supported side in alpn_mux_list structure
12150 - MINOR: mux: Unlink ALPN and multiplexers to rather speak of mux protocols
12151 - MINOR: mux: Print the list of existing mux protocols during HA startup
12152 - MEDIUM: checks: use the new rendez-vous point to spread check result
12153 - MEDIUM: haproxy: don't use sync_poll_loop() anymore in the main loop
12154 - MINOR: threads: remove the previous synchronization point
12155 - MAJOR: server: make server state changes synchronous again
12156 - CLEANUP: server: remove the update list and the update lock
12157 - BUG/MINOR: threads: Remove the unexisting lock label "UPDATED_SERVERS_LOCK"
12158 - BUG/MEDIUM: stream_int: Don't check CO_FL_SOCK_RD_SH flag to trigger cs receive
12159 - MINOR: mux: Change get_mux_proto to get an ist as parameter
12160 - MINOR: mux: Improve the message with the list of existing mux protocols
12161 - MINOR: mux/frontend: Add 'proto' keyword to force the mux protocol
12162 - MINOR: mux/server: Add 'proto' keyword to force the multiplexer's protocol
12163 - MEDIUM: mux: Use the mux protocol specified on bind/server lines
12164 - BUG/MEDIUM: connection/mux: take care of serverless proxies
12165 - MINOR: queue: make sure the pendconn is released before logging
12166 - MINOR: stream: rename {srv,prx}_queue_size to *_queue_pos
12167 - MINOR: queue: store the queue index in the stream when enqueuing
12168 - MINOR: queue: replace the linked list with a tree
12169 - MEDIUM: add set-priority-class and set-priority-offset
12170 - MEDIUM: queue: adjust position based on priority-class and priority-offset
12171 - DOC: update the roadmap about priority queues
12172 - BUG/MINOR: ssl: empty connections reported as errors.
12173 - MINOR: connections: Make rcv_buf mandatory and nuke cs_recv().
12174 - MINOR: connections: Move rxbuf from the conn_stream to the h2s.
12175 - MINOR: connections: Get rid of txbuf.
12176 - MINOR: tasks: Allow tasklet_wakeup() to wakeup a task.
12177 - MINOR: connections/mux: Add the wait reason(s) to wait_list.
12178 - MINOR: stream_interface: Don't use si_cs_send() as a task handler.
12179 - MINOR: stream_interface: Give stream_interface its own wait_list.
12180 - MINOR: mux_h2: Don't use h2_send() as a callback.
12181 - MINOR: checks: Add event_srv_chk_io().
12182 - BUG/MEDIUM: tasks: Don't insert in the global rqueue if nbthread == 1
12183 - BUG/MEDIUM: sessions: Don't use t->state.
12184 - BUG/MEDIUM: ssl: fix missing error loading a keytype cert from a bundle.
12185 - BUG/MEDIUM: ssl: loading dh param from certifile causes unpredictable error.
12186 - BUG/MINOR: map: fix map_regm with backref
12187 - DOC: dns: explain set server ... fqdn requires resolver
12188 - DOC: add documentation for prio_class and prio_offset sample fetches.
12189 - DOC: ssl: Use consistent naming for TLS protocols
12190 - DOC: update the layering design notes
12191 - MINOR: tasks: Don't special-case when nbthreads == 1
12192 - MINOR: fd cache: And the thread_mask with all_threads_mask.
12193 - BUG/MEDIUM: lua: socket timeouts are not applied
12194 - BUG/MINOR: lua: fix extra 500ms added to socket timeouts
12195 - BUG/MEDIUM: server: update our local state before propagating changes
12196 - BUG/MEDIUM: cli/threads: protect all "proxy" commands against concurrent updates
12197 - DOC: server/threads: document which functions need to be called with/without locks
12198 - BUG/MEDIUM: cli/threads: protect some server commands against concurrent operations
12199 - BUG/MEDIUM: streams: Don't forget to remove the si from the wait list.
12200 - BUG/MEDIUM: tasklets: Add the thread as active when waking a tasklet.
12201 - BUG/MEDIUM: stream-int: Check if the conn_stream exist in si_cs_io_cb.
12202 - BUG/MEDIUM: H2: Activate polling after successful h2_snd_buf().
12203 - BUG/MEDIUM: stream_interface: Call the wake callback after sending.
12204 - BUG/MAJOR: queue/threads: make pendconn_redistribute not lock the server
12205 - BUG/MEDIUM: connection: don't forget to always delete the list's head
12206 - BUG/MEDIUM: lb/threads: always properly lock LB algorithms on maintenance operations
12207 - BUG/MEDIUM: check/threads: do not involve the rendez-vous point for status updates
12208 - BUG/MINOR: chunks: do not store -1 into chunk_printf() in case of error
12209 - BUG/MEDIUM: http: don't store exp_replace() result in the trash's length
12210 - BUG/MEDIUM: http: don't store url_decode() result in the samples's length
12211 - BUG/MEDIUM: dns: don't store dns_build_query() result in the trash's length
12212 - BUG/MEDIUM: map: don't store exp_replace() result in the trash's length
12213 - BUG/MEDIUM: connection: don't store recv() result into trash.data
12214 - BUG/MEDIUM: cli/ssl: don't store base64dec() result in the trash's length
12215 - MINOR: chunk: remove impossible tests on negative chunk->data
12216 - MINOR: sample: remove impossible tests on negative smp->data.u.str.data
12217 - DOC: Fix spelling error in configuration doc
12218 - REGTEST/MINOR: Missing mandatory "ignore_unknown_macro".
12219 - REGTEST/MINOR: Add a new class of regression testing files.
12220 - BUG/MEDIUM: unix: provide a ->drain() function
12221 - MINOR: connection: make conn_sock_drain() work for all socket families
12222 - BUG/MINOR: lua: Bad HTTP client request duration.
12223 - REGEST/MINOR: Add reg testing files.
12224 - BUG/MEDIUM: mux_pt: dereference the connection with care in mux_pt_wake()
12225 - REGTEST/MINOR: Add a reg testing file for b406b87 commit.
12226 - BUG/MEDIUM: lua: reset lua transaction between http requests
12227 - MINOR: add be_conn_free sample fetch
12228 - MINOR: Add srv_conn_free sample fetch
12229 - BUG/MEDIUM: hlua: Make sure we drain the output buffer when done.
12230 - MINOR: checks: Call wake_srv_chk() when we can finally send data.
12231 - BUG/MEDIUM: stream_interface: try to call si_cs_send() earlier.
12232 - BUG/MAJOR: thread: lua: Wrong SSL context initialization.
12233 - REGTEST/MINOR: Add a reg testing file for 3e60b11.
12234 - BUG/MEDIUM: hlua: Don't call RESET_SAFE_LJMP if SET_SAFE_LJMP returns 0.
12235 - REGTEST/MINOR: lua: Add reg testing files for 70d318c.
12236 - BUG/MEDIUM: dns/server: fix incomatibility between SRV resolution and server state file
12237 - BUG/MEDIUM: ECC cert should work with TLS < v1.2 and openssl >= 1.1.1
12238 - MINOR: tools: make date2str_log() take some consts
12239 - MINOR: thread: implement HA_ATOMIC_XADD()
12240 - BUG/MINOR: stream: use atomic increments for the request counter
12241 - BUG/MEDIUM: session: fix reporting of handshake processing time in the logs
12242 - BUG/MEDIUM: h2: fix risk of memory leak on malformated wrapped frames
12243 - BUG/MAJOR: buffer: fix incorrect check in __b_putblk()
12244 - MINOR: log: move the log code to sess_build_logline() to add extra arguments
12245 - MINOR: log: make the backend fall back to the frontend when there's no stream
12246 - MINOR: log: make sess_build_logline() not dereference a NULL stream for txn
12247 - MINOR: log: don't unconditionally pick log info from s->logs
12248 - CLEANUP: log: make the low_level lf_{ip,port,text,text_len} functions take consts
12249 - MINOR: log: keep a copy of the backend connection early in sess_build_logline()
12250 - MINOR: log: do not dereference a null stream to access captures
12251 - MINOR: log: be sure not to dereference a null stream for a target
12252 - MINOR: log: don't check the stream-int's conn_retries if the stream is NULL
12253 - MINOR: log: use NULL for the unique_id if there is no stream
12254 - MINOR: log: keep a copy of s->flags early to avoid a dereference
12255 - MINOR: log: use zero as the request counter if there is no stream
12256 - MEDIUM: log: make sess_build_logline() support being called with no stream
12257 - MINOR: log: provide a function to emit a log for a session
12258 - MEDIUM: h2: produce some logs on early errors that prevent streams from being created
12259 - BUG/MINOR: h1: fix buffer shift after realignment
12260 - MINOR: connection: make the initialization more consistent
12261 - MINOR: connection: add new function conn_get_proxy()
12262 - MINOR: connection: add new function conn_is_back()
12263 - MINOR: log: One const should be enough.
12264 - BUG/MINOR: dns: check and link servers' resolvers right after config parsing
12265 - BUG/MINOR: http/threads: atomically increment the error snapshot ID
12266 - MINOR: snapshot: restart on the event ID and not the stream ID
12267 - MINOR: snapshot: split the error snapshots into common and proto-specific parts
12268 - MEDIUM: snapshot: start to reorder the HTTP snapshot output a little bit
12269 - MEDIUM: snapshot: implement a show() callback and use it for HTTP
12270 - MINOR: proxy: add a new generic proxy_capture_error()
12271 - MINOR: http: make the HTTP error capture rely on the generic proxy code
12272 - MINOR: http: remove the pointer to the error snapshot in http_capture_bad_message()
12273 - REORG: cli: move the "show errors" handler from http to proxy
12274 - BUG/MEDIUM: snapshot: take the proxy's lock while dumping errors
12275 - MEDIUM: snapshots: dynamically allocate the snapshots
12276 - MEDIUM: snapshot: merge the captured data after the descriptor
12277 - MEDIUM: mworker: remove register/unregister signal functions
12278 - MEDIUM: mworker: use the haproxy poll loop
12279 - BUG/MINOR: mworker: no need to stop peers for each proxy
12280 - MINOR: mworker: mworker_cleanlisteners() delete the listeners
12281 - MEDIUM: mworker: block SIGCHLD until the master is ready
12282 - MEDIUM: mworker: never block SIG{TERM,INT} during reload
12283 - MEDIUM: startup: unify signal init between daemon and mworker mode
12284 - MINOR: mworker: don't deinit the poller fd when in wait mode
12285 - MEDIUM: mworker: master wait mode use its own initialization
12286 - MEDIUM: mworker: replace the master pipe by socketpairs
12287 - MINOR: mworker: keep and clean the listeners
12288 - MEDIUM: threads: close the thread-waker pipe during deinit
12289 - MEDIUM: mworker: call per_thread deinit in mworker_reload()
12290 - REORG: http: move the HTTP semantics definitions to http.h/http.c
12291 - REORG: http: move http_get_path() to http.c
12292 - REORG: http: move error codes production and processing to http.c
12293 - REORG: http: move the log encoding tables to log.c
12294 - REORG: http: move some header value processing functions to http.c
12295 - BUG/MAJOR: kqueue: Don't reset the changes number by accident.
12296 - MEDIUM: protocol: use a custom AF_MAX to help protocol parser
12297 - MEDIUM: protocol: sockpair protocol
12298 - TESTS: add a python wrapper for sockpair@
12299 - BUG/MINOR: server: Crash when setting FQDN via CLI.
12300 - BUG/MINOR: h2: report asynchronous end of stream on closed connections
12301 - BUILD: fix build without thread
12302 - BUG/MEDIUM: tasks: Don't forget to decrement task_list_size in tasklet_free().
12303 - MEDIUM: connections: Don't reset the polling flags in conn_fd_handler().
12304 - MEDIUM: connections/mux: Add a recv and a send+recv wait list.
12305 - MEDIUM: connections: Get rid of the recv() method.
12306 - MINOR: h2: Let user of h2_recv() and h2_send() know xfer has been done.
12307 - MEDIUM: h2: always subscribe to receive if allowed.
12308 - MEDIUM: h2: Don't use a wake() method anymore.
12309 - MEDIUM: stream_interface: Make recv() subscribe when more data is needed.
12310 - MINOR: connections: Add a "handle" field to wait_list.
12311 - MEDIUM: mux_h2: Revamp the send path when blocking.
12312 - MEDIUM: stream_interfaces: Starts receiving from the upper layers.
12313 - MINOR: checks: Give checks their own wait_list.
12314 - MINOR: conn_streams: Remove wait_list from conn_streams.
12315 - REORG: h1: create a new h1m_state
12316 - MINOR: h1: add the restart offsets into struct h1m
12317 - MINOR: h1: remove the unused states from h1m_state
12318 - MINOR: h1: provide a distinct init() function for request and response
12319 - MINOR: h1: add a message flag to indicate that a message carries a response
12320 - MINOR: h2: make sure h1m->err_pos field is correct on chunk error
12321 - MINOR: h1: properly pre-initialize err_pos to -2
12322 - MINOR: mux_h2: replace the req,res h1 messages with a single h1 message
12323 - MINOR: h2: pre-initialize h1m->err_pos to -1 on the output path
12324 - MEDIUM: h1: consider err_pos before deciding to accept a header name or not
12325 - MEDIUM: h1: make the parser support a pointer to a start line
12326 - MEDIUM: h1: let the caller pass the initial parser's state
12327 - MINOR: h1: make the message parser support a null <hdr> argument
12328 - MEDIUM: h1: support partial message parsing
12329 - MEDIUM: h1: remove the useless H1_MSG_BODY state
12330 - MINOR: h2: store the HTTP status into the H2S, not the H1M
12331 - MINOR: h1: remove the HTTP status from the H1M struct
12332 - MEDIUM: h1: implement the request parser as well
12333 - MINOR: h1: add H1_MF_TOLOWER to decide when to turn header names to lower case
12334 - MINOR: connection: pass the proxy when creating a connection
12335 - BUG/MEDIUM: h2: Don't forget to empty the wait lists on destroy.
12336 - BUG/MEDIUM: h2: Don't forget to set recv_wait_list to NULL in h2_detach.
12337 - BUG/MAJOR: h2: reset the parser's state on mux buffer full
12338
Willy Tarreau65e94d12018-08-02 18:12:50 +0200123392018/08/02 : 1.9-dev1
12340 - BUG/MEDIUM: kqueue: Don't bother closing the kqueue after fork.
12341 - DOC: cache: update sections and fix some typos
12342 - BUILD/MINOR: deviceatlas: enable thread support
12343 - BUG/MEDIUM: tcp-check: Don't lock the server in tcpcheck_main
12344 - BUG/MEDIUM: ssl: don't allocate shctx several time
12345 - BUG/MEDIUM: cache: bad computation of the remaining size
12346 - BUILD: checks: don't include server.h
12347 - BUG/MEDIUM: stream: fix session leak on applet-initiated connections
12348 - BUILD/MINOR: haproxy : FreeBSD/cpu affinity needs pthread_np header
12349 - BUILD/MINOR: Makefile : enabling USE_CPU_AFFINITY
12350 - BUG/MINOR: ssl: CO_FL_EARLY_DATA removal is managed by stream
12351 - BUG/MEDIUM: threads/peers: decrement, not increment jobs on quitting
12352 - BUG/MEDIUM: h2: don't report an error after parsing a 100-continue response
12353 - BUG/MEDIUM: peers: fix some track counter rules dont register entries for sync.
12354 - BUG/MAJOR: thread/peers: fix deadlock on peers sync.
12355 - BUILD/MINOR: haproxy: compiling config cpu parsing handling when needed
12356 - MINOR: config: report when "monitor fail" rules are misplaced
12357 - BUG/MINOR: mworker: fix validity check for the pipe FDs
12358 - BUG/MINOR: mworker: detach from tty when in daemon mode
12359 - MINOR: threads: Fix pthread_setaffinity_np on FreeBSD.
12360 - BUG/MAJOR: thread: Be sure to request a sync between threads only once at a time
12361 - BUILD: Fix LDFLAGS vs. LIBS re linking order in various makefiles
12362 - BUG/MEDIUM: checks: Be sure we have a mux if we created a cs.
12363 - BUG/MINOR: hpack: fix debugging output of pseudo header names
12364 - BUG/MINOR: hpack: must reject huffman literals padded with more than 7 bits
12365 - BUG/MINOR: hpack: reject invalid header index
12366 - BUG/MINOR: hpack: dynamic table size updates are only allowed before headers
12367 - BUG/MAJOR: h2: correctly check the request length when building an H1 request
12368 - BUG/MINOR: h2: immediately close if receiving GOAWAY after the last stream
12369 - BUG/MINOR: h2: try to abort closed streams as soon as possible
12370 - BUG/MINOR: h2: ":path" must not be empty
12371 - BUG/MINOR: h2: fix a typo causing PING/ACK to be responded to
12372 - BUG/MINOR: h2: the TE header if present may only contain trailers
12373 - BUG/MEDIUM: h2: enforce the per-connection stream limit
12374 - BUG/MINOR: h2: do not accept SETTINGS_ENABLE_PUSH other than 0 or 1
12375 - BUG/MINOR: h2: reject incorrect stream dependencies on HEADERS frame
12376 - BUG/MINOR: h2: properly check PRIORITY frames
12377 - BUG/MINOR: h2: reject response pseudo-headers from requests
12378 - BUG/MEDIUM: h2: remove connection-specific headers from request
12379 - BUG/MEDIUM: h2: do not accept upper case letters in request header names
12380 - BUG/MINOR: h2: use the H2_F_DATA_* macros for DATA frames
12381 - BUG/MINOR: action: Don't check http capture rules when no id is defined
12382 - BUG/MAJOR: hpack: don't pretend large headers fit in empty table
12383 - BUG/MINOR: ssl: support tune.ssl.cachesize 0 again
12384 - BUG/MEDIUM: mworker: also close peers sockets in the master
12385 - BUG/MEDIUM: ssl engines: Fix async engines fds were not considered to fix fd limit automatically.
12386 - BUG/MEDIUM: checks: a down server going to maint remains definitely stucked on down state.
12387 - BUG/MEDIUM: peers: set NOLINGER on the outgoing stream interface
12388 - BUG/MEDIUM: h2: fix handling of end of stream again
12389 - MINOR: mworker: Update messages referencing exit-on-failure
12390 - MINOR: mworker: Improve wording in `void mworker_wait()`
12391 - CONTRIB: halog: Add help text for -s switch in halog program
12392 - BUG/MEDIUM: email-alert: don't set server check status from a email-alert task
12393 - BUG/MEDIUM: threads/vars: Fix deadlock in register_name
12394 - MINOR: systemd: remove comment about HAPROXY_STATS_SOCKET
12395 - DOC: notifications: add precisions about thread usage
12396 - BUG/MEDIUM: lua/notification: memory leak
12397 - MINOR: conn_stream: add new flag CS_FL_RCV_MORE to indicate pending data
12398 - BUG/MEDIUM: stream-int: always set SI_FL_WAIT_ROOM on CS_FL_RCV_MORE
12399 - BUG/MEDIUM: h2: automatically set CS_FL_RCV_MORE when the output buffer is full
12400 - BUG/MEDIUM: h2: enable recv polling whenever demuxing is possible
12401 - BUG/MEDIUM: h2: work around a connection API limitation
12402 - BUG/MEDIUM: h2: debug incoming traffic in h2_wake()
12403 - MINOR: h2: store the demux padding length in the h2c struct
12404 - BUG/MEDIUM: h2: support uploading partial DATA frames
12405 - MINOR: h2: don't demand that a DATA frame is complete before processing it
12406 - BUG/MEDIUM: h2: don't switch the state to HREM before end of DATA frame
12407 - BUG/MEDIUM: h2: don't close after the first DATA frame on tunnelled responses
12408 - BUG/MEDIUM: http: don't disable lingering on requests with tunnelled responses
12409 - BUG/MEDIUM: h2: fix stream limit enforcement
12410 - BUG/MINOR: stream-int: don't try to receive again after receiving an EOS
12411 - MINOR: sample: add len converter
12412 - BUG: MAJOR: lb_map: server map calculation broken
12413 - BUG: MINOR: http: don't check http-request capture id when len is provided
12414 - MINOR: sample: rename the "len" converter to "length"
12415 - BUG/MEDIUM: mworker: Set FD_CLOEXEC flag on log fd
12416 - DOC/MINOR: intro: typo, wording, formatting fixes
12417 - MINOR: netscaler: respect syntax
12418 - MINOR: netscaler: remove the use of cip_magic only used once
12419 - MINOR: netscaler: rename cip_len to clarify its uage
12420 - BUG/MEDIUM: netscaler: use the appropriate IPv6 header size
12421 - BUG/MAJOR: netscaler: address truncated CIP header detection
12422 - MINOR: netscaler: check in one-shot if buffer is large enough for IP and TCP header
12423 - MEDIUM: netscaler: do not analyze original IP packet size
12424 - MEDIUM: netscaler: add support for standard NetScaler CIP protocol
12425 - MINOR: spoe: add force-set-var option in spoe-agent configuration
12426 - CONTRIB: iprange: Fix compiler warning in iprange.c
12427 - CONTRIB: halog: Fix compiler warnings in halog.c
12428 - BUG/MINOR: h2: properly report a stream error on RST_STREAM
12429 - MINOR: mux: add flags to describe a mux's capabilities
12430 - MINOR: stream-int: set flag SI_FL_CLEAN_ABRT when mux supports clean aborts
12431 - BUG/MEDIUM: stream: don't consider abortonclose on muxes which close cleanly
12432 - BUG/MEDIUM: checks: a server passed in maint state was not forced down.
12433 - BUG/MEDIUM: lua: fix crash when using bogus mode in register_service()
12434 - MINOR: http: adjust the list of supposedly cacheable methods
12435 - MINOR: http: update the list of cacheable status codes as per RFC7231
12436 - MINOR: http: start to compute the transaction's cacheability from the request
12437 - BUG/MINOR: http: do not ignore cache-control: public
12438 - BUG/MINOR: http: properly detect max-age=0 and s-maxage=0 in responses
12439 - BUG/MINOR: cache: do not force the TX_CACHEABLE flag before checking cacheability
12440 - MINOR: http: add a function to check request's cache-control header field
12441 - BUG/MEDIUM: cache: do not try to retrieve host-less requests from the cache
12442 - BUG/MEDIUM: cache: replace old object on store
12443 - BUG/MEDIUM: cache: respect the request cache-control header
12444 - BUG/MEDIUM: cache: don't cache the response on no-cache="set-cookie"
12445 - BUG/MAJOR: connection: refine the situations where we don't send shutw()
12446 - BUG/MEDIUM: checks: properly set servers to stopping state on 404
12447 - BUG/MEDIUM: h2: properly handle and report some stream errors
12448 - BUG/MEDIUM: h2: improve handling of frames received on closed streams
12449 - DOC/MINOR: configuration: typo, formatting fixes
12450 - BUG/MEDIUM: h2: ensure we always know the stream before sending a reset
12451 - BUG/MEDIUM: mworker: don't close stdio several time
12452 - MINOR: don't close stdio anymore
12453 - BUG/MEDIUM: http: don't automatically forward request close
12454 - BUG/MAJOR: hpack: don't return direct references to the dynamic headers table
12455 - MINOR: h2: add a function to report pseudo-header names
12456 - DEBUG: hpack: make hpack_dht_dump() expose the output file
12457 - DEBUG: hpack: add more traces to the hpack decoder
12458 - CONTRIB: hpack: add an hpack decoder
12459 - MEDIUM: h2: prepare a graceful shutdown when the frontend is stopped
12460 - BUG/MEDIUM: h2: properly handle the END_STREAM flag on empty DATA frames
12461 - BUILD: ssl: silence a warning when building without NPN nor ALPN support
12462 - CLEANUP: rbtree: remove
12463 - BUG/MEDIUM: ssl: cache doesn't release shctx blocks
12464 - BUG/MINOR: lua: Fix default value for pattern in Socket.receive
12465 - DOC: lua: Fix typos in comments of hlua_socket_receive
12466 - BUG/MEDIUM: lua: Fix IPv6 with separate port support for Socket.connect
12467 - BUG/MINOR: lua: Fix return value of Socket.settimeout
12468 - MINOR: dns: Handle SRV record weight correctly.
12469 - BUG/MEDIUM: mworker: execvp failure depending on argv[0]
12470 - MINOR: hathreads: add support for gcc < 4.7
12471 - BUILD/MINOR: ancient gcc versions atomic fix
12472 - BUG/MEDIUM: stream: properly handle client aborts during redispatch
12473 - MINOR: spoe: add register-var-names directive in spoe-agent configuration
12474 - MINOR: spoe: Don't queue a SPOE context if nothing is sent
12475 - DOC: clarify the scope of ssl_fc_is_resumed
12476 - CONTRIB: debug: fix a few flags definitions
12477 - BUG/MINOR: poll: too large size allocation for FD events
12478 - MINOR: sample: add date_us sample
12479 - BUG/MEDIUM: peers: fix expire date wasn't updated if entry is modified remotely.
12480 - MINOR: servers: Don't report duplicate dyncookies for disabled servers.
12481 - MINOR: global/threads: move cpu_map at the end of the global struct
12482 - MINOR: threads: add a MAX_THREADS define instead of LONGBITS
12483 - MINOR: global: add some global activity counters to help debugging
12484 - MINOR: threads/fd: Use a bitfield to know if there are FDs for a thread in the FD cache
12485 - BUG/MEDIUM: threads/polling: Use fd_cache_mask instead of fd_cache_num
12486 - BUG/MEDIUM: fd: maintain a per-thread update mask
12487 - MINOR: fd: add a bitmask to indicate that an FD is known by the poller
12488 - BUG/MEDIUM: epoll/threads: use one epoll_fd per thread
12489 - BUG/MEDIUM: kqueue/threads: use one kqueue_fd per thread
12490 - BUG/MEDIUM: threads/mworker: fix a race on startup
12491 - BUG/MINOR: mworker: only write to pidfile if it exists
12492 - MINOR: threads: Fix build when we're not compiling with threads.
12493 - BUG/MINOR: threads: always set an owner to the thread_sync pipe
12494 - BUG/MEDIUM: threads/server: Fix deadlock in srv_set_stopping/srv_set_admin_flag
12495 - BUG/MEDIUM: checks: Don't try to release undefined conn_stream when a check is freed
12496 - BUG/MINOR: kqueue/threads: Don't forget to close kqueue_fd[tid] on each thread
12497 - MINOR: threads: Use __decl_hathreads instead of #ifdef/#endif
12498 - BUILD: epoll/threads: Add test on MAX_THREADS to avoid warnings when complied without threads
12499 - BUILD: kqueue/threads: Add test on MAX_THREADS to avoid warnings when complied without threads
12500 - CLEANUP: sample: Fix comment encoding of sample.c
12501 - CLEANUP: sample: Fix outdated comment about sample casts functions
12502 - BUG/MINOR: sample: Fix output type of c_ipv62ip
12503 - CLEANUP: Fix typo in ARGT_MSK6 comment
12504 - CLEANUP: standard: Use len2mask4 in str2mask
12505 - MINOR: standard: Add str2mask6 function
12506 - MINOR: config: Add support for ARGT_MSK6
12507 - MEDIUM: sample: Add IPv6 support to the ipmask converter
12508 - MINOR: config: Enable tracking of up to MAX_SESS_STKCTR stick counters.
12509 - BUG/MINOR: cli: use global.maxsock and not maxfd to list all FDs
12510 - MINOR: polling: make epoll and kqueue not depend on maxfd anymore
12511 - MINOR: fd: don't report maxfd in alert messages
12512 - MEDIUM: polling: start to move maxfd computation to the pollers
12513 - CLEANUP: fd/threads: remove the now unused fdtab_lock
12514 - MINOR: poll: more accurately compute the new maxfd in the loop
12515 - CLEANUP: fd: remove the unused "new" field
12516 - MINOR: fd: move the hap_fd_{clr,set,isset} functions to fd.h
12517 - MEDIUM: select: make use of hap_fd_* functions
12518 - MEDIUM: fd: use atomic ops for hap_fd_{clr,set} and remove poll_lock
12519 - MEDIUM: select: don't use the old FD state anymore
12520 - MEDIUM: poll: don't use the old FD state anymore
12521 - MINOR: fd: pass the iocb and owner to fd_insert()
12522 - BUG/MINOR: threads: Update labels array because of changes in lock_label enum
12523 - MINOR: stick-tables: Adds support for new "gpc1" and "gpc1_rate" counters.
12524 - BUG/MINOR: epoll/threads: only call epoll_ctl(DEL) on polled FDs
12525 - DOC: don't suggest using http-server-close
12526 - MINOR: introduce proxy-v2-options for send-proxy-v2
12527 - BUG/MEDIUM: spoe: Always try to receive or send the frame to detect shutdowns
12528 - BUG/MEDIUM: spoe: Allow producer to read and to forward shutdown on request side
12529 - MINOR: spoe: Remove check on min_applets number when a SPOE context is queued
12530 - MINOR: spoe: Always link a SPOE context with the applet processing it
12531 - MINOR: spoe: Replace sending_rate by a frequency counter
12532 - MINOR: spoe: Count the number of frames waiting for an ack for each applet
12533 - MEDIUM: spoe: Use an ebtree to manage idle applets
12534 - MINOR: spoa_example: Count the number of frames processed by each worker
12535 - MINOR: spoe: Add max-waiting-frames directive in spoe-agent configuration
12536 - MINOR: init: make stdout unbuffered
12537 - MINOR: early data: Don't rely on CO_FL_EARLY_DATA to wake up streams.
12538 - MINOR: early data: Never remove the CO_FL_EARLY_DATA flag.
12539 - MINOR: compiler: introduce offsetoff().
12540 - MINOR: threads: Introduce double-width CAS on x86_64 and arm.
12541 - MINOR: threads: add test and set/reset operations
12542 - MINOR: pools/threads: Implement lockless memory pools.
12543 - MAJOR: fd/threads: Make the fdcache mostly lockless.
12544 - MEDIUM: fd/threads: Make sure we don't miss a fd cache entry.
12545 - MAJOR: fd: compute the new fd polling state out of the fd lock
12546 - MINOR: epoll: get rid of the now useless fd_compute_new_polled_status()
12547 - MINOR: kqueue: get rid of the now useless fd_compute_new_polled_status()
12548 - MINOR: poll: get rid of the now useless fd_compute_new_polled_status()
12549 - MINOR: select: get rid of the now useless fd_compute_new_polled_status()
12550 - CLEANUP: fd: remove the now unused fd_compute_new_polled_status() function
12551 - MEDIUM: fd: make updt_fd_polling() use atomics
12552 - MEDIUM: poller: use atomic ops to update the fdtab mask
12553 - MINOR: fd: move the fd_{add_to,rm_from}_fdlist functions to fd.c
12554 - BUG/MINOR: fd/threads: properly dereference fdcache as volatile
12555 - MINOR: fd: remove the unneeded last CAS when adding an fd to the list
12556 - MINOR: fd: reorder fd_add_to_fd_list()
12557 - BUG/MINOR: time/threads: ensure the adjusted time is always correct
12558 - BUG/MEDIUM: standard: Fix memory leak in str2ip2()
12559 - MINOR: init: emit warning when -sf/-sd cannot parse argument
12560 - BUILD: fd/threads: fix breakage build breakage without threads
12561 - DOC: Describe routing impact of using interface keyword on bind lines
12562 - DOC: Mention -Ws in the list of available options
12563 - BUG/MINOR: config: don't emit a warning when global stats is incompletely configured
12564 - BUG/MINOR: fd/threads: properly lock the FD before adding it to the fd cache.
12565 - BUG/MEDIUM: threads: fix the double CAS implementation for ARMv7
12566 - BUG/MEDIUM: ssl: Don't always treat SSL_ERROR_SYSCALL as unrecovarable.
12567 - BUILD/MINOR: memory: stdint is needed for uintptr_t
12568 - BUG/MINOR: init: Add missing brackets in the code parsing -sf/-st
12569 - DOC: lua: new prototype for function "register_action()"
12570 - DOC: cfgparse: Warn on option (tcp|http)log in backend
12571 - BUG/MINOR: ssl/threads: Make management of the TLS ticket keys files thread-safe
12572 - MINOR: sample: add a new "concat" converter
12573 - BUG/MEDIUM: ssl: Shutdown the connection for reading on SSL_ERROR_SYSCALL
12574 - BUG/MEDIUM: http: Switch the HTTP response in tunnel mode as earlier as possible
12575 - BUG/MEDIUM: ssl/sample: ssl_bc_* fetch keywords are broken.
12576 - MINOR: ssl/sample: adds ssl_bc_is_resumed fetch keyword.
12577 - CLEANUP: cfgparse: Remove unused label end
12578 - CLEANUP: spoe: Remove unused label retry
12579 - CLEANUP: h2: Remove unused labels from mux_h2.c
12580 - CLEANUP: pools: Remove unused end label in memory.h
12581 - CLEANUP: standard: Fix typo in IPv6 mask example
12582 - BUG/MINOR: pools/threads: don't ignore DEBUG_UAF on double-word CAS capable archs
12583 - BUG/MINOR: debug/pools: properly handle out-of-memory when building with DEBUG_UAF
12584 - MINOR: debug/pools: make DEBUG_UAF also detect underflows
12585 - MINOR: stats: display the number of threads in the statistics.
12586 - BUG/MINOR: h2: Set the target of dbuf_wait to h2c
12587 - BUG/MEDIUM: h2: always consume any trailing data after end of output buffers
12588 - BUG/MEDIUM: buffer: Fix the wrapping case in bo_putblk
12589 - BUG/MEDIUM: buffer: Fix the wrapping case in bi_putblk
12590 - BUG/MEDIUM: spoe: Remove idle applets from idle list when HAProxy is stopping
12591 - Revert "BUG/MINOR: send-proxy-v2: string size must include ('\0')"
12592 - MINOR: ssl: extract full pkey info in load_certificate
12593 - MINOR: ssl: add ssl_sock_get_pkey_algo function
12594 - MINOR: ssl: add ssl_sock_get_cert_sig function
12595 - MINOR: connection: add proxy-v2-options ssl-cipher,cert-sig,cert-key
12596 - MINOR: connection: add proxy-v2-options authority
12597 - MINOR: systemd: Add section for SystemD sandboxing to unit file
12598 - MINOR: systemd: Add SystemD's Protect*= options to the unit file
12599 - MINOR: systemd: Add SystemD's SystemCallFilter option to the unit file
12600 - CLEANUP: h2: rename misleading h2c_stream_close() to h2s_close()
12601 - MINOR: h2: provide and use h2s_detach() and h2s_free()
12602 - MEDIUM: h2: use a single buffer allocator
12603 - MINOR/BUILD: fix Lua build on Mac OS X
12604 - BUILD/MINOR: fix Lua build on Mac OS X (again)
12605 - BUG/MINOR: session: Fix tcp-request session failure if handshake.
12606 - CLEANUP: .gitignore: Ignore binaries from the contrib directory
12607 - BUG/MINOR: unix: Don't mess up when removing the socket from the xfer_sock_list.
12608 - DOC: buffers: clarify the purpose of the <from> pointer in offer_buffers()
12609 - BUG/MEDIUM: h2: also arm the h2 timeout when sending
12610 - BUG/MINOR: cli: Fix a crash when passing a negative or too large value to "show fd"
12611 - CLEANUP: ssl: Remove a duplicated #include
12612 - CLEANUP: cli: Remove a leftover debug message
12613 - BUG/MINOR: cli: Fix a typo in the 'set rate-limit' usage
12614 - BUG/MEDIUM: fix a 100% cpu usage with cpu-map and nbthread/nbproc
12615 - BUG/MINOR: force-persist and ignore-persist only apply to backends
12616 - BUG/MEDIUM: threads/unix: Fix a deadlock when a listener is temporarily disabled
12617 - BUG/MAJOR: threads/queue: Fix thread-safety issues on the queues management
12618 - BUG/MINOR: dns: don't downgrade DNS accepted payload size automatically
12619 - TESTS: Add a testcase for multi-port + multi-server listener issue
12620 - CLEANUP: dns: remove duplicate code in src/dns.c
12621 - BUG/MINOR: seemless reload: Fix crash when an interface is specified.
12622 - BUG/MINOR: cli: Ensure all command outputs end with a LF
12623 - BUG/MINOR: cli: Fix a crash when sending a command with too many arguments
12624 - BUILD: ssl: Fix build with OpenSSL without NPN capability
12625 - BUG/MINOR: spoa-example: unexpected behavior for more than 127 args
12626 - BUG/MINOR: lua: return bad error messages
12627 - CLEANUP: lua/syntax: lua is a name and not an acronym
12628 - BUG/MEDIUM: tcp-check: single connect rule can't detect DOWN servers
12629 - BUG/MINOR: tcp-check: use the server's service port as a fallback
12630 - BUG/MEDIUM: threads/queue: wake up other threads upon dequeue
12631 - MINOR: log: stop emitting alerts when it's not possible to write on the socket
12632 - BUILD/BUG: enable -fno-strict-overflow by default
12633 - BUG/MEDIUM: fd/threads: ensure the fdcache_mask always reflects the cache contents
12634 - DOC: log: more than 2 log servers are allowed
12635 - MINOR: hash: add new function hash_crc32c
12636 - MINOR: proxy-v2-options: add crc32c
12637 - MINOR: accept-proxy: support proxy protocol v2 CRC32c checksum
12638 - REORG: compact "struct server"
12639 - MINOR: samples: add crc32c converter
12640 - BUG/MEDIUM: h2: properly account for DATA padding in flow control
12641 - BUG/MINOR: h2: ensure we can never send an RST_STREAM in response to an RST_STREAM
12642 - BUG/MINOR: listener: Don't decrease actconn twice when a new session is rejected
12643 - CLEANUP: map, stream: remove duplicate code in src/map.c, src/stream.c
12644 - BUG/MINOR: lua: the function returns anything
12645 - BUG/MINOR: lua funtion hlua_socket_settimeout don't check negative values
12646 - CLEANUP: lua: typo fix in comments
12647 - BUILD/MINOR: fix build when USE_THREAD is not defined
12648 - MINOR: lua: allow socket api settimeout to accept integers, float, and doubles
12649 - BUG/MINOR: hpack: fix harmless use of uninitialized value in hpack_dht_insert
12650 - MINOR: cli/threads: make "show fd" report thread_sync_io_handler instead of "unknown"
12651 - MINOR: cli: make "show fd" report the mux and mux_ctx pointers when available
12652 - BUILD/MINOR: cli: fix a build warning introduced by last commit
12653 - BUG/MAJOR: h2: remove orphaned streams from the send list before closing
12654 - MINOR: h2: always call h2s_detach() in h2_detach()
12655 - MINOR: h2: fuse h2s_detach() and h2s_free() into h2s_destroy()
12656 - BUG/MEDIUM: h2/threads: never release the task outside of the task handler
12657 - BUG/MEDIUM: h2: don't consider pending data on detach if connection is in error
12658 - BUILD/MINOR: threads: always export thread_sync_io_handler()
12659 - MINOR: mux: add a "show_fd" function to dump debugging information for "show fd"
12660 - MINOR: h2: implement a basic "show_fd" function
12661 - MINOR: cli: report cache indexes in "show fd"
12662 - BUG/MINOR: h2: remove accidental debug code introduced with show_fd function
12663 - BUG/MEDIUM: h2: always add a stream to the send or fctl list when blocked
12664 - BUG/MINOR: checks: check the conn_stream's readiness and not the connection
12665 - BUG/MINOR: fd: Don't clear the update_mask in fd_insert.
12666 - BUG/MINOR: email-alert: Set the mailer port during alert initialization
12667 - BUG/MINOR: cache: fix "show cache" output
12668 - BUG/MAJOR: cache: fix random crashes caused by incorrect delete() on non-first blocks
12669 - BUG/MINOR: spoe: Initialize variables used during conf parsing before any check
12670 - BUG/MINOR: spoe: Don't release the context buffer in .check_timeouts callbaclk
12671 - BUG/MINOR: spoe: Register the variable to set when an error occurred
12672 - BUG/MINOR: spoe: Don't forget to decrement fpa when a processing is interrupted
12673 - MINOR: spoe: Add metrics in to know time spent in the SPOE
12674 - MINOR: spoe: Add options to store processing times in variables
12675 - MINOR: log: move 'log' keyword parsing in dedicated function
12676 - MINOR: log: Keep the ref when a log server is copied to avoid duplicate entries
12677 - MINOR: spoe: Add loggers dedicated to the SPOE agent
12678 - MINOR: spoe: Add support for option dontlog-normal in the SPOE agent section
12679 - MINOR: spoe: use agent's logger to log SPOE messages
12680 - MINOR: spoe: Add counters to log info about SPOE agents
12681 - BUG/MAJOR: cache: always initialize newly created objects
12682 - MINOR: servers: Support alphanumeric characters for the server templates names
12683 - BUG/MEDIUM: threads: Fix the max/min calculation because of name clashes
12684 - BUG/MEDIUM: connection: Make sure we have a mux before calling detach().
12685 - BUG/MINOR: http: Return an error in proxy mode when url2sa fails
12686 - MINOR: proxy: Add fe_defbe fetcher
12687 - MINOR: config: Warn if resolvers has no nameservers
12688 - BUG/MINOR: cli: Guard against NULL messages when using CLI_ST_PRINT_FREE
12689 - MINOR: cli: Ensure the CLI always outputs an error when it should
12690 - MEDIUM: sample: Extend functionality for field/word converters
12691 - MINOR: export localpeer as an environment variable
12692 - BUG/MEDIUM: kqueue: When adding new events, provide an output to get errors.
12693 - BUILD: sample: avoid build warning in sample.c
12694 - BUG/CRITICAL: h2: fix incorrect frame length check
12695 - DOC: lua: update the links to the config and Lua API
12696 - BUG/MINOR: pattern: Add a missing HA_SPIN_INIT() in pat_ref_newid()
12697 - BUG/MAJOR: channel: Fix crash when trying to read from a closed socket
12698 - BUG/MINOR: log: t_idle (%Ti) is not set for some requests
12699 - BUG/MEDIUM: lua: Fix segmentation fault if a Lua task exits
12700 - MINOR: h2: detect presence of CONNECT and/or content-length
12701 - BUG/MEDIUM: h2: implement missing support for chunked encoded uploads
12702 - BUG/MINOR: spoe: Fix counters update when processing is interrupted
12703 - BUG/MINOR: spoe: Fix parsing of dontlog-normal option
12704 - MEDIUM: cli: Add payload support
12705 - MINOR: map: Add payload support to "add map"
12706 - MINOR: ssl: Add payload support to "set ssl ocsp-response"
12707 - BUG/MINOR: lua/threads: Make lua's tasks sticky to the current thread
12708 - MINOR: sample: Add strcmp sample converter
12709 - MINOR: http: Add support for 421 Misdirected Request
12710 - BUG/MINOR: config: disable http-reuse on TCP proxies
12711 - MINOR: ssl: disable SSL sample fetches when unsupported
12712 - MINOR: ssl: add fetch 'ssl_fc_session_key' and 'ssl_bc_session_key'
12713 - BUG/MINOR: checks: Fix check->health computation for flapping servers
12714 - BUG/MEDIUM: threads: Fix the sync point for more than 32 threads
12715 - BUG/MINOR, BUG/MINOR: lua: Put tasks to sleep when waiting for data
12716 - MINOR: backend: implement random-based load balancing
12717 - DOC/MINOR: clean up LUA documentation re: servers & array/table.
12718 - MINOR: lua: Add server name & puid to LUA Server class.
12719 - MINOR: lua: add get_maxconn and set_maxconn to LUA Server class.
12720 - BUG/MINOR: map: correctly track reference to the last ref_elt being dumped
12721 - BUG/MEDIUM: task: Don't free a task that is about to be run.
12722 - MINOR: fd: Make the lockless fd list work with multiple lists.
12723 - BUG/MEDIUM: pollers: Use a global list for fd shared between threads.
12724 - MINOR: pollers: move polled_mask outside of struct fdtab.
12725 - BUG/MINOR: lua: schedule socket task upon lua connect()
12726 - BUG/MINOR: lua: ensure large proxy IDs can be represented
12727 - BUG/MEDIUM: pollers/kqueue: use incremented position in event list
12728 - BUG/MINOR: cli: don't stop cli_gen_usage_msg() when kw->usage == NULL
12729 - BUG/MEDIUM: http: don't always abort transfers on CF_SHUTR
12730 - BUG/MEDIUM: ssl: properly protect SSL cert generation
12731 - BUG/MINOR: lua: Socket.send threw runtime error: 'close' needs 1 arguments.
12732 - BUG/MINOR: spoe: Mistake in error message about SPOE configuration
12733 - BUG/MEDIUM: spoe: Flags are not encoded in network order
12734 - CLEANUP: spoe: Remove unused variables the agent structure
12735 - DOC: spoe: fix a typo
12736 - BUG/MEDIUM: contrib/mod_defender: Use network order to encode/decode flags
12737 - BUG/MEDIUM: contrib/modsecurity: Use network order to encode/decode flags
12738 - DOC: add some description of the pending rework of the buffer structure
12739 - BUG/MINOR: ssl/lua: prevent lua from affecting automatic maxconn computation
12740 - MINOR: lua: Improve error message
12741 - BUG/MEDIUM: cache: don't cache when an Authorization header is present
12742 - MINOR: ssl: set SSL_OP_PRIORITIZE_CHACHA
12743 - BUG/MEDIUM: dns: Delay the attempt to run a DNS resolution on check failure.
12744 - BUG/BUILD: threads: unbreak build without threads
12745 - BUG/MEDIUM: servers: Add srv_addr default placeholder to the state file
12746 - BUG/MEDIUM: lua/socket: Length required read doesn't work
12747 - MINOR: tasks: Change the task API so that the callback takes 3 arguments.
12748 - MAJOR: tasks: Create a per-thread runqueue.
12749 - MAJOR: tasks: Introduce tasklets.
12750 - MINOR: tasks: Make the number of tasks to run at once configurable.
12751 - MAJOR: applets: Use tasks, instead of rolling our own scheduler.
12752 - BUG/MEDIUM: stick-tables: Decrement ref_cnt in table_* converters
12753 - MINOR: http: Log warning if (add|set)-header fails
12754 - DOC: management: add the new wrew stats column
12755 - MINOR: stats: also report the failed header rewrites warnings on the stats page
12756 - BUG/MEDIUM: tasks: Don't forget to increase/decrease tasks_run_queue.
12757 - BUG/MEDIUM: task: Don't forget to decrement max_processed after each task.
12758 - MINOR: task: Also consider the task list size when getting global tasks.
12759 - MINOR: dns: Implement `parse-resolv-conf` directive
12760 - BUG/MEDIUM: spoe: Return an error when the wrong ACK is received in sync mode
12761 - MINOR: task/notification: Is notifications registered ?
12762 - BUG/MEDIUM: lua/socket: wrong scheduling for sockets
12763 - BUG/MAJOR: lua: Dead lock with sockets
12764 - BUG/MEDIUM: lua/socket: Notification error
12765 - BUG/MEDIUM: lua/socket: Sheduling error on write: may dead-lock
12766 - BUG/MEDIUM: lua/socket: Buffer error, may segfault
12767 - DOC: contrib/modsecurity: few typo fixes
12768 - DOC: SPOE.txt: fix a typo
12769 - MAJOR: spoe: upgrade the SPOP version to 2.0 and remove the support for 1.0
12770 - BUG/MINOR: contrib/spoa_example: Don't reset the status code during disconnect
12771 - BUG/MINOR: contrib/mod_defender: Don't reset the status code during disconnect
12772 - BUG/MINOR: contrib/modsecurity: Don't reset the status code during disconnect
12773 - BUG/MINOR: contrib/mod_defender: update pointer on the end of the frame
12774 - BUG/MINOR: contrib/modsecurity: update pointer on the end of the frame
12775 - MINOR: task: Fix a compiler warning by adding a cast.
12776 - MINOR: stats: also report the nice and number of calls for applets
12777 - MINOR: applet: assign the same nice value to a new appctx as its owner task
12778 - MINOR: task: Fix compiler warning.
12779 - BUG/MEDIUM: tasks: Use the local runqueue when building without threads.
12780 - MINOR: tasks: Don't define rqueue if we're building without threads.
12781 - BUG/MINOR: unix: Make sure we can transfer abns sockets on seamless reload.
12782 - MINOR: lua: Increase debug information
12783 - BUG/MEDIUM: threads: handle signal queue only in thread 0
12784 - BUG/MINOR: don't ignore SIG{BUS,FPE,ILL,SEGV} during signal processing
12785 - BUG/MINOR: signals: ha_sigmask macro for multithreading
12786 - BUG/MAJOR: map: fix a segfault when using http-request set-map
12787 - DOC: regression testing: Add a short starting guide.
12788 - MINOR: tasks: Make sure we correctly init and deinit a tasklet.
12789 - BUG/MINOR: tasklets: Just make sure we don't pass a tasklet to the handler.
12790 - BUG/MINOR: lua: Segfaults with wrong usage of types.
12791 - BUG/MAJOR: ssl: Random crash with cipherlist capture
12792 - BUG/MAJOR: ssl: OpenSSL context is stored in non-reserved memory slot
12793 - BUG/MEDIUM: ssl: do not store pkinfo with SSL_set_ex_data
12794 - MINOR: tests: First regression testing file.
12795 - MINOR: reg-tests: Add reg-tests/README file.
12796 - MINOR: reg-tests: Add a few regression testing files.
12797 - DOC: Add new REGTEST tag info about reg testing.
12798 - BUG/MEDIUM: fd: Don't modify the update_mask in fd_dodelete().
12799 - MINOR: Some spelling cleanup in the comments.
12800 - BUG/MEDIUM: threads: Use the sync point to check active jobs and exit
12801 - MINOR: threads: Be sure to remove threads from all_threads_mask on exit
12802 - REGTEST/MINOR: Wrong URI in a reg test for SSL/TLS.
12803 - REGTEST/MINOR: Set HAPROXY_PROGRAM default value.
12804 - REGTEST/MINOR: Add levels to reg-tests target.
12805 - BUG/MAJOR: Stick-tables crash with segfault when the key is not in the stick-table
12806 - BUG/BUILD: threads: unbreak build without threads
12807 - BUG/MAJOR: stick_table: Complete incomplete SEGV fix
12808 - MINOR: stick-tables: make stktable_release() do nothing on NULL
12809 - BUG/MEDIUM: lua: possible CLOSE-WAIT state with '\n' headers
12810 - MINOR: startup: change session/process group settings
12811 - MINOR: systemd: consider exit status 143 as successful
12812 - REGTEST/MINOR: Wrong URI syntax.
12813 - CLEANUP: dns: remove obsolete macro DNS_MAX_IP_REC
12814 - CLEANUP: dns: inacurate comment about prefered IP score
12815 - MINOR: dns: fix wrong score computation in dns_get_ip_from_response
12816 - MINOR: dns: new DNS options to allow/prevent IP address duplication
12817 - REGTEST/MINOR: Unexpected curl URL globling.
12818 - BUG/MINOR: ssl: properly ref-count the tls_keys entries
12819 - MINOR: h2: keep a count of the number of conn_streams attached to the mux
12820 - BUG/MEDIUM: h2: don't accept new streams if conn_streams are still in excess
12821 - MINOR: h2: add the mux and demux buffer lengths on "show fd"
12822 - BUG/MEDIUM: h2: never leave pending data in the output buffer on close
12823 - BUG/MEDIUM: h2: make sure the last stream closes the connection after a timeout
12824 - MINOR: tasklet: Set process to NULL.
12825 - MINOR: buffer: implement a new file for low-level buffer manipulation functions
12826 - MINOR: buffer: switch buffer sizes and offsets to size_t
12827 - MINOR: buffer: add a few basic functions for the new API
12828 - MINOR: buffer: Introduce b_sub(), b_add(), and bo_add()
12829 - MINOR: buffer: Add b_set_data().
12830 - MINOR: buffer: introduce b_realign_if_empty()
12831 - MINOR: compression: pass the channel to http_compression_buffer_end()
12832 - MINOR: channel: add a few basic functions for the new buffer API
12833 - MINOR: channel/buffer: use c_realign_if_empty() instead of buffer_realign()
12834 - MINOR: channel/buffer: replace buffer_slow_realign() with channel_slow_realign() and b_slow_realign()
12835 - MEDIUM: channel: make channel_slow_realign() take a swap buffer
12836 - MINOR: h2: use b_slow_realign() with the trash as a swap buffer
12837 - MINOR: buffer: remove buffer_slow_realign() and the swap_buffer allocation code
12838 - MINOR: channel/buffer: replace b_{adv,rew} with c_{adv,rew}
12839 - MINOR: buffer: replace calls to buffer_space_wraps() with b_space_wraps()
12840 - MINOR: buffer: remove bi_getblk() and bi_getblk_nc()
12841 - MINOR: buffer: split bi_contig_data() into ci_contig_data and b_config_data()
12842 - MINOR: buffer: remove bi_ptr()
12843 - MINOR: buffer: remove bo_ptr()
12844 - MINOR: buffer: remove bo_end()
12845 - MINOR: buffer: remove bi_end()
12846 - MINOR: buffer: remove bo_contig_data()
12847 - MINOR: buffer: merge b{i,o}_contig_space()
12848 - MINOR: buffer: replace bo_getblk() with direction agnostic b_getblk()
12849 - MINOR: buffer: replace bo_getblk_nc() with b_getblk_nc() which takes an offset
12850 - MINOR: buffer: replace bi_del() and bo_del() with b_del()
12851 - MINOR: buffer: convert most b_ptr() calls to c_ptr()
12852 - MINOR: h1: make h1_measure_trailers() take the byte count in argument
12853 - MINOR: h2: clarify the fact that the send functions are unsigned
12854 - MEDIUM: h2: prevent the various mux encoders from modifying the buffer
12855 - MINOR: h1: make h1_skip_chunk_crlf() not depend on b_ptr() anymore
12856 - MINOR: h1: make h1_parse_chunk_size() not depend on b_ptr() anymore
12857 - MINOR: h1: make h1_measure_trailers() use an offset and a count
12858 - MEDIUM: h2: do not use buf->o anymore inside h2_snd_buf's loop
12859 - MEDIUM: h2: don't use b_ptr() nor b_end() anymore
12860 - MINOR: buffer: get rid of b_end() and b_to_end()
12861 - MINOR: buffer: make b_getblk_nc() take const pointers
12862 - MINOR: buffer: make b_getblk_nc() take size_t for the block sizes
12863 - MEDIUM: connection: make xprt->snd_buf() take the byte count in argument
12864 - MEDIUM: mux: make mux->snd_buf() take the byte count in argument
12865 - MEDIUM: connection: make xprt->rcv_buf() use size_t for the count
12866 - MEDIUM: mux: make mux->rcv_buf() take a size_t for the count
12867 - MINOR: connection: add a flags argument to rcv_buf()
12868 - MINOR: connection: add a new receive flag : CO_RFL_BUF_WET
12869 - MINOR: buffer: get rid of b_ptr() and convert its last users
12870 - MINOR: buffer: use b_room() to determine available space in a buffer
12871 - MINOR: buffer: replace buffer_not_empty() with b_data() or c_data()
12872 - MINOR: buffer: replace buffer_empty() with b_empty() or c_empty()
12873 - MINOR: buffer: make bo_putchar() use b_tail()
12874 - MINOR: buffer: replace buffer_full() with channel_full()
12875 - MINOR: buffer: replace bi_space_for_replace() with ci_space_for_replace()
12876 - MINOR: buffer: replace buffer_pending() with ci_data()
12877 - MINOR: buffer: replace buffer_flush() with c_adv(chn, ci_data(chn))
12878 - MINOR: buffer: use c_head() instead of buffer_wrap_sub(c->buf, p-o)
12879 - MINOR: buffer: use b_orig() to replace most references to b->data
12880 - MINOR: buffer: Use b_add()/bo_add() instead of accessing b->i/b->o.
12881 - MINOR: channel: remove almost all references to buf->i and buf->o
12882 - MINOR: channel: Add co_set_data().
12883 - MEDIUM: channel: adapt to the new buffer API
12884 - MINOR: checks: adapt to the new buffer API
12885 - MEDIUM: h2: update to the new buffer API
12886 - MINOR: buffer: remove unused bo_add()
12887 - MEDIUM: spoe: use the new buffer API for the SPOE buffer
12888 - MINOR: stats: adapt to the new buffers API
12889 - MINOR: cli: use the new buffer API
12890 - MINOR: cache: use the new buffer API
12891 - MINOR: stream-int: use the new buffer API
12892 - MINOR: stream: use wrappers instead of directly manipulating buffers
12893 - MINOR: backend: use new buffer API
12894 - MEDIUM: http: use wrappers instead of directly manipulating buffers states
12895 - MINOR: filters: convert to the new buffer API
12896 - MINOR: payload: convert to the new buffer API
12897 - MEDIUM: h1: port to new buffer API.
12898 - MINOR: flt_trace: adapt to the new buffer API
12899 - MEDIUM: compression: start to move to the new buffer API
12900 - MINOR: lua: use the wrappers instead of directly manipulating buffer states
12901 - MINOR: buffer: convert part bo_putblk() and bi_putblk() to the new API
12902 - MINOR: buffer: adapt buffer_slow_realign() and buffer_dump() to the new API
12903 - MAJOR: start to change buffer API
12904 - MINOR: buffer: remove the check for output on b_del()
12905 - MINOR: buffer: b_set_data() doesn't truncate output data anymore
12906 - MINOR: buffer: rename the "data" field to "area"
12907 - MEDIUM: buffers: move "output" from struct buffer to struct channel
12908 - MINOR: buffer: replace bi_fast_delete() with b_del()
12909 - MINOR: buffer: replace b{i,o}_put* with b_put*
12910 - MINOR: buffer: add a new file for ist + buffer manipulation functions
12911 - MINOR: checks: use b_putist() instead of b_putstr()
12912 - MINOR: buffers: remove b_putstr()
12913 - CLEANUP: buffer: minor cleanups to buffer.h
12914 - MINOR: buffers/channel: replace buffer_insert_line2() with ci_insert_line2()
12915 - MINOR: buffer: replace buffer_replace2() with b_rep_blk()
12916 - MINOR: buffer: rename the data length member to '->data'
12917 - MAJOR: buffer: finalize buffer detachment
12918 - MEDIUM: chunks: make the chunk struct's fields match the buffer struct
12919 - MAJOR: chunks: replace struct chunk with struct buffer
12920 - DOC: buffers: document the new buffers API
12921 - DOC: buffers: remove obsolete docs about buffers
12922 - MINOR: tasklets: Don't attempt to add a tasklet in the list twice.
12923 - MINOR: connections/mux: Add a new "subscribe" method.
12924 - MEDIUM: connections/mux: Revamp the send direction.
12925 - MINOR: connection: simplify subscription by adding a registration function
12926 - BUG/MINOR: http: Set brackets for the unlikely macro at the right place
12927 - BUG/MINOR: build: Fix compilation with debug mode enabled
12928 - BUILD: Generate sha256 checksums in publish-release
12929 - MINOR: debug: Add check for CO_FL_WILL_UPDATE
12930 - MINOR: debug: Add checks for conn_stream flags
12931 - MINOR: ist: Add the function isteqi
12932 - BUG/MEDIUM: threads: Fix the exit condition of the thread barrier
12933 - BUG/MEDIUM: mux_h2: Call h2_send() before updating polling.
12934 - MINOR: buffers: simplify b_contig_space()
12935 - MINOR: buffers: split b_putblk() into __b_putblk()
12936 - MINOR: buffers: add b_xfer() to transfer data between buffers
12937 - DOC: add some design notes about the new layering model
12938 - MINOR: conn_stream: add a new CS_FL_REOS flag
12939 - MINOR: conn_stream: add an rx buffer to the conn_stream
12940 - MEDIUM: conn_stream: add cs_recv() as a default rcv_buf() function
12941 - MEDIUM: stream-int: automatically call si_cs_recv_cb() if the cs has data on wake()
12942 - MINOR: h2: make each H2 stream support an intermediary input buffer
12943 - MEDIUM: h2: make h2_frt_decode_headers() use an intermediary buffer
12944 - MEDIUM: h2: make h2_frt_transfer_data() copy via an intermediary buffer
12945 - MEDIUM: h2: centralize transfer of decoded frames in h2_rcv_buf()
12946 - MEDIUM: h2: move headers and data frame decoding to their respective parsers
12947 - MEDIUM: buffers: make b_xfer() automatically swap buffers when possible
12948 - MEDIUM: h2: perform a single call to the data layer in demux()
12949 - MEDIUM: h2: don't call data_cb->recv() anymore
12950 - MINOR: h2: make use of CS_FL_REOS to indicate that end of stream was seen
12951 - MEDIUM: h2: use the default conn_stream's receive function
12952 - DOC: add more design feedback on the new layering model
12953 - MINOR: h2: add the error code and the max/last stream IDs to "show fd"
12954 - BUG/MEDIUM: stream-int: don't immediately enable reading when the buffer was reportedly full
12955 - BUG/MEDIUM: stats: don't ask for more data as long as we're responding
12956 - BUG/MINOR: servers: Don't make "server" in a frontend fatal.
12957 - BUG/MEDIUM: tasks: make sure we pick all tasks in the run queue
12958 - BUG/MEDIUM: tasks: Decrement rqueue_size at the right time.
12959 - BUG/MEDIUM: tasks: use atomic ops for active_tasks_mask
12960 - BUG/MEDIUM: tasks: Make sure there's no task left before considering inactive.
12961 - MINOR: signal: don't pass the signal number anymore as the wakeup reason
12962 - MINOR: tasks: extend the state bits from 8 to 16 and remove the reason
12963 - MINOR: tasks: Add a flag that tells if we're in the global runqueue.
12964 - BUG/MEDIUM: tasks: make __task_unlink_rq responsible for the rqueue size.
12965 - MINOR: queue: centralize dequeuing code a bit better
12966 - MEDIUM: queue: make pendconn_free() work on the stream instead
12967 - DOC: queue: document the expected locking model for the server's queue
12968 - MINOR: queue: make sure pendconn->strm->pend_pos is always valid
12969 - MINOR: queue: use a distinct variable for the assigned server and the queue
12970 - MINOR: queue: implement pendconn queue locking functions
12971 - MEDIUM: queue: get rid of the pendconn lock
12972 - MINOR: tasks: Make active_tasks_mask volatile.
12973 - MINOR: tasks: Make global_tasks_mask volatile.
12974 - MINOR: pollers: Add a way to wake a thread sleeping in the poller.
12975 - MINOR: threads/queue: Get rid of THREAD_WANT_SYNC in the queue code.
12976 - BUG/MEDIUM: threads/sync: use sched_yield when available
12977 - MINOR: ssl: BoringSSL matches OpenSSL 1.1.0
12978 - BUG/MEDIUM: h2: prevent orphaned streams from blocking a connection forever
12979 - BUG/MINOR: config: stick-table is not supported in defaults section
12980 - BUILD/MINOR: threads: unbreak build with threads disabled
12981 - BUG/MINOR: threads: Handle nbthread == MAX_THREADS.
12982 - BUG/MEDIUM: threads: properly fix nbthreads == MAX_THREADS
12983 - MINOR: threads: move "nbthread" parsing to hathreads.c
12984 - BUG/MEDIUM: threads: unbreak "bind" referencing an incorrect thread number
12985 - MEDIUM: proxy_protocol: Convert IPs to v6 when protocols are mixed
12986 - BUILD/MINOR: compiler: fix offsetof() on older compilers
12987 - SCRIPTS: git-show-backports: add missing quotes to "echo"
12988 - MINOR: threads: add more consistency between certain variables in no-thread case
12989 - MEDIUM: hathreads: implement a more flexible rendez-vous point
12990 - BUG/MEDIUM: cli: make "show fd" thread-safe
12991
Willy Tarreaub3066502017-11-26 19:50:17 +0100129922017/11/26 : 1.9-dev0
12993
Willy Tarreau0b787922017-11-26 19:25:23 +0100129942017/11/26 : 1.8.0
12995 - BUG/MEDIUM: stream: don't automatically forward connect nor close
12996 - BUG/MAJOR: stream: ensure analysers are always called upon close
12997 - BUG/MINOR: stream-int: don't try to read again when CF_READ_DONTWAIT is set
12998 - MEDIUM: mworker: Add systemd `Type=notify` support
12999 - BUG/MEDIUM: cache: free callback to remove from tree
13000 - CLEANUP: cache: remove unused struct
13001 - MEDIUM: cache: enable the HTTP analysers
13002 - CLEANUP: cache: remove wrong comment
13003 - MINOR: threads/atomic: rename local variables in macros to avoid conflicts
13004 - MINOR: threads/plock: rename local variables in macros to avoid conflicts
13005 - MINOR: threads/atomic: implement pl_mb() in asm on x86
13006 - MINOR: threads/atomic: implement pl_bts() on non-x86
13007 - MINOR: threads/build: atomic: replace the few inlines with macros
13008 - BUILD: threads/plock: fix a build issue on Clang without optimization
13009 - BUILD: ebtree: don't redefine types u32/s32 in scope-aware trees
13010 - BUILD: compiler: add a new type modifier __maybe_unused
13011 - BUILD: h2: mark some inlined functions "unused"
13012 - BUILD: server: check->desc always exists
13013 - BUG/MEDIUM: h2: properly report connection errors in headers and data handlers
13014 - MEDIUM: h2: add a function to emit an HTTP/1 request from a headers list
13015 - MEDIUM: h2: change hpack_decode_headers() to only provide a list of headers
13016 - BUG/MEDIUM: h2: always reassemble the Cookie request header field
13017 - BUG/MINOR: systemd: ignore daemon mode
13018 - CONTRIB: spoa_example: allow to compile outside HAProxy.
13019 - CONTRIB: spoa_example: remove bref, wordlist, cond_wordlist
13020 - CONTRIB: spoa_example: remove last dependencies on type "sample"
13021 - CONTRIB: spoa_example: remove SPOE enums that are useless for clients
13022 - CLEANUP: cache: reorder includes
13023 - MEDIUM: shctx: use unsigned int for len and block_count
13024 - MEDIUM: cache: "show cache" on the cli
13025 - BUG/MEDIUM: cache: use key=0 as a condition for freeing
13026 - BUG/MEDIUM: cache: refcount forbids to free the objects
13027 - BUG/MEDIUM: cache fix cli_kws structure
13028 - BUG/MEDIUM: deinit: correctly deinitialize the proxy and global listener tasks
13029 - BUG/MINOR: ssl: Always start the handshake if we can't send early data.
13030 - MINOR: ssl: Don't disable early data handling if we could not write.
13031 - MINOR: pools: prepare functions to override malloc/free in pools
13032 - MINOR: pools: implement DEBUG_UAF to detect use after free
13033 - BUG/MEDIUM: threads/time: fix time drift correction
13034 - BUG/MEDIUM: threads/time: maintain a common time reference between all threads
13035 - MINOR: sample: Add "thread" sample fetch
13036 - BUG/MINOR: Use crt_base instead of ca_base when crt is parsed on a server line
13037 - BUG/MINOR: stream: fix tv_request calculation for applets
13038 - BUG/MAJOR: h2: always remove a stream from the send list before freeing it
13039 - BUG/MAJOR: threads/task: dequeue expired tasks under the WQ lock
13040 - MINOR: ssl: Handle reading early data after writing better.
13041 - MINOR: mux: Make sure every string is woken up after the handshake.
13042 - MEDIUM: cache: store sha1 for hashing the cache key
13043 - MINOR: http: implement the "http-request reject" rule
13044 - MINOR: h2: send RST_STREAM before GOAWAY on reject
13045 - MEDIUM: h2: don't gracefully close the connection anymore on Connection: close
13046 - MINOR: h2: make use of client-fin timeout after GOAWAY
13047 - MEDIUM: config: ensure that tune.bufsize is at least 16384 when using HTTP/2
13048 - MINOR: ssl: Handle early data with BoringSSL
13049 - BUG/MEDIUM: stream: always release the stream-interface on abort
13050 - BUG/MEDIUM: cache: free ressources in chn_end_analyze
13051 - MINOR: cache: move the refcount decrease in the applet release
13052 - BUG/MINOR: listener: Allow multiple "process" options on "bind" lines
13053 - MINOR: config: Support a range to specify processes in "cpu-map" parameter
13054 - MINOR: config: Slightly change how parse_process_number works
13055 - MINOR: config: Export parse_process_number and use it wherever it's applicable
13056 - MINOR: standard: Add my_ffsl function to get the position of the bit set to one
13057 - MINOR: config: Add auto-increment feature for cpu-map
13058 - MINOR: config: Support partial ranges in cpu-map directive
13059 - MINOR:: config: Remove thread-map directive
13060 - MINOR: config: Add the threads support in cpu-map directive
13061 - MINOR: config: Add threads support for "process" option on "bind" lines
13062 - MEDIUM: listener: Bind listeners on a thread subset if specified
13063 - CLEANUP: debug: Use DPRINTF instead of fprintf into #ifdef DEBUG_FULL/#endif
13064 - CLEANUP: log: Rename Alert/Warning in ha_alert/ha_warning
13065 - MINOR/CLEANUP: proxy: rename "proxy" to "proxies_list"
13066 - CLEANUP: pools: rename all pool functions and pointers to remove this "2"
13067 - DOC: update the roadmap file with the latest changes merged in 1.8
13068 - DOC: fix mangled version in peers protocol documentation
13069 - DOC: add initial peers protovol v2.0 documentation.
13070 - DOC: mention William as maintainer of the cache and master-worker
13071 - DOC: add Christopher and Emeric as maintainers of the threads
13072 - MINOR: cache: replace a fprint() by an abort()
13073 - MEDIUM: cache: max-age configuration keyword
13074 - DOC: explain HTTP2 timeout behavior
13075 - DOC: cache: configuration and management
13076 - MAJOR: mworker: exits the master on failure
13077 - BUG/MINOR: threads: don't drop "extern" on the lock in include files
13078 - MINOR: task: keep a pointer to the currently running task
13079 - MINOR: task: align the rq and wq locks
13080 - MINOR: fd: cache-align fdtab and fdcache locks
13081 - MINOR: buffers: cache-align buffer_wq_lock
13082 - CLEANUP: server: reorder some fields in struct server to save 40 bytes
13083 - CLEANUP: proxy: slightly reorder the struct proxy to reduce holes
13084 - CLEANUP: checks: remove 16 bytes of holes in struct check
13085 - CLEANUP: cache: more efficiently pack the struct cache
13086 - CLEANUP: fd: place the lock at the beginning of struct fdtab
13087 - CLEANUP: pools: align pools on a cache line
13088 - DOC: config: add a few bits about how to configure HTTP/2
13089 - BUG/MAJOR: threads/queue: avoid recursive locking in pendconn_get_next_strm()
13090 - BUILD: Makefile: reorder object files by size
13091
Willy Tarreaucfe14662017-11-19 09:55:29 +0100130922017/11/19 : 1.8-rc4
13093 - BUG/MEDIUM: cache: does not cache if no Content-Length
13094 - BUILD: thread/pipe: fix build without threads
13095 - BUG/MINOR: spoe: check buffer size before acquiring or releasing it
13096 - MINOR: debug/flags: Add missing flags
13097 - MINOR: threads: Use __decl_hathreads to declare locks
13098 - BUG/MINOR: buffers: Fix b_alloc_margin to be "fonctionnaly" thread-safe
13099 - BUG/MAJOR: ebtree/scope: fix insertion and removal of duplicates in scope-aware trees
13100 - BUG/MAJOR: ebtree/scope: fix lookup of next node in scope-aware trees
13101 - MINOR: ebtree/scope: add a function to find next node from a parent
13102 - MINOR: ebtree/scope: simplify the lookup functions by using eb32sc_next_with_parent()
13103 - BUG/MEDIUM: mworker: Fix re-exec when haproxy is started from PATH
13104 - BUG/MEDIUM: cache: use msg->sov to forward header
13105 - MINOR: cache: forward data with headers
13106 - MINOR: cache: disable cache if shctx_row_data_append fail
13107 - BUG/MINOR: threads: tid_bit must be a unsigned long
13108 - CLEANUP: tasks: Remove useless double test on rq_next
13109 - BUG/MEDIUM: standard: itao_str/idx and quote_str/idx must be thread-local
13110 - MINOR: tools: add a function to dump a scope-aware tree to a file
13111 - MINOR: tools: improve the DOT dump of the ebtree
13112 - MINOR: tools: emphasize the node being worked on in the tree dump
13113 - BUG/MAJOR: ebtree/scope: properly tag upper nodes during insertion
13114 - DOC: peers: Add a first version of peers protocol v2.1.
13115 - CONTRIB: Wireshark dissector for HAProxy Peer Protocol.
13116 - MINOR: mworker: display an accurate error when the reexec fail
13117 - BUG/MEDIUM: mworker: wait again for signals when execvp fail
13118 - BUG/MEDIUM: mworker: does not deinit anymore
13119 - BUG/MEDIUM: mworker: does not close inherited FD
13120 - MINOR: tests: add a python wrapper to test inherited fd
13121 - BUG/MINOR: Allocate the log buffers before the proxies startup
13122 - MINOR: tasks: Use a bitfield to track tasks activity per-thread
13123 - MAJOR: polling: Use active_tasks_mask instead of tasks_run_queue
13124 - MINOR: applets: Use a bitfield to track applets activity per-thread
13125 - MAJOR: polling: Use active_appels_mask instead of applets_active_queue
13126 - MEDIUM: applets: Don't process more than 200 active applets at once
13127 - MINOR: stream: Add thread-mask of tasks/FDs/applets in "show sess all" command
13128 - MINOR: SSL: Store the ASN1 representation of client sessions.
13129 - MINOR: ssl: Make sure we don't shutw the connection before the handshake.
13130 - BUG/MEDIUM: deviceatlas: ignore not valuable HTTP request data
13131
Willy Tarreau34650d52017-11-11 09:06:48 +0100131322017/11/11 : 1.8-rc3
13133 - BUILD: use MAXPATHLEN instead of NAME_MAX.
13134 - BUG/MAJOR: threads/checks: add 4 missing spin_unlock() in various functions
13135 - BUG/MAJOR: threads/server: missing unlock in CLI fqdn parser
13136 - BUG/MINOR: cli: do not perform an invalid action on "set server check-port"
13137 - BUG/MAJOR: threads/checks: wrong use of SPIN_LOCK instead of SPIN_UNLOCK
13138 - CLEANUP: checks: remove return statements in locked functions
13139 - BUG/MINOR: cli: add severity in "set server addr" parser
13140 - CLEANUP: server: get rid of return statements in the CLI parser
13141 - BUG/MAJOR: cli/streams: missing unlock on exit "show sess"
13142 - BUG/MAJOR: threads/dns: add missing unlock on allocation failure path
13143 - BUG/MAJOR: threads/lb: fix missing unlock on consistent hash LB
13144 - BUG/MAJOR: threads/lb: fix missing unlock on map-based hash LB
13145 - BUG/MEDIUM: threads/stick-tables: close a race condition on stktable_trash_expired()
13146 - BUG/MAJOR: h2: set the connection's task to NULL when no client timeout is set
13147 - BUG/MAJOR: thread/listeners: enable_listener must not call unbind_listener()
13148 - BUG/MEDIUM: threads: don't try to free build option message on exit
13149 - MINOR: applets: no need to check for runqueue's emptiness in appctx_res_wakeup()
13150 - MINOR: add master-worker in the warning about nbproc
13151 - MINOR: mworker: allow pidfile in mworker + foreground
13152 - MINOR: mworker: write parent pid in the pidfile
13153 - MINOR: mworker: do not store child pid anymore in the pidfile
13154 - MINOR: ebtree: implement the scope-aware functions for eb32
13155 - MEDIUM: ebtree: specify the scope of every node inserted via eb32sc
13156 - MINOR: ebtree: update the eb32sc parent node's scope on delete
13157 - MEDIUM: ebtree: only consider the branches matching the scope in lookups
13158 - MINOR: ebtree: implement eb32sc_lookup_ge_or_first()
13159 - MAJOR: task: make use of the scope-aware ebtree functions
13160 - MINOR: task: simplify wake_expired_tasks() to avoid unlocking in the loop
13161 - MEDIUM: task: change the construction of the loop in process_runnable_tasks()
13162 - MINOR: threads: use faster locks for the spin locks
13163 - MINOR: tasks: only visit filled task slots after processing them
13164 - MEDIUM: tasks: implement a lockless scheduler for single-thread usage
13165 - BUG/MINOR: dns: Don't try to get the server lock if it's already held.
13166 - BUG/MINOR: dns: Don't lock the server lock in snr_check_ip_callback().
13167 - DOC: Add note about encrypted password CPU usage
13168 - BUG/MINOR: h2: set the "HEADERS_SENT" flag on stream, not connection
13169 - BUG/MEDIUM: h2: properly send an RST_STREAM on mux stream error
13170 - BUG/MEDIUM: h2: properly send the GOAWAY frame in the mux
13171 - BUG/MEDIUM: h2: don't try (and fail) to send non-existing data in the mux
13172 - MEDIUM: h2: remove the H2_SS_RESET intermediate state
13173 - BUG/MEDIUM: h2: fix some wrong error codes on connections
13174 - BUILD: threads: Rename SPIN/RWLOCK macros using HA_ prefix
13175 - BUILD: enable USE_THREAD for Solaris build.
13176 - BUG/MEDIUM: h2: don't close the connection is there are data left
13177 - MINOR: h2: don't re-enable the connection's task when we're closing
13178 - BUG/MEDIUM: h2: properly set H2_SF_ES_SENT when sending the final frame
13179 - BUG/MINOR: h2: correctly check for H2_SF_ES_SENT before closing
13180 - MINOR: h2: add new stream flag H2_SF_OUTGOING_DATA
13181 - BUG/MINOR: h2: don't send GOAWAY on failed response
13182 - BUG/MEDIUM: splice/threads: pipe reuse list was not protected.
13183 - BUG/MINOR: comp: fix compilation warning compiling without compression.
13184 - BUG/MINOR: stream-int: don't set MSG_MORE on closed request path
13185 - BUG/MAJOR: threads/tasks: fix the scheduler again
13186 - BUG/MINOR; ssl: Don't assume we have a ssl_bind_conf because a SNI is matched.
13187 - MINOR: ssl: Handle session resumption with TLS 1.3
13188 - MINOR: ssl: Spell 0x10101000L correctly.
13189 - MINOR: ssl: Handle sending early data to server.
13190 - BUILD: ssl: fix build of backend without ssl
13191 - BUILD: shctx: do not depend on openssl anymore
13192 - BUG/MINOR: h1: the HTTP/1 make status code parser check for digits
13193 - BUG/MEDIUM: h2: reject non-3-digit status codes
13194 - BUG/MEDIUM: stream-int: Don't loss write's notifs when a stream is woken up
13195 - BUG/MINOR: pattern: Rely on the sample type to copy it in pattern_exec_match
13196 - BUG/MEDIUM: h2: split the function to send RST_STREAM
13197 - BUG/MEDIUM: h1: ensure the chunk size parser can deal with full buffers
13198 - MINOR: tools: don't use unlikely() in hex2i()
13199 - BUG/MEDIUM: h2: support orphaned streams
13200 - BUG/MEDIUM: threads/cli: fix "show sess" locking on release
13201 - CLEANUP: mux: remove the unused "release()" function
13202 - MINOR: cli: make "show fd" report the fd's thread mask
13203 - BUG/MEDIUM: stream: don't ignore res.analyse_exp anymore
13204 - CLEANUP: global: introduce variable pid_bit to avoid shifts with relative_pid
13205 - MEDIUM: http: always reject the "PRI" method
13206
Willy Tarreaua8d8d6e2017-11-03 23:52:47 +0100132072017/11/03 : 1.8-rc2
13208 - BUG/MINOR: send-proxy-v2: fix dest_len in make_tlv call
13209 - BUG/MINOR: send-proxy-v2: string size must include ('\0')
13210 - MINOR: mux: Only define pipe functions on linux.
13211 - MINOR: cache: Remove useless test for nonzero.
13212 - MINOR: cache: Don't confuse act_return and act_parse_ret.
13213 - BUG/MEDIUM: h2: don't try to parse incomplete H1 responses
13214 - BUG/MEDIUM: checks/mux: always enable send-polling after connecting
13215 - BUG/MAJOR: fix deadlock on healthchecks.
13216 - BUG/MINOR: thread: fix a typo in the debug code
13217 - BUILD: shctx: allow to be built without openssl
13218 - BUG/MEDIUM: cache: don't try to resolve wrong filters
13219 - BUG/MAJOR: buffers: fix get_buffer_nc() for data at end of buffer
13220 - BUG/MINOR: freq: fix infinite loop on freq_ctr_period.
13221 - BUG/MINOR: stdarg.h inclusion
13222 - BUG/MINOR: dns: fix missing lock protection on server.
13223 - BUG/MINOR: lua: fix missing lock protection on server.
13224 - BUILD: enable USE_THREAD for OpenBSD build.
13225 - BUG/MAJOR: mux_pt: don't dereference a connstream after ->wake()
13226 - MINOR: thread: report multi-thread support in haproxy -vv
13227
Willy Tarreau901f75c2017-10-31 23:18:29 +0100132282017/10/31 : 1.8-rc1
13229 - BUG/MEDIUM: server: Allocate tmptrash before using it.
13230 - CONTRIB: trace: add the possibility to place trace calls in the code
13231 - CONTRIB: trace: try to display the function's return value on exit
13232 - CONTRIB: trace: report the base name only for file names
13233 - BUILD: ssl: support OPENSSL_NO_ASYNC #define
13234 - MINOR: ssl: build with recent BoringSSL library
13235 - BUG/MINOR: ssl: OCSP_single_get0_status can return -1
13236 - BUG/MINOR: cli: restore "set ssl tls-key" command
13237 - CLEANUP: cli: remove undocumented "set ssl tls-keys" command
13238 - IMPORT: sha1: import SHA1 functions
13239 - MINOR: sample: add the sha1 converter
13240 - MINOR: sample: add the hex2i converter
13241 - MINOR: stream-int: stop checking for useless connection flags in chk_snd_conn
13242 - MINOR: ssl: don't abort after sending 16kB
13243 - MINOR: connection: move the cleanup of flag CO_FL_WAIT_ROOM
13244 - MINOR: connection: add flag CO_FL_WILL_UPDATE to indicate when updates are granted
13245 - MEDIUM: connection: make use of CO_FL_WILL_UPDATE in conn_sock_shutw()
13246 - MINOR: raw_sock: make use of CO_FL_WILL_UPDATE
13247 - MINOR: ssl_sock: make use of CO_FL_WILL_UPDATE
13248 - BUG/MINOR: checks: Don't forget to release the connection on error case.
13249 - MINOR: buffer: add the buffer input manipulation functions
13250 - BUG/MEDIUM: prevent buffers being overwritten during build_logline() execution
13251 - MEDIUM: cfgparse: post section callback
13252 - MEDIUM: cfgparse: post parsing registration
13253 - MINOR: lua: add uuid to the Class Proxy
13254 - MINOR: hlua: Add regex class
13255 - MINOR: http: Mark the 425 code as "Too Early".
13256 - MEDIUM: ssl: convert CBS (BoringSSL api) usage to neutral code
13257 - MINOR: ssl: support Openssl 1.1.1 early callback for switchctx
13258 - MINOR: ssl: generated certificate is missing in switchctx early callback
13259 - MEDIUM: ssl: Handle early data with OpenSSL 1.1.1
13260 - BUILD: Makefile: disable -Wunused-label
13261 - MINOR: ssl/proto_http: Add keywords to take care of early data.
13262 - BUG/MINOR: lua: const attribute of a string is overridden
13263 - MINOR: ssl: Don't abuse ssl_options.
13264 - MINOR: update proxy-protocol-v2 #define
13265 - MINOR: merge ssl_sock_get calls for log and ppv2
13266 - MINOR: add ALPN information to send-proxy-v2
13267 - MEDIUM: h1: ensure that 1xx, 204 and 304 don't have a payload body
13268 - CLEANUP: shctx: get ride of the shsess_packet{_hdr} structures
13269 - MEDIUM: lists: list_for_each_entry{_safe}_from functions
13270 - REORG: shctx: move lock functions and struct
13271 - MEDIUM: shctx: allow the use of multiple shctx
13272 - REORG: shctx: move ssl functions to ssl_sock.c
13273 - MEDIUM: shctx: separate ssl and shctx
13274 - MINOR: shctx: rename lock functions
13275 - MINOR: h1: store the status code in the H1 message
13276 - BUG/MINOR: spoe: Don't compare engine name and SPOE scope when both are NULL
13277 - BUG/MINOR: spoa: Update pointer on the end of the frame when a reply is encoded
13278 - MINOR: action: Add trk_idx inline function
13279 - MINOR: action: Use trk_idx instead of tcp/http_trk_idx
13280 - MINOR: action: Add a function pointer in act_rule struct to check its validity
13281 - MINOR: action: Add function to check rules using an action ACT_ACTION_TRK_*
13282 - MINOR: action: Add a functions to check http capture rules
13283 - MINOR: action: Factorize checks on rules calling check_ptr if defined
13284 - MINOR: acl: Pass the ACLs as an explicit parameter of build_acl_cond
13285 - MEDIUM: spoe: Add support of ACLS to enable or disable sending of SPOE messages
13286 - MINOR: spoe: Check uniqness of SPOE engine names during config parsing
13287 - MEDIUM: spoe: Parse new "spoe-group" section in SPOE config file
13288 - MEDIUM: spoe/rules: Add "send-spoe-group" action for tcp/http rules
13289 - MINOR: spoe: Move message encoding in its own function
13290 - MINOR: spoe: Add a type to qualify the message list during encoding
13291 - MINOR: spoe: Add a generic function to encode a list of SPOE message
13292 - MEDIUM: spoe/rules: Process "send-spoe-group" action
13293 - BUG/MINOR: dns: Fix CLI keyword declaration
13294 - MAJOR: dns: Refactor the DNS code
13295 - BUG/MINOR: mailers: Fix a memory leak when email alerts are released
13296 - MEDIUM: mailers: Init alerts during conf parsing and refactor their processing
13297 - MINOR: mailers: Use pools to allocate email alerts and its tcpcheck_rules
13298 - MINOR: standard: Add memvprintf function
13299 - MINOR: log: Save alerts and warnings emitted during HAProxy startup
13300 - MINOR: cli: Add "show startup-logs" command
13301 - MINOR: startup: Extend the scope the MODE_STARTING flag
13302 - MINOR: threads: Prepare makefile to link with pthread
13303 - MINOR: threads: Add THREAD_LOCAL macro
13304 - MINOR: threads: Add atomic-ops and plock includes in import dir
13305 - MEDIUM: threads: Add hathreads header file
13306 - MINOR: threads: Add mechanism to register per-thread init/deinit functions
13307 - MINOR: threads: Add nbthread parameter
13308 - MEDIUM: threads: Adds a set of functions to handle sync-point
13309 - MAJOR: threads: Start threads to experiment multithreading
13310 - MINOR: threads: Define the sync-point inside run_poll_loop
13311 - MEDIUM: threads/buffers: Define and register per-thread init/deinit functions
13312 - MEDIUM: threads/chunks: Transform trash chunks in thread-local variables
13313 - MEDIUM: threads/time: Many global variables from time.h are now thread-local
13314 - MEDIUM: threads/logs: Make logs thread-safe
13315 - MEDIUM: threads/pool: Make pool thread-safe by locking all access to a pool
13316 - MAJOR: threads/fd: Make fd stuffs thread-safe
13317 - MINOR: threads/fd: Add a mask of threads allowed to process on each fd in fdtab array
13318 - MEDIUM: threads/fd: Initialize the process mask during the call to fd_insert
13319 - MINOR: threads/fd: Process cached events of FDs depending on the process mask
13320 - MINOR: threads/polling: pollers now handle FDs depending on the process mask
13321 - WIP: SQUASH WITH SYNC POINT
13322 - MAJOR: threads/task: handle multithread on task scheduler
13323 - MEDIUM: threads/signal: Add a lock to make signals thread-safe
13324 - MEDIUM: threads/listeners: Make listeners thread-safe
13325 - MEDIUM: threads/proxy: Add a lock per proxy and atomically update proxy vars
13326 - MEDIUM: threads/server: Make connection list (priv/idle/safe) thread-safe
13327 - MEDIUM: threads/server: Add a lock per server and atomically update server vars
13328 - MINOR: threads/server: Add a lock to deal with insert in updates_servers list
13329 - MEDIUM: threads/lb: Make LB algorithms (lb_*.c) thread-safe
13330 - MEDIUM: threads/stick-tables: handle multithreads on stick tables
13331 - MINOR: threads/sample: Change temp_smp into a thread local variable
13332 - MEDIUM: threads/http: Make http_capture_bad_message thread-safe
13333 - MINOR: threads/regex: Change Regex trash buffer into a thread local variable
13334 - MAJOR: threads/applet: Handle multithreading for applets
13335 - MAJOR: threads/peers: Make peers thread safe
13336 - MAJOR: threads/buffer: Make buffer wait queue thread safe
13337 - MEDIUM: threads/stream: Make streams list thread safe
13338 - MAJOR: threads/ssl: Make SSL part thread-safe
13339 - MEDIUM: threads/queue: Make queues thread-safe
13340 - MAJOR: threads/map: Make acls/maps thread safe
13341 - MEDIUM: threads/freq_ctr: Make the frequency counters thread-safe
13342 - MEDIUM: thread/vars: Make vars thread-safe
13343 - MEDIUM: threads/filters: Add init/deinit callback per thread
13344 - MINOR: threads/filters: Update trace filter to add _per_thread callbacks
13345 - MEDIUM: threads/compression: Make HTTP compression thread-safe
13346 - MEDIUM: threads/lua: Makes the jmpbuf and some other buffers local to the current thread.
13347 - MEDIUM: threads/lua: Add locks around the Lua execution parts.
13348 - MEDIUM: threads/lua: Ensure that the launched tasks runs on the same threads than me
13349 - MEDIUM: threads/lua: Cannot acces to the socket if we try to access from another thread.
13350 - MEDIUM: threads/xref: Convert xref function to a thread safe model
13351 - MEDIUM: threads/tasks: Add lock around notifications
13352 - MEDIUM: thread/spoe: Make the SPOE thread-safe
13353 - MEDIUM: thread/dns: Make DNS thread-safe
13354 - MINOR: threads: Add thread-map config parameter in the global section
13355 - MINOR: threads/checks: Add a lock to protect the pid list used by external checks
13356 - MINOR: threads/checks: Set the task process_mask when a check is executed
13357 - MINOR: threads/mailers: Add a lock to protect queues of email alerts
13358 - MEDIUM: threads/server: Use the server lock to protect health check and cli concurrency
13359 - MINOR: threads: Don't start when device a detection module is used
13360 - BUG/MEDIUM: threads: Run the poll loop on the main thread too
13361 - BUG/MINOR: threads: Add missing THREAD_LOCAL on static here and there
13362 - MAJOR: threads: Offically enable the threads support in HAProxy
13363 - BUG/MAJOR: threads/freq_ctr: fix lock on freq counters.
13364 - BUG/MAJOR: threads/time: Store the time deviation in an 64-bits integer
13365 - BUILD: stick-tables: silence an uninitialized variable warning
13366 - BUG/MINOR: dns: Fix SRV records with the new thread code.
13367 - MINOR: ssl: Remove the global allow-0rtt option.
13368 - CLEANUP: threads: replace the last few 1UL<<tid with tid_bit
13369 - CLEANUP: threads: rename process_mask to thread_mask
13370 - MINOR: h1: add a function to measure the trailers length
13371 - MINOR: threads: add a portable barrier for threads and non-threads
13372 - BUG/MAJOR: threads/freq_ctr: use a memory barrier to detect changes
13373 - BUG/MEDIUM: threads: Initialize the sync-point
13374 - MEDIUM: connection: start to introduce a mux layer between xprt and data
13375 - MINOR: connection: implement alpn registration of muxes
13376 - MINOR: mux: register the pass-through mux for any ALPN string
13377 - MEDIUM: session: use the ALPN token and proxy mode to select the mux
13378 - MINOR: connection: report the major HTTP version from the MUX for logging (fc_http_major)
13379 - MINOR: connection: introduce conn_stream
13380 - MINOR: mux: add more methods to mux_ops
13381 - MINOR: connection: introduce the conn_stream manipulation functions
13382 - MINOR: mux_pt: implement remaining mux_ops methods
13383 - MAJOR: connection : Split struct connection into struct connection and struct conn_stream.
13384 - MINOR: connection: make conn_stream users also check for per-stream error flag
13385 - MINOR: conn_stream: new shutr/w status flags
13386 - MINOR: conn_stream: modify cs_shut{r,w} API to pass the desired mode
13387 - MEDIUM: connection: make conn_sock_shutw() aware of lingering
13388 - MINOR: connection: add cs_close() to close a conn_stream
13389 - MEDIUM: mux_pt: make cs_shutr() / cs_shutw() properly close the connection
13390 - MEDIUM: connection: replace conn_full_close() with cs_close()
13391 - MEDIUM: connection: make mux->detach() release the connection
13392 - MEDIUM: stream: do not forcefully close the client connection anymore
13393 - MEDIUM: checks: exclusively use cs_destroy() to release a connection
13394 - MEDIUM: connection: add a destroy callback
13395 - MINOR: session: release the listener with the session, not the stream
13396 - MEDIUM: session: make use of the connection's destroy callback
13397 - CONTRIB: hpack: implement a reverse huffman table generator for hpack
13398 - MINOR: hpack: implement the HPACK Huffman table decoder
13399 - MINOR: hpack: implement the header tables management
13400 - MINOR: hpack: implement the decoder
13401 - MEDIUM: hpack: implement basic hpack encoding
13402 - MINOR: h2: centralize all HTTP/2 protocol elements and constants
13403 - MINOR: h2: create a very minimalistic h2 mux
13404 - MINOR: h2: expose tune.h2.header-table-size to configure the table size
13405 - MINOR: h2: expose tune.h2.initial-window-size to configure the window size
13406 - MINOR: h2: expose tune.h2.max-concurrent-streams to limit the number of streams
13407 - MINOR: h2: create the h2c struct and allocate its pool
13408 - MINOR: h2: create the h2s struct and the associated pool
13409 - MINOR: h2: handle two extra stream states for errors
13410 - MINOR: h2: add a frame header descriptor for incoming frames
13411 - MEDIUM: h2: allocate and release the h2c context on connection init/end
13412 - MEDIUM: h2: implement basic recv/send/wake functions
13413 - MEDIUM: h2: dynamically allocate the demux buffer on Rx
13414 - MEDIUM: h2: implement the mux buffer allocator
13415 - MINOR: h2: add the connection and stream flags listing the causes for blocking
13416 - MINOR: h2: add function h2s_id() to report a stream's ID
13417 - MINOR: h2: small function to know when the mux is busy
13418 - MINOR: h2: new function h2c_error to mark an error on the connection
13419 - MINOR: h2: new function h2s_error() to mark an error on a stream
13420 - MINOR: h2: add h2_set_frame_size() to update the size in a binary frame
13421 - MINOR: h2: new function h2_peek_frame_hdr() to retrieve a new frame header
13422 - MINOR: h2: add a few functions to retrieve contents from a wrapping buffer
13423 - MINOR: h2: add stream lookup function based on the stream ID
13424 - MINOR: h2: create dummy idle and closed streams
13425 - MINOR: h2: add the function to create a new stream
13426 - MINOR: h2: update the {MUX,DEM}_{M,D}ALLOC flags on buffer availability
13427 - MEDIUM: h2: start to consider the H2_CF_{MUX,DEM}_* flags for polling
13428 - MINOR: h2: also terminate the connection on shutr
13429 - MEDIUM: h2: properly consider all conditions for end of connection
13430 - MEDIUM: h2: wake the connection up for send on pending streams
13431 - MEDIUM: h2: start to implement the frames processing loop
13432 - MINOR: h2: add a function to send a GOAWAY error frame
13433 - MINOR: h2: match the H2 connection preface on init
13434 - MEDIUM: h2: enable connection polling for send when a cs wants to emit
13435 - MEDIUM: h2: enable reading again on the connection if it was blocked on stream buffer full
13436 - MEDIUM: h2: process streams pending for sending
13437 - MINOR: h2: send a real SETTINGS frame based on the configuration
13438 - MEDIUM: h2: detect the presence of the first settings frame
13439 - MINOR: h2: create a stream parser for the demuxer
13440 - MINOR: h2: implement PING frames
13441 - MEDIUM: h2: decode SETTINGS frames and extract relevant settings
13442 - MINOR: h2: lookup the stream during demuxing
13443 - MEDIUM: h2: honor WINDOW_UPDATE frames
13444 - MINOR: h2: implement h2_send_rst_stream() to send RST_STREAM frames
13445 - MINOR: h2: handle CONTINUATION frames
13446 - MEDIUM: h2: partial implementation of h2_detach()
13447 - MEDIUM: h2: unblock a connection when its current stream detaches
13448 - MEDIUM: h2: basic processing of HEADERS frame
13449 - MEDIUM: h2: don't use trash to decode headers!
13450 - MEDIUM: h2: implement the response HEADERS frame to encode the H1 response
13451 - MEDIUM: h2: send the H1 response body as DATA frames
13452 - MEDIUM: h2: skip the response trailers if any
13453 - MEDIUM: h2: properly continue to parse header block when facing a 1xx response
13454 - MEDIUM: h2: send WINDOW_UPDATE frames for connection
13455 - MEDIUM: h2: handle request body in DATA frames
13456 - MINOR: h2: handle RST_STREAM frames
13457 - MEDIUM: h2: send DATA+ES or RST_STREAM on shutw/shutr
13458 - MINOR: h2: use a common function to signal some and all streams.
13459 - MEDIUM: h2: handle GOAWAY frames
13460 - MINOR: h2: centralize the check for the idle streams
13461 - MINOR: h2: centralize the check for the half-closed(remote) streams
13462 - MEDIUM: h2: silently ignore frames higher than last_id after GOAWAY
13463 - MINOR: h2: properly reject PUSH_PROMISE frames coming from the client
13464 - MEDIUM: h2: perform a graceful shutdown on "Connection: close"
13465 - MEDIUM: h2: send a GOAWAY frame when dealing with an empty response
13466 - MEDIUM: h2: apply a timeout to h2 connections
13467 - BUG/MEDIUM: h2: fix incorrect timeout handling on the connection
13468 - MEDIUM: shctx: forbid shctx to read more than expected
13469 - MEDIUM: cache: configuration parsing and initialization
13470 - MEDIUM: cache: store objects in cache
13471 - MEDIUM: cache: deliver objects from cache
13472
Willy Tarreauf08137c2017-10-22 10:13:45 +0200134732017/10/22 : 1.8-dev3
13474 - REORG: ssl: move defines and methodVersions table upper
13475 - MEDIUM: ssl: ctx_set_version/ssl_set_version func for methodVersions table
13476 - MINOR: ssl: support ssl-min-ver and ssl-max-ver with crt-list
13477 - MEDIUM: ssl: disable SSLv3 per default for bind
13478 - BUG/MAJOR: ssl: fix segfault on connection close using async engines.
13479 - BUG/MAJOR: ssl: buffer overflow using offloaded ciphering on async engine
13480 - BUG/MINOR: ssl: do not call directly the conn_fd_handler from async_fd_handler
13481 - BUG/MINOR: haproxy/cli : fix for solaris/illumos distros for CMSG* macros
13482 - BUG/MEDIUM: build without openssl broken
13483 - BUG/MINOR: warning: need_resend may be used uninitialized
13484 - BUG/MEDIUM: misplaced exit and wrong exit code
13485 - BUG/MINOR: Makefile: fix compile error with USE_LUA=1 in ubuntu16.04
13486 - BUILD: scripts: make publish-release support bare repositories
13487 - BUILD: scripts: add an automatic mode for publish-release
13488 - BUILD: scripts: add a "quiet" mode to publish-release
13489 - BUG/MAJOR: http: call manage_client_side_cookies() before erasing the buffer
13490 - BUG/MINOR: buffers: Fix bi/bo_contig_space to handle full buffers
13491 - CONTRIB: plug qdiscs: Plug queuing disciplines mini HOWTO.
13492 - BUG/MINOR: acls: Set the right refflag when patterns are loaded from a map
13493 - BUG/MINOR: ssl: Be sure that SSLv3 connection methods exist for openssl < 1.1.0
13494 - BUG/MINOR: http/filters: Be sure to wait if a filter loops in HTTP_MSG_ENDING
13495 - BUG/MEDIUM: peers: Peers CLOSE_WAIT issue.
13496 - BUG/MAJOR: server: Segfault after parsing server state file.
13497 - BUG/MEDIUM: unix: never unlink a unix socket from the file system
13498 - scripts: create-release pass -n to tail
13499 - SCRIPTS: create-release: enforce GIT_COMMITTER_{NAME|EMAIL} validity
13500 - BUG/MEDIUM: fix segfault when no argument to -x option
13501 - MINOR: warning on multiple -x
13502 - MINOR: mworker: don't copy -x argument anymore in copy_argv()
13503 - BUG/MEDIUM: mworker: don't reuse PIDs passed to the master
13504 - BUG/MINOR: Wrong peer task expiration handling during synchronization processing.
13505 - BUG/MINOR: cfgparse: Check if tune.http.maxhdr is in the range 1..32767
13506 - BUG/MINOR: log: pin the front connection when front ip/ports are logged
13507 - DOC: fix references to the section about the unix socket
13508 - BUG/MINOR: stream: flag TASK_WOKEN_RES not set if task in runqueue
13509 - MAJOR: task: task scheduler rework.
13510 - MINOR: task/stream: tasks related to a stream must be init by the caller.
13511 - MINOR: queue: Change pendconn_get_next_strm into private function
13512 - MINOR: backends: Change get_server_sh/get_server_uh into private function
13513 - MINOR: queue: Change pendconn_from_srv/pendconn_from_px into private functions
13514 - MEDIUM: stream: make stream_new() always set the target and analysers
13515 - MINOR: frontend: initialize HTTP layer after the debugging code
13516 - MINOR: connection: add a .get_alpn() method to xprt_ops
13517 - MINOR: ssl: add a get_alpn() method to ssl_sock
13518 - MINOR: frontend: retrieve the ALPN name when available
13519 - MINOR: frontend: report the connection's ALPN in the debug output
13520 - MINOR: stream: don't set backend's nor response analysers on SF_TUNNEL
13521 - MINOR: connection: send data before receiving
13522 - MAJOR: applet: applet scheduler rework.
13523 - BUG/MAJOR: frontend: don't dereference a null conn on outgoing connections
13524 - BUG/MAJOR: cli: fix custom io_release was crushed by NULL.
13525 - BUG/MAJOR: map: fix segfault during 'show map/acl' on cli.
13526 - BUG/MAJOR: compression: Be sure to release the compression state in all cases
13527 - MINOR: compression: Use a memory pool to allocate compression states
13528 - BUG/MAJOR: applet: fix a freeze if data is immedately forwarded.
13529 - DOC: fix references to the section about time format.
13530 - BUG/MEDIUM: map/acl: fix unwanted flags inheritance.
13531 - BUG/MAJOR: http: fix buffer overflow on loguri buffer.
13532 - MINOR: ssl: compare server certificate names to the SNI on outgoing connections
13533 - BUG/MINOR: stream: Don't forget to remove CF_WAKE_ONCE flag on response channel
13534 - BUG/MINOR: http: Don't reset the transaction if there are still data to send
13535 - BUG/MEDIUM: filters: Be sure to call flt_end_analyze for both channels
13536 - MINOR: peers: Add additional information to stick-table definition messages.
13537 - BUG/MINOR: http: properly handle all 1xx informational responses
13538 - OPTIM: ssl: don't consider a small ssl_read() as an indication of end of buffer
13539 - BUG/MINOR: peers: peer synchronization issue (with several peers sections).
13540 - CLEANUP: hdr_idx: make some function arguments const where possible
13541 - BUG/MINOR: Prevent a use-after-free on error scenario on option "-x".
13542 - BUG/MINOR: lua: In error case, the safe mode is not removed
13543 - BUG/MINOR: lua: executes the function destroying the Lua session in safe mode
13544 - BUG/MAJOR: lua/socket: resources not detroyed when the socket is aborted
13545 - BUG/MEDIUM: lua: bad memory access
13546 - BUG/MINOR: Lua: variable already initialized
13547 - DOC: update CONTRIBUTING regarding optional parts and message format
13548 - DOC: update the list of OpenSSL versions in the README
13549 - BUG/MINOR: http: Set the response error state in http_sync_res_state
13550 - MINOR: http: Reorder/rewrite checks in http_resync_states
13551 - MINOR: http: Switch requests/responses in TUNNEL mode only by checking txn flags
13552 - BUG/MEDIUM: http: Switch HTTP responses in TUNNEL mode when body length is undefined
13553 - MINOR: http: Rely on analyzers mask to end processing in forward_body functions
13554 - BUG/MINOR: http: Fix bug introduced in previous patch in http_resync_states
13555 - BUG/MINOR: contrib/modsecurity: BSD build fix
13556 - BUG/MINOR: contrib/mod_defender: build fix
13557 - BUG/MINOR: ssl: remove haproxy SSLv3 support when ssl lib have no SSLv3
13558 - MINOR: ssl: remove an unecessary SSL_OP_NO_* dependancy
13559 - BUILD: ssl: fix compatibility with openssl without TLSEXT_signature_*
13560 - MINOR: tools: add a portable timegm() alternative
13561 - BUILD: lua: replace timegm() with my_timegm() to fix build on Solaris 10
13562 - DOC: Updated 51Degrees git URL to point to a stable version.
13563 - BUG/MAJOR: http: Fix possible infinity loop in http_sync_(req|res)_state
13564 - MINOR: memory: remove macros
13565 - BUG/MINOR: lua: Fix Server.get_addr() port values
13566 - BUG/MINOR: lua: Correctly use INET6_ADDRSTRLEN in Server.get_addr()
13567 - MINOR: samples: Handle the type SMP_T_METH when we duplicate a sample in smp_dup
13568 - MINOR: samples: Handle the type SMP_T_METH in smp_is_safe and smp_is_rw
13569 - MINOR: samples: Don't allocate memory for SMP_T_METH sample when method is known
13570 - BUG/MINOR: lua: always detach the tcp/http tasks before freeing them
13571 - MINOR: task: always preinitialize the task's timeout in task_init()
13572 - CLEANUP: task: remove all initializations to TICK_ETERNITY after task_new()
13573 - BUG/MAJOR: lua: properly dequeue hlua_applet_wakeup() for new scheduler
13574 - MINOR: lua: Add proxy as member of proxy object.
13575 - DOC: lua: Proxy class doc update
13576 - MINOR: lua: Add lists of frontends and backends
13577 - BUG/MINOR: ssl: Fix check against SNI during server certificate verification
13578 - BUG/MINOR: ssl: make use of the name in SNI before verifyhost
13579 - MINOR: ssl: add a new error codes for wrong server certificates
13580 - BUG/MEDIUM: stream: don't retry SSL connections which fail the SNI name check
13581 - MINOR: ssl: add "no-ca-names" parameter for bind
13582 - BUG/MINOR: lua: Fix bitwise logic for hlua_server_check_* functions.
13583 - DOC: fix alphabetical order of "show commands" in management.txt
13584 - MINOR: listener: add a function to return a listener's state as a string
13585 - MINOR: cli: add a new "show fd" command
13586 - BUG/MEDIUM: ssl: Fix regression about certificates generation
13587 - MINOR: Add server port field to server state file.
13588 - MINOR: ssl: allow to start without certificate if strict-sni is set
13589 - MINOR: dns: Cache previous DNS answers.
13590 - MINOR: obj: Add a new type of object, OBJ_TYPE_SRVRQ.
13591 - Add a few functions to do unaligned access.
13592 - MINOR: dns: Handle SRV records.
13593 - MINOR: check: Fix checks when using SRV records.
13594 - MINOR: doc: Document SRV label usage.
13595 - BUILD/MINOR: cli: shut a minor gcc warning in "show fd"
13596 - BUILD: ssl: replace SSL_CTX_get0_privatekey for openssl < 1.0.2
13597 - BUILD/MINOR: build without openssl still broken
13598 - BUG/MAJOR: stream: in stream_free(), close the front endpoint and not the origin
13599 - CLEANUP: raw_sock: Use a better name for the constructor than __ssl_sock_deinit()
13600 - MINOR: init: Fix CPU affinity setting on FreeBSD.
13601 - MINOR: dns: Update analysis of TRUNCATED response for SRV records
13602 - MINOR: dns: update record dname matching for SRV query types
13603 - MINOR: dns: update dns response buffer reading pointer due to SRV record
13604 - MINOR: dns: duplicate entries in resolution wait queue for SRV records
13605 - MINOR: dns: make debugging function dump_dns_config() compatible with SRV records
13606 - MINOR: dns: ability to use a SRV resolution for multiple backends
13607 - MINOR: dns: enable caching of responses for server set by a SRV record
13608 - MINOR: dns: new dns record type (RTYPE) for OPT
13609 - MINOR: dns: enabled edns0 extension and make accpeted payload size tunable
13610 - MINOR: dns: default "hold obsolete" timeout set to 0
13611 - MINOR: chunks: add chunk_memcpy() and chunk_memcat()
13612 - MINOR: session: add a streams field to the session struct
13613 - MINOR: stream: link the stream to its session
13614 - MEDIUM: session: do not free a session until no stream references it
13615 - MINOR: ist: implement very simple indirect strings
13616 - TESTS: ist: add a test file for the functions
13617 - MINOR: http: export some of the HTTP parser macros
13618 - BUG/MINOR: Wrong type used as argument for spoe_decode_buffer().
13619 - BUG/MINOR: dns: server set by SRV records stay in "no resolution" status
13620 - MINOR: dns: Maximum DNS udp payload set to 8192
13621 - MINOR: dns: automatic reduction of DNS accpeted payload size
13622 - MINOR: dns: make SRV record processing more verbose
13623 - CLEANUP: dns: remove duplicated code in dns_resolve_recv()
13624 - CLEANUP: dns: remove duplicated code in dns_validate_dns_response()
13625 - BUG/MINOR: dns: wrong resolution interval lead to 100% CPU
13626 - BUG/MEDIUM: dns: fix accepted_payload_size parser to avoid integer overflow
13627 - BUG/MAJOR: lua: fix the impact of the scheduler changes again
13628 - BUG/MEDIUM: lua: HTTP services must take care of body-less status codes
13629 - MINOR: lua: properly process the contents of the content-length field
13630 - BUG/MEDIUM: stream: properly set the required HTTP analysers on use-service
13631 - OPTIM: lua: don't use expensive functions to parse headers in the HTTP applet
13632 - OPTIM: lua: don't add "Connection: close" on the response
13633 - REORG/MEDIUM: connection: introduce the notion of connection handle
13634 - BUG/MINOR: stream-int: don't check the CO_FL_CURR_WR_ENA flag
13635 - MEDIUM: connection: get rid of data->init() which was not for data
13636 - MEDIUM: stream: make stream_new() allocate its own task
13637 - CLEANUP: listener: remove the unused handler field
13638 - MEDIUM: session: add a pointer to a struct task in the session
13639 - MINOR: stream: provide a new stream creation function for connections
13640 - MEDIUM: connection: remove useless flag CO_FL_DATA_RD_SH
13641 - CLEANUP: connection: remove the unused conn_sock_shutw_pending()
13642 - MEDIUM: connection: remove useless flag CO_FL_DATA_WR_SH
13643 - DOC: add CLI info on privilege levels
13644 - DOC: Refer to Mozilla TLS info / config generator
13645 - MINOR: ssl: remove duplicate ssl_methods in struct bind_conf
13646 - BUG/MEDIUM: http: Fix a regression bug when a HTTP response is in TUNNEL mode
13647 - DOC: Add note about "* " prefix in CSV stats
13648 - CLEANUP: memory: Remove unused function pool_destroy
13649 - MINOR: listeners: Change listener_full and limit_listener into private functions
13650 - MINOR: listeners: Change enable_listener and disable_listener into private functions
13651 - MINOR: fd: Don't forget to reset fdtab[fd].update when a fd is added/removed
13652 - MINOR: fd: Set owner and iocb field before inserting a new fd in the fdtab
13653 - MINOR: backends: Make get_server_* functions explicitly static
13654 - MINOR: applet: Check applets_active_queue before processing applets queue
13655 - MINOR: chunks: Use dedicated function to init/deinit trash buffers
13656 - MEDIUM: chunks: Realloc trash buffers only after the config is parsed and checked
13657 - MINOR: logs: Use dedicated function to init/deinit log buffers
13658 - MINOR: logs: Realloc log buffers only after the config is parsed and checked
13659 - MINOR: buffers: Move swap_buffer into buffer.c and add deinit_buffer function
13660 - MINOR: stick-tables: Make static_table_key a struct variable instead of a pointer
13661 - MINOR: http: Use a trash chunk to store decoded string of the HTTP auth header
13662 - MINOR: fd: Add fd_active function
13663 - MINOR: fd: Use inlined functions to check fd state in fd_*_send/recv functions
13664 - MINOR: fd: Move (de)allocation of fdtab and fdinfo in (de)init_pollers
13665 - MINOR: freq_ctr: Return the new value after an update
13666 - MEDIUM: check: server states and weight propagation re-work
13667 - BUG/MEDIUM: epoll: ensure we always consider HUP and ERR
13668 - MINOR: fd: Add fd_update_events function
13669 - MINOR: polling: Use fd_update_events to update events seen for a fd
13670 - BUG/MINOR: server: Remove FQDN requirement for using init-addr and state file
13671 - Revert "BUG/MINOR: server: Remove FQDN requirement for using init-addr and state file"
13672 - MINOR: ssl: rework smp_fetch_ssl_fc_cl_str without internal ssl use
13673 - BUG/MEDIUM: http: Close streams for connections closed before a redirect
13674 - BUG/MINOR: Lua: The socket may be destroyed when we try to access.
13675 - MINOR: xref: Add a new xref system
13676 - MEDIUM: xref/lua: Use xref for referencing cosocket relation between stream and lua
13677 - MINOR: tasks: Move Lua notification from Lua to tasks
13678 - MINOR: net_helper: Inline functions meant to be inlined.
13679 - MINOR: cli: add socket commands and config to prepend informational messages with severity
13680 - MINOR: add severity information to cli feedback messages
13681 - BUILD: Makefile: add a function to detect support by the compiler of certain options
13682 - BUILD: Makefile: shut certain gcc/clang stupid warnings
13683 - BUILD: Makefile: improve detection of support for compiler warnings
13684 - MINOR: peers: don't reference the incoming listener on outgoing connections
13685 - MINOR: frontend: don't retrieve ALPN on the critical path
13686 - MINOR: protocols: always pass a "port" argument to the listener creation
13687 - MINOR: protocols: register the ->add function and stop calling them directly
13688 - MINOR: unix: remove the now unused proto_uxst.h file
13689 - MINOR: listeners: new function create_listeners
13690 - MINOR: listeners: make listeners count consistent with reality
13691 - MEDIUM: session: take care of incrementing/decrementing jobs
13692 - MINOR: listener: new function listener_release
13693 - MINOR: session: small cleanup of conn_complete_session()
13694 - MEDIUM: session: factor out duplicated code for conn_complete_session
13695 - MEDIUM: session: count the frontend's connections at a single place
13696 - BUG/MEDIUM: compression: Fix check on txn in smp_fetch_res_comp_algo
13697 - BUG/MINOR: compression: Check response headers before http-response rules eval
13698 - BUG/MINOR: spoe: Don't rely on SPOE ctx in debug message when its creation failed
13699 - BUG/MINOR: dns: Fix check on nameserver in snr_resolution_cb
13700 - MINOR: ssl: Remove useless checks on bind_conf or bind_conf->is_ssl
13701 - BUG/MINOR: contrib/mod_defender: close the va_list argp before return
13702 - BUG/MINOR: contrib/modsecurity: close the va_list ap before return
13703 - MINOR: tools: make my_htonll() more efficient on x86_64
13704 - MINOR: buffer: add b_del() to delete a number of characters
13705 - MINOR: buffer: add b_end() and b_to_end()
13706 - MINOR: net_helper: add functions to read from vectors
13707 - MINOR: net_helper: add write functions
13708 - MINOR: net_helper: add 64-bit read/write functions
13709 - MINOR: connection: adjust CO_FL_NOTIFY_DATA after removal of flags
13710 - MINOR: ist: add a macro to ease const array initialization
13711 - BUG/MEDIUM: server: unwanted behavior leaving maintenance mode on tracked stopping server
13712 - BUG/MEDIUM: server: unwanted behavior leaving maintenance mode on tracked stopping server (take2)
13713 - BUG/MINOR: log: fixing small memory leak in error code path.
13714 - BUG/MINOR: contrib/halog: fixing small memory leak
13715 - BUG/MEDIUM: tcp/http: set-dst-port action broken
13716 - CLEANUUP: checks: don't set conn->handle.fd to -1
13717 - BUG/MEDIUM: tcp-check: properly indicate polling state before performing I/O
13718 - BUG/MINOR: tcp-check: don't quit with pending data in the send buffer
13719 - BUG/MEDIUM: tcp-check: don't call tcpcheck_main() from the I/O handlers!
13720 - BUG/MINOR: unix: properly check for octal digits in the "mode" argument
13721 - MINOR: checks: make chk_report_conn_err() take a check, not a connection
13722 - CLEANUP: checks: remove misleading comments and statuses for external process
13723 - CLEANUP: checks: don't report report the fork() error twice
13724 - CLEANUP: checks: do not allocate a connection for process checks
13725 - TESTS: checks: add a simple test config for external checks
13726 - BUG/MINOR: tcp-check: don't initialize then break a connection starting with a comment
13727 - TESTS: checks: add a simple test config for tcp-checks
13728 - MINOR: tcp-check: make tcpcheck_main() take a check, not a connection
13729 - MINOR: checks: don't create then kill a dummy connection before tcp-checks
13730 - MEDIUM: checks: make tcpcheck_main() indicate if it recycled a connection
13731 - MEDIUM: checks: do not allocate a permanent connection anymore
13732 - BUG/MEDIUM: cli: fix "show fd" crash when dumping closed FDs
13733 - BUG/MEDIUM: http: Return an error when url_dec sample converter failed
13734 - BUG/MAJOR: stream-int: don't re-arm recv if send fails
13735 - BUILD/MINOR: 51d: fix warning when building with 51Degrees release version 3.2.12.12
13736 - DOC: 51d: add 51Degrees git URL that points to release version 3.2.12.12
13737 - DOC: 51d: Updated git URL and instructions for getting Hash Trie data files.
13738 - MINOR: compiler: restore the likely() wrapper for gcc 5.x
13739 - MINOR: session: remove the list of streams from struct session
13740 - DOC: fix some typos
13741 - MINOR: server: add the srv_queue() sample fetch method
13742 - MINOR: payload: add new sample fetch functions to process distcc protocol
13743 - MAJOR: servers: propagate server status changes asynchronously.
13744 - BUG/MEDIUM: ssl: fix OCSP expiry calculation
13745 - BUG/MINOR: stream-int: don't set MSG_MORE on SHUTW_NOW without AUTO_CLOSE
13746 - MINOR: server: Handle weight increase in consistent hash.
13747 - MINOR: checks: Add a new keyword to specify a SNI when doing SSL checks.
13748 - BUG/MINOR: tools: fix my_htonll() on x86_64
13749 - BUG/MINOR: stats: Clear a bit more counters with in cli_parse_clear_counters().
13750 - BUG/MAJOR: lua: scheduled task is freezing.
13751 - MINOR: buffer: add bo_del() to delete a number of characters from output
13752 - MINOR: buffer: add a function to match against string patterns
13753 - MINOR: buffer: add two functions to inject data into buffers
13754 - MINOR: buffer: add buffer_space_wraps()
13755 - REORG: channel: finally rename the last bi_* / bo_* functions
13756 - MINOR: buffer: add bo_getblk() and bo_getblk_nc()
13757 - MINOR: channel: make use of bo_getblk{,_nc} for their channel equivalents
13758 - MINOR: channel: make the channel be a const in all {ci,co}_get* functions
13759 - MINOR: ist: add ist0() to add a trailing zero to a string.
13760 - BUG/MEDIUM: log: check result details truncated.
13761 - MINOR: buffer: make bo_getblk_nc() not return 2 for a full buffer
13762 - REORG: http: move some very http1-specific parts to h1.{c,h}
13763 - REORG: http: move the HTTP/1 chunk parser to h1.{c,h}
13764 - REORG: http: move the HTTP/1 header block parser to h1.c
13765 - MEDIUM: http: make the chunk size parser only depend on the buffer
13766 - MEDIUM: http: make the chunk crlf parser only depend on the buffer
13767 - MINOR: h1: add struct h1m for basic HTTP/1 messages
13768 - MINOR: http: add very simple header management based on double strings
13769 - MEDIUM: h1: reimplement the http/1 response parser for the gateway
13770 - REORG: connection: rename CO_FL_DATA_* -> CO_FL_XPRT_*
13771 - MEDIUM: connection: make conn_sock_shutw() aware of lingering
13772 - MINOR: connection: ensure conn_ctrl_close() also resets the fd
13773 - MINOR: connection: add conn_stop_tracking() to disable tracking
13774 - MINOR: tcp: use conn_full_close() instead of conn_force_close()
13775 - MINOR: unix: use conn_full_close() instead of conn_force_close()
13776 - MINOR: checks: use conn_full_close() instead of conn_force_close()
13777 - MINOR: session: use conn_full_close() instead of conn_force_close()
13778 - MINOR: stream: use conn_full_close() instead of conn_force_close()
13779 - MINOR: stream: use conn_full_close() instead of conn_force_close()
13780 - MINOR: backend: use conn_full_close() instead of conn_force_close()
13781 - MINOR: stream-int: use conn_full_close() instead of conn_force_close()
13782 - MINOR: connection: remove conn_force_close()
13783 - BUG/MINOR: ssl: ocsp response with 'revoked' status is correct
13784
Willy Tarreauf57a29a2017-06-02 15:59:51 +0200137852017/06/02 : 1.8-dev2
13786 - CLEANUP: server: moving netinet/tcp.h inclusion
13787 - DOC: changed "block"(deprecated) examples to http-request deny
13788 - DOC: add few comments to examples.
13789 - DOC: update sample code for PROXY protocol
13790 - DOC: mention lighttpd 1.4.46 implements PROXY
13791 - MINOR server: Restrict dynamic cookie check to the same proxy.
13792 - DOC: stick-table is available in frontend sections
13793 - BUG/MINOR: server : no transparent proxy for DragonflyBSD
13794 - BUILD/MINOR: stats: remove unexpected argument to stats_dump_json_header()
13795 - BUILD/MINOR: tools: fix build warning in debug_hexdump()
13796 - BUG/MINOR: dns: Wrong address family used when creating IPv6 sockets.
13797 - BUG/MINOR: config: missing goto out after parsing an incorrect ACL character
13798 - BUG/MINOR: arg: don't try to add an argument on failed memory allocation
13799 - MEDIUM: server: Inherit CLI weight changes and agent-check weight responses
13800 - BUG/MEDIUM: arg: ensure that we properly unlink unresolved arguments on error
13801 - BUG/MEDIUM: acl: don't free unresolved args in prune_acl_expr()
13802 - BUG/MEDIUM: servers: unbreak server weight propagation
13803 - MINOR: lua: ensure the memory allocator is used all the time
13804 - MINOR: cli: Add a command to send listening sockets.
13805 - MINOR: global: Add an option to get the old listening sockets.
13806 - MINOR: tcp: When binding socket, attempt to reuse one from the old proc.
13807 - MINOR: doc: document the -x flag
13808 - MINOR: proxy: Don't close FDs if not our proxy.
13809 - MINOR: socket transfer: Set a timeout on the socket.
13810 - MINOR: systemd wrapper: add support for passing the -x option.
13811 - BUG/MINOR: server: Fix a wrong error message during 'usesrc' keyword parsing.
13812 - BUG/MAJOR: Broken parsing for valid keywords provided after 'source' setting.
13813 - CLEANUP: logs: typo: simgle => single
13814 - BUG/MEDIUM: acl: proprely release unused args in prune_acl_expr()
13815 - MEDIUM: config: don't check config validity when there are fatal errors
13816 - BUG/MAJOR: Use -fwrapv.
13817 - BUG/MINOR: server: don't use "proxy" when px is really meant.
13818 - BUG/MEDIUM: http: Drop the connection establishment when a redirect is performed
13819 - BUG/MINOR: server: missing default server 'resolvers' setting duplication.
13820 - MINOR: server: Extract the code responsible of copying default-server settings.
13821 - MINOR: server: Extract the code which finalizes server initializations after 'server' lines parsing.
13822 - MINOR: server: Add 'server-template' new keyword supported in backend sections.
13823 - MINOR: server: Add server_template_init() function to initialize servers from a templates.
13824 - DOC: Add documentation for new "server-template" keyword.
13825 - DOC: add layer 4 links/cross reference to "block" keyword.
13826 - DOC: errloc/errorloc302/errorloc303 missing status codes.
13827 - BUG/MEDIUM: lua: memory leak
13828 - CLEANUP: lua: remove test
13829 - BUG/MINOR: hash-balance-factor isn't effective in certain circumstances
13830 - BUG/MINOR: change header-declared function to static inline
13831 - REORG: spoe: move spoe_encode_varint / spoe_decode_varint from spoe to common
13832 - MINOR: Add binary encoding request header sample fetch
13833 - MINOR: proto-http: Add sample fetch wich returns all HTTP headers
13834 - MINOR: Add ModSecurity wrapper as contrib
13835 - BUG/MINOR: ssl: fix warnings about methods for opensslv1.1.
13836 - DOC: update RFC references
13837 - CONTRIB: tcploop: add action "X" to execute a command
13838 - MINOR: server: cli: Add server FQDNs to server-state file and stats socket.
13839 - BUG/MINOR: contrib/mod_security: fix build on FreeBSD
13840 - BUG/MINOR: checks: don't send proxy protocol with agent checks
13841 - MINOR: ssl: add prefer-client-ciphers
13842 - MEDIUM: ssl: revert ssl/tls version settings relative to default-server.
13843 - MEDIUM: ssl: ssl_methods implementation is reworked and factored for min/max tlsxx
13844 - MEDIUM: ssl: calculate the real min/max TLS version and find holes
13845 - MINOR: ssl: support TLSv1.3 for bind and server
13846 - MINOR: ssl: show methods supported by openssl
13847 - MEDIUM: ssl: add ssl-min-ver and ssl-max-ver parameters for bind and server
13848 - MEDIUM: ssl: ssl-min-ver and ssl-max-ver compatibility.
13849 - CLEANUP: retire obsoleted USE_GETSOCKNAME build option
13850 - BUG/MAJOR: dns: Broken kqueue events handling (BSD systems).
13851 - MINOR: sample: Add b64dec sample converter
13852 - BUG/MEDIUM: lua: segfault if a converter or a sample doesn't return anything
13853 - MINOR: cli: add ACCESS_LVL_MASK to store the access level
13854 - MINOR: cli: add 'expose-fd listeners' to pass listeners FDs
13855 - MEDIUM: proxy: zombify proxies only when the expose-fd socket is bound
13856 - MEDIUM: ssl: add basic support for OpenSSL crypto engine
13857 - MAJOR: ssl: add openssl async mode support
13858 - MEDIUM: ssl: handle multiple async engines
13859 - MINOR: boringssl: basic support for OCSP Stapling
13860 - MEDIUM: mworker: replace systemd mode by master worker mode
13861 - MEDIUM: mworker: handle reload and signals
13862 - MEDIUM: mworker: wait mode on reload failure
13863 - MEDIUM: mworker: try to guess the next stats socket to use with -x
13864 - MEDIUM: mworker: exit-on-failure option
13865 - MEDIUM: mworker: workers exit when the master leaves
13866 - DOC: add documentation for the master-worker mode
13867 - MEDIUM: systemd: Type=forking in unit file
13868 - MAJOR: systemd-wrapper: get rid of the wrapper
13869 - MINOR: log: Add logurilen tunable.
13870 - CLEANUP: server.c: missing prototype of srv_free_dns_resolution
13871 - MINOR: dns: smallest DNS fqdn size
13872 - MINOR: dns: functions to manage memory for a DNS resolution structure
13873 - MINOR: dns: parse_server() now uses srv_alloc_dns_resolution()
13874 - REORG: dns: dns_option structure, storage of hostname_dn
13875 - MINOR: dns: new snr_check_ip_callback function
13876 - MAJOR: dns: save a copy of the DNS response in struct resolution
13877 - MINOR: dns: implement a LRU cache for DNS resolutions
13878 - MINOR: dns: make 'ancount' field to match the number of saved records
13879 - MINOR: dns: introduce roundrobin into the internal cache (WIP)
13880 - MAJOR/REORG: dns: DNS resolution task and requester queues
13881 - BUILD: ssl: fix build with OPENSSL_NO_ENGINE
13882 - MINOR: Add Mod Defender integration as contrib
13883 - CLEANUP: str2mask return code comment: non-zero -> zero.
13884 - MINOR: tools: make debug_hexdump() use a const char for the string
13885 - MINOR: tools: make debug_hexdump() take a string prefix
13886 - CLEANUP: connection: remove unused CO_FL_WAIT_DATA
13887
Willy Tarreau7b677262017-04-03 09:27:49 +0200138882017/04/03 : 1.8-dev1
13889 - BUG/MEDIUM: proxy: return "none" and "unknown" for unknown LB algos
13890 - BUG/MINOR: stats: make field_str() return an empty string on NULL
13891 - DOC: Spelling fixes
13892 - BUG/MEDIUM: http: Fix tunnel mode when the CONNECT method is used
13893 - BUG/MINOR: http: Keep the same behavior between 1.6 and 1.7 for tunneled txn
13894 - BUG/MINOR: filters: Protect args in macros HAS_DATA_FILTERS and IS_DATA_FILTER
13895 - BUG/MINOR: filters: Invert evaluation order of HTTP_XFER_BODY and XFER_DATA analyzers
13896 - BUG/MINOR: http: Call XFER_DATA analyzer when HTTP txn is switched in tunnel mode
13897 - BUG/MAJOR: stream: fix session abort on resource shortage
13898 - OPTIM: stream-int: don't disable polling anymore on DONT_READ
13899 - BUG/MINOR: cli: allow the backslash to be escaped on the CLI
13900 - BUG/MEDIUM: cli: fix "show stat resolvers" and "show tls-keys"
13901 - DOC: Fix map table's format
13902 - DOC: Added 51Degrees conv and fetch functions to documentation.
13903 - BUG/MINOR: http: don't send an extra CRLF after a Set-Cookie in a redirect
13904 - DOC: mention that req_tot is for both frontends and backends
13905 - BUG/MEDIUM: variables: some variable name can hide another ones
13906 - MINOR: lua: Allow argument for actions
13907 - BUILD: rearrange target files by build time
13908 - CLEANUP: hlua: just indent functions
13909 - MINOR: lua: give HAProxy variable access to the applets
13910 - BUG/MINOR: stats: fix be/sessions/max output in html stats
13911 - MINOR: proxy: Add fe_name/be_name fetchers next to existing fe_id/be_id
13912 - DOC: lua: Documentation about some entry missing
13913 - DOC: lua: Add documentation about variable manipulation from applet
13914 - MINOR: Do not forward the header "Expect: 100-continue" when the option http-buffer-request is set
13915 - DOC: Add undocumented argument of the trace filter
13916 - DOC: Fix some typo in SPOE documentation
13917 - MINOR: cli: Remove useless call to bi_putchk
13918 - BUG/MINOR: cli: be sure to always warn the cli applet when input buffer is full
13919 - MINOR: applet: Count number of (active) applets
13920 - MINOR: task: Rename run_queue and run_queue_cur counters
13921 - BUG/MEDIUM: stream: Save unprocessed events for a stream
13922 - BUG/MAJOR: Fix how the list of entities waiting for a buffer is handled
13923 - BUILD/MEDIUM: Fixing the build using LibreSSL
13924 - BUG/MEDIUM: lua: In some case, the return of sample-fetches is ignored (2)
13925 - SCRIPTS: git-show-backports: fix a harmless typo
13926 - SCRIPTS: git-show-backports: add -H to use the hash of the commit message
13927 - BUG/MINOR: stream-int: automatically release SI_FL_WAIT_DATA on SHUTW_NOW
13928 - CLEANUP: applet/lua: create a dedicated ->fcn entry in hlua_cli context
13929 - CLEANUP: applet/table: add an "action" entry in ->table context
13930 - CLEANUP: applet: remove the now unused appctx->private field
13931 - DOC: lua: documentation about time parser functions
13932 - DOC: lua: improve links
13933 - DOC: lua: section declared twice
13934 - MEDIUM: cli: 'show cli sockets' list the CLI sockets
13935 - BUG/MINOR: cli: "show cli sockets" wouldn't list all processes
13936 - BUG/MINOR: cli: "show cli sockets" would always report process 64
13937 - CLEANUP: lua: rename one of the lua appctx union
13938 - BUG/MINOR: lua/cli: bad error message
13939 - MEDIUM: lua: use memory pool for hlua struct in applets
13940 - MINOR: lua/signals: Remove Lua part from signals.
13941 - DOC: cli: show cli sockets
13942 - MINOR: cli: automatically enable a CLI I/O handler when there's no parser
13943 - CLEANUP: memory: remove the now unused cli_parse_show_pools() function
13944 - CLEANUP: applet: group all CLI contexts together
13945 - CLEANUP: stats: move a misplaced stats context initialization
13946 - MINOR: cli: add two general purpose pointers and integers in the CLI struct
13947 - MINOR: appctx/cli: remove the cli_socket entry from the appctx union
13948 - MINOR: appctx/cli: remove the env entry from the appctx union
13949 - MINOR: appctx/cli: remove the "be" entry from the appctx union
13950 - MINOR: appctx/cli: remove the "dns" entry from the appctx union
13951 - MINOR: appctx/cli: remove the "server_state" entry from the appctx union
13952 - MINOR: appctx/cli: remove the "tlskeys" entry from the appctx union
13953 - CONTRIB: tcploop: add limits.h to fix build issue with some compilers
13954 - MINOR/DOC: lua: just precise one thing
13955 - DOC: fix small typo in fe_id (backend instead of frontend)
13956 - BUG/MINOR: Fix the sending function in Lua's cosocket
13957 - BUG/MINOR: lua: memory leak executing tasks
13958 - BUG/MINOR: lua: bad return code
13959 - BUG/MINOR: lua: memleak when Lua/cli fails
13960 - MEDIUM: lua: remove Lua struct from session, and allocate it with memory pools
13961 - CLEANUP: haproxy: statify unexported functions
13962 - MINOR: haproxy: add a registration for build options
13963 - CLEANUP: wurfl: use the build options list to report it
13964 - CLEANUP: 51d: use the build options list to report it
13965 - CLEANUP: da: use the build options list to report it
13966 - CLEANUP: namespaces: use the build options list to report it
13967 - CLEANUP: tcp: use the build options list to report transparent modes
13968 - CLEANUP: lua: use the build options list to report it
13969 - CLEANUP: regex: use the build options list to report the regex type
13970 - CLEANUP: ssl: use the build options list to report the SSL details
13971 - CLEANUP: compression: use the build options list to report the algos
13972 - CLEANUP: auth: use the build options list to report its support
13973 - MINOR: haproxy: add a registration for post-check functions
13974 - CLEANUP: checks: make use of the post-init registration to start checks
13975 - CLEANUP: filters: use the function registration to initialize all proxies
13976 - CLEANUP: wurfl: make use of the late init registration
13977 - CLEANUP: 51d: make use of the late init registration
13978 - CLEANUP: da: make use of the late init registration code
13979 - MINOR: haproxy: add a registration for post-deinit functions
13980 - CLEANUP: wurfl: register the deinit function via the dedicated list
13981 - CLEANUP: 51d: register the deinitialization function
13982 - CLEANUP: da: register the deinitialization function
13983 - CLEANUP: wurfl: move global settings out of the global section
13984 - CLEANUP: 51d: move global settings out of the global section
13985 - CLEANUP: da: move global settings out of the global section
13986 - MINOR: cfgparse: add two new functions to check arguments count
13987 - MINOR: cfgparse: move parsing of "ca-base" and "crt-base" to ssl_sock
13988 - MEDIUM: cfgparse: move all tune.ssl.* keywords to ssl_sock
13989 - MEDIUM: cfgparse: move maxsslconn parsing to ssl_sock
13990 - MINOR: cfgparse: move parsing of ssl-default-{bind,server}-ciphers to ssl_sock
13991 - MEDIUM: cfgparse: move ssl-dh-param-file parsing to ssl_sock
13992 - MEDIUM: compression: move the zlib-specific stuff from global.h to compression.c
13993 - BUG/MEDIUM: ssl: properly reset the reused_sess during a forced handshake
13994 - BUG/MEDIUM: ssl: avoid double free when releasing bind_confs
13995 - BUG/MINOR: stats: fix be/sessions/current out in typed stats
13996 - MINOR: tcp-rules: check that the listener exists before updating its counters
13997 - MEDIUM: spoe: don't create a dummy listener for outgoing connections
13998 - MINOR: listener: move the transport layer pointer to the bind_conf
13999 - MEDIUM: move listener->frontend to bind_conf->frontend
14000 - MEDIUM: ssl: remote the proxy argument from most functions
14001 - MINOR: connection: add a new prepare_bind_conf() entry to xprt_ops
14002 - MEDIUM: ssl_sock: implement ssl_sock_prepare_bind_conf()
14003 - MINOR: connection: add a new destroy_bind_conf() entry to xprt_ops
14004 - MINOR: ssl_sock: implement ssl_sock_destroy_bind_conf()
14005 - MINOR: server: move the use_ssl field out of the ifdef USE_OPENSSL
14006 - MINOR: connection: add a minimal transport layer registration system
14007 - CLEANUP: connection: remove all direct references to raw_sock and ssl_sock
14008 - CLEANUP: connection: unexport raw_sock and ssl_sock
14009 - MINOR: connection: add new prepare_srv()/destroy_srv() entries to xprt_ops
14010 - MINOR: ssl_sock: implement and use prepare_srv()/destroy_srv()
14011 - CLEANUP: ssl: move tlskeys_finalize_config() to a post_check callback
14012 - CLEANUP: ssl: move most ssl-specific global settings to ssl_sock.c
14013 - BUG/MINOR: backend: nbsrv() should return 0 if backend is disabled
14014 - BUG/MEDIUM: ssl: for a handshake when server-side SNI changes
14015 - BUG/MINOR: systemd: potential zombie processes
14016 - DOC: Add timings events schemas
14017 - BUILD: lua: build failed on FreeBSD.
14018 - MINOR: samples: add xx-hash functions
14019 - MEDIUM: regex: pcre2 support
14020 - BUG/MINOR: option prefer-last-server must be ignored in some case
14021 - MINOR: stats: Support "select all" for backend actions
14022 - BUG/MINOR: sample-fetches/stick-tables: bad type for the sample fetches sc*_get_gpt0
14023 - BUG/MAJOR: channel: Fix the definition order of channel analyzers
14024 - BUG/MINOR: http: report real parser state in error captures
14025 - BUILD: scripts: automatically update the branch in version.h when releasing
14026 - MINOR: tools: add a generic hexdump function for debugging
14027 - BUG/MAJOR: http: fix risk of getting invalid reports of bad requests
14028 - MINOR: http: custom status reason.
14029 - MINOR: connection: add sample fetch "fc_rcvd_proxy"
14030 - BUG/MINOR: config: emit a warning if http-reuse is enabled with incompatible options
14031 - BUG/MINOR: tools: fix off-by-one in port size check
14032 - BUG/MEDIUM: server: consider AF_UNSPEC as a valid address family
14033 - MEDIUM: server: split the address and the port into two different fields
14034 - MINOR: tools: make str2sa_range() return the port in a separate argument
14035 - MINOR: server: take the destination port from the port field, not the addr
14036 - MEDIUM: server: disable protocol validations when the server doesn't resolve
14037 - BUG/MEDIUM: tools: do not force an unresolved address to AF_INET:0.0.0.0
14038 - BUG/MINOR: ssl: EVP_PKEY must be freed after X509_get_pubkey usage
14039 - BUG/MINOR: ssl: assert on SSL_set_shutdown with BoringSSL
14040 - MINOR: Use "500 Internal Server Error" for 500 error/status code message.
14041 - MINOR: proto_http.c 502 error txt typo.
14042 - DOC: add deprecation notice to "block"
14043 - MINOR: compression: fix -vv output without zlib/slz
14044 - BUG/MINOR: Reset errno variable before calling strtol(3)
14045 - MINOR: ssl: don't show prefer-server-ciphers output
14046 - OPTIM/MINOR: config: Optimize fullconn automatic computation loading configuration
14047 - BUG/MINOR: stream: Fix how backend-specific analyzers are set on a stream
14048 - MAJOR: ssl: bind configuration per certificat
14049 - MINOR: ssl: add curve suite for ECDHE negotiation
14050 - MINOR: checks: Add agent-addr config directive
14051 - MINOR: cli: Add possiblity to change agent config via CLI/socket
14052 - MINOR: doc: Add docs for agent-addr configuration variable
14053 - MINOR: doc: Add docs for agent-addr and agent-send CLI commands
14054 - BUILD: ssl: fix to build (again) with boringssl
14055 - BUILD: ssl: fix build on OpenSSL 1.0.0
14056 - BUILD: ssl: silence a warning reported for ERR_remove_state()
14057 - BUILD: ssl: eliminate warning with OpenSSL 1.1.0 regarding RAND_pseudo_bytes()
14058 - BUILD: ssl: kill a build warning introduced by BoringSSL compatibility
14059 - BUG/MEDIUM: tcp: don't poll for write when connect() succeeds
14060 - BUG/MINOR: unix: fix connect's polling in case no data are scheduled
14061 - MINOR: server: extend the flags to 32 bits
14062 - BUG/MINOR: lua: Map.end are not reliable because "end" is a reserved keyword
14063 - MINOR: dns: give ability to dns_init_resolvers() to close a socket when requested
14064 - BUG/MAJOR: dns: restart sockets after fork()
14065 - MINOR: chunks: implement a simple dynamic allocator for trash buffers
14066 - BUG/MEDIUM: http: prevent redirect from overwriting a buffer
14067 - BUG/MEDIUM: filters: Do not truncate HTTP response when body length is undefined
14068 - BUG/MEDIUM: http: Prevent replace-header from overwriting a buffer
14069 - BUG/MINOR: http: Return an error when a replace-header rule failed on the response
14070 - BUG/MINOR: sendmail: The return of vsnprintf is not cleanly tested
14071 - BUG/MAJOR: ssl: fix a regression in ssl_sock_shutw()
14072 - BUG/MAJOR: lua segmentation fault when the request is like 'GET ?arg=val HTTP/1.1'
14073 - BUG/MEDIUM: config: reject anything but "if" or "unless" after a use-backend rule
14074 - MINOR: http: don't close when redirect location doesn't start with "/"
14075 - MEDIUM: boringssl: support native multi-cert selection without bundling
14076 - BUG/MEDIUM: ssl: fix verify/ca-file per certificate
14077 - BUG/MEDIUM: ssl: switchctx should not return SSL_TLSEXT_ERR_ALERT_WARNING
14078 - MINOR: ssl: removes SSL_CTX_set_ssl_version call and cleanup CTX creation.
14079 - BUILD: ssl: fix build with -DOPENSSL_NO_DH
14080 - MEDIUM: ssl: add new sample-fetch which captures the cipherlist
14081 - MEDIUM: ssl: remove ssl-options from crt-list
14082 - BUG/MEDIUM: ssl: in bind line, ssl-options after 'crt' are ignored.
14083 - BUG/MINOR: ssl: fix cipherlist captures with sustainable SSL calls
14084 - MINOR: ssl: improved cipherlist captures
14085 - BUG/MINOR: spoe: Fix soft stop handler using a specific id for spoe filters
14086 - BUG/MINOR: spoe: Fix parsing of arguments in spoe-message section
14087 - MAJOR: spoe: Add support of pipelined and asynchronous exchanges with agents
14088 - MINOR: spoe: Add support for pipelining/async capabilities in the SPOA example
14089 - MINOR: spoe: Remove SPOE details from the appctx structure
14090 - MINOR: spoe: Add status code in error variable instead of hardcoded value
14091 - MINOR: spoe: Send a log message when an error occurred during event processing
14092 - MINOR: spoe: Check the scope of sample fetches used in SPOE messages
14093 - MEDIUM: spoe: Be sure to wakeup the good entity waiting for a buffer
14094 - MINOR: spoe: Use the min of all known max_frame_size to encode messages
14095 - MAJOR: spoe: Add support of payload fragmentation in NOTIFY frames
14096 - MINOR: spoe: Add support for fragmentation capability in the SPOA example
14097 - MAJOR: spoe: refactor the filter to clean up the code
14098 - MINOR: spoe: Handle NOTIFY frames cancellation using ABORT bit in ACK frames
14099 - REORG: spoe: Move struct and enum definitions in dedicated header file
14100 - REORG: spoe: Move low-level encoding/decoding functions in dedicated header file
14101 - MINOR: spoe: Improve implementation of the payload fragmentation
14102 - MINOR: spoe: Add support of negation for options in SPOE configuration file
14103 - MINOR: spoe: Add "pipelining" and "async" options in spoe-agent section
14104 - MINOR: spoe: Rely on alertif_too_many_arg during configuration parsing
14105 - MINOR: spoe: Add "send-frag-payload" option in spoe-agent section
14106 - MINOR: spoe: Add "max-frame-size" statement in spoe-agent section
14107 - DOC: spoe: Update SPOE documentation to reflect recent changes
14108 - MINOR: config: warn when some HTTP rules are used in a TCP proxy
14109 - BUG/MEDIUM: ssl: Clear OpenSSL error stack after trying to parse OCSP file
14110 - BUG/MEDIUM: cli: Prevent double free in CLI ACL lookup
14111 - BUG/MINOR: Fix "get map <map> <value>" CLI command
14112 - MINOR: Add nbsrv sample converter
14113 - CLEANUP: Replace repeated code to count usable servers with be_usable_srv()
14114 - MINOR: Add hostname sample fetch
14115 - CLEANUP: Remove comment that's no longer valid
14116 - MEDIUM: http_error_message: txn->status / http_get_status_idx.
14117 - MINOR: http-request tarpit deny_status.
14118 - CLEANUP: http: make http_server_error() not set the status anymore
14119 - MEDIUM: stats: Add JSON output option to show (info|stat)
14120 - MEDIUM: stats: Add show json schema
14121 - BUG/MAJOR: connection: update CO_FL_CONNECTED before calling the data layer
14122 - MINOR: server: Add dynamic session cookies.
14123 - MINOR: cli: Let configure the dynamic cookies from the cli.
14124 - BUG/MINOR: checks: attempt clean shutw for SSL check
14125 - CONTRIB: tcploop: make it build on FreeBSD
14126 - CONTRIB: tcploop: fix time format to silence build warnings
14127 - CONTRIB: tcploop: report action 'K' (kill) in usage message
14128 - CONTRIB: tcploop: fix connect's address length
14129 - CONTRIB: tcploop: use the trash instead of NULL for recv()
14130 - BUG/MEDIUM: listener: do not try to rebind another process' socket
14131 - BUG/MEDIUM server: Fix crash when dynamic is defined, but not key is provided.
14132 - CLEANUP: config: Typo in comment.
14133 - BUG/MEDIUM: filters: Fix channels synchronization in flt_end_analyze
14134 - TESTS: add a test configuration to stress handshake combinations
14135 - BUG/MAJOR: stream-int: do not depend on connection flags to detect connection
14136 - BUG/MEDIUM: connection: ensure to always report the end of handshakes
14137 - MEDIUM: connection: don't test for CO_FL_WAKE_DATA
14138 - CLEANUP: connection: completely remove CO_FL_WAKE_DATA
14139 - BUG: payload: fix payload not retrieving arbitrary lengths
14140 - BUILD: ssl: simplify SSL_CTX_set_ecdh_auto compatibility
14141 - BUILD: ssl: fix OPENSSL_NO_SSL_TRACE for boringssl and libressl
14142 - BUG/MAJOR: http: fix typo in http_apply_redirect_rule
14143 - MINOR: doc: 2.4. Examples should be 2.5. Examples
14144 - BUG/MEDIUM: stream: fix client-fin/server-fin handling
14145 - MINOR: fd: add a new flag HAP_POLL_F_RDHUP to struct poller
14146 - BUG/MINOR: raw_sock: always perfom the last recv if RDHUP is not available
14147 - OPTIM: poll: enable support for POLLRDHUP
14148 - MINOR: kqueue: exclusively rely on the kqueue returned status
14149 - MEDIUM: kqueue: take care of EV_EOF to improve polling status accuracy
14150 - MEDIUM: kqueue: only set FD_POLL_IN when there are pending data
14151 - DOC/MINOR: Fix typos in proxy protocol doc
14152 - DOC: Protocol doc: add checksum, TLV type ranges
14153 - DOC: Protocol doc: add SSL TLVs, rename CHECKSUM
14154 - DOC: Protocol doc: add noop TLV
14155 - MEDIUM: global: add a 'hard-stop-after' option to cap the soft-stop time
14156 - MINOR: dns: improve DNS response parsing to use as many available records as possible
14157 - BUG/MINOR: cfgparse: loop in tracked servers lists not detected by check_config_validity().
14158 - MINOR: server: irrelevant error message with 'default-server' config file keyword.
14159 - MINOR: server: Make 'default-server' support 'backup' keyword.
14160 - MINOR: server: Make 'default-server' support 'check-send-proxy' keyword.
14161 - CLEANUP: server: code alignement.
14162 - MINOR: server: Make 'default-server' support 'non-stick' keyword.
14163 - MINOR: server: Make 'default-server' support 'send-proxy' and 'send-proxy-v2 keywords.
14164 - MINOR: server: Make 'default-server' support 'check-ssl' keyword.
14165 - MINOR: server: Make 'default-server' support 'force-sslv3' and 'force-tlsv1[0-2]' keywords.
14166 - CLEANUP: server: code alignement.
14167 - MINOR: server: Make 'default-server' support 'no-ssl*' and 'no-tlsv*' keywords.
14168 - MINOR: server: Make 'default-server' support 'ssl' keyword.
14169 - MINOR: server: Make 'default-server' support 'send-proxy-v2-ssl*' keywords.
14170 - CLEANUP: server: code alignement.
14171 - MINOR: server: Make 'default-server' support 'verify' keyword.
14172 - MINOR: server: Make 'default-server' support 'verifyhost' setting.
14173 - MINOR: server: Make 'default-server' support 'check' keyword.
14174 - MINOR: server: Make 'default-server' support 'track' setting.
14175 - MINOR: server: Make 'default-server' support 'ca-file', 'crl-file' and 'crt' settings.
14176 - MINOR: server: Make 'default-server' support 'redir' keyword.
14177 - MINOR: server: Make 'default-server' support 'observe' keyword.
14178 - MINOR: server: Make 'default-server' support 'cookie' keyword.
14179 - MINOR: server: Make 'default-server' support 'ciphers' keyword.
14180 - MINOR: server: Make 'default-server' support 'tcp-ut' keyword.
14181 - MINOR: server: Make 'default-server' support 'namespace' keyword.
14182 - MINOR: server: Make 'default-server' support 'source' keyword.
14183 - MINOR: server: Make 'default-server' support 'sni' keyword.
14184 - MINOR: server: Make 'default-server' support 'addr' keyword.
14185 - MINOR: server: Make 'default-server' support 'disabled' keyword.
14186 - MINOR: server: Add 'no-agent-check' server keyword.
14187 - DOC: server: Add docs for "server" and "default-server" new "no-*" and other settings.
14188 - MINOR: doc: fix use-server example (imap vs mail)
14189 - BUG/MEDIUM: tcp: don't require privileges to bind to device
14190 - BUILD: make the release script use shortlog for the final changelog
14191 - BUILD: scripts: fix typo in announce-release error message
14192 - CLEANUP: time: curr_sec_ms doesn't need to be exported
14193 - BUG/MEDIUM: server: Wrong server default CRT filenames initialization.
14194 - BUG/MEDIUM: peers: fix buffer overflow control in intdecode.
14195 - BUG/MEDIUM: buffers: Fix how input/output data are injected into buffers
14196 - BUG/MINOR: http: Fix conditions to clean up a txn and to handle the next request
14197 - CLEANUP: http: Remove channel_congested function
14198 - CLEANUP: buffers: Remove buffer_bounce_realign function
14199 - CLEANUP: buffers: Remove buffer_contig_area and buffer_work_area functions
14200 - MINOR: http: remove useless check on HTTP_MSGF_XFER_LEN for the request
14201 - MINOR: http: Add debug messages when HTTP body analyzers are called
14202 - BUG/MEDIUM: http: Fix blocked HTTP/1.0 responses when compression is enabled
14203 - BUG/MINOR: filters: Don't force the stream's wakeup when we wait in flt_end_analyze
14204 - DOC: fix parenthesis and add missing "Example" tags
14205 - DOC: update the contributing file
14206 - DOC: log-format/tcplog/httplog update
14207 - MINOR: config parsing: add warning when log-format/tcplog/httplog is overriden in "defaults" sections
14208
Willy Tarreau0e658fb2016-11-25 16:55:50 +0100142092016/11/25 : 1.8-dev0
14210
Willy Tarreaue59fcdd2016-11-25 16:39:17 +0100142112016/11/25 : 1.7.0
14212 - SCRIPTS: make publish-release also copy the new SPOE doc
14213 - BUILD: http: include types/sample.h in proto_http.h
14214 - BUILD: debug/flags: remove test for SF_COMP_READY
14215 - CONTRIB: debug/flags: add check for SF_ERR_CHK_PORT
14216 - MINOR: lua: add function which return true if the channel is full.
14217 - MINOR: lua: add ip addresses and network manipulation function
14218 - CONTRIB: tcploop: scriptable TCP I/O for debugging purposes
14219 - CONTRIB: tcploop: implement fork()
14220 - CONTRIB: tcploop: implement logging when called with -v
14221 - CONTRIB: tcploop: update the usage output
14222 - CONTRIB: tcploop: support sending plain strings
14223 - CONTRIB: tcploop: don't report failed send() or recv()
14224 - CONTRIB: tcploop: add basic loops via a jump instruction
14225 - BUG/MEDIUM: channel: bad unlikely macro
14226 - CLEANUP: lua: move comment
14227 - CLEANUP: lua: control executed twice
14228 - BUG/MEDIUM: ssl: Store certificate filename in a variable
14229 - BUG/MINOR: ssl: Print correct filename when error occurs reading OCSP
14230 - CLEANUP: ssl: Remove goto after return dead code
14231 - CLEANUP: ssl: Fix bind keywords name in comments
14232 - DOC: ssl: Use correct wording for ca-sign-pass
14233 - CLEANUP: lua: avoid directly calling getsockname/getpeername()
14234 - BUG/MINOR: stick-table: handle out-of-memory condition gracefully
14235 - MINOR: cli: add private pointer and release function
14236 - MEDIUM: lua: Add cli handler for Lua
14237 - BUG/MEDIUM: connection: check the control layer before stopping polling
14238 - DEBUG: connection: mark the closed FDs with a value that is easier to detect
14239 - BUG/MEDIUM: stick-table: fix regression caused by recent fix for out-of-memory
14240 - BUG/MINOR: cli: properly decrement ref count on tables during failed dumps
14241 - BUG/MEDIUM: lua: In some case, the return of sample-fetche is ignored
14242 - MINOR: filters: Add check_timeouts callback to handle timers expiration on streams
14243 - MINOR: spoe: Add 'timeout processing' option to limit time to process an event
14244 - MINOR: spoe: Remove useless 'timeout ack' option
14245 - MINOR: spoe: Add 'option continue-on-error' statement in spoe-agent section
14246 - MINOR: spoe: Add "maxconnrate" and "maxerrrate" statements
14247 - MINOR: spoe: Add "option set-on-error" statement
14248 - MINOR: stats: correct documentation of process ID for typed output
14249 - BUILD: contrib: fix ip6range build on Centos 7
14250 - BUILD: fix build on Solaris 10/11
14251 - BUG/MINOR: cli: fix pointer size when reporting data/transport layer name
14252 - BUG/MINOR: cli: dequeue from the proxy when changing a maxconn
14253 - BUG/MINOR: cli: wake up the CLI's task after a timeout update
14254 - MINOR: connection: add a few functions to report the data and xprt layers' names
14255 - MINOR: connection: add names for transport and data layers
14256 - REORG: cli: split dumpstats.c in src/cli.c and src/stats.c
14257 - REORG: cli: split dumpstats.h in stats.h and cli.h
14258 - REORG: cli: move ssl CLI functions to ssl_sock.c
14259 - REORG: cli: move map and acl code to map.c
14260 - REORG: cli: move show stat resolvers to dns.c
14261 - MINOR: cli: create new function cli_has_level() to validate permissions
14262 - MINOR: server: create new function cli_find_server() to find a server
14263 - MINOR: proxy: create new function cli_find_frontend() to find a frontend
14264 - REORG: cli: move 'set server' to server.c
14265 - REORG: cli: move 'show pools' to memory.c
14266 - REORG: cli: move 'show servers' to proxy.c
14267 - REORG: cli: move 'show sess' to stream.c
14268 - REORG: cli: move 'show backend' to proxy.c
14269 - REORG: cli: move get/set weight to server.c
14270 - REORG: cli: move "show stat" to stats.c
14271 - REORG: cli: move "show info" to stats.c
14272 - REORG: cli: move dump_text(), dump_text_line(), and dump_binary() to standard.c
14273 - REORG: cli: move table dump/clear/set to stick_table.c
14274 - REORG: cli: move "show errors" out of cli.c
14275 - REORG: cli: make "show env" also use the generic keyword registration
14276 - REORG: cli: move "set timeout" to its own handler
14277 - REORG: cli: move "clear counters" to stats.c
14278 - REORG: cli: move "set maxconn global" to its own handler
14279 - REORG: cli: move "set maxconn server" to server.c
14280 - REORG: cli: move "set maxconn frontend" to proxy.c
14281 - REORG: cli: move "shutdown sessions server" to stream.c
14282 - REORG: cli: move "shutdown session" to stream.c
14283 - REORG: cli: move "shutdown frontend" to proxy.c
14284 - REORG: cli: move "{enable|disable} frontend" to proxy.c
14285 - REORG: cli: move "{enable|disable} server" to server.c
14286 - REORG: cli: move "{enable|disable} health" to server.c
14287 - REORG: cli: move "{enable|disable} agent" to server.c
14288 - REORG: cli: move the "set rate-limit" functions to their own parser
14289 - CLEANUP: cli: rename STAT_CLI_* to CLI_ST_*
14290 - CLEANUP: cli: simplify the request parser a little bit
14291 - CLEANUP: cli: remove assignments to st0 and st2 in keyword parsers
14292 - BUILD: server: remove a build warning introduced by latest series
14293 - BUG/MINOR: log-format: uncatched memory allocation functions
14294 - CLEANUP: log-format: useless file and line in json converter
14295 - CLEANUP/MINOR: log-format: unexport functions parse_logformat_var_args() and parse_logformat_var()
14296 - CLEANUP: log-format: fix return code of the function parse_logformat_var()
14297 - CLEANUP: log-format: fix return code of function parse_logformat_var_args()
14298 - CLEANUP: log-format: remove unused arguments
14299 - MEDIUM: log-format: strict parsing and enable fail
14300 - MEDIUM: log-format/conf: take into account the parse_logformat_string() return code
14301 - BUILD: ssl: make the SSL layer build again with openssl 0.9.8
14302 - BUILD: vars: remove a build warning on vars.c
14303 - MINOR: lua: add utility function for check boolean argument
14304 - MINOR: lua: Add tokenize function.
14305 - BUG/MINOR: conf: calloc untested
14306 - MINOR: http/conf: store the use_backend configuration file and line for logs
14307 - MEDIUM: log-format: Use standard HAProxy log system to report errors
14308 - CLEANUP: sample: report "converter" instead of "conv method" in error messages
14309 - BUG: spoe: Fix parsing of SPOE actions in ACK frames
14310 - MINOR: cli: make "show stat" support a proxy name
14311 - MINOR: cli: make "show errors" support a proxy name
14312 - MINOR: cli: make "show errors" capable of dumping only request or response
14313 - BUG/MINOR: freq-ctr: make swrate_add() support larger values
14314 - CLEANUP: counters: move from 3 types to 2 types
14315 - CLEANUP: cfgparse: cascade the warnif_misplaced_* rules
14316 - REORG: tcp-rules: move tcp rules processing to their own file
14317 - REORG: stkctr: move all the stick counters processing to stick-tables.c
14318 - DOC: update the roadmap file with the latest changes
14319
Willy Tarreaud5d890b2016-11-09 23:18:17 +0100143202016/11/09 : 1.7-dev6
14321 - DOC: fix the entry for hash-balance-factor config option
14322 - DOC: Fix typo in description of `-st` parameter in man page
14323 - CLEANUP: cfgparse: Very minor spelling correction
14324 - MINOR: examples: Update haproxy.spec URLs to haproxy.org
14325 - BUG/MEDIUM: peers: on shutdown, wake up the appctx, not the stream
14326 - BUG/MEDIUM: peers: fix use after free in peer_session_create()
14327 - MINOR: peers: make peer_session_forceshutdown() use the appctx and not the stream
14328 - MINOR: peers: remove the pointer to the stream
14329 - BUG/MEDIUM: systemd-wrapper: return correct exit codes
14330 - DOC: stats: provide state details for show servers state
14331 - MEDIUM: tools: make str2ip2() preserve existing ports
14332 - CLEANUP: tools: make ipcpy() preserve the original port
14333 - OPTIM: http: move all http character classs tables into a single one
14334 - OPTIM: http: improve parsing performance of long header lines
14335 - OPTIM: http: improve parsing performance of long URIs
14336 - OPTIM: http: optimize lookup of comma and quote in header values
14337 - BUG/MEDIUM: srv-state: properly restore the DRAIN state
14338 - BUG/MINOR: srv-state: allow to have both CMAINT and FDRAIN flags
14339 - MINOR: server: do not emit warnings/logs/alerts on server state changes at boot
14340 - BUG/MEDIUM: servers: properly propagate the maintenance states during startup
14341 - MEDIUM: wurfl: add Scientiamobile WURFL device detection module
14342 - DOC: move the device detection modules documentation to their own files
14343 - CLEANUP: wurfl: reduce exposure in the rest of the code
14344 - MEDIUM: ssl: Add support for OpenSSL 1.1.0
14345 - MINOR: stream: make option contstats usable again
14346 - MEDIUM: tools: make str2sa_range() return the FQDN even when not resolving
14347 - MINOR: init: move apply_server_state in haproxy.c before MODE_CHECK
14348 - MAJOR: server: postpone address resolution
14349 - MINOR: new srv_admin flag: SRV_ADMF_RMAINT
14350 - MINOR: server: indicate in the logs when RMAINT is cleared
14351 - MINOR: stats: indicate it when a server is down due to resolution
14352 - MINOR: server: make srv_set_admin_state() capable of telling why this happens
14353 - MINOR: dns: implement extra 'hold' timers.
14354 - MAJOR: dns: runtime resolution can change server admin state
14355 - MEDIUM: cli: leave the RMAINT state when setting an IP address on the CLI
14356 - MEDIUM: server: add a new init-addr server line setting
14357 - MEDIUM: server: make use of init-addr
14358 - MINOR: server: implement init-addr none
14359 - MEDIUM: server: make libc resolution failure non-fatal
14360 - MINOR: server: add support for explicit numeric address in init-addr
14361 - DOC: add some documentation for the "init-addr" server keyword
14362 - MINOR: init: add -dr to ignore server address resolution failures
14363 - MEDIUM: server: do not restrict anymore usage of IP address from the state file
14364 - BUG: vars: Fix 'set-var' converter because of a typo
14365 - CLEANUP: remove last references to 'ruleset' section
14366 - MEDIUM: filters: Add attch/detach and stream_set_backend callbacks
14367 - MINOR: filters: Update filters documentation accordingly to recent changes
14368 - MINOR: filters: Call stream_set_backend callbacks before updating backend stats
14369 - MINOR: filters: Remove backend filters attached to a stream only for HTTP streams
14370 - MINOR: flt_trace: Add hexdump option to dump forwarded data
14371 - MINOR: cfgparse: Add functions to backup and restore registered sections
14372 - MINOR: cfgparse: Parse scope lines and save the last one parsed
14373 - REORG: sample: move code to release a sample expression in sample.c
14374 - MINOR: vars: Allow '.' in variable names
14375 - MINOR: vars: Add vars_set_by_name_ifexist function
14376 - MEDIUM: vars: Add a per-process scope for variables
14377 - MINOR: vars: Add 'unset-var' action/converter
14378 - MAJOR: spoe: Add an experimental Stream Processing Offload Engine
14379 - MINOR: spoe: add random ip-reputation service as SPOA example
14380 - MINOR: spoe/checks: Add support for SPOP health checks
14381 - DOC: update ROADMAP file
14382
Willy Tarreau608efa12016-10-25 22:22:00 +0200143832016/10/25 : 1.7-dev5
14384 - MINOR: cfgparse: few memory leaks fixes.
14385 - MEDIUM: log: Decompose %Tq in %Th %Ti %TR
14386 - CLEANUP: logs: remove unused log format field definitions
14387 - BUILD/MAJOR:updated 51d Trie implementation to incorperate latest update to 51Degrees.c
14388 - BUG/MAJOR: stream: properly mark the server address as unset on connect retry
14389 - CLEANUP: proto_http: Removing useless variable assignation
14390 - CLEANUP: dumpstats: Removing useless variables allocation
14391 - CLEANUP: dns: Removing usless variable & assignation
14392 - BUG/MINOR: payload: fix SSLv2 version parser
14393 - MINOR: cli: allow the semi-colon to be escaped on the CLI
14394 - MINOR: cli: change a server health check port through the stats socket
14395 - BUG/MINOR: Fix OSX compilation errors
14396 - MAJOR: check: find out which port to use for health check at run time
14397 - MINOR: server: introduction of 3 new server flags
14398 - MINOR: new update_server_addr_port() function to change both server's ADDR and service PORT
14399 - MINOR: cli: ability to change a server's port
14400 - CLEANUP/MINOR dns: comment do not follow up code update
14401 - MINOR: chunk: new strncat function
14402 - MINOR: dns: wrong DNS_MAX_UDP_MESSAGE value
14403 - MINOR: dns: new MAX values
14404 - MINOR: dns: new macro to compute DNS header size
14405 - MINOR: dns: new DNS structures to store received packets
14406 - MEDIUM: dns: new DNS response parser
14407 - MINOR: dns: query type change when last record is a CNAME
14408 - MINOR: dns: proper domain name validation when receiving DNS response
14409 - MINOR: dns: comments in types/dns.h about structures endianness
14410 - BUG/MINOR: displayed PCRE version is running release
14411 - MINOR: show Built with PCRE version
14412 - MINOR: show Running on zlib version
14413 - MEDIUM: make SO_REUSEPORT configurable
14414 - MINOR: enable IP_BIND_ADDRESS_NO_PORT on backend connections
14415 - BUG/MEDIUM: http/compression: Fix how chunked data are copied during the HTTP body parsing
14416 - BUG/MINOR: stats: report the correct conn_time in backend's html output
14417 - BUG/MEDIUM: dns: don't randomly crash on out-of-memory
14418 - MINOR: Add fe_req_rate sample fetch
14419 - MEDIUM: peers: Fix a peer stick-tables synchronization issue.
14420 - MEDIUM: cli: register CLI keywords with cli_register_kw()
14421 - BUILD: Make use of accept4() on OpenBSD.
14422 - MINOR: tcp: make set-src/set-src-port and set-dst/set-dst-port commutative
14423 - DOC: fix missed entry for "set-{src,dst}{,-port}"
14424 - BUG/MINOR: vars: use sess and not s->sess in action_store()
14425 - BUG/MINOR: vars: make smp_fetch_var() more robust against misuses
14426 - BUG/MINOR: vars: smp_fetch_var() doesn't depend on HTTP but on the session
14427 - MINOR: stats: output dcon
14428 - CLEANUP: tcp rules: mention everywhere that tcp-conn rules are L4
14429 - MINOR: counters: add new fields for denied_sess
14430 - MEDIUM: tcp: add registration and processing of TCP L5 rules
14431 - MINOR: stats: emit dses
14432 - DOC: document tcp-request session
14433 - MINOR: ssl: add debug traces
14434 - BUILD/CLEANUP: ssl: Check BIO_reset() return code
14435 - BUG/MINOR: ssl: Check malloc return code
14436 - BUG/MINOR: ssl: prevent multiple entries for the same certificate
14437 - BUG/MINOR: systemd: make the wrapper return a non-null status code on error
14438 - BUG/MINOR: systemd: always restore signals before execve()
14439 - BUG/MINOR: systemd: check return value of calloc()
14440 - MINOR: systemd: report it when execve() fails
14441 - BUG/MEDIUM: systemd: let the wrapper know that haproxy has completed or failed
14442 - MINOR: proxy: add 'served' field to proxy, equal to total of all servers'
14443 - MINOR: backend: add hash-balance-factor option for hash-type consistent
14444 - MINOR: server: compute a "cumulative weight" to allow chash balancing to hit its target
14445 - MEDIUM: server: Implement bounded-load hash algorithm
14446 - SCRIPTS: make git-show-backports also dump a "git show" command
14447 - MINOR: build: Allow linking to device-atlas library file
14448 - MINOR: stats: Escape equals sign on socket dump
14449
Willy Tarreau41d5e3a2016-08-14 12:25:21 +0200144502016/08/14 : 1.7-dev4
14451 - MINOR: add list_append_word function
14452 - MEDIUM: init: use list_append_word in haproxy.c
14453 - MEDIUM: init: allow directory as argument of -f
14454 - CLEANUP: config: detect double registration of a config section
14455 - MINOR: log: add the %Td log-format specifier
14456 - MEDIUM: filters: Move HTTP headers filtering in its own callback
14457 - MINOR: filters: Simplify calls to analyzers using 2 new macros
14458 - MEDIUM: filters: Add pre and post analyzer callbacks
14459 - DOC: filters: Update the filters documentation accordingly to recent changes
14460 - BUG/MEDIUM: init: don't use environment locale
14461 - SCRIPTS: teach git-show-backports how to report upstream commits
14462 - SCRIPTS: make git-show-backports capable of limiting its history
14463 - BUG/MAJOR: fix listening IP address storage for frontends
14464 - BUG/MINOR: fix listening IP address storage for frontends (cont)
14465 - DOC: Fix typo so fetch is properly parsed by Cyril's converter
14466 - BUG/MAJOR: http: fix breakage of "reqdeny" causing random crashes
14467 - BUG/MEDIUM: stick-tables: fix breakage in table converters
14468 - MINOR: stick-table: change all stick-table converters' inputs to SMP_T_ANY
14469 - BUG/MEDIUM: dns: unbreak DNS resolver after header fix
14470 - BUILD: fix build on Solaris 11
14471 - BUG/MEDIUM: config: fix multiple declaration of section parsers
14472 - BUG/MEDIUM: stats: show servers state may show an servers from another backend
14473 - BUG/MEDIUM: fix risk of segfault with "show tls-keys"
14474 - MEDIUM: dumpstats: 'show tls-keys' is now able to show secrets
14475 - DOC: update doc about tls-tickets-keys dump
14476 - MEDIUM: tcp: add 'set-src' to 'tcp-request connection'
14477 - MINOR: set the CO_FL_ADDR_FROM_SET flags with 'set-src'
14478 - MEDIUM: tcp/http: add 'set-src-port' action
14479 - MEDIUM: tcp/http: new set-dst/set-dst-port actions
14480 - BUG/MEDIUM: sticktables: segfault in some configuration error cases
14481 - BUILD/MEDIUM: rebuild everything when an include file is changed
14482 - BUILD/MEDIUM: force a full rebuild if some build options change
14483 - BUG/MEDIUM: lua: converters doesn't work
14484 - BUG/MINOR: http: add-header: header name copied twice
14485 - BUG/MEDIUM: http: add-header: buffer overwritten
14486 - BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()
14487 - MINOR: stream: export the function 'smp_create_src_stkctr'
14488 - BUG/MEDIUM: dumpstats: undefined behavior in stats_tlskeys_list()
14489 - MEDIUM: dumpstats: make stats_tlskeys_list() yield-aware during tls-keys dump
14490 - BUG/MINOR: http: url32+src should use the big endian version of url32
14491 - BUG/MINOR: http: url32+src should check cli_conn before using it
14492 - DOC: http: add documentation for url32 and url32+src
14493 - BUG/MINOR: fix http-response set-log-level parsing error
14494 - MINOR: systemd: Use variable for config and pidfile paths
14495 - MINOR: systemd: Perform sanity check on config before reload
14496 - MEDIUM: ssl: support SNI filters with multicerts
14497 - MINOR: ssl: crt-list parsing factor
14498 - BUILD: ssl: fix typo causing a build failure in the multicert patch
14499 - MINOR: listener: add the "accept-netscaler-cip" option to the "bind" keyword
14500 - MINOR: tcp: add "tcp-request connection expect-netscaler-cip layer4"
14501 - BUG/MINOR: init: always ensure that global.rlimit_nofile matches actual limits
14502 - BUG/MINOR: init: ensure that FD limit is raised to the max allowed
14503 - BUG/MEDIUM: external-checks: close all FDs right after the fork()
14504 - BUG/MAJOR: external-checks: use asynchronous signal delivery
14505 - BUG/MINOR: external-checks: do not unblock undesired signals
14506 - CLEANUP: external-check: don't block/unblock SIGCHLD when manipulating the list
14507 - BUG/MEDIUM: filters: Fix data filtering when data are modified
14508 - BUG/MINOR: filters: Fix HTTP parsing when a filter loops on data forwarding
14509 - BUG/MINOR: srv-state: fix incorrect output of state file
14510 - BUG/MINOR: ssl: close ssl key file on error
14511 - BUG/MINOR: http: fix misleading error message for response captures
14512 - BUG/BUILD: don't automatically run "make" on "make install"
14513 - DOC: add missing doc for http-request deny [deny_status <status>]
14514 - CLEANUP: dumpstats: u64 field is an unsigned type.
14515 - BUG/MEDIUM: http: unbreak uri/header/url_param hashing
14516 - BUG/MINOR: Rework slightly commit 9962f8fc to clean code and avoid mistakes
14517 - MINOR: new function my_realloc2 = realloc + free upon failure
14518 - CLEANUP: fixed some usages of realloc leading to memory leak
14519 - Revert "BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()"
14520 - CLEANUP: connection: using internal struct to hold source and dest port.
14521 - DOC: spelling fixes
14522 - BUG/MINOR: ssl: fix potential memory leak in ssl_sock_load_dh_params()
14523 - BUG/MEDIUM: dns: fix alignment issues in the DNS response parser
14524 - BUG/MINOR: Fix endiness issue in DNS header creation code
14525 - BUG/MEDIUM: lua: the function txn_done() from sample fetches can crash
14526 - BUG/MEDIUM: lua: the function txn_done() from action wrapper can crash
14527 - MEDIUM: http: implement http-response track-sc* directive
14528 - BUG/MINOR: peers: Fix peers data decoding issue
14529 - BUG/MINOR: peers: don't count track-sc multiple times on errors
14530 - MINOR: standard: add function "escape_string"
14531 - BUG/MEDIUM: log: use function "escape_string" instead of "escape_chunk"
14532 - MINOR: tcp: Return TCP statistics like RTT and RTT variance
14533 - DOC: lua: remove old functions
14534 - BUG/MEDIUM: lua: somme HTTP manipulation functions are called without valid requests
14535 - DOC: fix json converter example and error message
14536 - BUG/MEDIUM: stream-int: completely detach connection on connect error
14537 - DOC: minor typo fixes to improve HTML parsing by haproxy-dconv
14538 - BUILD: make proto_tcp.c compatible with musl library
14539 - BUG/MAJOR: compression: initialize avail_in/next_in even during flush
14540 - BUG/MEDIUM: samples: make smp_dup() always duplicate the sample
14541 - MINOR: sample: implement smp_is_safe() and smp_make_safe()
14542 - MINOR: sample: provide smp_is_rw() and smp_make_rw()
14543 - BUG/MAJOR: server: the "sni" directive could randomly cause trouble
14544 - BUG/MEDIUM: stick-tables: do not fail on string keys with no allocated size
14545 - BUG/MEDIUM: stick-table: properly convert binary samples to keys
14546 - MINOR: sample: use smp_make_rw() in upper/lower converters
14547 - MINOR: tcp: add dst_is_local and src_is_local
14548 - BUG/MINOR: peers: some updates are pushed twice after a resync.
14549 - BUILD: protocol: fix some build errors on OpenBSD
14550 - BUILD: log: iovec requires to include sys/uio.h on OpenBSD
14551 - BUILD: tcp: do not include netinet/ip.h for IP_TTL
14552 - BUILD: connection: fix build breakage on openbsd due to missing in_systm.h
14553 - BUILD: checks: remove the last strcat and eliminate a warning on OpenBSD
14554 - BUILD: tcp: define SOL_TCP when only IPPROTO_TCP exists
14555 - BUILD: compression: remove a warning when no compression lib is used
14556 - BUILD: poll: remove unused hap_fd_isset() which causes a warning with clang
14557 - MINOR: tcp: add further tcp info fetchers
14558 - BUG/MINOR: peers: empty chunks after a resync.
14559 - BUG/MAJOR: stick-counters: possible crash when using sc_trackers with wrong table
14560 - MINOR: standard.c: ipcmp() function to compare 2 IP addresses stored in 2 struct sockaddr_storage
14561 - MINOR: standard.c: ipcpy() function to copy an IP address from a struct sockaddr_storage into an other one
14562 - MAJOR: listen section: don't use first bind port anymore when no server ports are provided
14563
Willy Tarreau7d1b48f2016-05-10 15:36:58 +0200145642016/05/10 : 1.7-dev3
14565 - MINOR: sample: Moves ARGS underlying type from 32 to 64 bits.
14566 - BUG/MINOR: log: Don't use strftime() which can clobber timezone if chrooted
14567 - BUILD: namespaces: fix a potential build warning in namespaces.c
14568 - MINOR: da: Using ARG12 macro for the sample fetch and the convertor.
14569 - DOC: add encoding to json converter example
14570 - BUG/MINOR: conf: "listener id" expects integer, but its not checked
14571 - DOC: Clarify tunes.vars.xxx-max-size settings
14572 - CLEANUP: chunk: adding NULL check to chunk_dup allocation.
14573 - CLEANUP: connection: fix double negation on memcmp()
14574 - BUG/MEDIUM: peers: fix incorrect age in frequency counters
14575 - BUG/MEDIUM: Fix RFC5077 resumption when more than TLS_TICKETS_NO are present
14576 - BUG/MAJOR: Fix crash in http_get_fhdr with exactly MAX_HDR_HISTORY headers
14577 - BUG/MINOR: lua: can't load external libraries
14578 - BUG/MINOR: prevent the dump of uninitialized vars
14579 - CLEANUP: map: it seems that the map were planed to be chained
14580 - MINOR: lua: move class registration facilities
14581 - MINOR: lua: remove some useless checks
14582 - CLEANUP: lua: Remove two same functions
14583 - MINOR: lua: refactor the Lua object registration
14584 - MINOR: lua: precise message when a critical error is catched
14585 - MINOR: lua: post initialization
14586 - MINOR: lua: Add internal function which strip spaces
14587 - MINOR: lua: convert field to lua type
14588 - DOC: "addr" parameter applies to both health and agent checks
14589 - DOC: timeout client: pointers to timeout http-request
14590 - DOC: typo on stick-store response
14591 - DOC: stick-table: amend paragraph blaming the loss of table upon reload
14592 - DOC: typo: ACL subdir match
14593 - DOC: typo: maxconn paragraph is wrong due to a wrong buffer size
14594 - DOC: regsub: parser limitation about the inability to use closing square brackets
14595 - DOC: typo: req.uri is now replaced by capture.req.uri
14596 - DOC: name set-gpt0 mismatch with the expected keyword
14597 - MINOR: http: sample fetch which returns unique-id
14598 - MINOR: dumpstats: extract stats fields enum and names
14599 - MINOR: dumpstats: split stats_dump_info_to_buffer() in two parts
14600 - MINOR: dumpstats: split stats_dump_fe_stats() in two parts
14601 - MINOR: dumpstats: split stats_dump_li_stats() in two parts
14602 - MINOR: dumpstats: split stats_dump_sv_stats() in two parts
14603 - MINOR: dumpstats: split stats_dump_be_stats() in two parts
14604 - MINOR: lua: dump general info
14605 - MINOR: lua: add class proxy
14606 - MINOR: lua: add class server
14607 - MINOR: lua: add class listener
14608 - BUG/MEDIUM: stick-tables: some sample-fetch doesn't work in the connection state.
14609 - MEDIUM: proxy: use dynamic allocation for error dumps
14610 - CLEANUP: remove unneeded casts
14611 - CLEANUP: uniformize last argument of malloc/calloc
14612 - DOC: fix "needed" typo
14613 - BUG/MINOR: dumpstats: fix write to global chunk
14614 - BUG/MINOR: dns: inapropriate way out after a resolution timeout
14615 - BUG/MINOR: dns: trigger a DNS query type change on resolution timeout
14616 - CLEANUP: proto_http: few corrections for gcc warnings.
14617 - BUG/MINOR: DNS: resolution structure change
14618 - BUG/MINOR : allow to log cookie for tarpit and denied request
14619 - BUG/MEDIUM: ssl: rewind the BIO when reading certificates
14620 - OPTIM/MINOR: session: abort if possible before connecting to the backend
14621 - DOC: http: rename the unique-id sample and add the documentation
14622 - BUG/MEDIUM: trace.c: rdtsc() is defined in two files
14623 - BUG/MEDIUM: channel: fix miscalculation of available buffer space (2nd try)
14624 - BUG/MINOR: server: risk of over reading the pref_net array.
14625 - BUG/MINOR: cfgparse: couple of small memory leaks.
14626 - BUG/MEDIUM: sample: initialize the pointer before parse_binary call.
14627 - DOC: fix discrepancy in the example for http-request redirect
14628 - MINOR: acl: Add predefined METH_DELETE, METH_PUT
14629 - CLEANUP: .gitignore cleanup
14630 - DOC: Clarify IPv4 address / mask notation rules
14631 - CLEANUP: fix inconsistency between fd->iocb, proto->accept and accept()
14632 - BUG/MEDIUM: fix maxaccept computation on per-process listeners
14633 - BUG/MINOR: listener: stop unbound listeners on startup
14634 - BUG/MINOR: fix maxaccept computation according to the frontend process range
14635 - TESTS: add blocksig.c to run tests with all signals blocked
14636 - MEDIUM: unblock signals on startup.
14637 - MINOR: filters: Print the list of existing filters during HA startup
14638 - MINOR: filters: Typo in an error message
14639 - MINOR: filters: Filters must define the callbacks struct during config parsing
14640 - DOC: filters: Add filters documentation
14641 - BUG/MEDIUM: channel: don't allow to overwrite the reserve until connected
14642 - BUG/MEDIUM: channel: incorrect polling condition may delay event delivery
14643 - BUG/MEDIUM: channel: fix miscalculation of available buffer space (3rd try)
14644 - BUG/MEDIUM: log: fix risk of segfault when logging HTTP fields in TCP mode
14645 - MINOR: Add ability for agent-check to set server maxconn
14646 - CLEANUP: Use server_parse_maxconn_change_request for maxconn CLI updates
14647 - MINOR: filters: add opaque data
14648 - BUG/MEDIUM: lua: protects the upper boundary of the argument list for converters/fetches.
14649 - MINOR: lua: migrate the argument mask to 64 bits type.
14650 - BUG/MINOR: dumpstats: Fix the "Total bytes saved" counter in backends stats
14651 - BUG/MINOR: log: fix a typo that would cause %HP to log <BADREQ>
14652 - BUG/MEDIUM: http: fix incorrect reporting of server errors
14653 - MINOR: channel: add new function channel_congested()
14654 - BUG/MEDIUM: http: fix risk of CPU spikes with pipelined requests from dead client
14655 - BUG/MAJOR: channel: fix miscalculation of available buffer space (4th try)
14656 - BUG/MEDIUM: stream: ensure the SI_FL_DONT_WAKE flag is properly cleared
14657 - BUG/MEDIUM: channel: fix inconsistent handling of 4GB-1 transfers
14658 - BUG/MEDIUM: stats: show servers state may show an empty or incomplete result
14659 - BUG/MEDIUM: stats: show backend may show an empty or incomplete result
14660 - MINOR: stats: fix typo in help messages
14661 - MINOR: stats: show stat resolvers missing in the help message
14662 - BUG/MINOR: dns: fix DNS header definition
14663 - BUG/MEDIUM: dns: fix alignment issue when building DNS queries
14664 - CLEANUP: don't ignore scripts in .gitignore
14665 - BUILD: add a few release and backport scripts in scripts/
14666
Willy Tarreau8234f6d2016-03-14 00:10:05 +0100146672016/03/14 : 1.7-dev2
14668 - DOC: lua: fix lua API
14669 - DOC: mailers: typo in 'hostname' description
14670 - DOC: compression: missing mention of libslz for compression algorithm
14671 - BUILD/MINOR: regex: missing header
14672 - BUG/MINOR: stream: bad return code
14673 - DOC: lua: fix somme errors and add implicit types
14674 - MINOR: lua: add set/get priv for applets
14675 - BUG/MINOR: http: fix several off-by-one errors in the url_param parser
14676 - BUG/MINOR: http: Be sure to process all the data received from a server
14677 - MINOR: filters/http: Use a wrapper function instead of stream_int_retnclose
14678 - BUG/MINOR: chunk: make chunk_dup() always check and set dst->size
14679 - DOC: ssl: fixed some formatting errors in crt tag
14680 - MINOR: chunks: ensure that chunk_strcpy() adds a trailing zero
14681 - MINOR: chunks: add chunk_strcat() and chunk_newstr()
14682 - MINOR: chunk: make chunk_initstr() take a const string
14683 - MEDIUM: tools: add csv_enc_append() to preserve the original chunk
14684 - MINOR: tools: make csv_enc_append() always start at the first byte of the chunk
14685 - MINOR: lru: new function to delete <nb> least recently used keys
14686 - DOC: add Ben Shillito as the maintainer of 51d
14687 - BUG/MINOR: 51d: Ensures a unique domain for each configuration
14688 - BUG/MINOR: 51d: Aligns Pattern cache implementation with HAProxy best practices.
14689 - BUG/MINOR: 51d: Releases workset back to pool.
14690 - BUG/MINOR: 51d: Aligned const pointers to changes in 51Degrees.
14691 - CLEANUP: 51d: Aligned if statements with HAProxy best practices and removed casts from malloc.
14692 - MINOR: rename master process name in -Ds (systemd mode)
14693 - DOC: fix a few spelling mistakes
14694 - DOC: fix "workaround" spelling
14695 - BUG/MINOR: examples: Fixing haproxy.spec to remove references to .cfg files
14696 - MINOR: fix the return type for dns_response_get_query_id() function
14697 - MINOR: server state: missing LF (\n) on error message printed when parsing server state file
14698 - BUG/MEDIUM: dns: no DNS resolution happens if no ports provided to the nameserver
14699 - BUG/MAJOR: servers state: server port is erased when dns resolution is enabled on a server
14700 - BUG/MEDIUM: servers state: server port is used uninitialized
14701 - BUG/MEDIUM: config: Adding validation to stick-table expire value.
14702 - BUG/MEDIUM: sample: http_date() doesn't provide the right day of the week
14703 - BUG/MEDIUM: channel: fix miscalculation of available buffer space.
14704 - MEDIUM: pools: add a new flag to avoid rounding pool size up
14705 - BUG/MEDIUM: buffers: do not round up buffer size during allocation
14706 - BUG/MINOR: stream: don't force retries if the server is DOWN
14707 - BUG/MINOR: counters: make the sc-inc-gpc0 and sc-set-gpt0 touch the table
14708 - MINOR: unix: don't mention free ports on EAGAIN
14709 - BUG/CLEANUP: CLI: report the proper field states in "show sess"
14710 - MINOR: stats: send content-length with the redirect to allow keep-alive
14711 - BUG: stream_interface: Reuse connection even if the output channel is empty
14712 - DOC: remove old tunnel mode assumptions
14713 - BUG/MAJOR: http-reuse: fix risk of orphaned connections
14714 - BUG/MEDIUM: http-reuse: do not share private connections across backends
14715 - BUG/MINOR: ssl: Be sure to use unique serial for regenerated certificates
14716 - BUG/MINOR: stats: fix missing comma in stats on agent drain
14717 - MAJOR: filters: Add filters support
14718 - MINOR: filters: Do not reset stream analyzers if the client is gone
14719 - REORG: filters: Prepare creation of the HTTP compression filter
14720 - MAJOR: filters/http: Rewrite the HTTP compression as a filter
14721 - MEDIUM: filters: Use macros to call filters callbacks to speed-up processing
14722 - MEDIUM: filters: remove http_start_chunk, http_last_chunk and http_chunk_end
14723 - MEDIUM: filters: Replace filter_http_headers callback by an analyzer
14724 - MEDIUM: filters/http: Move body parsing of HTTP messages in dedicated functions
14725 - MINOR: filters: Add stream_filters structure to hide filters info
14726 - MAJOR: filters: Require explicit registration to filter HTTP body and TCP data
14727 - MINOR: filters: Remove unused or useless stuff and do small optimizations
14728 - MEDIUM: filters: Optimize the HTTP compression for chunk encoded response
14729 - MINOR: filters/http: Slightly update the parsing of chunks
14730 - MINOR: filters/http: Forward remaining data when a channel has no "data" filters
14731 - MINOR: filters: Add an filter example
14732 - MINOR: filters: Extract proxy stuff from the struct filter
14733 - MINOR: map: Add regex matching replacement
14734 - BUG/MINOR: lua: unsafe initialization
14735 - DOC: lua: fix somme errors
14736 - MINOR: lua: file dedicated to unsafe functions
14737 - MINOR: lua: add "now" time function
14738 - MINOR: standard: add RFC HTTP date parser
14739 - MINOR: lua: Add date functions
14740 - MINOR: lua: move common function
14741 - MINOR: lua: merge function
14742 - MINOR: lua: Add concat class
14743 - MINOR: standard: add function "escape_chunk"
14744 - MEDIUM: log: add a new log format flag "E"
14745 - DOC: add server name at rate-limit sessions example
14746 - BUG/MEDIUM: ssl: fix off-by-one in ALPN list allocation
14747 - BUG/MEDIUM: ssl: fix off-by-one in NPN list allocation
14748 - DOC: LUA: fix some typos and syntax errors
14749 - MINOR: cli: add a new "show env" command
14750 - MEDIUM: config: allow to manipulate environment variables in the global section
14751 - MEDIUM: cfgparse: reject incorrect 'timeout retry' keyword spelling in resolvers
14752 - MINOR: mailers: increase default timeout to 10 seconds
14753 - MINOR: mailers: use <CRLF> for all line endings
14754 - BUG/MAJOR: lua: segfault using Concat object
14755 - DOC: lua: copyrights
14756 - MINOR: common: mask conversion
14757 - MEDIUM: dns: extract options
14758 - MEDIUM: dns: add a "resolve-net" option which allow to prefer an ip in a network
14759 - MINOR: mailers: make it possible to configure the connection timeout
14760 - BUG/MAJOR: lua: applets can't sleep.
14761 - BUG/MINOR: server: some prototypes are renamed
14762 - BUG/MINOR: lua: Useless copy
14763 - BUG/MEDIUM: stats: stats bind-process doesn't propagate the process mask correctly
14764 - BUG/MINOR: server: fix the format of the warning on address change
14765 - CLEANUP: server: add "const" to some message strings
14766 - MINOR: server: generalize the "updater" source
14767 - BUG/MEDIUM: chunks: always reject negative-length chunks
14768 - BUG/MINOR: systemd: ensure we don't miss signals
14769 - BUG/MINOR: systemd: report the correct signal in debug message output
14770 - BUG/MINOR: systemd: propagate the correct signal to haproxy
14771 - MINOR: systemd: ensure a reload doesn't mask a stop
14772 - BUG/MEDIUM: cfgparse: wrong argument offset after parsing server "sni" keyword
14773 - CLEANUP: stats: Avoid computation with uninitialized bits.
14774 - CLEANUP: pattern: Ignore unknown samples in pat_match_ip().
14775 - CLEANUP: map: Avoid memory leak in out-of-memory condition.
14776 - BUG/MINOR: tcpcheck: fix incorrect list usage resulting in failure to load certain configs
14777 - BUG/MAJOR: samples: check smp->strm before using it
14778 - MINOR: sample: add a new helper to initialize the owner of a sample
14779 - MINOR: sample: always set a new sample's owner before evaluating it
14780 - BUG/MAJOR: vars: always retrieve the stream and session from the sample
14781 - CLEANUP: payload: remove useless and confusing nullity checks for channel buffer
14782 - BUG/MINOR: ssl: fix usage of the various sample fetch functions
14783 - MINOR: stats: create fields types suitable for all CSV output data
14784 - MINOR: stats: add all the "show info" fields in a table
14785 - MEDIUM: stats: fill all the show info elements prior to displaying them
14786 - MINOR: stats: add a function to emit fields into a chunk
14787 - MINOR: stats: add stats_dump_info_fields() to dump one field per line
14788 - MEDIUM: stats: make use of stats_dump_info_fields() for "show info"
14789 - MINOR: stats: add a declaration of all stats fields
14790 - MINOR: stats: don't hard-code the CSV fields list anymore
14791 - MINOR: stats: create stats fields storage and CSV dump function
14792 - MEDIUM: stats: convert stats_dump_fe_stats() to use stats_dump_fields_csv()
14793 - MEDIUM: stats: make stats_dump_fe_stats() use stats fields for HTML dump
14794 - MEDIUM: stats: convert stats_dump_li_stats() to use stats_dump_fields_csv()
14795 - MEDIUM: stats: make stats_dump_li_stats() use stats fields for HTML dump
14796 - MEDIUM: stats: convert stats_dump_be_stats() to use stats_dump_fields_csv()
14797 - MEDIUM: stats: make stats_dump_be_stats() use stats fields for HTML dump
14798 - MEDIUM: stats: convert stats_dump_sv_stats() to use stats_dump_fields_csv()
14799 - MEDIUM: stats: make stats_dump_sv_stats() use the stats field for HTML
14800 - MEDIUM: stats: move the server state coloring logic to the server dump function
14801 - MINOR: stats: do not use srv->admin & STATS_ADMF_MAINT in HTML dumps
14802 - MINOR: stats: do not check srv->state for SRV_ST_STOPPED in HTML dumps
14803 - MINOR: stats: make CSV report server check status only when enabled
14804 - MINOR: stats: only report backend's down time if it has servers
14805 - MINOR: stats: prepend '*' in front of the check status when in progress
14806 - MINOR: stats: make HTML stats dump rely on the table for the check status
14807 - MINOR: stats: add agent_status, agent_code, agent_duration to output
14808 - MINOR: stats: add check_desc and agent_desc to the output fields
14809 - MINOR: stats: add check and agent's health values in the output
14810 - MEDIUM: stats: make the HTML server state dump use the CSV states
14811 - MEDIUM: stats: only report observe errors when observe is set
14812 - MEDIUM: stats: expose the same flags for CLI and HTTP accesses
14813 - MEDIUM: stats: report server's address in the CSV output
14814 - MEDIUM: stats: report the cookie value in the server & backend CSV dumps
14815 - MEDIUM: stats: compute the color code only in the HTML form
14816 - MEDIUM: stats: report the listeners' address in the CSV output
14817 - MEDIUM: stats: make it possible to report the WAITING state for listeners
14818 - REORG: stats: dump the frontend's HTML stats via a generic function
14819 - REORG: stats: dump the socket stats via the generic function
14820 - REORG: stats: dump the server stats via the generic function
14821 - REORG: stats: dump the backend stats via the generic function
14822 - MEDIUM: stats: add a new "mode" column to report the proxy mode
14823 - MINOR: stats: report the load balancing algorithm in CSV output
14824 - MINOR: stats: add 3 fields to report the frontend-specific connection stats
14825 - MINOR: stats: report number of intercepted requests for frontend and backends
14826 - MINOR: stats: introduce stats_dump_one_line() to dump one stats line
14827 - CLEANUP: stats: make stats_dump_fields_html() not rely on proxy anymore
14828 - MINOR: stats: add ST_SHOWADMIN to pass the admin info in the regular flags
14829 - MINOR: stats: make stats_dump_fields_html() not use &trash by default
14830 - MINOR: stats: add functions to emit typed fields into a chunk
14831 - MEDIUM: stats: support "show info typed" on the CLI
14832 - MEDIUM: stats: implement a typed output format for stats
14833 - DOC: document the "show info typed" and "show stat typed" output formats
14834 - MINOR: cfgparse: warn when uid parameter is not a number
14835 - MINOR: cfgparse: warn when gid parameter is not a number
14836 - BUG/MINOR: standard: Avoid free of non-allocated pointer
14837 - BUG/MINOR: pattern: Avoid memory leak on out-of-memory condition
14838 - CLEANUP: http: fix a build warning introduced by a recent fix
14839 - BUG/MINOR: log: GMT offset not updated when entering/leaving DST
14840
Willy Tarreaucb928252015-12-20 23:33:18 +0100148412015/12/20 : 1.7-dev1
14842 - DOC: specify that stats socket doc (section 9.2) is in management
14843 - BUILD: install only relevant and existing documentation
14844 - CLEANUP: don't ignore debian/ directory if present
14845 - BUG/MINOR: dns: parsing error of some DNS response
14846 - BUG/MEDIUM: namespaces: don't fail if no namespace is used
14847 - BUG/MAJOR: ssl: free the generated SSL_CTX if the LRU cache is disabled
14848 - MEDIUM: dns: Don't use the ANY query type
14849 - BUILD: ssl: fix build error introduced in commit 7969a3 with OpenSSL < 1.0.0
14850 - DOC: fix a typo for a "deviceatlas" keyword
14851 - FIX: small typo in an example using the "Referer" header
14852 - MINOR: cli: ability to set per-server maxconn
14853 - DEBUG/MINOR: memory: add a build option to disable memory pools sharing
14854 - DEBUG/MEDIUM: memory: optionally protect free data in pools
14855 - DEBUG/MEDIUM: memory: add optional control pool memory operations
14856 - MEDIUM: memory: add accounting for failed allocations
14857 - BUG/MEDIUM: config: count memory limits on 64 bits, not 32
14858 - BUG/MAJOR: dns: first DNS response packet not matching queried hostname may lead to a loop
14859 - BUG/MINOR: dns: unable to parse CNAMEs response
14860 - BUG/MINOR: examples/haproxy.init: missing brace in quiet_check()
14861 - DOC: deviceatlas: more example use cases.
14862 - MINOR: config: allow IPv6 bracketed literals
14863 - BUG/BUILD: replace haproxy-systemd-wrapper with $(EXTRA) in install-bin.
14864 - BUILD: add Haiku as supported target.
14865 - BUG/MAJOR: http: don't requeue an idle connection that is already queued
14866 - DOC: typo on capture.res.hdr and capture.req.hdr
14867 - BUG/MINOR: dns: check for duplicate nameserver id in a resolvers section was missing
14868 - CLEANUP: use direction names in place of numeric values
14869 - BUG/MEDIUM: lua: sample fetches based on response doesn't work
14870 - MINOR: check: add agent-send server parameter
14871 - BUG/MINOR: http rule: http capture 'id' rule points to a non existing id
14872 - BUG/MINOR: server: check return value of fgets() in apply_server_state()
14873 - BUG/MINOR: acl: don't use record layer in req_ssl_ver
14874 - BUILD: freebsd: double declaration
14875 - BUG/MEDIUM: lua: clean output buffer
14876 - BUILD: check for libressl to be able to build against it
14877 - DOC: lua-api/index.rst small example fixes, spelling correction.
14878 - DOC: lua: architecture and first steps
14879 - DOC: relation between timeout http-request and option http-buffer-request
14880 - BUILD: Make deviceatlas require PCRE
14881 - BUG: http: do not abort keep-alive connections on server timeout
14882 - BUG/MEDIUM: http: switch the request channel to no-delay once done.
14883 - BUG/MINOR: lua: don't force-sslv3 LUA's SSL socket
14884 - BUILD/MINOR: http: proto_http.h needs sample.h
14885 - BUG/MEDIUM: http: don't enable auto-close on the response side
14886 - BUG/MEDIUM: stream: fix half-closed timeout handling
14887 - CLEANUP: compression: don't allocate DEFAULT_MAXZLIBMEM without USE_ZLIB
14888 - BUG/MEDIUM: cli: changing compression rate-limiting must require admin level
14889 - BUG/MEDIUM: sample: urlp can't match an empty value
14890 - BUILD: dumpstats: silencing warning for printf format specifier / time_t
14891 - CLEANUP: proxy: calloc call inverted arguments
14892 - MINOR: da: silent logging by default and displaying DeviceAtlas support if built.
14893 - BUG/MEDIUM: da: stop DeviceAtlas processing in the convertor if there is no input.
14894 - DOC: Edited 51Degrees section of README/
14895 - BUG/MEDIUM: checks: email-alert not working when declared in defaults
14896 - BUG/MINOR: checks: email-alert causes a segfault when an unknown mailers section is configured
14897 - BUG/MINOR: checks: typo in an email-alert error message
14898 - BUG/MINOR: tcpcheck: conf parsing error when no port configured on server and last rule is a CONNECT with no port
14899 - BUG/MINOR: tcpcheck: conf parsing error when no port configured on server and first rule(s) is (are) COMMENT
14900 - BUG/MEDIUM: http: fix http-reuse when frontend and backend differ
14901 - DOC: prefer using http-request/response over reqXXX/rspXXX directives
14902 - CLEANUP: haproxy: using _GNU_SOURCE instead of __USE_GNU macro.
14903 - MINOR: ssl: Added cert_key_and_chain struct
14904 - MEDIUM: ssl: Added support for creating SSL_CTX with multiple certs
14905 - MINOR: ssl: Added multi cert support for crt-list config keyword
14906 - MEDIUM: ssl: Added multi cert support for loading crt directories
14907 - MEDIUM: ssl: Added support for Multi-Cert OCSP Stapling
14908 - BUILD: ssl: set SSL_SOCK_NUM_KEYTYPES with openssl < 1.0.2
14909 - MINOR: config: make tune.recv_enough configurable
14910 - BUG/MEDIUM: config: properly adjust maxconn with nbproc when memmax is forced
14911 - DOC: ssl: Adding docs for Multi-Cert bundling
14912 - BUG/MEDIUM: peers: table entries learned from a remote are pushed to others after a random delay.
14913 - BUG/MEDIUM: peers: old stick table updates could be repushed.
14914 - MINOR: lua: service/applet can have access to the HTTP headers when a POST is received
14915 - REORG/MINOR: lua: convert boolean "int" to bitfield
14916 - BUG/MEDIUM: lua: Lua applets must not fetch samples using http_txn
14917 - BUG/MINOR: lua: Lua applets must not use http_txn
14918 - BUG/MEDIUM: lua: Forbid HTTP applets from being called from tcp rulesets
14919 - BUG/MAJOR: lua: Do not force the HTTP analysers in use-services
14920 - CLEANUP: lua: bad error messages
14921 - CONTRIB: initiate a debugging suite to make debugging easier
14922
Willy Tarreau991b4782015-10-13 21:48:10 +0200149232015/10/13 : 1.7-dev0
14924 - exact copy of 1.6.0
14925
Willy Tarreau844028b2015-10-13 18:52:22 +0200149262015/10/13 : 1.6.0
14927 - BUG/MINOR: Handle interactive mode in cli handler
14928 - DOC: global section missing parameters
14929 - DOC: backend section missing parameters
14930 - DOC: stats paramaters available in frontend
14931 - MINOR: lru: do not allocate useless memory in lru64_lookup
14932 - BUG/MINOR: http: Add OPTIONS in supported http methods (found by find_http_meth)
14933 - BUG/MINOR: ssl: fix management of the cache where forged certificates are stored
14934 - MINOR: ssl: Release Servers SSL context when HAProxy is shut down
14935 - MINOR: ssl: Read the file used to generate certificates in any order
14936 - MINOR: ssl: Add support for EC for the CA used to sign generated certificates
14937 - MINOR: ssl: Add callbacks to set DH/ECDH params for generated certificates
14938 - BUG/MEDIUM: logs: fix time zone offset format in RFC5424
14939 - BUILD: Fix the build on OSX (htonll/ntohll)
14940 - BUILD: enable build on Linux/s390x
14941 - BUG/MEDIUM: lua: direction test failed
14942 - MINOR: lua: fix a spelling error in some error messages
14943 - CLEANUP: cli: ensure we can never double-free error messages
14944 - BUG/MEDIUM: lua: force server-close mode on Lua services
14945 - MEDIUM: init: support more command line arguments after pid list
14946 - MEDIUM: init: support a list of files on the command line
14947 - MINOR: debug: enable memory poisonning to use byte 0
14948 - BUILD: ssl: fix build error introduced by recent commit
14949 - BUG/MINOR: config: make the stats socket pass the correct proxy to the parsers
14950 - MEDIUM: server: implement TCP_USER_TIMEOUT on the server
14951 - DOC: mention the "namespace" options for bind and server lines
14952 - DOC: add the "management" documentation
14953 - DOC: move the stats socket documentation from config to management
14954 - MINOR: examples: update haproxy.spec to mention new docs
14955 - DOC: mention management.txt in README
14956 - DOC: remove haproxy-{en,fr}.txt
14957 - BUILD: properly report when USE_ZLIB and USE_SLZ are used together
14958 - MINOR: init: report use of libslz instead of "no compression"
14959 - CLEANUP: examples: remove some obsolete and confusing files
14960 - CLEANUP: examples: remove obsolete configuration file samples
14961 - CLEANUP: examples: fix the example file content-sw-sample.cfg
14962 - CLEANUP: examples: update sample file option-http_proxy.cfg
14963 - CLEANUP: examples: update sample file ssl.cfg
14964 - CLEANUP: tests: move a test file from examples/ to tests/
14965 - CLEANUP: examples: shut up warnings in transparent proxy example
14966 - CLEANUP: tests: removed completely obsolete test files
14967 - DOC: update ROADMAP to remove what was done in 1.6
14968 - BUG/MEDIUM: pattern: fixup use_after_free in the pat_ref_delete_by_id
14969
Willy Tarreau8c1ad712015-10-06 12:13:56 +0200149702015/10/06 : 1.6-dev7
14971 - MINOR: cli: Dump all resolvers stats if no resolver section is given
14972 - BUG: config: external-check command validation is checking for incorrect arguments.
14973 - DOC: documentation format cleanups
14974 - DOC: lua: few typos.
14975 - BUG/MEDIUM: str2ip: make getaddrinfo() consider local address selection policy
14976 - BUG/MEDIUM: logs: segfault writing to log from Lua
14977 - DOC: fix lua use-service example
14978 - MINOR: payload: add support for tls session ticket ext
14979 - MINOR: lua: remove the run flag
14980 - MEDIUM: lua: change the timeout execution
14981 - MINOR: lua: rename the tune.lua.applet-timeout
14982 - DOC: lua: update Lua doc
14983 - DOC: lua: update doc according with the last Lua changes
14984 - MINOR: http/tcp: fill the avalaible actions
14985 - DOC: reorder misplaced res.ssl_hello_type in the doc
14986 - BUG/MINOR: tcp: make silent-drop always force a TCP reset
14987 - CLEANUP: tcp: silent-drop: only drain the connection when quick-ack is disabled
14988 - BUILD: tcp: use IPPROTO_IP when SOL_IP is not available
14989 - BUILD: server: fix build warnings introduced by load-server-state
14990 - BUG/MEDIUM: server: fix misuse of format string in load-server-state's warnings
14991
Willy Tarreaue7ae6562015-09-28 23:46:27 +0200149922015/09/28 : 1.6-dev6
14993 - BUG/MAJOR: can't enable a server through the stat socket
14994 - MINOR: server: Macro definition for server-state
14995 - MINOR: cli: new stats socket command: show servers state
14996 - DOC: stats socket command: show servers state
14997 - MINOR: config: new global directive server-state-base
14998 - DOC: global directive server-state-base
14999 - MINOR: config: new global section directive: server-state-file
15000 - DOC: new global directive: server-state-file
15001 - MINOR: config: new backend directives: load-server-state-from-file and server-state-file-name
15002 - DOC: load-server-state-from-file
15003 - MINOR: init: server state loaded from file
15004 - MINOR: server: startup slowstart task when using seamless reload of HAProxy
15005 - MINOR: cli: new stats socket command: show backend
15006 - DOC: servers state seamless reload example
15007 - BUG: dns: can't connect UDP socket on FreeBSD
15008 - MINOR: cfgparse: New function cfg_unregister_sections()
15009 - MINOR: chunk: New function free_trash_buffers()
15010 - BUG/MEDIUM: main: Freeing a bunch of static pointers
15011 - MINOR: proto_http: Externalisation of previously internal functions
15012 - MINOR: global: Few new struct fields for da module
15013 - MAJOR: da: Update of the DeviceAtlas API module
15014 - DOC: DeviceAtlas new keywords
15015 - DOC: README: DeviceAtlas sample configuration updates
15016 - MEDIUM: log: replace sendto() with sendmsg() in __send_log()
15017 - MEDIUM: log: use a separate buffer for the header and for the message
15018 - MEDIUM: logs: remove the hostname, tag and pid part from the logheader
15019 - MEDIUM: logs: add support for RFC5424 header format per logger
15020 - MEDIUM: logs: add a new RFC5424 log-format for the structured-data
15021 - DOC: mention support for the RFC5424 syslog message format
15022 - MEDIUM: logs: have global.log_send_hostname not contain the trailing space
15023 - MEDIUM: logs: pass the trailing "\n" as an iovec
15024 - BUG/MEDIUM: peers: some table updates are randomly not pushed.
15025 - BUG/MEDIUM: peers: same table updates re-pushed after a re-connect
15026 - BUG/MINOR: fct peer_prepare_ackmsg should not use trash.
15027 - MINOR: http: made CHECK_HTTP_MESSAGE_FIRST accessible to other functions
15028 - MINOR: global: Added new fields for 51Degrees device detection
15029 - DOC: Added more explanation for 51Degrees V3.2
15030 - BUILD: Changed 51Degrees option to support V3.2
15031 - MAJOR: 51d: Upgraded to support 51Degrees V3.2 and new features
15032 - MINOR: 51d: Improved string handling for LRU cache
15033 - DOC: add references to rise/fall for the fastinter explanation
15034 - MINOR: support cpu-map feature through the compile option USE_CPU_AFFINITY on FreeBSD
15035 - BUG/MAJOR: lua: potential unexpected aborts()
15036 - BUG/MINOR: lua: breaks the log message if his size exceed one buffer
15037 - MINOR: action: add private configuration
15038 - MINOR: action: add reference to the original keywork matched for the called parser.
15039 - MINOR: lua: change actions registration
15040 - MEDIUM: proto_http: smp_prefetch_http initialize txn
15041 - MINOR: channel: rename function chn_sess to chn_strm
15042 - CLEANUP: lua: align defines
15043 - MINOR: http: export http_get_path() function
15044 - MINOR: http: export the get_reason() function
15045 - MINOR: http: export function http_msg_analyzer()
15046 - MINOR: http: split initialization
15047 - MINOR: lua: reset pointer after use
15048 - MINOR: lua: identify userdata objects
15049 - MEDIUM: lua: use the function lua_rawset in place of lua_settable
15050 - BUG/MAJOR: lua: segfault after the channel data is modified by some Lua action.
15051 - CLEANUP: lua: use calloc in place of malloc
15052 - BUG/MEDIUM: lua: longjmp function must be unregistered
15053 - BUG/MEDIUM: lua: forces a garbage collection
15054 - BUG/MEDIUM: lua: wakeup task on bad conditions
15055 - MINOR: standard: avoid DNS resolution from the function str2sa_range()
15056 - MINOR: lua: extend socket address to support non-IP families
15057 - MINOR: lua/applet: the cosocket applet should use appctx_wakeup in place of task_wakeup
15058 - BUG/MEDIUM: lua: socket destroy before reading pending data
15059 - MEDIUM: lua: change the GC policy
15060 - OPTIM/MEDIUM: lua: executes the garbage collector only when using cosocket
15061 - BUG/MEDIUM: lua: don't reset undesired flags in hlua_ctx_resume
15062 - MINOR: applet: add init function
15063 - MINOR: applet: add an execution timeout
15064 - MINOR: stream/applet: add use-service action
15065 - MINOR: lua: add AppletTCP class and service
15066 - MINOR: lua: add AppletHTTP class and service
15067 - DOC: lua: some documentation update
15068 - DOC: add the documentation about internal circular lists
15069 - DOC: add a CONTRIBUTING file
15070 - DOC: add a MAINTAINERS file
15071 - BUG/MAJOR: peers: fix a crash when stopping peers on unbound processes
15072 - DOC: update coding-style to reference checkpatch.pl
15073 - BUG/MEDIUM: stick-tables: fix double-decrement of tracked entries
15074 - BUG/MINOR: args: add name for ARGT_VAR
15075 - DOC: add more entries to MAINTAINERS
15076 - DOC: add more entries to MAINTAINERS
15077 - CLEANUP: stream-int: remove obsolete function si_applet_call()
15078 - BUG/MAJOR: cli: do not dereference strm_li()->proto->name
15079 - BUG/MEDIUM: http: do not dereference strm_li(stream)
15080 - BUG/MEDIUM: proxy: do not dereference strm_li(stream)
15081 - BUG/MEDIUM: stream: do not dereference strm_li(stream)
15082 - MINOR: stream-int: use si_release_endpoint() to close idle conns
15083 - BUG/MEDIUM: payload: make req.payload and payload_lv aware of dynamic buffers
15084 - BUG/MEDIUM: acl: always accept match "found"
15085 - MINOR: applet: rename applet_runq to applet_active_queue
15086 - BUG/MAJOR: applet: use a separate run queue to maintain list integrity
15087 - MEDIUM: stream-int: split stream_int_update_conn() into si- and conn-specific parts
15088 - MINOR: stream-int: implement a new stream_int_update() function
15089 - MEDIUM: stream-int: factor out the stream update functions
15090 - MEDIUM: stream-int: call stream_int_update() from si_update()
15091 - MINOR: stream-int: export stream_int_update_*
15092 - MINOR: stream-int: move the applet_pause call out of the stream updates
15093 - MEDIUM: stream-int: clean up the conditions to enable reading in si_conn_wake_cb
15094 - MINOR: stream-int: implement the stream_int_notify() function
15095 - MEDIUM: stream-int: use the same stream notification function for applets and conns
15096 - MEDIUM: stream-int: completely remove stream_int_update_embedded()
15097 - MINOR: stream-int: rename si_applet_done() to si_applet_wake_cb()
15098 - BUG/MEDIUM: applet: fix reporting of broken write situation
15099 - BUG/MINOR: stats: do not call cli_release_handler 3 times
15100 - BUG/MEDIUM: cli: properly handle closed output
15101 - MINOR: cli: do not call the release handler on internal error.
15102 - BUG/MEDIUM: stream-int: avoid double-call to applet->release
15103 - DEBUG: add p_malloc() to return a poisonned memory area
15104 - CLEANUP: lua: remove unneeded memset(0) after calloc()
15105 - MINOR: lua: use the proper applet wakeup mechanism
15106 - BUG/MEDIUM: lua: better fix for the protocol check
15107 - BUG/MEDIUM: lua: properly set the target on the connection
15108 - MEDIUM: actions: pass a new "flags" argument to custom actions
15109 - MEDIUM: actions: add new flag ACT_FLAG_FINAL to notify about last call
15110 - MEDIUM: http: pass ACT_FLAG_FINAL to custom actions
15111 - MEDIUM: lua: only allow actions to yield if not in a final call
15112 - DOC: clarify how to make use of abstract sockets in socat
15113 - CLEANUP: config: make the errorloc/errorfile messages less confusing
15114 - MEDIUM: action: add a new flag ACT_FLAG_FIRST
15115 - BUG/MINOR: config: check that tune.bufsize is always positive
15116 - MEDIUM: config: set tune.maxrewrite to 1024 by default
15117 - DOC: add David Carlier as maintainer of da.c
15118 - DOC: fix some broken unexpected unicode chars in the Lua doc.
15119 - BUG/MEDIUM: proxy: ignore stopped peers
15120 - BUG/MEDIUM: proxy: do not wake stopped proxies' tasks during soft_stop()
15121 - MEDIUM: init: completely deallocate unused peers
15122 - BUG/MEDIUM: tcp: fix inverted condition to call custom actions
15123 - DOC: remove outdated actions lists on tcp-request/response
15124 - MEDIUM: tcp: add new tcp action "silent-drop"
15125 - DOC: add URLs to optional libraries in the README
15126
Willy Tarreaua02e8a62015-09-14 12:23:10 +0200151272015/09/14 : 1.6-dev5
15128 - MINOR: dns: dns_resolution structure update: time_t to unsigned int
15129 - BUG/MEDIUM: dns: DNS resolution doesn't start
15130 - BUG/MAJOR: dns: dns client resolution infinite loop
15131 - MINOR: dns: coding style update
15132 - MINOR: dns: new bitmasks to use against DNS flags
15133 - MINOR: dns: dns_nameserver structure update: new counter for truncated response
15134 - MINOR: dns: New DNS response analysis code: DNS_RESP_TRUNCATED
15135 - MEDIUM: dns: handling of truncated response
15136 - MINOR: DNS client query type failover management
15137 - MINOR: dns: no expected DNS record type found
15138 - MINOR: dns: new flag to report that no IP can be found in a DNS response packet
15139 - BUG/MINOR: DNS request retry counter used for retry only
15140 - DOC: DNS documentation updated
15141 - MEDIUM: actions: remove ACTION_STOP
15142 - BUG/MEDIUM: lua: outgoing connection was broken since 1.6-dev2 (bis)
15143 - BUG/MINOR: lua: last log character truncated.
15144 - CLEANUP: typo: bad indent
15145 - CLEANUP: actions: missplaced includes
15146 - MINOR: build: missing header
15147 - CLEANUP: lua: Merge log functions
15148 - BUG/MAJOR: http: don't manipulate the server connection if it's killed
15149 - BUG/MINOR: http: remove stupid HTTP_METH_NONE entry
15150 - BUG/MAJOR: http: don't call http_send_name_header() after an error
15151 - MEDIUM: tools: make str2sa_range() optionally return the FQDN
15152 - BUG/MINOR: tools: make str2sa_range() report unresolvable addresses
15153 - BUG/MEDIUM: dns: use the correct server hostname when resolving
15154
Willy Tarreau61d301f2015-08-30 00:17:17 +0200151552015/08/30 : 1.6-dev4
15156 - MINOR: log: Add log-format variable %HQ, to log HTTP query strings
15157 - DOC: typo in 'redirect', 302 code meaning
15158 - DOC: typos in tcp-check expect examples
15159 - DOC: resolve-prefer default value and default-server update
15160 - MINOR: DNS counters: increment valid counter
15161 - BUG/MEDIUM: DNS resolution response parsing broken
15162 - MINOR: server: add new SRV_ADMF_CMAINT flag
15163 - MINOR: server SRV_ADMF_CMAINT flag doesn't imply SRV_ADMF_FMAINT
15164 - BUG/MEDIUM: dns: wrong first time DNS resolution
15165 - BUG/MEDIUM: lua: Lua tasks fail to start.
15166 - BUILD: add USE_LUA to BUILD_OPTIONS when it's used
15167 - DOC/MINOR: fix OpenBSD versions where haproxy works
15168 - MINOR: 51d: unable to start haproxy without "51degrees-data-file"
15169 - BUG/MEDIUM: peers: fix wrong message id on stick table updates acknowledgement.
15170 - BUG/MAJOR: peers: fix current table pointer not re-initialized on session release.
15171 - BUILD: ssl: Allow building against libssl without SSLv3.
15172 - DOC: clarify some points about SSL and the proxy protocol
15173 - DOC: mention support for RFC 5077 TLS Ticket extension in starter guide
15174 - BUG/MEDIUM: mailer: DATA part must be terminated with <CRLF>.<CRLF>
15175 - DOC: match several lua configuration option names to those implemented in code
15176 - MINOR cfgparse: Correct the mailer warning text to show the right names to the user
15177 - BUG/MINOR: ssl: TLS Ticket Key rotation broken via socket command
15178 - MINOR: stream: initialize the current_rule field to NULL on stream init
15179 - BUG/MEDIUM: lua: timeout error with converters, wrapper and actions.
15180 - CLEANUP: proto_http: remove useless initialisation
15181 - CLEANUP: http/tcp actions: remove the scope member
15182 - BUG/MINOR: proto_tcp: custom action continue is ignored
15183 - MINOR: proto_tcp: add session in the action prototype
15184 - MINOR: vars: reduce the code size of some wrappers
15185 - MINOR: Move http method enum from proto_http to sample
15186 - MINOR: sample: Add ipv6 to ipv4 and sint to ipv6 casts
15187 - MINOR: sample/proto_tcp: export "smp_fetch_src"
15188 - MEDIUM: cli: rely on the map's output type instead of the sample type
15189 - BUG/MEDIUM: stream: The stream doen't inherit SC from the session
15190 - BUG/MEDIUM: vars: segfault during the configuration parsing
15191 - BUG/MEDIUM: stick-tables: refcount error after copying SC for the session to the stream
15192 - BUG/MEDIUM: lua: bad error processing
15193 - MINOR: samples: rename a struct from sample_storage to sample_data
15194 - MINOR: samples: rename some struct member from "smp" to "data"
15195 - MEDIUM: samples: Use the "struct sample_data" in the "struct sample"
15196 - MINOR: samples: extract the anonymous union and create the union sample_value
15197 - MINOR: samples: rename union from "data" to "u"
15198 - MEDIUM: 51degrees: Adapt the 51Degrees library
15199 - MINOR: samples: data assignation simplification
15200 - MEDIUM: pattern/map: Maps can returns various types
15201 - MINOR: map: The map can return IPv4 and IPv6
15202 - MEDIUM: actions: Merge (http|tcp)-(request|reponse) action structs
15203 - MINOR: actions: Remove the data opaque pointer
15204 - MINOR: lua: use the hlua_rule type in place of opaque type
15205 - MINOR: vars: use the vars types as argument in place of opaque type
15206 - MINOR: proto_http: use an "expr" type in place of generic opaque type.
15207 - MINOR: proto_http: replace generic opaque types by real used types for the actions on thr request line
15208 - MINOR: proto_http: replace generic opaque types by real used types in "http_capture"
15209 - MINOR: proto_http: replace generic opaque types by real used types in "http_capture" by id
15210 - MEDIUM: track-sc: Move the track-sc configuration storage in the union
15211 - MEDIUM: capture: Move the capture configuration storage in the union
15212 - MINOR: actions: add "from" information
15213 - MINOR: actions: remove the mark indicating the last entry in enum
15214 - MINOR: actions: Declare all the embedded actions in the same header file
15215 - MINOR: actions: change actions names
15216 - MEDIUM: actions: Add standard return code for the action API
15217 - MEDIUM: actions: Merge (http|tcp)-(request|reponse) keywords structs
15218 - MINOR: proto_tcp: proto_tcp.h is now useles
15219 - MINOR: actions: mutualise the action keyword lookup
15220 - MEDIUM: actions: Normalize the return code of the configuration parsers
15221 - MINOR: actions: Remove wrappers
15222 - MAJOR: stick-tables: use sample types in place of dedicated types
15223 - MEDIUM: stick-tables: use the sample type names
15224 - MAJOR: stick-tables: remove key storage from the key struct
15225 - MEDIUM: stick-tables: Add GPT0 in the stick tables
15226 - MINOR: stick-tables: Add GPT0 access
15227 - MINOR: stick-tables: Add GPC0 actions
15228 - BUG/MEDIUM: lua: the lua fucntion Channel:close() causes a segfault
15229 - DOC: ssl: missing LF
15230 - MINOR: lua: add core.done() function
15231 - DOC: fix function name
15232 - BUG/MINOR: lua: in some case a sample may remain undefined
15233 - DOC: fix "http_action_set_req_line()" comments
15234 - MINOR: http: Action for manipulating the returned status code.
15235 - MEDIUM: lua: turns txn:close into txn:done
15236 - BUG/MEDIUM: lua: cannot process more Lua hooks after a "done()" function call
15237 - BUILD: link with libdl if needed for Lua support
15238 - CLEANUP: backend: factor out objt_server() in connect_server()
15239 - MEDIUM: backend: don't call si_alloc_conn() when we reuse a valid connection
15240 - MEDIUM: stream-int: simplify si_alloc_conn()
15241 - MINOR: stream-int: add new function si_detach_endpoint()
15242 - MINOR: server: add a list of private idle connections
15243 - MINOR: connection: add a new list member in the connection struct
15244 - MEDIUM: stream-int: queue idle connections at the server
15245 - MINOR: stream-int: make si_idle_conn() only accept valid connections
15246 - MINOR: server: add a list of already used idle connections
15247 - MINOR: connection: add a new flag CO_FL_PRIVATE
15248 - MINOR: config: add new setting "http-reuse"
15249 - MAJOR: backend: initial work towards connection reuse
15250 - MAJOR: backend: improve the connection reuse mechanism
15251 - MEDIUM: backend: implement "http-reuse safe"
15252 - MINOR: server: add a list of safe, already reused idle connections
15253 - MEDIUM: backend: add the "http-reuse aggressive" strategy
15254 - DOC: document the new http-reuse directive
15255 - DOC: internals: document next steps for HTTP connection reuse
15256 - DOC: mention that %ms is left-padded with zeroes.
15257 - MINOR: init: indicate to check 'bind' lines when no listeners were found.
15258 - MAJOR: http: remove references to appsession
15259 - CLEANUP: config: remove appsession initialization
15260 - CLEANUP: appsession: remove appsession.c and sessionhash.c
15261 - CLEANUP: tests: remove sessionhash_test.c and test-cookie-appsess.cfg
15262 - CLEANUP: proxy: remove last references to appsession
15263 - CLEANUP: appsession: remove the last include files
15264 - DOC: remove documentation about appsession
15265 - CLEANUP: .gitignore: ignore more test files
15266 - CLEANUP: .gitignore: finally ignore everything but what is known.
15267 - MEDIUM: config: emit a warning on a frontend without listener
15268 - DOC: add doc/internals/entities-v2.txt
15269 - DOC: add doc/linux-syn-cookies.txt
15270 - DOC: add design thoughts on HTTP/2
15271 - DOC: add some thoughts on connection sharing for HTTP/2
15272 - DOC: add design thoughts on dynamic buffer allocation
15273 - BUG/MEDIUM: counters: ensure that src_{inc,clr}_gpc0 creates a missing entry
15274 - DOC: add new file intro.txt
15275 - MAJOR: tproxy: remove support for cttproxy
15276 - BUG/MEDIUM: lua: outgoing connection was broken since 1.6-dev2
15277 - DOC: lua: replace txn:close with txn:done in lua-api
15278 - DOC: intro: minor updates and fixes
15279 - DOC: intro: fix too long line.
15280 - DOC: fix example of http-request using ssl_fc_session_id
15281 - BUG/MEDIUM: lua: txn:done() still causes a segfault in TCP mode
15282 - CLEANUP: lua: fix some indent issues
15283 - BUG/MEDIUM: lua: fix a segfault in txn:done() if called twice
15284 - DOC: lua: mention than txn:close was renamed txn:done.
15285
Willy Tarreau50bdda62015-07-22 17:32:56 +0200152862015/07/22 : 1.6-dev3
15287 - CLEANUP: sample: generalize sample_fetch_string() as sample_fetch_as_type()
15288 - MEDIUM: http: Add new 'set-src' option to http-request
15289 - DOC usesrc root privileges requirments
15290 - BUG/MINOR: dns: wrong time unit for some DNS default parameters
15291 - MINOR: proxy: bit field for proxy_find_best_match diff status
15292 - MINOR: server: new server flag: SRV_F_FORCED_ID
15293 - MINOR: server: server_find functions: id, name, best_match
15294 - DOC: dns: fix chapters syntax
15295 - BUILD/MINOR: tools: rename popcount to my_popcountl
15296 - BUILD: add netbsd TARGET
15297 - MEDIUM: 51Degrees code refactoring and cleanup
15298 - MEDIUM: 51d: add LRU-based cache on User-Agent string detection
15299 - DOC: add notes about the "51degrees-cache-size" parameter
15300 - BUG/MEDIUM: 51d: possible incorrect operations on smp->data.str.str
15301 - BUG/MAJOR: connection: fix TLV offset calculation for proxy protocol v2 parsing
15302 - MINOR: Add sample fetch to detect Supported Elliptic Curves Extension
15303 - BUG/MINOR: payload: Add volatile flag to smp_fetch_req_ssl_ec_ext
15304 - BUG/MINOR: lua: type error in the arguments wrapper
15305 - CLEANUP: vars: remove unused struct
15306 - BUG/MINOR: http/sample: gmtime/localtime can fail
15307 - MINOR: standard: add 64 bits conversion functions
15308 - MAJOR: sample: converts uint and sint in 64 bits signed integer
15309 - MAJOR: arg: converts uint and sint in sint
15310 - MEDIUM: sample: switch to saturated arithmetic
15311 - MINOR: vars: returns variable content
15312 - MEDIUM: vars/sample: operators can use variables as parameter
15313 - BUG/MINOR: ssl: fix smp_fetch_ssl_fc_session_id
15314 - BUILD/MINOR: lua: fix a harmless build warning
15315 - BUILD/MINOR: stats: fix build warning due to condition always true
15316 - BUG/MAJOR: lru: fix unconditional call to free due to unexpected semi-colon
15317 - BUG/MEDIUM: logs: fix improper systematic use of quotes with a few tags
15318 - BUILD/MINOR: lua: ensure that hlua_ctx_destroy is properly defined
15319 - BUG/MEDIUM: lru: fix possible memory leak when ->free() is used
15320 - MINOR: vars: make the accounting not depend on the stream
15321 - MEDIUM: vars: move the session variables to the session, not the stream
15322 - BUG/MEDIUM: vars: do not freeze the connection when the expression cannot be fetched
15323 - BUG/MAJOR: buffers: make the buffer_slow_realign() function respect output data
15324 - BUG/MAJOR: tcp: tcp rulesets were still broken
15325 - MINOR: stats: improve compression stats reporting
15326 - MINOR: ssl: make self-generated certs also work with raw IPv6 addresses
15327 - CLEANUP: ssl: make ssl_sock_generated_cert_serial() take a const
15328 - CLEANUP: ssl: make ssl_sock_generate_certificate() use ssl_sock_generated_cert_serial()
15329 - BUG/MINOR: log: missing some ARGC_* entries in fmt_directives()
15330 - MINOR: args: add new context for servers
15331 - MINOR: stream: maintain consistence between channel_forward and HTTP forward
15332 - MINOR: ssl: provide ia function to set the SNI extension on a connection
15333 - MEDIUM: ssl: add sni support on the server lines
15334 - CLEANUP: stream: remove a useless call to si_detach()
15335 - CLEANUP: stream-int: fix a few outdated comments about stream_int_register_handler()
15336 - CLEANUP: stream-int: remove stream_int_unregister_handler() and si_detach()
15337 - MINOR: stream-int: only use si_release_endpoint() to release a connection
15338 - MINOR: standard: provide htonll() and ntohll()
15339 - CLEANUP/MINOR: dns: dns_str_to_dn_label() only needs a const char
15340 - BUG/MAJOR: dns: fix the length of the string to be copied
15341
Willy Tarreauad90f0d2015-06-17 15:53:25 +0200153422015/06/17 : 1.6-dev2
15343 - BUG/MINOR: ssl: Display correct filename in error message
15344 - MEDIUM: logs: Add HTTP request-line log format directives
15345 - BUG/MEDIUM: check: tcpcheck regression introduced by e16c1b3f
15346 - BUG/MINOR: check: fix tcpcheck error message
15347 - MINOR: use an int instead of calling tcpcheck_get_step_id
15348 - MINOR: tcpcheck_rule structure update
15349 - MINOR: include comment in tcpcheck error log
15350 - DOC: tcpcheck comment documentation
15351 - MEDIUM: server: add support for changing a server's address
15352 - MEDIUM: server: change server ip address from stats socket
15353 - MEDIUM: protocol: add minimalist UDP protocol client
15354 - MEDIUM: dns: implement a DNS resolver
15355 - MAJOR: server: add DNS-based server name resolution
15356 - DOC: server name resolution + proto DNS
15357 - MINOR: dns: add DNS statistics
15358 - MEDIUM: http: configurable http result codes for http-request deny
15359 - BUILD: Compile clean when debug options defined
15360 - MINOR: lru: Add the possibility to free data when an item is removed
15361 - MINOR: lru: Add lru64_lookup function
15362 - MEDIUM: ssl: Add options to forge SSL certificates
15363 - MINOR: ssl: Export functions to manipulate generated certificates
15364 - MEDIUM: config: add DeviceAtlas global keywords
15365 - MEDIUM: global: add the DeviceAtlas required elements to struct global
15366 - MEDIUM: sample: add the da-csv converter
15367 - MEDIUM: init: DeviceAtlas initialization
15368 - BUILD: Makefile: add options to build with DeviceAtlas
15369 - DOC: README: explain how to build with DeviceAtlas
15370 - BUG/MEDIUM: http: fix the url_param fetch
15371 - BUG/MEDIUM: init: segfault if global._51d_property_names is not initialized
15372 - MAJOR: peers: peers protocol version 2.0
15373 - MINOR: peers: avoid re-scheduling of pending stick-table's updates still not pushed.
15374 - MEDIUM: peers: re-schedule stick-table's entry for sync when data is modified.
15375 - MEDIUM: peers: support of any stick-table data-types for sync
15376 - BUG/MAJOR: sample: regression on sample cast to stick table types.
15377 - CLEANUP: deinit: remove codes for cleaning p->block_rules
15378 - DOC: Fix L4TOUT typo in documentation
15379 - DOC: set-log-level in Logging section preamble
15380 - BUG/MEDIUM: compat: fix segfault on FreeBSD
15381 - MEDIUM: check: include server address and port in the send-state header
15382 - MEDIUM: backend: Allow redispatch on retry intervals
15383 - MINOR: Add TLS ticket keys reference and use it in the listener struct
15384 - MEDIUM: Add support for updating TLS ticket keys via socket
15385 - DOC: Document new socket commands "show tls-keys" and "set ssl tls-key"
15386 - MINOR: Add sample fetch which identifies if the SSL session has been resumed
15387 - DOC: Update doc about weight, act and bck fields in the statistics
15388 - BUG/MEDIUM: ssl: fix tune.ssl.default-dh-param value being overwritten
15389 - MINOR: ssl: add a destructor to free allocated SSL ressources
15390 - MEDIUM: ssl: add the possibility to use a global DH parameters file
15391 - MEDIUM: ssl: replace standards DH groups with custom ones
15392 - MEDIUM: stats: Add enum srv_stats_state
15393 - MEDIUM: stats: Separate server state and colour in stats
15394 - MEDIUM: stats: Only report drain state in stats if server has SRV_ADMF_DRAIN set
15395 - MEDIUM: stats: Differentiate between DRAIN and DRAIN (agent)
15396 - MEDIUM: Lower priority of email alerts for log-health-checks messages
15397 - MEDIUM: Send email alerts when servers are marked as UP or enter the drain state
15398 - MEDIUM: Document when email-alerts are sent
15399 - BUG/MEDIUM: lua: bad argument number in analyser and in error message
15400 - MEDIUM: lua: automatically converts strings in proxy, tables, server and ip
15401 - BUG/MINOR: utf8: remove compilator warning
15402 - MEDIUM: map: uses HAProxy facilities to store default value
15403 - BUG/MINOR: lua: error in detection of mandatory arguments
15404 - BUG/MINOR: lua: set current proxy as default value if it is possible
15405 - BUG/MEDIUM: http: the action set-{method|path|query|uri} doesn't run.
15406 - BUG/MEDIUM: lua: undetected infinite loop
15407 - BUG/MAJOR: http: don't read past buffer's end in http_replace_value
15408 - BUG/MEDIUM: http: the function "(req|res)-replace-value" doesn't respect the HTTP syntax
15409 - MEDIUM/CLEANUP: http: rewrite and lighten http_transform_header() prototype
15410 - BUILD: lua: it miss the '-ldl' directive
15411 - MEDIUM: http: allows 'R' and 'S' in the protocol alphabet
15412 - MINOR: http: split the function http_action_set_req_line() in two parts
15413 - MINOR: http: split http_transform_header() function in two parts.
15414 - MINOR: http: export function inet_set_tos()
15415 - MINOR: lua: txn: add function set_(loglevel|tos|mark)
15416 - MINOR: lua: create and register HTTP class
15417 - DOC: lua: fix some typos
15418 - MINOR: lua: add log functions
15419 - BUG/MINOR: lua: Fix SSL initialisation
15420 - DOC: lua: some fixes
15421 - MINOR: lua: (req|res)_get_headers return more than one header value
15422 - MINOR: lua: map system integration in Lua
15423 - BUG/MEDIUM: http: functions set-{path,query,method,uri} breaks the HTTP parser
15424 - MINOR: sample: add url_dec converter
15425 - MEDIUM: sample: fill the struct sample with the session, proxy and stream pointers
15426 - MEDIUM: sample change the prototype of sample-fetches and converters functions
15427 - MINOR: sample: fill the struct sample with the options.
15428 - MEDIUM: sample: change the prototype of sample-fetches functions
15429 - MINOR: http: split the url_param in two parts
15430 - CLEANUP: http: bad indentation
15431 - MINOR: http: add body_param fetch
15432 - MEDIUM: http: url-encoded parsing function can run throught wrapped buffer
15433 - DOC: http: req.body_param documentation
15434 - MINOR: proxy: custom capture declaration
15435 - MINOR: capture: add two "capture" converters
15436 - MEDIUM: capture: Allow capture with slot identifier
15437 - MINOR: http: add array of generic pointers in http_res_rules
15438 - MEDIUM: capture: adds http-response capture
15439 - MINOR: common: escape CSV strings
15440 - MEDIUM: stats: escape some strings in the CSV dump
15441 - MINOR: tcp: add custom actions that can continue tcp-(request|response) processing
15442 - MINOR: lua: Lua tcp action are not final action
15443 - DOC: lua: schematics about lua socket organization
15444 - BUG/MINOR: debug: display (null) in place of "meth"
15445 - DOC: mention the "lua action" in documentation
15446 - MINOR: standard: add function that converts signed int to a string
15447 - BUG/MINOR: sample: wrong conversion of signed values
15448 - MEDIUM: sample: Add type any
15449 - MINOR: debug: add a special converter which display its input sample content.
15450 - MINOR: tcp: increase the opaque data array
15451 - MINOR: tcp/http/conf: extends the keyword registration options
15452 - MINOR: build: fix build dependency
15453 - MEDIUM: vars: adds support of variables
15454 - MINOR: vars: adds get and set functions
15455 - MINOR: lua: Variable access
15456 - MINOR: samples: add samples which returns constants
15457 - BUG/MINOR: vars/compil: fix some warnings
15458 - BUILD: add 51degrees options to makefile.
15459 - MINOR: global: add several 51Degrees members to global
15460 - MINOR: config: add 51Degrees config parsing.
15461 - MINOR: init: add 51Degrees initialisation code
15462 - MEDIUM: sample: add fiftyone_degrees converter.
15463 - MEDIUM: deinit: add cleanup for 51Degrees to deinit
15464 - MEDIUM: sample: add trie support to 51Degrees
15465 - DOC: add 51Degrees notes to configuration.txt.
15466 - DOC: add build indications for 51Degrees to README.
15467 - MEDIUM: cfgparse: introduce weak and strong quoting
15468 - BUG/MEDIUM: cfgparse: incorrect memmove in quotes management
15469 - MINOR: cfgparse: remove line size limitation
15470 - MEDIUM: cfgparse: expand environment variables
15471 - BUG/MINOR: cfgparse: fix typo in 'option httplog' error message
15472 - BUG/MEDIUM: cfgparse: segfault when userlist is misused
15473 - CLEANUP: cfgparse: remove reference to 'ruleset' section
15474 - MEDIUM: cfgparse: check section maximum number of arguments
15475 - MEDIUM: cfgparse: max arguments check in the global section
15476 - MEDIUM: cfgparse: check max arguments in the proxies sections
15477 - CLEANUP: stream-int: remove a redundant clearing of the linger_risk flag
15478 - MINOR: connection: make conn_sock_shutw() actually perform the shutdown() call
15479 - MINOR: stream-int: use conn_sock_shutw() to shutdown a connection
15480 - MINOR: connection: perform the call to xprt->shutw() in conn_data_shutw()
15481 - MEDIUM: stream-int: replace xprt->shutw calls with conn_data_shutw()
15482 - MINOR: checks: use conn_data_shutw_hard() instead of call via xprt
15483 - MINOR: connection: implement conn_sock_send()
15484 - MEDIUM: stream-int: make conn_si_send_proxy() use conn_sock_send()
15485 - MEDIUM: connection: make conn_drain() perform more controls
15486 - REORG: connection: move conn_drain() to connection.c and rename it
15487 - CLEANUP: stream-int: remove inclusion of fd.h that is not used anymore
15488 - MEDIUM: channel: don't always set CF_WAKE_WRITE on bi_put*
15489 - CLEANUP: lua: don't use si_ic/si_oc on known stream-ints
15490 - BUG/MEDIUM: peers: correctly configure the client timeout
15491 - MINOR: peers: centralize configuration of the peers frontend
15492 - MINOR: proxy: store the default target into the frontend's configuration
15493 - MEDIUM: stats: use frontend_accept() as the accept function
15494 - MEDIUM: peers: use frontend_accept() instead of peer_accept()
15495 - CLEANUP: listeners: remove unused timeout
15496 - MEDIUM: listener: store the default target per listener
15497 - BUILD: fix automatic inclusion of libdl.
15498 - MEDIUM: lua: implement a simple memory allocator
15499 - MEDIUM: compression: postpone buffer adjustments after compression
15500 - MEDIUM: compression: don't send leading zeroes with chunk size
15501 - BUG/MINOR: compression: consider the expansion factor in init
15502 - MINOR: http: check the algo name "identity" instead of the function pointer
15503 - CLEANUP: compression: statify all algo-specific functions
15504 - MEDIUM: compression: add a distinction between UA- and config- algorithms
15505 - MEDIUM: compression: add new "raw-deflate" compression algorithm
15506 - MEDIUM: compression: split deflate_flush() into flush and finish
15507 - CLEANUP: compression: remove unused reset functions
15508 - MAJOR: compression: integrate support for libslz
15509 - BUG/MEDIUM: http: hdr_cnt would not count any header when called without name
15510 - BUG/MAJOR: http: null-terminate the http actions keywords list
15511 - CLEANUP: lua: remove the unused hlua_sleep memory pool
15512 - BUG/MAJOR: lua: use correct object size when initializing a new converter
15513 - CLEANUP: lua: remove hard-coded sizeof() in object creations and mallocs
15514 - CLEANUP: lua: fix confusing local variable naming in hlua_txn_new()
15515 - CLEANUP: hlua: stop using variable name "s" alternately for hlua_txn and hlua_smp
15516 - CLEANUP: lua: get rid of the last "*ht" for struct hlua_txn.
15517 - CLEANUP: lua: rename last occurrences of "*s" to "*htxn" for hlua_txn
15518 - CLEANUP: lua: rename variable "sc" for struct hlua_smp
15519 - CLEANUP: lua: get rid of the last two "*hs" for hlua_smp
15520 - REORG/MAJOR: session: rename the "session" entity to "stream"
15521 - REORG/MEDIUM: stream: rename stream flags from SN_* to SF_*
15522 - MINOR: session: start to reintroduce struct session
15523 - MEDIUM: stream: allocate the session when a stream is created
15524 - MEDIUM: stream: move the listener's pointer to the session
15525 - MEDIUM: stream: move the frontend's pointer to the session
15526 - MINOR: session: add a pointer to the session's origin
15527 - MEDIUM: session: use the pointer to the origin instead of s->si[0].end
15528 - CLEANUP: sample: remove useless tests in fetch functions for l4 != NULL
15529 - MEDIUM: http: move header captures from http_txn to struct stream
15530 - MINOR: http: create a dedicated pool for http_txn
15531 - MAJOR: http: move http_txn out of struct stream
15532 - MAJOR: sample: don't pass l7 anymore to sample fetch functions
15533 - CLEANUP: lua: remove unused hlua_smp->l7 and hlua_txn->l7
15534 - MEDIUM: http: remove the now useless http_txn from {req/res} rules
15535 - CLEANUP: lua: don't pass http_txn anymore to hlua_request_act_wrapper()
15536 - MAJOR: sample: pass a pointer to the session to each sample fetch function
15537 - MINOR: stream: provide a few helpers to retrieve frontend, listener and origin
15538 - CLEANUP: stream: don't set ->target to the incoming connection anymore
15539 - MINOR: stream: move session initialization before the stream's
15540 - MINOR: session: store the session's accept date
15541 - MINOR: session: don't rely on s->logs.logwait in embryonic sessions
15542 - MINOR: session: implement session_free() and use it everywhere
15543 - MINOR: session: add stick counters to the struct session
15544 - REORG: stktable: move the stkctr_* functions from stream to sticktable
15545 - MEDIUM: streams: support looking up stkctr in the session
15546 - MEDIUM: session: update the session's stick counters upon session_free()
15547 - MEDIUM: proto_tcp: track the session's counters in the connection ruleset
15548 - MAJOR: tcp: make tcp_exec_req_rules() only rely on the session
15549 - MEDIUM: stream: don't call stream_store_counters() in kill_mini_session() nor session_accept()
15550 - MEDIUM: stream: move all the session-specific stuff of stream_accept() earlier
15551 - MAJOR: stream: don't initialize the stream anymore in stream_accept
15552 - MEDIUM: session: remove the task pointer from the session
15553 - REORG: session: move the session parts out of stream.c
15554 - MINOR: stream-int: make appctx_new() take the applet in argument
15555 - MEDIUM: peers: move the appctx initialization earlier
15556 - MINOR: session: introduce session_new()
15557 - MINOR: session: make use of session_new() when creating a new session
15558 - MINOR: peers: make use of session_new() when creating a new session
15559 - MEDIUM: peers: initialize the task before the stream
15560 - MINOR: session: set the CO_FL_CONNECTED flag on the connection once ready
15561 - CLEANUP: stream.c: do not re-attach the connection to the stream
15562 - MEDIUM: stream: isolate connection-specific initialization code
15563 - MEDIUM: stream: also accept appctx as origin in stream_accept_session()
15564 - MEDIUM: peers: make use of stream_accept_session()
15565 - MEDIUM: frontend: make ->accept only return +/-1
15566 - MEDIUM: stream: return the stream upon accept()
15567 - MEDIUM: frontend: move some stream initialisation to stream_new()
15568 - MEDIUM: frontend: move the fd-specific settings to session_accept_fd()
15569 - MEDIUM: frontend: don't restrict frontend_accept() to connections anymore
15570 - MEDIUM: frontend: move some remaining stream settings to stream_new()
15571 - CLEANUP: frontend: remove one useless local variable
15572 - MEDIUM: stream: don't rely on the session's listener anymore in stream_new()
15573 - MEDIUM: lua: make use of stream_new() to create an outgoing connection
15574 - MINOR: lua: minor cleanup in hlua_socket_new()
15575 - MINOR: lua: no need for setting timeouts / conn_retries in hlua_socket_new()
15576 - MINOR: peers: no need for setting timeouts / conn_retries in peer_session_create()
15577 - CLEANUP: stream-int: swap stream-int and appctx declarations
15578 - CLEANUP: namespaces: fix protection against multiple inclusions
15579 - MINOR: session: maintain the session count stats in the session, not the stream
15580 - MEDIUM: session: adjust the connection flags before stream_new()
15581 - MINOR: stream: pass the pointer to the origin explicitly to stream_new()
15582 - CLEANUP: poll: move the conditions for waiting out of the poll functions
15583 - BUG/MEDIUM: listener: don't report an error when resuming unbound listeners
15584 - BUG/MEDIUM: init: don't limit cpu-map to the first 32 processes only
15585 - BUG/MAJOR: tcp/http: fix current_rule assignment when restarting over a ruleset
15586 - BUG/MEDIUM: stream-int: always reset si->ops when si->end is nullified
15587 - DOC: update the entities diagrams
15588 - BUG/MEDIUM: http: properly retrieve the front connection
15589 - MINOR: applet: add a new "owner" pointer in the appctx
15590 - MEDIUM: applet: make the applet not depend on a stream interface anymore
15591 - REORG: applet: move the applet definitions out of stream_interface
15592 - CLEANUP: applet: rename struct si_applet to applet
15593 - REORG: stream-int: create si_applet_ops dedicated to applets
15594 - MEDIUM: applet: add basic support for an applet run queue
15595 - MEDIUM: applet: implement a run queue for active appctx
15596 - MEDIUM: stream-int: add a new function si_applet_done()
15597 - MAJOR: applet: now call si_applet_done() instead of si_update() in I/O handlers
15598 - MAJOR: stream: use a regular ->update for all stream interfaces
15599 - MEDIUM: dumpstats: don't unregister the applet anymore
15600 - MEDIUM: applet: centralize the call to si_applet_done() in the I/O handler
15601 - MAJOR: stream: do not allocate request buffers anymore when the left side is an applet
15602 - MINOR: stream-int: add two flags to indicate an applet's wishes regarding I/O
15603 - MEDIUM: applet: make the applets only use si_applet_{cant|want|stop}_{get|put}
15604 - MEDIUM: stream-int: pause the appctx if the task is woken up
15605 - BUG/MAJOR: tcp: only call registered actions when they're registered
15606 - BUG/MEDIUM: peers: fix applet scheduling
15607 - BUG/MEDIUM: peers: recent applet changes broke peers updates scheduling
15608 - MINOR: tools: provide an rdtsc() function for time comparisons
15609 - IMPORT: lru: import simple ebtree-based LRU functions
15610 - IMPORT: hash: import xxhash-r39
15611 - MEDIUM: pattern: add a revision to all pattern expressions
15612 - MAJOR: pattern: add LRU-based cache on pattern matching
15613 - BUG/MEDIUM: http: remove content-length from chunked messages
15614 - DOC: http: update the comments about the rules for determining transfer-length
15615 - BUG/MEDIUM: http: do not restrict parsing of transfer-encoding to HTTP/1.1
15616 - BUG/MEDIUM: http: incorrect transfer-coding in the request is a bad request
15617 - BUG/MEDIUM: http: remove content-length form responses with bad transfer-encoding
15618 - MEDIUM: http: restrict the HTTP version token to 1 digit as per RFC7230
15619 - MEDIUM: http: disable support for HTTP/0.9 by default
15620 - MEDIUM: http: add option-ignore-probes to get rid of the floods of 408
15621 - BUG/MINOR: config: clear proxy->table.peers.p for disabled proxies
15622 - MEDIUM: init: don't stop proxies in parent process when exiting
15623 - MINOR: stick-table: don't attach to peers in stopped state
15624 - MEDIUM: config: initialize stick-tables after peers, not before
15625 - MEDIUM: peers: add the ability to disable a peers section
15626 - MINOR: peers: store the pointer to the signal handler
15627 - MEDIUM: peers: unregister peers that were never started
15628 - MEDIUM: config: propagate the table's process list to the peers sections
15629 - MEDIUM: init: stop any peers section not bound to the correct process
15630 - MEDIUM: config: validate that peers sections are bound to exactly one process
15631 - MAJOR: peers: allow peers section to be used with nbproc > 1
15632 - DOC: relax the peers restriction to single-process
15633 - DOC: document option http-ignore-probes
15634 - DOC: fix the comments about the meaning of msg->sol in HTTP
15635 - BUG/MEDIUM: http: wait for the exact amount of body bytes in wait_for_request_body
15636 - BUG/MAJOR: http: prevent risk of reading past end with balance url_param
15637 - MEDIUM: stream: move HTTP request body analyser before process_common
15638 - MEDIUM: http: add a new option http-buffer-request
15639 - MEDIUM: http: provide 3 fetches for the body
15640 - DOC: update the doc on the proxy protocol
15641 - BUILD: pattern: fix build warnings introduced in the LRU cache
15642 - BUG/MEDIUM: stats: properly initialize the scope before dumping stats
15643 - CLEANUP: config: fix misleading information in error message.
15644 - MINOR: config: report the number of processes using a peers section in the error case
15645 - BUG/MEDIUM: config: properly compute the default number of processes for a proxy
15646 - MEDIUM: http: add new "capture" action for http-request
15647 - BUG/MEDIUM: http: fix the http-request capture parser
15648 - BUG/MEDIUM: http: don't forward client shutdown without NOLINGER except for tunnels
15649 - BUILD/MINOR: ssl: fix build failure introduced by recent patch
15650 - BUG/MAJOR: check: fix breakage of inverted tcp-check rules
15651 - CLEANUP: checks: fix double usage of cur / current_step in tcp-checks
15652 - BUG/MEDIUM: checks: do not dereference head of a tcp-check at the end
15653 - CLEANUP: checks: simplify the loop processing of tcp-checks
15654 - BUG/MAJOR: checks: always check for end of list before proceeding
15655 - BUG/MEDIUM: checks: do not dereference a list as a tcpcheck struct
15656 - BUG/MAJOR: checks: break infinite loops when tcp-checks starts with comment
15657 - MEDIUM: http: make url_param iterate over multiple occurrences
15658 - BUG/MEDIUM: peers: apply a random reconnection timeout
15659 - MEDIUM: config: reject invalid config with name duplicates
15660 - MEDIUM: config: reject conflicts in table names
15661 - CLEANUP: proxy: make the proxy lookup functions more user-friendly
15662 - MINOR: proxy: simply ignore duplicates in proxy name lookups
15663 - MINOR: config: don't open-code proxy name lookups
15664 - MEDIUM: config: clarify the conflicting modes detection for backend rules
15665 - CLEANUP: proxy: remove now unused function findproxy_mode()
15666 - MEDIUM: stick-table: remove the now duplicate find_stktable() function
15667 - MAJOR: config: remove the deprecated reqsetbe / reqisetbe actions
15668 - MINOR: proxy: add a new function proxy_find_by_id()
15669 - MINOR: proxy: add a flag to memorize that the proxy's ID was forced
15670 - MEDIUM: proxy: add a new proxy_find_best_match() function
15671 - CLEANUP: http: explicitly reference request in http_apply_redirect_rules()
15672 - MINOR: http: prepare support for parsing redirect actions on responses
15673 - MEDIUM: http: implement http-response redirect rules
15674 - MEDIUM: http: no need to close the request on redirect if data was parsed
15675 - BUG/MEDIUM: http: fix body processing for the stats applet
15676 - BUG/MINOR: da: fix log-level comparison to emove annoying warning
15677 - CLEANUP: global: remove one ifdef USE_DEVICEATLAS
15678 - CLEANUP: da: move the converter registration to da.c
15679 - CLEANUP: da: register the config keywords in da.c
15680 - CLEANUP: adjust the envelope name in da.h to reflect the file name
15681 - CLEANUP: da: remove ifdef USE_DEVICEATLAS from da.c
15682 - BUILD: make 51D easier to build by defaulting to 51DEGREES_SRC
15683 - BUILD: fix build warning when not using 51degrees
15684 - BUILD: make DeviceAtlas easier to build by defaulting to DEVICEATLAS_SRC
15685 - BUILD: ssl: fix recent build breakage on older SSL libs
15686
Willy Tarreau8747b6d2015-03-11 23:57:23 +0100156872015/03/11 : 1.6-dev1
15688 - CLEANUP: extract temporary $CFG to eliminate duplication
15689 - CLEANUP: extract temporary $BIN to eliminate duplication
15690 - CLEANUP: extract temporary $PIDFILE to eliminate duplication
15691 - CLEANUP: extract temporary $LOCKFILE to eliminate duplication
15692 - CLEANUP: extract quiet_check() to avoid duplication
15693 - BUG/MINOR: don't start haproxy on reload
15694 - DOC: Address issue where documentation is excluded due to a gitignore rule.
15695 - BUG/MEDIUM: systemd: set KillMode to 'mixed'
15696 - BUILD: fix "make install" to support spaces in the install dirs
15697 - BUG/MINOR: config: http-request replace-header arg typo
15698 - BUG: config: error in http-response replace-header number of arguments
15699 - DOC: missing track-sc* in http-request rules
15700 - BUILD: lua: missing ifdef related to SSL when enabling LUA
15701 - BUG/MEDIUM: regex: fix pcre_study error handling
15702 - MEDIUM: regex: Use pcre_study always when PCRE is used, regardless of JIT
15703 - BUG/MINOR: Fix search for -p argument in systemd wrapper.
15704 - MEDIUM: Improve signal handling in systemd wrapper.
15705 - DOC: fix typo in Unix Socket commands
15706 - BUG/MEDIUM: checks: external checks can't change server status to UP
15707 - BUG/MEDIUM: checks: segfault with external checks in a backend section
15708 - BUG/MINOR: checks: external checks shouldn't wait for timeout to return the result
15709 - BUG/MEDIUM: auth: fix segfault with http-auth and a configuration with an unknown encryption algorithm
15710 - BUG/MEDIUM: config: userlists should ensure that encrypted passwords are supported
15711 - BUG/MINOR: config: don't propagate process binding for dynamic use_backend
15712 - BUG/MINOR: log: fix request flags when keep-alive is enabled
15713 - BUG/MEDIUM: checks: fix conflicts between agent checks and ssl healthchecks
15714 - MINOR: checks: allow external checks in backend sections
15715 - MEDIUM: checks: provide environment variables to the external checks
15716 - MINOR: checks: update dynamic environment variables in external checks
15717 - DOC: checks: environment variables used by "external-check command"
15718 - BUG/MEDIUM: backend: correctly detect the domain when use_domain_only is used
15719 - MINOR: ssl: load certificates in alphabetical order
15720 - BUG/MINOR: checks: prevent http keep-alive with http-check expect
15721 - MINOR: lua: typo in an error message
15722 - MINOR: report the Lua version in -vv
15723 - MINOR: lua: add a compilation error message when compiled with an incompatible version
15724 - BUG/MEDIUM: lua: segfault when calling haproxy sample fetches from lua
15725 - BUILD: try to automatically detect the Lua library name
15726 - BUILD/CLEANUP: systemd: avoid a warning due to mixed code and declaration
15727 - BUG/MEDIUM: backend: Update hash to use unsigned int throughout
15728 - BUG/MEDIUM: connection: fix memory corruption when building a proxy v2 header
15729 - MEDIUM: connection: add new bit in Proxy Protocol V2
15730 - BUG/MINOR: ssl: rejects OCSP response without nextupdate.
15731 - BUG/MEDIUM: ssl: Fix to not serve expired OCSP responses.
15732 - BUG/MINOR: ssl: Fix OCSP resp update fails with the same certificate configured twice.
15733 - BUG/MINOR: ssl: Fix external function in order not to return a pointer on an internal trash buffer.
15734 - MINOR: add fetchs 'ssl_c_der' and 'ssl_f_der' to return DER formatted certs
15735 - MINOR: ssl: add statement to force some ssl options in global.
15736 - BUG/MINOR: ssl: correctly initialize ssl ctx for invalid certificates
15737 - BUG/MEDIUM: ssl: fix bad ssl context init can cause segfault in case of OOM.
15738 - BUG/MINOR: samples: fix unnecessary memcopy converting binary to string.
15739 - MINOR: samples: adds the bytes converter.
15740 - MINOR: samples: adds the field converter.
15741 - MINOR: samples: add the word converter.
15742 - BUG/MINOR: server: move the directive #endif to the end of file
15743 - BUG/MAJOR: buffer: check the space left is enough or not when input data in a buffer is wrapped
15744 - DOC: fix a few typos
15745 - CLEANUP: epoll: epoll_events should be allocated according to global.tune.maxpollevents
15746 - BUG/MINOR: http: fix typo: "401 Unauthorized" => "407 Unauthorized"
15747 - BUG/MINOR: parse: refer curproxy instead of proxy
15748 - BUG/MINOR: parse: check the validity of size string in a more strict way
15749 - BUILD: add new target 'make uninstall' to support uninstalling haproxy from OS
15750 - DOC: expand the docs for the provided stats.
15751 - BUG/MEDIUM: unix: do not unlink() abstract namespace sockets upon failure.
15752 - MEDIUM: ssl: Certificate Transparency support
15753 - MEDIUM: stats: proxied stats admin forms fix
15754 - MEDIUM: http: Compress HTTP responses with status codes 201,202,203 in addition to 200
15755 - BUG/MEDIUM: connection: sanitize PPv2 header length before parsing address information
15756 - MAJOR: namespace: add Linux network namespace support
15757 - MINOR: systemd: Check configuration before start
15758 - BUILD: ssl: handle boringssl in openssl version detection
15759 - BUILD: ssl: disable OCSP when using boringssl
15760 - BUILD: ssl: don't call get_rfc2409_prime when using boringssl
15761 - MINOR: ssl: don't use boringssl's cipher_list
15762 - BUILD: ssl: use OPENSSL_NO_OCSP to detect OCSP support
15763 - MINOR: stats: fix minor typo in HTML page
15764 - MINOR: Also accept SIGHUP/SIGTERM in systemd-wrapper
15765 - MEDIUM: Add support for configurable TLS ticket keys
15766 - DOC: Document the new tls-ticket-keys bind keyword
15767 - DOC: clearly state that the "show sess" output format is not fixed
15768 - MINOR: stats: fix minor typo fix in stats_dump_errors_to_buffer()
15769 - DOC: httplog does not support 'no'
15770 - BUG/MEDIUM: ssl: Fix a memory leak in DHE key exchange
15771 - MINOR: ssl: use SSL_get_ciphers() instead of directly accessing the cipher list.
15772 - BUG/MEDIUM: Consistently use 'check' in process_chk
15773 - MEDIUM: Add external check
15774 - BUG/MEDIUM: Do not set agent health to zero if server is disabled in config
15775 - MEDIUM/BUG: Only explicitly report "DOWN (agent)" if the agent health is zero
15776 - MEDIUM: Remove connect_chk
15777 - MEDIUM: Refactor init_check and move to checks.c
15778 - MEDIUM: Add free_check() helper
15779 - MEDIUM: Move proto and addr fields struct check
15780 - MEDIUM: Attach tcpcheck_rules to check
15781 - MEDIUM: Add parsing of mailers section
15782 - MEDIUM: Allow configuration of email alerts
15783 - MEDIUM: Support sending email alerts
15784 - DOC: Document email alerts
15785 - MINOR: Remove trailing '.' from email alert messages
15786 - MEDIUM: Allow suppression of email alerts by log level
15787 - BUG/MEDIUM: Do not consider an agent check as failed on L7 error
15788 - MINOR: deinit: fix memory leak
15789 - MINOR: http: export the function 'smp_fetch_base32'
15790 - BUG/MEDIUM: http: tarpit timeout is reset
15791 - MINOR: sample: add "json" converter
15792 - BUG/MEDIUM: pattern: don't load more than once a pattern list.
15793 - MINOR: map/acl/dumpstats: remove the "Done." message
15794 - BUG/MAJOR: ns: HAProxy segfault if the cli_conn is not from a network connection
15795 - BUG/MINOR: pattern: error message missing
15796 - BUG/MEDIUM: pattern: some entries are not deleted with case insensitive match
15797 - BUG/MINOR: ARG6 and ARG7 don't fit in a 32 bits word
15798 - MAJOR: poll: only rely on wake_expired_tasks() to compute the wait delay
15799 - MEDIUM: task: call session analyzers if the task is woken by a message.
15800 - MEDIUM: protocol: automatically pick the proto associated to the connection.
15801 - MEDIUM: channel: wake up any request analyzer on response activity
15802 - MINOR: converters: add a "void *private" argument to converters
15803 - MINOR: converters: give the session pointer as converter argument
15804 - MINOR: sample: add private argument to the struct sample_fetch
15805 - MINOR: global: export function and permits to not resolve DNS names
15806 - MINOR: sample: add function for browsing samples.
15807 - MINOR: global: export many symbols.
15808 - MINOR: includes: fix a lot of missing or useless includes
15809 - MEDIUM: tcp: add register keyword system.
15810 - MEDIUM: buffer: make bo_putblk/bo_putstr/bo_putchk return the number of bytes copied.
15811 - MEDIUM: http: change the code returned by the response processing rule functions
15812 - MEDIUM: http/tcp: permit to resume http and tcp custom actions
15813 - MINOR: channel: functions to get data from a buffer without copy
15814 - MEDIUM: lua: lua integration in the build and init system.
15815 - MINOR: lua: add ease functions
15816 - MINOR: lua: add runtime execution context
15817 - MEDIUM: lua: "com" signals
15818 - MINOR: lua: add the configuration directive "lua-load"
15819 - MINOR: lua: core: create "core" class and object
15820 - MINOR: lua: post initialisation bindings
15821 - MEDIUM: lua: add coroutine as tasks.
15822 - MINOR: lua: add sample and args type converters
15823 - MINOR: lua: txn: create class TXN associated with the transaction.
15824 - MINOR: lua: add shared context in the lua stack
15825 - MINOR: lua: txn: import existing sample-fetches in the class TXN
15826 - MINOR: lua: txn: add lua function in TXN that returns an array of http headers
15827 - MINOR: lua: register and execute sample-fetches in LUA
15828 - MINOR: lua: register and execute converters in LUA
15829 - MINOR: lua: add bindings for tcp and http actions
15830 - MINOR: lua: core: add sleep functions
15831 - MEDIUM: lua: socket: add "socket" class for TCP I/O
15832 - MINOR: lua: core: pattern and acl manipulation
15833 - MINOR: lua: channel: add "channel" class
15834 - MINOR: lua: txn: object "txn" provides two objects "channel"
15835 - MINOR: lua: core: can set the nice of the current task
15836 - MINOR: lua: core: can yield an execution stack
15837 - MINOR: lua: txn: add binding for closing the client connection.
15838 - MEDIUM: lua: Lua initialisation "on demand"
15839 - BUG/MAJOR: lua: send function fails and return bad bytes
15840 - MINOR: remove unused declaration.
15841 - MINOR: lua: remove some #define
15842 - MINOR: lua: use bitfield and macro in place of integer and enum
15843 - MINOR: lua: set skeleton for Lua execution expiration
15844 - MEDIUM: lua: each yielding function returns a wake up time.
15845 - MINOR: lua: adds "forced yield" flag
15846 - MEDIUM: lua: interrupt the Lua execution for running other process
15847 - MEDIUM: lua: change the sleep function core
15848 - BUG/MEDIUM: lua: the execution timeout is ignored in yield case
15849 - DOC: lua: Lua configuration documentation
15850 - MINOR: lua: add the struct session in the lua channel struct
15851 - BUG/MINOR: lua: set buffer if it is nnot avalaible.
15852 - BUG/MEDIUM: lua: reset flags before resuming execution
15853 - BUG/MEDIUM: lua: fix infinite loop about channel
15854 - BUG/MEDIUM: lua: the Lua process is not waked up after sending data on requests side
15855 - BUG/MEDIUM: lua: many errors when we try to send data with the channel API
15856 - MEDIUM: lua: use the Lua-5.3 version of the library
15857 - BUG/MAJOR: lua: some function are not yieldable, the forced yield causes errors
15858 - BUG/MEDIUM: lua: can't handle the response bytes
15859 - BUG/MEDIUM: lua: segfault with buffer_replace2
15860 - BUG/MINOR: lua: check buffers before initializing socket
15861 - BUG/MINOR: log: segfault if there are no proxy reference
15862 - BUG/MEDIUM: lua: sockets don't have buffer to write data
15863 - BUG/MEDIUM: lua: cannot connect socket
15864 - BUG/MINOR: lua: sockets receive behavior doesn't follows the specs
15865 - BUG/BUILD: lua: The strict Lua 5.3 version check is not done.
15866 - BUG/MEDIUM: buffer: one byte miss in buffer free space check
15867 - MEDIUM: lua: make the functions hlua_gethlua() and hlua_sethlua() faster
15868 - MINOR: replace the Core object by a simple model.
15869 - MEDIUM: lua: change the objects configuration
15870 - MEDIUM: lua: create a namespace for the fetches
15871 - MINOR: converters: add function to browse converters
15872 - MINOR: lua: wrapper for converters
15873 - MINOR: lua: replace function (req|get)_channel by a variable
15874 - MINOR: lua: fetches and converters can return an empty string in place of nil
15875 - DOC: lua api
15876 - BUG/MEDIUM: sample: fix random number upper-bound
15877 - BUG/MINOR: stats:Fix incorrect printf type.
15878 - BUG/MAJOR: session: revert all the crappy client-side timeout changes
15879 - BUG/MINOR: logs: properly initialize and count log sockets
15880 - BUG/MEDIUM: http: fetch "base" is not compatible with set-header
15881 - BUG/MINOR: counters: do not untrack counters before logging
15882 - BUG/MAJOR: sample: correctly reinitialize sample fetch context before calling sample_process()
15883 - MINOR: stick-table: make stktable_fetch_key() indicate why it failed
15884 - BUG/MEDIUM: counters: fix track-sc* to wait on unstable contents
15885 - BUILD: remove TODO from the spec file and add README
15886 - MINOR: log: make MAX_SYSLOG_LEN overridable at build time
15887 - MEDIUM: log: support a user-configurable max log line length
15888 - DOC: provide an example of how to use ssl_c_sha1
15889 - BUILD: checks: external checker needs signal.h
15890 - BUILD: checks: kill a minor warning on Solaris in external checks
15891 - BUILD: http: fix isdigit & isspace warnings on Solaris
15892 - BUG/MINOR: listener: set the listener's fd to -1 after deletion
15893 - BUG/MEDIUM: unix: failed abstract socket binding is retryable
15894 - MEDIUM: listener: implement a per-protocol pause() function
15895 - MEDIUM: listener: support rebinding during resume()
15896 - BUG/MEDIUM: unix: completely unbind abstract sockets during a pause()
15897 - DOC: explicitly mention the limits of abstract namespace sockets
15898 - DOC: minor fix on {sc,src}_kbytes_{in,out}
15899 - DOC: fix alphabetical sort of converters
15900 - MEDIUM: stick-table: implement lookup from a sample fetch
15901 - MEDIUM: stick-table: add new converters to fetch table data
15902 - MINOR: samples: add two converters for the date format
15903 - BUG/MAJOR: http: correctly rewind the request body after start of forwarding
15904 - DOC: remove references to CPU=native in the README
15905 - DOC: mention that "compression offload" is ignored in defaults section
15906 - DOC: mention that Squid correctly responds 400 to PPv2 header
15907 - BUILD: fix dependencies between config and compat.h
15908 - MINOR: session: export the function 'smp_fetch_sc_stkctr'
15909 - MEDIUM: stick-table: make it easier to register extra data types
15910 - BUG/MINOR: http: base32+src should use the big endian version of base32
15911 - MINOR: sample: allow IP address to cast to binary
15912 - MINOR: sample: add new converters to hash input
15913 - MINOR: sample: allow integers to cast to binary
15914 - BUILD: report commit ID in git versions as well
15915 - CLEANUP: session: move the stick counters declarations to stick_table.h
15916 - MEDIUM: http: add the track-sc* actions to http-request rules
15917 - BUG/MEDIUM: connection: fix proxy v2 header again!
15918 - BUG/MAJOR: tcp: fix a possible busy spinning loop in content track-sc*
15919 - OPTIM/MINOR: proxy: reduce struct proxy by 48 bytes on 64-bit archs
15920 - MINOR: log: add a new field "%lc" to implement a per-frontend log counter
15921 - BUG/MEDIUM: http: fix inverted condition in pat_match_meth()
15922 - BUG/MEDIUM: http: fix improper parsing of HTTP methods for use with ACLs
15923 - BUG/MINOR: pattern: remove useless allocation of unused trash in pat_parse_reg()
15924 - BUG/MEDIUM: acl: correctly compute the output type when a converter is used
15925 - CLEANUP: acl: cleanup some of the redundancy and spaghetti after last fix
15926 - BUG/CRITICAL: http: don't update msg->sov once data start to leave the buffer
15927 - MEDIUM: http: enable header manipulation for 101 responses
15928 - BUG/MEDIUM: config: propagate frontend to backend process binding again.
15929 - MEDIUM: config: properly propagate process binding between proxies
15930 - MEDIUM: config: make the frontends automatically bind to the listeners' processes
15931 - MEDIUM: config: compute the exact bind-process before listener's maxaccept
15932 - MEDIUM: config: only warn if stats are attached to multi-process bind directives
15933 - MEDIUM: config: report it when tcp-request rules are misplaced
15934 - DOC: indicate in the doc that track-sc* can wait if data are missing
15935 - MINOR: config: detect the case where a tcp-request content rule has no inspect-delay
15936 - MEDIUM: systemd-wrapper: support multiple executable versions and names
15937 - BUG/MEDIUM: remove debugging code from systemd-wrapper
15938 - BUG/MEDIUM: http: adjust close mode when switching to backend
15939 - BUG/MINOR: config: don't propagate process binding on fatal errors.
15940 - BUG/MEDIUM: check: rule-less tcp-check must detect connect failures
15941 - BUG/MINOR: tcp-check: report the correct failed step in the status
15942 - DOC: indicate that weight zero is reported as DRAIN
15943 - BUG/MEDIUM: config: avoid skipping disabled proxies
15944 - BUG/MINOR: config: do not accept more track-sc than configured
15945 - BUG/MEDIUM: backend: fix URI hash when a query string is present
15946 - BUG/MEDIUM: http: don't dump debug headers on MSG_ERROR
15947 - BUG/MAJOR: cli: explicitly call cli_release_handler() upon error
15948 - BUG/MEDIUM: tcp: fix outgoing polling based on proxy protocol
15949 - BUILD/MINOR: ssl: de-constify "ciphers" to avoid a warning on openssl-0.9.8
15950 - BUG/MEDIUM: tcp: don't use SO_ORIGINAL_DST on non-AF_INET sockets
15951 - BUG/BUILD: revert accidental change in the makefile from latest SSL fix
15952 - BUG/MEDIUM: ssl: force a full GC in case of memory shortage
15953 - MEDIUM: ssl: add support for smaller SSL records
15954 - MINOR: session: release a few other pools when stopping
15955 - MINOR: task: release the task pool when stopping
15956 - BUG/MINOR: config: don't inherit the default balance algorithm in frontends
15957 - BUG/MAJOR: frontend: initialize capture pointers earlier
15958 - BUG/MINOR: stats: correctly set the request/response analysers
15959 - MAJOR: polling: centralize calls to I/O callbacks
15960 - DOC: fix typo in the body parser documentation for msg.sov
15961 - BUG/MINOR: peers: the buffer size is global.tune.bufsize, not trash.size
15962 - MINOR: sample: add a few basic internal fetches (nbproc, proc, stopping)
15963 - DEBUG: pools: apply poisonning on every allocated pool
15964 - BUG/MAJOR: sessions: unlink session from list on out of memory
15965 - BUG/MEDIUM: patterns: previous fix was incomplete
15966 - BUG/MEDIUM: payload: ensure that a request channel is available
15967 - BUG/MINOR: tcp-check: don't condition data polling on check type
15968 - BUG/MEDIUM: tcp-check: don't rely on random memory contents
15969 - BUG/MEDIUM: tcp-checks: disable quick-ack unless next rule is an expect
15970 - BUG/MINOR: config: fix typo in condition when propagating process binding
15971 - BUG/MEDIUM: config: do not propagate processes between stopped processes
15972 - BUG/MAJOR: stream-int: properly check the memory allocation return
15973 - BUG/MEDIUM: memory: fix freeing logic in pool_gc2()
15974 - BUG/MAJOR: namespaces: conn->target is not necessarily a server
15975 - BUG/MEDIUM: compression: correctly report zlib_mem
15976 - CLEANUP: lists: remove dead code
15977 - CLEANUP: memory: remove dead code
15978 - CLEANUP: memory: replace macros pool_alloc2/pool_free2 with functions
15979 - MINOR: memory: cut pool allocator in 3 layers
15980 - MEDIUM: memory: improve pool_refill_alloc() to pass a refill count
15981 - MINOR: stream-int: retrieve session pointer from stream-int
15982 - MINOR: buffer: reset a buffer in b_reset() and not channel_init()
15983 - MEDIUM: buffer: use b_alloc() to allocate and initialize a buffer
15984 - MINOR: buffer: move buffer initialization after channel initialization
15985 - MINOR: buffer: only use b_free to release buffers
15986 - MEDIUM: buffer: always assign a dummy empty buffer to channels
15987 - MEDIUM: buffer: add a new buf_wanted dummy buffer to report failed allocations
15988 - MEDIUM: channel: do not report full when buf_empty is present on a channel
15989 - MINOR: session: group buffer allocations together
15990 - MINOR: buffer: implement b_alloc_fast()
15991 - MEDIUM: buffer: implement b_alloc_margin()
15992 - MEDIUM: session: implement a basic atomic buffer allocator
15993 - MAJOR: session: implement a wait-queue for sessions who need a buffer
15994 - MAJOR: session: only allocate buffers when needed
15995 - MINOR: stats: report a "waiting" flags for sessions
15996 - MAJOR: session: only wake up as many sessions as available buffers permit
15997 - MINOR: config: implement global setting tune.buffers.reserve
15998 - MINOR: config: implement global setting tune.buffers.limit
15999 - MEDIUM: channel: implement a zero-copy buffer transfer
16000 - MEDIUM: stream-int: support splicing from applets
16001 - OPTIM: stream-int: try to send pending spliced data
16002 - CLEANUP: session: remove session_from_task()
16003 - DOC: add missing entry for log-format and clarify the text
16004 - MINOR: logs: add a new per-proxy "log-tag" directive
16005 - BUG/MEDIUM: http: fix header removal when previous header ends with pure LF
16006 - MINOR: config: extend the default max hostname length to 64 and beyond
16007 - BUG/MEDIUM: channel: fix possible integer overflow on reserved size computation
16008 - BUG/MINOR: channel: compare to_forward with buf->i, not buf->size
16009 - MINOR: channel: add channel_in_transit()
16010 - MEDIUM: channel: make buffer_reserved() use channel_in_transit()
16011 - MEDIUM: channel: make bi_avail() use channel_in_transit()
16012 - BUG/MEDIUM: channel: don't schedule data in transit for leaving until connected
16013 - CLEANUP: channel: rename channel_reserved -> channel_is_rewritable
16014 - MINOR: channel: rename channel_full() to !channel_may_recv()
16015 - MINOR: channel: rename buffer_reserved() to channel_reserved()
16016 - MINOR: channel: rename buffer_max_len() to channel_recv_limit()
16017 - MINOR: channel: rename bi_avail() to channel_recv_max()
16018 - MINOR: channel: rename bi_erase() to channel_truncate()
16019 - BUG/MAJOR: log: don't try to emit a log if no logger is set
16020 - MINOR: tools: add new round_2dig() function to round integers
16021 - MINOR: global: always export some SSL-specific metrics
16022 - MINOR: global: report information about the cost of SSL connections
16023 - MAJOR: init: automatically set maxconn and/or maxsslconn when possible
16024 - MINOR: http: add a new fetch "query" to extract the request's query string
16025 - MINOR: hash: add new function hash_crc32
16026 - MINOR: samples: provide a "crc32" converter
16027 - MEDIUM: backend: add the crc32 hash algorithm for load balancing
16028 - BUG/MINOR: args: add missing entry for ARGT_MAP in arg_type_names
16029 - BUG/MEDIUM: http: make http-request set-header compute the string before removal
16030 - MEDIUM: args: use #define to specify the number of bits used by arg types and counts
16031 - MEDIUM: args: increase arg type to 5 bits and limit arg count to 5
16032 - MINOR: args: add type-specific flags for each arg in a list
16033 - MINOR: args: implement a new arg type for regex : ARGT_REG
16034 - MEDIUM: regex: add support for passing regex flags to regex_exec_match()
16035 - MEDIUM: samples: add a regsub converter to perform regex-based transformations
16036 - BUG/MINOR: sample: fix case sensitivity for the regsub converter
16037 - MEDIUM: http: implement http-request set-{method,path,query,uri}
16038 - DOC: fix missing closing brackend on regsub
16039 - MEDIUM: samples: provide basic arithmetic and bitwise operators
16040 - MEDIUM: init: continue to enforce SYSTEM_MAXCONN with auto settings if set
16041 - BUG/MINOR: http: fix incorrect header value offset in replace-hdr/replace-value
16042 - BUG/MINOR: http: abort request processing on filter failure
16043 - MEDIUM: tcp: implement tcp-ut bind option to set TCP_USER_TIMEOUT
16044 - MINOR: ssl/server: add the "no-ssl-reuse" server option
16045 - BUG/MAJOR: peers: initialize s->buffer_wait when creating the session
16046 - MINOR: http: add a new function to iterate over each header line
16047 - MINOR: http: add the new sample fetches req.hdr_names and res.hdr_names
16048 - MEDIUM: task: always ensure that the run queue is consistent
16049 - BUILD: Makefile: add -Wdeclaration-after-statement
16050 - BUILD/CLEANUP: ssl: avoid a warning due to mixed code and declaration
16051 - BUILD/CLEANUP: config: silent 3 warnings about mixed declarations with code
16052 - MEDIUM: protocol: use a family array to index the protocol handlers
16053 - BUILD: lua: cleanup many mixed occurrences declarations & code
16054 - BUG/MEDIUM: task: fix recently introduced scheduler skew
16055 - BUG/MINOR: lua: report the correct function name in an error message
16056 - BUG/MAJOR: http: fix stats regression consecutive to HTTP_RULE_RES_YIELD
16057 - Revert "BUG/MEDIUM: lua: can't handle the response bytes"
16058 - MINOR: lua: convert IP addresses to type string
16059 - CLEANUP: lua: use the same function names in C and Lua
16060 - REORG/MAJOR: move session's req and resp channels back into the session
16061 - CLEANUP: remove now unused channel pool
16062 - REORG/MEDIUM: stream-int: introduce si_ic/si_oc to access channels
16063 - MEDIUM: stream-int: add a flag indicating which side the SI is on
16064 - MAJOR: stream-int: only rely on SI_FL_ISBACK to find the requested channel
16065 - MEDIUM: stream-interface: remove now unused pointers to channels
16066 - MEDIUM: stream-int: make si_sess() use the stream int's side
16067 - MEDIUM: stream-int: use si_task() to retrieve the task from the stream int
16068 - MEDIUM: stream-int: remove any reference to the owner
16069 - CLEANUP: stream-int: add si_ib/si_ob to dereference the buffers
16070 - CLEANUP: stream-int: add si_opposite() to find the other stream interface
16071 - REORG/MEDIUM: channel: only use chn_prod / chn_cons to find stream-interfaces
16072 - MEDIUM: channel: add a new flag "CF_ISRESP" for the response channel
16073 - MAJOR: channel: only rely on the new CF_ISRESP flag to find the SI
16074 - MEDIUM: channel: remove now unused ->prod and ->cons pointers
16075 - CLEANUP: session: simplify references to chn_{prod,cons}(&s->{req,res})
16076 - CLEANUP: session: use local variables to access channels / stream ints
16077 - CLEANUP: session: don't needlessly pass a pointer to the stream-int
16078 - CLEANUP: session: don't use si_{ic,oc} when we know the session.
16079 - CLEANUP: stream-int: limit usage of si_ic/si_oc
16080 - CLEANUP: lua: limit usage of si_ic/si_oc
16081 - MINOR: channel: add chn_sess() helper to retrieve session from channel
16082 - MEDIUM: session: simplify receive buffer allocator to only use the channel
16083 - MEDIUM: lua: use CF_ISRESP to detect the channel's side
16084 - CLEANUP: lua: remove the session pointer from hlua_channel
16085 - CLEANUP: lua: hlua_channel_new() doesn't need the pointer to the session anymore
16086 - MEDIUM: lua: remove struct hlua_channel
16087 - MEDIUM: lua: remove hlua_sample_fetch
16088
Willy Tarreau15480d72014-06-19 21:10:58 +0200160892014/06/19 : 1.6-dev0
16090 - exact copy of 1.5.0
16091
Willy Tarreau9229f122014-06-19 21:01:06 +0200160922014/06/19 : 1.5.0
16093 - MEDIUM: ssl: ignored file names ending as '.issuer' or '.ocsp'.
16094 - MEDIUM: ssl: basic OCSP stapling support.
16095 - MINOR: ssl/cli: Fix unapropriate comment in code on 'set ssl ocsp-response'
16096 - MEDIUM: ssl: add 300s supported time skew on OCSP response update.
16097 - MINOR: checks: mysql-check: Add support for v4.1+ authentication
16098 - MEDIUM: ssl: Add the option to use standardized DH parameters >= 1024 bits
16099 - MEDIUM: ssl: fix detection of ephemeral diffie-hellman key exchange by using the cipher description.
16100 - MEDIUM: http: add actions "replace-header" and "replace-values" in http-req/resp
16101 - MEDIUM: Break out check establishment into connect_chk()
16102 - MEDIUM: Add port_to_str helper
16103 - BUG/MEDIUM: fix ignored values for half-closed timeouts (client-fin and server-fin) in defaults section.
16104 - BUG/MEDIUM: Fix unhandled connections problem with systemd daemon mode and SO_REUSEPORT.
16105 - MINOR: regex: fix a little configuration memory leak.
16106 - MINOR: regex: Create JIT compatible function that return match strings
16107 - MEDIUM: regex: replace all standard regex function by own functions
16108 - MEDIUM: regex: Remove null terminated strings.
16109 - MINOR: regex: Use native PCRE API.
16110 - MINOR: missing regex.h include
16111 - DOC: Add Exim as Proxy Protocol implementer.
16112 - BUILD: don't use type "uint" which is not portable
16113 - BUILD: stats: workaround stupid and bogus -Werror=format-security behaviour
16114 - BUG/MEDIUM: http: clear CF_READ_NOEXP when preparing a new transaction
16115 - CLEANUP: http: don't clear CF_READ_NOEXP twice
16116 - DOC: fix proxy protocol v2 decoder example
16117 - DOC: fix remaining occurrences of "pattern extraction"
16118 - MINOR: log: allow the HTTP status code to be logged even in TCP frontends
16119 - MINOR: logs: don't limit HTTP header captures to HTTP frontends
16120 - MINOR: sample: improve sample_fetch_string() to report partial contents
16121 - MINOR: capture: extend the captures to support non-header keys
16122 - MINOR: tcp: prepare support for the "capture" action
16123 - MEDIUM: tcp: add a new tcp-request capture directive
16124 - MEDIUM: session: allow shorter retry delay if timeout connect is small
16125 - MEDIUM: session: don't apply the retry delay when redispatching
16126 - MEDIUM: session: redispatch earlier when possible
16127 - MINOR: config: warn when tcp-check rules are used without option tcp-check
16128 - BUG/MINOR: connection: make proxy protocol v1 support the UNKNOWN protocol
16129 - DOC: proxy protocol example parser was still wrong
16130 - DOC: minor updates to the proxy protocol doc
16131 - CLEANUP: connection: merge proxy proto v2 header and address block
16132 - MEDIUM: connection: add support for proxy protocol v2 in accept-proxy
16133 - MINOR: tools: add new functions to quote-encode strings
16134 - DOC: clarify the CSV format
16135 - MEDIUM: stats: report the last check and last agent's output on the CSV status
16136 - MINOR: freq_ctr: introduce a new averaging method
16137 - MEDIUM: session: maintain per-backend and per-server time statistics
16138 - MEDIUM: stats: report per-backend and per-server time stats in HTML and CSV outputs
16139 - BUG/MINOR: http: fix typos in previous patch
16140 - DOC: remove the ultra-obsolete TODO file
16141 - DOC: update roadmap
16142 - DOC: minor updates to the README
16143 - DOC: mention the maxconn limitations with the select poller
16144 - DOC: commit a few old design thoughts files
16145
Willy Tarreau2e858402014-05-28 17:50:53 +0200161462014/05/28 : 1.5-dev26
16147 - BUG/MEDIUM: polling: fix possible CPU hogging of worker processes after receiving SIGUSR1.
16148 - BUG/MINOR: stats: fix a typo on a closing tag for a server tracking another one
16149 - OPTIM: stats: avoid the calculation of a useless link on tracking servers in maintenance
16150 - MINOR: fix a few memory usage errors
16151 - CONTRIB: halog: Filter input lines by date and time through timestamp
16152 - MINOR: ssl: SSL_CTX_set_options() and SSL_CTX_set_mode() take a long, not an int
16153 - BUG/MEDIUM: regex: fix risk of buffer overrun in exp_replace()
16154 - MINOR: acl: set "str" as default match for strings
16155 - DOC: Add some precisions about acl default matching method
16156 - MEDIUM: acl: strenghten the option parser to report invalid options
16157 - BUG/MEDIUM: config: a stats-less config crashes in 1.5-dev25
16158 - BUG/MINOR: checks: tcp-check must not stop on '\0' for binary checks
16159 - MINOR: stats: improve alignment of color codes to save one line of header
16160 - MINOR: checks: simplify and improve reporting of state changes when using log-health-checks
16161 - MINOR: server: remove the SRV_DRAIN flag which can always be deduced
16162 - MINOR: server: use functions to detect state changes and to update them
16163 - MINOR: server: create srv_was_usable() from srv_is_usable() and use a pointer
16164 - BUG/MINOR: stats: do not report "100%" in the thottle column when server is draining
16165 - BUG/MAJOR: config: don't free valid regex memory
16166 - BUG/MEDIUM: session: don't clear CF_READ_NOEXP if analysers are not called
16167 - BUG/MINOR: stats: tracking servers may incorrectly report an inherited DRAIN status
16168 - MEDIUM: proxy: make timeout parser a bit stricter
16169 - REORG/MEDIUM: server: split server state and flags in two different variables
16170 - REORG/MEDIUM: server: move the maintenance bits out of the server state
16171 - MAJOR: server: use states instead of flags to store the server state
16172 - REORG: checks: put the functions in the appropriate files !
16173 - MEDIUM: server: properly support and propagate the maintenance status
16174 - MEDIUM: server: allow multi-level server tracking
16175 - CLEANUP: checks: rename the server_status_printf function
16176 - MEDIUM: checks: simplify server up/down/nolb transitions
16177 - MAJOR: checks: move health checks changes to set_server_check_status()
16178 - MINOR: server: make the status reporting function support a reason
16179 - MINOR: checks: simplify health check reporting functions
16180 - MINOR: server: implement srv_set_stopped()
16181 - MINOR: server: implement srv_set_running()
16182 - MINOR: server: implement srv_set_stopping()
16183 - MEDIUM: checks: simplify failure notification using srv_set_stopped()
16184 - MEDIUM: checks: simplify success notification using srv_set_running()
16185 - MEDIUM: checks: simplify stopping mode notification using srv_set_stopping()
16186 - MEDIUM: stats: report a server's own state instead of the tracked one's
16187 - MINOR: server: make use of srv_is_usable() instead of checking eweight
16188 - MAJOR: checks: add support for a new "drain" administrative mode
16189 - MINOR: stats: use the admin flags for soft enable/disable/stop/start on the web page
16190 - MEDIUM: stats: introduce new actions to simplify admin status management
16191 - MINOR: cli: introduce a new "set server" command
16192 - MINOR: stats: report a distinct output for DOWN caused by agent
16193 - MINOR: checks: support specific check reporting for the agent
16194 - MINOR: checks: support a neutral check result
16195 - BUG/MINOR: cli: "agent" was missing from the "enable"/"disable" help message
16196 - MEDIUM: cli: add support for enabling/disabling health checks.
16197 - MEDIUM: stats: report down caused by agent prior to reporting up
16198 - MAJOR: agent: rework the response processing and support additional actions
16199 - MINOR: stats: improve the stats web page to support more actions
16200 - CONTRIB: halog: avoid calling time/localtime/mktime for each line
16201 - DOC: document the workarouds for Google Chrome's bogus pre-connect
16202 - MINOR: stats: report SSL key computations per second
16203 - MINOR: stats: add counters for SSL cache lookups and misses
16204
Willy Tarreaua3393952014-05-10 15:16:43 +0200162052014/05/10 : 1.5-dev25
16206 - MEDIUM: connection: Implement and extented PROXY Protocol V2
16207 - MINOR: ssl: clean unused ACLs declarations
16208 - MINOR: ssl: adds fetchs and ACLs for ssl back connection.
16209 - MINOR: ssl: merge client's and frontend's certificate functions.
16210 - MINOR: ssl: adds ssl_f_sha1 fetch to return frontend's certificate fingerprint
16211 - MINOR: ssl: adds sample converter base64 for binary type.
16212 - MINOR: ssl: convert to binary ssl_fc_unique_id and ssl_bc_unique_id.
16213 - BUG/MAJOR: ssl: Fallback to private session cache if current lock mode is not supported.
16214 - MAJOR: ssl: Change default locks on ssl session cache.
16215 - BUG/MINOR: chunk: Fix function chunk_strcmp and chunk_strcasecmp match a substring.
16216 - MINOR: ssl: add global statement tune.ssl.force-private-cache.
16217 - MINOR: ssl: remove fallback to SSL session private cache if lock init fails.
16218 - BUG/MEDIUM: patterns: last fix was still not enough
16219 - MINOR: http: export the smp_fetch_cookie function
16220 - MINOR: http: generic pointer to rule argument
16221 - BUG/MEDIUM: pattern: a typo breaks automatic acl/map numbering
16222 - BUG/MAJOR: patterns: -i and -n are ignored for inlined patterns
16223 - BUG/MINOR: proxy: unsafe initialization of HTTP transaction when switching from TCP frontend
16224 - BUG/MINOR: http: log 407 in case of proxy auth
16225 - MINOR: http: rely on the message body parser to send 100-continue
16226 - MEDIUM: http: move reqadd after execution of http_request redirect
16227 - MEDIUM: http: jump to dedicated labels after http-request processing
16228 - BUG/MINOR: http: block rules forgot to increment the denied_req counter
16229 - BUG/MINOR: http: block rules forgot to increment the session's request counter
16230 - MEDIUM: http: move Connection header processing earlier
16231 - MEDIUM: http: remove even more of the spaghetti in the request path
16232 - MINOR: http: silently support the "block" action for http-request
16233 - CLEANUP: proxy: rename "block_cond" to "block_rules"
16234 - MEDIUM: http: emulate "block" rules using "http-request" rules
16235 - MINOR: http: remove the now unused loop over "block" rules
16236 - MEDIUM: http: factorize the "auth" action of http-request and stats
16237 - MEDIUM: http: make http-request rules processing return a verdict instead of a rule
16238 - MINOR: config: add minimum support for emitting warnings only once
16239 - MEDIUM: config: inform the user about the deprecatedness of "block" rules
16240 - MEDIUM: config: inform the user that "reqsetbe" is deprecated
16241 - MEDIUM: config: inform the user only once that "redispatch" is deprecated
16242 - MEDIUM: config: warn that '{cli,con,srv}timeout' are deprecated
16243 - BUG/MINOR: auth: fix wrong return type in pat_match_auth()
16244 - BUILD: config: remove a warning with clang
16245 - BUG/MAJOR: http: connection setup may stall on balance url_param
16246 - BUG/MEDIUM: http/session: disable client-side expiration only after body
16247 - BUG/MEDIUM: http: correctly report request body timeouts
16248 - BUG/MEDIUM: http: disable server-side expiration until client has sent the body
16249 - MEDIUM: listener: make the accept function more robust against pauses
16250 - BUILD: syscalls: remove improper inline statement in front of syscalls
16251 - BUILD: ssl: SSL_CTX_set_msg_callback() needs openssl >= 0.9.7
16252 - BUG/MAJOR: session: recover the correct connection pointer in half-initialized sessions
16253 - DOC: add some explanation on the shared cache build options in the readme.
16254 - MEDIUM: proxy: only adjust the backend's bind-process when already set
16255 - MEDIUM: config: limit nbproc to the machine's word size
16256 - MEDIUM: config: check the bind-process settings according to nbproc
16257 - MEDIUM: listener: parse the new "process" bind keyword
16258 - MEDIUM: listener: inherit the process mask from the proxy
16259 - MAJOR: listener: only start listeners bound to the same processes
16260 - MINOR: config: only report a warning when stats sockets are bound to more than 1 process
16261 - CLEANUP: config: set the maxaccept value for peers listeners earlier
16262 - BUG/MINOR: backend: only match IPv4 addresses with RDP cookies
16263 - BUG/MINOR: checks: correctly configure the address family and protocol
16264 - MINOR: tools: split is_addr() and is_inet_addr()
16265 - MINOR: protocols: use is_inet_addr() when only INET addresses are desired
16266 - MEDIUM: unix: add preliminary support for connecting to servers over UNIX sockets
16267 - MEDIUM: checks: only complain about the missing port when the check uses TCP
16268 - MEDIUM: unix: implement support for Linux abstract namespace sockets
16269 - DOC: map_beg was missing from the table of map_* converters
16270 - DOC: ebtree: indicate that prefix insertion/lookup may be used with strings
16271 - MEDIUM: pattern: use ebtree's longest match to index/lookup string beginning
16272 - BUILD: remove the obsolete BSD and OSX makefiles
16273 - MEDIUM: unix: avoid a double connect probe when no data are sent
16274 - DOC: stop referencing the slow git repository in the README
16275 - BUILD: only build the systemd wrapper on Linux 2.6 and above
16276 - DOC: update roadmap with completed tasks
16277 - MEDIUM: session: implement half-closed timeouts (client-fin and server-fin)
16278
Willy Tarreau8860dcd2014-04-26 00:08:14 +0200162792014/04/26 : 1.5-dev24
16280 - MINOR: pattern: find element in a reference
16281 - MEDIUM: http: ACL and MAP updates through http-(request|response) rules
16282 - MEDIUM: ssl: explicitly log failed handshakes after a heartbeat
16283 - DOC: Full section dedicated to the converters
16284 - MEDIUM: http: register http-request and http-response keywords
16285 - BUG/MINOR: compression: correctly report incoming byte count
16286 - BUG/MINOR: http: don't report server aborts as client aborts
16287 - BUG/MEDIUM: channel: bi_putblk() must not wrap before the end of buffer
16288 - CLEANUP: buffers: remove unused function buffer_contig_space_with_res()
16289 - MEDIUM: stats: reimplement HTTP keep-alive on the stats page
16290 - BUG/MAJOR: http: fix timeouts during data forwarding
16291 - BUG/MEDIUM: http: 100-continue responses must process the next part immediately
16292 - MEDIUM: http: move skipping of 100-continue earlier
16293 - BUILD: stats: let gcc know that last_fwd cannot be used uninitialized...
16294 - CLEANUP: general: get rid of all old occurrences of "session *t"
16295 - CLEANUP: http: remove the useless "if (1)" inherited from version 1.4
16296 - BUG/MEDIUM: stats: mismatch between behaviour and doc about front/back
16297 - MEDIUM: http: enable analysers to have keep-alive on stats
16298 - REORG: http: move HTTP Connection response header parsing earlier
16299 - MINOR: stats: always emit HTTP/1.1 in responses
16300 - MINOR: http: add capture.req.ver and capture.res.ver
16301 - MINOR: checks: add a new global max-spread-checks directive
16302 - BUG/MAJOR: http: fix the 'next' pointer when performing a redirect
16303 - MINOR: http: implement the max-keep-alive-queue setting
16304 - DOC: fix alphabetic order of tcp-check
16305 - MINOR: connection: add a new error code for SSL with heartbeat
16306 - MEDIUM: ssl: implement a workaround for the OpenSSL heartbleed attack
16307 - BUG/MEDIUM: Revert "MEDIUM: ssl: Add standardized DH parameters >= 1024 bits"
16308 - BUILD: http: remove a warning on strndup
16309 - BUILD: ssl: avoid a warning about conn not used with OpenSSL < 1.0.1
16310 - BUG/MINOR: ssl: really block OpenSSL's response to heartbleed attack
16311 - MINOR: ssl: finally catch the heartbeats missing the padding
16312
Willy Tarreau8317b282014-04-23 01:49:41 +0200163132014/04/23 : 1.5-dev23
16314 - BUG/MINOR: reject malformed HTTP/0.9 requests
16315 - MINOR: systemd wrapper: re-execute on SIGUSR2
16316 - MINOR: systemd wrapper: improve logging
16317 - MINOR: systemd wrapper: propagate exit status
16318 - BUG/MINOR: tcpcheck connect wrong behavior
16319 - MEDIUM: proxy: support use_backend with dynamic names
16320 - MINOR: stats: Enhancement to stats page to provide information of last session time.
16321 - BUG/MEDIUM: peers: fix key consistency for integer stick tables
16322 - DOC: fix a typo on http-server-close and encapsulate options with double-quotes
16323 - DOC: fix fetching samples syntax
16324 - MINOR: ssl: add ssl_fc_unique_id to fetch TLS Unique ID
16325 - MEDIUM: ssl: Use ALPN support as it will be available in OpenSSL 1.0.2
16326 - DOC: fix typo
16327 - CLEANUP: code style: use tabs to indent codes instead of spaces
16328 - DOC: fix a few config typos.
16329 - BUG/MINOR: raw_sock: also consider ENOTCONN in addition to EAGAIN for recv()
16330 - DOC: lowercase format string in unique-id
16331 - MINOR: set IP_FREEBIND on IPv6 sockets in transparent mode
16332 - BUG/MINOR: acl: req_ssl_sni fails with SSLv3 record version
16333 - BUG/MINOR: build: add missing objects in osx and bsd Makefiles
16334 - BUG/MINOR: build: handle whitespaces in wc -l output
16335 - BUG/MINOR: Fix name lookup ordering when compiled with USE_GETADDRINFO
16336 - MEDIUM: ssl: Add standardized DH parameters >= 1024 bits
16337 - BUG/MEDIUM: map: The map parser includes blank lines.
16338 - BUG/MINOR: log: The log of quotted capture header has been terminated by 2 quotes.
16339 - MINOR: standard: add function "encode_chunk"
16340 - BUG/MINOR: http: fix encoding of samples used in http headers
16341 - MINOR: sample: add hex converter
16342 - MEDIUM: sample: change the behavior of the bin2str cast
16343 - MAJOR: auth: Change the internal authentication system.
16344 - MEDIUM: acl/pattern: standardisation "of pat_parse_int()" and "pat_parse_dotted_ver()"
16345 - MEDIUM: pattern: The pattern parser no more uses <opaque> and just takes one string.
16346 - MEDIUM: pattern: Change the prototype of the function pattern_register().
16347 - CONTRIB: ip6range: add a network IPv6 range to mask converter
16348 - MINOR: pattern: separe list element from the data part.
16349 - MEDIUM: pattern: add indexation function.
16350 - MEDIUM: pattern: The parse functions just return "struct pattern" without memory allocation
16351 - MINOR: pattern: Rename "pat_idx_elt" to "pattern_tree"
16352 - MINOR: sample: dont call the sample cast function "c_none"
16353 - MINOR: standard: Add function for converting cidr to network mask.
16354 - MEDIUM: sample: Remove types SMP_T_CSTR and SMP_T_CBIN, replace it by SMP_F_CONST flags
16355 - MEDIUM: sample/http_proto: Add new type called method
16356 - MINOR: dumpstats: Group map inline help
16357 - MEDIUM: pattern: The function pattern_exec_match() returns "struct pattern" if the patten match.
16358 - MINOR: dumpstats: change map inline sentences
16359 - MINOR: dumpstats: change the "get map" display management
16360 - MINOR: map/dumpstats: The cli cmd "get map ..." display the "int" format.
16361 - MEDIUM: pattern: The match function browse itself the list or the tree.
16362 - MEDIUM: pattern: Index IPv6 addresses in a tree.
16363 - MEDIUM: pattern: add delete functions
16364 - MEDIUM: pattern: add prune function
16365 - MEDIUM: pattern: add sample lookup function.
16366 - MEDIUM: pattern/dumpstats: The function pattern_lookup() is no longer used
16367 - MINOR: map/pattern: The sample parser is stored in the pattern
16368 - MAJOR: pattern/map: Extends the map edition system in the patterns
16369 - MEDIUM: pattern: merge same pattern
16370 - MEDIUM: pattern: The expected type is stored in the pattern head, and conversion is executed once.
16371 - MINOR: pattern: Each pattern is identified by unique id.
16372 - MINOR: pattern/acl: Each pattern of each acl can be load with specified id
16373 - MINOR: pattern: The function "pattern_register()" is no longer used.
16374 - MINOR: pattern: Merge function pattern_add() with pat_ref_push().
16375 - MINOR: pattern: store configuration reference for each acl or map pattern.
16376 - MINOR: pattern: Each pattern expression element store the reference struct.
16377 - MINOR: dumpstats: display the reference for th key/pattern and value.
16378 - MEDIUM: pattern: delete() function uses the pat_ref_elt to find the element to be removed
16379 - MEDIUM: pattern_find_smp: functions find_smp uses the pat_ref_elt to find the element to be removed
16380 - MEDIUM: dumpstats/pattern: display and use each pointer of each pattern dumped
16381 - MINOR: pattern/map/acl: Centralization of the file parsers
16382 - MINOR: pattern: Check if the file reference is not used with acl and map
16383 - MINOR: acl/pattern: Acl "-M" option force to load file as map file with two columns
16384 - MEDIUM: dumpstats: Display error message during add of values.
16385 - MINOR: pattern: The function pat_ref_set() have now atomic behavior
16386 - MINOR: regex: The pointer regstr in the struc regex is no longer used.
16387 - MINOR: cli: Block the usage of the command "acl add" in many cases.
16388 - MINOR: doc: Update the documentation about the map and acl
16389 - MINOR: pattern: index duplicates
16390 - MINOR: configuration: File and line propagation
16391 - MINOR: dumpstat/conf: display all the configuration lines that using pattern reference
16392 - MINOR: standard: Disable ip resolution during the runtime
16393 - MINOR: pattern: Remove the flag "PAT_F_FROM_FILE".
16394 - MINOR: pattern: forbid dns resolutions
16395 - DOC: document "get map" / "get acl" on the CLI
16396 - MEDIUM: acl: Change the acl register struct
16397 - BUG/MEDIUM: acl: boolean only matches were broken by recent changes
16398 - DOC: pattern: pattern organisation schematics
16399 - MINOR: pattern/cli: Update used terms in documentation and cli
16400 - MINOR: cli: remove information about acl or map owner.
16401 - MINOR: session: don't always assume there's a listener
16402 - MINOR: pattern: Add function to prune and reload pattern list.
16403 - MINOR: standard: Add ipv6 support in the function url2sa().
16404 - MEDIUM: config: Dynamic sections.
16405 - BUG/MEDIUM: stick-table: fix IPv4-to-IPv6 conversion in src_* fetches
16406 - MINOR: http: Add the "language" converter to for use with accept-language
16407 - BUG/MINOR: log: Don't dump empty unique-id
16408 - BUG/MAJOR: session: fix a possible crash with src_tracked
16409 - DOC: Update "language" documentation
16410 - MINOR: http: add the function "del-header" to the directives http-request and http-response
16411 - DOC: add some information on capture.(req|res).hdr
16412 - MINOR: http: capture.req.method and capture.req.uri
16413 - MINOR: http: optimize capture.req.method and capture.req.uri
16414 - MINOR: session: clean up the connection free code
16415 - BUG/MEDIUM: checks: immediately report a connection success
16416 - MEDIUM: connection: don't use real send() flags in snd_buf()
16417 - OPTIM: ssl: implement dynamic record size adjustment
16418 - MINOR: stats: report exact last session time in backend too
16419 - BUG/MEDIUM: stats: the "lastsess" field must appear last in the CSV.
16420 - BUG/MAJOR: check: fix memory leak in "tcp-check connect" over SSL
16421 - BUG/MINOR: channel: initialize xfer_small/xfer_large on new buffers
16422 - MINOR: channel: add the date of last read in the channel
16423 - MEDIUM: stream-int: automatically disable CF_STREAMER flags after idle
16424 - MINOR: ssl: add DEFAULT_SSL_MAX_RECORD to set the record size at build time
16425 - MINOR: config: make the stream interface idle timer user-configurable
16426 - MINOR: config: add global directives to set default SSL ciphers
16427 - MINOR: sample: add a rand() sample fetch to return a sample.
16428 - BUG/MEDIUM: config: immediately abort if peers section has no name
16429 - BUG/MINOR: ssl: fix syntax in config error message
16430 - BUG/MEDIUM: ssl: always send a full buffer after EAGAIN
16431 - BUG/MINOR: config: server on-marked-* statement is ignored in default-server
16432 - BUG/MEDIUM: backend: prefer-last-server breaks redispatch
16433 - BUG/MEDIUM: http: continue to emit 503 on keep-alive to different server
16434 - MEDIUM: acl: fix pattern type for payload / payload_lv
16435 - BUG/MINOR: config: fix a crash on startup when a disabled backend references a peer
16436 - BUG/MEDIUM: compression: fix the output type of the compressor name
16437 - BUG/MEDIUM: http: don't start to forward request data before the connect
16438 - MINOR: http: release compression context only in http_end_txn()
16439 - MINOR: protect ebimtree/ebistree against multiple inclusions
16440 - MEDIUM: proxy: create a tree to store proxies by name
16441 - MEDIUM: proxy: make findproxy() use trees to look up proxies
16442 - MEDIUM: proxy: make get_backend_server() use findproxy() to lookup proxies
16443 - MEDIUM: stick-table: lookup table names using trees.
16444 - MEDIUM: config: faster lookup for duplicated proxy name
16445 - CLEANUP: acl: remove obsolete test in parse_acl_expr()
16446 - MINOR: sample: move smp_to_type to sample.c
16447 - MEDIUM: compression: consider the "q=" attribute in Accept-Encoding
16448 - REORG: cfgparse: move server keyword parsing to server.c
16449 - BUILD: adjust makefile for AIX 5.1
16450 - BUG/MEDIUM: pattern: fix wrong definition of the pat_prune_fcts array
16451 - CLEANUP: pattern: move array definitions to proto/ and not types/
16452 - BUG/MAJOR: counters: check for null-deref when looking up an alternate table
16453 - BUILD: ssl: previous patch failed
16454 - BUILD/MEDIUM: standard: get rid of the last strcpy()
16455 - BUILD/MEDIUM: standard: get rid of sprintf()
16456 - BUILD/MEDIUM: cfgparse: get rid of sprintf()
16457 - BUILD/MEDIUM: checks: get rid of sprintf()
16458 - BUILD/MEDIUM: http: remove calls to sprintf()
16459 - BUG/MEDIUM: systemd-wrapper: fix locating of haproxy binary
16460 - BUILD/MINOR: ssl: remove one call to sprintf()
16461 - MEDIUM: http: don't reject anymore message bodies not containing the url param
16462 - MEDIUM: http: wait for the first chunk or message body length in http_process_body
16463 - CLEANUP: http: rename http_process_request_body()
16464 - CLEANUP: http: prepare dedicated processing for chunked encoded message bodies
16465 - MINOR: http: make msg->eol carry the last CRLF length
16466 - MAJOR: http: do not use msg->sol while processing messages or forwarding data
16467 - MEDIUM: http: http_parse_chunk_crlf() must not advance the buffer pointer
16468 - MAJOR: http: don't update msg->sov anymore while processing the body
16469 - MINOR: http: add a small helper to compute the amount of body bytes present
16470 - MEDIUM: http: add a small helper to compute how far to rewind to find headers
16471 - MINOR: http: add a small helper to compute how far to rewind to find URI
16472 - MEDIUM: http: small helpers to compute how far to rewind to find BODY and DATA
16473 - MAJOR: http: reset msg->sov after headers are forwarded
16474 - MEDIUM: http: forward headers again while waiting for connection to complete
16475 - BUG/MINOR: http: deinitialize compression after a parsing error
16476 - BUG/MINOR: http: deinitialize compression after a compression error
16477 - MEDIUM: http: headers must be forwarded even if data was already inspected
16478 - MAJOR: http: re-enable compression on chunked encoding
16479 - MAJOR: http/compression: fix chunked-encoded response processing
16480 - MEDIUM: http: cleanup: centralize a little bit HTTP compression end
16481 - MEDIUM: http: start to centralize the forwarding code
16482 - MINOR: http: further cleanups of response forwarding function
16483 - MEDIUM: http: only allocate the temporary compression buffer when needed
16484 - MAJOR: http: centralize data forwarding in the request path
16485 - CLEANUP: http: document the response forwarding states
16486 - CLEANUP: http: remove all calls to http_silent_debug()
16487 - DOC: internal: add some reminders about HTTP parsing and pointer states
16488 - BUG/MAJOR: http: fix bug in parse_qvalue() when selecting compression algo
16489 - BUG/MINOR: stats: last session was not always set
16490 - DOC: add pointer to the Cyril's HTML doc in the README
16491 - MEDIUM: config: relax use_backend check to make the condition optional
16492 - MEDIUM: config: report misplaced http-request rules
16493 - MEDIUM: config: report misplaced use-server rules
16494 - DOC: update roadmap with what was done.
16495
Willy Tarreau1a34d572014-02-03 00:41:29 +0100164962014/02/03 : 1.5-dev22
16497 - MEDIUM: tcp-check new feature: connect
16498 - MEDIUM: ssl: Set verify 'required' as global default for servers side.
16499 - MINOR: ssl: handshake optim for long certificate chains.
16500 - BUG/MINOR: pattern: pattern comparison executed twice
16501 - BUG/MEDIUM: map: segmentation fault with the stats's socket command "set map ..."
16502 - BUG/MEDIUM: pattern: Segfault in binary parser
16503 - MINOR: pattern: move functions for grouping pat_match_* and pat_parse_* and add documentation.
16504 - MINOR: standard: The parse_binary() returns the length consumed and his documentation is updated
16505 - BUG/MINOR: payload: the patterns of the acl "req.ssl_ver" are no parsed with the good function.
16506 - BUG/MEDIUM: pattern: "pat_parse_dotted_ver()" set bad expect_type.
16507 - BUG/MINOR: sample: The c_str2int converter does not fail if the entry is not an integer
16508 - BUG/MEDIUM: http/auth: Sometimes the authentication credentials can be mix between two requests
16509 - MINOR: doc: Bad cli function name.
16510 - MINOR: http: smp_fetch_capture_header_* fetch captured headers
16511 - BUILD: last release inadvertently prepended a "+" in front of the date
16512 - BUG/MEDIUM: stream-int: fix the keep-alive idle connection handler
16513 - BUG/MEDIUM: backend: do not re-initialize the connection's context upon reuse
16514 - BUG: Revert "OPTIM/MEDIUM: epoll: fuse active events into polled ones during polling changes"
16515 - BUG/MINOR: checks: successful check completion must not re-enable MAINT servers
16516 - MINOR: http: try to stick to same server after status 401/407
16517 - BUG/MINOR: http: always disable compression on HTTP/1.0
16518 - OPTIM: poll: restore polling after a poll/stop/want sequence
16519 - OPTIM: http: don't stop polling for read on the client side after a request
16520 - BUG/MEDIUM: checks: unchecked servers could not be enabled anymore
16521 - BUG/MEDIUM: stats: the web interface must check the tracked servers before enabling
16522 - BUG/MINOR: channel: CHN_INFINITE_FORWARD must be unsigned
16523 - BUG/MINOR: stream-int: do not clear the owner upon unregister
16524 - MEDIUM: stats: add support for HTTP keep-alive on the stats page
16525 - BUG/MEDIUM: stats: fix HTTP/1.0 breakage introduced in previous patch
16526 - Revert "MEDIUM: stats: add support for HTTP keep-alive on the stats page"
16527 - MAJOR: channel: add a new flag CF_WAKE_WRITE to notify the task of writes
16528 - OPTIM: session: set the READ_DONTWAIT flag when connecting
16529 - BUG/MINOR: http: don't clear the SI_FL_DONT_WAKE flag between requests
16530 - MINOR: session: factor out the connect time measurement
16531 - MEDIUM: session: prepare to support earlier transitions to the established state
16532 - MEDIUM: stream-int: make si_connect() return an established state when possible
16533 - MINOR: checks: use an inline function for health_adjust()
16534 - OPTIM: session: put unlikely() around the freewheeling code
16535 - MEDIUM: config: report a warning when multiple servers have the same name
16536 - BUG: Revert "OPTIM: poll: restore polling after a poll/stop/want sequence"
16537 - BUILD/MINOR: listener: remove a glibc warning on accept4()
16538 - BUG/MAJOR: connection: fix mismatch between rcv_buf's API and usage
16539 - BUILD: listener: fix recent accept4() again
16540 - BUG/MAJOR: ssl: fix breakage caused by recent fix abf08d9
16541 - BUG/MEDIUM: polling: ensure we update FD status when there's no more activity
16542 - MEDIUM: listener: fix polling management in the accept loop
16543 - MINOR: protocol: improve the proto->drain() API
16544 - MINOR: connection: add a new conn_drain() function
16545 - MEDIUM: tcp: report in tcp_drain() that lingering is already disabled on close
16546 - MEDIUM: connection: update callers of ctrl->drain() to use conn_drain()
16547 - MINOR: connection: add more error codes to report connection errors
16548 - MEDIUM: tcp: report connection error at the connection level
16549 - MEDIUM: checks: make use of chk_report_conn_err() for connection errors
16550 - BUG/MEDIUM: unique_id: HTTP request counter is not stable
16551 - DOC: fix misleading information about SIGQUIT
16552 - BUG/MAJOR: fix freezes during compression
16553 - BUG/MEDIUM: stream-interface: don't wake the task up before end of transfer
16554 - BUILD: fix VERDATE exclusion regex
16555 - CLEANUP: polling: rename "spec_e" to "state"
16556 - DOC: add a diagram showing polling state transitions
16557 - REORG: polling: rename "spec_e" to "state" and "spec_p" to "cache"
16558 - REORG: polling: rename "fd_spec" to "fd_cache"
16559 - REORG: polling: rename the cache allocation functions
16560 - REORG: polling: rename "fd_process_spec_events()" to "fd_process_cached_events()"
16561 - MAJOR: polling: rework the whole polling system
16562 - MAJOR: connection: remove the CO_FL_WAIT_{RD,WR} flags
16563 - MEDIUM: connection: remove conn_{data,sock}_poll_{recv,send}
16564 - MEDIUM: connection: add check for readiness in I/O handlers
16565 - MEDIUM: stream-interface: the polling flags must always be updated in chk_snd_conn
16566 - MINOR: stream-interface: no need to call fd_stop_both() on error
16567 - MEDIUM: connection: no need to recheck FD state
16568 - CLEANUP: connection: use conn_ctrl_ready() instead of checking the flag
16569 - CLEANUP: connection: use conn_xprt_ready() instead of checking the flag
16570 - CLEANUP: connection: fix comments in connection.h to reflect new behaviour.
16571 - OPTIM: raw-sock: don't speculate after a short read if polling is enabled
16572 - MEDIUM: polling: centralize polled events processing
16573 - MINOR: polling: create function fd_compute_new_polled_status()
16574 - MINOR: cli: add more information to the "show info" output
16575 - MEDIUM: listener: add support for limiting the session rate in addition to the connection rate
16576 - MEDIUM: listener: apply a limit on the session rate submitted to SSL
16577 - REORG: stats: move the stats socket states to dumpstats.c
16578 - MINOR: cli: add the new "show pools" command
16579 - BUG/MEDIUM: counters: flush content counters after each request
16580 - BUG/MEDIUM: counters: fix stick-table entry leak when using track-sc2 in connection
16581 - MINOR: tools: add very basic support for composite pointers
16582 - MEDIUM: counters: stop relying on session flags at all
16583 - BUG/MINOR: cli: fix missing break in command line parser
16584 - BUG/MINOR: config: correctly report when log-format headers require HTTP mode
16585 - MAJOR: http: update connection mode configuration
16586 - MEDIUM: http: make keep-alive + httpclose be passive mode
16587 - MAJOR: http: switch to keep-alive mode by default
16588 - BUG/MEDIUM: http: fix regression caused by recent switch to keep-alive by default
16589 - BUG/MEDIUM: listener: improve detection of non-working accept4()
16590 - BUILD: listener: add fcntl.h and unistd.h
16591 - BUG/MINOR: raw_sock: correctly set the MSG_MORE flag
16592
Willy Tarreau6b07bf72013-12-17 00:45:49 +0100165932013/12/17 : 1.5-dev21
16594 - MINOR: stats: don't use a monospace font to report numbers
16595 - MINOR: session: remove debugging code
16596 - BUG/MAJOR: patterns: fix double free caused by loading strings from files
16597 - MEDIUM: http: make option http_proxy automatically rewrite the URL
16598 - BUG/MEDIUM: http: cook_cnt() forgets to set its output type
16599 - BUG/MINOR: stats: correctly report throttle rate of low weight servers
16600 - BUG/MEDIUM: checks: servers must not start in slowstart mode
16601 - BUG/MINOR: acl: parser must also stop at comma on ACL-only keywords
16602 - MEDIUM: stream-int: implement a very simplistic idle connection manager
16603 - DOC: update the ROADMAP file
16604
Willy Tarreau11f64d62013-12-16 02:32:37 +0100166052013/12/16 : 1.5-dev20
16606 - DOC: add missing options to the manpage
16607 - DOC: add manpage references to all system calls
16608 - DOC: update manpage reference to haproxy-en.txt
16609 - DOC: remove -s and -l options from the manpage
16610 - DOC: missing information for the "description" keyword
16611 - DOC: missing http-send-name-header keyword in keyword table
16612 - MINOR: tools: function my_memmem() to lookup binary contents
16613 - MEDIUM: checks: add send/expect tcp based check
16614 - MEDIUM: backend: Enhance hash-type directive with an algorithm options
16615 - MEDIUM: backend: Implement avalanche as a modifier of the hashing functions.
16616 - DOC: Documentation for hashing function, with test results.
16617 - BUG/MEDIUM: ssl: potential memory leak using verifyhost
16618 - BUILD: ssl: compilation issue with openssl v0.9.6.
16619 - BUG/MINOR: ssl: potential memory leaks using ssl_c_key_alg or ssl_c_sig_alg.
16620 - MINOR: ssl: optimization of verifyhost on wildcard certificates.
16621 - BUG/MINOR: ssl: verifyhost does not match empty strings on wildcard.
16622 - MINOR: ssl: Add statement 'verifyhost' to "server" statements
16623 - CLEANUP: session: remove event_accept() which was not used anymore
16624 - BUG/MINOR: deinit: free fdinfo while doing cleanup
16625 - DOC: minor typo fix in documentation
16626 - BUG/MEDIUM: server: set the macro for server's max weight SRV_UWGHT_MAX to SRV_UWGHT_RANGE
16627 - BUG/MINOR: use the same check condition for server as other algorithms
16628 - DOC: fix typo in comments
16629 - BUG/MINOR: deinit: free server map which is allocated in init_server_map()
16630 - CLEANUP: stream_interface: cleanup loop information in si_conn_send_loop()
16631 - MINOR: buffer: align the last output line of buffer_dump()
16632 - MINOR: buffer: align the last output line if there are less than 8 characters left
16633 - DOC: stick-table: modify the description
16634 - OPTIM: stream_interface: return directly if the connection flag CO_FL_ERROR has been set
16635 - CLEANUP: code style: use tabs to indent codes
16636 - DOC: checkcache: block responses with cacheable cookies
16637 - BUG/MINOR: check_config_validity: check the returned value of stktable_init()
16638 - MEDIUM: haproxy-systemd-wrapper: Use haproxy in same directory
16639 - MEDIUM: systemd-wrapper: Kill child processes when interrupted
16640 - LOW: systemd-wrapper: Write debug information to stdout
16641 - BUG/MINOR: http: fix "set-tos" not working in certain configurations
16642 - MEDIUM: http: add IPv6 support for "set-tos"
16643 - DOC: ssl: update build instructions to use new SSL_* variables
16644 - BUILD/MINOR: systemd: fix compiler warning about unused result
16645 - url32+src - like base32+src but whole url including parameters
16646 - BUG/MINOR: fix forcing fastinter in "on-error"
16647 - CLEANUP: Make parameters of srv_downtime and srv_getinter const
16648 - CLEANUP: Remove unused 'last_slowstart_change' field from struct peer
16649 - MEDIUM: Split up struct server's check element
16650 - MEDIUM: Move result element to struct check
16651 - MEDIUM: Paramatise functions over the check of a server
16652 - MEDIUM: cfgparse: Factor out check initialisation
16653 - MEDIUM: Add state to struct check
16654 - MEDIUM: Move health element to struct check
16655 - MEDIUM: Add helper for task creation for checks
16656 - MEDIUM: Add helper function for failed checks
16657 - MEDIUM: Log agent fail, stopped or down as info
16658 - MEDIUM: Remove option lb-agent-chk
16659 - MEDIUM: checks: Add supplementary agent checks
16660 - MEDIUM: Do not mark a server as down if the agent is unavailable
16661 - MEDIUM: Set rise and fall of agent checks to 1
16662 - MEDIUM: Add enable and disable agent unix socket commands
16663 - MEDIUM: Add DRAIN state and report it on the stats page
16664 - BUILD/MINOR: missing header file
16665 - CLEANUP: regex: Create regex_comp function that compiles regex using compilation options
16666 - CLEANUP: The function "regex_exec" needs the string length but in many case they expect null terminated char.
16667 - MINOR: http: some exported functions were not in the header file
16668 - MINOR: http: change url_decode to return the size of the decoded string.
16669 - BUILD/MINOR: missing header file
16670 - BUG/MEDIUM: sample: The function v4tov6 cannot support input and output overlap
16671 - BUG/MINOR: arg: fix error reporting for add-header/set-header sample fetch arguments
16672 - MINOR: sample: export the generic sample conversion parser
16673 - MINOR: sample: export sample_casts
16674 - MEDIUM: acl: use the fetch syntax 'fetch(args),conv(),conv()' into the ACL keyword
16675 - MINOR: stick-table: use smp_expr_output_type() to retrieve the output type of a "struct sample_expr"
16676 - MINOR: sample: provide the original sample_conv descriptor struct to the argument checker function.
16677 - MINOR: tools: Add a function to convert buffer to an ipv6 address
16678 - MINOR: acl: export acl arrays
16679 - MINOR: acl: Extract the pattern parsing and indexation from the "acl_read_patterns_from_file()" function
16680 - MINOR: acl: Extract the pattern matching function
16681 - MINOR: sample: Define new struct sample_storage
16682 - MEDIUM: acl: associate "struct sample_storage" to each "struct acl_pattern"
16683 - REORG: acl/pattern: extract pattern matching from the acl file and create pattern.c
16684 - MEDIUM: pattern: create pattern expression
16685 - MEDIUM: pattern: rename "acl" prefix to "pat"
16686 - MEDIUM: sample: let the cast functions set their output type
16687 - MINOR: sample: add a private field to the struct sample_conv
16688 - MINOR: map: Define map types
16689 - MEDIUM: sample: add the "map" converter
16690 - MEDIUM: http: The redirect strings follows the log format rules.
16691 - BUG/MINOR: acl: acl parser does not recognize empty converter list
16692 - BUG/MINOR: map: The map list was declared in the map.h file
16693 - MINOR: map: Cleanup the initialisation of map descriptors.
16694 - MEDIUM: map: merge identical maps
16695 - BUG/MEDIUM: pattern: Pattern node has type of "struct pat_idx_elt" in place of "struct eb_node"
16696 - BUG/MEDIUM: map: Bad map file parser
16697 - CLEANUP/MINOR: standard: use the system define INET6_ADDRSTRLEN in place of MAX_IP6_LEN
16698 - BUG/MEDIUM: sample: conversion from str to ipv6 may read data past end
16699 - MINOR: map: export map_get_reference() function
16700 - MINOR: pattern: Each pattern sets the expected input type
16701 - MEDIUM: acl: Last patch change the output type
16702 - MEDIUM: pattern: Extract the index process from the pat_parse_*() functions
16703 - MINOR: standard: The function parse_binary() can use preallocated buffer
16704 - MINOR: regex: Change the struct containing regex
16705 - MINOR: regex: Copy the original regex expression into string.
16706 - MINOR: pattern: add support for compiling patterns for lookups
16707 - MINOR: pattern: make the pattern matching function return a pointer to the matched element
16708 - MINOR: map: export parse output sample functions
16709 - MINOR: pattern: add function to lookup a specific entry in pattern list
16710 - MINOR: pattern/map: Each pattern must free the associated sample
16711 - MEDIUM: dumpstat: make the CLI parser understand the backslash as an escape char
16712 - MEDIUM: map: dynamic manipulation of maps
16713 - BUG/MEDIUM: unique_id: junk in log on empty unique_id
16714 - BUG/MINOR: log: junk at the end of syslog packet
16715 - MINOR: Makefile: provide cscope rule
16716 - DOC: compression: chunk are not compressed anymore
16717 - MEDIUM: session: disable lingering on the server when the client aborts
16718 - BUG/MEDIUM: prevent gcc from moving empty keywords lists into BSS
16719 - DOC: remove the comment saying that SSL certs are not checked on the server side
16720 - BUG: counters: third counter was not stored if others unset
16721 - BUG/MAJOR: http: don't emit the send-name-header when no server is available
16722 - BUG/MEDIUM: http: "option checkcache" fails with the no-cache header
16723 - BUG/MAJOR: http: sample prefetch code was not properly migrated
16724 - BUG/MEDIUM: splicing: fix abnormal CPU usage with splicing
16725 - BUG/MINOR: stream_interface: don't call chk_snd() on polled events
16726 - OPTIM: splicing: use splice() for the last block when relevant
16727 - MEDIUM: sample: handle comma-delimited converter list
16728 - MINOR: sample: fix sample_process handling of unstable data
16729 - CLEANUP: acl: move the 3 remaining sample fetches to samples.c
16730 - MINOR: sample: add a new "date" fetch to return the current date
16731 - MINOR: samples: add the http_date([<offset>]) sample converter.
16732 - DOC: minor improvements to the part on the stats socket.
16733 - MEDIUM: sample: systematically pass the keyword pointer to the keyword
16734 - MINOR: payload: split smp_fetch_rdp_cookie()
16735 - MINOR: counters: factor out smp_fetch_sc*_tracked
16736 - MINOR: counters: provide a generic function to retrieve a stkctr for sc* and src.
16737 - MEDIUM: counters: factor out smp_fetch_sc*_get_gpc0
16738 - MEDIUM: counters: factor out smp_fetch_sc*_gpc0_rate
16739 - MEDIUM: counters: factor out smp_fetch_sc*_inc_gpc0
16740 - MEDIUM: counters: factor out smp_fetch_sc*_clr_gpc0
16741 - MEDIUM: counters: factor out smp_fetch_sc*_conn_cnt
16742 - MEDIUM: counters: factor out smp_fetch_sc*_conn_rate
16743 - MEDIUM: counters: factor out smp_fetch_sc*_conn_cur
16744 - MEDIUM: counters: factor out smp_fetch_sc*_sess_cnt
16745 - MEDIUM: counters: factor out smp_fetch_sc*_sess_rate
16746 - MEDIUM: counters: factor out smp_fetch_sc*_http_req_cnt
16747 - MEDIUM: counters: factor out smp_fetch_sc*_http_req_rate
16748 - MEDIUM: counters: factor out smp_fetch_sc*_http_err_cnt
16749 - MEDIUM: counters: factor out smp_fetch_sc*_http_err_rate
16750 - MEDIUM: counters: factor out smp_fetch_sc*_kbytes_in
16751 - MEDIUM: counters: factor out smp_fetch_sc*_bytes_in_rate
16752 - MEDIUM: counters: factor out smp_fetch_sc*_kbytes_out
16753 - MEDIUM: counters: factor out smp_fetch_sc*_bytes_out_rate
16754 - MEDIUM: counters: factor out smp_fetch_sc*_trackers
16755 - MINOR: session: make the number of stick counter entries more configurable
16756 - MEDIUM: counters: support passing the counter number as a fetch argument
16757 - MEDIUM: counters: support looking up a key in an alternate table
16758 - MEDIUM: cli: adjust the method for feeding frequency counters in tables
16759 - MINOR: cli: make it possible to enter multiple values at once with "set table"
16760 - MINOR: payload: allow the payload sample fetches to retrieve arbitrary lengths
16761 - BUG/MINOR: cli: "clear table" must not kill entries that don't match condition
16762 - MINOR: ssl: use MAXPATHLEN instead of PATH_MAX
16763 - MINOR: config: warn when a server with no specific port uses rdp-cookie
16764 - BUG/MEDIUM: unique_id: HTTP request counter must be unique!
16765 - DOC: add a mention about the limited chunk size
16766 - BUG/MEDIUM: fix broken send_proxy on FreeBSD
16767 - MEDIUM: stick-tables: flush old entries upon soft-stop
16768 - MINOR: tcp: add new "close" action for tcp-response
16769 - MINOR: payload: provide the "res.len" fetch method
16770 - BUILD: add SSL_INC/SSL_LIB variables to force the path to openssl
16771 - MINOR: http: compute response time before processing headers
16772 - BUG/MINOR: acl: fix improper string size assignment in proxy argument
16773 - BUG/MEDIUM: http: accept full buffers on smp_prefetch_http
16774 - BUG/MINOR: acl: implicit arguments of ACL keywords were not properly resolved
16775 - BUG/MEDIUM: session: risk of crash on out of memory conditions
16776 - BUG/MINOR: peers: set the accept date in outgoing connections
16777 - BUG/MEDIUM: tcp: do not skip tracking rules on second pass
16778 - BUG/MEDIUM: acl: do not evaluate next terms after a miss
16779 - MINOR: acl: add a warning when an ACL keyword is used without any value
16780 - MINOR: tcp: don't use tick_add_ifset() when timeout is known to be set
16781 - BUG/MINOR: acl: remove patterns from the tree before freeing them
16782 - MEDIUM: backend: add support for the wt6 hash
16783 - OPTIM/MEDIUM: epoll: fuse active events into polled ones during polling changes
16784 - OPTIM/MINOR: mark the source address as already known on accept()
16785 - BUG/MINOR: stats: don't count tarpitted connections twice
16786 - CLEANUP: http: homogenize processing of denied req counter
16787 - CLEANUP: http: merge error handling for req* and http-request *
16788 - BUG/MEDIUM: http: fix possible parser crash when parsing erroneous "http-request redirect" rules
16789 - BUG/MINOR: http: fix build warning introduced with url32/url32_src
16790 - BUG/MEDIUM: checks: fix slow start regression after fix attempt
16791 - BUG/MAJOR: server: weight calculation fails for map-based algorithms
16792 - MINOR: stats: report correct throttling percentage for servers in slowstart
16793 - OPTIM: connection: fold the error handling with handshake handling
16794 - MINOR: peers: accept to learn strings of different lengths
16795 - BUG/MAJOR: fix haproxy crash when using server tracking instead of checks
16796 - BUG/MAJOR: check: fix haproxy crash during soft-stop/soft-start
16797 - BUG/MINOR: stats: do not report "via" on tracking servers in maintenance
16798 - BUG/MINOR: connection: fix typo in error message report
16799 - BUG/MINOR: backend: fix target address retrieval in transparent mode
16800 - BUG/MINOR: config: report the correct track-sc number in tcp-rules
16801 - BUG/MINOR: log: fix log-format parsing errors
16802 - DOC: add some information about how to apply converters to samples
16803 - MINOR: acl/pattern: use types different from int to clarify who does what.
16804 - MINOR: pattern: import acl_find_match_name() into pattern.h
16805 - MEDIUM: stick-tables: support automatic conversion from ipv4<->ipv6
16806 - MEDIUM: log-format: relax parsing of '%' followed by unsupported characters
16807 - BUG/MINOR: http: usual deinit stuff in last commit
16808 - BUILD: log: silent a warning about isblank() with latest patches
16809 - BUG/MEDIUM: checks: fix health check regression causing them to depend on declaration order
16810 - BUG/MEDIUM: checks: fix a long-standing issue with reporting connection errors
16811 - BUG/MINOR: checks: don't consider errno and use conn->err_code
16812 - BUG/MEDIUM: checks: also update the DRAIN state from the web interface
16813 - MINOR: stats: remove some confusion between the DRAIN state and NOLB
16814 - BUG/MINOR: tcp: check that no error is pending during a connect probe
16815 - BUG/MINOR: connection: check EINTR when sending a PROXY header
16816 - MEDIUM: connection: set the socket shutdown flags on socket errors
16817 - BUG/MEDIUM: acl: fix regression introduced by latest converters support
16818 - MINOR: connection: clear errno prior to checking for errors
16819 - BUG/MINOR: checks: do not trust errno in write event before any syscall
16820 - MEDIUM: checks: centralize error reporting
16821 - OPTIM: checks: don't poll on recv when using plain TCP connects
16822 - OPTIM: checks: avoid setting SO_LINGER twice
16823 - MINOR: tools: add a generic binary hex string parser
16824 - BUG/MEDIUM: checks: tcp-check: do not poll when there's nothing to send
16825 - BUG/MEDIUM: check: tcp-check might miss some outgoing data when socket buffers are full
16826 - BUG/MEDIUM: args: fix double free on error path in argument expression parser
16827 - BUG/MINOR: acl: fix sample expression error reporting
16828 - BUG/MINOR: checks: tcp-check actions are enums, not flags
16829 - MEDIUM: checks: make tcp-check perform multiple send() at once
16830 - BUG/MEDIUM: stick: completely remove the unused flag from the store entries
16831 - OPTIM: ebtree: pack the struct eb_node to avoid holes on 64-bit
16832 - BUG/MEDIUM: stick-tables: complete the latest fix about store-responses
16833 - CLEANUP: stream_interface: remove unused field err_loc
16834 - MEDIUM: stats: don't use conn->xprt_st anymore
16835 - MINOR: session: add a simple function to retrieve a session from a task
16836 - MEDIUM: stats: don't use conn->xprt_ctx anymore
16837 - MEDIUM: peers: don't rely on conn->xprt_ctx anymore
16838 - MINOR: http: prevent smp_fetch_url_{ip,port} from using si->conn
16839 - MINOR: connection: make it easier to emit proxy protocol for unknown addresses
16840 - MEDIUM: stats: prepare the HTTP stats I/O handler to support more states
16841 - MAJOR: stats: move the HTTP stats handling to its applet
16842 - MEDIUM: stats: move request argument processing to the final step
16843 - MEDIUM: session: detect applets from the session by using s->target
16844 - MAJOR: session: check for a connection to an applet in sess_prepare_conn_req()
16845 - MAJOR: session: pass applet return traffic through the response analysers
16846 - MEDIUM: stream-int: split the shutr/shutw functions between applet and conn
16847 - MINOR: stream-int: make the shutr/shutw functions void
16848 - MINOR: obj: provide a safe and an unsafe access to pointed objects
16849 - MINOR: connection: add a field to store an object type
16850 - MINOR: connection: always initialize conn->objt_type to OBJ_TYPE_CONN
16851 - MEDIUM: stream interface: move the peers' ptr into the applet context
16852 - MINOR: stream-interface: move the applet context to its own struct
16853 - MINOR: obj: introduce a new type appctx
16854 - MINOR: stream-int: rename ->applet to ->appctx
16855 - MINOR: stream-int: split si_prepare_embedded into si_prepare_none and si_prepare_applet
16856 - MINOR: stream-int: add a new pointer to the end point
16857 - MEDIUM: stream-interface: set the pointer to the applet into the applet context
16858 - MAJOR: stream interface: remove the ->release function pointer
16859 - MEDIUM: stream-int: make ->end point to the connection or the appctx
16860 - CLEANUP: stream-int: remove obsolete si_ctrl function
16861 - MAJOR: stream-int: stop using si->conn and use si->end instead
16862 - MEDIUM: stream-int: do not allocate a connection in parallel to applets
16863 - MEDIUM: session: attach incoming connection to target on embryonic sessions
16864 - MINOR: connection: add conn_init() to (re)initialize a connection
16865 - MINOR: checks: call conn_init() to properly initialize the connection.
16866 - MINOR: peers: make use of conn_init() to initialize the connection
16867 - MINOR: session: use conn_init() to initialize the connections
16868 - MINOR: http: use conn_init() to reinitialize the server connection
16869 - MEDIUM: connection: replace conn_prepare with conn_assign
16870 - MINOR: get rid of si_takeover_conn()
16871 - MINOR: connection: add conn_new() / conn_free()
16872 - MAJOR: connection: add two new flags to indicate readiness of control/transport
16873 - MINOR: stream-interface: introduce si_reset() and si_set_state()
16874 - MINOR: connection: reintroduce conn_prepare to set the protocol and transport
16875 - MINOR: connection: replace conn_assign with conn_attach
16876 - MEDIUM: stream-interface: introduce si_attach_conn to replace si_prepare_conn
16877 - MAJOR: stream interface: dynamically allocate the outgoing connection
16878 - MEDIUM: connection: move the send_proxy offset to the connection
16879 - MINOR: connection: check for send_proxy during the connect(), not the SI
16880 - MEDIUM: connection: merge the send_proxy and local_send_proxy calls
16881 - MEDIUM: stream-int: replace occurrences of si->appctx with si_appctx()
16882 - MEDIUM: stream-int: return the allocated appctx in stream_int_register_handler()
16883 - MAJOR: stream-interface: dynamically allocate the applet context
16884 - MEDIUM: session: automatically register the applet designated by the target
16885 - MEDIUM: stats: delay appctx initialization
16886 - CLEANUP: peers: use less confusing state/status code names
16887 - MEDIUM: peers: delay appctx initialization
16888 - MINOR: stats: provide some appctx information in "show sess all"
16889 - DIET/MINOR: obj: pack the obj_type enum to 8 bits
16890 - DIET/MINOR: connection: rearrange a few fields to save 8 bytes in the struct
16891 - DIET/MINOR: listener: rearrange a few fields in struct listener to save 16 bytes
16892 - DIET/MINOR: proxy: rearrange a few fields in struct proxy to save 16 bytes
16893 - DIET/MINOR: session: reduce the struct session size by 8 bytes
16894 - DIET/MINOR: stream-int: rearrange a few fields in struct stream_interface to save 8 bytes
16895 - DIET/MINOR: http: reduce the size of struct http_txn by 8 bytes
16896 - MINOR: http: switch the http state to an enum
16897 - MINOR: http: use an enum for the auth method in http_auth_data
16898 - DIET/MINOR: task: reduce struct task size by 8 bytes
16899 - MINOR: stream_interface: add reporting of ressouce allocation errors
16900 - MINOR: session: report lack of resources using the new stream-interface's error code
16901 - BUILD: simplify the date and version retrieval in the makefile
16902 - BUILD: prepare the makefile to skip format lines in SUBVERS and VERDATE
16903 - BUILD: use format tags in VERDATE and SUBVERS files
16904 - BUG/MEDIUM: channel: bo_getline() must wait for \n until buffer is full
16905 - CLEANUP: check: server port is unsigned
16906 - BUG/MEDIUM: checks: agent doesn't get the response if server does not closes
16907 - MINOR: tools: buf2ip6 must not modify output on failure
16908 - MINOR: pattern: do not assign SMP_TYPES by default to patterns
16909 - MINOR: sample: make sample_parse_expr() use memprintf() to report parse errors
16910 - MINOR: arg: improve wording on error reporting
16911 - BUG/MEDIUM: sample: simplify and fix the argument parsing
16912 - MEDIUM: acl: fix the argument parser to let the lower layer report detailed errors
16913 - MEDIUM: acl: fix the initialization order of the ACL expression
16914 - CLEANUP: acl: remove useless blind copy-paste from sample converters
16915 - TESTS: add regression tests for ACL and sample expression parsers
16916 - BUILD: time: adapt the type of TV_ETERNITY to the local system
16917 - MINOR: chunks: allocate the trash chunks before parsing the config
16918 - BUILD: definitely silence some stupid GCC warnings
16919 - MINOR: chunks: always initialize the output chunk in get_trash_chunk()
16920 - MINOR: checks: improve handling of the servers tracking chain
16921 - REORG: checks: retrieve the check-specific defines from server.h to checks.h
16922 - MINOR: checks: use an enum instead of flags to report a check result
16923 - MINOR: checks: rename the state flags
16924 - MINOR: checks: replace state DISABLED with CONFIGURED and ENABLED
16925 - MINOR: checks: use check->state instead of srv->state & SRV_CHECKED
16926 - MINOR: checks: fix agent check interval computation
16927 - MINOR: checks: add a PAUSED state for the checks
16928 - MINOR: checks: create the agent tasks even when no check is configured
16929 - MINOR: checks: add a flag to indicate what check is an agent
16930 - MEDIUM: checks: enable agent checks even if health checks are disabled
16931 - BUG/MEDIUM: checks: ensure we can enable a server after boot
16932 - BUG/MEDIUM: checks: tracking servers must not inherit the MAINT flag
16933 - BUG/MAJOR: session: repair tcp-request connection rules
16934 - BUILD: fix SUBVERS extraction in the Makefile
16935 - BUILD: pattern: silence a warning about uninitialized value
16936 - BUILD: log: fix build warning on Solaris
16937 - BUILD: dumpstats: fix build error on Solaris
16938 - DOC: move option pgsql-check to the correct place
16939 - DOC: move option tcp-check to the proper place
16940 - MINOR: connection: add simple functions to report connection readiness
16941 - MEDIUM: connection: centralize handling of nolinger in fd management
16942 - OPTIM: http: set CF_READ_DONTWAIT on response message
16943 - OPTIM: http: do not re-enable reading on client side while closing the server side
16944 - MINOR: config: add option http-keep-alive
16945 - MEDIUM: connection: inform si_alloc_conn() whether existing conn is OK or not
16946 - MAJOR: stream-int: handle the connection reuse in si_connect()
16947 - MAJOR: http: add the keep-alive transition on the server side
16948 - MAJOR: backend: enable connection reuse
16949 - MINOR: http: add option prefer-last-server
16950 - MEDIUM: http: do not report connection errors for second and further requests
16951
Willy Tarreaueab1dc62013-06-17 15:10:25 +0200169522013/06/17 : 1.5-dev19
16953 - MINOR: stats: remove the autofocus on the scope input field
16954 - BUG/MEDIUM: Fix crt-list file parsing error: filtered name was ignored.
16955 - BUG/MEDIUM: ssl: EDH ciphers are not usable if no DH parameters present in pem file.
16956 - BUG/MEDIUM: shctx: makes the code independent on SSL runtime version.
16957 - MEDIUM: ssl: improve crt-list format to support negation
16958 - BUG: ssl: fix crt-list for clients not supporting SNI
16959 - MINOR: stats: show soft-stopped servers in different color
16960 - BUG/MINOR: config: "source" does not work in defaults section
16961 - BUG: regex: fix pcre compile error when using JIT
16962 - MINOR: ssl: add pattern fetch 'ssl_c_sha1'
16963 - BUG: ssl: send payload gets corrupted if tune.ssl.maxrecord is used
16964 - MINOR: show PCRE version and JIT status in -vv
16965 - BUG/MINOR: jit: don't rely on USE flag to detect support
16966 - DOC: readme: add suggestion to link against static openssl
16967 - DOC: examples: provide simplified ssl configuration
16968 - REORG: tproxy: prepare the transparent proxy defines for accepting other OSes
16969 - MINOR: tproxy: add support for FreeBSD
16970 - MINOR: tproxy: add support for OpenBSD
16971 - DOC: examples: provide an example of transparent proxy configuration for FreeBSD 8
16972 - CLEANUP: fix minor typo in error message.
16973 - CLEANUP: fix missing include <string.h> in proto/listener.h
16974 - CLEANUP: protect checks.h from multiple inclusions
16975 - MINOR: compression: acl "res.comp" and fetch "res.comp_algo"
16976 - BUG/MINOR: http: add-header/set-header did not accept the ACL condition
16977 - BUILD: mention in the Makefile that USE_PCRE_JIT is for libpcre >= 8.32
16978 - BUG/MEDIUM: splicing is broken since 1.5-dev12
16979 - BUG/MAJOR: acl: add implicit arguments to the resolve list
16980 - BUG/MINOR: tcp: fix error reporting for TCP rules
16981 - CLEANUP: peers: remove a bit of spaghetti to prepare for the next bugfix
16982 - MINOR: stick-table: allow to allocate an entry without filling it
16983 - BUG/MAJOR: peers: fix an overflow when syncing strings larger than 16 bytes
16984 - MINOR: session: only call http_send_name_header() when changing the server
16985 - MINOR: tcp: report the erroneous word in tcp-request track*
16986 - BUG/MAJOR: backend: consistent hash can loop forever in certain circumstances
16987 - BUG/MEDIUM: log: fix regression on log-format handling
16988 - MEDIUM: log: report file name, line number, and directive name with log-format errors
16989 - BUG/MINOR: cli: "clear table" did not work anymore without a key
16990 - BUG/MINOR: cli: "clear table xx data.xx" does not work anymore
16991 - BUG/MAJOR: http: compression still has defects on chunked responses
16992 - BUG/MINOR: stats: fix confirmation links on the stats interface
16993 - BUG/MINOR: stats: the status bar does not appear anymore after a change
16994 - BUG/MEDIUM: stats: allocate the stats frontend also on "stats bind-process"
16995 - BUG/MEDIUM: stats: fix a regression when dealing with POST requests
16996 - BUG/MINOR: fix unterminated ACL array in compression
16997 - BUILD: last fix broke non-linux platforms
16998 - MINOR: init: indicate the SSL runtime version on -vv.
16999 - BUG/MEDIUM: compression: the deflate algorithm must use global settings as well
17000 - BUILD: stdbool is not portable (again)
17001 - DOC: readme: add a small reminder about restrictions to respect in the code
17002 - MINOR: ebtree: add new eb_next_dup/eb_prev_dup() functions to visit duplicates
17003 - BUG/MINOR: acl: fix a double free during exit when using PCRE_JIT
17004 - DOC: fix wrong copy-paste in the rspdel example
17005 - MINOR: counters: make it easier to extend the amount of tracked counters
17006 - MEDIUM: counters: add support for tracking a third counter
17007 - MEDIUM: counters: add a new "gpc0_rate" counter in stick-tables
17008 - BUG/MAJOR: http: always ensure response buffer has some room for a response
17009 - MINOR: counters: add fetch/acl sc*_tracked to indicate whether a counter is tracked
17010 - MINOR: defaults: allow REQURI_LEN and CAPTURE_LEN to be redefined
17011 - MINOR: log: add a new flag 'L' for locally processed requests
17012 - MINOR: http: add full-length header fetch methods
17013 - MEDIUM: protocol: implement a "drain" function in protocol layers
17014 - MEDIUM: http: add a new "http-response" ruleset
17015 - MEDIUM: http: add the "set-nice" action to http-request and http-response
17016 - MEDIUM: log: add a log level override value in struct session
17017 - MEDIUM: http: add support for action "set-log-level" in http-request/http-response
17018 - MEDIUM: http: add support for "set-tos" in http-request/http-response
17019 - MEDIUM: http: add the "set-mark" action on http-request/http-response rules
17020 - MEDIUM: tcp: add "tcp-request connection expect-proxy layer4"
17021 - MEDIUM: acl: automatically detect the type of certain fetches
17022 - MEDIUM: acl: remove a lot of useless ACLs that are equivalent to their fetches
17023 - MEDIUM: acl: remove 15 additional useless ACLs that are equivalent to their fetches
17024 - DOC: major reorg of ACL + sample fetch
17025 - CLEANUP: http: remove the bogus urlp_ip ACL match
17026 - MINOR: acl: add the new "env()" fetch method to retrieve an environment variable
17027 - BUG/MINOR: acl: correctly consider boolean fetches when doing casts
17028 - BUG/CRITICAL: fix a possible crash when using negative header occurrences
17029 - DOC: update ROADMAP file
17030 - MEDIUM: counters: use sc0/sc1/sc2 instead of sc1/sc2/sc3
17031 - MEDIUM: stats: add proxy name filtering on the statistic page
17032
Willy Tarreau289dd922013-04-03 02:26:31 +0200170332013/04/03 : 1.5-dev18
17034 - DOCS: Add explanation of intermediate certs to crt paramater
17035 - DOC: typo and minor fixes in compression paragraph
17036 - MINOR: config: http-request configuration error message misses new keywords
17037 - DOC: minor typo fix in documentation
17038 - BUG/MEDIUM: ssl: ECDHE ciphers not usable without named curve configured.
17039 - MEDIUM: ssl: add bind-option "strict-sni"
17040 - MEDIUM: ssl: add mapping from SNI to cert file using "crt-list"
17041 - MEDIUM: regex: Use PCRE JIT in acl
17042 - DOC: simplify bind option "interface" explanation
17043 - DOC: tfo: bump required kernel to linux-3.7
17044 - BUILD: add explicit support for TFO with USE_TFO
17045 - MEDIUM: New cli option -Ds for systemd compatibility
17046 - MEDIUM: add haproxy-systemd-wrapper
17047 - MEDIUM: add systemd service
17048 - BUG/MEDIUM: systemd-wrapper: don't leak zombie processes
17049 - BUG/MEDIUM: remove supplementary groups when changing gid
17050 - BUG/MEDIUM: config: fix parser crash with bad bind or server address
17051 - BUG/MINOR: Correct logic in cut_crlf()
17052 - CLEANUP: checks: Make desc argument to set_server_check_status const
17053 - CLEANUP: dumpstats: Make cli_release_handler() static
17054 - MEDIUM: server: Break out set weight processing code
17055 - MEDIUM: server: Allow relative weights greater than 100%
17056 - MEDIUM: server: Tighten up parsing of weight string
17057 - MEDIUM: checks: Add agent health check
17058 - BUG/MEDIUM: ssl: openssl 0.9.8 doesn't open /dev/random before chroot
17059 - BUG/MINOR: time: frequency counters are not totally accurate
17060 - BUG/MINOR: http: don't process abortonclose when request was sent
17061 - BUG/MEDIUM: stream_interface: don't close outgoing connections on shutw()
17062 - BUG/MEDIUM: checks: ignore late resets after valid responses
17063 - DOC: fix bogus recommendation on usage of gpc0 counter
17064 - BUG/MINOR: http-compression: lookup Cache-Control in the response, not the request
17065 - MINOR: signal: don't block SIGPROF by default
17066 - OPTIM: epoll: make use of EPOLLRDHUP
17067 - OPTIM: splice: detect shutdowns and avoid splice() == 0
17068 - OPTIM: splice: assume by default that splice is working correctly
17069 - BUG/MINOR: log: temporary fix for lost SSL info in some situations
17070 - BUG/MEDIUM: peers: only the last peers section was used by tables
17071 - BUG/MEDIUM: config: verbosely reject peers sections with multiple local peers
17072 - BUG/MINOR: epoll: use a fix maxevents argument in epoll_wait()
17073 - BUG/MINOR: config: fix improper check for failed memory alloc in ACL parser
17074 - BUG/MINOR: config: free peer's address when exiting upon parsing error
17075 - BUG/MINOR: config: check the proper variable when parsing log minlvl
17076 - BUG/MEDIUM: checks: ensure the health_status is always within bounds
17077 - BUG/MINOR: cli: show sess should always validate s->listener
17078 - BUG/MINOR: log: improper NULL return check on utoa_pad()
17079 - CLEANUP: http: remove a useless null check
17080 - CLEANUP: tcp/unix: remove useless NULL check in {tcp,unix}_bind_listener()
17081 - BUG/MEDIUM: signal: signal handler does not properly check for signal bounds
17082 - BUG/MEDIUM: tools: off-by-one in quote_arg()
17083 - BUG/MEDIUM: uri_auth: missing NULL check and memory leak on memory shortage
17084 - BUG/MINOR: unix: remove the 'level' field from the ux struct
17085 - CLEANUP: http: don't try to deinitialize http compression if it fails before init
17086 - CLEANUP: config: slowstart is never negative
17087 - CLEANUP: config: maxcompcpuusage is never negative
17088 - BUG/MEDIUM: log: emit '-' for empty fields again
17089 - BUG/MEDIUM: checks: fix a race condition between checks and observe layer7
17090 - BUILD: fix a warning emitted by isblank() on non-c99 compilers
17091 - BUILD: improve the makefile's support for libpcre
17092 - MEDIUM: halog: add support for counting per source address (-ic)
17093 - MEDIUM: tools: make str2sa_range support all address syntaxes
17094 - MEDIUM: config: make use of str2sa_range() instead of str2sa()
17095 - MEDIUM: config: use str2sa_range() to parse server addresses
17096 - MEDIUM: config: use str2sa_range() to parse peers addresses
17097 - MINOR: tests: add a config file to ease address parsing tests.
17098 - MINOR: ssl: add a global tunable for the max SSL/TLS record size
17099 - BUG/MINOR: syscall: fix NR_accept4 system call on sparc/linux
17100 - BUILD/MINOR: syscall: add definition of NR_accept4 for ARM
17101 - MINOR: config: report missing peers section name
17102 - BUG/MEDIUM: tools: fix bad character handling in str2sa_range()
17103 - BUG/MEDIUM: stats: never apply "unix-bind prefix" to the global stats socket
17104 - MINOR: tools: prepare str2sa_range() to return an error message
17105 - BUG/MEDIUM: checks: don't call connect() on unsupported address families
17106 - MINOR: tools: prepare str2sa_range() to accept a prefix
17107 - MEDIUM: tools: make str2sa_range() parse unix addresses too
17108 - MEDIUM: config: make str2listener() use str2sa_range() to parse unix addresses
17109 - MEDIUM: config: use a single str2sa_range() call to parse bind addresses
17110 - MEDIUM: config: use str2sa_range() to parse log addresses
17111 - CLEANUP: tools: remove str2sun() which is not used anymore.
17112 - MEDIUM: config: add complete support for str2sa_range() in dispatch
17113 - MEDIUM: config: add complete support for str2sa_range() in server addr
17114 - MEDIUM: config: add complete support for str2sa_range() in 'server'
17115 - MEDIUM: config: add complete support for str2sa_range() in 'peer'
17116 - MEDIUM: config: add complete support for str2sa_range() in 'source' and 'usesrc'
17117 - CLEANUP: minor cleanup in str2sa_range() and str2ip()
17118 - CLEANUP: config: do not use multiple errmsg at once
17119 - MEDIUM: tools: support specifying explicit address families in str2sa_range()
17120 - MAJOR: listener: support inheriting a listening fd from the parent
17121 - MAJOR: tools: support environment variables in addresses
17122 - BUG/MEDIUM: http: add-header should not emit "-" for empty fields
17123 - BUG/MEDIUM: config: ACL compatibility check on "redirect" was wrong
17124 - BUG/MEDIUM: http: fix another issue caused by http-send-name-header
17125 - DOC: mention the new HTTP 307 and 308 redirect statues
17126 - MEDIUM: poll: do not use FD_* macros anymore
17127 - BUG/MAJOR: ev_select: disable the select() poller if maxsock > FD_SETSIZE
17128 - BUG/MINOR: acl: ssl_fc_{alg,use}_keysize must parse integers, not strings
17129 - BUG/MINOR: acl: ssl_c_used, ssl_fc{,_has_crt,_has_sni} take no pattern
17130 - BUILD: fix usual isdigit() warning on solaris
17131 - BUG/MEDIUM: tools: vsnprintf() is not always reliable on Solaris
17132 - OPTIM: buffer: remove one jump in buffer_count()
17133 - OPTIM: http: improve branching in chunk size parser
17134 - OPTIM: http: optimize the response forward state machine
17135 - BUILD: enable poll() by default in the makefile
17136 - BUILD: add explicit support for Mac OS/X
17137 - BUG/MAJOR: http: use a static storage for sample fetch context
17138 - BUG/MEDIUM: ssl: improve error processing and reporting in ssl_sock_load_cert_list_file()
17139 - BUG/MAJOR: http: fix regression introduced by commit a890d072
17140 - BUG/MAJOR: http: fix regression introduced by commit d655ffe
17141 - BUG/CRITICAL: using HTTP information in tcp-request content may crash the process
17142 - MEDIUM: acl: remove flag ACL_MAY_LOOKUP which is improperly used
17143 - MEDIUM: samples: use new flags to describe compatibility between fetches and their usages
17144 - MINOR: log: indicate it when some unreliable sample fetches are logged
17145 - MEDIUM: samples: move payload-based fetches and ACLs to their own file
17146 - MINOR: backend: rename sample fetch functions and declare the sample keywords
17147 - MINOR: frontend: rename sample fetch functions and declare the sample keywords
17148 - MINOR: listener: rename sample fetch functions and declare the sample keywords
17149 - MEDIUM: http: unify acl and sample fetch functions
17150 - MINOR: session: rename sample fetch functions and declare the sample keywords
17151 - MAJOR: acl: make all ACLs reference the fetch function via a sample.
17152 - MAJOR: acl: remove the arg_mask from the ACL definition and use the sample fetch's
17153 - MAJOR: acl: remove fetch argument validation from the ACL struct
17154 - MINOR: http: add new direction-explicit sample fetches for headers and cookies
17155 - MINOR: payload: add new direction-explicit sample fetches
17156 - CLEANUP: acl: remove ACL hooks which were never used
17157 - MEDIUM: proxy: remove acl_requires and just keep a flag "http_needed"
17158 - MINOR: sample: provide a function to report the name of a sample check point
17159 - MAJOR: acl: convert all ACL requires to SMP use+val instead of ->requires
17160 - CLEANUP: acl: remove unused references to ACL_USE_*
17161 - MINOR: http: replace acl_parse_ver with acl_parse_str
17162 - MEDIUM: acl: move the ->parse, ->match and ->smp fields to acl_expr
17163 - MAJOR: acl: add option -m to change the pattern matching method
17164 - MINOR: acl: remove the use_count in acl keywords
17165 - MEDIUM: acl: have a pointer to the keyword name in acl_expr
17166 - MEDIUM: acl: support using sample fetches directly in ACLs
17167 - MEDIUM: http: remove val_usr() to validate user_lists
17168 - MAJOR: sample: maintain a per-proxy list of the fetch args to resolve
17169 - MINOR: ssl: add support for the "alpn" bind keyword
17170 - MINOR: http: status code 303 is HTTP/1.1 only
17171 - MEDIUM: http: implement redirect 307 and 308
17172 - MINOR: http: status 301 should not be marked non-cacheable
17173
Willy Tarreaua3ecbd92012-12-28 15:04:05 +0100171742012/12/28 : 1.5-dev17
17175 - MINOR: ssl: Setting global tune.ssl.cachesize value to 0 disables SSL session cache.
17176 - BUG/MEDIUM: stats: fix stats page regression introduced by commit 20b0de5
17177 - BUG/MINOR: stats: last fix was still wrong
17178 - BUG/MINOR: stats: http-request rules still don't cope with stats
17179 - BUG/MINOR: http: http-request add-header emits a corrupted header
17180 - BUG/MEDIUM: stats: disable request analyser when processing POST or HEAD
17181 - BUG/MINOR: log: make log-format, unique-id-format and add-header more independant
17182 - BUILD: log: unused variable svid
17183 - CLEANUP: http: rename the misleading http_check_access_rule
17184 - MINOR: http: move redirect rule processing to its own function
17185 - REORG: config: move the http redirect rule parser to proto_http.c
17186 - MEDIUM: http: add support for "http-request redirect" rules
17187 - MEDIUM: http: add support for "http-request tarpit" rule
17188
Willy Tarreau69eda352012-12-24 16:48:14 +0100171892012/12/24 : 1.5-dev16
17190 - BUG/MEDIUM: ssl: Prevent ssl error from affecting other connections.
17191 - BUG/MINOR: ssl: error is not reported if it occurs simultaneously with peer close detection.
17192 - MINOR: ssl: add fetch and acl "ssl_c_used" to check if current SSL session uses a client certificate.
17193 - MINOR: contrib: make the iprange tool grep for addresses
17194 - CLEANUP: polling: gcc doesn't always optimize constants away
17195 - OPTIM: poll: optimize fd management functions for low register count CPUs
17196 - CLEANUP: poll: remove a useless double-check on fdtab[fd].owner
17197 - OPTIM: epoll: use a temp variable for intermediary flag computations
17198 - OPTIM: epoll: current fd does not count as a new one
17199 - BUG/MINOR: poll: the I/O handler was called twice for polled I/Os
17200 - MINOR: http: make resp_ver and status ACLs check for the presence of a response
17201 - BUG/MEDIUM: stream-interface: fix possible stalls during transfers
17202 - BUG/MINOR: stream_interface: don't return when the fd is already set
17203 - BUG/MEDIUM: connection: always update connection flags prior to computing polling
17204 - CLEANUP: buffer: use buffer_empty() instead of buffer_len()==0
17205 - BUG/MAJOR: stream_interface: fix occasional data transfer freezes
17206 - BUG/MEDIUM: stream_interface: fix another case where the reader might not be woken up
17207 - BUG/MINOR: http: don't abort client connection on premature responses
17208 - BUILD: no need to clean up when making git-tar
17209 - MINOR: log: add a tag for amount of bytes uploaded from client to server
17210 - BUG/MEDIUM: log: fix possible segfault during config parsing
17211 - MEDIUM: log: change a few log tokens to make them easier to remember
17212 - BUG/MINOR: log: add_to_logformat_list() used the wrong constants
17213 - MEDIUM: log-format: make the format parser more robust and more extensible
17214 - MINOR: sample: support cast from bool to string
17215 - MINOR: samples: add a function to fetch and convert any sample to a string
17216 - MINOR: log: add lf_text_len
17217 - MEDIUM: log: add the ability to include samples in logs
17218 - REORG: stats: massive code reorg and cleanup
17219 - REORG: stats: move the HTTP header injection to proto_http
17220 - REORG: stats: functions are now HTTP/CLI agnostic
17221 - BUG/MINOR: log: fix regression introduced by commit 8a3f52
17222 - MINOR: chunks: centralize the trash chunk allocation
17223 - MEDIUM: stats: use hover boxes instead of title to report details
17224 - MEDIUM: stats: use multi-line tips to display detailed counters
17225 - MINOR: tools: simplify the use of the int to ascii macros
17226 - MINOR: stats: replace STAT_FMT_CSV with STAT_FMT_HTML
17227 - MINOR: http: prepare to support more http-request actions
17228 - MINOR: log: make parse_logformat_string() take a const char *
17229 - MEDIUM: http: add http-request 'add-header' and 'set-header' to build headers
17230
Willy Tarreau0cae4b32012-12-12 00:39:52 +0100172312012/12/12 : 1.5-dev15
17232 - DOC: add a few precisions on compression
17233 - BUG/MEDIUM: ssl: Fix handshake failure on session resumption with client cert.
17234 - BUG/MINOR: ssl: One free session in cache remains unused.
17235 - BUG/MEDIUM: ssl: first outgoing connection would fail with {ca,crt}-ignore-err
17236 - MEDIUM: ssl: manage shared cache by blocks for huge sessions.
17237 - MINOR: acl: add fetch for server session rate
17238 - BUG/MINOR: compression: Content-Type is case insensitive
17239 - MINOR: compression: disable on multipart or status != 200
17240 - BUG/MINOR: http: don't report client aborts as server errors
17241 - MINOR: stats: compute the ratio of compressed response based on 2xx responses
17242 - MINOR: http: factor out the content-type checks
17243 - BUG/MAJOR: stats: correctly check for a possible divide error when showing compression ratios
17244 - BUILD: ssl: OpenSSL 0.9.6 has no renegociation
17245 - BUG/MINOR: http: disable compression when message has no body
17246 - MINOR: compression: make the stats a bit more robust
17247 - BUG/MEDIUM: comp: DEFAULT_MAXZLIBMEM was expressed in bytes and not megabytes
17248 - MINOR: connection: don't remove failed handshake flags
17249 - MEDIUM: connection: add an error code in connections
17250 - MEDIUM: connection: add minimal error reporting in logs for incomplete connections
17251 - MEDIUM: connection: add error reporting for the PROXY protocol header
17252 - MEDIUM: connection: add error reporting for the SSL
17253 - DOC: document the connection error format in logs
17254 - BUG/MINOR: http: don't log a 503 on client errors while waiting for requests
17255 - BUILD: stdbool is not portable
17256 - BUILD: ssl: NAME_MAX is not portable, use MAXPATHLEN instead
17257 - BUG/MAJOR: raw_sock: must check error code on hangup
17258 - BUG/MAJOR: polling: do not set speculative events on ERR nor HUP
17259 - BUG/MEDIUM: session: fix FD leak when transport layer logging is enabled
17260 - MINOR: stats: add a few more information on session dump
17261 - BUG/MINOR: tcp: set the ADDR_TO_SET flag on outgoing connections
17262 - CLEANUP: connection: remove unused server/proxy/task/si_applet declarations
17263 - BUG/MEDIUM: tcp: process could theorically crash on lack of source ports
17264 - MINOR: cfgparse: mention "interface" in the list of allowed "source" options
17265 - MEDIUM: connection: introduce "struct conn_src" for servers and proxies
17266 - CLEANUP: proto_tcp: use the same code to bind servers and backends
17267 - CLEANUP: backend: use the same tproxy address selection code for servers and backends
17268 - BUG/MEDIUM: stick-tables: conversions to strings were broken in dev13
17269 - MEDIUM: proto_tcp: add support for tracking L7 information
17270 - MEDIUM: counters: add sc1_trackers/sc2_trackers
17271 - MINOR: http: add the "base32" pattern fetch function
17272 - MINOR: http: add the "base32+src" fetch method.
17273 - CLEANUP: session: use an array for the stick counters
17274 - BUG/MINOR: proto_tcp: fix parsing of "table" in track-sc1/2
17275 - BUG/MINOR: proto_tcp: bidirectional fetches not supported anymore in track-sc1/2
17276 - BUG/MAJOR: connection: always recompute polling status upon I/O
17277 - BUG/MINOR: connection: remove a few synchronous calls to polling updates
17278 - MINOR: config: improve error checking on TCP stick-table tracking
17279 - DOC: add some clarifications to the readme
17280
Willy Tarreaufee48ce2012-11-26 03:11:05 +0100172812012/11/26 : 1.5-dev14
17282 - DOC: fix minor typos
17283 - BUG/MEDIUM: compression: does not forward trailers
17284 - MINOR: buffer_dump with ASCII
17285 - BUG/MEDIUM: checks: mark the check as stopped after a connect error
17286 - BUG/MEDIUM: checks: ensure we completely disable polling upon success
17287 - BUG/MINOR: checks: don't mark the FD as closed before transport close
17288 - MEDIUM: checks: avoid accumulating TIME_WAITs during checks
17289 - MINOR: cli: report the msg state in full text in "show sess $PTR"
17290 - CLEANUP: checks: rename some server check flags
17291 - MAJOR: checks: rework completely bogus state machine
17292 - BUG/MINOR: checks: slightly clean the state machine up
17293 - MEDIUM: checks: avoid waking the application up for pure TCP checks
17294 - MEDIUM: checks: close the socket as soon as we have a response
17295 - BUG/MAJOR: checks: close FD on all timeouts
17296 - MINOR: checks: fix recv polling after connect()
17297 - MEDIUM: connection: provide a common conn_full_close() function
17298 - BUG/MEDIUM: checks: prevent TIME_WAITs from appearing also on timeouts
17299 - BUG/MAJOR: peers: the listener's maxaccept was not set and caused loops
17300 - MINOR: listeners: make the accept loop more robust when maxaccept==0
17301 - BUG/MEDIUM: acl: correctly resolve all args, not just the first one
17302 - BUG/MEDIUM: acl: make prue_acl_expr() correctly free ACL expressions upon exit
17303 - BUG/MINOR: stats: fix inversion of the report of a check in progress
17304 - MEDIUM: tcp: add explicit support for delayed ACK in connect()
17305 - BUG/MEDIUM: connection: always disable polling upon error
17306 - MINOR: connection: abort earlier when errors are detected
17307 - BUG/MEDIUM: checks: report handshake failures
17308 - BUG/MEDIUM: connection: local_send_proxy must wait for connection to establish
17309 - MINOR: tcp: add support for the "v6only" bind option
17310 - MINOR: stats: also report the computed compression savings in html stats
17311 - MINOR: stats: report the total number of compressed responses per front/back
17312 - MINOR: tcp: add support for the "v4v6" bind option
17313 - DOC: stats: document the comp_rsp stats column
17314 - BUILD: buffer: fix another isprint() warning on solaris
17315 - MINOR: cli: add support for the "show sess all" command
17316 - BUG/MAJOR: cli: show sess <id> may randomly corrupt the back-ref list
17317 - MINOR: cli: improve output format for show sess $ptr
17318
Willy Tarreauad15d122012-11-22 01:11:33 +0100173192012/11/22 : 1.5-dev13
17320 - BUILD: fix build issue without USE_OPENSSL
17321 - BUILD: fix compilation error with DEBUG_FULL
17322 - DOC: ssl: remove prefer-server-ciphers documentation
17323 - DOC: ssl: surround keywords with quotes
17324 - DOC: fix minor typo on http-send-name-header
17325 - BUG/MEDIUM: acls using IPv6 subnets patterns incorrectly match IPs
17326 - BUG/MAJOR: fix a segfault on option http_proxy and url_ip acl
17327 - MEDIUM: http: accept IPv6 values with (s)hdr_ip acl
17328 - BUILD: report zlib support in haproxy -vv
17329 - DOC: compression: add some details and clean up the formatting
17330 - DOC: Change is_ssl acl to ssl_fc acl in example
17331 - DOC: make it clear what the HTTP request size is
17332 - MINOR: ssl: try to load Diffie-Hellman parameters from cert file
17333 - DOC: ssl: update 'crt' statement on 'bind' about Diffie-Hellman parameters loading
17334 - MINOR: ssl: add elliptic curve Diffie-Hellman support for ssl key generation
17335 - DOC: ssl: add 'ecdhe' statement on 'bind'
17336 - MEDIUM: ssl: add client certificate authentication support
17337 - DOC: ssl: add 'verify', 'cafile' and 'crlfile' statements on 'bind'
17338 - MINOR: ssl: add fetch and ACL 'client_crt' to test a client cert is present
17339 - DOC: ssl: add fetch and ACL 'client_cert'
17340 - MINOR: ssl: add ignore verify errors options
17341 - DOC: ssl: add 'ca-ignore-err' and 'crt-ignore-err' statements on 'bind'
17342 - MINOR: ssl: add fetch and ACL 'ssl_verify_result'
17343 - DOC: ssl: add fetch and ACL 'ssl_verify_result'
17344 - MINOR: ssl: add fetches and ACLs to return verify errors
17345 - DOC: ssl: add fetches and ACLs 'ssl_verify_crterr', 'ssl_verify_caerr', and 'ssl_verify_crterr_depth'
17346 - MINOR: ssl: disable shared memory and locks on session cache if nbproc == 1
17347 - MINOR: ssl: add build param USE_PRIVATE_CACHE to build cache without shared memory
17348 - MINOR: ssl : add statements 'notlsv11' and 'notlsv12' and rename 'notlsv1' to 'notlsv10'.
17349 - DOC: ssl : add statements 'notlsv11' and 'notlsv12' and rename 'notlsv1' to 'notlsv10'.
17350 - MEDIUM: config: authorize frontend and listen without bind.
17351 - MINOR: ssl: add statement 'no-tls-tickets' on bind to disable stateless session resumption
17352 - DOC: ssl: add 'no-tls-tickets' statement documentation.
17353 - BUG/MINOR: ssl: Fix CRL check was not enabled when crlfile was specified.
17354 - BUG/MINOR: build: Fix compilation issue on openssl 0.9.6 due to missing CRL feature.
17355 - BUG/MINOR: conf: Fix 'maxsslconn' statement error if built without OPENSSL.
17356 - BUG/MINOR: build: Fix failure with USE_OPENSSL=1 and USE_FUTEX=1 on archs i486 and i686.
17357 - MINOR: ssl: remove prefer-server-ciphers statement and set it as the default on ssl listeners.
17358 - BUG/MEDIUM: ssl: subsequent handshakes fail after server configuration changes
17359 - MINOR: ssl: add 'crt-base' and 'ca-base' global statements.
17360 - MEDIUM: conf: rename 'nosslv3' and 'notlsvXX' statements 'no-sslv3' and 'no-tlsvXX'.
17361 - MEDIUM: conf: rename 'cafile' and 'crlfile' statements 'ca-file' and 'crl-file'
17362 - MINOR: ssl: use bit fields to store ssl options instead of one int each
17363 - MINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on bind.
17364 - MINOR: ssl: add 'force-sslv3' and 'force-tlsvXX' statements on server
17365 - MINOR: ssl: add defines LISTEN_DEFAULT_CIPHERS and CONNECT_DEFAULT_CIPHERS.
17366 - BUG/MINOR: ssl: Fix issue on server statements 'no-tls*' and 'no-sslv3'
17367 - MINOR: ssl: move ssl context init for servers from cfgparse.c to ssl_sock.c
17368 - MEDIUM: ssl: reject ssl server keywords in default-server statement
17369 - MINOR: ssl: add statement 'no-tls-tickets' on server side.
17370 - MINOR: ssl: add statements 'verify', 'ca-file' and 'crl-file' on servers.
17371 - DOC: Fix rename of options cafile and crlfile to ca-file and crl-file.
17372 - MINOR: sample: manage binary to string type convertion in stick-table and samples.
17373 - MINOR: acl: add parse and match primitives to use binary type on ACLs
17374 - MINOR: sample: export 'sample_get_trash_chunk(void)'
17375 - MINOR: conf: rename all ssl modules fetches using prefix 'ssl_fc' and 'ssl_c'
17376 - MINOR: ssl: add pattern and ACLs fetches 'ssl_fc_protocol', 'ssl_fc_cipher', 'ssl_fc_use_keysize' and 'ssl_fc_alg_keysize'
17377 - MINOR: ssl: add pattern fetch 'ssl_fc_session_id'
17378 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_version' and 'ssl_f_version'
17379 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_s_dn', 'ssl_c_i_dn', 'ssl_f_s_dn' and 'ssl_c_i_dn'
17380 - MINOR: ssl: add pattern and ACLs 'ssl_c_sig_alg' and 'ssl_f_sig_alg'
17381 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_key_alg' and 'ssl_f_key_alg'
17382 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_notbefore', 'ssl_c_notafter', 'ssl_f_notbefore' and 'ssl_f_notafter'
17383 - MINOR: ssl: add 'crt' statement on server.
17384 - MINOR: ssl: checks the consistency of a private key with the corresponding certificate
17385 - BUG/MEDIUM: ssl: review polling on reneg.
17386 - BUG/MEDIUM: ssl: Fix some reneg cases not correctly handled.
17387 - BUG/MEDIUM: ssl: Fix sometimes reneg fails if requested by server.
17388 - MINOR: build: allow packagers to specify the ssl cache size
17389 - MINOR: conf: add warning if ssl is not enabled and a certificate is present on bind.
17390 - MINOR: ssl: Add tune.ssl.lifetime statement in global.
17391 - MINOR: compression: Enable compression for IE6 w/SP2, IE7 and IE8
17392 - BUG: http: revert broken optimisation from 82fe75c1a79dac933391501b9d293bce34513755
17393 - DOC: duplicate ssl_sni section
17394 - MEDIUM: HTTP compression (zlib library support)
17395 - CLEANUP: use struct comp_ctx instead of union
17396 - BUILD: remove dependency to zlib.h
17397 - MINOR: compression: memlevel and windowsize
17398 - MEDIUM: use pool for zlib
17399 - MINOR: compression: try init in cfgparse.c
17400 - MINOR: compression: init before deleting headers
17401 - MEDIUM: compression: limit RAM usage
17402 - MINOR: compression: tune.comp.maxlevel
17403 - MINOR: compression: maximum compression rate limit
17404 - MINOR: log-format: check number of arguments in cfgparse.c
17405 - BUG/MEDIUM: compression: no Content-Type header but type in configuration
17406 - BUG/MINOR: compression: deinit zlib only when required
17407 - MEDIUM: compression: don't compress when no data
17408 - MEDIUM: compression: use pool for comp_ctx
17409 - MINOR: compression: rate limit in 'show info'
17410 - MINOR: compression: report zlib memory usage
17411 - BUG/MINOR: compression: dynamic level increase
17412 - DOC: compression: unsupported cases.
17413 - MINOR: compression: CPU usage limit
17414 - MEDIUM: http: add "redirect scheme" to ease HTTP to HTTPS redirection
17415 - BUG/MAJOR: ssl: missing tests in ACL fetch functions
17416 - MINOR: config: add a function to indent error messages
17417 - REORG: split "protocols" files into protocol and listener
17418 - MEDIUM: config: replace ssl_conf by bind_conf
17419 - CLEANUP: listener: remove unused conf->file and conf->line
17420 - MEDIUM: listener: add a minimal framework to register "bind" keyword options
17421 - MEDIUM: config: move the "bind" TCP parameters to proto_tcp
17422 - MEDIUM: move bind SSL parsing to ssl_sock
17423 - MINOR: config: improve error reporting for "bind" lines
17424 - MEDIUM: config: move the common "bind" settings to listener.c
17425 - MEDIUM: config: move all unix-specific bind keywords to proto_uxst.c
17426 - MEDIUM: config: enumerate full list of registered "bind" keywords upon error
17427 - MINOR: listener: add a scope field in the bind keyword lists
17428 - MINOR: config: pass the file and line to config keyword parsers
17429 - MINOR: stats: fill the file and line numbers in the stats frontend
17430 - MINOR: config: set the bind_conf entry on listeners created from a "listen" line.
17431 - MAJOR: listeners: use dual-linked lists to chain listeners with frontends
17432 - REORG: listener: move unix perms from the listener to the bind_conf
17433 - BUG: backend: balance hdr was broken since 1.5-dev11
17434 - MINOR: standard: make memprintf() support a NULL destination
17435 - MINOR: config: make str2listener() use memprintf() to report errors.
17436 - MEDIUM: stats: remove the stats_sock struct from the global struct
17437 - MINOR: ssl: set the listeners' data layer to ssl during parsing
17438 - MEDIUM: stats: make use of the standard "bind" parsers to parse global socket
17439 - DOC: move bind options to their own section
17440 - DOC: stats: refer to "bind" section for "stats socket" settings
17441 - DOC: fix index to reference bind and server options
17442 - BUG: http: do not print garbage on invalid requests in debug mode
17443 - BUG/MINOR: config: check the proper pointer to report unknown protocol
17444 - CLEANUP: connection: offer conn_prepare() to set up a connection
17445 - CLEANUP: config: fix typo inteface => interface
17446 - BUG: stats: fix regression introduced by commit 4348fad1
17447 - MINOR: cli: allow to set frontend maxconn to zero
17448 - BUG/MAJOR: http: chunk parser was broken with buffer changes
17449 - MEDIUM: monitor: simplify handling of monitor-net and mode health
17450 - MINOR: connection: add a pointer to the connection owner
17451 - MEDIUM: connection: make use of the owner instead of container_of
17452 - BUG/MINOR: ssl: report the L4 connection as established when possible
17453 - BUG/MEDIUM: proxy: must not try to stop disabled proxies upon reload
17454 - BUG/MINOR: config: use a copy of the file name in proxy configurations
17455 - BUG/MEDIUM: listener: don't pause protocols that do not support it
17456 - MEDIUM: proxy: add the global frontend to the list of normal proxies
17457 - BUG/MINOR: epoll: correctly disable FD polling in fd_rem()
17458 - MINOR: signal: really ignore signals configured with no handler
17459 - MINOR: buffers: add a few functions to write chars, strings and blocks
17460 - MINOR: raw_sock: always report asynchronous connection errors
17461 - MEDIUM: raw_sock: improve connection error reporting
17462 - REORG: connection: rename the data layer the "transport layer"
17463 - REORG: connection: rename app_cb "data"
17464 - MINOR: connection: provide a generic data layer wakeup callback
17465 - MINOR: connection: split conn_prepare() in two functions
17466 - MINOR: connection: add an init callback to the data_cb struct
17467 - MEDIUM: session: use a specific data_cb for embryonic sessions
17468 - MEDIUM: connection: use a generic data-layer init() callback
17469 - MEDIUM: connection: reorganize connection flags
17470 - MEDIUM: connection: only call the data->wake callback on activity
17471 - MEDIUM: connection: make it possible for data->wake to return an error
17472 - MEDIUM: session: register a data->wake callback to process errors
17473 - MEDIUM: connection: don't call the data->init callback upon error
17474 - MEDIUM: connection: it's not the data layer's role to validate the connection
17475 - MEDIUM: connection: automatically disable polling on error
17476 - REORG: connection: move the PROXY protocol management to connection.c
17477 - MEDIUM: connection: add a new local send-proxy transport callback
17478 - MAJOR: checks: make use of the connection layer to send checks
17479 - REORG: server: move the check-specific parts into a check subsection
17480 - MEDIUM: checks: use real buffers to store requests and responses
17481 - MEDIUM: check: add the ctrl and transport layers in the server check structure
17482 - MAJOR: checks: completely use the connection transport layer
17483 - MEDIUM: checks: add the "check-ssl" server option
17484 - MEDIUM: checks: enable the PROXY protocol with health checks
17485 - CLEANUP: checks: remove minor warnings for assigned but not used variables
17486 - MEDIUM: tcp: enable TCP Fast Open on systems which support it
17487 - BUG: connection: fix regression from commit 9e272bf9
17488 - CLEANUP: cttproxy: remove a warning on undeclared close()
17489 - BUG/MAJOR: ensure that hdr_idx is always reserved when L7 fetches are used
17490 - MEDIUM: listener: add support for linux's accept4() syscall
17491 - MINOR: halog: sort output by cookie code
17492 - BUG/MINOR: halog: -ad/-ac report the correct number of output lines
17493 - BUG/MINOR: halog: fix help message for -ut/-uto
17494 - MINOR: halog: add a parameter to limit output line count
17495 - BUILD: accept4: move the socketcall declaration outside of accept4()
17496 - MINOR: server: add minimal infrastructure to parse keywords
17497 - MINOR: standard: make indent_msg() support empty messages
17498 - MEDIUM: server: check for registered keywords when parsing unknown keywords
17499 - MEDIUM: server: move parsing of keyword "id" to server.c
17500 - BUG/MEDIUM: config: check-send-proxy was ignored if SSL was not builtin
17501 - MEDIUM: ssl: move "server" keyword SSL options parsing to ssl_sock.c
17502 - MEDIUM: log: suffix the frontend's name with '~' when using SSL
17503 - MEDIUM: connection: always unset the transport layer upon close
17504 - BUG/MINOR: session: fix some leftover from debug code
17505 - BUG/MEDIUM: session: enable the conn_session_update() callback
17506 - MEDIUM: connection: add a flag to hold the transport layer
17507 - MEDIUM: log: add a new LW_XPRT flag to pin the transport layer
17508 - MINOR: log: make lf_text use a const char *
17509 - MEDIUM: log: report SSL ciphers and version in logs using logformat %sslc/%sslv
17510 - REORG: http: rename msg->buf to msg->chn since it's a channel
17511 - CLEANUP: http: use 'chn' to name channel variables, not 'buf'
17512 - CLEANUP: channel: use 'chn' instead of 'buf' as local variable names
17513 - CLEANUP: tcp: use 'chn' instead of 'buf' or 'b' for channel pointer names
17514 - CLEANUP: stream_interface: use 'chn' instead of 'b' to name channel pointers
17515 - CLEANUP: acl: use 'chn' instead of 'b' to name channel pointers
17516 - MAJOR: channel: replace the struct buffer with a pointer to a buffer
17517 - OPTIM: channel: reorganize struct members to improve cache efficiency
17518 - CLEANUP: session: remove term_trace which is not used anymore
17519 - OPTIM: session: reorder struct session fields
17520 - OPTIM: connection: pack the struct target
17521 - DOC: document relations between internal entities
17522 - MINOR: ssl: add 'ssl_npn' sample/acl to extract TLS/NPN information
17523 - BUILD: ssl: fix shctx build on older compilers
17524 - MEDIUM: ssl: add support for the "npn" bind keyword
17525 - BUG: ssl: fix ssl_sni ACLs to correctly process regular expressions
17526 - MINOR: chunk: provide string compare functions
17527 - MINOR: sample: accept fetch keywords without parenthesis
17528 - MEDIUM: sample: pass an empty list instead of a null for fetch args
17529 - MINOR: ssl: improve socket behaviour upon handshake abort.
17530 - BUG/MEDIUM: http: set DONTWAIT on data when switching to tunnel mode
17531 - MEDIUM: listener: provide a fallback for accept4() when not supported
17532 - BUG/MAJOR: connection: risk of crash on certain tricky close scenario
17533 - MEDIUM: cli: allow the stats socket to be bound to a specific set of processes
17534 - OPTIM: channel: inline channel_forward's fast path
17535 - OPTIM: http: inline http_parse_chunk_size() and http_skip_chunk_crlf()
17536 - OPTIM: tools: inline hex2i()
17537 - CLEANUP: http: rename HTTP_MSG_DATA_CRLF state
17538 - MINOR: compression: automatically disable compression for older browsers
17539 - MINOR: compression: optimize memLevel to improve byte rate
17540 - BUG/MINOR: http: compression should consider all Accept-Encoding header values
17541 - BUILD: fix coexistence of openssl and zlib
17542 - MINOR: ssl: add pattern and ACLs fetches 'ssl_c_serial' and 'ssl_f_serial'
17543 - BUG/MEDIUM: command-line option -D must have precedence over "debug"
17544 - MINOR: tools: add a clear_addr() function to unset an address
17545 - BUG/MEDIUM: tcp: transparent bind to the source only when address is set
17546 - CLEANUP: remove trashlen
17547 - MAJOR: session: detach the connections from the stream interfaces
17548 - DOC: update document describing relations between internal entities
17549 - BUILD: make it possible to specify ZLIB path
17550 - MINOR: compression: add an offload option to remove the Accept-Encoding header
17551 - BUG: compression: disable auto-close and enable MSG_MORE during transfer
17552 - CLEANUP: completely remove trashlen
17553 - MINOR: chunk: add a function to reset a chunk
17554 - CLEANUP: replace chunk_printf() with chunk_appendf()
17555 - MEDIUM: make the trash be a chunk instead of a char *
17556 - MEDIUM: remove remains of BUFSIZE in HTTP auth and sample conversions
17557 - MEDIUM: stick-table: allocate the table key of size buffer size
17558 - BUG/MINOR: stream_interface: don't loop over ->snd_buf()
17559 - BUG/MINOR: session: ensure that we don't retry connection if some data were sent
17560 - OPTIM: session: don't process the whole session when only timers need a refresh
17561 - BUG/MINOR: session: mark the handshake as complete earlier
17562 - MAJOR: connection: remove the CO_FL_CURR_*_POL flag
17563 - BUG/MAJOR: always clear the CO_FL_WAIT_* flags after updating polling flags
17564 - MAJOR: sepoll: make the poller totally event-driven
17565 - OPTIM: stream_interface: disable reading when CF_READ_DONTWAIT is set
17566 - BUILD: compression: remove a build warning
17567 - MEDIUM: fd: don't unset fdtab[].updated upon delete
17568 - REORG: fd: move the speculative I/O management from ev_sepoll
17569 - REORG: fd: move the fd state management from ev_sepoll
17570 - REORG: fd: centralize the processing of speculative events
17571 - BUG: raw_sock: also consider ENOTCONN in addition to EAGAIN
17572 - BUILD: stream_interface: remove si_fd() and its references
17573 - BUILD: compression: enable build in BSD and OSX Makefiles
17574 - MAJOR: ev_select: make the poller support speculative events
17575 - MAJOR: ev_poll: make the poller support speculative events
17576 - MAJOR: ev_kqueue: make the poller support speculative events
17577 - MAJOR: polling: replace epoll with sepoll and remove sepoll
17578 - MAJOR: polling: remove unused callbacks from the poller struct
17579 - MEDIUM: http: refrain from sending "Connection: close" when Upgrade is present
17580 - CLEANUP: channel: remove any reference of the hijackers
17581 - CLEANUP: stream_interface: remove the external task type target
17582 - MAJOR: connection: replace struct target with a pointer to an enum
17583 - BUG: connection: fix typo in previous commit
17584 - BUG: polling: don't skip polled events in the spec list
17585 - MINOR: splice: disable it when the system returns EBADF
17586 - MINOR: build: allow packagers to specify the default maxzlibmem
17587 - BUG: halog: fix broken output limitation
17588 - BUG: proxy: fix server name lookup in get_backend_server()
17589 - BUG: compression: do not always increment the round counter on allocation failure
17590 - BUG/MEDIUM: compression: release the zlib pools between keep-alive requests
17591 - MINOR: global: don't prevent nbproc from being redefined
17592 - MINOR: config: support process ranges for "bind-process"
17593 - MEDIUM: global: add support for CPU binding on Linux ("cpu-map")
17594 - MINOR: ssl: rename and document the tune.ssl.cachesize option
17595 - DOC: update the PROXY protocol spec to support v2
17596 - MINOR: standard: add a simple popcount function
17597 - MEDIUM: adjust the maxaccept per listener depending on the number of processes
17598 - BUG: compression: properly disable compression when content-type does not match
17599 - MINOR: cli: report connection status in "show sess xxx"
17600 - BUG/MAJOR: stream_interface: certain workloads could cause get stuck
17601 - BUILD: cli: fix build when SSL is enabled
17602 - MINOR: cli: report the fd state in "show sess xxx"
17603 - MINOR: cli: report an error message on missing argument to compression rate
17604 - MINOR: http: add some debugging functions to pretty-print msg state names
17605 - BUG/MAJOR: stream_interface: read0 not always handled since dev12
17606 - DOC: documentation on http header capture is wrong
17607 - MINOR: http: allow the cookie capture size to be changed
17608 - DOC: http header capture has not been limited in size for a long time
17609 - DOC: update readme with build methods for BSD
17610 - BUILD: silence a warning on Solaris about usage of isdigit()
17611 - MINOR: stats: report HTTP compression stats per frontend and per backend
17612 - MINOR: log: add '%Tl' to log-format
17613 - MINOR: samples: update the url_param fetch to match parameters in the path
17614
Willy Tarreau16216822012-09-10 09:46:55 +0200176152012/09/10 : 1.5-dev12
17616 - CONTRIB: halog: sort URLs by avg bytes_read or total bytes_read
17617 - MEDIUM: ssl: add support for prefer-server-ciphers option
17618 - MINOR: IPv6 support for transparent proxy
17619 - MINOR: protocol: add SSL context to listeners if USE_OPENSSL is defined
17620 - MINOR: server: add SSL context to servers if USE_OPENSSL is defined
17621 - MEDIUM: connection: add a new handshake flag for SSL (CO_FL_SSL_WAIT_HS).
17622 - MEDIUM: ssl: add new files ssl_sock.[ch] to provide the SSL data layer
17623 - MEDIUM: config: add the 'ssl' keyword on 'bind' lines
17624 - MEDIUM: config: add support for the 'ssl' option on 'server' lines
17625 - MEDIUM: ssl: protect against client-initiated renegociation
17626 - BUILD: add optional support for SSL via the USE_OPENSSL flag
17627 - MEDIUM: ssl: add shared memory session cache implementation.
17628 - MEDIUM: ssl: replace OpenSSL's session cache with the shared cache
17629 - MINOR: ssl add global setting tune.sslcachesize to set SSL session cache size.
17630 - MEDIUM: ssl: add support for SNI and wildcard certificates
17631 - DOC: Typos cleanup
17632 - DOC: fix name for "option independant-streams"
17633 - DOC: specify the default value for maxconn in the context of a proxy
17634 - BUG/MINOR: to_log erased with unique-id-format
17635 - LICENSE: add licence exception for OpenSSL
17636 - BUG/MAJOR: cookie prefix doesn't support cookie-less servers
17637 - BUILD: add an AIX 5.2 (and later) target.
17638 - MEDIUM: fd/si: move peeraddr from struct fdinfo to struct connection
17639 - MINOR: halog: use the more recent dual-mode fgets2 implementation
17640 - BUG/MEDIUM: ebtree: ebmb_insert() must not call cmp_bits on full-length matches
17641 - CLEANUP: halog: make clean should also remove .o files
17642 - OPTIM: halog: make use of memchr() on platforms which provide a fast one
17643 - OPTIM: halog: improve cold-cache behaviour when loading a file
17644 - BUG/MINOR: ACL implicit arguments must be created with unresolved flag
17645 - MINOR: replace acl_fetch_{path,url}* with smp_fetch_*
17646 - MEDIUM: pattern: add the "base" sample fetch method
17647 - OPTIM: i386: make use of kernel-mode-linux when available
17648 - BUG/MINOR: tarpit: fix condition to return the HTTP 500 message
17649 - BUG/MINOR: polling: some events were not set in various pollers
17650 - MINOR: http: add the urlp_val ACL match
17651 - BUG: stktable: tcp_src_to_stktable_key() must return NULL on invalid families
17652 - MINOR: stats/cli: add plans to support more stick-table actions
17653 - MEDIUM: stats/cli: add support for "set table key" to enter values
17654 - REORG/MEDIUM: fd: remove FD_STCLOSE from struct fdtab
17655 - REORG/MEDIUM: fd: remove checks for FD_STERROR in ev_sepoll
17656 - REORG/MEDIUM: fd: get rid of FD_STLISTEN
17657 - REORG/MINOR: connection: move declaration to its own include file
17658 - REORG/MINOR: checks: put a struct connection into the server
17659 - MINOR: connection: add flags to the connection struct
17660 - MAJOR: get rid of fdtab[].state and use connection->flags instead
17661 - MINOR: fd: add a new I/O handler to fdtab
17662 - MEDIUM: polling: prepare to call the iocb() function when defined.
17663 - MEDIUM: checks: make use of fdtab->iocb instead of cb[]
17664 - MEDIUM: protocols: use the generic I/O callback for accept callbacks
17665 - MINOR: connection: add a handler for fd-based connections
17666 - MAJOR: connection: replace direct I/O callbacks with the connection callback
17667 - MINOR: fd: make fdtab->owner a connection and not a stream_interface anymore
17668 - MEDIUM: connection: remove the FD_POLL_* flags only once
17669 - MEDIUM: connection: extract the send_proxy callback from proto_tcp
17670 - MAJOR: tcp: remove the specific I/O callbacks for TCP connection probes
17671 - CLEANUP: remove the now unused fdtab direct I/O callbacks
17672 - MAJOR: remove the stream interface and task management code from sock_*
17673 - MEDIUM: stream_interface: pass connection instead of fd in sock_ops
17674 - MEDIUM: stream_interface: centralize the SI_FL_ERR management
17675 - MAJOR: connection: add a new CO_FL_CONNECTED flag
17676 - MINOR: rearrange tcp_connect_probe() and fix wrong return codes
17677 - MAJOR: connection: call data layer handshakes from the handler
17678 - MEDIUM: fd: remove the EV_FD_COND_* primitives
17679 - MINOR: sock_raw: move calls to si_data_close upper
17680 - REORG: connection: replace si_data_close() with conn_data_close()
17681 - MEDIUM: sock_raw: introduce a read0 callback that is different from shutr
17682 - MAJOR: stream_int: use a common stream_int_shut*() functions regardless of the data layer
17683 - MAJOR: fd: replace all EV_FD_* macros with new fd_*_* inline calls
17684 - MEDIUM: fd: add fd_poll_{recv,send} for use when explicit polling is required
17685 - MEDIUM: connection: add definitions for dual polling mechanisms
17686 - MEDIUM: connection: make use of the new polling functions
17687 - MAJOR: make use of conn_{data|sock}_{poll|stop|want}* in connection handlers
17688 - MEDIUM: checks: don't use FD_WAIT_* anymore
17689 - MINOR: fd: get rid of FD_WAIT_*
17690 - MEDIUM: stream_interface: offer a generic function for connection updates
17691 - MEDIUM: stream-interface: offer a generic chk_rcv function for connections
17692 - MEDIUM: stream-interface: add a snd_buf() callback to sock_ops
17693 - MEDIUM: stream-interface: provide a generic stream_int_chk_snd_conn() function
17694 - MEDIUM: stream-interface: provide a generic si_conn_send_cb callback
17695 - MEDIUM: stream-interface: provide a generic stream_sock_read0() function
17696 - REORG/MAJOR: use "struct channel" instead of "struct buffer"
17697 - REORG/MAJOR: extract "struct buffer" from "struct channel"
17698 - MINOR: connection: provide conn_{data|sock}_{read0|shutw} functions
17699 - REORG: sock_raw: rename the files raw_sock*
17700 - MAJOR: raw_sock: extract raw_sock_to_buf() from raw_sock_read()
17701 - MAJOR: raw_sock: temporarily disable splicing
17702 - MINOR: stream-interface: add an rcv_buf callback to sock_ops
17703 - REORG: stream-interface: move sock_raw_read() to si_conn_recv_cb()
17704 - MAJOR: connection: split the send call into connection and stream interface
17705 - MAJOR: stream-interface: restore splicing mechanism
17706 - MAJOR: stream-interface: make conn_notify_si() more robust
17707 - MEDIUM: proxy-proto: don't use buffer flags in conn_si_send_proxy()
17708 - MAJOR: stream-interface: don't commit polling changes in every callback
17709 - MAJOR: stream-interface: fix splice not to call chk_snd by itself
17710 - MEDIUM: stream-interface: don't remove WAIT_DATA when a handshake is in progress
17711 - CLEANUP: connection: split sock_ops into data_ops, app_cp and si_ops
17712 - REORG: buffers: split buffers into chunk,buffer,channel
17713 - MAJOR: channel: remove the BF_OUT_EMPTY flag
17714 - REORG: buffer: move buffer_flush, b_adv and b_rew to buffer.h
17715 - MINOR: channel: rename bi_full to channel_full as it checks the whole channel
17716 - MINOR: buffer: provide a new buffer_full() function
17717 - MAJOR: channel: stop relying on BF_FULL to take action
17718 - MAJOR: channel: remove the BF_FULL flag
17719 - REORG: channel: move buffer_{replace,insert_line}* to buffer.{c,h}
17720 - CLEANUP: channel: usr CF_/CHN_ prefixes instead of BF_/BUF_
17721 - CLEANUP: channel: use "channel" instead of "buffer" in function names
17722 - REORG: connection: move the target pointer from si to connection
17723 - MAJOR: connection: move the addr field from the stream_interface
17724 - MEDIUM: stream_interface: remove CAP_SPLTCP/CAP_SPLICE flags
17725 - MEDIUM: proto_tcp: remove any dependence on stream_interface
17726 - MINOR: tcp: replace tcp_src_to_stktable_key with addr_to_stktable_key
17727 - MEDIUM: connection: add an ->init function to data layer
17728 - MAJOR: session: introduce embryonic sessions
17729 - MAJOR: connection: make the PROXY decoder a handshake handler
17730 - CLEANUP: frontend: remove the old proxy protocol decoder
17731 - MAJOR: connection: rearrange the polling flags.
17732 - MEDIUM: connection: only call tcp_connect_probe when nothing was attempted yet
17733 - MEDIUM: connection: complete the polling cleanups
17734 - MEDIUM: connection: avoid calling handshakes when polling is required
17735 - MAJOR: stream_interface: continue to update data polling flags during handshakes
17736 - CLEANUP: fd: remove fdtab->flags
17737 - CLEANUP: fdtab: flatten the struct and merge the spec struct with the rest
17738 - CLEANUP: includes: fix includes for a number of users of fd.h
17739 - MINOR: ssl: disable TCP quick-ack by default on SSL listeners
17740 - MEDIUM: config: add a "ciphers" keyword to set SSL cipher suites
17741 - MEDIUM: config: add "nosslv3" and "notlsv1" on bind and server lines
17742 - BUG: ssl: mark the connection as waiting for an SSL connection during the handshake
17743 - BUILD: http: rename error_message http_error_message to fix conflicts on RHEL
17744 - BUILD: ssl: fix shctx build on RHEL with futex
17745 - BUILD: include sys/socket.h to fix build failure on FreeBSD
17746 - BUILD: fix build error without SSL (ssl_cert)
17747 - BUILD: ssl: use MAP_ANON instead of MAP_ANONYMOUS
17748 - BUG/MEDIUM: workaround an eglibc bug which truncates the pidfiles when nbproc > 1
17749 - MEDIUM: config: support per-listener backlog and maxconn
17750 - MINOR: session: do not send an HTTP/500 error on SSL sockets
17751 - MEDIUM: config: implement maxsslconn in the global section
17752 - BUG: tcp: close socket fd upon connect error
17753 - MEDIUM: connection: improve error handling around the data layer
17754 - MINOR: config: make the tasks "nice" value configurable on "bind" lines.
17755 - BUILD: shut a gcc warning introduced by commit 269ab31
17756 - MEDIUM: config: centralize handling of SSL config per bind line
17757 - BUILD: makefile: report USE_OPENSSL status in build options
17758 - BUILD: report openssl build settings in haproxy -vv
17759 - MEDIUM: ssl: add sample fetches for is_ssl, ssl_has_sni, ssl_sni_*
17760 - DOC: add a special acknowledgement for the stud project
17761 - DOC: add missing SSL options for servers and listeners
17762 - BUILD: automatically add -lcrypto for SSL
17763 - DOC: add some info about openssl build in the README
17764
Willy Tarreau02c7c142012-06-04 00:43:45 +0200177652012/06/04 : 1.5-dev11
17766 - BUG/MEDIUM: option forwardfor if-none doesn't work with some configurations
17767 - BUG/MAJOR: trash must always be the size of a buffer
17768 - DOC: fix minor regex example issue and improve doc on stats
17769 - MINOR: stream_interface: add a pointer to the listener for TARG_TYPE_CLIENT
17770 - MEDIUM: protocol: add a pointer to struct sock_ops to the listener struct
17771 - MINOR: checks: add on-marked-up option
17772 - MINOR: balance uri: added 'whole' parameter to include query string in hash calculation
17773 - MEDIUM: stream_interface: remove the si->init
17774 - MINOR: buffers: add a rewind function
17775 - BUG/MAJOR: fix regression on content-based hashing and http-send-name-header
17776 - MAJOR: http: stop using msg->sol outside the parsers
17777 - CLEANUP: http: make it more obvious that msg->som is always null outside of chunks
17778 - MEDIUM: http: get rid of msg->som which is not used anymore
17779 - MEDIUM: http: msg->sov and msg->sol will never wrap
17780 - BUG/MAJOR: checks: don't call set_server_status_* when no LB algo is set
17781 - BUG/MINOR: stop connect timeout when connect succeeds
17782 - REORG: move the send-proxy code to tcp_connect_write()
17783 - REORG/MINOR: session: detect the TCP monitor checks at the protocol accept
17784 - MINOR: stream_interface: introduce a new "struct connection" type
17785 - REORG/MINOR: stream_interface: move si->fd to struct connection
17786 - REORG/MEDIUM: stream_interface: move applet->state and private to connection
17787 - MINOR: stream_interface: add a data channel close function
17788 - MEDIUM: stream_interface: call si_data_close() before releasing the si
17789 - MINOR: peers: use the socket layer operations from the peer instead of sock_raw
17790 - BUG/MINOR: checks: expire on timeout.check if smaller than timeout.connect
17791 - MINOR: add a new function call tracer for debugging purposes
17792 - BUG/MINOR: perform_http_redirect also needs to rewind the buffer
17793 - BUG/MAJOR: b_rew() must pass a signed offset to b_ptr()
17794 - BUG/MEDIUM: register peer sync handler in the proper order
17795 - BUG/MEDIUM: buffers: fix bi_putchr() to correctly advance the pointer
17796 - BUG/MINOR: fix option httplog validation with TCP frontends
17797 - BUG/MINOR: log: don't report logformat errors in backends
17798 - REORG/MINOR: use dedicated proxy flags for the cookie handling
17799 - BUG/MINOR: config: do not report twice the incompatibility between cookie and non-http
17800 - MINOR: http: add support for "httponly" and "secure" cookie attributes
17801 - BUG/MEDIUM: ensure that unresolved arguments are freed exactly once
17802 - BUG/MINOR: commit 196729ef used wrong condition resulting in freeing constants
17803 - MEDIUM: stats: add support for soft stop/soft start in the admin interface
17804 - MEDIUM: stats: add the ability to kill sessions from the admin interface
17805 - BUILD: add support for linux kernels >= 2.6.28
17806
Willy Tarreauffb89472012-05-14 07:26:56 +0200178072012/05/14 : 1.5-dev10
17808 - BUG/MINOR: stats admin: "Unexpected result" was displayed unconditionally
17809 - BUG/MAJOR: acl: http_auth_group() must not accept any user from the userlist
17810 - CLEANUP: auth: make the code build again with DEBUG_AUTH
17811 - BUG/MEDIUM: config: don't crash at config load time on invalid userlist names
17812 - REORG: use the name sock_raw instead of stream_sock
17813 - MINOR: stream_interface: add a client target : TARG_TYPE_CLIENT
17814 - BUG/MEDIUM: stream_interface: restore get_src/get_dst
17815 - CLEANUP: sock_raw: remove last references to stream_sock
17816 - CLEANUP: stream_interface: stop exporting socket layer functions
17817 - MINOR: stream_interface: add an init callback to sock_ops
17818 - MEDIUM: stream_interface: derive the socket operations from the target
17819 - MAJOR: fd: remove the need for the socket layer to recheck the connection
17820 - MINOR: session: call the socket layer init function when a session establishes
17821 - MEDIUM: session: add support for tunnel timeouts
17822 - MINOR: standard: add a new debug macro : fddebug()
17823 - CLEANUP: fd: remove unused cb->b pointers in the struct fdtab
17824 - OPTIM: proto_http: don't enable quick-ack on empty buffers
17825 - OPTIM/MAJOR: ev_sepoll: process spec events after polled events
17826 - OPTIM/MEDIUM: stream_interface: add a new SI_FL_NOHALF flag
17827
Willy Tarreaua0564f32012-05-08 21:56:27 +0200178282012/05/08 : 1.5-dev9
17829 - MINOR: Add release callback to si_applet
17830 - CLEANUP: Fix some minor typos
17831 - MINOR: Add TO/FROM_SET flags to struct stream_interface
17832 - CLEANUP: Fix some minor whitespace issues
17833 - MINOR: stats admin: allow unordered parameters in POST requests
17834 - CLEANUP: fix typo in findserver() log message
17835 - MINOR: stats admin: use the backend id instead of its name in the form
17836 - MINOR: stats admin: reduce memcmp()/strcmp() calls on status codes
17837 - DOC: cleanup indentation, alignment, columns and chapters
17838 - DOC: fix some keywords arguments documentation
17839 - MINOR: cli: display the 4 IP addresses and ports on "show sess XXX"
17840 - BUG/MAJOR: log: possible segfault with logformat
17841 - MEDIUM: log: split of log_format generation
17842 - MEDIUM: log: New format-log flags: %Fi %Fp %Si %Sp %Ts %rt %H %pid
17843 - MEDIUM: log: Unique ID
17844 - MINOR: log: log-format: usable without httplog and tcplog
17845 - BUG/MEDIUM: balance source did not properly hash IPv6 addresses
17846 - MINOR: contrib/iprange: add a network IP range to mask converter
17847 - MEDIUM: session: implement the "use-server" directive
17848 - MEDIUM: log: add a new cookie flag 'U' to report situations where cookie is not used
17849 - MEDIUM: http: make extract_cookie_value() iterate over cookie values
17850 - MEDIUM: http: add cookie and scookie ACLs
17851 - CLEANUP: lb_first: add reference to a paper describing the original idea
17852 - MEDIUM: stream_sock: add a get_src and get_dst callback and remove SN_FRT_ADDR_SET
17853 - BUG/MINOR: acl: req_ssl_sni would randomly fail if a session ID is present
17854 - BUILD: http: make extract_cookie_value() return an int not size_t
17855 - BUILD: http: stop gcc-4.1.2 from complaining about possibly uninitialized values
17856 - CLEANUP: http: message parser must ignore HTTP_MSG_ERROR
17857 - MINOR: standard: add a memprintf() function to build formatted error messages
17858 - CLEANUP: remove a few warning about unchecked return values in debug code
17859 - MEDIUM: move message-related flags from transaction to message
17860 - DOC: add a diagram to explain how circular buffers work
17861 - MAJOR: buffer rework: replace ->send_max with ->o
17862 - MAJOR: buffer: replace buf->l with buf->{o+i}
17863 - MINOR: buffers: provide simple pointer normalization functions
17864 - MINOR: buffers: remove unused function buffer_contig_data()
17865 - MAJOR: buffers: replace buf->w with buf->p - buf->o
17866 - MAJOR: buffers: replace buf->r with buf->p + buf->i
17867 - MAJOR: http: move buffer->lr to http_msg->next
17868 - MAJOR: http: change msg->{som,col,sov,eoh} to be relative to buffer origin
17869 - CLEANUP: http: remove unused http_msg->col
17870 - MAJOR: http: turn http_msg->eol to a buffer-relative offset
17871 - MEDIUM: http: add a pointer to the buffer in http_msg
17872 - MAJOR: http: make http_msg->sol relative to buffer's origin
17873 - MEDIUM: http: http_send_name_header: remove references to msg and buffer
17874 - MEDIUM: http: remove buffer arg in a few header manipulation functions
17875 - MEDIUM: http: remove buffer arg in http_capture_bad_message
17876 - MEDIUM: http: remove buffer arg in http_msg_analyzer
17877 - MEDIUM: http: remove buffer arg in http_upgrade_v09_to_v10
17878 - MEDIUM: http: remove buffer arg in http_buffer_heavy_realign
17879 - MEDIUM: http: remove buffer arg in chunk parsing functions
17880 - MINOR: http: remove useless wrapping checks in http_msg_analyzer
17881 - MEDIUM: buffers: fix unsafe use of buffer_ignore at some places
17882 - MEDIUM: buffers: add new pointer wrappers and get rid of almost all buffer_wrap_add calls
17883 - MEDIUM: buffers: implement b_adv() to advance a buffer's pointer
17884 - MEDIUM: buffers: rename a number of buffer management functions
17885 - MEDIUM: http: add a prefetch function for ACL pattern fetch
17886 - MEDIUM: http: make all ACL fetch function use acl_prefetch_http()
17887 - BUG/MINOR: http_auth: ACLs are volatile, not permanent
17888 - MEDIUM: http/acl: merge all request and response ACL fetches of headers and cookies
17889 - MEDIUM: http/acl: make acl_fetch_hdr_{ip,val} rely on acl_fetch_hdr()
17890 - MEDIUM: add a new typed argument list parsing framework
17891 - MAJOR: acl: make use of the new argument parsing framework
17892 - MAJOR: acl: store the ACL argument types in the ACL keyword declaration
17893 - MEDIUM: acl: acl_find_target() now resolves arguments based on their types
17894 - MAJOR: acl: make acl_find_targets also resolve proxy names at config time
17895 - MAJOR: acl: ensure that implicit table and proxies are valid
17896 - MEDIUM: acl: remove unused tests for missing args when args are mandatory
17897 - MEDIUM: pattern: replace type pattern_arg with type arg
17898 - MEDIUM: pattern: get rid of arg_i in all functions making use of arguments
17899 - MEDIUM: pattern: use the standard arg parser
17900 - MEDIUM: pattern: add an argument validation callback to pattern descriptors
17901 - MEDIUM: pattern: report the precise argument parsing error when known.
17902 - MEDIUM: acl: remove the ACL_TEST_F_NULL_MATCH flag
17903 - MINOR: pattern: add a new 'sample' type to store fetched data
17904 - MEDIUM: pattern: add new sample types to replace pattern types
17905 - MAJOR: acl: make use of the new sample struct and get rid of acl_test
17906 - MEDIUM: pattern/acl: get rid of temp_pattern in ACLs
17907 - MEDIUM: acl: get rid of the SET_RES flags
17908 - MEDIUM: get rid of SMP_F_READ_ONLY and SMP_F_MUST_FREE
17909 - MINOR: pattern: replace struct pattern with struct sample
17910 - MEDIUM: pattern: integrate pattern_data into sample and use sample everywhere
17911 - MEDIUM: pattern: retrieve the sample type in the sample, not in the keyword description
17912 - MEDIUM: acl/pattern: switch rdp_cookie functions stack up-down
17913 - MEDIUM: acl: replace acl_expr with args in acl fetch_* functions
17914 - MINOR: tcp: replace acl_fetch_rdp_cookie with smp_fetch_rdp_cookie
17915 - MEDIUM: acl/pattern: use the same direction scheme
17916 - MEDIUM: acl/pattern: start merging common sample fetch functions
17917 - MEDIUM: pattern: ensure that sample types always cast into other types.
17918 - MEDIUM: acl/pattern: factor out the src/dst address fetches
17919 - MEDIUM: acl: implement payload and payload_lv
17920 - CLEANUP: pattern: ensure that payload and payload_lv always stay in the buffer
17921 - MINOR: stick_table: centralize the handling of empty keys
17922 - MINOR: pattern: centralize handling of unstable data in pattern_process()
17923 - MEDIUM: pattern: use smp_fetch_rdp_cookie instead of the pattern specific version
17924 - MINOR: acl: set SMP_OPT_ITERATE on fetch functions
17925 - MINOR: acl: add a val_args field to keywords
17926 - MINOR: proto_tcp: validate arguments of payload and payload_lv ACLs
17927 - MEDIUM: http: merge acl and pattern header fetch functions
17928 - MEDIUM: http: merge ACL and pattern cookie fetches into a single one
17929 - MEDIUM: acl: report parsing errors to the caller
17930 - MINOR: arg: improve error reporting on invalid arguments
17931 - MINOR: acl: report errors encountered when loading patterns from files
17932 - MEDIUM: acl: extend the pattern parsers to report meaningful errors
17933 - REORG: use the name "sample" instead of "pattern" to designate extracted data
17934 - REORG: rename "pattern" files
17935 - MINOR: acl: add types to ACL patterns
17936 - MINOR: standard: add an IPv6 parsing function (str62net)
17937 - MEDIUM: acl: support IPv6 address matching
17938 - REORG: stream_interface: create a struct sock_ops to hold socket operations
17939 - REORG/MEDIUM: move protocol->{read,write} to sock_ops
17940 - REORG/MEDIUM: stream_interface: initialize socket ops from descriptors
17941 - REORG/MEDIUM: replace stream interface protocol functions by a proto pointer
17942 - REORG/MEDIUM: move the default accept function from sockstream to protocols.c
17943 - MEDIUM: proto_tcp: remove src6 and dst6 pattern fetch methods
17944 - BUG/MINOR: http: error snapshots are wrong if buffer wraps
17945 - BUG/MINOR: http: ensure that msg->err_pos is always relative to buf->p
17946 - MEDIUM: http: improve error capture reports
17947 - MINOR: acl: add the cook_val() match to match a cookie against an integer
17948 - BUG/MEDIUM: send_proxy: fix initialisation of send_proxy_ofs
17949 - MEDIUM: memory: add the ability to poison memory at run time
17950 - BUG/MEDIUM: log: ensure that unique_id is properly initialized
17951 - MINOR: cfgparse: use a common errmsg pointer for all parsers
17952 - MEDIUM: cfgparse: make backend_parse_balance() use memprintf to report errors
17953 - MEDIUM: cfgparse: use the new error reporting framework for remaining cfg_keywords
17954 - MINOR: http: replace http_message_realign() with buffer_slow_realign()
17955
Willy Tarreau9eeb57b2012-03-26 06:15:29 +0200179562012/03/26 : 1.5-dev8
17957 - MINOR: patch for minor typo (ressources/resources)
17958 - MEDIUM: http: add support for sending the server's name in the outgoing request
17959 - DOC: mention that default checks are TCP connections
17960 - BUG/MINOR: fix options forwardfor if-none when an alternative header name is specified
17961 - CLEANUP: Make check_statuses, analyze_statuses and process_chk static
17962 - CLEANUP: Fix HCHK spelling errors
17963 - BUG/MINOR: fix typo in processing of http-send-name-header
17964 - MEDIUM: log: Use linked lists for loggers
17965 - BUILD: fix declaration inside a scope block
17966 - REORG: log: split send_log function
17967 - MINOR: config: Parse the string of the log-format config keyword
17968 - MINOR: add ultoa, ulltoa, ltoa, lltoa implementations
17969 - MINOR: Date and time fonctions that don't use snprintf
17970 - MEDIUM: log: make http_sess_log use log_format
17971 - DOC: log-format documentation
17972 - MEDIUM: log: use log_format for mode tcplog
17973 - MEDIUM: log-format: backend source address %Bi %Bp
17974 - BUG/MINOR: log-format: fix %o flag
17975 - BUG/MEDIUM: bad length in log_format and __send_log
17976 - MINOR: logformat %st is signed
17977 - BUILD/MINOR: fix the source URL in the spec file
17978 - DOC: acl is http_first_req, not http_req_first
17979 - BUG/MEDIUM: don't trim last spaces from headers consisting only of spaces
17980 - MINOR: acl: add new matches for header/path/url length
17981 - BUILD: halog: make halog build on solaris
17982 - BUG/MINOR: don't use a wrong port when connecting to a server with mapped ports
17983 - MINOR: remove the client/server side distinction in SI addresses
17984 - MINOR: halog: add support for matching queued requests
17985 - DOC: indicate that cookie "prefix" and "indirect" should not be mixed
17986 - OPTIM/MINOR: move struct sockaddr_storage to the tail of structs
17987 - OPTIM/MINOR: make it possible to change pipe size (tune.pipesize)
17988 - BUILD/MINOR: silent a build warning in src/pipe.c (fcntl)
17989 - OPTIM/MINOR: move the hdr_idx pools out of the proxy struct
17990 - MEDIUM: tune.http.maxhdr makes it possible to configure the maximum number of HTTP headers
17991 - BUG/MINOR: fix a segfault when parsing a config with undeclared peers
17992 - CLEANUP: rename possibly confusing struct field "tracked"
17993 - BUG/MEDIUM: checks: fix slowstart behaviour when server tracking is in use
17994 - MINOR: config: tolerate server "cookie" setting in non-HTTP mode
17995 - MEDIUM: buffers: add some new primitives and rework existing ones
17996 - BUG: buffers: don't return a negative value on buffer_total_space_res()
17997 - MINOR: buffers: make buffer_pointer() support negative pointers too
17998 - CLEANUP: kill buffer_replace() and use an inline instead
17999 - BUG: tcp: option nolinger does not work on backends
18000 - CLEANUP: ebtree: remove a few annoying signedness warnings
18001 - CLEANUP: ebtree: clarify licence and update to 6.0.6
18002 - CLEANUP: ebtree: remove 4-year old harmless typo in duplicates insertion code
18003 - CLEANUP: ebtree: remove another typo, a wrong initialization in insertion code
18004 - BUG: ebtree: ebst_lookup() could return the wrong entry
18005 - OPTIM: stream_sock: reduce the amount of in-flight spliced data
18006 - OPTIM: stream_sock: save a failed recv syscall when splice returns EAGAIN
18007 - MINOR: acl: add support for TLS server name matching using SNI
18008 - BUG: http: re-enable TCP quick-ack upon incomplete HTTP requests
18009 - BUG: proto_tcp: don't try to bind to a foreign address if sin_family is unknown
18010 - MINOR: pattern: export the global temporary pattern
18011 - CLEANUP: patterns: get rid of pattern_data_setstring()
18012 - MEDIUM: acl: use temp_pattern to store fetched information in the "method" match
18013 - MINOR: acl: include pattern.h to make pattern migration more transparent
18014 - MEDIUM: pattern: change the pattern data integer from unsigned to signed
18015 - MEDIUM: acl: use temp_pattern to store any integer-type information
18016 - MEDIUM: acl: use temp_pattern to store any address-type information
18017 - CLEANUP: acl: integer part of acl_test is not used anymore
18018 - MEDIUM: acl: use temp_pattern to store any string-type information
18019 - CLEANUP: acl: remove last data fields from the acl_test struct
18020 - MEDIUM: http: replace get_ip_from_hdr2() with http_get_hdr()
18021 - MEDIUM: patterns: the hdr() pattern is now of type string
18022 - DOC: add minimal documentation on how ACLs work internally
18023 - DOC: add a coding-style file
18024 - OPTIM: halog: keep a fast path for the lines-count only
18025 - CLEANUP: silence a warning when building on sparc
18026 - BUG: http: tighten the list of allowed characters in a URI
18027 - MEDIUM: http: block non-ASCII characters in URIs by default
18028 - DOC: add some documentation from RFC3986 about URI format
18029 - BUG/MINOR: cli: correctly remove the whole table on "clear table"
18030 - BUG/MEDIUM: correctly disable servers tracking another disabled servers.
18031 - BUG/MEDIUM: zero-weight servers must not dequeue requests from the backend
18032 - MINOR: halog: add some help on the command line
18033 - BUILD: fix build error on FreeBSD
18034 - BUG: fix double free in peers config error path
18035 - MEDIUM: improve config check return codes
18036 - BUILD: make it possible to look for pcre in the default system paths
18037 - MINOR: config: emit a warning when 'default_backend' masks servers
18038 - MINOR: backend: rework the LC definition to support other connection-based algos
18039 - MEDIUM: backend: add the 'first' balancing algorithm
18040 - BUG: fix httplog trailing LF
18041 - MEDIUM: increase chunk-size limit to 2GB-1
18042 - BUG: queue: fix dequeueing sequence on HTTP keep-alive sessions
18043 - BUG: http: disable TCP delayed ACKs when forwarding content-length data
18044 - BUG: checks: fix server maintenance exit sequence
18045 - BUG/MINOR: stream_sock: don't remove BF_EXPECT_MORE and BF_SEND_DONTWAIT on partial writes
18046 - DOC: enumerate valid status codes for "observe layer7"
18047 - MINOR: buffer: switch a number of buffer args to const
18048 - CLEANUP: silence signedness warning in acl.c
18049 - BUG: stream_sock: si->release was not called upon shutw()
18050 - MINOR: log: use "%ts" to log term status only and "%tsc" to log with cookie
18051 - BUG/CRITICAL: log: fix risk of crash in development snapshot
18052 - BUG/MAJOR: possible crash when using capture headers on TCP frontends
18053 - MINOR: config: disable header captures in TCP mode and complain
18054
Willy Tarreau60612eb2011-09-10 23:43:11 +0200180552011/09/10 : 1.5-dev7
18056 - [BUG] fix binary stick-tables
18057 - [MINOR] http: *_dom matching header functions now also split on ":"
18058 - [BUG] checks: fix support of Mysqld >= 5.5 for mysql-check
18059 - [MINOR] acl: add srv_conn acl to count connections on a specific backend server
18060 - [MINOR] check: add redis check support
18061 - [DOC] small fixes to clearly distinguish between keyword and variables
18062 - [MINOR] halog: add support for termination code matching (-tcn/-TCN)
18063 - [DOC] Minor spelling fixes and grammatical enhancements
18064 - [CLEANUP] dumpstats: make symbols static where possible
18065 - [MINOR] Break out dumping table
18066 - [MINOR] Break out processing of clear table
18067 - [MINOR] Allow listing of stick table by key
18068 - [MINOR] Break out all stick table socat command parsing
18069 - [MINOR] More flexible clearing of stick table
18070 - [MINOR] Allow showing and clearing by key of ipv6 stick tables
18071 - [MINOR] Allow showing and clearing by key of integer stick tables
18072 - [MINOR] Allow showing and clearing by key of string stick tables
18073 - [CLEANUP] Remove assigned but unused variables
18074 - [CLEANUP] peers.h: fix declarations
18075 - [CLEANUP] session.c: Make functions static where possible
18076 - [MINOR] Add active connection list to server
18077 - [MINOR] Allow shutdown of sessions when a server becomes unavailable
18078 - [MINOR] Add down termination condition
18079 - [MINOR] Make appsess{,ion}_refresh static
18080 - [MINOR] Add rdp_cookie pattern fetch function
18081 - [CLEANUP] Remove unnecessary casts
18082 - [MINOR] Add non-stick server option
18083 - [MINOR] Consistently use error in tcp_parse_tcp_req()
18084 - [MINOR] Consistently free expr on error in cfg_parse_listen()
18085 - [MINOR] Free rdp_cookie_name on denint()
18086 - [MINOR] Free tcp rules on denint()
18087 - [MINOR] Free stick table pool on denint()
18088 - [MINOR] Free stick rules on denint()
18089 - [MEDIUM] Fix stick-table replication on soft-restart
18090 - [MEDIUM] Correct ipmask() logic
18091 - [MINOR] Correct type in table dump examples
18092 - [MINOR] Fix build error in stream_int_register_handler()
18093 - [MINOR] Use DPRINTF in assign_server()
18094 - [BUG] checks: http-check expect could fail a check on multi-packet responses
18095 - [DOC] fix minor typo in the "dispatch" doc
18096 - [BUG] proto_tcp: fix address binding on remote source
18097 - [MINOR] http: don't report the "haproxy" word on the monitoring response
18098 - [REORG] http: move HTTP error codes back to proto_http.h
18099 - [MINOR] http: make the "HTTP 200" status code configurable.
18100 - [MINOR] http: partially revert the chunking optimization for now
18101 - [MINOR] stream_sock: always clear BF_EXPECT_MORE upon complete transfer
18102 - [CLEANUP] stream_sock: remove unneeded FL_TCP and factor out test
18103 - [MEDIUM] http: add support for "http-no-delay"
18104 - [OPTIM] http: optimize chunking again in non-interactive mode
18105 - [OPTIM] stream_sock: avoid fast-forwarding of partial data
18106 - [OPTIM] stream_sock: don't use splice on too small payloads
18107 - [MINOR] config: make it possible to specify a cookie even without a server
18108 - [BUG] stats: support url-encoded forms
18109 - [MINOR] config: automatically compute a default fullconn value
18110 - [CLEANUP] config: remove some left-over printf debugging code from previous patch
18111 - [DOC] add missing entry or stick store-response
18112 - [MEDIUM] http: add support for 'cookie' and 'set-cookie' patterns
18113 - [BUG] halog: correctly handle truncated last line
18114 - [MINOR] halog: make SKIP_CHAR stop on field delimiters
18115 - [MINOR] halog: add support for HTTP log matching (-H)
18116 - [MINOR] halog: gain back performance before SKIP_CHAR fix
18117 - [OPTIM] halog: cache some common fields positions
18118 - [OPTIM] halog: check once for correct line format and reuse the pointer
18119 - [OPTIM] halog: remove many 'if' by using a function pointer for the filters
18120 - [OPTIM] halog: remove support for tab delimiters in input data
18121 - [BUG] session: risk of crash on out of memory (1.5-dev regression)
18122 - [MINOR] session: try to emit a 500 response on memory allocation errors
18123 - [OPTIM] stream_sock: reduce the default number of accepted connections at once
18124 - [BUG] stream_sock: disable listener when system resources are exhausted
18125 - [MEDIUM] proxy: add a PAUSED state to listeners and move socket tricks out of proxy.c
18126 - [BUG] stream_sock: ensure orphan listeners don't accept too many connections
18127 - [MINOR] listeners: add listen_full() to mark a listener full
18128 - [MINOR] listeners: add support for queueing resource limited listeners
18129 - [MEDIUM] listeners: put listeners in queue upon resource shortage
18130 - [MEDIUM] listeners: queue proxy-bound listeners at the proxy's
18131 - [MEDIUM] listeners: don't stop proxies when global maxconn is reached
18132 - [MEDIUM] listeners: don't change listeners states anymore in maintain_proxies
18133 - [CLEANUP] proxy: rename a few proxy states (PR_STIDLE and PR_STRUN)
18134 - [MINOR] stats: report a "WAITING" state for sockets waiting for resource
18135 - [MINOR] proxy: make session rate-limit more accurate
18136 - [MINOR] sessions: only wake waiting listeners up if rate limit is OK
18137 - [BUG] proxy: peers must only be stopped once, not upon every call to maintain_proxies
18138 - [CLEANUP] proxy: merge maintain_proxies() operation inside a single loop
18139 - [MINOR] task: new function task_schedule() to schedule a wake up
18140 - [MAJOR] proxy: finally get rid of maintain_proxies()
18141 - [BUG] proxy: stats frontend and peers were missing many initializers
18142 - [MEDIUM] listeners: add a global listener management task
18143 - [MINOR] proxy: make findproxy() return proxies from numeric IDs too
18144 - [DOC] fix typos, "#" is a sharp, not a dash
18145 - [MEDIUM] stats: add support for changing frontend's maxconn at runtime
18146 - [MEDIUM] checks: group health checks methods by values and save option bits
18147 - [MINOR] session-counters: add the ability to clear the counters
18148 - [BUG] check: http-check expect + regex would crash in defaults section
18149 - [MEDIUM] http: make x-forwarded-for addition conditional
18150 - [REORG] build: move syscall redefinition to specific places
18151 - [CLEANUP] update the year in the copyright banner
18152 - [BUG] possible crash in 'show table' on stats socket
18153 - [BUG] checks: use the correct destination port for sending checks
18154 - [BUG] backend: risk of picking a wrong port when mapping is used with crossed families
18155 - [MINOR] make use of set_host_port() and get_host_port() to get rid of family mismatches
18156 - [DOC] fixed a few "sensible" -> "sensitive" errors
18157 - [MINOR] make use of addr_to_str() and get_host_port() to replace many inet_ntop()
18158 - [BUG] http: trailing white spaces must also be trimmed after headers
18159 - [MINOR] stats: display "<NONE>" instead of the frontend name when unknown
18160 - [MINOR] http: take a capture of too large requests and responses
18161 - [MINOR] http: take a capture of truncated responses
18162 - [MINOR] http: take a capture of bad content-lengths.
18163 - [DOC] add a few old and uncommitted docs
18164 - [CLEANUP] cfgparse: fix reported options for the "bind" keyword
18165 - [MINOR] halog: add -hs/-HS to filter by HTTP status code range
18166 - [MINOR] halog: support backslash-escaped quotes
18167 - [CLEANUP] remove dirty left-over of a debugging message
18168 - [MEDIUM] stats: disable complex socket reservation for stats socket
18169 - [CLEANUP] remove a useless test in manage_global_listener_queue()
18170 - [MEDIUM] stats: add the "set maxconn" setting to the command line interface
18171 - [MEDIUM] add support for global.maxconnrate to limit the per-process conn rate.
18172 - [MINOR] stats: report the current and max global connection rates
18173 - [MEDIUM] stats: add the ability to adjust the global maxconnrate
18174 - [BUG] peers: don't pre-allocate 65000 connections to each peer
18175 - [MEDIUM] don't limit peers nor stats socket to maxconn nor maxconnrate
18176 - [BUG] peers: the peer frontend must not emit any log
18177 - [CLEANUP] proxy: make pause_proxy() perform the required controls and emit the logs
18178 - [BUG] peers: don't keep a peers section which has a NULL frontend
18179 - [BUG] peers: ensure the peers are resumed if they were paused
18180 - [MEDIUM] stats: add the ability to enable/disable/shutdown a frontend at runtime
18181 - [MEDIUM] session: make session_shutdown() an independant function
18182 - [MEDIUM] stats: offer the possibility to kill a session from the CLI
18183 - [CLEANUP] stats: centralize tests for backend/server inputs on the CLI
18184 - [MEDIUM] stats: offer the possibility to kill sessions by server
18185 - [MINOR] halog: do not consider byte 0x8A as end of line
18186 - [MINOR] frontend: ensure debug message length is always initialized
18187 - [OPTIM] halog: make fgets parse more bytes by blocks
18188 - [OPTIM] halog: add assembly version of the field lookup code
18189 - [MEDIUM] poll: add a measurement of idle vs work time
18190 - [CLEANUP] startup: report only the basename in the usage message
18191 - [MINOR] startup: add an option to change to a new directory
18192 - [OPTIM] task: don't scan the run queue if we know it's empty
18193 - [BUILD] stats: stdint is not present on solaris
18194 - [DOC] update the README file to reflect new naming rules for patches
18195 - [MINOR] stats: report the number of requests intercepted by the frontend
18196 - [DOC] update ROADMAP file
18197
Willy Tarreau04df1122011-04-08 00:56:41 +0200181982011/04/08 : 1.5-dev6
18199 - [BUG] stream_sock: use get_addr_len() instead of sizeof() on sockaddr_storage
18200 - [BUG] TCP source tracking was broken with IPv6 changes
18201 - [BUG] stick-tables did not work when converting IPv6 to IPv4
18202 - [CRITICAL] fix risk of crash when dealing with space in response cookies
18203
Willy Tarreaub06ed2c2011-03-29 01:10:33 +0200182042011/03/29 : 1.5-dev5
18205 - [BUG] standard: is_addr return value for IPv4 was inverted
18206 - [MINOR] update comment about IPv6 support for server
18207 - [MEDIUM] use getaddrinfo to resolve names if gethostbyname fail
18208 - [DOC] update IPv6 support for bind
18209 - [DOC] document IPv6 support for server
18210 - [DOC] fix a minor typo
18211 - [MEDIUM] IPv6 support for syslog
18212 - [DOC] document IPv6 support for syslog
18213 - [MEDIUM] IPv6 support for stick-tables
18214 - [DOC] document IPv6 support for stick-tables
18215 - [DOC] update ROADMAP file
18216 - [BUG] session: src_conn_cur was returning src_conn_cnt instead
18217 - [MINOR] frontend: add a make_proxy_line function
18218 - [MEDIUM] stream_sock: add support for sending the proxy protocol header line
18219 - [MEDIUM] server: add support for the "send-proxy" option
18220 - [DOC] update the spec on the proxy protocol
18221 - [BUILD] proto_tcp: fix build issue with CTTPROXY
18222 - [DOC] update ROADMAP file
18223 - [MEDIUM] config: rework the IPv4/IPv6 address parser to support host-only addresses
18224 - [MINOR] cfgparse: better report wrong listening addresses and make use of str2sa_range
18225 - [BUILD] add the USE_GETADDRINFO build option
18226 - [TESTS] provide a test case for various address formats
18227 - [BUG] session: conn_retries was not always initialized
18228 - [BUG] log: retrieve the target from the session, not the SI
18229 - [BUG] http: fix possible incorrect forwarded wrapping chunk size (take 2)
18230 - [MINOR] tools: add two macros MID_RANGE and MAX_RANGE
18231 - [BUG] http: fix content-length handling on 32-bit platforms
18232 - [OPTIM] buffers: uninline buffer_forward()
18233 - [BUG] stream_sock: fix handling for server side PROXY protocol
18234 - [MINOR] acl: add support for table_cnt and table_avl matches
18235 - [DOC] update ROADMAP file
18236
Willy Tarreaue0052cc2011-03-13 22:15:02 +0100182372011/03/13 : 1.5-dev4
18238 - [MINOR] cfgparse: Check whether the path given for the stats socket actually fits into the sockaddr_un structure to avoid truncation.
18239 - [MINOR] unix sockets : inherits the backlog size from the listener
18240 - [CLEANUP] unix sockets : move create_uxst_socket() in uxst_bind_listener()
18241 - [DOC] fix a minor typo
18242 - [DOC] fix ignore-persist documentation
18243 - [MINOR] add warnings on features not compatible with multi-process mode
18244 - [BUG] http: fix http-pretend-keepalive and httpclose/tunnel mode
18245 - [MINOR] stats: add support for several packets in stats admin
18246 - [BUG] stats: admin commands must check the proxy state
18247 - [BUG] stats: admin web interface must check the proxy state
18248 - [MINOR] http: add pattern extraction method to stick on query string parameter
18249 - [MEDIUM] add internal support for IPv6 server addresses
18250 - [MINOR] acl: add be_id/srv_id to match backend's and server's id
18251 - [MINOR] log: add support for passing the forwarded hostname
18252 - [MINOR] log: ability to override the syslog tag
18253 - [MINOR] checks: add PostgreSQL health check
18254 - [DOC] update ROADMAP file
18255 - [BUILD] pattern: use 'int' instead of 'int32_t'
18256 - [OPTIM] linux: add support for bypassing libc to force using vsyscalls
18257 - [BUG] debug: report the correct poller list in verbose mode
18258 - [BUG] capture: do not capture a cookie if there is no memory left
18259 - [BUG] appsession: fix possible double free in case of out of memory
18260 - [CRITICAL] cookies: mixing cookies in indirect mode and appsession can crash the process
18261 - [BUG] http: correctly update the header list when removing two consecutive headers
18262 - [BUILD] add the CPU=native and ARCH=32/64 build options
18263 - [BUILD] add -fno-strict-aliasing to fix warnings with gcc >= 4.4
18264 - [CLEANUP] hash: move the avalanche hash code globally available
18265 - [MEDIUM] hash: add support for an 'avalanche' hash-type
18266 - [DOC] update roadmap file
18267 - [BUG] http: do not re-enable the PROXY analyser on keep-alive
18268 - [OPTIM] http: don't send each chunk in a separate packet
18269 - [DOC] fix minor typos reported recently in the peers section
18270 - [DOC] fix another typo in the doc
18271 - [MINOR] stats: report HTTP message state and buffer flags in error dumps
18272 - [BUG] http chunking: don't report a parsing error on connection errors
18273 - [BUG] stream_interface: truncate buffers when sending error messages
18274 - [MINOR] http: support wrapping messages in error captures
18275 - [MINOR] http: capture incorrectly chunked message bodies
18276 - [MINOR] stats: add global event ID and count
18277 - [BUG] http: analyser optimizations broke pipelining
18278 - [CLEANUP] frontend: only apply TCP-specific settings to TCP/TCP6 sockets
18279 - [BUG] http: fix incorrect error reporting during data transfers
18280 - [CRITICAL] session: correctly leave turn-around and queue states on abort
18281 - [BUG] session: release slot before processing pending connections
18282 - [MINOR] tcp: add support for dynamic MSS setting
18283 - [BUG] stick-table: correctly terminate string keys during lookups
18284 - [BUG] acl: fix handling of empty lines in pattern files
18285 - [BUG] stick-table: use the private buffer when padding strings
18286 - [BUG] ebtree: fix ebmb_lookup() with len smaller than the tree's keys
18287 - [OPTIM] ebtree: ebmb_lookup: reduce stack usage by moving the return code out of the loop
18288 - [OPTIM] ebtree: inline ebst_lookup_len and ebis_lookup_len
18289 - [REVERT] undo the stick-table string key lookup fixes
18290 - [MINOR] http: improve url_param pattern extraction to ignore empty values
18291 - [BUILD] frontend: shut a warning with TCP_MAXSEG
18292 - [BUG] http: update the header list's tail when removing the last header
18293 - [DOC] fix minor typo in the proxy protocol doc
18294 - [DOC] fix typos (http-request instead of http-check)
18295 - [BUG] http: use correct ACL pointer when evaluating authentication
18296 - [BUG] cfgparse: correctly count one socket per port in ranges
18297 - [BUG] startup: set the rlimits before binding ports, not after.
18298 - [BUG] acl: srv_id must return no match when the server is NULL
18299 - [MINOR] acl: add ability to check for internal response-only parameters
18300 - [MINOR] acl: srv_id is only valid in responses
18301 - [MINOR] config: warn if response-only conditions are used in "redirect" rules
18302 - [BUG] acl: fd leak when reading patterns from file
18303 - [DOC] fix minor typo in "usesrc"
18304 - [BUG] http: fix possible incorrect forwarded wrapping chunk size
18305 - [BUG] http: fix computation of message body length after forwarding has started
18306 - [BUG] http: balance url_param did not work with first parameters on POST
18307 - [TESTS] update the url_param regression test to test check_post too
18308 - [DOC] update ROADMAP
18309 - [DOC] internal: reflect the fact that SI_ST_ASS is transient
18310 - [BUG] config: don't crash on empty pattern files.
18311 - [MINOR] stream_interface: make use of an applet descriptor for IO handlers
18312 - [REORG] stream_interface: move the st0, st1 and private members to the applet
18313 - [REORG] stream_interface: split the struct members in 3 parts
18314 - [REORG] session: move client and server address to the stream interface
18315 - [REORG] tcp: make tcpv4_connect_server() take the target address from the SI
18316 - [MEDIUM] stream_interface: store the target pointer and type
18317 - [CLEANUP] stream_interface: remove the applet.handler pointer
18318 - [MEDIUM] log: take the logged server name from the stream interface
18319 - [CLEANUP] session: remove data_source from struct session
18320 - [CLEANUP] stats: make all dump functions only rely on the stream interface
18321 - [REORG] session: move the data_ctx struct to the stream interface's applet
18322 - [MINOR] proxy: add PR_O2_DISPATCH to detect dispatch mode
18323 - [MINOR] cfgparse: only keep one of dispatch, transparent, http_proxy
18324 - [MINOR] session: add a pointer to the new target into the session
18325 - [MEDIUM] session: remove s->prev_srv which is not needed anymore
18326 - [CLEANUP] stream_interface: use inline functions to manipulate targets
18327 - [MAJOR] session: remove the ->srv pointer from struct session
18328 - [MEDIUM] stats: split frontend and backend stats
18329 - [MEDIUM] http: always evaluate http-request rules before stats http-request
18330 - [REORG] http: move the http-request rules to proto_http
18331 - [BUG] http: stats were not incremented on http-request deny
18332 - [MINOR] checks: report it if checks fail due to socket creation error
18333
Willy Tarreau442e8342010-11-11 23:29:35 +0100183342010/11/11 : 1.5-dev3
18335 - [DOC] fix http-request documentation
18336 - [MEDIUM] enable/disable servers from the stats web interface
18337 - [MEDIUM] stats: add an admin level
18338 - [DOC] stats: document the "stats admin" statement
18339 - [MINOR] startup: print the proxy socket which caused an error
18340 - [CLEANUP] Remove unneeded chars allocation
18341 - [MINOR] config: detect options not supported due to compilation options
18342 - [MINOR] Add pattern's fetchs payload and payload_lv
18343 - [MINOR] frontend: improve accept-proxy header parsing
18344 - [MINOR] frontend: add tcpv6 support on accept-proxy bind
18345 - [MEDIUM] Enhance message errors management on binds
18346 - [MINOR] Manage unix socket source field on logs
18347 - [MINOR] Manage unix socket source field on session dump on sock stats
18348 - [MINOR] Support of unix listener sockets for debug and log event messages on frontend.c
18349 - [MINOR] Add some tests on sockets family for port remapping and mode transparent.
18350 - [MINOR] Manage socket type unix for some logs
18351 - [MINOR] Enhance controls of socket's family on acls and pattern fetch
18352 - [MINOR] Support listener's sockets unix on http logs.
18353 - [MEDIUM] Add supports of bind on unix sockets.
18354 - [BUG] stick table purge failure if size less than 255
18355 - [BUG] stick table entries expire on counters updates/read or show table, even if there is no "expire" parameter
18356 - [MEDIUM] Implement tcp inspect response rules
18357 - [DOC] tcp-response content and inspect
18358 - [MINOR] new acls fetch req_ssl_hello_type and rep_ssl_hello_type
18359 - [DOC] acls rep_ssl_hello and req_ssl_hello
18360 - [MEDIUM] Create new protected pattern types CONSTSTRING and CONSTDATA to force memcpy if data from protected areas need to be manipulated.
18361 - [DOC] new type binary in stick-table
18362 - [DOC] stick store-response and new patterns payload and payload_lv
18363 - [MINOR] Manage all types (ip, integer, string, binary) on cli "show table" command
18364 - [MEDIUM] Create updates tree on stick table to manage sync.
18365 - [MAJOR] Add new files src/peer.c, include/proto/peers.h and include/types/peers.h for sync stick table management
18366 - [MEDIUM] Manage peers section parsing and stick table registration on peers.
18367 - [MEDIUM] Manage soft stop on peers proxy
18368 - [DOC] add documentation for peers section
18369 - [MINOR] checks: add support for LDAPv3 health checks
18370 - [MINOR] add better support to "mysql-check"
18371 - [BUG] Restore info about available active/backup servers
18372 - [CONTRIB] Update haproxy.pl
18373 - [CONTRIB] Update Cacti Tempates
18374 - [CONTRIB] add templates for Cacti.
18375 - [BUG] http: don't consider commas as a header delimitor within quotes
18376 - [MINOR] support a global jobs counter
18377 - [DOC] add a summary about cookie incompatibilities between specs and browsers
18378 - [DOC] fix description of cookie "insert" and "indirect" modes
18379 - [MEDIUM] http: fix space handling in the request cookie parser
18380 - [MEDIUM] http: fix space handling in the response cookie parser
18381 - [DOC] fix typo in the queue() definition (backend, not frontend)
18382 - [BUG] deinit: unbind listeners before freeing them
18383 - [BUG] stream_interface: only call si->release when both dirs are closed
18384 - [MEDIUM] buffers: rework the functions to exchange between SI and buffers
18385 - [DOC] fix typo in the avg_queue() and be_conn() definition (backend, not frontend)
18386 - [MINOR] halog: add '-tc' to sort by termination codes
18387 - [MINOR] halog: skip non-traffic logs for -st and -tc
18388 - [BUG] stream_sock: cleanly disable the listener in case of resource shortage
18389 - [BUILD] stream_sock: previous fix lacked the #include, causing a warning.
18390 - [DOC] bind option is "defer-accept", not "defer_accept"
18391 - [DOC] missing index entry for http-check send-state
18392 - [DOC] tcp-request inspect-delay is for backends too
18393 - [BUG] ebtree: string_equal_bits() could return garbage on identical strings
18394 - [BUG] stream_sock: try to flush any extra pending request data after a POST
18395 - [BUILD] proto_http: eliminate some build warnings with gcc-2.95
18396 - [MEDIUM] make it possible to combine http-pretend-keepalived with httpclose
18397 - [MEDIUM] tcp-request : don't wait for inspect-delay to expire when the buffer is full
18398 - [MEDIUM] checks: add support for HTTP contents lookup
18399 - [TESTS] add test-check-expect to test various http-check methods
18400 - [MINOR] global: add "tune.chksize" to change the default check buffer size
18401 - [MINOR] cookie: add options "maxidle" and "maxlife"
18402 - [MEDIUM] cookie: support client cookies with some contents appended to their value
18403 - [MINOR] http: make some room in the transaction flags to extend cookies
18404 - [MINOR] cookie: add the expired (E) and old (O) flags for request cookies
18405 - [MEDIUM] cookie: reassign set-cookie status flags to store more states
18406 - [MINOR] add encode/decode function for 30-bit integers from/to base64
18407 - [MEDIUM] cookie: check for maxidle and maxlife for incoming dated cookies
18408 - [MEDIUM] cookie: set the date in the cookie if needed
18409 - [DOC] document the cookie maxidle and maxlife parameters
18410 - [BUG] checks: don't log backend down for all zero-weight servers
18411 - [MEDIUM] checks: set server state to one state from failure when leaving maintenance
18412 - [BUG] config: report correct keywords for "observe"
18413 - [MINOR] checks: ensure that we can inherit binary checks from the defaults section
18414 - [MINOR] acl: add the http_req_first match
18415 - [DOC] fix typos about bind-process syntax
18416 - [BUG] cookie: correctly unset default cookie parameters
18417 - [MINOR] cookie: add support for the "preserve" option
18418 - [BUG] ebtree: fix duplicate strings insertion
18419 - [CONTRIB] halog: report per-url counts, errors and times
18420 - [CONTRIB] halog: minor speed improvement in timer parser
18421 - [MINOR] buffers: add a new request analyser flag for PROXY mode
18422 - [MINOR] listener: add the "accept-proxy" option to the "bind" keyword
18423 - [MINOR] standard: add read_uint() to parse a delimited unsigned integer
18424 - [MINOR] standard: change arg type from const char* to char*
18425 - [MINOR] frontend: add a new analyser to parse a proxied connection
18426 - [MEDIUM] session: call the frontend_decode_proxy analyser on proxied connections
18427 - [DOC] add the proxy protocol's specifications
18428 - [DOC] document the 'accept-proxy' bind option
18429 - [MINOR] cfgparse: report support of <path> for the 'bind' statements
18430 - [DOC] add references to unix socket handling
18431 - [MINOR] move MAXPATHLEN definition to compat.h
18432 - [MEDIUM] unix sockets: cleanup the error reporting path
18433 - [BUG] session: don't stop forwarding of data upon last packet
18434 - [CLEANUP] accept: replace some inappropriate Alert() calls with send_log()
18435 - [BUILD] peers: shut a printf format warning (key_size is a size_t)
18436 - [BUG] accept: don't close twice upon error
18437 - [OPTIM] session: don't recheck analysers when buffer flags have not changed
18438 - [OPTIM] stream_sock: don't clear FDs that are already cleared
18439 - [BUG] proto_tcp: potential bug on pattern fetch dst and dport
18440
Willy Tarreau37242fa2010-08-28 19:21:00 +0200184412010/08/28 : 1.5-dev2
18442 - [MINOR] startup: release unused structs after forking
18443 - [MINOR] startup: don't wait for nothing when no old pid remains
18444 - [CLEANUP] reference product branch 1.5
18445 - [MEDIUM] signals: add support for registering functions and tasks
18446 - [MEDIUM] signals: support redistribution of signal zero when stopping
18447 - [BUG] http: don't set auto_close if more data are expected
18448
Willy Tarreaufc815fd2010-08-25 10:56:53 +0200184492010/08/25 : 1.5-dev1
18450 - [BUG] stats: session rate limit gets garbaged in the stats
18451 - [DOC] mention 'option http-server-close' effect in Tq section
18452 - [DOC] summarize and highlight persistent connections behaviour
18453 - [DOC] add configuration samples
18454 - [BUG] http: dispatch and http_proxy modes were broken for a long time
18455 - [BUG] http: the transaction must be initialized even in TCP mode
18456 - [BUG] tcp: dropped connections must be counted as "denied" not "failed"
18457 - [BUG] consistent hash: balance on all servers, not only 2 !
18458 - [CONTRIB] halog: report per-server status codes, errors and response times
18459 - [BUG] http: the transaction must be initialized even in TCP mode (part 2)
18460 - [BUG] client: always ensure to zero rep->analysers
18461 - [BUG] session: clear BF_READ_ATTACHED before next I/O
18462 - [BUG] http: automatically close response if req is aborted
18463 - [BUG] proxy: connection rate limiting was eating lots of CPU
18464 - [BUG] http: report correct flags in case of client aborts during body
18465 - [TESTS] refine non-regression tests and add 4 new tests
18466 - [BUG] debug: wrong pointer was used to report a status line
18467 - [BUG] debug: correctly report truncated messages
18468 - [DOC] document the "dispatch" keyword
18469 - [BUG] stick_table: fix possible memory leak in case of connection error
18470 - [CLEANUP] acl: use 'L6' instead of 'L4' in ACL flags relying on contents
18471 - [MINOR] accept: count the incoming connection earlier
18472 - [CLEANUP] tcp: move some non tcp-specific layer6 processing out of proto_tcp
18473 - [CLEANUP] client: move some ACLs away to their respective locations
18474 - [CLEANUP] rename client -> frontend
18475 - [MEDIUM] separate protocol-level accept() from the frontend's
18476 - [MINOR] proxy: add a list to hold future layer 4 rules
18477 - [MEDIUM] config: parse tcp layer4 rules (tcp-request accept/reject)
18478 - [MEDIUM] tcp: check for pure layer4 rules immediately after accept()
18479 - [OPTIM] frontend: tell the compiler that errors are unlikely to occur
18480 - [MEDIUM] frontend: check for LI_O_TCP_RULES in the listener
18481 - [MINOR] frontend: only check for monitor-net rules if LI_O_CHK_MONNET is set
18482 - [CLEANUP] buffer->cto is not used anymore
18483 - [MEDIUM] session: finish session establishment sequence in with I/O handlers
18484 - [MEDIUM] session: initialize server-side timeouts after connect()
18485 - [MEDIUM] backend: initialize the server stream_interface upon connect()
18486 - [MAJOR] frontend: don't initialize the server-side stream_int anymore
18487 - [MEDIUM] session: move the conn_retries attribute to the stream interface
18488 - [MEDIUM] session: don't assign conn_retries upon accept() anymore
18489 - [MINOR] frontend: rely on the frontend and not the backend for INDEPSTR
18490 - [MAJOR] frontend: reorder the session initialization upon accept
18491 - [MINOR] proxy: add an accept() callback for the application layer
18492 - [MAJOR] frontend: split accept() into frontend_accept() and session_accept()
18493 - [MEDIUM] stats: rely on the standard session_accept() function
18494 - [MINOR] buffer: refine the flags that may wake an analyser up.
18495 - [MINOR] stream_sock: don't dereference a non-existing frontend
18496 - [MINOR] session: differenciate between accepted connections and received connections
18497 - [MEDIUM] frontend: count the incoming connection earlier
18498 - [MINOR] frontend: count denied TCP requests separately
18499 - [CLEANUP] stick_table: add/clarify some comments
18500 - [BUILD] memory: add a few missing parenthesis to the pool management macros
18501 - [MINOR] stick_table: add support for variable-sized data
18502 - [CLEANUP] stick_table: rename some stksess struct members to avoid confusion
18503 - [CLEANUP] stick_table: move pattern to key functions to stick_table.c
18504 - [MEDIUM] stick_table: add room for extra data types
18505 - [MINOR] stick_table: add support for "conn_cum" data type.
18506 - [MEDIUM] stick_table: don't overwrite data when storing an entry
18507 - [MINOR] config: initialize stick tables after all the parsing
18508 - [MINOR] stick_table: provide functions to return stksess data from a type
18509 - [MEDIUM] stick_table: move the server ID to a generic data type
18510 - [MINOR] stick_table: enable it for frontends too
18511 - [MINOR] stick_table: export the stick_table_key
18512 - [MINOR] tcp: add per-source connection rate limiting
18513 - [MEDIUM] stick_table: separate storage and update of session entries
18514 - [MEDIUM] stick-tables: add a reference counter to each entry
18515 - [MINOR] session: add a pointer to the tracked counters for the source
18516 - [CLEANUP] proto_tcp: make the config parser a little bit more flexible
18517 - [BUG] config: report the correct proxy type in tcp-request errors
18518 - [MINOR] config: provide a function to quote args in a more friendly way
18519 - [BUG] stick_table: the fix for the memory leak caused a regression
18520 - [MEDIUM] backend: support servers on 0.0.0.0
18521 - [BUG] stick-table: correctly refresh expiration timers
18522 - [MEDIUM] stream-interface: add a ->release callback
18523 - [MINOR] proxy: add a "parent" member to the structure
18524 - [MEDIUM] session: make it possible to call an I/O handler on both SI
18525 - [MINOR] tools: add a fast div64_32 function
18526 - [MINOR] freq_ctr: add new types and functions for periods different from 1s
18527 - [MINOR] errors: provide new status codes for config parsing functions
18528 - [BUG] http: denied requests must not be counted as denied resps in listeners
18529 - [MINOR] tools: add a get_std_op() function to parse operators
18530 - [MEDIUM] acl: make use of get_std_op() to parse intger ranges
18531 - [MAJOR] stream_sock: better wakeup conditions on read()
18532 - [BUG] session: analysers must be checked when SI state changes
18533 - [MINOR] http: reset analysers to listener's, not frontend's
18534 - [MEDIUM] session: support "tcp-request content" rules in backends
18535 - [BUILD] always match official tags when doing git-tar
18536 - [MAJOR] stream_interface: fix the wakeup conditions for embedded iohandlers
18537 - [MEDIUM] buffer: make buffer_feed* support writing non-contiguous chunks
18538 - [MINOR] tcp: src_count acl does not have a permanent result
18539 - [MAJOR] session: add track-counters to track counters related to the session
18540 - [MINOR] stick-table: provide a table lookup function
18541 - [MINOR] stick-table: use suffix "_cnt" for cumulated counts
18542 - [MEDIUM] session: move counter ACL fetches from proto_tcp
18543 - [MEDIUM] session: add concurrent connections counter
18544 - [MEDIUM] session: add data in and out volume counters
18545 - [MINOR] session: add the trk_conn_cnt ACL keyword to track connection counts
18546 - [MEDIUM] session-counters: automatically update tracked connection count
18547 - [MINOR] session: add the trk_conn_cur ACL keyword to track concurrent connection
18548 - [MINOR] session: add trk_kbytes_* ACL keywords to track data size
18549 - [MEDIUM] session: add a counter on the cumulated number of sessions
18550 - [MINOR] config: support a comma-separated list of store data types in stick-table
18551 - [MEDIUM] stick-tables: add support for arguments to data_types
18552 - [MEDIUM] stick-tables: add stored data argument type checking
18553 - [MEDIUM] session counters: add conn_rate and sess_rate counters
18554 - [MEDIUM] session counters: add bytes_in_rate and bytes_out_rate counters
18555 - [MINOR] stktable: add a stktable_update_key() function
18556 - [MINOR] session-counters: add a general purpose counter (gpc0)
18557 - [MEDIUM] session-counters: add HTTP req/err tracking
18558 - [MEDIUM] stats: add "show table [<name>]" to dump a stick-table
18559 - [MEDIUM] stats: add "clear table <name> key <value>" to clear table entries
18560 - [CLEANUP] stick-table: declare stktable_data_types as extern
18561 - [MEDIUM] stick-table: make use of generic types for stored data
18562 - [MINOR] stats: correctly report errors on "show table" and "clear table"
18563 - [MEDIUM] stats: add the ability to dump table entries matching criteria
18564 - [DOC] configuration: document all the new tracked counters
18565 - [DOC] stats: document "show table" and "clear table"
18566 - [MAJOR] session-counters: split FE and BE track counters
18567 - [MEDIUM] tcp: accept the "track-counters" in "tcp-request content" rules
18568 - [MEDIUM] session counters: automatically remove expired entries.
18569 - [MEDIUM] config: replace 'tcp-request <action>' with "tcp-request connection"
18570 - [MEDIUM] session-counters: make it possible to count connections from frontend
18571 - [MINOR] session-counters: use "track-sc{1,2}" instead of "track-{fe,be}-counters"
18572 - [MEDIUM] session-counters: correctly unbind the counters tracked by the backend
18573 - [CLEANUP] stats: use stksess_kill() to remove table entries
18574 - [DOC] update the references to session counters and to tcp-request connection
18575 - [DOC] cleanup: split a few long lines
18576 - [MEDIUM] http: forward client's close when abortonclose is set
18577 - [BUG] queue: don't dequeue proxy-global requests on disabled servers
18578 - [BUG] stats: global stats timeout may be specified before stats socket.
18579 - [BUG] conf: add tcp-request content rules to the correct list
18580
Willy Tarreau21475e32010-05-23 08:46:08 +0200185812010/05/23 : 1.5-dev0
18582 - exact copy of 1.4.6
18583
Willy Tarreau5fdd77d2010-05-16 22:34:28 +0200185842010/05/16 : 1.4.6
18585 - [BUILD] ebtree: update to v6.0.1 to remove references to dprintf()
18586 - [CLEANUP] acl: make use of eb_is_empty() instead of open coding the tree's emptiness test
18587 - [MINOR] acl: add srv_is_up() to check that a specific server is up or not
18588 - [DOC] add a few precisions about the use of RDP cookies
18589
Willy Tarreau9d4d9e32010-05-13 22:17:08 +0200185902010/05/13 : 1.4.5
18591 - [DOC] report minimum kernel version for tproxy in the Makefile
18592 - [MINOR] add the "ignore-persist" option to conditionally ignore persistence
18593 - [DOC] add the "ignore-persist" option to conditionally ignore persistence
18594 - [DOC] fix ignore-persist/force-persist documentation
18595 - [BUG] cttproxy: socket fd leakage in check_cttproxy_version
18596 - [DOC] doc/configuration.txt: fix typos
18597 - [MINOR] option http-pretend-keepalive is both for FEs and BEs
18598 - [MINOR] fix possible crash in debug mode with invalid responses
18599 - [MINOR] halog: add support for statisticts on status codes
18600 - [OPTIM] halog: use a faster zero test in fgets()
18601 - [OPTIM] halog: minor speedup by using unlikely()
18602 - [OPTIM] halog: speed up fgets2-64 by about 10%
18603 - [DOC] refresh the README file and merge the CONTRIB file into it
18604 - [MINOR] acl: support loading values from files
18605 - [MEDIUM] ebtree: upgrade to version 6.0
18606 - [MINOR] acl trees: add flags and union members to store values in trees
18607 - [MEDIUM] acl: add ability to insert patterns in trees
18608 - [MEDIUM] acl: add tree-based lookups of exact strings
18609 - [MEDIUM] acl: add tree-based lookups of networks
18610 - [MINOR] acl: ignore empty lines and comments in pattern files
18611 - [MINOR] stick-tables: add support for "stick on hdr"
18612
Willy Tarreau9508c1c2010-04-07 23:12:24 +0200186132010/04/07 : 1.4.4
18614 - [BUG] appsession should match the whole cookie name
18615 - [CLEANUP] proxy: move PR_O_SSL3_CHK to options2 to release one flag
18616 - [MEDIUM] backend: move the transparent proxy address selection to backend
18617 - [MINOR] add very fast IP parsing functions
18618 - [MINOR] add new tproxy flags for dynamic source address binding
18619 - [MEDIUM] add ability to connect to a server from an IP found in a header
18620 - [BUILD] config: last patch breaks build without CONFIG_HAP_LINUX_TPROXY
18621 - [MINOR] http: make it possible to pretend keep-alive when doing close
18622 - [MINOR] config: report "default-server" instead of "(null)" in error messages
18623
Willy Tarreau75934a12010-03-30 09:50:08 +0200186242010/03/30 : 1.4.3
18625 - [CLEANUP] stats: remove printf format warning in stats_dump_full_sess_to_buffer()
18626 - [MEDIUM] session: better fix for connection to servers with closed input
18627 - [DOC] indicate in the doc how to bind to port ranges
18628 - [BUG] backend: L7 hashing must not be performed on incomplete requests
18629 - [TESTS] add a simple program to test connection resets
18630 - [MINOR] cli: "show errors" should display "backend <NONE>" when backend was not used
18631 - [MINOR] config: emit warnings when HTTP-only options are used in TCP mode
18632 - [MINOR] config: allow "slowstart 0s"
18633 - [BUILD] 'make tags' did not consider files ending in '.c'
18634 - [MINOR] checks: add the ability to disable a server in the config
18635
Willy Tarreauda618cb2010-03-17 23:41:57 +0100186362010/03/17 : 1.4.2
18637 - [CLEANUP] product branch update
18638 - [DOC] Some more documentation cleanups
18639 - [BUG] clf logs segfault when capturing a non existant header
18640 - [OPTIM] config: only allocate check buffer when checks are enabled
18641 - [MEDIUM] checks: support multi-packet health check responses
18642 - [CLEANUP] session: remove duplicate test
18643 - [BUG] http: don't wait for response data to leave buffer is client has left
18644 - [MINOR] proto_uxst: set accept_date upon accept() to the wall clock time
18645 - [MINOR] stats: don't send empty lines in "show errors"
18646 - [MINOR] stats: make the data dump function reusable for other purposes
18647 - [MINOR] stats socket: add show sess <id> to dump details about a session
18648 - [BUG] stats: connection reset counters must be plain ascii, not HTML
18649 - [BUG] url_param hash may return a down server
18650 - [MINOR] force null-termination of hostname
18651 - [MEDIUM] connect to servers even when the input has already been closed
18652 - [BUG] don't merge anonymous ACLs !
18653 - [BUG] config: fix endless loop when parsing "on-error"
18654 - [MINOR] http: don't mark a server as failed when it returns 501/505
18655 - [OPTIM] checks: try to detect the end of response without polling again
18656 - [BUG] checks: don't report an error when recv() returns an error after data
18657 - [BUG] checks: don't abort when second poll returns an error
18658 - [MINOR] checks: make shutdown() silently fail
18659 - [BUG] http: fix truncated responses on chunk encoding when size divides buffer size
18660 - [BUG] init: unconditionally catch SIGPIPE
18661 - [BUG] checks: don't wait for a close to start parsing the response
18662
Willy Tarreauc5e60c32010-03-04 23:39:19 +0100186632010/03/04 : 1.4.1
18664 - [BUG] Clear-cookie path issue
18665 - [DOC] fix typo on stickiness rules
18666 - [BUILD] fix BSD and OSX makefiles for missing files
18667 - [BUILD] includes order breaks OpenBSD build
18668 - [BUILD] fix some build warnings on Solaris with is* macros
18669 - [BUG] logs: don't report "last data" when we have just closed after an error
18670 - [BUG] logs: don't report "proxy request" when server closes early
18671 - [BUILD] fix platform-dependant build issues related to crypt()
18672 - [STATS] count transfer aborts caused by client and by server
18673 - [STATS] frontend requests were not accounted for failed requests
18674 - [MINOR] report total number of processed connections when stopping a proxy
18675 - [DOC] be more clear about the limitation to one single monitor-net entry
18676
Willy Tarreaue18fdfd2010-02-26 14:55:22 +0100186772010/02/26 : 1.4.0
18678 - [MINOR] stats: report maint state for tracking servers too
18679 - [DOC] fix summary to add pattern extraction
18680 - [DOC] Documentation cleanups
18681 - [BUG] cfgparse memory leak and missing free calls in deinit()
18682 - [BUG] pxid/puid/luid: don't shift IDs when some of them are forced
18683 - [EXAMPLES] add auth.cfg
18684 - [BUG] uri_auth: ST_SHLGNDS should be 0x00000008 not 0x0000008
18685 - [BUG] uri_auth: do not attemp to convert uri_auth -> http-request more than once
18686 - [BUILD] auth: don't use unnamed unions
18687 - [BUG] config: report unresolvable host names as errors
18688 - [BUILD] fix build breakage with DEBUG_FULL
18689 - [DOC] fix a typo about timeout check and clarify the explanation.
18690 - [MEDIUM] http: don't use trash to realign large buffers
18691 - [STATS] report HTTP requests (total and rate) in frontends
18692 - [STATS] separate frontend and backend HTTP stats
18693 - [MEDIUM] http: revert to use a swap buffer for realignment
18694 - [MINOR] stats: report the request rate in frontends as cell titles
18695 - [MINOR] stats: mark areas with an underline when tooltips are available
18696 - [DOC] reorder some entries to maintain the alphabetical order
18697 - [DOC] cleanup of the keyword matrix
18698
Willy Tarreaub05613d2010-02-02 10:18:28 +0100186992010/02/02 : 1.4-rc1
18700 - [MEDIUM] add a maintenance mode to servers
18701 - [MINOR] http-auth: last fix was wrong
18702 - [CONTRIB] add base64rev-gen.c that was used to generate the base64rev table.
18703 - [MINOR] Base64 decode
18704 - [MINOR] generic auth support with groups and encrypted passwords
18705 - [MINOR] add ACL_TEST_F_NULL_MATCH
18706 - [MINOR] http-request: allow/deny/auth support for frontend/backend/listen
18707 - [MINOR] acl: add http_auth and http_auth_group
18708 - [MAJOR] use the new auth framework for http stats
18709 - [DOC] add info about userlists, http-request and http_auth/http_auth_group acls
18710 - [STATS] make it possible to change a CLI connection timeout
18711 - [BUG] patterns: copy-paste typo in type conversion arguments
18712 - [MINOR] pattern: make the converter more flexible by supporting void* and int args
18713 - [MINOR] standard: str2mask: string to netmask converter
18714 - [MINOR] pattern: add support for argument parsers for converters
18715 - [MINOR] pattern: add the "ipmask()" converting function
18716 - [MINOR] config: off-by-one in "stick-table" after list of converters
18717 - [CLEANUP] acl, patterns: make use of my_strndup() instead of malloc+memcpy
18718 - [BUG] restore accidentely removed line in last patch !
18719 - [MINOR] checks: make the HTTP check code add the CRLF itself
18720 - [MINOR] checks: add the server's status in the checks
18721 - [BUILD] halog: make without arch-specific optimizations
18722 - [BUG] halog: fix segfault in case of empty log in PCT mode (cherry picked from commit fe362fe4762151d209b9656639ee1651bc2b329d)
18723 - [MINOR] http: disable keep-alive when process is going down
18724 - [MINOR] acl: add build_acl_cond() to make it easier to add ACLs in config
18725 - [CLEANUP] config: use build_acl_cond() instead of parse_acl_cond()
18726 - [CLEANUP] config: use warnif_cond_requires_resp() to check for bad ACLs
18727 - [MINOR] prepare req_*/rsp_* to receive a condition
18728 - [CLEANUP] config: specify correct const char types to warnif_* functions
18729 - [MEDIUM] config: factor out the parsing of 20 req*/rsp* keywords
18730 - [MEDIUM] http: make the request filter loop check for optional conditions
18731 - [MEDIUM] http: add support for conditional request filter execution
18732 - [DOC] add some build info about the AIX platform (cherry picked from commit e41914c77edbc40aebf827b37542d37d758e371e)
18733 - [MEDIUM] http: add support for conditional request header addition
18734 - [MEDIUM] http: add support for conditional response header rewriting
18735 - [DOC] add some missing ACLs about response header matching
18736 - [MEDIUM] http: add support for proxy authentication
18737 - [MINOR] http-auth: make the 'unless' keyword work as expected
18738 - [CLEANUP] config: use build_acl_cond() to simplify http-request ACL parsing
18739 - [MEDIUM] add support for anonymous ACLs
18740 - [MEDIUM] http: switch to tunnel mode after status 101 responses
18741 - [MEDIUM] http: stricter processing of the CONNECT method
18742 - [BUG] config: reset check request to avoid double free when switching to ssl/sql
18743 - [MINOR] config: fix too large ssl-hello-check message.
18744 - [BUG] fix error response in case of server error
18745
Willy Tarreau2eba6aa2010-01-25 23:28:05 +0100187462010/01/25 : 1.4-dev8
18747 - [CLEANUP] Keep in sync "defaults" support between documentation and code
18748 - [MEDIUM] http: add support for Proxy-Connection header
18749 - [CRITICAL] buffers: buffer_insert_line2 must not change the ->w entry
18750 - [MINOR] http: remove a copy-paste typo in transaction cleaning
18751 - [BUG] http: trim any excess buffer data when recycling a connection
18752
Willy Tarreau6939b552010-01-25 01:54:37 +0100187532010/01/25 : 1.4-dev7
18754 - [BUG] appsession: possible memory leak in case of out of memory condition
18755 - [MINOR] config: don't accept 'appsession' in defaults section
18756 - [MINOR] Add function to parse a size in configuration
18757 - [MEDIUM] Add stick table (persistence) management functions and types
18758 - [MEDIUM] Add pattern fetch management types and functions
18759 - [MEDIUM] Add src dst and dport pattern fetches.
18760 - [MEDIUM] Add stick table configuration and init.
18761 - [MEDIUM] Add stick and store rules analysers.
18762 - [MINOR] add option "mysql-check" to use MySQL health checks
18763 - [BUG] health checks: fix requeued message
18764 - [OPTIM] remove SSP_O_VIA and SSP_O_STATUS
18765 - [BUG] checks: fix newline termination
18766 - [MINOR] acl: add fe_id/so_id to match frontend's and socket's id
18767 - [BUG] appsession's sessid must be reset at end of transaction
18768 - [BUILD] appsession did not build anymore under gcc-2.95
18769 - [BUG] server redirection used an uninitialized string.
18770 - [MEDIUM] http: fix handling of message pointers
18771 - [MINOR] http: fix double slash prefix with server redirect
18772 - [MINOR] http redirect: add the ability to append a '/' to the URL
18773 - [BUG] stream_interface: fix retnclose and remove cond_close
18774 - [MINOR] http redirect: don't explicitly state keep-alive on 1.1
18775 - [MINOR] http: move appsession 'sessid' from session to http_txn
18776 - [OPTIM] reorder http_txn to optimize cache lines placement
18777 - [MINOR] http: differentiate waiting for new request and waiting for a complete requst
18778 - [MINOR] http: add a separate "http-keep-alive" timeout
18779 - [MINOR] config: remove undocumented and buggy 'timeout appsession'
18780 - [DOC] fix various too large lines
18781 - [DOC] remove several trailing spaces
18782 - [DOC] add the doc about stickiness
18783 - [BUILD] remove a warning in standard.h on AIX
18784 - [BUG] checks: chars are unsigned on AIX, check was always true
18785 - [CLEANUP] stream_sock: MSG_NOSIGNAL is only for send(), not recv()
18786 - [BUG] check: we must not check for error before reading a response
18787 - [BUG] buffers: remove remains of wrong obsolete length check
18788 - [OPTIM] stream_sock: don't shutdown(write) when the socket is in error
18789 - [BUG] http: don't count req errors on client resets or t/o during keep-alive
18790 - [MEDIUM] http: don't switch to tunnel mode upon close
18791 - [DOC] add documentation about connection header processing
18792 - [MINOR] http: add http_remove_header2() to remove a header value.
18793 - [MINOR] tools: add a "word_match()" function to match words and ignore spaces
18794 - [MAJOR] http: rework request Connection header handling
18795 - [MAJOR] http: rework response Connection header handling
18796 - [MINOR] add the ability to force kernel socket buffer size.
18797 - [BUG] http_server_error() must not purge a previous pending response
18798 - [OPTIM] http: don't delay response if next request is incomplete
18799 - [MINOR] add the "force-persist" statement to force persistence on down servers
18800 - [MINOR] http: logs must report persistent connections to down servers
18801 - [BUG] buffer_replace2 must never change the ->w entry
18802
Willy Tarreau11f8f542010-01-08 07:49:44 +0100188032010/01/08 : 1.4-dev6
18804 - [BUILD] warning in stream_interface.h
18805 - [BUILD] warning ultoa_r returns char *
18806 - [MINOR] hana: only report stats if it is enabled
18807 - [MINOR] stats: add "a link" & "a href" for sockets
18808 - [MINOR]: stats: add show-legends to report additional informations
18809 - [MEDIUM] default-server support
18810 - [BUG]: add 'observer', 'on-error', 'error-limit' to supported options list
18811 - [MINOR] stats: add href to tracked server
18812 - [BUG] stats: show UP/DOWN status also in tracking servers
18813 - [DOC] Restore ability to search a keyword at the beginning of a line
18814 - [BUG] stats: cookie should be reported under backend not under proxy
18815 - [BUG] cfgparser/stats: fix error message
18816 - [BUG] http: disable auto-closing during chunk analysis
18817 - [BUG] http: fix hopefully last closing issue on data forwarding
18818 - [DEBUG] add an http_silent_debug function to debug HTTP states
18819 - [MAJOR] http: fix again the forward analysers
18820 - [BUG] http_process_res_common() must not skip the forward analyser
18821 - [BUG] http: some possible missed close remain in the forward chain
18822 - [BUG] http: redirect needed to be updated after recent changes
18823 - [BUG] http: don't set no-linger on response in case of forced close
18824 - [MEDIUM] http: restore the original behaviour of option httpclose
18825 - [TESTS] add a file to test various connection modes
18826 - [BUG] http: check options before the connection header
18827 - [MAJOR] session: fix the order by which the analysers are run
18828 - [MEDIUM] session: also consider request analysers added during response
18829 - [MEDIUM] http: make safer use of the DONT_READ and AUTO_CLOSE flags
18830 - [BUG] http: memory leak with captures when using keep-alive
18831 - [BUG] http: fix for capture memory leak was incorrect
18832 - [MINOR] http redirect: use proper call to return last response
18833 - [MEDIUM] http: wait for some flush of the response buffer before a new request
18834 - [MEDIUM] session: limit the number of analyser loops
18835
Willy Tarreau1f445892010-01-03 23:23:36 +0100188362010/01/03 : 1.4-dev5
18837 - [MINOR] server tracking: don't care about the tracked server's mode
18838 - [MEDIUM] appsession: add "len", "prefix" and "mode" options
18839 - [MEDIUM] appsession: add the "request-learn" option
18840 - [BUG] Configuration parser bug when escaping characters
18841 - [MINOR] CSS & HTML fun
18842 - [MINOR] Collect & provide http response codes received from servers
18843 - [BUG] Fix silly typo: hspr_other -> hrsp_other
18844 - [MINOR] Add "a name" to stats page
18845 - [MINOR] add additional "a href"s to stats page
18846 - [MINOR] Collect & provide http response codes for frontends, fix backends
18847 - [DOC] some small spell fixes and unifications
18848 - [MEDIUM] Decrease server health based on http responses / events, version 3
18849 - [BUG] format '%d' expects type 'int', but argument 5 has type 'long int'
18850 - [BUG] config: fix erroneous check on cookie domain names, again
18851 - [BUG] Healthchecks: get a proper error code if connection cannot be completed immediately
18852 - [DOC] trivial fix for man page
18853 - [MINOR] config: report all supported options for the "bind" keyword
18854 - [MINOR] tcp: add support for the defer_accept bind option
18855 - [MINOR] unix socket: report the socket path in case of bind error
18856 - [CONTRIB] halog: support searching by response time
18857 - [DOC] add a reminder about obsolete documents
18858 - [DOC] point to 1.4 doc, not 1.3
18859 - [DOC] option tcp-smart-connect was missing from index
18860 - [MINOR] http: detect connection: close earlier
18861 - [CLEANUP] sepoll: clean up the fd_clr/fd_set functions
18862 - [OPTIM] move some rarely used fields out of fdtab
18863 - [MEDIUM] fd: merge fd_list into fdtab
18864 - [MAJOR] buffer: flag BF_DONT_READ to disable reads when not required
18865 - [MINOR] http: add new transaction flags for keep-alive and content-length
18866 - [MEDIUM] http request: parse connection, content-length and transfer-encoding
18867 - [MINOR] http request: update the TX_SRV_CONN_KA flag on rewrite
18868 - [MINOR] http request: simplify the test of no-data
18869 - [MEDIUM] http request: simplify POST length detection
18870 - [MEDIUM] http request: make use of pre-parsed transfer-encoding header
18871 - [MAJOR] http: create the analyser which waits for a response
18872 - [MINOR] http: pre-set the persistent flags in the transaction
18873 - [MEDIUM] http response: check body length and set transaction flags
18874 - [MINOR] http response: update the TX_CLI_CONN_KA flag on rewrite
18875 - [MINOR] http: remove the last call to stream_int_return
18876 - [IMPORT] import ebtree v5.0 into directory ebtree/
18877 - [MEDIUM] build: switch ebtree users to use new ebtree version
18878 - [CLEANUP] ebtree: remove old unused files
18879 - [BUG] definitely fix regparm issues between haproxy core and ebtree
18880 - [CLEANUP] ebtree: cast to char * to get rid of gcc warning
18881 - [BUILD] missing #ifndef in ebmbtree.h
18882 - [BUILD] missing #ifndef in ebsttree.h
18883 - [MINOR] tools: add hex2i() function to convert hex char to int
18884 - [MINOR] http: create new MSG_BODY sub-states
18885 - [BUG] stream_sock: BUF_INFINITE_FORWARD broke splice on 64-bit platforms
18886 - [DOC] option is "defer-accept", not "defer_accept"
18887 - [MINOR] http: keep pointer to beginning of data
18888 - [BUG] x-original-to: name was not set in default instance
18889 - [MINOR] http: detect tunnel mode and set it in the session
18890 - [BUG] config: fix error message when config file is not found
18891 - [BUG] config: fix wrong handling of too large argument count
18892 - [BUG] config: disable 'option httplog' on TCP proxies
18893 - [BUG] config: fix erroneous check on cookie domain names
18894 - [BUG] config: cookie domain was ignored in defaults sections
18895 - [MINOR] config: support passing multiple "domain" statements to cookies
18896 - [MINOR] ebtree: add functions to lookup non-null terminated strings
18897 - [MINOR] config: don't report error on all subsequent files on failure
18898 - [BUG] second fix for the printf format warning
18899 - [BUG] check_post: limit analysis to the buffer length
18900 - [MEDIUM] http: process request body in a specific analyser
18901 - [MEDIUM] backend: remove HTTP POST parsing from get_server_ph_post()
18902 - [MAJOR] http: completely process the "connection" header
18903 - [MINOR] http: only consider chunk encoding with HTTP/1.1
18904 - [MAJOR] buffers: automatically compute the maximum buffer length
18905 - [MINOR] http: move the http transaction init/cleanup code to proto_http
18906 - [MINOR] http: move 1xx handling earlier to eliminate a lot of ifs
18907 - [MINOR] http: introduce a new synchronisation state : HTTP_MSG_DONE
18908 - [MEDIUM] http: rework chunk-size parser
18909 - [MEDIUM] http: add a new transaction flags indicating if we know the transfer length
18910 - [MINOR] buffers: add buffer_ignore() to skip some bytes
18911 - [BUG] http: offsets are relative to the buffer, not to ->som
18912 - [MEDIUM] http: automatically re-aling request buffer
18913 - [BUG] http: body parsing must consider the start of message
18914 - [MINOR] new function stream_int_cond_close()
18915 - [MAJOR] http: implement body parser
18916 - [BUG] http: typos on several unlikely() around header insertion
18917 - [BUG] stream_sock: wrong max computation on recv
18918 - [MEDIUM] http: rework the buffer alignment logic
18919 - [BUG] buffers: wrong size calculation for displaced data
18920 - [MINOR] stream_sock: prepare for closing when all pending data are sent
18921 - [MEDIUM] http: add two more states for the closing period
18922 - [MEDIUM] http: properly handle "option forceclose"
18923 - [MINOR] stream_sock: add SI_FL_NOLINGER for faster close
18924 - [MEDIUM] http: make forceclose use SI_FL_NOLINGER
18925 - [MEDIUM] session: set SI_FL_NOLINGER when aborting on write timeouts
18926 - [MEDIUM] http: add some SI_FL_NOLINGER around server errors
18927 - [MINOR] config: option forceclose is valid in frontends too
18928 - [BUILD] halog: insufficient include path in makefile
18929 - [MEDIUM] http: make the analyser not rely on msg being initialized anymore
18930 - [MEDIUM] http: make the parsers able to wait for a buffer flush
18931 - [MAJOR] http: add support for option http-server-close
18932 - [BUG] http: ensure we abort data transfer on write error
18933 - [BUG] last fix was overzealous and disabled server-close
18934 - [BUG] http: fix erroneous trailers size computation
18935 - [MINOR] stream_sock: enable MSG_MORE when forwarding finite amount of data
18936 - [OPTIM] http: set MSG_MORE on response when a pipelined request is pending
18937 - [BUG] http: redirects were broken by chunk changes
18938 - [BUG] http: the request URI pointer is relative to the buffer
18939 - [OPTIM] http: don't immediately enable reading on request
18940 - [MINOR] http: move redirect messages to HTTP/1.1 with a content-length
18941 - [BUG] http: take care of errors, timeouts and aborts during the data phase
18942 - [MINOR] http: don't wait for sending requests to the server
18943 - [MINOR] http: make the conditional redirect support keep-alive
18944 - [BUG] http: fix cookie parser to support spaces and commas in values
18945 - [MINOR] config: some options were missing for "redirect"
18946 - [MINOR] redirect: add support for unconditional rules
18947 - [MINOR] config: centralize proxy struct initialization
18948 - [MEDIUM] config: remove the limitation of 10 reqadd/rspadd statements
18949 - [MEDIUM] config: remove the limitation of 10 config files
18950 - [CLEANUP] http: remove a remaining impossible condition
18951 - [OPTIM] http: optimize a bit the construct of the forward loops
18952
Willy Tarreauc82a9e52009-10-12 06:40:53 +0200189532009/10/12 : 1.4-dev4
18954 - [DOC] add missing rate_lim and rate_max
18955 - [MAJOR] struct chunk rework
18956 - [MEDIUM] Health check reporting code rework + health logging, v3
18957 - [BUG] check if rise/fall has an argument and it is > 0
18958 - [MINOR] health checks logging unification
18959 - [MINOR] add "description", "node" and show-node"/"show-desc", remove "node-name", v2
18960 - [MINOR] Allow dots in show-node & add "white-space: nowrap" in th.pxname.
18961 - [DOC] Add information about http://haproxy.1wt.eu/contrib.html
18962 - [MINOR] Introduce include/types/counters.h
18963 - [CLEANUP] Move counters to dedicated structures
18964 - [MINOR] Add "clear counters" to clear statistics counters
18965 - [MEDIUM] Collect & provide separate statistics for sockets, v2
18966 - [BUG] Fix NULL pointer dereference in stats_check_uri_auth(), v2
18967 - [MINOR] acl: don't report valid acls as potential mistakes
18968 - [MINOR] Add cut_crlf(), ltrim(), rtrim() and alltrim()
18969 - [MINOR] Add chunk_htmlencode and chunk_asciiencode
18970 - [MINOR] Capture & display more data from health checks, v2
18971 - [BUG] task.c: don't assing last_timer to node-less entries
18972 - [BUG] http stats: large outputs sometimes got some parts chopped off
18973 - [MINOR] backend: export some functions to recount servers
18974 - [MINOR] backend: uninline some LB functions
18975 - [MINOR] include time.h from freq_ctr.h as is uses "now".
18976 - [CLEANUP] backend: move LB algos to individual files
18977 - [MINOR] lb_map: reorder code in order to ease integration of new hash functions
18978 - [CLEANUP] proxy: move last lb-specific bits to their respective files
18979 - [MINOR] backend: separate declarations of LB algos from their lookup method
18980 - [MINOR] backend: reorganize the LB algorithm selection
18981 - [MEDIUM] backend: introduce the "static-rr" LB algorithm
18982 - [MINOR] report list of supported pollers with -vv
18983 - [DOC] log-health-checks is an option, not a directive
18984 - [MEDIUM] new option "independant-streams" to stop updating read timeout on writes
18985 - [BUG] stats: don't call buffer_shutw(), but ->shutw() instead
18986 - [MINOR] stats: strip CR and LF from the input command line
18987 - [BUG] don't refresh timeouts late after detected activity
18988 - [MINOR] stats_dump_errors_to_buffer: use buffer_feed_chunk()
18989 - [MINOR] stats_dump_sess_to_buffer: use buffer_feed_chunk()
18990 - [MINOR] stats: make stats_dump_raw_to_buffer() use buffer_feed_chunk
18991 - [MEDIUM] stats: don't use s->ana_state anymore
18992 - [MINOR] remove now obsolete ana_state from the session struct
18993 - [MEDIUM] stats: make HTTP stats use an I/O handler
18994 - [MEDIUM] stream_int: adjust WAIT_ROOM handling
18995 - [BUG] config: look for ID conflicts in all sockets, not only last ones.
18996 - [MINOR] config: reference file and line with any listener/proxy/server declaration
18997 - [MINOR] config: report places of duplicate names or IDs
18998 - [MINOR] config: add pointer to file name in block/redirect/use_backend/monitor rules
18999 - [MINOR] tools: add a new get_next_id() function
19000 - [MEDIUM] config: automatically find unused IDs for proxies, servers and listeners
19001 - [OPTIM] counters: move some max numbers to the counters struct
19002 - [BUG] counters: fix segfault on missing counters for a listener
19003 - [MEDIUM] backend: implement consistent hashing variation
19004 - [MINOR] acl: add fe_conn, be_conn, queue, avg_queue
19005 - [MINOR] stats: use 'clear counters all' to clear all values
19006 - [MEDIUM] add access restrictions to the stats socket
19007 - [MINOR] buffers: add buffer_feed2() and make buffer_feed() measure string length
19008 - [MINOR] proxy: provide function to retrieve backend/server pointers
19009 - [MINOR] add the "initial weight" to the server struct.
19010 - [MEDIUM] stats: add the "get weight" command to report a server's weight
19011 - [MEDIUM] stats: add the "set weight" command
19012 - [BUILD] add a 'make tags' target
19013 - [MINOR] stats: add support for numeric IDs in set weight/get weight
19014 - [MINOR] stats: use a dedicated state to output static data
19015 - [OPTIM] stats: check free space before trying to print
19016
Willy Tarreau9f389e02009-09-24 00:12:50 +0200190172009/09/24 : 1.4-dev3
19018 - [BUILD] compilation of haproxy-1.4-dev2 on FreeBSD
19019 - [MEDIUM] Collect & show information about last health check, v3
19020 - [MINOR] export the hostname variable so that all the code can access it
19021 - [MINOR] stats: add a new node-name setting
19022 - [MEDIUM] remove old experimental tcpsplice option
19023 - [BUILD] fix build for systems without SOL_TCP
19024 - [MEDIUM] move connection establishment from backend to the SI.
19025 - [MEDIUM] make the global stats socket part of a frontend
19026 - [MEDIUM] session: account per-listener connections
19027 - [MINOR] session: switch to established state if no connect function
19028 - [MEDIUM] make the unix stats sockets use the generic session handler
19029 - [CLEANUP] unix: remove uxst_process_session()
19030 - [CLEANUP] move remaining stats sockets code to dumpstats
19031 - [MINOR] move the initial task's nice value to the listener
19032 - [MINOR] cleanup set_session_backend by using pre-computed analysers
19033 - [MINOR] set s->srv_error according to the analysers
19034 - [MEDIUM] set rep->analysers from fe and be analysers
19035 - [MEDIUM] replace BUFSIZE with buf->size in computations
19036 - [MEDIUM] make it possible to change the buffer size in the configuration
19037 - [MEDIUM] report error on buffer writes larger than buffer size
19038 - [MEDIUM] stream_interface: add and use ->update function to resync
19039 - [CLEANUP] remove ifdef MSG_NOSIGNAL and define it instead
19040 - [MEDIUM] remove TCP_CORK and make use of MSG_MORE instead
19041 - [BUG] tarpit did not work anymore
19042 - [MINOR] acl: add support for hdr_ip to match IP addresses in headers
19043 - [MAJOR] buffers: fix misuse of the BF_SHUTW_NOW flag
19044 - [MINOR] buffers: provide more functions to handle buffer data
19045 - [MEDIUM] buffers: provide new buffer_feed*() function
19046 - [MINOR] buffers: add peekchar and peekline functions for stream interfaces
19047 - [MINOR] buffers: provide buffer_si_putchar() to send a char from a stream interface
19048 - [BUG] buffer_forward() would not correctly consider data already scheduled
19049 - [MINOR] buffers: add buffer_cut_tail() to cut only unsent data
19050 - [MEDIUM] stream_interface: make use of buffer_cut_tail() to report errors
19051 - [MAJOR] http: add support for HTTP 1xx informational responses
19052 - [MINOR] buffers: inline buffer_si_putchar()
19053 - [MAJOR] buffers: split BF_WRITE_ENA into BF_AUTO_CONNECT and BF_AUTO_CLOSE
19054 - [MAJOR] buffers: fix the BF_EMPTY flag's meaning
19055 - [BUG] stream_interface: SI_ST_CLO must have buffers SHUT
19056 - [MINOR] stream_sock: don't set SI_FL_WAIT_DATA if BF_SHUTW_NOW is set
19057 - [MEDIUM] add support for infinite forwarding
19058 - [BUILD] stream_interface: fix conflicting declaration
19059 - [BUG] buffers: buffer_forward() must not always clear BF_OUT_EMPTY
19060 - [BUG] variable buffer size ignored at initialization time
19061 - [MINOR] ensure that buffer_feed() and buffer_skip() set BF_*_PARTIAL
19062 - [BUG] fix buffer_skip() and buffer_si_getline() to correctly handle wrap-arounds
19063 - [MINOR] stream_interface: add SI_FL_DONT_WAKE flag
19064 - [MINOR] stream_interface: add iohandler callback
19065 - [MINOR] stream_interface: add functions to support running as internal/external tasks
19066 - [MEDIUM] session: call iohandler for embedded tasks (applets)
19067 - [MINOR] add a ->private member to the stream_interface
19068 - [MEDIUM] stats: prepare the connection for closing before dumping
19069 - [MEDIUM] stats: replace the stats socket analyser with an SI applet
19070
Willy Tarreau68dcd252009-08-09 22:57:09 +0200190712009/08/09 : 1.4-dev2
19072 - [BUG] task: fix possible crash when some timeouts are not configured
19073 - [BUG] log: option tcplog would log to global if no logger was defined
19074
Willy Tarreaub03d2982009-07-29 22:38:32 +0200190752009/07/29 : 1.4-dev1
19076 - [MINOR] acl: add support for matching of RDP cookies
19077 - [MEDIUM] add support for RDP cookie load-balancing
19078 - [MEDIUM] add support for RDP cookie persistence
19079 - [MINOR] add a new CLF log format
19080 - [MINOR] startup: don't imply -q with -D
19081 - [BUG] ensure that we correctly re-start old process in case of error
19082 - [MEDIUM] add support for binding to source port ranges during connect
19083 - [MINOR] config: track "no option"/"option" changes
19084 - [MINOR] config: support resetting options do default values
19085 - [MEDIUM] implement option tcp-smart-accept at the frontend
19086 - [MEDIUM] stream_sock: implement tcp-cork for use during shutdowns on Linux
19087 - [MEDIUM] implement tcp-smart-connect option at the backend
19088 - [MEDIUM] add support for TCP MSS adjustment for listeners
19089 - [MEDIUM] support setting a server weight to zero
19090 - [MINOR] make DEFAULT_MAXCONN user-configurable at build time
19091 - [MAJOR] session: don't clear buffer status flags anymore
19092 - [MAJOR] session: only check for timeouts when they have just occurred.
19093 - [MAJOR] session: simplify buffer error handling
19094 - [MEDIUM] config: split parser and checker in two functions
19095 - [MEDIUM] config: support loading multiple configuration files
19096 - [MEDIUM] stream_sock: don't close prematurely when nolinger is set
19097 - [MEDIUM] session: rework buffer analysis to permit permanent analysers
19098 - [MEDIUM] splice: set the capability on each stream_interface
19099 - [BUG] http: redirect rules were processed too early
19100 - [CLEANUP] remove unused DEBUG_PARSE_NO_SPEEDUP define
19101 - [MEDIUM] http: split request waiter from request processor
19102 - [MEDIUM] session: tell analysers what bit they were called for
19103 - [MAJOR] http: complete splitting of the remaining stages
19104 - [MINOR] report in the proxies the requirements for ACLs
19105 - [MINOR] http: rely on proxy->acl_requires to allocate hdr_idx
19106 - [MINOR] acl: add HTTP protocol detection (req_proto_http)
19107 - [MINOR] prepare callers of session_set_backend to handle errors
19108 - [BUG] default ACLs did not properly set the ->requires flag
19109 - [MEDIUM] allow a TCP frontend to switch to an HTTP backend
19110 - [MINOR] ensure we can jump from swiching rules to http without data
19111 - [MINOR] http: take http request timeout from the backend
19112 - [MINOR] allow TCP inspection rules to make use of HTTP ACLs
19113 - [BUILD] report commit date and not author's date as build date
19114 - [MINOR] acl: don't complain anymore when using L7 acls in TCP
19115 - [BUG] stream_sock: always shutdown(SHUT_WR) before closing
19116 - [BUG] stream_sock: don't stop reading when the poller reports an error
19117 - [BUG] config: tcp-request content only accepts "if" or "unless"
19118 - [BUG] task: fix possible timer drift after update
19119 - [MINOR] apply tcp-smart-connect option for the checks too
19120 - [MINOR] stats: better displaying in MSIE
19121 - [MINOR] config: improve error reporting in global section
19122 - [MINOR] config: improve error reporting in listen sections
19123 - [MINOR] config: the "capture" keyword is not allowed in backends
19124 - [MINOR] config: improve error reporting when checking configuration
19125 - [BUILD] fix a minor build warning on AIX
19126 - [BUILD] use "git cmd" instead of "git-cmd"
19127 - [CLEANUP] report 2009 not 2008 in the copyright banner.
19128 - [MINOR] print usage on the stats sockets upon invalid commands
19129 - [MINOR] acl: detect and report potential mistakes in ACLs
19130 - [BUILD] fix incorrect printf arg count with tcp_splice
19131 - [BUG] fix random pauses on last segment of a series
19132 - [BUILD] add support for build under Cygwin
19133
Willy Tarreau79158882009-06-09 11:59:08 +0200191342009/06/09 : 1.4-dev0
19135 - exact copy of 1.3.18
19136
Willy Tarreaubeb05ae2009-05-10 20:27:47 +0200191372009/05/10 : 1.3.18
19138 - [MEDIUM] add support for "balance hdr(name)"
19139 - [CLEANUP] give a little bit more information in error message
19140 - [MINOR] add X-Original-To: header
19141 - [BUG] x-original-to: fix missing initialization to default value
19142 - [BUILD] spec file: fix broken pipe during rpmbuild and add man file
19143 - [MINOR] improve reporting of misplaced acl/reqxxx rules
19144 - [MEDIUM] http: add options to ignore invalid header names
19145 - [MEDIUM] http: capture invalid requests/responses even if accepted
19146 - [BUILD] add format(printf) to printf-like functions
19147 - [MINOR] fix several printf formats and missing arguments
19148 - [BUG] stats: total and lbtot are unsigned
19149 - [MINOR] fix a few remaining printf-like formats on 64-bit platforms
19150 - [CLEANUP] remove unused make option from haproxy.spec
19151 - [BUILD] make it possible to pass alternative arch at build time
19152 - [MINOR] switch all stat counters to 64-bit
19153 - [MEDIUM] ensure we don't recursively call pool_gc2()
19154 - [CRITICAL] uninitialized response field can sometimes cause crashes
19155 - [BUG] fix wrong pointer arithmetics in HTTP message captures
19156 - [MINOR] rhel init script : support the reload operation
19157 - [MINOR] add basic signal handling functions
19158 - [BUILD] add signal.o to all makefiles
19159 - [MEDIUM] call signal_process_queue from run_poll_loop
19160 - [MEDIUM] pollers: don't wait if a signal is pending
19161 - [MEDIUM] convert all signals to asynchronous signals
19162 - [BUG] O(1) pollers should check their FD before closing it
19163 - [MINOR] don't close stdio fds twice
19164 - [MINOR] add options dontlog-normal and log-separate-errors
19165 - [DOC] minor fixes and rearrangements
19166 - [BUG] fix parser crash on unconditional tcp content rules
19167 - [DOC] rearrange the configuration manual and add a summary
19168 - [MINOR] standard: provide a new 'my_strndup' function
19169 - [MINOR] implement per-logger log level limitation
19170 - [MINOR] compute the max of sessions/s on fe/be/srv
19171 - [MINOR] stats: report max sessions/s and limit in CSV export
19172 - [MINOR] stats: report max sessions/s and limit in HTML stats
19173 - [MINOR] stats/html: use the arial font before helvetica
19174
Willy Tarreauf459b422009-03-29 15:26:57 +0200191752009/03/29 : 1.3.17
19176 - Update specfile to build for v2.6 kernel.
19177 - [BUG] reset the stream_interface connect timeout upon connect or error
19178 - [BUG] reject unix accepts when connection limit is reached
19179 - [MINOR] show sess: report number of calls to each task
19180 - [BUG] don't call epoll_ctl() on closed sockets
19181 - [BUG] stream_sock: disable I/O on fds reporting an error
19182 - [MINOR] sepoll: don't count two events on the same FD.
19183 - [MINOR] show sess: report a lot more information about sessions
19184 - [BUG] stream_sock: check for shut{r,w} before refreshing some timeouts
19185 - [BUG] don't set an expiration date directly from now_ms
19186 - [MINOR] implement ulltoh() to write HTML-formatted numbers
19187 - [MINOR] stats/html: group digits by 3 to clarify numbers
19188 - [BUILD] remove haproxy-small.spec
19189 - [BUILD] makefile: remove unused references to linux24eold and EPOLL_CTL_WORKAROUND
19190
Willy Tarreau8019ffa2009-03-22 23:46:12 +0100191912009/03/22 : 1.3.16
19192 - [BUILD] Fixed Makefile for linking pcre
19193 - [CONTRIB] selinux policy for haproxy
19194 - [MINOR] show errors: encode backslash as well as non-ascii characters
19195 - [MINOR] cfgparse: some cleanups in the consistency checks
19196 - [MINOR] cfgparse: set backends to "balance roundrobin" by default
19197 - [MINOR] tcp-inspect: permit the use of no-delay inspection
19198 - [MEDIUM] reverse internal proxy declaration order to match configuration
19199 - [CLEANUP] config: catch and report some possibly wrong rule ordering
19200 - [BUG] connect timeout is in the stream interface, not the buffer
19201 - [BUG] session: errors were not reported in termination flags in TCP mode
19202 - [MINOR] tcp_request: let the caller take care of errors and timeouts
19203 - [CLEANUP] http: remove some commented out obsolete code in process_response
19204 - [MINOR] update ebtree to version 4.1
19205 - [MEDIUM] scheduler: get rid of the 4 trees thanks and use ebtree v4.1
19206 - [BUG] sched: don't leave 3 lasts tasks unprocessed when niced tasks are present
19207 - [BUG] scheduler: fix improper handling of duplicates __task_queue()
19208 - [MINOR] sched: permit a task to stay up between calls
19209 - [MINOR] task: keep a task count and clean up task creators
19210 - [MINOR] stats: report number of tasks (active and running)
19211 - [BUG] server check intervals must not be null
19212 - [OPTIM] stream_sock: don't retry to read after a large read
19213 - [OPTIM] buffer: new BF_READ_DONTWAIT flag reduces EAGAIN rates
19214 - [MEDIUM] session: don't resync FSMs on non-interesting changes
19215 - [BUG] check for global.maxconn before doing accept()
19216 - [OPTIM] sepoll: do not re-check whole list upon accepts
19217
Willy Tarreau8185ced2009-03-09 22:45:53 +0100192182009/03/09 : 1.3.16-rc2
19219 - [BUG] stream_sock: write timeout must be updated when forwarding !
19220
Willy Tarreauff63b432009-03-09 01:03:42 +0100192212009/03/09 : 1.3.16-rc1
19222 - appsessions: cleanup DEBUG_HASH and initialize request_counter
19223 - [MINOR] acl: add new keyword "connslots"
19224 - [MINOR] cfgparse: fix off-by 2 in error message size
19225 - [BUILD] fix build with gcc 4.3
19226 - [BUILD] fix MANDIR default location to match documentation
19227 - [TESTS] add a debug patch to help trigger the stats bug
19228 - [BUG] Flush buffers also where there are exactly 0 bytes left
19229 - [MINOR] Allow to specify a domain for a cookie
19230 - [BUG/CLEANUP] cookiedomain -> cookie_domain rename + free(p->cookie_domain)
19231 - [MEDIUM] Fix memory freeing at exit
19232 - [MEDIUM] Fix memory freeing at exit, part 2
19233 - [BUG] Fix listen & more of 2 couples <ip>:<port>
19234 - [DOC] remove buggy comment for use_backend
19235 - [CRITICAL] fix server state tracking: it was O(n!) instead of O(n)
19236 - [MEDIUM] add support for URI hash depth and length limits
19237 - [MINOR] permit renaming of x-forwarded-for header
19238 - [BUILD] fix Makefile.bsd and Makefile.osx for stream_interface
19239 - [BUILD] Haproxy won't compile if DEBUG_FULL is defined
19240 - [MEDIUM] upgrade to ebtree v4.0
19241 - [DOC] update the README file with new build options
19242 - [MEDIUM] reduce risk of event starvation in ev_sepoll
19243 - [MEDIUM] detect streaming buffers and tag them as such
19244 - [MEDIUM] add support for conditional HTTP redirection
19245 - [BUILD] make install should depend on haproxy not "all"
19246 - [DEBUG] add a TRACE macro to facilitate runtime data extraction
19247 - [BUG] event pollers must not wait if a task exists in the run queue
19248 - [BUG] queue management: wake oldest request in queues
19249 - [BUG] log: reported queue position was offed-by-one
19250 - [BUG] fix the dequeuing logic to ensure that all requests get served
19251 - [DOC] documentation for the "retries" parameter was missing.
19252 - [MEDIUM] implement a monotonic internal clock
19253 - [MEDIUM] further improve monotonic clock by check forward jumps
19254 - [OPTIM] add branch prediction hints in list manipulations
19255 - [MAJOR] replace ultree with ebtree in wait-queues
19256 - [BUG] we could segfault during exit while freeing uri_auths
19257 - [BUG] wqueue: perform proper timeout comparisons with wrapping values
19258 - [MINOR] introduce now_ms, the current date in milliseconds
19259 - [BUG] disable buffer read timeout when reading stats
19260 - [MEDIUM] rework the wait queue mechanism
19261 - [BUILD] change declaration of base64tab to fix build with Intel C++
19262 - [OPTIM] shrink wake_expired_tasks() by using task_wakeup()
19263 - [MAJOR] use an ebtree instead of a list for the run queue
19264 - [MEDIUM] introduce task->nice and boot access to statistics
19265 - [OPTIM] task_queue: assume most consecutive timers are equal
19266 - [BUILD] silent a warning in unlikely() with gcc 4.x
19267 - [MAJOR] convert all expiration timers from timeval to ticks
19268 - [BUG] use_backend would not correctly consider "unless"
19269 - [TESTS] added test-acl.cfg to test some ACL combinations
19270 - [MEDIUM] add support for configuration keyword registration
19271 - [MEDIUM] modularize the global "stats" keyword configuration parser
19272 - [MINOR] cfgparse: add support for warnings in external functions
19273 - [MEDIUM] modularize the "timeout" keyword configuration parser
19274 - [MAJOR] implement tcp request content inspection
19275 - [MINOR] acl: add a new parsing function: parse_dotted_ver
19276 - [MINOR] acl: add req_ssl_ver in TCP, to match an SSL version
19277 - [CLEANUP] remove unused include/types/client.h
19278 - [CLEANUP] remove many #include <types/xxx> from C files
19279 - [CLEANUP] remove dependency on obsolete INTBITS macro
19280 - [DOC] document the new "tcp-request" keyword and associated ACLs
19281 - [MINOR] acl: add REQ_CONTENT to the list of default acls
19282 - [MEDIUM] acl: permit fetch() functions to set the result themselves
19283 - [MEDIUM] acl: get rid of dummy values in always_true/always_false
19284 - [MINOR] acl: add the "wait_end" acl verb
19285 - [MEDIUM] acl: enforce ACL type checking
19286 - [MEDIUM] acl: set types on all currently known ACL verbs
19287 - [MEDIUM] acl: when possible, report the name and requirements of ACLs in warnings
19288 - [CLEANUP] remove 65 useless NULL checks before free
19289 - [MEDIUM] memory: update pool_free2() to support NULL pointers
19290 - [MEDIUM] buffers: ensure buffer_shut* are properly called upon shutdowns
19291 - [MEDIUM] process_srv: rely on buffer flags for client shutdown
19292 - [MEDIUM] process_srv: don't rely at all on client state
19293 - [MEDIUM] process_cli: don't rely at all on server state
19294 - [BUG] fix segfault with url_param + check_post
19295 - [BUG] server timeout was not considered in some circumstances
19296 - [BUG] client timeout incorrectly rearmed while waiting for server
19297 - [MAJOR] kill CL_STINSPECT and CL_STHEADERS (step 1)
19298 - [MAJOR] get rid of SV_STANALYZE (step 2)
19299 - [MEDIUM] simplify and centralize request timeout cancellation and request forwarding
19300 - [MAJOR] completely separate HTTP and TCP states on the request path
19301 - [BUG] fix recently introduced loop when client closes early
19302 - [MAJOR] get rid of the SV_STHEADERS state
19303 - [MAJOR] better separation of response processing and server state
19304 - [MAJOR] clearly separate HTTP response processing from TCP server state
19305 - [MEDIUM] remove unused references to {CL|SV}_STSHUT*
19306 - [MINOR] term_trace: add better instrumentations to trace the code
19307 - [BUG] ev_sepoll: closed file descriptors could persist in the spec list
19308 - [BUG] process_response must not enable the read FD
19309 - [BUG] buffers: remove BF_MAY_CONNECT and fix forwarding issue
19310 - [BUG] process_response: do not touch srv_state
19311 - [BUG] maintain_proxies must not disable backends
19312 - [CLEANUP] get rid of BF_SHUT*_PENDING
19313 - [MEDIUM] buffers: add BF_EMPTY and BF_FULL to remove dependency on req/rep->l
19314 - [MAJOR] process_session: rely only on buffer flags
19315 - [MEDIUM] use buffer->wex instead of buffer->cex for connect timeout
19316 - [MEDIUM] centralize buffer timeout checks at the top of process_session
19317 - [MINOR] ensure the termination flags are set by process_xxx
19318 - [MEDIUM] session: move the analysis bit field to the buffer
19319 - [OPTIM] process_cli/process_srv: reduce the number of tests
19320 - [BUG] regparm is broken on gcc < 3
19321 - [BUILD] fix warning in proto_tcp.c with gcc >= 4
19322 - [MEDIUM] merge inspect_exp and txn->exp into request buffer
19323 - [BUG] process_cli/process_srv: don't call shutdown when already done
19324 - [BUG] process_request: HTTP body analysis must return zero if missing data
19325 - [TESTS] test-fsm: 22 regression tests for state machines
19326 - [BUG] Fix empty X-Forwarded-For header name when set in defaults section
19327 - [BUG] fix harmless but wrong fd insertion sequence
19328 - [MEDIUM] make it possible for analysers to follow the whole session
19329 - [MAJOR] rework of the server FSM
19330 - [OPTIM] remove useless fd_set(read) upon shutdown(write)
19331 - [MEDIUM] massive cleanup of process_srv()
19332 - [MEDIUM] second level of code cleanup for process_srv_data
19333 - [MEDIUM] third cleanup and optimization of process_srv_data()
19334 - [MEDIUM] process_srv_data: ensure that we always correctly re-arm timeouts
19335 - [MEDIUM] stream_sock_process_data moved to stream_sock.c
19336 - [MAJOR] make the client side use stream_sock_process_data()
19337 - [MEDIUM] split stream_sock_process_data
19338 - [OPTIM] stream_sock_read must check for null-reads more often
19339 - [MINOR] only call flow analysers when their read side is connected.
19340 - [MEDIUM] reintroduce BF_HIJACK with produce_content
19341 - [MINOR] re-arrange buffer flags and rename some of them
19342 - [MINOR] do not check for BF_SHUTR when computing write timeout
19343 - [OPTIM] ev_sepoll: detect newly created FDs and check them once
19344 - [OPTIM] reduce the number of calls to task_wakeup()
19345 - [OPTIM] force inlining of large functions with gcc >= 3
19346 - [MEDIUM] indicate a reason for a task wakeup
19347 - [MINOR] change type of fdtab[]->owner to void*
19348 - [MAJOR] make stream sockets aware of the stream interface
19349 - [MEDIUM] stream interface: add the ->shutw method as well as in and out buffers
19350 - [MEDIUM] buffers: add BF_READ_ATTACHED and BF_ANA_TIMEOUT
19351 - [MEDIUM] process_session: make use of the new buffer flags
19352 - [CLEANUP] process_session: move debug outputs out of the critical loop
19353 - [MEDIUM] move QUEUE and TAR timers to stream interfaces
19354 - [OPTIM] add compiler hints in tick_is_expired()
19355 - [MINOR] add buffer_check_timeouts() to check what timeouts have fired.
19356 - [MEDIUM] use buffer_check_timeouts instead of stream_sock_check_timeouts()
19357 - [MINOR] add an expiration flag to the stream_sock_interface
19358 - [MAJOR] migrate the connection logic to stream interface
19359 - [MAJOR] add a connection error state to the stream_interface
19360 - [MEDIUM] add the SN_CURR_SESS flag to the session to track open sessions
19361 - [MEDIUM] continue layering cleanups.
19362 - [MEDIUM] stream_interface: added a DISconnected state between CON/EST and CLO
19363 - [MEDIUM] remove stream_sock_update_data()
19364 - [MINOR] maintain a global session list in order to ease debugging
19365 - [BUG] shutw must imply close during a connect
19366 - [MEDIUM] process shutw during connection attempt
19367 - [MEDIUM] make the stream interface control the SHUT{R,W} bits
19368 - [MAJOR] complete layer4/7 separation
19369 - [CLEANUP] move the session-related functions to session.c
19370 - [MINOR] call session->do_log() for logging
19371 - [MINOR] replace the ambiguous client_return function by stream_int_return
19372 - [MINOR] replace client_retnclose() with stream_int_retnclose()
19373 - [MINOR] replace srv_close_with_err() with http_server_error()
19374 - [MEDIUM] make the http server error function a pointer in the session
19375 - [CLEANUP] session.c: removed some migration left-overs in sess_establish()
19376 - [MINOR] stream_sock_data_finish() should not expose fd
19377 - [MEDIUM] extract TCP request processing from HTTP
19378 - [MEDIUM] extract the HTTP tarpit code from process_request().
19379 - [MEDIUM] move the HTTP request body analyser out of process_request().
19380 - [MEDIUM] rename process_request to http_process_request
19381 - [BUG] fix forgotten server session counter
19382 - [MINOR] declare process_session in session.h, not proto_http.h
19383 - [MEDIUM] first pass of lifting to proto_uxst.c:uxst_event_accept()
19384 - [MINOR] add an analyser code for UNIX stats request
19385 - [MINOR] pre-set analyser flags on the listener at registration time
19386 - [BUG] do not forward close from cons to prod with analysers
19387 - [MEDIUM] ensure that sock->shutw() also closes read for init states
19388 - [MINOR] add an analyser state in struct session
19389 - [MAJOR] make unix sockets work again with stats
19390 - [MEDIUM] remove cli_fd, srv_fd, cli_state and srv_state from the session
19391 - [MINOR] move the listener reference from fd to session
19392 - [MEDIUM] reference the current hijack function in the buffer itself
19393 - [MINOR] slightly rebalance stats_dump_{raw,http}
19394 - [MINOR] add a new back-reference type : struct bref
19395 - [MINOR] add back-references to sessions for later use by a dumper.
19396 - [MEDIUM] add support for "show sess" in unix stats socket
19397 - [BUG] do not release the connection slot during a retry
19398 - [BUG] dynamic connection throttling could return a max of zero conns
19399 - [BUG] do not try to pause backends during reload
19400 - [BUG] ensure that listeners from disabled proxies are correctly unbound.
19401 - [BUG] acl-related keywords are not allowed in defaults sections
19402 - [BUG] cookie capture is declared in the frontend but checked on the backend
19403 - [BUG] critical errors should be reported even in daemon mode
19404 - [MINOR] redirect: add support for the "drop-query" option
19405 - [MINOR] redirect: add support for "set-cookie" and "clear-cookie"
19406 - [MINOR] redirect: in prefix mode a "/" means not to change the URI
19407 - [BUG] do not dequeue requests on a dead server
19408 - [BUG] do not dequeue the backend's pending connections on a dead server
19409 - [MINOR] stats: indicate if a task is running in "show sess"
19410 - [BUG] check timeout must not be changed if timeout.check is not set
19411 - [BUG] "option transparent" is for backend, not frontend !
19412 - [MINOR] transfer errors were not reported anymore in data phase
19413 - [MEDIUM] add a send limit to a buffer
19414 - [MEDIUM] don't report buffer timeout when there is I/O activity
19415 - [MEDIUM] indicate when we don't care about read timeout
19416 - [MINOR] add flags to indicate when a stream interface is waiting for space/data
19417 - [MEDIUM] enable inter-stream_interface wakeup calls
19418 - [MAJOR] implement autonomous inter-socket forwarding
19419 - [MINOR] add the splice_len member to the buffer struct in preparation of splice support
19420 - [MEDIUM] stream_sock: factor out the return path in case of no-writes
19421 - [MEDIUM] i/o: rework ->to_forward and ->send_max
19422 - [OPTIM] stream_sock: do not ask for polling on EAGAIN if we have read
19423 - [OPTIM] buffer: replace rlim by max_len
19424 - [OPTIM] stream_sock: factor out the buffer full handling out of the loop
19425 - [CLEANUP] replace a few occurrences of (flags & X) && !(flags & Y)
19426 - [CLEANUP] stream_sock: move the write-nothing condition out of the loop
19427 - [MEDIUM] split stream_sock_write() into callback and core functions
19428 - [MEDIUM] stream_sock_read: call ->chk_snd whenever there are data pending
19429 - [MINOR] stream_sock: fix a few wrong empty calculations
19430 - [MEDIUM] stream_sock: try to send pending data on chk_snd()
19431 - [MINOR] global.maxpipes: add the ability to reserve file descriptors for pipes
19432 - [MEDIUM] splice: add configuration options and set global.maxpipes
19433 - [MINOR] introduce structures required to support Linux kernel splicing
19434 - [MEDIUM] add definitions for Linux kernel splicing
19435 - [MAJOR] complete support for linux 2.6 kernel splicing
19436 - [BUG] reserve some pipes for backends with splice enabled
19437 - [MEDIUM] splice: add hints to support older buggy kernels
19438 - [MEDIUM] introduce pipe pools
19439 - [MEDIUM] splice: make use of pipe pools
19440 - [STATS] report pipe usage in the statistics
19441 - [OPTIM] make global.maxpipes default to global.maxconn/4 when not specified
19442 - [BUILD] fix snapshot date extraction with negative timezones
19443 - [MEDIUM] move global tuning options to the global structure
19444 - [MEDIUM] splice: add the global "nosplice" option
19445 - [BUILD] add USE_LINUX_SPLICE to enable LINUX_SPLICE on linux 2.6
19446 - [BUG] we must not exit if protocol binding only returns a warning
19447 - [MINOR] add support for bind interface name
19448 - [BUG] inform the user when root is expected but not set
19449 - [MEDIUM] add support for source interface binding
19450 - [MEDIUM] add support for source interface binding at the server level
19451 - [MEDIUM] implement bind-process to limit service presence by process
19452 - [DOC] document maxpipes, nosplice, option splice-{auto,request,response}
19453 - [DOC] filled the logging section of the configuration manual
19454 - [DOC] document HTTP status codes
19455 - [DOC] document a few missing info about errorfile
19456 - [BUG] fix random memory corruption using "show sess"
19457 - [BUG] fix unix socket processing of interrupted output
19458 - [DOC] add diagrams of queuing and future ACL design
19459 - [BUILD] proto_http did not build on gcc-2.95
19460 - [BUG] the "source" keyword must first clear optional settings
19461 - [BUG] global.tune.maxaccept must be limited even in mono-process mode
19462 - [MINOR] ensure that http_msg_analyzer updates pointer to invalid char
19463 - [MEDIUM] store a complete dump of request and response errors in proxies
19464 - [MEDIUM] implement error dump on unix socket with "show errors"
19465 - [DOC] document "show errors"
19466 - [MINOR] errors dump must use user-visible date, not internal date.
19467 - [MINOR] time: add __usec_to_1024th to convert usecs to 1024th of second
19468 - [MINOR] add curr_sec_ms and curr_sec_ms_scaled for current second.
19469 - [MEDIUM] measure and report session rate on frontend, backends and servers
19470 - [BUG] the "connslots" keyword was matched as "connlots"
19471 - [MINOR] acl: add 2 new verbs: fe_sess_rate and be_sess_rate
19472 - [MEDIUM] implement "rate-limit sessions" for the frontend
19473 - [BUG] interface binding: length must include the trailing zero
19474 - [BUG] typo in timeout error reporting : report *res and not *err
19475 - [OPTIM] maintain_proxies: only wake up when the frontend will be ready
19476 - [OPTIM] rate-limit: cleaner behaviour on low rates and reduce consumption
19477 - [BUG] switch server-side stream interface to close in case of abort
19478 - [CLEANUP] remove last references to term_trace
19479 - [OPTIM] freq_ctr: do not rotate the counters when reading
19480 - [BUG] disable any analysers for monitoring requests
19481 - [BUG] rate-limit in defaults section was ignored
19482 - [BUG] task: fix handling of duplicate keys
19483 - [OPTIM] task: don't unlink a task from a wait queue when waking it up
19484 - [OPTIM] displace tasks in the wait queue only if absolutely needed
19485 - [MEDIUM] minor update to the task api: let the scheduler queue itself
19486 - [BUG] event_accept() must always wake the task up, even in health mode
19487 - [CLEANUP] task: distinguish between clock ticks and timers
19488 - [OPTIM] task: reduce the number of calls to task_queue()
19489 - [OPTIM] do not re-check req buffer when only response has changed
19490 - [CLEANUP] don't enable kernel splicing when socket is closed
19491 - [CLEANUP] buffer_flush() was misleading, rename it as buffer_erase
19492 - [MINOR] buffers: implement buffer_flush()
19493 - [MEDIUM] rearrange forwarding condition to enable splice during analysis
19494 - [BUILD] build fixes for Solaris
19495 - [BUILD] proto_http did not build on gcc-2.95 (again)
19496 - [CONTRIB] halog: fast log parser for haproxy
19497 - [CONTRIB] halog: faster fgets() and add support for percentile reporting
19498
Willy Tarreau7b4c5ae2008-04-19 21:06:14 +0200194992008/04/19 : 1.3.15
19500 - [BUILD] Added support for 'make install'
19501 - [BUILD] Added 'install-man' make target for installing the man page
19502 - [BUILD] Added 'install-bin' make target
19503 - [BUILD] Added 'install-doc' make target
19504 - [BUILD] Removed "/" after '$(DESTDIR)' in install targets
19505 - [BUILD] Changed 'install' target to install the binaries first
19506 - [BUILD] Replace hardcoded 'LD = gcc' with 'LD = $(CC)'
19507 - [MEDIUM]: Inversion for options
19508 - [MEDIUM]: Count retries and redispatches also for servers, fix redistribute_pending, extend logs, %d->%u cleanup
19509 - [BUG]: Restore clearing t->logs.bytes
19510 - [MEDIUM]: rework checks handling
19511 - [DOC] Update a "contrib" file with a hint about a scheme used for formathing subjects
19512 - [MEDIUM] Implement "track [<backend>/]<server>"
19513 - [MINOR] Implement persistent id for proxies and servers
19514 - [BUG] Don't increment server connections too much + fix retries
19515 - [MEDIUM]: Prevent redispatcher from selecting the same server, version #3
19516 - [MAJOR] proto_uxst rework -> SNMP support
19517 - [BUG] appsession lookup in URL does not work
19518 - [BUG] transparent proxy address was ignored in backend
19519 - [BUG] hot reconfiguration failed because of a wrong error check
19520 - [DOC] big update to the configuration manual
19521 - [DOC] large update to the configuration manual
19522 - [DOC] document more options
19523 - [BUILD] major rework of the GNU Makefile
19524 - [STATS] add support for "show info" on the unix socket
19525 - [DOC] document options forwardfor to logasap
19526 - [MINOR] add support for the "backlog" parameter
19527 - [OPTIM] introduce global parameter "tune.maxaccept"
19528 - [MEDIUM] introduce "timeout http-request" in frontends
19529 - [MINOR] tarpit timeout is also allowed in backends
19530 - [BUG] increment server connections for each connect()
19531 - [MEDIUM] add a turn-around state of one second after a connection failure
19532 - [BUG] fix typo in redispatched connection
19533 - [DOC] document options nolinger to ssl-hello-chk
19534 - [DOC] added documentation for "option tcplog" to "use_backend"
19535 - [BUG] connect_server: server might not exist when sending error report
19536 - [MEDIUM] support fully transparent proxy on Linux (USE_LINUX_TPROXY)
19537 - [MEDIUM] add non-local bind to connect() on Linux
19538 - [MINOR] add transparent proxy support for balabit's Tproxy v4
19539 - [BUG] use backend's source and not server's source with tproxy
19540 - [BUG] fix overlapping server flags
19541 - [MEDIUM] fix server health checks source address selection
19542 - [BUG] build failed on CONFIG_HAP_LINUX_TPROXY without CONFIG_HAP_CTTPROXY
19543 - [DOC] added "server", "source" and "stats" keywords
19544 - [DOC] all server parameters have been documented
19545 - [DOC] document all req* and rsp* keywords.
19546 - [DOC] added documentation about HTTP header manipulations
19547 - [BUG] log response byte count, not request
19548 - [BUILD] code did not build in full debug mode
19549 - [BUG] fix truncated responses with sepoll
19550 - [MINOR] use s->frt_addr as the server's address in transparent proxy
19551 - [MINOR] fix configuration hint about timeouts
19552 - [DOC] minor cleanup of the doc and notice to contributors
19553 - [MINOR] report correct section type for unknown keywords.
19554 - [BUILD] update MacOS Makefile to build on newer versions
19555 - [DOC] fix erroneous "useallbackups" option in the doc
19556 - [DOC] applied small fixes from early readers
19557 - [MINOR] add configuration support for "redir" server keyword
19558 - [MEDIUM] completely implement the server redirection method
19559 - [TESTS] add a test case for the server redirection mechanism
19560 - [DOC] add a configuration entry for "server ... redir <prefix>"
19561 - [BUILD] backend.c and checks.c did not build without tproxy !
19562 - Revert "[BUILD] backend.c and checks.c did not build without tproxy !"
19563 - [BUILD] backend.c and checks.c did not build without tproxy !
19564 - [OPTIM] used unsigned ints for HTTP state and message offsets
19565 - [OPTIM] GCC4's builtin_expect() is suboptimal
19566 - [BUG] failed conns were sometimes incremented in the frontend!
19567 - [BUG] timeout.check was not pre-set to eternity
19568 - [TESTS] add test-pollers.cfg to easily report pollers in use
19569 - [BUG] do not apply timeout.connect in checks if unset
19570 - [BUILD] ensure that makefile understands USE_DLMALLOC=1
19571 - [MINOR] silent gcc for a wrong warning
19572 - [CLEANUP] update .gitignore to ignore more temporary files
19573 - [CLEANUP] report dlmalloc's source path only if explictly specified
19574 - [BUG] str2sun could leak a small buffer in case of error during parsing
19575 - [BUG] option allbackups was not working anymore in roundrobin mode
19576 - [MAJOR] implementation of the "leastconn" load balancing algorithm
19577 - [BUILD] ensure that users don't build without setting the target anymore.
19578 - [DOC] document the leastconn LB algo
19579 - [MEDIUM] fix stats socket limitation to 16 kB
19580 - [DOC] fix unescaped space in httpchk example.
19581 - [BUG] fix double-decrement of server connections
19582 - [TESTS] add a test case for port mapping
19583 - [TESTS] add a benchmark for integer hashing
19584 - [TESTS] add new methods in ip-hash test file
19585 - [MAJOR] implement parameter hashing for POST requests
19586
Willy Tarreaue5b77e82007-12-06 01:25:44 +0100195872007/12/06 : 1.3.14
19588 - New option http_proxy (Alexandre Cassen)
19589 - add support for "maxqueue" to limit server queue overload (Elijah Epifanov)
19590 - Check for duplicated conflicting proxies (Krzysztof Oledzki)
19591 - stats: report server and backend cumulated downtime (Krzysztof Oledzki)
19592 - use backends only with use_backend directive (Krzysztof Oledzki)
19593 - Handle long lines properly (Krzysztof Oledzki)
19594 - Implement and use generic findproxy and relax duplicated proxy check (Krzysztof Oledzki)
19595 - continous statistics (Krzysztof Oledzki)
19596 - add support for logging via a UNIX socket (Robert Tsai)
19597 - fix error checking in strl2ic/strl2uic()
19598 - fix calls to localtime()
19599 - provide easier-to-use ultoa_* functions
19600 - provide easy-to-use limit_r and LIM2A* macros
19601 - add a simple test for the status page
19602 - move error codes to common/errors.h
19603 - silent warning about LIST_* being redefined on OpenBSD
19604 - add socket address length to the protocols
19605 - group PR_O_BALANCE_* bits into a checkable value
19606 - externalize the "balance" option parser to backend.c
19607 - introduce the "url_param" balance method
19608 - make default_backend work in TCP mode too
19609 - disable warning about localtime_r on Solaris
19610 - adjust error messages about conflicting proxies
19611 - avoid calling some layer7 functions if not needed
19612 - simplify error path in event_accept()
19613 - add an options field to the listeners
19614 - added a new state to listeners
19615 - unbind_listener() must use fd_delete() and not close()
19616 - add a generic unbind_listener() primitive
19617 - add a generic delete_listener() primitive
19618 - add a generic unbind_all_listeners() primitive
19619 - create proto_tcp and move initialization of proxy listeners
19620 - stats: report numerical process ID, proxy ID and server ID
19621 - relative_pid was not initialized
19622 - missing header names in raw stats output
19623 - fix missing parenthesis in check_response_for_cacheability
19624 - small optimization on session_process_counters()
19625 - merge ebtree version 3.0
19626 - make ebtree headers multiple-include compatible
19627 - ebtree: include config.h for REGPRM*
19628 - differentiate between generic LB params and map-specific ones
19629 - add a weight divisor to the struct proxy
19630 - implement the Fast Weighted Round Robin (FWRR) algo
19631 - include filltab25.c to experiment on FWRR for dynamic weights
19632 - merge test-fwrr.cfg to validate dynamic weights
19633 - move the load balancing algorithm to be->lbprm.algo
19634 - change server check result to a bit field
19635 - implement "http-check disable-on-404" for graceful shutdown
19636 - secure the calling conditions of ->set_server_status_{up,down}
19637 - report disabled servers as "NOLB" when they are still UP
19638 - document the "http-check disable-on-404" option
19639 - http-check disable-on-404 is not limited to HTTP mode
19640 - add a test file for disable-on-404
19641 - use distinct bits per load-balancing algorithm type
19642 - implement the slowstart parameter for servers
19643 - document the server's slowstart parameter
19644 - stats: report the server warm up status in a "throttle" column
19645 - fix 2 minor issues on AIX
19646 - add the "nbsrv" ACL verb
19647 - add the "fail" condition to monitor requests
19648 - remove a warning from gcc due to htons() in standard.c
19649 - fwrr: ensure that we never overflow in placements
19650 - store the build options to report with -vv
19651 - fix the status return of the init script (R.I. Pienaar)
19652 - stats: real time monitoring script for unix socket (Prizee)
19653 - document "nbsrv" and "monitor fail"
19654 - restrict the set of allowed characters for identifiers
19655 - implement a time parsing function
19656 - add support for time units in the configuration
19657 - add a bit of documentation about timers
19658 - introduce separation between contimeout, and tarpit + queue
19659 - introduce the "timeout" keyword
19660 - grouped all timeouts in one structure
19661 - slowstart is in ms, not seconds
19662 - slowstart: ensure we don't start with a null weight
19663 - report the number of times each server was selected
19664 - fix build on AIX due to recent log changes
19665 - fix build on Solaris due to recent log changes
19666
Willy Tarreaue855f422007-10-18 22:38:22 +0200196672007/10/18 : 1.3.13
19668 - replace the code under O'Reilly license (Arnaud Cornet)
19669 - add a small man page (Arnaud Cornet)
19670 - stats: report haproxy's version by default (Krzysztof Oledzki)
19671 - stats: count server retries and redispatches (Krzysztof Oledzki)
19672 - core: added easy support for Doug Lea's malloc (dlmalloc)
19673 - core: fade out memory usage when stopping proxies
19674 - core: moved the sockaddr pointer to the fdtab structure
19675 - core: add generic protocol support
19676 - core: implement client-side support for PF_UNIX sockets
19677 - stats: implement the CSV output
19678 - stats: add a link to the CSV export HTML page
19679 - stats: implement the statistics output on a unix socket
19680 - config: introduce the "stats" keyword in global section
19681 - build: centralize version and date into one file for each
19682 - tests: added a new hash algorithm
19683
196842007/10/18 : 1.3.12.3
19685 - add the "nolinger" option to disable data lingering (Alexandre Cassen)
19686 - fix double-free during clean exit (Krzysztof Oledzki)
19687 - prevent the system from sending an RST when closing health-checks
19688 (Krzysztof Oledzki)
19689 - do not add a cache-control header when on non-cacheable responses
19690 (Krzysztof Oledzki)
19691 - spread health checks even more (Krzysztof Oledzki)
19692 - stats: scope "." must match the backend and not the frontend
19693 - fixed call to chroot() during startup
19694 - fix wrong timeout computation in event_accept()
19695 - remove condition for exit() under fork() failure
19696
196972007/09/20 : 1.3.12.2
19698 - fix configuration sanity checks for TCP listeners
19699 - set the log socket receive window to zero bytes
19700 - pre-initialize timeouts to infinity, not zero
19701 - fix the SIGHUP message not to alert on server-less proxies
19702 - timeouts and retries could be ignored when switching backend
19703 - added a file to check that "retries" works.
19704 - O'Reilly has clarified its license
19705
197062007/09/05 : 1.3.12.1
19707 - spec I/O: fix allocations of spec entries for an FD
19708 - ensure we never overflow in chunk_printf()
19709 - improve behaviour with large number of servers per proxy
19710 - add support for "stats refresh <interval>"
19711 - stats page: added links for 'refresh' and 'hide down'
19712 - fix backend's weight in the stats page.
19713 - the "stats" keyword is not allowed in a pure frontend.
19714 - provide a test configuration file for stats and checks
19715
Willy Tarreaub21152b2007-06-17 23:41:40 +0200197162007/06/17 : 1.3.12
19717 - fix segfault at exit when using captures
19718 - bug: negation in ACL conds was not cleared between terms
19719 - errorfile: use a local file to feed error messages
19720 - acl: support '-i' to ignore case when matching
19721 - acl: smarter integer comparison with operators eq,lt,gt,le,ge
19722 - acl: support maching on 'path' component
19723 - acl: implement matching on header values
19724 - acl: distinguish between request and response headers
19725 - acl: permit to return any header when no name specified
19726 - acl: provide default ACLs
19727 - added the 'use_backend' keyword for full content-switching
19728 - acl: specify the direction during fetches
19729 - acl: provide the argument length for fetch functions
19730 - acl: provide a reference to the expr to fetch()
19731 - improve memory freeing upon exit
19732 - str2net() must not change the const char *
19733 - shut warnings 'is*' macros from ctype.h on solaris
19734
Willy Tarreaua3503e02007-06-03 17:27:07 +0200197352007/06/03 : 1.3.11.4
19736 - do not re-arm read timeout in SHUTR state !
19737 - optimize I/O by detecting system starvation
19738 - the epoll FD must not be shared between processes
19739 - limit the number of events returned by *poll*
19740
Willy Tarreau3c6fc072007-05-14 14:40:25 +0200197412007/05/14 : 1.3.11.3
19742 - pre-initialize timeouts with tv_eternity during parsing
19743
Willy Tarreaufc273c22007-05-14 03:42:47 +0200197442007/05/14 : 1.3.11.2
19745 - fixed broken health-checks since switch to timeval
19746
Willy Tarreau3c5340c2007-05-14 03:18:43 +0200197472007/05/14 : 1.3.11.1
19748 - fixed ev_kqueue which was forgotten during the switch to timeval
19749 - allowed null timeouts for past events in select
19750
Willy Tarreau544eb402007-05-14 02:42:33 +0200197512007/05/14 : 1.3.11
19752 - fixed ev_sepoll again by rewriting the state machine
19753 - switched all timeouts to timevals instead of milliseconds
19754 - improved memory management using mempools v2.
19755 - several minor optimizations
19756
Willy Tarreau9ca931f2007-05-10 07:51:17 +0200197572007/05/09 : 1.3.10.2
19758 - fixed build on OpenBSD (missing types.h)
19759
Willy Tarreau13398d32007-05-09 22:58:28 +0200197602007/05/09 : 1.3.10.1
19761 - fixed sepoll transition matrix (two states were missing)
19762
Willy Tarreau61beedf2007-05-09 01:44:58 +0200197632007/05/08 : 1.3.10
19764 - several fixes in ev_sepoll
19765 - fixed some expiration dates on some tasks
19766 - fixed a bug in connection establishment detection due to speculative I/O
19767 - fixed rare bug occuring on TCP with early close (reported by Andy Smith)
19768 - implemented URI hashing algorithm (Guillaume Dallaire)
19769 - implemented SMTP health checks (Peter van Dijk)
19770 - replaced the rbtree with ul2tree from old scheduler project
19771 - new framework for generic ACL support
19772 - added the 'acl' and 'block' keywords to the config language
19773 - added several ACL criteria and matches (IP, port, URI, ...)
19774 - cleaned up and better modularization for some time functions
19775 - fixed list macros
19776 - fixed useless memory allocation in str2net()
19777 - store the original destination address in the session
19778
Willy Tarreau6e0433f2007-04-16 01:18:12 +0200197792007/04/15 : 1.3.9
19780 - modularized the polling mechanisms and use function pointers instead
19781 of macros at many places
19782 - implemented support for FreeBSD's kqueue() polling mechanism
19783 - fixed a warning on OpenBSD : MIN/MAX redefined
19784 - change socket registration order at startup to accomodate kqueue.
19785 - several makefile cleanups to support old shells
19786 - fix build with limits.h once for all
19787 - ev_epoll: do not rely on fd_sets anymore, use changes stacks instead.
19788 - fdtab now holds the results of polling
19789 - implemented support for speculative I/O processing with epoll()
19790 - remove useless calls to shutdown(SHUT_RD), resulting in small speed boost
19791 - auto-registering of pollers at load time
19792
Willy Tarreau42c76592007-04-03 20:30:13 +0200197932007/04/03 : 1.3.8.2
19794 - rewriting either the status line or request line could crash the
19795 process due to a pointer which ought to be reset before parsing.
19796 - rewriting the status line in the response did not work, it caused
19797 a 502 Bad Gateway due to an erroneous state during parsing
19798
Willy Tarreauef6d7612007-04-01 11:06:22 +0200197992007/04/01 : 1.3.8.1
19800 - fix reqadd when no option httpclose is used.
19801 - removed now unused fiprm and beprm from proxies
19802 - split logs into two versions : TCP and HTTP
19803 - added some docs about http headers storage and acls
19804 - added a VIM script for syntax color highlighting (Bruno Michel)
19805
Willy Tarreaud661cc02007-03-26 00:24:56 +0200198062007/03/25 : 1.3.8
19807 - fixed several bugs which might have caused a crash with bad configs
19808 - several optimizations in header processing
19809 - many progresses towards transaction-based processing
19810 - option forwardfor may be used in frontends
19811 - completed HTTP response processing
19812 - some code refactoring between request and response processing
19813 - new HTTP header manipulation functions
19814 - optimizations on the recv() patch to reduce CPU usage under very
19815 high data rates.
19816 - more user-friendly help about the 'usesrc' keyword (CTTPROXY)
19817 - username/groupname support from Marcus Rueckert
19818 - added the "except" keyword to the "forwardfor" option (Bryan German)
19819 - support for health-checks on other addresses (Fabrice Dulaunoy)
19820 - makefile for MacOS 10.4 / Darwin (Dan Zinngrabe)
19821 - do not insert "Connection: close" in HTTP/1.0 messages
19822
Willy Tarreau9cabf702007-01-26 23:49:01 +0100198232007/01/26 : 1.3.7
19824 - fix critical bug introduced with 1.3.6 : an empty request header
19825 may lead to a crash due to missing pointer assignment
19826 - hdr_idx might be left uninitialized in debug mode
19827 - fixed build on FreeBSD due to missing fd_set declaration
19828
Willy Tarreaue7a24382007-01-22 08:57:44 +0100198292007/01/22 : 1.3.6.1
19830 - change in the header chaining broke cookies and authentication
19831
Willy Tarreau49e1ee82007-01-22 00:56:46 +0100198322007/01/22 : 1.3.6
19833 - stats now support the HEAD method too
19834 - extracted http request from the session
19835 - huge rework of the HTTP parser which is now a 28-state FSM.
19836 - linux-style likely/unlikely macros for optimization hints
19837 - do not create a server socket when there's no server
19838 - imported lots of docs
19839
Willy Tarreau5871f8e2007-01-07 02:47:01 +0100198402007/01/07 : 1.3.5
19841 - stats: swap color sets for active and backup servers
19842 - try to guess server check port when unset
19843 - added complete support and doc for TCP Splicing
19844 - replace the wait-queue linked list with an rbtree.
19845 - a few bugfixes and cleanups
19846
Willy Tarreau85270da2007-01-02 00:59:39 +0100198472007/01/02 : 1.3.4
19848 - support for cttproxy on the server side to present the client
19849 address to the server.
19850 - added support for SO_REUSEPORT on Linux (needs kernel patch)
19851 - new RFC2616-compliant HTTP request parser with header indexing
19852 - split proxies in frontends, rulesets and backends
19853 - implemented the 'req[i]setbe' to select a backend depending
19854 on the contents
19855 - added the 'default_backend' keyword to select a default BE.
19856 - new stats page featuring FEs and BEs + bytes in both dirs
19857 - improved log format to indicate the backend and the time in ms.
19858 - lots of cleanups
19859
Willy Tarreau9c9fea42006-10-16 00:03:35 +0200198602006/10/15 : 1.3.3
19861 - fix broken redispatch option in case the connection has already
19862 been marked "in progress" (ie: nearly always).
19863 - support regparm on x86 to speed up some often called functions
19864 - removed a few useless calls to gettimeofday() in log functions.
19865 - lots of 'const char*' cleanups
19866 - turn every FD_* into functions which are faster on recent CPUs
19867
Willy Tarreau690f9aa2006-09-03 11:23:06 +0200198682006/09/03 : 1.3.2
19869 - started the changes towards I/O completion callbacks. stream_sock* have
19870 replaced event_*.
19871 - added the new "reqtarpit" and "reqitarpit" protection features
19872
Willy Tarreau8f2b8552006-07-09 17:11:39 +0200198732006/07/09 : 1.3.1 (1.2.15)
19874 - now, haproxy warns about missing timeout during startup to try to
19875 eliminate all those buggy configurations.
19876 - added "Content-Type: text/html" in responses wherever appropriate, as
19877 suggested by Cameron Simpson.
19878 - implemented "option ssl-hello-chk" to use SSLv3 CLIENT HELLO messages to
19879 test server's health
19880 - implemented "monitor-uri" so that haproxy can reply to a specific URI with
19881 an "HTTP/1.0 200 OK" response. This is useful to validate multiple proxies
19882 at once.
19883
Willy Tarreaub9e98b62006-07-03 10:32:46 +0200198842006/06/29 : 1.3.0
19885 - exploded the whole file into multiple .c and .h. No functionnal
Willy Tarreau8f2b8552006-07-09 17:11:39 +020019886 difference is expected at all.
19887 - fixed a bug by which neither stats nor error messages could be returned if
19888 'clitimeout' was missing.
Willy Tarreaub9e98b62006-07-03 10:32:46 +020019889
willy tarreau7e6328d2006-05-21 23:26:20 +0200198902006/05/21 : 1.2.14
19891 - new HTML status report with the 'stats' keyword.
19892 - added the 'abortonclose' option to better resist traffic surges
19893 - implemented dynamic traffic regulation with the 'minconn' option
19894 - show request time on denied requests
19895 - definitely fixed hot reconf on OpenBSD by the use of SO_REUSEPORT
19896 - now a proxy instance is allowed to run without servers, which is
19897 useful to dedicate one instance to stats
19898 - added lots of error counters
19899 - a missing parenthesis preventd matching of cacheable cookies
19900 - a missing parenthesis in poll_loop() might have caused missed events.
19901
Willy TARREAU4404b7e2006-05-14 10:00:09 +0200199022006/05/14 : 1.2.13.1
19903 - an uninitialized field in the struct session could cause a crash when
19904 the session was freed. This has been encountered on Solaris only.
19905 - Solaris and OpenBSD no not support shutdown() on listening socket. Let's
19906 be nice to them by performing a soft stop if pause fails.
19907
willy tarreauc3a2e072006-05-13 18:51:38 +0200199082006/05/13 : 1.2.13
19909 - 'maxconn' server parameter to do per-server session limitation
19910 - queueing to support non-blocking session limitation
19911 - fixed removal of cookies for cookie-less servers such as backup servers
19912 - two separate wait queues for expirable and non-expirable tasks provide
19913 better performance with lots of sessions.
19914 - some code cleanups and performance improvements
19915 - made state dumps a bit more verbose
19916 - fixed missing checks for NULL srv in dispatch mode
19917 - load balancing on backup servers was not possible in source hash mode.
19918 - two session flags shared the same bit, but fortunately they were not
19919 compatible.
19920
willy tarreauc0d4bbd2006-04-15 21:47:50 +0200199212006/04/15 : 1.2.12
19922 Very few changes preparing for more important changes to support per-server
19923 session limitations and queueing :
19924 - ignore leading empty lines in HTTP requests as suggested by RFC2616.
19925 - added the 'weight' parameter to the servers, limited to 1..256. It applies
19926 to roundrobin and source hash.
19927 - the optional '-s' option could clobber '-st' and '-sf' if compiled in.
19928
willy tarreaue0dd2692006-03-30 16:27:34 +0200199292006/03/30 : 1.2.11.1
19930 - under some conditions, it might have been possible that when the
19931 last dead server became available, it would not have been used
19932 till another one would have changed state. Could not be reproduced
19933 at all, however seems possible from the code.
19934
willy tarreaud2058dc2006-03-25 20:35:41 +0100199352006/03/25 : 1.2.11
19936 - added the '-db' command-line option to disable backgrounding.
19937 - added the -sf/-st command-line arguments which are used to specify
19938 a list of pids to send a FINISH or TERMINATE signal upon startup.
19939 They will also be asked to release their port if a bind fails.
19940 - reworked the startup mechanism to allow the sending of a signal to a list
19941 of old pids if a socket cannot be bound, with a retry for a limited amount
19942 of time (1 second by default).
19943 - added the ability to enforce limits on memory usage.
19944 - added the 'source' load-balancing algorithm which uses the source IP(v4|v6)
19945 - re-architectured the server round-robin mechanism to ease integration of
19946 other algorithms. It now relies on the number of active and backup servers.
19947 - added a counter for the number of active and backup servers, and report
19948 these numbers upon SIGHUP or state change.
19949
willy tarreaubfad5742006-03-23 14:19:11 +0100199502006/03/23 : 1.2.10.1
19951 - while fixing the backup server round-robin "feature", a new bug was
19952 introduced which could miss some backup servers.
19953 - the displayed proxy name was wrong when dumping upon SIGHUP.
19954
willy tarreauaaff30e2006-03-19 21:30:41 +0100199552006/03/19 : 1.2.10
19956 - assert.h is needed when DEBUG is defined.
19957 - ENORMOUS long standing bug affecting the epoll polling system :
19958 event_data is a union, not a structure !
19959 - Make fd management more robust and easier to debug. Also some
19960 micro-optimisations.
19961 - Limit the number of consecutive accept() in multi-process mode.
19962 This produces a more evenly distributed load across the processes and
19963 slightly improves performance by reducing bottlenecks.
19964 - Make health-checks be more regular, and faster to retry after a timeout.
19965 - Fixed some messages to ease parsing of alerts.
19966 - provided a patch to enable epoll on RHEL3 kernels.
19967 - Separated OpenBSD build from the main Makefile into a new one.
19968
willy tarreau50be0172006-03-15 19:41:19 +0100199692006/03/15 : 1.2.9
19970 - haproxy could not be stopped after being paused, it had to be woken up
19971 first. This has been fixed.
19972 - the 'ulimit-n' parameter is now optional and by default computed from
19973 maxconn + the number of listeners + the number of health-checks.
19974 - it is now possible to specify a maximum number of connections at build
19975 time with the SYSTEM_MAXCONN define. The value set in the configuration
19976 file will then be limited to this value, and only the command-line '-n'
19977 option will be able to bypass it. It will prevent against accidental
19978 high memory usage on small systems.
19979 - RFC2616 expects that any HTTP agent accepts multi-line headers. Earlier
19980 versions did not detect a line beginning with a space as the continuation
19981 of previous header. It is now correct.
19982 - health checks sent to servers configured with identical intervals were
19983 sent in perfect synchronisation because the initial time was the same
19984 for all. This could induce high load peaks when fragile servers were
19985 hosting tens of instances for the same application. Now the load is
19986 spread evenly across the smallest interval amongst a listener.
19987 - a new 'forceclose' option was added to make the proxy close the outgoing
19988 channel to the server once it has sent all its headers and the server
19989 starts responding. This helps some servers which don't close upon the
19990 'Connection: close' header. It implies 'option httpclose'.
19991 - there was a bug in the way the backup servers were handled. They were
19992 erroneously load-balanced while the doc said the opposite. Since
19993 load-balanced backup servers is one of the features some people have
19994 been asking for, the problem was fixed to reflect the documented
19995 behaviour and a new option 'allbackups' was introduced to provide the
19996 feature to those who need it.
19997 - a never ending connect() could lead to a fast select() loop if its
19998 timeout times the number of retransmits exceeded the server read or write
19999 timeout, because the later was used to compute select()'s timeout while
20000 the connection timeout was not reached.
20001 - now we initialize the libc's localtime structures very early so that even
20002 under OOM conditions, we can still send dated error messages without
20003 segfaulting.
20004 - the 'daemon' mode implies 'quiet' and disables 'verbose' because file
20005 descriptors are closed.
20006
willy tarreau065f1c02006-01-29 22:10:07 +0100200072006/01/29 : 1.2.8
20008 - fixed a nasty bug affecting poll/epoll which could return unmodified data
20009 from the server to the client, and sometimes lead to memory corruption
20010 crashing the process.
20011 - added the new pause/play mechanism with SIGTTOU/SIGTTIN for hot-reconf.
20012
200132005/12/18 : 1.2.7.1
20014 - the "retries" option was ignored because connect() could not return an
20015 error if the connection failed before the timeout.
20016 - TCP health-checks could not detect a connection refused in poll/epoll
20017 mode.
20018
willy tarreaua56eca72005-12-18 01:34:42 +0100200192005/11/13 : 1.2.7
willy tarreau77bc8542005-12-18 01:31:43 +010020020 - building with -DUSE_PCRE should include PCRE headers and not regex.h. At
20021 least on Solaris, this caused the libc's regex primitives to be used instead
20022 of PCRE, which caused trouble on group references. This is now fixed.
willy tarreaud0fb4652005-12-18 01:32:04 +010020023 - delayed the quiet mode during startup so that most of the startup alerts can
20024 be displayed even in quiet mode.
20025 - display an alert when a listener has no address, invalid or no port, or when
20026 there are no enabled listeners upon startup.
willy tarreau4373b962005-12-18 01:32:31 +010020027 - added "static-pcre" to the list of supported regex options in the Makefile.
willy tarreau77bc8542005-12-18 01:31:43 +010020028
willy tarreaub952e1d2005-12-18 01:31:20 +0100200292005/10/09 : 1.2.7rc (1.1.33rc)
20030 - second batch of socklen_t changes.
20031 - clean-ups from Cameron Simpson.
20032 - because tv_remain() does not know about eternity, using no timeout can
20033 make select() spin around a null time-out. Bug reported by Cameron Simpson.
20034 - client read timeout was not properly set to eternity initialized after an
20035 accept() if it was not set in the config. It remained undetected so long
20036 because eternity is 0 and newly allocated pages are zeroed by the system.
20037 - do not call get_original_dst() when not in transparent mode.
20038 - implemented a workaround for a bug in certain epoll() implementations on
20039 linux-2.4 kernels (epoll-lt <= 0.21).
20040 - implemented TCP keepalive with new options : tcpka, clitcpka, srvtcpka.
20041
willy tarreauc5f73ed2005-12-18 01:26:38 +0100200422005/08/07 : 1.2.6
20043 - clean-up patch from Alexander Lazic fixes build on Debian 3.1 (socklen_t).
20044
200452005/07/06 : 1.2.6-pre5 (1.1.32)
willy tarreau0fe39652005-12-18 01:25:24 +010020046 - added the number of active sessions (proxy/process) in the logs
20047
200482005/07/06 : 1.2.6-pre4 (1.1.32-pre4)
willy tarreaub1285d52005-12-18 01:20:14 +010020049 - the time-out fix introduced in 1.1.25 caused a corner case where it was
20050 possible for a client to keep a connection maintained regardless of the
20051 timeout if the server closed the connection during the HEADER phase,
20052 while the client ignored the close request while doing nothing in the
20053 other direction. This has been fixed now by ensuring that read timeouts
20054 are re-armed when switching to any SHUTW state.
20055
200562005/07/05 : 1.2.6-pre3 (1.1.32-pre3)
20057 - enhanced error reporting in the logs. Now the proxy will precisely detect
20058 various error conditions related to the system and/or process limits, and
20059 generate LOG_EMERG logs indicating that a resource has been exhausted.
20060 - logs will contain two new characters for the error cause : 'R' indicates
20061 a resource exhausted, and 'I' indicates an internal error, though this
20062 one should never happen.
20063 - server connection timeouts can now be reported in the logs (sC), as well
20064 as connections refused because of maxconn limitations (PC).
20065
200662005/07/05 : 1.2.6-pre2 (1.1.32-pre2)
20067 - new global configuration keyword "ulimit-n" may be used to raise the FD
20068 limit to usable values.
20069 - a warning is now displayed on startup if the FD limit is lower than the
20070 configured maximum number of sockets.
20071
200722005/07/05 : 1.2.6-pre1 (1.1.32-pre1)
20073 - new configuration keyword "monitor-net" makes it possible to be monitored
20074 by external devices which connect to the proxy without being logged nor
20075 forwarded to any server. Particularly useful on generic TCPv4 relays.
20076
willy tarreau5dffb602005-12-18 01:15:23 +0100200772005/06/21 : 1.2.5.2
20078 - fixed build on PPC where chars are unsigned by default
20079
willy tarreau08dedbe2005-12-18 01:13:48 +0100200802005/05/02 : 1.2.5.1
20081 - dirty hack to fix a bug introduced with epoll : if we close an FD and
20082 immediately reassign it to another session through a connect(), the
20083 Prev{Read,Write}Events are not updated, which causes trouble detecting
20084 changes, thus leading to many timeouts at high loads.
20085
willy tarreau64a3cc32005-12-18 01:13:11 +0100200862005/04/30 : 1.2.5 (1.1.31)
20087 - changed the runtime argument to disable epoll() to '-de'
20088 - changed the runtime argument to disable poll() to '-dp'
20089 - added global options 'nopoll' and 'noepoll' to do the same at the
20090 configuration level.
20091 - added a 'linux24e' target to the Makefile for Linux 2.4 systems patched to
20092 support epoll().
20093 - changed default FD_SETSIZE to 65536 on Solaris (default=1024)
20094 - conditionned signals redirection to #ifdef DEBUG_MEMORY
20095
willy tarreau1c2ad212005-12-18 01:11:29 +0100200962005/04/26 : 1.2.5-pre4
20097 - made epoll() support a compile-time option : ENABLE_EPOLL
20098 - provided a very little libc replacement for a possibly missing epoll()
20099 implementation which can be enabled by -DUSE_MY_EPOLL
20100 - implemented the poll() poller, which can be enabled with -DENABLE_POLL.
20101 The equivalent runtime argument becomes '-P'. A few tests show that it
20102 performs like select() with many fds, but slightly slower (certainly
20103 because of the higher amount of memory involved).
20104 - separated the 3 polling methods and the tasks scheduler into 4 distinct
20105 functions which makes the code a lot more modular.
20106 - moved some event tables to private static declarations inside the poller
20107 functions.
20108 - the poller functions can now initialize themselves, run, and cleanup.
20109 - changed the runtime argument to enable epoll() to '-E'.
20110 - removed buggy epoll_ctl() code in the client_retnclose() function. This
20111 function was never meant to remove anything.
20112 - fixed a typo which caused glibc to yell about a double free on exit.
20113 - removed error checking after epoll_ctl(DEL) because we can never know if
20114 the fd is still active or already closed.
20115 - added a few entries in the makefile
20116
willy tarreauad90a0c2005-12-18 01:09:15 +0100201172005/04/25 : 1.2.5-pre3
20118 - experimental epoll() support (use temporary '-e' argument)
20119
201202005/04/24 : 1.2.5-pre2
willy tarreauc1f47532005-12-18 01:08:26 +010020121 - implemented the HTTP 303 code for error redirection. This forces the
20122 browser to fetch the given URI with a GET request. The new keyword for
20123 this is 'errorloc303', and a new 'errorloc302' keyword has been created
20124 to make them easily distinguishable.
20125 - added more controls in the parser for valid use of '\x' sequence.
20126 - few fixes from Alex & Klaus
20127
willy tarreauad90a0c2005-12-18 01:09:15 +0100201282005/02/17 : 1.2.5-pre1
willy tarreauc1f47532005-12-18 01:08:26 +010020129 - fixed a few errors in the documentation
20130
201312005/02/13
20132 - do not pre-initialize unused file-descriptors before select() anymore.
20133
willy tarreau12350152005-12-18 01:03:27 +0100201342005/01/22 : 1.2.4
20135 - merged Alexander Lazic's and Klaus Wagner's work on application
20136 cookie-based persistence. Since this is the first merge, this version is
20137 not intended for general use and reports are more than welcome. Some
20138 documentation is really needed though.
20139
willy tarreau0174f312005-12-18 01:02:42 +0100201402005/01/22 : 1.2.3 (1.1.30)
20141 - add an architecture guide to the documentation
20142 - released without any changes
20143
201442004/12/26 : 1.2.3-pre1 (1.1.30-pre1)
20145 - increased default BUFSIZE to 16 kB to accept max headers of 8 kB which is
20146 compatible with Apache. This limit can be configured in the makefile now.
20147 Thanks to Eric Fehr for the checks.
20148 - added a per-server "source" option which now makes it possible to bind to
20149 a different source for each (potentially identical) server.
20150 - changed cookie-based server selection slightly to allow several servers to
20151 share a same cookie, thus making it possible to associate backup servers to
20152 live servers and ease soft-stop for maintenance periods. (Alexander Lazic)
20153 - added the cookie 'prefix' mode which makes it possible to use persistence
20154 with thin clients which support only one cookie. The server name is prefixed
20155 before the application cookie, and restore back.
20156 - fixed the order of servers within an instance to match documentation. Now
20157 the servers are *really* used in the order of their declaration. This is
20158 particularly important when multiple backup servers are in use.
20159
willy tarreau4302f492005-12-18 01:00:37 +0100201602004/10/18 : 1.2.2 (1.1.29)
20161 - fixed a bug where a TCP connection would be logged twice if the 'logasap'
20162 option was enabled without the 'tcplog' option.
20163 - encode_string() would use hdr_encode_map instead of the map argument.
20164
201652004/08/10 : (1.1.29-pre2)
20166 - the logged request is now encoded with '#XX' for unprintable characters
20167 - new keywords 'capture request header' and 'capture response header' enable
20168 logging of arbitrary HTTP headers in requests and responses
20169 - removed "-DSOLARIS" after replacing the last inet_aton() with inet_pton()
20170
willy tarreau982249e2005-12-18 00:57:06 +0100201712004/06/06 : 1.2.1 (1.1.28)
20172 - added the '-V' command line option to verbosely report errors even though
20173 the -q or 'quiet' options are specified. This is useful with '-c'.
20174 - added a Red Hat init script and a .spec from Simon Matter <simon.matter@invoca.ch>
willy tarreau036e1ce2005-12-17 13:46:33 +010020175
willy tarreau982249e2005-12-18 00:57:06 +0100201762004/06/05 :
20177 - added the "logasap" option which produces a log without waiting for the data
20178 to be transferred from the server to the client.
20179 - added the "httpclose" option which removes any "connection:" header and adds
20180 "Connection: close" in both direction.
willy tarreau97f58572005-12-18 00:53:44 +010020181 - added the 'checkcache' option which blocks cacheable responses containing
20182 dangerous headers, such as 'set-cookie'.
willy tarreau982249e2005-12-18 00:57:06 +010020183 - added 'rspdeny' and 'rspideny' to block certain responses to avoid sensible
20184 information leak from servers.
willy tarreau25c4ea52005-12-18 00:49:49 +010020185
201862004/04/18 :
willy tarreaudd07e972005-12-18 00:48:48 +010020187 - send an EMERG log when no server is available for a given proxy
20188 - added the '-c' command line option to syntactically check the
20189 configuration file without starting the service.
20190
willy tarreau8a86dbf2005-12-18 00:45:59 +0100201912003/11/09 : 1.2.0
20192 - the same as 1.1.27 + IPv6 support on the client side
20193
willy tarreaufe2c5c12005-12-17 14:14:34 +0100201942003/10/27 : 1.1.27
20195 - the configurable HTTP health check introduced in 1.1.23 revealed a shameful
20196 bug : the code still assumed that HTTP requests were the same size as the
20197 original ones (22 bytes), and failed if they were not.
20198 - added support for pidfiles.
20199
willy tarreauc58fc692005-12-17 14:13:08 +0100202002003/10/22 : 1.1.26
20201 - the fix introduced in 1.1.25 for client timeouts while waiting for servers
20202 broke almost all compatibility with POST requests, because the proxy
20203 stopped to read anything from the client as soon as it got all of its
20204 headers.
20205
willy tarreauc1cae632005-12-17 14:12:23 +0100202062003/10/15 : 1.1.25
20207 - added the 'tcplog' option, which provides enhanced, HTTP-like logs for
20208 generic TCP proxies, or lighter logs for HTTP proxies.
20209 - fixed a time-out condition wrongly reported as client time-out in data
20210 phase if the client timeout was lower than the connect timeout times the
20211 number of retries.
20212
willy tarreau197e8ec2005-12-17 14:10:59 +0100202132003/09/21 : 1.1.24
20214 - if a client sent a full request then shut its write connection down, then
20215 the request was aborted. This case was detected only when using haproxy
20216 both as health-check client and as a server.
20217 - if 'option httpchk' is used in a 'health' mode server, then responses will
20218 change from 'OK' to 'HTTP/1.0 200 OK'.
20219 - fixed a Linux-only bug in case of HTTP server health-checks, where a single
20220 server response followed by a close could be ignored, and the server seen
20221 as failed.
20222
willy tarreaueedaa9f2005-12-17 14:08:03 +0100202232003/09/19 : 1.1.23
20224 - fixed a stupid bug introduced in 1.1.22 which caused second and subsequent
20225 'default' sections to keep previous parameters, and not initialize logs
20226 correctly.
20227 - fixed a second stupid bug introduced in 1.1.22 which caused configurations
20228 relying on 'dispatch' mode to segfault at the first connection.
20229 - 'option httpchk' now supports method, HTTP version and a few headers.
20230 - now, 'option httpchk', 'cookie' and 'capture' can be specified in
20231 'defaults' section
20232
202332003/09/10 : 1.1.22
willy tarreaua41a8b42005-12-17 14:02:24 +010020234 - 'listen' now supports optionnal address:port-range lists
20235 - 'bind' introduced to add new listen addresses
20236 - fixed a bug which caused a session to be kept established on a server till
20237 it timed out if the client closed during the DATA phase.
20238 - the port part of each server address can now be empty to make the proxy
20239 connect to the server on the same port it was connected to, be an absolute
20240 unsigned number to reflect a single port (as in older versions), or an
20241 explicitly signed number (+N/-N) to indicate that this offset must be
20242 applied to the port the proxy was connected to, when connecting to the
20243 server.
20244 - the 'port' server option allows the user to specify a different
20245 health-check port than the service one. It is mandatory when only relative
20246 ports have been specified and check is required. By default, the checks are
20247 sent to the service port.
20248 - new 'defaults' section which is rather similar to 'listen' except that all
20249 values are only used as default values for future 'listen' sections, until
20250 a new 'defaults' resets them. At the moment, server options, regexes,
20251 cookie names and captures cannot be set in the 'defaults' section.
20252
willy tarreau2f6ba652005-12-17 13:57:42 +0100202532003/05/06 : 1.1.21
20254 - changed the debug output format so that it now includes the session unique
20255 ID followed by the instance name at the beginning of each line.
20256 - in debug mode, accept now shows the client's IP and port.
20257 - added one 3 small debugging scripts to search and pretty print debug output
20258 - changed the default health check request to "OPTIONS /" instead of
20259 "OPTIONS *" since not all servers implement the later one.
20260 - "option httpchk" now accepts an optional parameter allowing the user to
20261 specify and URI other than '/' during health-checks.
20262
willy tarreaub1ff9db2005-12-17 13:51:03 +0100202632003/04/21 : 1.1.20
20264 - fixed two problems with time-outs, one where a server would be logged as
20265 timed out during transfer that take longer to complete than the fixed
20266 time-out, and one where clients were logged as timed-out during the data
20267 phase because they didn't have anything to send. This sometimes caused
20268 slow client connections to close too early while in fact there was no
20269 problem. The proper fix would be to have a per-fd time-out with
20270 conditions depending on the state of the HTTP FSM.
20271
willy tarreau906b2682005-12-17 13:49:52 +0100202722003/04/16 : 1.1.19
20273 - haproxy was NOT RFC compliant because it was case-sensitive on HTTP
20274 "Cookie:" and "Set-Cookie:" headers. This caused JVM 1.4 to fail on
20275 cookie persistence because it uses "cookie:". Two memcmp() have been
20276 replaced with strncasecmp().
20277
willy tarreau036e1ce2005-12-17 13:46:33 +0100202782003/04/02 : 1.1.18
20279 - Haproxy can be compiled with PCRE regex instead of libc regex, by setting
20280 REGEX=pcre on the make command line.
20281 - HTTP health-checks now use "OPTIONS *" instead of "OPTIONS /".
20282 - when explicit source address binding is required, it is now also used for
20283 health-checks.
20284 - added 'reqpass' and 'reqipass' to allow certain headers but not the request
20285 itself.
20286 - factored several strings to reduce binary size by about 2 kB.
20287 - replaced setreuid() and setregid() with more standard setuid() and setgid().
20288 - added 4 status flags to the log line indicating who ended the connection
20289 first, the sessions state, the validity of the cookie, and action taken on
20290 the set-cookie header.
20291
202922002/10/18 : 1.1.17
20293 - add the notion of "backup" servers, which are used only when all other
20294 servers are down.
20295 - make Set-Cookie return "" instead of "(null)" when the server has no
20296 cookie assigned (useful for backup servers).
20297 - "log" now supports an optionnal level name (info, notice, err ...) above
20298 which nothing is sent.
20299 - replaced some strncmp() with memcmp() for better efficiency.
20300 - added "capture cookie" option which logs client and/or server cookies
20301 - cleaned up/down messages and dump servers states upon SIGHUP
20302 - added a redirection feature for errors : "errorloc <errnum> <url>"
20303 - now we won't insist on connecting to a dead server, even with a cookie,
20304 unless option "persist" is specified.
20305 - added HTTP/408 response for client request time-out and HTTP/50[234] for
20306 server reply time-out or errors.
20307
203082002/09/01 : 1.1.16
20309 - implement HTTP health checks when option "httpchk" is specified.
20310
203112002/08/07 : 1.1.15
20312 - replaced setpgid()/setpgrp() with setsid() for better portability, because
20313 setpgrp() doesn't have the same meaning under Solaris, Linux, and OpenBSD.
20314
203152002/07/20 : 1.1.14
20316 - added "postonly" cookie mode
20317
203182002/07/15 : 1.1.13
20319 - tv_diff used inverted parameters which led to negative times !
20320
203212002/07/13 : 1.1.12
20322 - fixed stats monitoring, and optimized some tv_* for most common cases.
20323 - replaced temporary 'newhdr' with 'trash' to reduce stack size
20324 - made HTTP errors more HTML-fiendly.
20325 - renamed strlcpy() to strlcpy2() because of a slightly difference between
20326 their behaviour (return value), to avoid confusion.
20327 - restricted HTTP messages to HTTP proxies only
20328 - added a 502 message when the connection has been refused by the server,
20329 to prevent clients from believing this is a zero-byte HTTP 0.9 reply.
20330 - changed 'Cache-control:' from 'no-cache="set-cookie"' to 'private' when
20331 inserting a cookie, because some caches (apache) don't understand it.
20332 - fixed processing of server headers when client is in SHUTR state
20333
203342002/07/04 :
20335 - automatically close fd's 0,1 and 2 when going daemon ; setpgrp() after
20336 setpgid()
20337
203382002/06/04 : 1.1.11
20339 - fixed multi-cookie handling in client request to allow clean deletion
20340 in insert+indirect mode. Now, only the server cookie is deleted and not
willy tarreau906b2682005-12-17 13:49:52 +010020341 all the header. Should now be compliant to RFC2965.
willy tarreau036e1ce2005-12-17 13:46:33 +010020342 - added a "nocache" option to "cookie" to specify that we explicitly want
20343 to add a "cache-control" header when we add a cookie.
20344 It is also possible to add an "Expires: <old-date>" to keep compatibility
20345 with old/broken caches.
20346
203472002/05/10 : 1.1.10
20348 - if a cookie is used in insert+indirect mode, it's desirable that the
20349 the servers don't see it. It was not possible to remove it correctly
20350 with regexps, so now it's removed automatically.
20351
203522002/04/19 : 1.1.9
20353 - don't use snprintf()'s return value as an end of message since it may
20354 be larger. This caused bus errors and segfaults in internal libc's
20355 getenv() during localtime() in send_log().
20356 - removed dead insecure send_syslog() function and all references to it.
20357 - fixed warnings on Solaris due to buggy implementation of isXXXX().
20358
203592002/04/18 : 1.1.8
20360 - option "dontlognull"
20361 - fixed "double space" bug in config parser
20362 - fixed an uninitialized server field in case of dispatch
20363 with no existing server which could cause a segfault during
20364 logging.
20365 - the pid logged was always the father's, which was wrong for daemons.
20366 - fixed wrong level "LOG_INFO" for message "proxy started".
20367
203682002/04/13 :
20369 - http logging is now complete :
20370 - ip:port, date, proxy, server
20371 - req_time, conn_time, hdr_time, tot_time
20372 - status, size, request
20373 - source address
20374
203752002/04/12 : 1.1.7
20376 - added option forwardfor
20377 - added reqirep, reqidel, reqiallow, reqideny, rspirep, rspidel
20378 - added "log global" in "listen" section.
20379
203802002/04/09 :
20381 - added a new "global" section :
20382 - logs
20383 - debug, quiet, daemon modes
20384 - uid, gid, chroot, nbproc, maxconn
20385
203862002/04/08 : 1.1.6
20387 - regex are now chained and not limited anymore.
20388 - unavailable server now returns HTTP/502.
20389 - increased per-line args limit to 40
20390 - added reqallow/reqdeny to block some request on matches
20391 - added HTTP 400/403 responses
20392
203932002/04/03 : 1.1.5
20394 - connection logging displayed incorrect source address.
20395 - added proxy start/stop and server up/down log events.
20396 - replaced log message short buffers with larger trash.
20397 - enlarged buffer to 8 kB and replace buffer to 4 kB.
20398
203992002/03/25 : 1.1.4
20400 - made rise/fall/interval time configurable
20401
204022002/03/22 : 1.1.3
20403 - fixed a bug : cr_expire and cw_expire were inverted in CL_STSHUT[WR]
20404 which could lead to loops.
20405
204062002/03/21 : 1.1.2
20407 - fixed a bug in buffer management where we could have a loop
20408 between event_read() and process_{cli|srv} if R==BUFSIZE-MAXREWRITE.
20409 => implemented an adjustable buffer limit.
20410 - fixed a bug : expiration of tasks in wait queue timeout is used again,
20411 and running tasks are skipped.
20412 - added some debug lines for accept events.
20413 - send warnings for servers up/down.
20414
204152002/03/12 : 1.1.1
20416 - fixed a bug in total failure handling
20417 - fixed a bug in timestamp comparison within same second (tv_cmp_ms)
20418
204192002/03/10 : 1.1.0
20420 - fixed a few timeout bugs
20421 - rearranged the task scheduler subsystem to improve performance,
20422 add new tasks, and make it easier to later port to librt ;
20423 - allow multiple accept() for one select() wake up ;
20424 - implemented internal load balancing with basic health-check ;
20425 - cookie insertion and header add/replace/delete, with better strings
20426 support.
20427
204282002/03/08
20429 - reworked buffer handling to fix a few rewrite bugs, and
20430 improve overall performance.
20431 - implement the "purge" option to delete server cookies in direct mode.
20432
204332002/03/07
20434 - fixed some error cases where the maxfd was not decreased.
20435
204362002/02/26
20437 - now supports transparent proxying, at least on linux 2.4.
20438
204392002/02/12
20440 - soft stop works again (fixed select timeout computation).
20441 - it seems that TCP proxies sometimes cannot timeout.
20442 - added a "quiet" mode.
20443 - enforce file descriptor limitation on socket() and accept().
20444
204452001/12/30 : release of version 1.0.2 : fixed a bug in header processing
204462001/12/19 : release of version 1.0.1 : no MSG_NOSIGNAL on solaris
204472001/12/16 : release of version 1.0.0.
204482001/12/16 : added syslog capability for each accepted connection.
204492001/11/19 : corrected premature end of files and occasional SIGPIPE.
204502001/10/31 : added health-check type servers (mode health) which replies OK then closes.
204512001/10/30 : added the ability to support standard TCP proxies and HTTP proxies
20452 with or without cookies (use keyword http for this).
204532001/09/01 : added client/server header replacing with regexps.
20454 eg:
20455 cliexp ^(Host:\ [^:]*).* Host:\ \1:80
20456 srvexp ^Server:\ .* Server:\ Apache
204572000/11/29 : first fully working release with complete FSMs and timeouts.
204582000/11/28 : major rewrite
204592000/11/26 : first write